Do you trust the wifi you’re using at Starbucks? Maybe that hardline at the hotel is sketchy. You never know who is on the network with you and what their skills and motivations might be. Why share anything with them if you don’t have to? What the sections below cover is setting up a secure proxy server that you have control of to allow you to surf the internet on even the most questionable connections without having to worry about eavesdroppers and MITM attacks. We’ll set up a linux server, SSH with certificate authentication, and then start browsing through an encrypted tunnel. Your SSHD options may dictate another setting but typically this tunnel will be secured with AES-256 which is a secure and fast cypher. AES-256 is what’s used with other encrypted storage or communications like BitLocker, IronKey devices, and SSL.
This does assume that you have some technical background already but I tried to make things pretty easy. If there are any questions please add them in the comments and I can try to answer there or add them into the post.
The first section below covers the setup and initial configuration of the proxy server. In this example we’re using a linux server and the Squid proxy. Linux natively supports SSH for the encrypted tunnel and Squid is an excellent open-source proxy solution that also provides web caching. You can set up a similar solution using SSH via a Windows server but it requires a more involved setup process as SSH isn’t natively a part of the Windows OS.
The second section describes the client setup and use from either linux or Windows. The linux instructions should work for Mac users as well. Once the proxy is up and online using it from your client system is easy and straightforward.
The third section is optional as it’s additional configuration that doesn’t have a major technical effect as we’ve already encrypted everything but what it does to is prevent the sites your visiting from knowing you’re even using a proxy. The possible implications of that would be altered behavior of the site due to your IP being identified as from another nation or similar. For example, some sites limit your access based on your location because of copyright reasons. While this is not meant to be an assist to violating copyrights that ability is there. The goal for me in this was being able to get US internet while abroad. I can’t watch Netflix movies from Europe on my US Netflix account but it works well when I pass my traffic via my transparent US proxy server.
In the last section I’ll address an additional configuration option for Firefox that will also prevent information leakage via your DNS requests. What the setting does is tell Firefox to forward DNS requests to the proxy server to answer rather than querying the DNS server your client system is pointed to. This means that if an attacker is listening on the wire they are unable to see what sites you’re browsing based on your DNS queries.
If you don’t have a handy dandy home linux server like I do then you’ll want to get one set up or use a cloud provider. Amazon Web Services provides an intro tier that gives you enough free utilization to run a small linux server for a year and a fair amount of bandwidth along with several other services. You can sign up for this at https://aws.amazon.com/free Just keep an eye on your bandwidth usage and you can use it 100% free. It’s cheap after you get out of the free tier but keep in mind it does cost money if you use more than the allotted free amount. Beyond that there are other options (all paid) by using Linode, Rackspace, or others. There’s no option for a linux server with Azure (yet?) so don’t try there unless you want to try to set this up on Windows.
Note: These instructions assume that they are run as an administrative user such as root. If you will be using a non-administrative user with sudo rights just keep in mind most of these commands require sudo first. Also, note that the instructions below are based on completing this on Ubuntu, Arch, or Fedora. The packages specific to your system may vary slightly if you’re using another distribution. You can check the online references or package lists to verify which package is right for you.
Part 1: Server Setup (Linux)
1. Make sure your server’s firewall is secure. You’re going to be installing a proxy server and you don’t want the world trying to use it. How you choose to do this is up to you but IPTables is a solid option.  Make sure, however, that you are careful with the rules or your own connections will be blocked as well.  If there’s interest I’ll add an IPTables how-to onto here as well.  If you are using an AWS VM the default setting is very secure as it doesn’t allow anything through you haven’t already specified.  If you haven’t done so already make sure the server is up to date as well.  Example: apt-get upgrade or yum update or pacman -Syu
2. Install SSH if not already present. Example: apt-get install openssh-server or yum install openssh-server or pacman -S openssh
3. Set up SSHD. You can find the config usually in /etc/ssh/sshd_config.  Example:  nano /etc/ssh/sshd_config
— a. Set port to something high and/or unusual like 45454
— b. Disable password authentication.
— c. Disable remote root login
— d. Enable logging to SYSLOG for all AUTH if not already enabled
— e. Ensure RSA logins are enabled and using .ssh/authorized_keys or another to your preference.  Here I will assume .ssh/authorized_keys
4. Create a new user on the system. I recommend using -m to create the home directory in advance. If you’d like to be able to use this account for administrative functions you can also use -G to specify the group the user should belong to. For Ubuntu you would use the second example provided. Example: useradd -m newuser Example 2: useradd -Gm newuser,wheel
5. Use ssh-keygen to generate an ssh key for this user. I recommend using -b 4096 -t rsa to use a 4096bit RSA certificate. Example: ssh-keygen -b 4096 -t rsa
6. Copy the public key into the users authorized key file. Create the file and folder if needed. Example: cat newuserkey.pub > /home/newuser/.ssh/authorized_keys
7. Use chmod to change the permissions of the file to 0600 so it is recognized by SSHD. Example: chmod 0600 /home/newuser/.ssh/authorized_keys
8. Copy the private key to the system you’ll be connecting from. Make sure you name it something obvious so you’ll be able to find it again. Example: newuserkey.pem
9. Start/restart SSHD. If SSHD is running use /etc/rc.d/sshd restart or /etc/init.d/sshd start or service sshd restart. Which works will depend on your distro. If not running use start instead of restart.
10. From the other system use PuTTy or SSH to test the connection and make sure it works and the key works. If you’re not familiar with this process use the instructions in Part 2. Example: ssh -i newuser.pem newuser@server -p 45454
11. Once SSHD is verified go back to the server and install Squid. Example: yum install squid or apt-get install squid or pacman -S squid
12. The Squid default config will be fine for our purposes but you can harden it by editing /etc/squid/squid.conf or wherever you installed to.
13. Start Squid. Example: /etc/rc.d/squid start or /etc/init.d/squid start or service squid start
14. Use chkconfig to verify the services for Squid and SSH start automatically.  Run  chkconfig   to see the current setting.
•  a. If one of both of the services aren’t set to on at any run level you can fix that also using chkconfig.
•  b. To start Squid automatically use the first example.  The second is for SSHD.  Example:  chkconfig –level 2345 squid on Example 2:  chkconfig –level 2345 sshd on
16. Validate that the firewall between this system and the internet allows incoming connections on the port you chose.
Part 2: Using your new RSA encrypted secure proxy
Part 2a: Linux Client system
1. From a remote site verify you have internet connectivity.
2. Verify that SSH back to your server is working. Example: ssh -i newuserkey.pem newuser@server -p 45454
3. Disconnect and reconnect with tunneling enabled targeting the Squid port. Example: ssh -i newuserkey.pem -L 8080:localhost:3128 newuser@server -p 45454
4. Open your browser and change the proxy setting to 127.0.0.1:8080. In Firefox this is in Options -> Advanced -> Network -> Settings
5. Attempt to open a web site. You should be able to browse like normal.
6. Congrats! You are now browsing inside an encrypted tunnel!
Part 2b: Windows Client Cygwin Method
1. From a remote site verify you have internet connectivity.
2. Install Cygwin from http://www.cygwin.com/install.html
3. Open the Cygwin terminal and verify that SSH back to your server is working. Example: ssh -i newuserkey.pem newuser@server -p 45454
4. If that succeeds disconnect (just type exit) and reconnect with tunneling enabled targeting the Squid port. Example: ssh -i newuserkey.pem -L 8080:localhost:3128newuser@server -p 45454
5. Open your browser and change the proxy setting to 127.0.0.1:8080 for all protocols. In Firefox this is in Options -> Advanced -> Network -> Settings
6. Attempt to open a web site. You should be able to browse like normal.
7. Congrats! You are now browsing inside an encrypted tunnel!
Part 2c: Windows Client PuTTy Method
1. From a remote site verify you have internet connectivity.
2. Install Putty using the Windows installer from http://www.chiark.greenend.org.uk/~sgtatham/putty/download.html
3. Open up PuTTyGen and import your newuserkey.pem certificate file.
4. Save the new PuTTy formatted key by clicking Save Private Key. You can ignore the prompt about not passwording the file. It will now have a PPK extension and look like newuserkey.ppk
5. Open the main PuTTy program and type or paste in the server’s DNS name or IP and correct the port number to the one you set SSHD to.
6. In the left-side menu select SSH and then Auth to get to the SSH Authorization section. Click browse next to Private Key File For Authentication and select your newuserkey.ppk file.
7. At the bottom of the window type in a name for the config and click Save and then Connect to test the connection.
8. If that succeeds disconnect (just type exit) and reopen PuTTy.
9. Once PuTTy is open select your saved config and click on Load.
10. Now that your config is loaded use the left-side menu to select SSH and then tunnels
11. Type in 8080 in the source port and for destination use 127.0.0.1:3128 and click Add.
12. Click on Session at the top of the menu and click Save to save your updated config.
13. Click on connect to start a new SSH connection to the server.
14. Open your browser and change the proxy setting to 127.0.0.1:8080 for all protocols. In Firefox this is in Options -> Advanced -> Network -> Settings
15. Attempt to open a web site. You should be able to browse like normal.
16. Congrats! You are now browsing inside an encrypted tunnel!
Part 3: Hide the proxy flags (optional)
1. Open your Squid config file for editing (Example: nano /etc/squid/squid.conf) and add the following lines to the bottom:
Squid 2.x:
via off
follow_x_forwarded_for deny all
forwarded_for delete
request_header_access From deny all
request_header_access Server deny all
request_header_access WWW-Authenticate deny all
request_header_access Link deny all
Squid 3.x:
via off
forwarded_for delete
request_header_access X-Forwarded-For deny all
request_header_access From deny all
request_header_access Server deny all
request_header_access WWW-Authenticate deny all
request_header_access Link deny all
Part 4:  Extra Firefox Settings (all clients)
1. Open up Firefox and in the URL bar type in about:config
2. Find the setting network.proxy.socks_remote_dns and change the value to true