A top-like tunnel manager
Project description
tunneltop
A tunnel manager in the familiar top style written with ncurses and asyncio.
Install
pip install tunneltop
what it is
- a simple tunnel manager written in python that uses the standard library only(standard library only in python 3.11)
- it starts and manages the tunnels for you
- lets the user interactively manage the tunnels as well
- will reload the config file if it receives a
SIGHUP
- it is intentionally written as simple and tunnel-agnostic
- may or may not work on windows(let me know if you test it on windows)
toml file
tunneltop expects its config file to be at at $HOME/.tunneltoprc
.
You can see an example config file below:
[color]
header_fg = 4
header_bg = 0
active_fg = 23
active_bg = 0
disabled_fg = 8
disabled_bg = 0
timeout_fg = 63
timeout_bg = 0
unknown_fg = 38
unknown_bg = 0
down_fg = 208
down_bg = 0
box_fg = 22
box_bg = 0
[tunnel.socks5ir]
address = "127.0.0.1"
port = 9997
command = "autossh -M 0 -N -D 9997 -o ServerAliveInterval=180 -o ServerAliveCountMax=3 -o ExitOnForwardFailure=yes -l debian -p 22 100.100.100.101"
test_command = 'curl "%{http_code}" -k -I -4 --socks5 socks5h://127.0.0.1:9997 https://icanhazip.com'
test_command_result = "200"
test_interval = 300
test_timeout = 10
[tunnel.socks5_3]
address = "127.0.0.1"
port = 9995
command = "autossh -M 0 -N -D 0.0.0.0:9995 -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null -o VerifyHostKeyDNS=no -o ServerAliveInterval=180 -o ServerAliveCountMax=3 -o ExitOnForwardFailure=yes -l debian -p 2022 100.100.100.100"
test_command = 'curl "%{http_code}" -k -I -4 --socks5 socks5h://127.0.0.1:9995 https://icanhazip.com'
test_command_result = "200"
test_interval = 300
test_timeout = 10
The tunnel names must be unique.
address
Displays the address at which the tunnel is available at. It is a display-only option.
port
Displays the port at which the tunnel is available at. It is a display-only option.
command
The command used to start the tunnel.
test_command
The command used to test the state of the tunnel.
test_command_result
The expected result of the test command.
test_interval
How often should the test_command
be run.
test_timeout
How long before the test is considered to have timed out.
keybindings
j
and k
move you up and down.
g
and G
move you to the first or last tunnel.
s
toggles a tunnel from enabled to disabled or vice versa.
r
restarts a tunnel.
To quit send a SIGINT
or a SIGTERM
. I'm working on improving this of course.
tunneltop will reload its config file upon receiving a SIGHUP
and apply the changes immediately if there are any.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for tunneltop-0.2.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9511e88039900561c091d95338b93ffa2d3ca5e8ddd263b31639820f1e1f9a89 |
|
MD5 | 0eccd35936c3f0ad2aaee4f53362c0b3 |
|
BLAKE2b-256 | 577861cb58bce50bfbb8bab41b19c8ccfea7fbe20744e5b99c67775df1a06b26 |