|
|
@ -45,19 +45,52 @@ echo "*** Updating System ***" |
|
|
|
sudo apt-get update |
|
|
|
echo "" |
|
|
|
|
|
|
|
echo "*** Install Tor & Config ***" |
|
|
|
echo "*** Install Tor ***" |
|
|
|
sudo apt install tor tor-arm -y |
|
|
|
echo "uncommenting #RunAsDaemon 1" |
|
|
|
sudo sed -i "s/^#RunAsDaemon 1/RunAsDaemon 1/g" $torrc |
|
|
|
echo "adding PortForward 1 & ControlPort 9051 after RunAsDaemon 1" |
|
|
|
sudo sed -i '\|RunAsDaemon 1| {N;s|\n$|\nPortForwarding 1\nControlPort 9051\n|}' $torrc |
|
|
|
echo "uncommenting #CookieAuthentication 1" |
|
|
|
sudo sed -i "s/^#CookieAuthentication 1/CookieAuthentication 1/g" $torrc |
|
|
|
echo "adding CookieAuthFileGroupReadable 1 after CookieAuthentication 1" |
|
|
|
sudo sed -i '\|CookieAuthentication 1| {N;s|\n$|\nCookieAuthFileGroupReadable 1\n|}' $torrc |
|
|
|
echo "*** enabling logs of tor to /var/log/tor/notices.log ***" |
|
|
|
sudo sed -i "s/^#Log notice file/Log notice file/g" $torrc |
|
|
|
echo "OK - configured tor" |
|
|
|
|
|
|
|
echo "" |
|
|
|
echo "*** Tor Config ***" |
|
|
|
sudo mkdir /mnt/hdd/tor |
|
|
|
sudo mkdir /mnt/hdd/tor/sys |
|
|
|
sudo mkdir /mnt/hdd/tor/web80 |
|
|
|
sudo mkdir /mnt/hdd/tor/lnd9735 |
|
|
|
sudo chmod -R 700 /mnt/hdd/tor |
|
|
|
sudo chown -R debian-tor:debian-tor /mnt/hdd/tor |
|
|
|
cat > ./torrc <<EOF |
|
|
|
### See 'man tor', or https://www.torproject.org/docs/tor-manual.html |
|
|
|
|
|
|
|
DataDirectory /mnt/hdd/tor/sys |
|
|
|
PidFile /mnt/hdd/tor/sys/tor.pid |
|
|
|
|
|
|
|
SafeLogging 0 |
|
|
|
Log notice stdout |
|
|
|
Log notice file /mnt/hdd/tor/notice.log |
|
|
|
Log info file /mnt/hdd/tor/info.log |
|
|
|
|
|
|
|
RunAsDaemon 1 |
|
|
|
PortForwarding 1 |
|
|
|
ControlPort 905 |
|
|
|
SocksPort 9050 |
|
|
|
|
|
|
|
CookieAuthFile /mnt/hdd/tor/sys/control_auth_cookie |
|
|
|
CookieAuthentication 1 |
|
|
|
CookieAuthFileGroupReadable 1 |
|
|
|
|
|
|
|
# Hidden Service v2 for WEB ADMIN INTERFACE |
|
|
|
HiddenServiceDir /mnt/hdd/tor/web80/ |
|
|
|
HiddenServicePort 80 127.0.0.1:80 |
|
|
|
|
|
|
|
# Hidden Service v3 for LND incomming connections |
|
|
|
# https://trac.torproject.org/projects/tor/wiki/doc/NextGenOnions#Howtosetupyourownprop224service |
|
|
|
HiddenServiceDir /mnt/hdd/tor/lnd9735 |
|
|
|
HiddenServiceVersion 3 |
|
|
|
HiddenServicePort 9735 127.0.0.1:9735 |
|
|
|
|
|
|
|
# NOTE: bitcoind get tor service automatically - see /mnt/hdd/bitcoin for onion key |
|
|
|
EOF |
|
|
|
sudo rm $torrc |
|
|
|
sudo mv ./torrc $torrc |
|
|
|
sudo chmod 644 $torrc |
|
|
|
echo "" |
|
|
|
|
|
|
|
# NYX - Tor monitor tool |
|
|
@ -79,22 +112,12 @@ sudo cp /home/bitcoin/.${network}/${network}.conf /home/admin/.${network}/${netw |
|
|
|
sudo chown admin:admin /home/admin/.${network}/${network}.conf |
|
|
|
echo "" |
|
|
|
|
|
|
|
#echo "*** Changing LND Config ***" |
|
|
|
#echo "tor.active" | sudo tee --append /home/bitcoin/.lnd/lnd.conf |
|
|
|
#echo "tor.streamisolation" | sudo tee --append /home/bitcoin/.lnd/lnd.conf |
|
|
|
#echo "tor.v2" | sudo tee --append /home/bitcoin/.lnd/lnd.conf |
|
|
|
#echo "tor.privatekeypath=/home/bitcoin/.bitcoin/onion_private_key" | sudo tee --append /home/bitcoin/.lnd/lnd.conf |
|
|
|
#sudo cp /home/bitcoin/.lnd/lnd.conf /home/admin/.lnd/lnd.conf |
|
|
|
#sudo chown admin:admin /home/admin/.lnd/lnd.conf |
|
|
|
#echo "OK" |
|
|
|
#echo "" |
|
|
|
|
|
|
|
echo "*** Activating TOR system service ***" |
|
|
|
sudo systemctl restart tor@default |
|
|
|
echo "" |
|
|
|
|
|
|
|
echo "*** Setting Permissions ***" |
|
|
|
# so that Bitcoind can create Tor hidden service |
|
|
|
# so that chain network can create Tor hidden service |
|
|
|
echo "setting bitcoind permissions" |
|
|
|
sudo usermod -a -G debian-tor bitcoin |
|
|
|
# so that you can run `arm` as user |
|
|
@ -123,25 +146,27 @@ sudo systemctl restart ${network}d |
|
|
|
sleep 8 |
|
|
|
onionAddress="" |
|
|
|
while [ ${#onionAddress} -eq 0 ] |
|
|
|
do |
|
|
|
echo "--- Checking ---" |
|
|
|
date +%s |
|
|
|
sudo cat /mnt/hdd/${network}/debug.log | grep "tor" | tail -n 10 |
|
|
|
onionAddress=$(${network}-cli getnetworkinfo | grep '"address"' | cut -d '"' -f4) |
|
|
|
echo "If this takes too long --> CTRL+c, reboot and check manually" |
|
|
|
sleep 5 |
|
|
|
do |
|
|
|
done |
|
|
|
echo "" |
|
|
|
|
|
|
|
|
|
|
|
echo "*** Setting your Onion Address ***" |
|
|
|
onionPort=$(${network}-cli getnetworkinfo | grep '"port"' | tr -dc '0-9') |
|
|
|
echo "Your Onion Address is: ${onionAddress}:${onionPort}" |
|
|
|
echo "TODO: Make LND reachable over TOR when compiled for ARM with TOR support" |
|
|
|
echo "Your Chain Network Onion Address is: ${onionAddress}:${onionPort}" |
|
|
|
onionLND=$(sudo cat /mnt/hdd/tor/lnd9735/hostname) |
|
|
|
echo "Your Lightning Tor Onion Address is: ${onionLND}:9735" |
|
|
|
echo "" |
|
|
|
|
|
|
|
# ACTIVATE LND OVER TOR LATER ... see DEV NOTES AT END OF FILE |
|
|
|
sudo systemctl disable lnd |
|
|
|
echo "Writing Public Onion Address to /run/publicip" |
|
|
|
echo "PUBLICIP=${onionAddress}" | sudo tee /run/publicip |
|
|
|
printf "PUBLICIP=${onionLND}\n" > /run/publicip; |
|
|
|
sed -i "5s/.*/Wants=${network}d.service/" ./assets/lnd.tor.service |
|
|
|
sed -i "6s/.*/After=${network}d.service/" ./assets/lnd.tor.service |
|
|
|
sudo cp /home/admin/assets/lnd.tor.service /etc/systemd/system/lnd.service |
|
|
@ -149,7 +174,6 @@ sudo chmod +x /etc/systemd/system/lnd.service |
|
|
|
sudo systemctl enable lnd |
|
|
|
echo "OK" |
|
|
|
|
|
|
|
|
|
|
|
echo "*** Finshing Setup / REBOOT ***" |
|
|
|
echo "OK - all should be set" |
|
|
|
echo "" |
|
|
@ -157,41 +181,4 @@ echo "PRESS ENTER ... to REBOOT" |
|
|
|
read key |
|
|
|
|
|
|
|
sudo shutdown -r now |
|
|
|
exit 0 |
|
|
|
|
|
|
|
DEV NOTES ---> maybe use this /etc/tor/torrc to have all toor config on HDD |
|
|
|
--> needs /mnt/hdd/tor & with dirs: sys, lnd9735, web80 |
|
|
|
--> all with chown debian-tor:debian-tor & chmod 700 |
|
|
|
--> update getpublicip script to use if available: cat /mnt/hdd/tor/lnd9735/hostname |
|
|
|
--> Above activate LND tor service when LND is compiled for ARM with TOR service |
|
|
|
|
|
|
|
### See 'man tor', or https://www.torproject.org/docs/tor-manual.html |
|
|
|
|
|
|
|
DataDirectory /mnt/hdd/tor/sys |
|
|
|
PidFile /mnt/hdd/tor/sys/tor.pid |
|
|
|
|
|
|
|
SafeLogging 0 |
|
|
|
Log notice stdout |
|
|
|
Log notice file /mnt/hdd/tor/notice.log |
|
|
|
Log info file /mnt/hdd/tor/info.log |
|
|
|
|
|
|
|
RunAsDaemon 1 |
|
|
|
PortForwarding 1 |
|
|
|
ControlPort 905 |
|
|
|
SocksPort 9050 |
|
|
|
|
|
|
|
CookieAuthFile /mnt/hdd/tor/sys/control_auth_cookie |
|
|
|
CookieAuthentication 1 |
|
|
|
CookieAuthFileGroupReadable 1 |
|
|
|
|
|
|
|
# Hidden Service v2 for WEB ADMIN INTERFACE |
|
|
|
HiddenServiceDir /mnt/hdd/tor/web80/ |
|
|
|
HiddenServicePort 80 127.0.0.1:80 |
|
|
|
|
|
|
|
# Hidden Service v3 for LND incomming connections |
|
|
|
# https://trac.torproject.org/projects/tor/wiki/doc/NextGenOnions#Howtosetupyourownprop224service |
|
|
|
HiddenServiceDir /mnt/hdd/tor/lnd9735 |
|
|
|
HiddenServiceVersion 3 |
|
|
|
HiddenServicePort 9735 127.0.0.1:9735 |
|
|
|
|
|
|
|
# NOTE: bitcoind get tor service automatically - see /mnt/hdd/bitcoin for onion key |
|
|
|
exit 0 |