#!/bin/bash
## get basic info
source /home/admin/raspiblitz.info
source /mnt/hdd/raspiblitz.conf
# CHECK #########
echo "*** Check Basic Config ***"
if [ ${# network } -eq 0 ] ; then
echo "FAIL - missing: network"
exit 1
fi
if [ ${# chain } -eq 0 ] ; then
echo "FAIL - missing: chain"
exit 1
fi
# CHECK #########
echo " *** Check ${ network } Running *** "
bitcoinRunning = $( systemctl status ${ network } d.service 2>/dev/null | grep -c running)
if [ ${ bitcoinRunning } -eq 0 ] ; then
bitcoinRunning = $( sudo -u bitcoin ${ network } -cli -datadir= /home/bitcoin/.${ network } getblockchaininfo | grep -c verificationprogress)
fi
if [ ${ bitcoinRunning } -eq 0 ] ; then
whiptail --title "70initLND - WARNING" --yes-button "Retry" --no-button "EXIT+Logs" --yesno " Service ${ network } d is not running. " 8 50
if [ $? -eq 0 ] ; then
/home/admin/70initLND.sh
else
/home/admin/XXdebugLogs.sh
fi
exit 1
fi
# CHECK #########
echo " *** Check ${ network } Responding *** "
chainIsReady = 0
loopCount = 0
while [ ${ chainIsReady } -eq 0 ]
do
loopCount = $(( $loopCount + 1 ))
result = $( sudo -u bitcoin ${ network } -cli -datadir= /home/bitcoin/.${ network } getblockchaininfo 2>error.out)
error = ` cat error.out`
rm error.out
if [ ${# error } -gt 0 ] ; then
if [ ${ loopCount } -gt 33 ] ; then
echo "*** TAKES LONGER THEN EXCEPTED ***"
date +%s
echo " result( ${ result } ) "
echo " error( ${ error } ) "
testnetAdd = ""
if [ " ${ chain } " = "test" ] ; then
testnetAdd = "testnet3/"
fi
sudo tail -n 5 /mnt/hdd/${ network } /${ testnetAdd } debug.log
echo "If you see an error -28 relax, just give it some time."
echo "Waiting 1 minute and then trying again ..."
sleep 60
else
echo " ( ${ loopCount } /33) still waiting .. "
sleep 10
fi
else
echo "OK - chainnetwork is working"
echo ""
chainIsReady = 1
break
fi
done
# CHECK #########
echo "*** Check LND Config ***"
configExists = $( sudo ls /mnt/hdd/lnd/ | grep -c lnd.conf )
if [ ${ configExists } -eq 0 ] ; then
sudo cp /home/admin/assets/lnd.${ network } .conf /mnt/hdd/lnd/lnd.conf
sudo chown bitcoin:bitcoin /mnt/hdd/lnd/lnd.conf
if [ -d /home/bitcoin/.lnd ] ; then
echo "OK - LND config written"
else
echo "FAIL - Was not able to setup LND"
exit 1
fi
else
echo "OK - exists"
fi
echo ""
###### Start LND
echo "*** Starting LND ***"
lndRunning = $( sudo systemctl status lnd.service 2>/dev/null | grep -c running)
if [ ${ lndRunning } -eq 0 ] ; then
sed -i " 5s/.*/Wants= ${ network } d.service/ " ./assets/lnd.service
sed -i " 6s/.*/After= ${ network } d.service/ " ./assets/lnd.service
sudo cp /home/admin/assets/lnd.service /etc/systemd/system/lnd.service
sudo chmod +x /etc/systemd/system/lnd.service
sudo systemctl enable lnd
sudo systemctl start lnd
echo ""
dialog --pause " Starting LND - please wait .." 8 58 120
fi
###### Check LND starting
while [ ${ lndRunning } -eq 0 ]
do
lndRunning = $( sudo systemctl status lnd.service | grep -c running)
if [ ${ lndRunning } -eq 0 ] ; then
date +%s
echo "LND not ready yet ... waiting another 60 seconds."
echo "If this takes too long (more then 10min total) --> CTRL+c and report Problem"
sleep 60
fi
done
echo "OK - LND is running"
echo ""
###### Check LND health/fails (to be extended)
fail = ""
tlsExists = $( sudo ls /mnt/hdd/lnd/tls.cert 2>/dev/null | grep -c "tls.cert" )
if [ ${ tlsExists } -eq 0 ] ; then
fail = "LND was starting, but missing /mnt/hdd/lnd/tls.cert"
fi
if [ ${# fail } -gt 0 ] ; then
whiptail --title "70initLND - WARNING" --yes-button "Retry" --no-button "EXIT+Logs" --yesno " ${ fail } " 8 50
if [ $? -eq 0 ] ; then
/home/admin/70initLND.sh
else
/home/admin/XXdebugLogs.sh
fi
exit 1
fi
###### Instructions on Creating/Restoring LND Wallet
walletExists = $( sudo ls /mnt/hdd/lnd/data/chain/${ network } /${ chain } net/wallet.db 2>/dev/null | grep wallet.db -c)
echo " walletExists( ${ walletExists } ) "
sleep 2
if [ ${ walletExists } -eq 0 ] ; then
# UI: Ask if user wants NEW wallet or RECOVER a wallet
OPTIONS = ( NEW "Setup a brand new Lightning Node (DEFAULT)" \
OLD "I had a old Node I want to recover/restore" )
CHOICE = $( dialog --backtitle "RaspiBlitz" --clear --title "LND Setup" --menu "LND Data & Wallet" 11 60 6 " ${ OPTIONS [@] } " 2>& 1 >/dev/tty)
echo " choice( $CHOICE ) "
if [ " ${ CHOICE } " = = "NEW" ] ; then
# let user enter password c
sudo shred /home/admin/.pass.tmp 2>/dev/null
sudo ./config.scripts/blitz.setpassword.sh x "Set your Password C for the LND Wallet Unlock" /home/admin/.pass.tmp
passwordC = ` sudo cat /home/admin/.pass.tmp`
sudo shred /home/admin/.pass.tmp 2>/dev/null
# make sure passwordC is set
if [ ${# passwordC } -eq 0 ] ; then
/home/admin/70initLND.sh
exit 1
fi
# generate wallet with seed and set passwordC
echo "Generating new Wallet ...."
source /home/admin/python-env-lnd/bin/activate
python /home/admin/config.scripts/lnd.initwallet.py new ${ passwordC } > /home/admin/.seed.tmp
source /home/admin/.seed.tmp
sudo shred /home/admin/.pass.tmp 2>/dev/null
# in case of error - retry
if [ ${# err } -gt 0 ] ; then
whiptail --title "lnd.initwallet.py - ERROR" --msgbox " ${ err } " 8 50
/home/admin/70initLND.sh
exit 1
else
if [ ${# seedwords } -eq 0 ] ; then
echo "FAIL!! -> MISSING seedwords data - but also no err data ?!?"
echo "CHECK output data above - PRESS ENTER to restart 70initLND.sh"
read key
/home/admin/70initLND.sh
exit 1
fi
fi
if [ ${# seedwords6x4 } -eq 0 ] ; then
seedwords6x4 = " ${ seedwords } "
fi
ack = 0
while [ ${ ack } -eq 0 ]
do
whiptail --title "IMPORTANT SEED WORDS - PLEASE WRITE DOWN" --msgbox " LND Wallet got created. Store these numbered words in a safe location:\n\n ${ seedwords6x4 } " 12 76
whiptail --title "Please Confirm" --yes-button "Show Again" --no-button "CONTINUE" --yesno " Are you sure that you wrote down the word list?" 8 55
if [ $? -eq 1 ] ; then
ack = 1
fi
done
sudo sed -i "s/^setupStep=.*/setupStep=65/g" /home/admin/raspiblitz.info
else
OPTIONS = ( LNDRESCUE "LND tar.gz-Backupfile (BEST)" \
SEED_SCB "Seed & channel.backup file (OK)" \
ONLYSEED "Only Seed Word List (FALLBACK)" )
CHOICE = $( dialog --backtitle "RaspiBlitz" --clear --title "RECOVER LND DATA & WALLET" --menu "Data you have to recover from?" 11 60 6 " ${ OPTIONS [@] } " 2>& 1 >/dev/tty)
echo " choice( $CHOICE ) "
if [ " ${ CHOICE } " = = "SEED_SCB" ] ; then
# dialog to enter
dialog --backtitle "RaspiBlitz - LND Recover" --inputbox "Please enter/paste the SEED WORD LIST:\n(just the words, seperated by commas, in correct order as numbered)" 9 78 2>/home/admin/.seed.tmp
wordstring = $( cat /home/admin/.seed.tmp | tr -dc '[:alnum:]-.' | tr -d ' ' )
shred /home/admin/.seed.tmp
echo " processing ... ${ wordstring } "
# remove spaces
wordstring = $( echo " ${ wordstring } " | sed 's/[^a-zA-Z0-9 ]//g' )
# string to array
IFS = ',' read -r -a seedArray <<< " $wordstring "
# check array
if [ ${# seedArray [@] } -eq 24 ] ; then
echo "OK - 24 words"
exit 1
else
echo "wrong number of words"
wordstring = ""
exit 1
fi
fi
if [ " ${ CHOICE } " = = "ONLYSEED" ] ; then
echo "TODO: ONLYSEED"
exit 1
elif [ " ${ CHOICE } " = = "SEED_SCB" ] ; then
echo "TODO: SEED+SCB"
exit 1
elif [ " ${ CHOICE } " = = "LNDRESCUE" ] ; then
sudo /home/admin/config.scripts/lnd.rescue.sh restore
echo ""
echo "PRESS ENTER to continue."
read key
/home/admin/70initLND.sh
exit 1
else
echo "CANCEL"
/home/admin/70initLND.sh
exit 1
fi
# TODO: IMPLEMENT
# - Recover with Seed Word List
# --> (ask if seed word list was password D protected)
# - Recover with Seed Word List & channel.backup file
# --> (ask if seed word list was password D protected)
# - Restore LND backup made with Rescue-Script (tar.gz-file)
# --> run retsore script
# FALLBACK TO lncli create FOR NOW
#dialog --title "OK" --msgbox "\nI will start 'lncli create' for you ..." 7 44
#sudo -u bitcoin /usr/local/bin/lncli --chain=${network} create
#/home/admin/70initLND.sh
fi
else
echo "OK - LND wallet already exists."
fi
dialog --pause " Waiting for LND - please wait .." 8 58 60
###### Copy LND macaroons to admin
echo ""
echo "*** Copy LND Macaroons to user admin ***"
macaroonExists = $( sudo -u bitcoin ls -la /home/bitcoin/.lnd/data/chain/${ network } /${ chain } net/admin.macaroon 2>/dev/null | grep -c admin.macaroon)
if [ ${ macaroonExists } -eq 0 ] ; then
./AAunlockLND.sh
sleep 3
fi
macaroonExists = $( sudo -u bitcoin ls -la /home/bitcoin/.lnd/data/chain/${ network } /${ chain } net/admin.macaroon 2>/dev/null | grep -c admin.macaroon)
if [ ${ macaroonExists } -eq 0 ] ; then
sudo -u bitcoin ls -la /home/bitcoin/.lnd/data/chain/${ network } /${ chain } net/admin.macaroon
echo ""
echo "FAIL - LND Macaroons not created"
echo "Please check the following LND issue:"
echo "https://github.com/lightningnetwork/lnd/issues/890"
echo "You may want try again with starting ./70initLND.sh"
exit 1
fi
macaroonExists = $( sudo ls -la /home/admin/.lnd/data/chain/${ network } /${ chain } net/ | grep -c admin.macaroon)
if [ ${ macaroonExists } -eq 0 ] ; then
sudo mkdir /home/admin/.lnd
sudo mkdir /home/admin/.lnd/data
sudo mkdir /home/admin/.lnd/data/chain
sudo mkdir /home/admin/.lnd/data/chain/${ network }
sudo mkdir /home/admin/.lnd/data/chain/${ network } /${ chain } net
sudo cp /home/bitcoin/.lnd/tls.cert /home/admin/.lnd
sudo cp /home/bitcoin/.lnd/lnd.conf /home/admin/.lnd
sudo cp /home/bitcoin/.lnd/data/chain/${ network } /${ chain } net/admin.macaroon /home/admin/.lnd/data/chain/${ network } /${ chain } net
sudo chown -R admin:admin /home/admin/.lnd/
echo "OK - LND Macaroons created"
echo ""
else
echo "OK - Macaroons are already copied"
echo ""
fi
###### Unlock Wallet (if needed)
echo "*** Check Wallet Lock ***"
locked = $( sudo tail -n 1 /mnt/hdd/lnd/logs/${ network } /${ chain } net/lnd.log | grep -c unlock)
if [ ${ locked } -gt 0 ] ; then
echo "OK - Wallet is locked ... starting unlocking dialog"
./AAunlockLND.sh
else
echo "OK - Wallet is already unlocked"
fi
# set SetupState (scan is done - so its 80%)
sudo sed -i "s/^setupStep=.*/setupStep=80/g" /home/admin/raspiblitz.info
###### finishSetup
sudo ./90finishSetup.sh
sudo ./95finalSetup.sh