mirror of
https://github.com/nahuhh/basicswap-bash.git
synced 2024-12-22 19:49:21 +00:00
98 lines
2.9 KiB
Bash
Executable file
98 lines
2.9 KiB
Bash
Executable file
#!/bin/bash
|
|
|
|
# Colors
|
|
red="printf \e[31;1m"
|
|
green="printf \e[32;1m"
|
|
nocolor="printf \e[0m"
|
|
|
|
# Detect Operating system
|
|
INSTALL=""
|
|
UPDATE=""
|
|
INIT_TOR=""
|
|
SYSTEMD_TOR="sudo systemctl restart tor"
|
|
|
|
check_tails() {
|
|
if [[ $USER == amnesia ]]; then
|
|
$green"\n\nDetected Tails";$nocolor
|
|
TAILS=1
|
|
else
|
|
$green"\n\nDetected Debian";$nocolor
|
|
fi
|
|
}
|
|
|
|
detect_os_arch() {
|
|
if [[ $(uname -s) = "Darwin" ]]; then
|
|
# MacOS
|
|
export MACOS=1
|
|
if type -p brew > /dev/null; then
|
|
$green"Homebrew is installed\n";$nc
|
|
INSTALL="brew install"
|
|
else
|
|
$green"Installing Homebrew\n";$nc
|
|
INSTALL="curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh | /bin/bash && brew install"
|
|
fi
|
|
INIT_TOR="pkill tor && tor"
|
|
$green"\n\nDetected MacOS";$nocolor
|
|
elif type -p apt > /dev/null; then
|
|
check_tails
|
|
# Debian / Ubuntu / Mint
|
|
INSTALL="sudo apt install"
|
|
UPDATE="sudo apt update"
|
|
INIT_TOR=$SYSTEMD_TOR
|
|
elif type -p dnf > /dev/null; then
|
|
# Fedora
|
|
INSTALL="sudo dnf install"
|
|
UPDATE="sudo dnf check-update"
|
|
INIT_TOR=$SYSTEMD_TOR
|
|
$green"\n\nDetected Fedora";$nocolor
|
|
elif type -p pacman > /dev/null; then
|
|
# Arch Linux
|
|
INSTALL="sudo pacman -S"
|
|
UPDATE="sudo pacman -Syu"
|
|
INIT_TOR=$SYSTEMD_TOR
|
|
$green"\n\nDetected Arch Linux";$nocolor
|
|
else
|
|
$red"\nFailed to detect OS. Unsupported or unknown distribution.\nInstall Failed.\n";$nocolor
|
|
exit
|
|
fi
|
|
}
|
|
|
|
detect_os_arch
|
|
|
|
# Check for Tor installation
|
|
if type -p tor > /dev/null; then
|
|
printf "\nTor is already installed :)\n"
|
|
else
|
|
# Install and configure tor
|
|
echo "Installing Tor..."
|
|
$UPDATE
|
|
$INSTALL tor
|
|
fi
|
|
|
|
# Create HashedControlPassword
|
|
torcontrolpass=$(cat /dev/urandom | tr -dc 'a-zA-Z0-9' | fold -w 24 | head -n 1)
|
|
# Edit /etc/tor/torrc
|
|
torhashedpass=$(tor --hash-password $torcontrolpass)
|
|
enabledcontrol=$(echo "ControlPort 9051")
|
|
skipcontrol=$(sudo grep -x "$enabledcontrol" /etc/tor/torrc)
|
|
echo "Check torrc for enabled ControlPort"
|
|
if [[ $skipcontrol ]]; then
|
|
# Use Existing enabled ControlPort and append HashedControlPassword
|
|
printf "# Added by basicswap-bash\nHashedControlPassword $torhashedpass\n" | sudo tee -a /etc/tor/torrc
|
|
else
|
|
printf "# Added by basicswap-bash\n$enabledcontrol\nHashedControlPassword $torhashedpass\n" | sudo tee -a /etc/tor/torrc
|
|
fi
|
|
|
|
# Restart tor to apply
|
|
$INIT_TOR
|
|
echo "Waiting for Tor... 5sec" && sleep 5
|
|
|
|
# lol are we there yet?
|
|
TOR_PROXY_HOST=127.0.0.1
|
|
basicswap-prepare --datadir=$SWAP_DATADIR --enabletor
|
|
|
|
# Workaround: Replace torpassword in various config files
|
|
oldtorpass=$(cat $SWAP_DATADIR/basicswap.json | jq -r .tor_control_password)
|
|
sed -i "s/$oldtorpass/$torcontrolpass/" $SWAP_DATADIR/*/*.conf $SWAP_DATADIR/basicswap.json
|
|
# Fix: localhost binding for btc/ltc/part (etc) configs
|
|
sed -i -z "s/\nbind=0.0.0.0/\nbind=127.0.0.1/" $SWAP_DATADIR/*/*.conf
|