Skip to main content

Ethernet tethering for Linux - NAT a single device through an interface

Project description

tETHer - ethernet tethering

Tether one device to another over an ethernet interface on linux (rather than USB)

Tethering proxies one device through another devices internet connections. A common use case is to connect to a mobile phone over USB and then use its internet connection. tETHer does the same thing but via an ethernet connection such as an rj-45 cable. This also allows forwarding

Unreviewed ai-generated code. But I am using it.

Motivation

I had a camera which only supported wired connection. I did not want to run a long wire to a router and wireless bridges were moderately expensive so I decided to get this working with an old raspberry pi. I don't really like "infrastructure" because I forget how it works. I prefer tools which minimise the amount of infrastructure so I coded this.

Alterantives and prior work

Use a wireless bridge. Hand code the networking yourself using wireless. RaspAP is an image for raspberry pi to set up a wireless bridge it also supports port forwarding.

This is very similar to the idea of setting up an access point, but it has some additional features for port forwarding which are made easier if you are providing access or a single device.

Installation

tETHer requires nmap dnsmasq and Linux. On a linux machine install them: sudo apt install nmap dnsmasq pipx.

You can then install with pipx: pipx install t-eth-er

Usage

Set up dhcp and forwarding on eth0 so that if you plug in a device which uses DHCP it will connect to you and then via you to the rest of the network - including the internet.

eth-tether eth0

If you want to forward ports you can capture all the ports that the tethering machine has

eth-tether eth0 --scan ports

Then on subsequent files you can use the generated ports file

eth-tether eth0 --ports ports

To avoid requiring too many permissions, tETHer uses sudo to run privileged commands. You can allow your use to only run these commands or you can run the entire commadn with sudo. To get a sudoers file alowing these commands run eth-tether eth0 --sudoers

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

t_eth_er-1.3.2.tar.gz (6.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

t_eth_er-1.3.2-py3-none-any.whl (6.9 kB view details)

Uploaded Python 3

File details

Details for the file t_eth_er-1.3.2.tar.gz.

File metadata

  • Download URL: t_eth_er-1.3.2.tar.gz
  • Upload date:
  • Size: 6.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for t_eth_er-1.3.2.tar.gz
Algorithm Hash digest
SHA256 83ae4b786eca1221886ad2dca187876a4fb1320bcddf3a4026aea887d2952bc0
MD5 7cc6e0bf1d3680cd6c515e10f02d326e
BLAKE2b-256 e99d4bb7f5767918c62a120b30a6e85eafdc6b5ba0d18329833dbc0a591644fe

See more details on using hashes here.

File details

Details for the file t_eth_er-1.3.2-py3-none-any.whl.

File metadata

  • Download URL: t_eth_er-1.3.2-py3-none-any.whl
  • Upload date:
  • Size: 6.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for t_eth_er-1.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 0a915060395da8b8f4b3df08c9b9824030e11a9a19676234fbac99116e0e3822
MD5 2f348db54ecab35aab9c483644ebfdf2
BLAKE2b-256 947e4a2c96ea9694e9e8c8feb831426c6ff892a20f0abc3ea7d306b3366ec38d

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page