Things we tried:
- DNS tunnels
- Listening outside on externalhost:1111
- PingTunnel FTW!!!!
Enter PingTunnel (http://www.cs.uit.no/~daniels/PingTunnel/)
I downloaded and installed PingTunnel on my laptop and on my linode.
On the linode:
ptunnel -x [password]
On my laptop:
ptunnel -x
This tunnels localhost:8001 to my linode:22
I finish by creating a socks proxy using ssh dynamic port forwarding:
ssh [user]
Once I log into my server I configure firefox to use localhost:1080 as a socks proxy.
data:image/s3,"s3://crabby-images/9f271/9f2710a19789e52f326cc1044179e7ad8d9822d3" alt=""
Huzzah!
PS. If you don't think it will work, I'm posting this through the tunnel.
Update:
Connections can be problematic. You must allow all ICMP on input. The following iptables rules work for me:
iptables -F
iptables -P INPUT ACCEPT
iptables -A INPUT -i lo -j ACCEPT
iptables -A INPUT -p icmp -j ACCEPT
iptables -A INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT
iptables -A INPUT -j DROP
The icmp rule is the one I changed that got it working.