Browsing Onion sites using Tinyproxy

1.0 Motivation                                                           line 13
2.0 Bill of materials                                                    line 29
3.0 Tinyproxy configuration and testing                                  line 40

This is a short guide showing how to set up the HTTP proxy Tinyproxy (
https://tinyproxy.github.io ) to access Onion services (
https://support.torproject.org/onionservices/ ) while accessing other sites
directly.


    1.0 Motivation

Tor ( https://www.torproject.org ) itself exposes a SOCKS5 proxy, so if that is
all that is needed, you might as well stop reading this file now. Tinyproxy is a
lightweight HTTP/HTTPS proxy, so this is for those cases where SOCKS is not
available or practical. Onion sites must be accessed through Tor, but browsing
the web in general through Tor circuits is quite slow and wastes electricity if
you do not need Tor's features. Also, you might be in a situation reading from a
computer where running torsocks or a Tor service is not an option, which is
quite common in retrocomputing.

The idea is setting up Tinyproxy to just pass-through traffic for the ordinary
web, while passing traffic directed to the Scary Dark Web to a locally running
Tor service.


    2.0 Bill of materials

I used a Fedora Linux desktop to run Tor and Tinyproxy, but I assume this is all
the same on pretty much any Freenix or UNIX system.

    1. A Freenix box to run Tor and Tinyproxy
    2. A Tor installation
    3. Tinyproxy
    4. A browser which supports a HTTP proxy, I used Lynx


    3.0 Tinyproxy configuration and testing

For the Tor service, default configuration (at least on my system) was perfectly
fine. It fires up a SOCKS server on port 9050 on localhost, which gives the
following "tinyproxy.conf" file:

    # Basic connection parameters, only browsing from localhost in this example
    Port 8888
    Listen 127.0.0.1
    Timeout 600
    Allow 127.0.0.1

    # The quotes are mandatory, I did not know that first
    Upstream socks5 127.0.0.1:9050 ".onion"

    # Some mandatory settings where I used more or less arbitrary values
    MaxClients 10
    StartServers 2
    MinSpareServers 1
    MaxSpareServers 8

Those 9 settings above is it. Those lines are the entire point of this whole
document. Obviously, it is in the line starting with "Upstream" the action
happens, and it means what it locks like. If the request has anything to do with
the "onion" top-level domain, route it through the SOCKS5 proxy running locally
on port 9050. Since that is the only Upstream rule, all other traffic will just
pass through.

As for testing it, this should work:

    1. Make sure Tor is running. If using systemd:

       systemctl start tor

    2. Start Tinyproxy in a shell with the experimental config file:

       tinyproxy -d -c tinyproxy.conf

    3. Try to access the Tor projects own Onion site with Lynx:

       http_proxy=http://127.0.0.1:8888/ lynx http://2gzyxa5ihm7nsggfxnu52rck2vv4rvmdlkiu3zzui5du4xyclen53wid.onion/index.html

    4. Try to access the Tor project's conventional site:

       http_proxy=http://127.0.0.1:8888/ lynx http://www.torproject.org

In step 3, you should get the Tor project's home page, as you should in step 4.
The difference is in the tinyproxy log output to standard out. In step 3, it
should say something like "Found upstream proxy socks5 127.0.0.1:9050 for
2gzyxa5ihm7nsggfxnu52rck2vv4rvmdlkiu3zzui5du4xyclen53wid.onion". In step 4, it
should report on no upstream, "No upstream proxy for www.torproject.org". (It
then connects to the site, which redirects to HTTPS. Then nothing more is
logged, as our proxy is left out of the rest of the equation as the example has
no "https_proxy" setting.)

20231004T171926Z, 8C17C712