2019-12-04 08:13:21 +00:00
#!/bin/bash
2020-05-01 11:34:52 +02:00
# Based on: https://gist.github.com/normandmickey/3f10fc077d15345fb469034e3697d0d0
2019-12-04 08:13:21 +00:00
2021-11-30 11:43:52 +00:00
# https://github.com/dgarage/NBXplorer/tags
2022-01-27 18:29:16 +01:00
NBXplorerVersion = "v2.2.20"
2020-11-11 16:40:48 +00:00
# https://github.com/btcpayserver/btcpayserver/releases
2022-02-10 16:26:55 +00:00
BTCPayVersion = "v1.4.4"
2021-11-30 11:43:52 +00:00
PGPsigner = "nicolasdorier"
PGPpubkeyLink = "https://keybase.io/nicolasdorier/pgp_keys.asc"
PGPpubkeyFingerprint = "AB4CFA9895ACA0DBE27F6B346618763EF09186FE"
2020-11-11 16:40:48 +00:00
2019-12-04 08:13:21 +00:00
# command info
if [ $# -eq 0 ] || [ " $1 " = "-h" ] || [ " $1 " = "-help" ] ; then
2021-11-30 11:43:52 +00:00
echo "Config script to switch BTCPay Server on or off"
echo "Usage:"
echo "bonus.btcpayserver.sh [on|off|menu|write-tls-macaroon]"
echo " installs BTCPayServer $BTCPayVersion with NBXplorer $NBXplorerVersion "
echo "To update to the latest release published on github run:"
echo "bonus.btcpayserver.sh update"
echo
2019-12-05 16:45:27 +00:00
exit 1
2019-12-04 08:13:21 +00:00
fi
source /mnt/hdd/raspiblitz.conf
2020-06-04 14:33:19 +01:00
# get cpu architecture
source /home/admin/raspiblitz.info
2021-12-14 23:34:35 +01:00
source <( /home/admin/_cache.sh get state)
2019-12-04 08:13:21 +00:00
2020-07-14 23:46:06 +02:00
if [ " $1 " = "status" ] ; then
2020-07-18 13:40:41 +02:00
2020-07-14 23:46:06 +02:00
if [ " ${ BTCPayServer } " = "on" ] ; then
2020-07-18 13:40:41 +02:00
echo "switchedon=1"
isInstalled = $( sudo ls /etc/systemd/system/btcpayserver.service 2>/dev/null | grep -c 'btcpayserver.service' )
echo " installed= ${ isInstalled } "
2020-07-14 23:46:06 +02:00
2021-08-04 00:18:30 +02:00
localIP = $( hostname -I | awk '{print $1}' )
2020-07-14 23:46:06 +02:00
echo " localIP=' ${ localIP } ' "
echo "httpsPort='23001'"
echo " publicIP=' ${ publicIP } ' "
2020-01-27 02:00:38 +01:00
2021-03-16 22:49:13 +00:00
# check for LetsEncryptDomain for DynDns
2020-07-14 23:46:06 +02:00
error = ""
source <( sudo /home/admin/config.scripts/blitz.subscriptions.ip2tor.py ip-by-tor $publicIP )
if [ ${# error } -eq 0 ] ; then
echo " publicDomain=' ${ domain } ' "
fi
2020-01-27 02:00:38 +01:00
2020-07-14 23:46:06 +02:00
sslFingerprintIP = $( openssl x509 -in /mnt/hdd/app-data/nginx/tls.cert -fingerprint -noout 2>/dev/null | cut -d"=" -f2)
echo " sslFingerprintIP=' ${ sslFingerprintIP } ' "
2020-01-27 02:00:38 +01:00
2020-07-14 23:46:06 +02:00
toraddress = $( sudo cat /mnt/hdd/tor/btcpay/hostname 2>/dev/null)
echo " toraddress=' ${ toraddress } ' "
2020-01-27 02:00:38 +01:00
2020-07-14 23:46:06 +02:00
sslFingerprintTOR = $( openssl x509 -in /mnt/hdd/app-data/nginx/tor_tls.cert -fingerprint -noout 2>/dev/null | cut -d"=" -f2)
echo " sslFingerprintTOR=' ${ sslFingerprintTOR } ' "
# check for IP2TOR
error = ""
source <( sudo /home/admin/config.scripts/blitz.subscriptions.ip2tor.py ip-by-tor $toraddress )
if [ ${# error } -eq 0 ] ; then
echo " ip2torType=' ${ ip2tor -v1 } ' "
echo " ip2torID=' ${ id } ' "
echo " ip2torIP=' ${ ip } ' "
echo " ip2torPort=' ${ port } ' "
# check for LetsEnryptDomain on IP2TOR
error = ""
source <( sudo /home/admin/config.scripts/blitz.subscriptions.letsencrypt.py domain-by-ip $ip )
if [ ${# error } -eq 0 ] ; then
echo " ip2torDomain=' ${ domain } ' "
2020-09-14 15:29:50 +02:00
domainWarning = $( sudo /home/admin/config.scripts/blitz.subscriptions.letsencrypt.py subscription-detail ${ domain } ${ port } | jq -r ".warning" )
if [ ${# domainWarning } -gt 0 ] ; then
echo " ip2torWarn=' ${ domainWarning } ' "
fi
2020-07-14 23:46:06 +02:00
fi
2020-06-25 18:57:05 +02:00
fi
2020-07-14 23:46:06 +02:00
# check for error
isDead = $( sudo systemctl status btcpayserver | grep -c 'inactive (dead)' )
if [ ${ isDead } -eq 1 ] ; then
echo "error='Service Failed'"
2020-06-25 19:58:22 +02:00
fi
2020-07-14 23:46:06 +02:00
else
2020-07-18 13:40:41 +02:00
echo "switchedon=0"
2020-07-14 23:46:06 +02:00
echo "installed=0"
fi
exit 0
fi
# show info menu
if [ " $1 " = "menu" ] ; then
2020-11-11 16:40:48 +00:00
# get status info
2020-07-14 23:46:06 +02:00
echo "# collecting status info ... (please wait)"
source <( sudo /home/admin/config.scripts/bonus.btcpayserver.sh status)
2020-07-18 13:40:41 +02:00
if [ ${ switchedon } -eq 0 ] ; then
whiptail --title " BTCPay Server " --msgbox "BTCPay Server is not activated." 7 36
exit 0
fi
if [ ${ installed } -eq 0 ] ; then
whiptail --title " BTCPay Server " --msgbox "BTCPay Server needs to be re-installed.\nPress OK to start process." 8 45
/home/admin/config.scripts/bonus.btcpayserver.sh on
exit 0
fi
2020-11-23 21:27:39 +01:00
# display possible problems with IP2TOR setup
2020-09-14 15:29:50 +02:00
if [ ${# ip2torWarn } -gt 0 ] ; then
2020-11-23 21:27:39 +01:00
whiptail --title " Warning " \
--yes-button "Back" \
--no-button "Continue Anyway" \
--yesno " Your IP2TOR+LetsEncrypt may have problems:\n ${ ip2torWarn } \n\nCheck if locally responding: https:// ${ localIP } : ${ httpsPort } \n\nCheck if service is reachable over Tor:\n ${ toraddress } " 14 72
if [ " $? " != "1" ] ; then
exit 0
fi
2020-09-14 15:29:50 +02:00
fi
2021-08-19 21:06:27 +01:00
text = " Local Web Browser: https:// ${ localIP } : ${ httpsPort } "
2020-07-14 23:46:06 +02:00
if [ ${# publicDomain } -gt 0 ] ; then
text = " ${ text }
Public Domain: https://${ publicDomain } :${ httpsPort }
2021-12-14 23:34:35 +01:00
port forwarding on router needs to be active & may change port"
2020-07-14 23:46:06 +02:00
fi
text = " ${ text }
2021-12-14 23:34:35 +01:00
SHA1 ${ sslFingerprintIP } "
2020-07-14 23:46:06 +02:00
if [ " ${ runBehindTor } " = "on" ] && [ ${# toraddress } -gt 0 ] ; then
2021-04-08 00:02:57 +02:00
/home/admin/config.scripts/blitz.display.sh qr " ${ toraddress } "
2020-07-14 23:46:06 +02:00
text = " ${ text } \n
2020-11-11 16:40:48 +00:00
TOR Browser Hidden Service address ( see the QR onLCD) :
2020-07-14 23:46:06 +02:00
${ toraddress } "
fi
2021-12-14 23:34:35 +01:00
2020-07-14 23:46:06 +02:00
if [ ${# ip2torDomain } -gt 0 ] ; then
text = " ${ text } \n
IP2TOR+LetsEncrypt: https://${ ip2torDomain } :${ ip2torPort }
SHA1 ${ sslFingerprintTOR } "
elif [ ${# ip2torIP } -gt 0 ] ; then
text = " ${ text } \n
IP2TOR: https://${ ip2torIP } :${ ip2torPort }
SHA1 ${ sslFingerprintTOR }
go MAINMENU > SUBSCRIBE and add LetsEncrypt HTTPS Domain"
elif [ ${# publicDomain } -eq 0 ] ; then
text = " ${ text } \n
2020-08-12 09:44:49 +02:00
To enable easy reachability with normal browser from the outside
2020-09-17 16:53:44 +02:00
consider adding a IP2TOR Bridge: MAINMENU > SUBSCRIBE > IP2TOR"
2020-01-27 02:00:38 +01:00
fi
2020-09-17 16:53:44 +02:00
text = " ${ text } \n
To get the 'Connection String' to activate Lightning Payments:
2021-04-18 18:04:59 +02:00
MAINMENU > CONNECT > BTCPay Server"
2020-09-17 16:53:44 +02:00
whiptail --title " BTCPay Server " --msgbox " ${ text } " 17 69
2021-12-14 23:34:35 +01:00
2021-04-08 00:02:57 +02:00
/home/admin/config.scripts/blitz.display.sh hide
2020-11-11 16:40:48 +00:00
echo "# please wait ..."
2020-01-27 02:00:38 +01:00
exit 0
fi
2020-04-28 14:14:17 +01:00
# write-tls-macaroon
2020-04-28 14:40:09 +01:00
if [ " $1 " = "write-tls-macaroon" ] ; then
2020-05-01 11:34:52 +02:00
2020-11-11 16:40:48 +00:00
echo "# make sure btcpay is member of lndadmin"
2020-05-01 11:39:29 +02:00
sudo /usr/sbin/usermod --append --groups lndadmin btcpay
2020-11-11 16:40:48 +00:00
echo "# make sure symlink to central app-data directory exists"
2020-05-01 11:34:52 +02:00
if ! [ [ -L "/home/btcpay/.lnd" ] ] ; then
sudo rm -rf "/home/btcpay/.lnd" # not a symlink.. delete it silently
sudo ln -s "/mnt/hdd/app-data/lnd/" "/home/btcpay/.lnd" # and create symlink
fi
2020-04-28 14:14:17 +01:00
# copy admin macaroon
2020-11-11 16:40:48 +00:00
echo "# extra symlink to admin.macaroon for btcpay"
2020-05-01 11:34:52 +02:00
if ! [ [ -L "/home/btcpay/admin.macaroon" ] ] ; then
sudo ln -s " /home/btcpay/.lnd/data/chain/ ${ network } / ${ chain } net/admin.macaroon " "/home/btcpay/admin.macaroon"
fi
2020-04-28 14:14:17 +01:00
# set thumbprint
2020-05-01 11:34:52 +02:00
FINGERPRINT = $( openssl x509 -noout -fingerprint -sha256 -inform pem -in /home/btcpay/.lnd/tls.cert | cut -d"=" -f2)
2020-04-28 14:14:17 +01:00
doesNetworkEntryAlreadyExists = $( sudo cat /home/btcpay/.btcpayserver/Main/settings.config | grep -c '^network=' )
if [ ${ doesNetworkEntryAlreadyExists } -eq 0 ] ; then
2020-11-11 16:40:48 +00:00
echo "# setting the LND TLS thumbprint for BTCPay"
2020-04-28 14:14:17 +01:00
echo "
### Global settings ###
network = mainnet
### Server settings ###
port = 23000
bind = 127.0.0.1
externalurl = https://$BTCPayDomain
### NBXplorer settings ###
BTC.explorer.url= http://127.0.0.1:24444/
BTC.lightning= type = lnd-rest; server = https://127.0.0.1:8080/; macaroonfilepath = /home/btcpay/admin.macaroon; certthumbprint = $FINGERPRINT
" | sudo -u btcpay tee -a /home/btcpay/.btcpayserver/Main/settings.config
else
2020-11-11 16:40:48 +00:00
echo "# setting new LND TLS thumbprint for BTCPay"
2020-05-01 11:34:52 +02:00
s = "BTC.lightning=type=lnd-rest\;server=https\://127.0.0.1:8080/\;macaroonfilepath=/home/btcpay/admin.macaroon\;"
sudo -u btcpay sed -i " s|^ ${ s } certthumbprint=.*| ${ s } certthumbprint= $FINGERPRINT |g " /home/btcpay/.btcpayserver/Main/settings.config
2020-04-28 14:14:17 +01:00
fi
2021-12-14 23:34:35 +01:00
2020-07-18 22:49:26 +02:00
if [ " ${ state } " = = "ready" ] ; then
sudo systemctl restart btcpayserver
fi
2020-04-28 14:14:17 +01:00
exit 0
fi
2019-12-04 08:13:21 +00:00
# switch on
if [ " $1 " = "1" ] || [ " $1 " = "on" ] ; then
2021-03-16 22:49:13 +00:00
echo "# INSTALL BTCPAYSERVER"
2019-12-05 13:37:33 +00:00
2020-06-11 18:15:42 +01:00
##################
# NGINX
##################
# setup nginx symlinks
if ! [ -f /etc/nginx/sites-available/btcpay_ssl.conf ] ; then
sudo cp /home/admin/assets/nginx/sites-available/btcpay_ssl.conf /etc/nginx/sites-available/btcpay_ssl.conf
fi
if ! [ -f /etc/nginx/sites-available/btcpay_tor.conf ] ; then
sudo cp /home/admin/assets/nginx/sites-available/btcpay_tor.conf /etc/nginx/sites-available/btcpay_tor.conf
fi
if ! [ -f /etc/nginx/sites-available/btcpay_tor_ssl.conf ] ; then
sudo cp /home/admin/assets/nginx/sites-available/btcpay_tor_ssl.conf /etc/nginx/sites-available/btcpay_tor_ssl.conf
fi
sudo ln -sf /etc/nginx/sites-available/btcpay_ssl.conf /etc/nginx/sites-enabled/
sudo ln -sf /etc/nginx/sites-available/btcpay_tor.conf /etc/nginx/sites-enabled/
sudo ln -sf /etc/nginx/sites-available/btcpay_tor_ssl.conf /etc/nginx/sites-enabled/
sudo nginx -t
sudo systemctl reload nginx
2021-12-14 23:34:35 +01:00
2020-06-11 18:15:42 +01:00
# open the firewall
2021-03-16 22:49:13 +00:00
echo "# Updating the firewall"
2020-06-11 18:15:42 +01:00
sudo ufw allow 23000 comment 'allow BTCPay HTTP'
sudo ufw allow 23001 comment 'allow BTCPay HTTPS'
2020-11-11 16:40:48 +00:00
echo
2020-06-11 18:15:42 +01:00
# Hidden Service for BTCPay if Tor is active
if [ " ${ runBehindTor } " = "on" ] ; then
2021-12-14 23:34:35 +01:00
# make sure to keep in sync with tor.network.sh script
/home/admin/config.scripts/tor.onion-service.sh btcpay 80 23002 443 23003
2020-01-28 17:54:28 +01:00
fi
2020-01-28 16:30:08 +01:00
2020-01-13 15:00:22 +00:00
# check for $BTCPayDomain
source /mnt/hdd/raspiblitz.conf
2019-12-05 13:37:33 +00:00
2020-04-28 14:14:17 +01:00
# stop services
2020-11-11 16:40:48 +00:00
echo "# making sure services are not running"
2020-04-28 14:14:17 +01:00
sudo systemctl stop nbxplorer 2>/dev/null
sudo systemctl stop btcpayserver 2>/dev/null
2019-12-04 08:13:21 +00:00
isInstalled = $( sudo ls /etc/systemd/system/btcpayserver.service 2>/dev/null | grep -c 'btcpayserver.service' )
if [ ${ isInstalled } -eq 0 ] ; then
2019-12-24 09:55:53 +01:00
# create btcpay user
2022-02-10 16:26:55 +00:00
sudo adduser --disabled-password --gecos "" btcpay
2021-03-16 22:49:13 +00:00
cd /home/btcpay || exit 1
2019-12-23 19:03:00 +01:00
2019-12-24 09:55:53 +01:00
# store BTCpay data on HDD
2020-01-13 15:00:22 +00:00
sudo mkdir /mnt/hdd/app-data/.btcpayserver 2>/dev/null
2019-12-24 09:55:53 +01:00
# move old btcpay data to app-data
2020-01-13 15:00:22 +00:00
sudo mv -f /mnt/hdd/.btcpayserver/* /mnt/hdd/app-data/.btcpayserver/ 2>/dev/null
sudo rm -rf /mnt/hdd/.btcpayserver 2>/dev/null
sudo chown -R btcpay:btcpay /mnt/hdd/app-data/.btcpayserver
2020-01-20 22:38:36 +00:00
sudo ln -s /mnt/hdd/app-data/.btcpayserver /home/btcpay/ 2>/dev/null
2020-01-13 15:00:22 +00:00
sudo chown -R btcpay:btcpay /home/btcpay/.btcpayserver
2019-12-24 09:55:53 +01:00
2021-12-14 23:34:35 +01:00
echo
2020-11-11 16:40:48 +00:00
echo "# Installing .NET"
2021-12-14 23:34:35 +01:00
echo
2022-01-27 21:44:05 +01:00
# https://dotnet.microsoft.com/en-us/download/dotnet/6.0
2020-06-04 14:33:19 +01:00
# dependencies
2019-12-04 08:13:21 +00:00
sudo apt-get -y install libunwind8 gettext libssl1.0
2021-12-14 23:34:35 +01:00
2022-01-27 21:37:54 +01:00
if [ " ${ cpu } " = "aarch64" ] ; then
2020-06-04 14:33:19 +01:00
binaryVersion = "arm64"
2022-01-27 21:44:05 +01:00
dotNetdirectLink = "https://download.visualstudio.microsoft.com/download/pr/d43345e2-f0d7-4866-b56e-419071f30ebe/68debcece0276e9b25a65ec5798cf07b/dotnet-sdk-6.0.101-linux-arm64.tar.gz"
dotNetChecksum = "04cd89279f412ae6b11170d1724c6ac42bb5d4fae8352020a1f28511086dd6d6af2106dd48ebe3b39d312a21ee8925115de51979687a9161819a3a29e270a954"
#dotNetdirectLink="https://download.visualstudio.microsoft.com/download/pr/d3aaa7cc-a603-4693-871b-53b1537a4319/5981099ca17a113b3ce1c080462c50ef/dotnet-sdk-3.1.416-linux-arm64.tar.gz"
#dotNetChecksum="0065c7afb129b1a0e0c11703309f3b45cf9a3c0ea156247f7cc61555f21c37054f215eb77add509dad77b1d388a4e6c585f8a8016109f31c5b64184b25e2c407"
2020-06-04 14:33:19 +01:00
elif [ " ${ cpu } " = "x86_64" ] ; then
binaryVersion = "x64"
2022-01-27 21:44:05 +01:00
dotNetdirectLink = "https://download.visualstudio.microsoft.com/download/pr/ede8a287-3d61-4988-a356-32ff9129079e/bdb47b6b510ed0c4f0b132f7f4ad9d5a/dotnet-sdk-6.0.101-linux-x64.tar.gz"
dotNetChecksum = "ca21345400bcaceadad6327345f5364e858059cfcbc1759f05d7df7701fec26f1ead297b6928afa01e46db6f84e50770c673146a10b9ff71e4c7f7bc76fbf709"
#dotNetdirectLink="https://download.visualstudio.microsoft.com/download/pr/3c98126b-50f5-4497-8ffd-18d17a3f6b95/044d0f20256fd9bf2971f8da9a0364e4/dotnet-sdk-3.1.416-linux-x64.tar.gz"
#dotNetChecksum="dec1dcf326487031c45dec0849a046a0d034d6cbb43ab591da6d94c2faf72da8e31deeaf4d2165049181546d5296bb874a039ccc2f618cf95e68a26399da5e7f"
2022-01-27 21:37:54 +01:00
else
echo " # FAIL! CPU ( ${ cpu } ) not supported. "
exit 1
2020-06-04 14:33:19 +01:00
fi
2022-01-27 21:48:50 +01:00
dotNetName = " dotnet-sdk-6.0.101-linux- ${ binaryVersion } .tar.gz "
2020-01-27 04:33:41 +01:00
sudo rm /home/btcpay/${ dotnetName } 2>/dev/null
2020-06-04 14:33:19 +01:00
sudo -u btcpay wget " ${ dotNetdirectLink } "
2020-01-27 04:33:41 +01:00
# check binary is was not manipulated (checksum test)
2020-06-04 14:33:19 +01:00
actualChecksum = $( sha512sum /home/btcpay/${ dotNetName } | cut -d " " -f1)
if [ " ${ actualChecksum } " != " ${ dotNetChecksum } " ] ; then
2020-11-11 16:40:48 +00:00
echo " # !!! FAIL !!! Downloaded ${ dotNetName } not matching SHA512 checksum: ${ dotNetChecksum } "
2019-12-04 08:13:21 +00:00
exit 1
fi
2020-05-01 11:34:52 +02:00
2019-12-04 08:13:21 +00:00
sudo -u btcpay mkdir /home/btcpay/dotnet
2020-06-04 14:33:19 +01:00
sudo -u btcpay tar -xvf ${ dotNetName } -C /home/btcpay/dotnet
2020-01-13 15:00:22 +00:00
sudo rm -f *.tar.gz*
2020-05-01 11:34:52 +02:00
2019-12-04 08:13:21 +00:00
# opt out of telemetry
echo "DOTNET_CLI_TELEMETRY_OPTOUT=1" | sudo tee -a /etc/environment
2020-05-01 11:34:52 +02:00
2020-01-21 04:21:35 +00:00
# make .NET accessible and add to PATH
sudo ln -s /home/btcpay/dotnet /usr/share
export PATH = $PATH :/usr/share
if [ $( cat /etc/profile | grep -c "/usr/share" ) -eq 0 ] ; then
sudo bash -c "echo 'PATH=\$PATH:/usr/share' >> /etc/profile"
fi
export DOTNET_ROOT = /home/btcpay/dotnet
export PATH = $PATH :/home/btcpay/dotnet
if [ $( cat /etc/profile | grep -c "DOTNET_ROOT" ) -eq 0 ] ; then
sudo bash -c "echo 'DOTNET_ROOT=/home/btcpay/dotnet' >> /etc/profile"
sudo bash -c "echo 'PATH=\$PATH:/home/btcpay/dotnet' >> /etc/profile"
fi
2019-12-04 08:13:21 +00:00
sudo -u btcpay /home/btcpay/dotnet/dotnet --info
2020-05-01 11:34:52 +02:00
2020-01-21 04:21:35 +00:00
# NBXplorer
2020-11-11 16:40:48 +00:00
echo
echo "# Install NBXplorer"
echo
2021-03-17 20:23:29 +00:00
cd /home/btcpay || exit 1
echo "# Download the NBXplorer source code ..."
2020-01-21 04:21:35 +00:00
sudo -u btcpay git clone https://github.com/dgarage/NBXplorer.git 2>/dev/null
2021-04-10 17:27:05 +01:00
cd NBXplorer || exit 1
2020-11-11 16:40:48 +00:00
sudo -u btcpay git reset --hard $NBXplorerVersion
2021-11-30 11:43:52 +00:00
# PGP verify
sudo -u btcpay /home/admin/config.scripts/blitz.git-verify.sh \
" ${ PGPsigner } " " ${ PGPpubkeyLink } " " ${ PGPpubkeyFingerprint } " || exit 1
2021-03-17 20:23:29 +00:00
echo "# Build NBXplorer ..."
2020-01-21 04:21:35 +00:00
# from the build.sh with path
sudo -u btcpay /home/btcpay/dotnet/dotnet build -c Release NBXplorer/NBXplorer.csproj
2021-03-17 20:23:29 +00:00
# see the configuration options with:
2021-09-17 00:26:35 +01:00
# sudo -u btcpay /home/btcpay/dotnet/dotnet run --no-launch-profile --no-build -c Release -p "NBXplorer/NBXplorer.csproj" -c /home/btcpay/.nbxplorer/Main/settings.config -h
2021-03-17 20:23:29 +00:00
# run manually to debug:
2021-09-17 00:26:35 +01:00
# sudo -u btcpay /home/btcpay/dotnet/dotnet run --no-launch-profile --no-build -c Release -p "NBXplorer/NBXplorer.csproj" -c /home/btcpay/.nbxplorer/Main/settings.config --network=mainnet -- $@
echo "# create the nbxplorer.service"
2019-12-04 08:13:21 +00:00
echo "
[ Unit]
Description = NBXplorer daemon
Requires = bitcoind.service
After = bitcoind.service
[ Service]
2021-09-17 00:26:35 +01:00
WorkingDirectory = /home/btcpay/NBXplorer
ExecStart = /home/btcpay/dotnet/dotnet run --no-launch-profile --no-build \
-c Release -p \" NBXplorer/NBXplorer.csproj\" -- \$ @
2019-12-04 08:13:21 +00:00
User = btcpay
Group = btcpay
2020-01-15 11:23:32 +01:00
Type = simple
2019-12-04 08:13:21 +00:00
PIDFile = /run/nbxplorer/nbxplorer.pid
Restart = on-failure
2021-08-04 00:18:30 +02:00
# Hardening measures
2019-12-04 08:13:21 +00:00
PrivateTmp = true
ProtectSystem = full
NoNewPrivileges = true
PrivateDevices = true
[ Install]
WantedBy = multi-user.target
2020-01-13 15:00:22 +00:00
" | sudo tee /etc/systemd/system/nbxplorer.service
2020-05-01 11:34:52 +02:00
2019-12-04 08:13:21 +00:00
sudo systemctl daemon-reload
2020-01-21 04:21:35 +00:00
# start to create settings.config
2019-12-04 08:13:21 +00:00
sudo systemctl enable nbxplorer
2020-07-24 00:42:56 +02:00
if [ " ${ state } " = = "ready" ] ; then
2020-11-11 16:40:48 +00:00
echo "# Starting nbxplorer"
2020-07-24 00:42:56 +02:00
sudo systemctl start nbxplorer
2020-11-11 16:40:48 +00:00
echo "# Checking for nbxplorer config"
2020-07-24 00:42:56 +02:00
while [ ! -f "/home/btcpay/.nbxplorer/Main/settings.config" ]
do
2020-11-11 16:40:48 +00:00
echo "# Waiting for nbxplorer to start - CTRL+C to abort"
2020-07-24 00:42:56 +02:00
sleep 10
hasFailed = $( sudo systemctl status nbxplorer | grep -c "Active: failed" )
if [ ${ hasFailed } -eq 1 ] ; then
2020-11-11 16:40:48 +00:00
echo "# seems like starting nbxplorer service has failed - see: systemctl status nbxplorer"
echo "# maybe report here: https://github.com/rootzoll/raspiblitz/issues/214"
2020-07-24 00:42:56 +02:00
fi
done
else
2020-11-11 16:40:48 +00:00
echo "# Because the system is not 'ready' the service 'nbxplorer' will not be started at this point .. its enabled and will start on next reboot"
2020-07-24 00:42:56 +02:00
fi
2020-05-01 11:34:52 +02:00
2020-11-11 16:40:48 +00:00
echo
echo "# getting RPC credentials from the bitcoin.conf"
2019-12-04 08:13:21 +00:00
RPC_USER = $( sudo cat /mnt/hdd/bitcoin/bitcoin.conf | grep rpcuser | cut -c 9-)
PASSWORD_B = $( sudo cat /mnt/hdd/bitcoin/bitcoin.conf | grep rpcpassword | cut -c 13-)
2020-07-18 22:58:13 +02:00
sudo -u btcpay mkdir -p /home/btcpay/.nbxplorer/Main
2021-03-16 22:49:13 +00:00
echo " \
btc.rpc.user= $RPC_USER
2019-12-04 08:13:21 +00:00
btc.rpc.password= $PASSWORD_B
2021-03-16 22:49:13 +00:00
" | sudo tee /home/btcpay/.nbxplorer/Main/settings.config
sudo chmod 600 /home/btcpay/.nbxplorer/Main/settings.config
2019-12-04 08:13:21 +00:00
sudo chown btcpay:btcpay /home/btcpay/.nbxplorer/Main/settings.config
2020-07-18 22:43:14 +02:00
2021-11-30 11:43:52 +00:00
# whitelist localhost in bitcoind
if ! sudo grep -Eq "^whitelist=127.0.0.1" /mnt/hdd/bitcoin/bitcoin.conf; then
echo "whitelist=127.0.0.1" | sudo tee -a /mnt/hdd/bitcoin/bitcoin.conf
bitcoindRestart = yes
fi
2020-07-18 22:43:14 +02:00
if [ " ${ state } " = = "ready" ] ; then
2021-11-30 11:43:52 +00:00
if [ " ${ bitcoindRestart } " = = "yes" ] ; then
echo "# Restarting bitcoind"
sudo systemctl restart bitcoind
fi
2020-07-24 00:42:56 +02:00
sudo systemctl restart nbxplorer
2021-12-14 23:34:35 +01:00
fi
2020-05-01 11:34:52 +02:00
2020-01-21 04:21:35 +00:00
# BTCPayServer
2020-11-11 16:40:48 +00:00
echo
echo "# Install BTCPayServer"
2021-03-16 22:49:13 +00:00
echo
2021-03-17 20:23:29 +00:00
cd /home/btcpay || exit 1
echo "# Download the BTCPayServer source code ..."
2020-01-21 04:21:35 +00:00
sudo -u btcpay git clone https://github.com/btcpayserver/btcpayserver.git 2>/dev/null
2019-12-04 08:13:21 +00:00
cd btcpayserver
2020-11-11 16:40:48 +00:00
sudo -u btcpay git reset --hard $BTCPayVersion
2022-02-10 16:26:55 +00:00
# sudo -u btcpay /home/admin/config.scripts/blitz.git-verify.sh \
# "web-flow" "https://github.com/web-flow.gpg" "4AEE18F83AFDEB23" || exit 1
2022-01-27 22:47:24 +01:00
sudo -u btcpay /home/admin/config.scripts/blitz.git-verify.sh \
2022-02-10 16:26:55 +00:00
" ${ PGPsigner } " " ${ PGPpubkeyLink } " " ${ PGPpubkeyFingerprint } " || exit 1
2021-03-17 20:23:29 +00:00
echo "# Build BTCPayServer ..."
2020-01-21 04:21:35 +00:00
# from the build.sh with path
2020-05-01 11:34:52 +02:00
sudo -u btcpay /home/btcpay/dotnet/dotnet build -c Release /home/btcpay/btcpayserver/BTCPayServer/BTCPayServer.csproj
2021-03-17 20:23:29 +00:00
# see the configuration options with:
# sudo -u btcpay /home/btcpay/dotnet/dotnet run --no-launch-profile --no-build -c Release -p "/home/btcpay/btcpayserver/BTCPayServer/BTCPayServer.csproj" -- -h
# run manually to debug:
# sudo -u btcpay /home/btcpay/dotnet/dotnet run --no-launch-profile --no-build -c Release -p "/home/btcpay/btcpayserver/BTCPayServer/BTCPayServer.csproj" -- --sqlitefile=sqllite.db --network=mainnet
echo "# create the btcpayserver.service"
2019-12-04 08:13:21 +00:00
echo "
[ Unit]
Description = BtcPayServer daemon
2021-03-17 20:23:29 +00:00
Requires = nbxplorer.service
2019-12-04 08:13:21 +00:00
After = nbxplorer.service
[ Service]
2021-03-17 20:23:29 +00:00
ExecStart = /home/btcpay/dotnet/dotnet run --no-launch-profile --no-build \
2021-09-17 00:26:35 +01:00
-c Release -p \" /home/btcpay/btcpayserver/BTCPayServer/BTCPayServer.csproj\" \
2021-12-14 23:34:35 +01:00
-- --sqlitefile= sqllite.db
2019-12-04 08:13:21 +00:00
User = btcpay
Group = btcpay
Type = simple
PIDFile = /run/btcpayserver/btcpayserver.pid
Restart = on-failure
2021-08-04 00:18:30 +02:00
# Hardening measures
PrivateTmp = true
ProtectSystem = full
NoNewPrivileges = true
PrivateDevices = true
2019-12-04 08:13:21 +00:00
[ Install]
WantedBy = multi-user.target
2020-01-13 15:00:22 +00:00
" | sudo tee /etc/systemd/system/btcpayserver.service
2021-03-16 22:49:13 +00:00
sudo systemctl enable btcpayserver
2020-05-01 11:34:52 +02:00
2021-03-16 22:49:13 +00:00
if [ " ${ state } " = = "ready" ] ; then
2020-11-11 16:40:48 +00:00
echo "# Starting btcpayserver"
2020-07-18 22:43:14 +02:00
sudo systemctl start btcpayserver
2020-11-11 16:40:48 +00:00
echo "# Checking for btcpayserver config"
2021-03-16 22:49:13 +00:00
while [ ! -f "/home/btcpay/.btcpayserver/Main/settings.config" ] ; do
echo "# Waiting for btcpayserver to start - CTRL+C to abort"
sleep 10
hasFailed = $( sudo systemctl status btcpayserver | grep -c "Active: failed" )
if [ ${ hasFailed } -eq 1 ] ; then
echo "# seems like starting btcpayserver service has failed - see: systemctl status btcpayserver"
echo "# maybe report here: https://github.com/rootzoll/raspiblitz/issues/214"
fi
2020-07-24 00:42:56 +02:00
done
2020-07-18 22:43:14 +02:00
else
2020-11-11 16:40:48 +00:00
echo "# Because the system is not 'ready' the service 'btcpayserver' will not be started at this point .. its enabled and will start on next reboot"
2020-07-18 22:43:14 +02:00
fi
2021-12-14 23:34:35 +01:00
2020-07-18 23:49:12 +02:00
sudo -u btcpay mkdir -p /home/btcpay/.btcpayserver/Main/
2020-04-28 14:14:17 +01:00
/home/admin/config.scripts/bonus.btcpayserver.sh write-tls-macaroon
2019-12-04 08:13:21 +00:00
2020-05-01 11:34:52 +02:00
else
2020-11-11 16:40:48 +00:00
echo "# BTCPay Server is already installed."
2020-07-18 22:43:14 +02:00
if [ " ${ state } " = = "ready" ] ; then
# start service
2020-11-11 16:40:48 +00:00
echo "# start service"
2020-07-18 22:43:14 +02:00
sudo systemctl start nbxplorer 2>/dev/null
sudo systemctl start btcpayserver 2>/dev/null
fi
2020-05-01 11:34:52 +02:00
fi
2019-12-05 15:31:07 +00:00
# setting value in raspi blitz config
2021-12-14 23:34:35 +01:00
/home/admin/config.scripts/blitz.conf.sh set BTCPayServer "on"
2019-12-04 08:13:21 +00:00
exit 0
fi
# switch off
if [ " $1 " = "0" ] || [ " $1 " = "off" ] ; then
2020-07-23 23:54:25 +02:00
# check for second parameter: should data be deleted?
deleteData = 0
if [ " $2 " = "--delete-data" ] ; then
deleteData = 1
elif [ " $2 " = "--keep-data" ] ; then
deleteData = 0
else
2020-10-14 23:25:39 +02:00
if ( whiptail --title " DELETE DATA? " --yesno "Do you want to delete\nthe BTCPay Server Data?" 8 30) ; then
2020-07-23 23:54:25 +02:00
deleteData = 1
else
deleteData = 0
fi
fi
2020-07-23 23:58:34 +02:00
echo " # deleteData( ${ deleteData } ) "
2020-07-23 23:54:25 +02:00
2019-12-04 08:13:21 +00:00
# setting value in raspi blitz config
2021-12-14 23:34:35 +01:00
/home/admin/config.scripts/blitz.conf.sh set BTCPayServer "off"
2019-12-04 08:13:21 +00:00
2020-07-12 20:05:41 +02:00
# Hidden Service if Tor is active
if [ " ${ runBehindTor } " = "on" ] ; then
2021-12-14 23:34:35 +01:00
/home/admin/config.scripts/tor.onion-service.sh off btcpay
2020-07-12 20:05:41 +02:00
fi
2019-12-04 08:13:21 +00:00
isInstalled = $( sudo ls /etc/systemd/system/btcpayserver.service 2>/dev/null | grep -c 'btcpayserver.service' )
if [ ${ isInstalled } -eq 1 ] ; then
2020-07-23 23:54:25 +02:00
echo "# *** REMOVING BTCPAYSERVER, NBXPLORER and .NET ***"
2020-01-27 08:29:25 +00:00
# removing services
# btcpay
2019-12-04 08:13:21 +00:00
sudo systemctl stop btcpayserver
sudo systemctl disable btcpayserver
sudo rm /etc/systemd/system/btcpayserver.service
2020-01-27 08:29:25 +00:00
# nbxplorer
sudo systemctl stop nbxplorer
sudo systemctl disable nbxplorer
sudo rm /etc/systemd/system/nbxplorer.service
# clear dotnet cache
2021-09-21 12:25:24 +02:00
/home/btcpay/dotnet/dotnet nuget locals all --clear
2020-01-21 04:21:35 +00:00
sudo rm -rf /tmp/NuGetScratch
2020-01-27 08:29:25 +00:00
# remove dotnet
2020-01-21 04:21:35 +00:00
sudo rm -rf /usr/share/dotnet
2020-01-27 08:29:25 +00:00
# clear app config (not user data)
2019-12-04 08:13:21 +00:00
sudo rm -f /home/btcpay/.nbxplorer/Main/settings.config
sudo rm -f /home/btcpay/.btcpayserver/Main/settings.config
2020-06-11 18:15:42 +01:00
# clear nginx config (from btcpaysetdomain)
2020-01-27 08:29:25 +00:00
sudo rm -f /etc/nginx/sites-enabled/btcpayserver
2020-01-27 04:12:03 +01:00
sudo rm -f /etc/nginx/sites-available/btcpayserver
2020-06-11 18:15:42 +01:00
# remove nginx symlinks
sudo rm -f /etc/nginx/sites-enabled/btcpay_ssl.conf
sudo rm -f /etc/nginx/sites-enabled/btcpay_tor.conf
sudo rm -f /etc/nginx/sites-enabled/btcpay_tor_ssl.conf
2020-06-26 20:43:16 +02:00
sudo rm -f /etc/nginx/sites-available/btcpay_ssl.conf
sudo rm -f /etc/nginx/sites-available/btcpay_tor.conf
sudo rm -f /etc/nginx/sites-available/btcpay_tor_ssl.conf
2020-06-11 18:15:42 +01:00
sudo nginx -t
sudo systemctl reload nginx
2020-04-28 14:40:09 +01:00
# nuke user
sudo userdel -rf btcpay 2>/dev/null
2020-07-23 23:54:25 +02:00
if [ ${ deleteData } -eq 1 ] ; then
echo "# deleting data"
sudo rm -R /mnt/hdd/app-data/.btcpayserver/
else
echo "# keeping data"
fi
echo "# OK BTCPayServer removed."
2020-05-01 11:34:52 +02:00
else
2020-07-23 23:54:25 +02:00
echo "# BTCPayServer is not installed."
2019-12-04 08:13:21 +00:00
fi
exit 0
fi
2021-11-30 11:43:52 +00:00
if [ " $1 " = "update" ] ; then
echo "# Update NBXplorer"
cd /home/btcpay || exit 1
cd NBXplorer || exit 1
# fetch latest master
if [ " $( sudo -u btcpay git fetch 2>& 1 | grep -c "Please tell me who you are" ) " -gt 0 ] ; then
sudo -u btcpay git config user.email "you@example.com"
sudo -u btcpay git config user.name "Your Name"
fi
sudo -u btcpay git fetch
# unset $1
set --
UPSTREAM = ${ 1 :- '@{u}' }
LOCAL = $( git rev-parse @)
REMOTE = $( git rev-parse " $UPSTREAM " )
if [ $LOCAL = $REMOTE ] ; then
TAG = $( git tag | sort -V | tail -1)
echo " # Up-to-date on version $TAG "
else
echo "# Pulling latest changes..."
sudo -u btcpay git pull -p
TAG = $( git tag | sort -V | tail -1)
echo " # Reset to the latest release tag: $TAG "
sudo -u btcpay git reset --hard $TAG
sudo -u btcpay /home/admin/config.scripts/blitz.git-verify.sh \
" ${ PGPsigner } " " ${ PGPpubkeyLink } " " ${ PGPpubkeyFingerprint } " || exit 1
echo "# Build NBXplorer ..."
# from the build.sh with path
sudo systemctl stop nbxplorer
sudo -u btcpay /home/btcpay/dotnet/dotnet build -c Release NBXplorer/NBXplorer.csproj
# whitelist localhost in bitcoind
if ! sudo grep -Eq "^whitelist=127.0.0.1" /mnt/hdd/bitcoin/bitcoin.conf; then
echo "whitelist=127.0.0.1" | sudo tee -a /mnt/hdd/bitcoin/bitcoin.conf
echo "# Restarting bitcoind"
sudo systemctl restart bitcoind
fi
sudo systemctl start nbxplorer
echo " # Updated NBXplorer to $TAG "
fi
echo "# Update BTCPayServer"
cd /home/btcpay || exit 1
cd btcpayserver || exit 1
# fetch latest master
if [ " $( sudo -u btcpay git fetch 2>& 1 | grep -c "Please tell me who you are" ) " -gt 0 ] ; then
sudo -u btcpay git config user.email "you@example.com"
sudo -u btcpay git config user.name "Your Name"
fi
sudo -u btcpay git fetch
# unset $1
set --
UPSTREAM = ${ 1 :- '@{u}' }
LOCAL = $( git rev-parse @)
REMOTE = $( git rev-parse " $UPSTREAM " )
if [ $LOCAL = $REMOTE ] ; then
TAG = $( git tag | grep v1 | sort -V | tail -1)
echo " # Up-to-date on version $TAG "
else
echo "# Pulling latest changes..."
sudo -u btcpay git pull -p
TAG = $( git tag | grep v1 | sort -V | tail -1)
echo " # Reset to the latest release tag: $TAG "
sudo -u btcpay git reset --hard $TAG
# PGP verify
sudo -u btcpay /home/admin/config.scripts/blitz.git-verify.sh \
" ${ PGPsigner } " " ${ PGPpubkeyLink } " " ${ PGPpubkeyFingerprint } " || exit 1
echo "# Build BTCPayServer ..."
# from the build.sh with path
sudo systemctl stop btcpayserver
sudo -u btcpay /home/btcpay/dotnet/dotnet build -c Release /home/btcpay/btcpayserver/BTCPayServer/BTCPayServer.csproj
sudo systemctl start btcpayserver
echo " # Updated BTCPayServer to $TAG "
fi
exit 0
fi
2020-11-11 16:40:48 +00:00
echo " # FAIL - Unknown Parameter $1 "
2019-12-23 19:03:00 +01:00
exit 1