2019-12-04 08:13:21 +00:00
|
|
|
#!/bin/bash
|
|
|
|
# $1 is the service name, same as the HiddenServiceDir in torrc
|
|
|
|
# $2 is the port the Hidden Service forwards to (to be used in the Tor browser)
|
2019-12-16 18:15:01 +00:00
|
|
|
# $3 is the port to be forwarded with the Hidden Service
|
2019-12-04 08:13:21 +00:00
|
|
|
|
|
|
|
# command info
|
|
|
|
if [ $# -eq 0 ] || [ "$1" = "-h" ] || [ "$1" = "-help" ]; then
|
|
|
|
echo "config script to configure a Tor Hidden Service"
|
2020-01-04 00:02:10 +00:00
|
|
|
echo "internet.hiddenservice.sh [service] [toPort] [fromPort] [optional-toPort2] [optional-fromPort2]"
|
2020-07-12 19:55:27 +02:00
|
|
|
echo "internet.hiddenservice.sh off [service]"
|
2019-12-04 08:13:21 +00:00
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2019-12-04 10:09:14 +00:00
|
|
|
source /mnt/hdd/raspiblitz.conf
|
|
|
|
|
2020-07-12 19:55:27 +02:00
|
|
|
# delete a hidden service
|
|
|
|
if [ "$1" == "off" ]; then
|
|
|
|
service="$2"
|
|
|
|
if [ ${#service} -eq 0 ]; then
|
|
|
|
echo "ERROR: service name is missing"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
sudo sed -i "/# Hidden Service for ${service}/,/^\s*$/{d}" /etc/tor/torrc
|
2020-07-12 20:05:41 +02:00
|
|
|
echo "# OK service is removed - restarting TOR ..."
|
|
|
|
sudo systemctl restart tor
|
|
|
|
sleep 10
|
|
|
|
echo "# Done"
|
2020-07-12 19:55:27 +02:00
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2019-12-04 08:13:21 +00:00
|
|
|
service="$1"
|
|
|
|
if [ ${#service} -eq 0 ]; then
|
|
|
|
echo "ERROR: service name is missing"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
toPort="$2"
|
|
|
|
if [ ${#toPort} -eq 0 ]; then
|
|
|
|
echo "ERROR: the port to forward to is missing"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2019-12-16 18:15:01 +00:00
|
|
|
fromPort="$3"
|
2019-12-04 08:13:21 +00:00
|
|
|
if [ ${#fromPort} -eq 0 ]; then
|
2020-01-05 10:29:04 +00:00
|
|
|
echo "ERROR: the port to forward from is missing"
|
2019-12-04 08:13:21 +00:00
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2020-01-04 00:02:10 +00:00
|
|
|
# not mandatory
|
|
|
|
toPort2="$4"
|
|
|
|
|
|
|
|
# needed if $4 is given
|
|
|
|
fromPort2="$5"
|
|
|
|
if [ ${#toPort2} -gt 0 ]; then
|
|
|
|
if [ ${#fromPort2} -eq 0 ]; then
|
2020-01-05 10:29:04 +00:00
|
|
|
echo "ERROR: the second port to forward from is missing"
|
2020-01-04 00:02:10 +00:00
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2019-12-04 10:09:14 +00:00
|
|
|
if [ "${runBehindTor}" = "on" ]; then
|
2020-01-04 00:02:10 +00:00
|
|
|
#check if the service is already present
|
2019-12-04 10:09:14 +00:00
|
|
|
isHiddenService=$(sudo cat /etc/tor/torrc 2>/dev/null | grep -c $service)
|
|
|
|
if [ ${isHiddenService} -eq 0 ]; then
|
2020-01-04 00:02:10 +00:00
|
|
|
#check if the port is already forwarded
|
2020-04-09 14:20:48 +01:00
|
|
|
alreadyThere=$(sudo cat /etc/tor/torrc 2>/dev/null | grep -c "\b127.0.0.1:$fromPort\b")
|
2020-01-04 00:02:10 +00:00
|
|
|
if [ ${alreadyThere} -gt 0 ]; then
|
2020-01-05 10:29:04 +00:00
|
|
|
echo "The port $fromPort is already forwarded. Check /etc/tor/torrc for the details."
|
2020-01-04 00:02:10 +00:00
|
|
|
exit 1
|
|
|
|
fi
|
2019-12-04 10:09:14 +00:00
|
|
|
echo "
|
2019-12-23 10:00:16 +01:00
|
|
|
# Hidden Service for $service
|
|
|
|
HiddenServiceDir /mnt/hdd/tor/$service
|
|
|
|
HiddenServiceVersion 3
|
|
|
|
HiddenServicePort $toPort 127.0.0.1:$fromPort" | sudo tee -a /etc/tor/torrc
|
|
|
|
|
2020-01-05 10:29:04 +00:00
|
|
|
# check and insert second port pair
|
|
|
|
if [ ${#toPort2} -gt 0 ]; then
|
2020-04-09 14:20:48 +01:00
|
|
|
alreadyThere=$(sudo cat /etc/tor/torrc 2>/dev/null | grep -c "\b127.0.0.1:$fromPort2\b")
|
2020-01-05 10:29:04 +00:00
|
|
|
if [ ${alreadyThere} -gt 0 ]; then
|
|
|
|
echo "The port $fromPort2 is already forwarded. Check the /etc/tor/torrc for the details."
|
|
|
|
else
|
|
|
|
echo "HiddenServicePort $toPort2 127.0.0.1:$fromPort2" | sudo tee -a /etc/tor/torrc
|
|
|
|
fi
|
|
|
|
fi
|
2020-01-04 00:02:10 +00:00
|
|
|
# restart tor
|
2020-01-05 10:29:04 +00:00
|
|
|
echo ""
|
2019-12-04 10:09:14 +00:00
|
|
|
echo "Restarting Tor to activate the Hidden Service..."
|
|
|
|
sudo systemctl restart tor
|
|
|
|
sleep 10
|
|
|
|
else
|
2020-01-05 10:29:04 +00:00
|
|
|
echo "The Hidden Service for $service is already installed."
|
2019-12-04 10:09:14 +00:00
|
|
|
fi
|
2020-01-04 00:02:10 +00:00
|
|
|
# show the Hidden Service address
|
|
|
|
TOR_ADDRESS=$(sudo cat /mnt/hdd/tor/$service/hostname)
|
|
|
|
if [ -z "$TOR_ADDRESS" ]; then
|
|
|
|
echo "Waiting for the Hidden Service"
|
|
|
|
sleep 10
|
|
|
|
TOR_ADDRESS=$(sudo cat /mnt/hdd/tor/$service/hostname)
|
|
|
|
if [ -z "$TOR_ADDRESS" ]; then
|
|
|
|
echo " FAIL - The Hidden Service address could not be found - Tor error?"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
fi
|
2020-01-05 10:29:04 +00:00
|
|
|
echo ""
|
2020-01-04 00:02:10 +00:00
|
|
|
echo "The Tor Hidden Service address for $service is:"
|
|
|
|
echo "$TOR_ADDRESS"
|
|
|
|
echo "use with the port: $toPort"
|
2020-01-05 10:29:04 +00:00
|
|
|
echo ""
|
|
|
|
if [ ${#toPort2} -gt 0 ]; then
|
2020-06-09 21:13:47 +01:00
|
|
|
alreadyThere=$(sudo cat /etc/tor/torrc 2>/dev/null | grep -c "\b127.0.0.1:$fromPort2\b")
|
2020-01-05 10:29:04 +00:00
|
|
|
if [ ${alreadyThere} -eq 0 ]; then
|
|
|
|
echo "or the port: $toPort2"
|
|
|
|
else
|
|
|
|
echo "The port $fromPort2 is forwarded for another Hidden Service. Check the /etc/tor/torrc for the details."
|
|
|
|
fi
|
2020-01-04 00:02:10 +00:00
|
|
|
fi
|
2019-12-04 08:13:21 +00:00
|
|
|
else
|
2019-12-04 10:09:14 +00:00
|
|
|
echo "Tor is not active"
|
2020-01-04 00:02:10 +00:00
|
|
|
exit 1
|
2019-12-16 18:15:01 +00:00
|
|
|
fi
|