Merge pull request #13 from openoms/user_btcpay

User btcpay
This commit is contained in:
bluecell296
2019-09-22 13:59:44 +01:00
committed by GitHub

View File

@@ -1,5 +1,5 @@
## Install BTCPayServer on the RaspiBlitz ## Install BTCPayServer on the RaspiBlitz
#Heavily based on: https://gist.github.com/normandmickey/3f10fc077d15345fb469034e3697d0d0 # Based on: https://gist.github.com/normandmickey/3f10fc077d15345fb469034e3697d0d0
# to download and run: # to download and run:
# wget https://raw.githubusercontent.com/openoms/bitcoin-tutorials/master/BTCPayServer/btcpay_to_blitz.sh && bash btcpay_to_blitz.sh # wget https://raw.githubusercontent.com/openoms/bitcoin-tutorials/master/BTCPayServer/btcpay_to_blitz.sh && bash btcpay_to_blitz.sh
@@ -19,71 +19,60 @@ echo "***"
echo "Type an email address that will be used to register the SSL certificate and press [ENTER]" echo "Type an email address that will be used to register the SSL certificate and press [ENTER]"
read YOUR_EMAIL read YOUR_EMAIL
# install nginx
sudo apt-get install nginx-full certbot -y
# get SSL cert
sudo certbot certonly -a standalone -m $YOUR_EMAIL --agree-tos -d $YOUR_DOMAIN --pre-hook "service nginx stop" --post-hook "service nginx start"
echo "" echo ""
echo "***" echo "***"
echo "Setting up certbot-auto renewal service" echo "Creating the btcpay user"
echo "***" echo "***"
echo "" echo ""
sudo adduser --disabled-password --gecos "" btcpay
cd /home/btcpay
sudo rm -f /etc/systemd/system/certbot.timer # store BTCpay data on HDD
echo " sudo mkdir /mnt/hdd/.btcpayserver
[Unit]
Description=Certbot-auto renewal service
[Timer] sudo mv -f /home/admin/.btcpayserver /mnt/hdd/
OnBootSec=20min sudo rm -rf /home/admin/.btcpayserver
OnCalendar=*-*-* 4:00:00 sudo mv -f /home/btcpay/.btcpayserver /mnt/hdd/
[Install] sudo chown -R btcpay:btcpay /mnt/hdd/.btcpayserver
WantedBy=timers.target sudo ln -s /mnt/hdd/.btcpayserver /home/btcpay/
" | sudo tee -a /etc/systemd/system/certbot.timer
sudo rm -f /etc/systemd/system/certbot.service
echo "
[Unit]
Description=Certbot-auto renewal service
After=bitcoind.service
[Service]
WorkingDirectory=/home/admin/
ExecStart=sudo certbot renew --pre-hook \"service nginx stop\" --post-hook \"service nginx start\"
User=admin
Group=admin
Type=simple
KillMode=process
TimeoutSec=60
Restart=always
RestartSec=60
" | sudo tee -a /etc/systemd/system/certbot.service
sudo systemctl enable certbot.timer
# cleanup possible residual files from previous installs
# clean when installed as admin
sudo rm -f /home/admin/dotnet-sdk*
sudo rm -f /home/admin/dotnet-sdk*
sudo rm -f /home/admin/.nbxplorer/Main/settings.config sudo rm -f /home/admin/.nbxplorer/Main/settings.config
# cleanup previous installs
sudo rm -f /home/btcpay/dotnet-sdk*
sudo rm -f /home/btcpay/aspnetcore*
sudo rm -rdf /home/btcpay/dotnet
sudo rm -f /usr/local/bin/dotnet
sudo systemctl stop nbxplorer
sudo systemctl disable nbxplorer
sudo rm -f /home/btcpay/.nbxplorer/Main/settings.config
sudo rm -f /etc/systemd/system/nbxplorer.service sudo rm -f /etc/systemd/system/nbxplorer.service
sudo systemctl stop btcpayserver
sudo systemctl disable btcpayserver
sudo rm -f /home/btcpay/.btcpayserver/Main/settings.config
sudo rm -f /etc/systemd/system/btcpayserver.service sudo rm -f /etc/systemd/system/btcpayserver.service
sudo rm -f /home/admin/.btcpayserver/Main/settings.config
sudo rm -f /etc/nginx/sites-available/btcpayserver sudo rm -f /etc/nginx/sites-available/btcpayserver
#dotNET echo ""
echo "***"
echo "Installing .NET"
echo "***"
echo ""
cd /home/admin
wget https://download.visualstudio.microsoft.com/download/pr/9650e3a6-0399-4330-a363-1add761127f9/14d80726c16d0e3d36db2ee5c11928e4/dotnet-sdk-2.2.102-linux-arm.tar.gz
wget https://download.visualstudio.microsoft.com/download/pr/9d049226-1f28-4d3d-a4ff-314e56b223c5/f67ab05a3d70b2bff46ff25e2b3acd2a/aspnetcore-runtime-2.2.1-linux-arm.tar.gz
sudo mkdir /opt/dotnet
sudo apt-get -y install libunwind8 gettext libssl1.0 sudo apt-get -y install libunwind8 gettext libssl1.0
sudo tar -xvf dotnet-sdk-2.2.102-linux-arm.tar.gz -C /opt/dotnet/ sudo -u btcpay wget https://download.visualstudio.microsoft.com/download/pr/9650e3a6-0399-4330-a363-1add761127f9/14d80726c16d0e3d36db2ee5c11928e4/dotnet-sdk-2.2.102-linux-arm.tar.gz
sudo tar -xvf aspnetcore-runtime-2.2.1-linux-arm.tar.gz -C /opt/dotnet/ sudo -u btcpay wget https://download.visualstudio.microsoft.com/download/pr/9d049226-1f28-4d3d-a4ff-314e56b223c5/f67ab05a3d70b2bff46ff25e2b3acd2a/aspnetcore-runtime-2.2.1-linux-arm.tar.gz
sudo ln -s /opt/dotnet/dotnet /usr/local/bin sudo -u btcpay mkdir /home/btcpay/dotnet
dotnet --info sudo -u btcpay tar -xvf dotnet-sdk-2.2.102-linux-arm.tar.gz -C /home/btcpay/dotnet
sudo -u btcpay tar -xvf aspnetcore-runtime-2.2.1-linux-arm.tar.gz -C /home/btcpay/dotnet
sudo ln -s /home/btcpay/dotnet/dotnet /usr/local/bin
sudo -u btcpay /home/btcpay/dotnet/dotnet --info
echo "" echo ""
echo "***" echo "***"
@@ -91,10 +80,10 @@ echo "Installing NBXplorer"
echo "***" echo "***"
echo "" echo ""
cd /home/admin cd /home/btcpay
git clone https://github.com/dgarage/NBXplorer.git sudo -u btcpay git clone https://github.com/dgarage/NBXplorer.git
cd NBXplorer cd NBXplorer
./build.sh sudo -u btcpay ./build.sh
echo " echo "
[Unit] [Unit]
@@ -103,9 +92,9 @@ Requires=bitcoind.service
After=bitcoind.service After=bitcoind.service
[Service] [Service]
ExecStart=/usr/local/bin/dotnet \"/home/admin/NBXplorer/NBXplorer/bin/Release/netcoreapp2.1/NBXplorer.dll\" -c /home/admin/.nbxplorer/Main/settings.config ExecStart=/usr/local/bin/dotnet \"/home/btcpay/NBXplorer/NBXplorer/bin/Release/netcoreapp2.1/NBXplorer.dll\" -c /home/btcpay/.nbxplorer/Main/settings.config
User=admin User=btcpay
Group=admin Group=btcpay
Type=simple Type=simple
PIDFile=/run/nbxplorer/nbxplorer.pid PIDFile=/run/nbxplorer/nbxplorer.pid
Restart=on-failure Restart=on-failure
@@ -127,7 +116,7 @@ sudo systemctl start nbxplorer
echo "Checking for nbxplorer config" echo "Checking for nbxplorer config"
while [ ! -f "/home/admin/.nbxplorer/Main/settings.config" ] while [ ! -f "/home/btcpay/.nbxplorer/Main/settings.config" ]
do do
echo "Waiting for nbxplorer to start - CTRL+C to abort" echo "Waiting for nbxplorer to start - CTRL+C to abort"
sleep 10 sleep 10
@@ -138,12 +127,17 @@ echo "***"
echo "getting RPC credentials from the bitcoin.conf" echo "getting RPC credentials from the bitcoin.conf"
RPC_USER=$(sudo cat /mnt/hdd/bitcoin/bitcoin.conf | grep rpcuser | cut -c 9-) 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-) PASSWORD_B=$(sudo cat /mnt/hdd/bitcoin/bitcoin.conf | grep rpcpassword | cut -c 13-)
chmod 600 /home/admin/.nbxplorer/Main/settings.config || exit 1 #sudo mv /home/btcpay/.nbxplorer/Main/settings.config /home/admin/settings.config
cat >> /home/admin/.nbxplorer/Main/settings.config <<EOF #sudo chown admin:admin /home/admin/settings.config
mv /home/btcpay/.nbxplorer/Main/settings.config /home/btcpay/.nbxplorer/Main/settings.config.backup
touch /home/admin/settings.config
sudo chmod 600 /home/admin/settings.config || exit 1
cat >> /home/admin/settings.config <<EOF
btc.rpc.user=raspibolt btc.rpc.user=raspibolt
btc.rpc.password=$PASSWORD_B btc.rpc.password=$PASSWORD_B
EOF EOF
sudo mv /home/admin/settings.config /home/btcpay/.nbxplorer/Main/settings.config
sudo chown btcpay:btcpay /home/btcpay/.nbxplorer/Main/settings.config
sudo systemctl restart nbxplorer sudo systemctl restart nbxplorer
echo "" echo ""
@@ -152,10 +146,10 @@ echo "Installing BTCPayServer"
echo "***" echo "***"
echo "" echo ""
cd /home/admin cd /home/btcpay
git clone https://github.com/btcpayserver/btcpayserver.git sudo -u btcpay git clone https://github.com/btcpayserver/btcpayserver.git
cd btcpayserver btcpay cd btcpayserver
./build.sh sudo -u btcpay ./build.sh
echo " echo "
[Unit] [Unit]
@@ -164,9 +158,9 @@ Requires=btcpayserver.service
After=nbxplorer.service After=nbxplorer.service
[Service] [Service]
ExecStart=/usr/local/bin/dotnet run --no-launch-profile --no-build -c Release -p \"/home/admin/btcpayserver/BTCPayServer/BTCPayServer.csproj\" -- \$@ ExecStart=/usr/local/bin/dotnet run --no-launch-profile --no-build -c Release -p \"/home/btcpay/btcpayserver/BTCPayServer/BTCPayServer.csproj\" -- \$@
User=admin User=btcpay
Group=admin Group=btcpay
Type=simple Type=simple
PIDFile=/run/btcpayserver/btcpayserver.pid PIDFile=/run/btcpayserver/btcpayserver.pid
Restart=on-failure Restart=on-failure
@@ -180,8 +174,10 @@ sudo systemctl enable btcpayserver
sudo systemctl start btcpayserver sudo systemctl start btcpayserver
# set thumbprint # set thumbprint
FINGERPRINT=$(openssl x509 -noout -fingerprint -sha256 -inform pem -in ~/.lnd/tls.cert | cut -c 20-) FINGERPRINT=$(openssl x509 -noout -fingerprint -sha256 -inform pem -in /home/admin/.lnd/tls.cert | cut -c 20-)
sudo cp /mnt/hdd/lnd/data/chain/bitcoin/mainnet/admin.macaroon /home/btcpay/admin.macaroon
sudo chown btcpay:btcpay /home/btcpay/admin.macaroon
sudo chmod 600 /home/btcpay/admin.macaroon
echo " echo "
### Global settings ### ### Global settings ###
network=mainnet network=mainnet
@@ -193,14 +189,26 @@ externalurl=https://$YOUR_DOMAIN
### NBXplorer settings ### ### NBXplorer settings ###
BTC.explorer.url=http://127.0.0.1:24444/ BTC.explorer.url=http://127.0.0.1:24444/
BTC.lightning=type=lnd-rest;server=https://127.0.0.1:8080/;macaroonfilepath=/home/admin/.lnd/data/chain/bitcoin/mainnet/admin.macaroon;certthumbprint=$FINGERPRINT BTC.lightning=type=lnd-rest;server=https://127.0.0.1:8080/;macaroonfilepath=/home/btcpay/admin.macaroon;certthumbprint=$FINGERPRINT
" | sudo tee -a /home/admin/.btcpayserver/Main/settings.config " | sudo -u btcpay tee -a /home/btcpay/.btcpayserver/Main/settings.config
sudo systemctl restart btcpayserver sudo systemctl restart btcpayserver
echo ""
echo "***"
echo "Setting up Nginx and Certbot"
echo "***"
echo ""
# install nginx and certbot
sudo apt-get install nginx-full certbot -y
sudo ufw allow 80 sudo ufw allow 80
sudo ufw allow 443 sudo ufw allow 443
# get SSL cert
sudo certbot certonly -a standalone -m $YOUR_EMAIL --agree-tos -d $YOUR_DOMAIN --pre-hook "service nginx stop" --post-hook "service nginx start"
# set nginx # set nginx
sudo rm -f /etc/nginx/sites-enabled/default sudo rm -f /etc/nginx/sites-enabled/default
@@ -291,5 +299,45 @@ sudo ln -s /etc/nginx/sites-available/btcpayserver /etc/nginx/sites-enabled/
sudo systemctl restart nginx sudo systemctl restart nginx
echo ""
echo "***"
echo "Setting up certbot-auto renewal service"
echo "***"
echo ""
sudo rm -f /etc/systemd/system/certbot.timer
echo "
[Unit]
Description=Certbot-auto renewal service
[Timer]
OnBootSec=20min
OnCalendar=*-*-* 4:00:00
[Install]
WantedBy=timers.target
" | sudo tee -a /etc/systemd/system/certbot.timer
sudo rm -f /etc/systemd/system/certbot.service
echo "
[Unit]
Description=Certbot-auto renewal service
After=bitcoind.service
[Service]
WorkingDirectory=/home/admin/
ExecStart=sudo certbot renew --pre-hook \"service nginx stop\" --post-hook \"service nginx start\"
User=admin
Group=admin
Type=simple
KillMode=process
TimeoutSec=60
Restart=always
RestartSec=60
" | sudo tee -a /etc/systemd/system/certbot.service
sudo systemctl enable certbot.timer
echo "" echo ""
echo "Visit your BTCpayServer instance on https://$YOUR_DOMAIN" echo "Visit your BTCpayServer instance on https://$YOUR_DOMAIN"