I’m working for a “very concerned about security” firm, that makes mandatory using VPN for accessing their network, and internal services:
- Online training, etc
As it should, we provided services for a client, also very concerned about security, thus not allowing internet access despite of using two squid proxies with a network appliance filtering protocols, scripts, viruses and malware. They only allow FTP, HTTP and HTTPS.
What to do when you need to access your business services from within the client network?
- an intermediate computer outside both networks (at home, for example…)
- a machine which you can reach by SSH on your business
- a squid server
- SSH Proxy Command by Shun-ichi GOTO
First of all, we need to be able to exit from our client network, and the only way is to use HTTP, HTTPS or FTP… and if we use HTTP packet filtering, would block access, so we only have the SSL choice, as it is cyphered, and doesn’t tolerate “Man-in-the-middle” attacks, and allows us to get internet traffic trough it.
SSH Proxy command¶
SSH Proxy command, is a excellent piece of code, distributed in C in only one file that we will get compiled with
gcc command.c -o connect
With “connect” we will get a connection, for example SSH trough squid. The way to configure it is just editing
.ssh/config file and make it look kind of sort like this:
1 2 3
Now, when we execute
ssh home.com 22 a SSH connection will be made using the squid proxy.
First problem arises, finding that we have a very smart client, and blocks every connection getting trough squid ending in privileged-ports despite of ftp(21),http(80) or https(443)…
As we have full-control of our computer at home, we can make SSH listen to 22 and 2222 adding a line
Listen 2222 in
Well, after this step, we have exterior connectivity, and we can make use of a good utility that SSH provides us: “tunnels” that will pass inside the SSH connection, so let’s use one text editor and begin
.ssh/config to add something like:
1 2 3 4 5 6 7
In this way, after establishing connection (trough the proxy) we will also establish three tunnels that will link 10993, 1025 and 2225 ports with 10993, 1025 and 2225 from our house’s computer.
This step could have been avoided connecting directly to our business computer (but as they are also very concerned about security (filtering, one time passwords (s/key), etc), they aren’t willing to change is security policies listening on extra port)…
We will need to repeat this configuration at home, this time, without using SSH Proxy Command, as we have full internet access from home.
.ssh/config from our house’s machine, and we will add the following configuration:
1 2 3 4 5 6
Now, if we connect using SSH from home, we will redirect another set of ports…
1 2 3 4 5
1 2 3 4 5 6 7 8
Now, we can run at our command line
lanzar and automatically all tunnels will be created for accessing IMAPS, SMTP and our business internal Proxy all by just using 10993, 1025 & 2225 of our local machine (all within a only-web internet access network ;) )
Special thanks to a colleague, JMP for original script for using SSH tunnels that I adapted for this manual.