/install sshtunnel
SSH Tunnel - Remote SSH Access via SSH-over-TLS
When to Use
Use this skill when:
- You need to access a remote machine via SSH that is behind NAT, firewall, or a private network
- You want to expose a local SSH server so a colleague or client can connect remotely
- You are running SSH in a container or VM that has no public IP and need to make it reachable
- You want to provide temporary SSH access for pair programming, debugging, or server maintenance
- You need to connect to a development machine from another location without VPN or port forwarding
- Multiple users each need their own SSH endpoint on the same server port
Do NOT use this skill when:
- The SSH server already has a public IP and is directly reachable
- You only need to transfer files (use sendfile instead)
- You want to expose an HTTP service (use aitun-tunnel instead)
Instructions
Step 1: Install aitun
pip install aitun
Or verify it is already installed:
which aitun || pip show aitun
Step 2: Ensure SSH server is running locally
Verify the local SSH daemon is running and accessible:
# Check if sshd is running
ps aux | grep sshd
# Or check if port 22 is listening
ss -tlnp | grep :22
# Test local SSH connection
ssh localhost echo "SSH OK"
If sshd is not running, install and start it:
# Ubuntu/Debian
sudo apt install openssh-server -y
sudo systemctl start sshd
# CentOS/RHEL
sudo yum install openssh-server -y
sudo systemctl start sshd
# macOS (usually pre-installed)
sudo systemsetup -setremotelogin on
Step 3: Create a TCP tunnel for SSH
SSH uses TCP port 22. Use aitun's --tcp-ports flag to forward this port. TCP forwarding requires an auth token (register at https://aitun.cc):
aitun -p 22 --tcp-ports 22 -k YOUR_TOKEN &
AITUN_PID=$!
sleep 3
The output will show:
[TCP] ssh -> localhost:22 (subdomain: yourname.t.aitun.cc:22)
Step 4: Configure SSH ProxyCommand
On the remote client machine (the one connecting TO your SSH server), add this to ~/.ssh/config:
Host *.t.aitun.cc
ProxyCommand aitun ssh-proxy %h %p
This tells SSH to route connections through aitun ssh-proxy, which wraps SSH in TLS with the correct SNI for subdomain routing.
Step 5: Connect remotely
From any machine with aitun installed:
# Direct SSH — just like a normal server!
ssh [email protected]
# With SSH key
ssh -i ~/.ssh/id_rsa [email protected]
# With verbose output for debugging
ssh -v [email protected]
Step 6: Clean up
When done, stop the tunnel:
kill $AITUN_PID 2>/dev/null
How SSH-over-TLS Works
aitun v4.7.0 uses SSH-over-TLS for perfect multi-tenant SSH on shared ports:
ssh [email protected]
↓
ProxyCommand: aitun ssh-proxy wraps SSH in TLS (SNI=acer.t.aitun.cc)
↓
Server terminates TLS, sees SNI → routes to "acer" tunnel
↓
Decrypted SSH stream → tunnel client → localhost:22
Why TLS? SSH is a plaintext protocol that doesn't send hostname information. Without TLS, there's no way to tell which subdomain an SSH connection is targeting. By wrapping SSH in TLS, we get SNI (Server Name Indication) which tells the server exactly which subdomain to route to.
Result: Every subdomain can have its own SSH on port 22 — no conflicts, no ambiguity, no --tcp-default needed.
Advanced Usage
Forward Multiple Ports (SSH + MySQL)
aitun -p 22 --tcp-ports 22,3306 -k YOUR_TOKEN &
AITUN_PID=$!
sleep 3
SSH into a Container
# If SSH is running in a Docker container on a non-standard port
aitun -p 2222 --tcp-ports 2222 -k YOUR_TOKEN &
# Then connect (add port to ssh config):
ssh -p 2222 [email protected]
Use with SSH Config (Recommended)
Add to ~/.ssh/config on the remote client:
Host *.t.aitun.cc
ProxyCommand aitun ssh-proxy %h %p
Host my-remote-dev
HostName yourname.t.aitun.cc
User username
IdentityFile ~/.ssh/id_rsa
Then simply:
ssh my-remote-dev
One-off SSH without Config
If you don't want to modify ssh config:
ssh -o "ProxyCommand=aitun ssh-proxy %h %p" [email protected]
CLI Reference
The aitun command (installed via pip install aitun) accepts these flags:
| Flag | Description |
|---|---|
-p PORT |
Local service port (default: 8080) |
-k TOKEN |
Auth token for registered subdomain (required for TCP forwarding) |
--host HOST |
Local service address (default: localhost) |
--tcp-ports PORTS |
TCP forwarding ports, comma-separated (e.g., 22,3306; requires -k) |
--p2p |
Enable P2P direct connection (default: enabled) |
--no-p2p |
Disable P2P, force server relay mode |
--daemon |
Run as background daemon |
--stop |
Stop running daemon |
Subcommand:
| Command | Description |
|---|---|
aitun ssh-proxy \x3Chost> [port] |
SSH ProxyCommand — wraps SSH in TLS for SNI routing |
Notes
- TCP forwarding (required for SSH) requires a registered account and
-ktoken — free tunnels do not support TCP - Register at https://aitun.cc to get an auth token
- All traffic is encrypted end-to-end: SSH inside TLS inside the aitun tunnel
- ProxyCommand is required — plaintext SSH is not supported. Add
ProxyCommand aitun ssh-proxy %h %pto your~/.ssh/config - If the requested port (e.g., 22) is occupied on the server, a port from the 7000-7999 range will be automatically assigned
- P2P mode reduces latency for SSH sessions; use
--no-p2ponly if P2P connection fails - For security, ensure your SSH server uses key-based authentication (disable password auth if possible)
- Consider using fail2ban or similar tools to protect against brute-force attacks on your SSH server
- The tunnel stays active as long as the aitun process runs; use
--daemonfor persistent background operation - Subdomains remain active for 30 days of inactivity; use heartbeat to renew
- Make sure OpenClaw is installed (local or Docker)
- Run the install command in chat:
/install sshtunnel - After installation, invoke the skill by name or use
/sshtunnel - Provide required inputs per the skill's parameter spec and get structured output
What is Sshtunnel?
Expose local SSH servers to the public internet via aitun TCP tunnel with SSH-over-TLS routing. Each subdomain gets its own SSH endpoint on port 22 with perf... It is an AI Agent Skill for Claude Code / OpenClaw, with 54 downloads so far.
How do I install Sshtunnel?
Run "/install sshtunnel" in the OpenClaw or Claude Code chat to install it in one step — no extra setup required.
Is Sshtunnel free?
Yes, Sshtunnel is completely free, licensed under MIT-0. You can download, install and use it at no cost.
Which platforms does Sshtunnel support?
Sshtunnel is cross-platform and runs anywhere OpenClaw / Claude Code is available (cross-platform).
Who created Sshtunnel?
It is built and maintained by SamAI.cc (@ctz168); the current version is v4.7.0.