Browse Source

merged and extended pr33

#146
rootzoll 7 years ago
parent
commit
e27395dccc
  1. 2
      home.admin/00infoLCD.sh
  2. 25
      home.admin/00mainMenu.sh
  3. 15
      home.admin/70initLND.sh
  4. 116
      home.admin/95switchMainTest.sh
  5. 52
      home.admin/95switchNetEnv.sh
  6. 53
      home.admin/BBcloseAllChannels.sh
  7. 11
      home.admin/BBfundWallet.sh

2
home.admin/00infoLCD.sh

@ -87,7 +87,7 @@ if [ "$USER" = "pi" ]; then
# RaspiBlitz is full Setup # RaspiBlitz is full Setup
chain=$(sudo -u bitcoin ${network}-cli -datadir=/home/bitcoin/.${network} getblockchaininfo | jq -r '.chain') chain=$(sudo -u bitcoin ${network}-cli -datadir=/home/bitcoin/.${network} getblockchaininfo | jq -r '.chain')
locked=$(sudo tail -n 1 /mnt/hdd/lnd/logs/${network}/${chain}net/lnd.log | grep -c unlock) locked=$(sudo tail -n 1 /mnt/hdd/lnd/logs/${network}/${chain}net/lnd.log 2>/dev/null | grep -c unlock)
if [ ${locked} -gt 0 ]; then if [ ${locked} -gt 0 ]; then
# special case: LND wallet is locked ---> show unlock info # special case: LND wallet is locked ---> show unlock info

25
home.admin/00mainMenu.sh

@ -56,18 +56,24 @@ else
# LOCK SCREEN # LOCK SCREEN
MENU="!!! YOUR WALLET IS LOCKED !!!" MENU="!!! YOUR WALLET IS LOCKED !!!"
OPTIONS+=(X "Unlock your Lightning Wallet with 'lncli unlock'") OPTIONS+=(U "Unlock your Lightning Wallet with 'lncli unlock'")
else else
chain=$(${network}-cli -datadir=/home/bitcoin/.${network} getblockchaininfo | jq -r '.chain')
switchOption="to MAINNET"
if [ "${chain}" = "test" ]; then
switchOption="back to TESTNET"
fi
# REGULAR MENU # REGULAR MENU
OPTIONS+=(INFO "RaspiBlitz Status Screen" \ OPTIONS+=(INFO "RaspiBlitz Status Screen" \
FUNDING "Fund your Wallet" \ FUNDING "Fund your Wallet" \
CONNECT "Connect to a Peer" \ CONNECT "Connect to a Peer" \
lnbalance "Detailed Wallet Balances" \ lnbalance "Detailed Wallet Balances" \
lnchannels "Lightning Channel List" \ lnchannels "Lightning Channel List" \
RECKLES "Console / Terminal"\ SWITCH "Switch ${switchOption}"
REKT "Go Reckless! Switch Testnet/Mainnet") X "Console / Terminal")
fi fi
@ -130,14 +136,17 @@ case $CHOICE in
read key read key
./00mainMenu.sh ./00mainMenu.sh
;; ;;
RECKLES) SWITCH)
sudo ./95switchMainTest.sh
echo "Press ENTER to return to main menu."
read key
./00mainMenu.sh
;;
X)
lncli -h lncli -h
echo "SUCH WOW come back with ./00mainMenu.sh" echo "SUCH WOW come back with ./00mainMenu.sh"
;; ;;
REKT) # switch configs U) # unlock
sudo ./95switchNetEnv.sh;
;;
X) # unlock
./AAunlockLND.sh ./AAunlockLND.sh
./00mainMenu.sh ./00mainMenu.sh
;; ;;

15
home.admin/70initLND.sh

@ -4,6 +4,9 @@ echo ""
# load network # load network
network=`cat .network` network=`cat .network`
# get chain
chain=$(${network}-cli -datadir=/home/bitcoin/.${network} getblockchaininfo | jq -r '.chain')
# verify that bitcoin is running # verify that bitcoin is running
echo "*** Checking ${network} ***" echo "*** Checking ${network} ***"
bitcoinRunning=$(sudo -u bitcoin ${network}-cli getblockchaininfo | grep -c blocks) bitcoinRunning=$(sudo -u bitcoin ${network}-cli getblockchaininfo | grep -c blocks)
@ -71,8 +74,8 @@ if [ ${lndRunning} -eq 0 ]; then
sudo cp /home/admin/assets/lnd.service /etc/systemd/system/lnd.service sudo cp /home/admin/assets/lnd.service /etc/systemd/system/lnd.service
sudo systemctl enable lnd sudo systemctl enable lnd
sudo systemctl start lnd sudo systemctl start lnd
echo "Started LND .. waiting 30 seconds for init ..." echo "Started LND .. waiting 60 seconds for init ..."
sleep 30 sleep 60
fi fi
###### Check LND is running ###### Check LND is running
@ -88,9 +91,8 @@ echo "OK - LND is running"
echo "" echo ""
###### Instructions on Creating LND Wallet ###### Instructions on Creating LND Wallet
setupStep=0 walletExists=$(sudo ls /mnt/hdd/lnd/data/chain/${network}/${cahin}net/wallet.db 2>/dev/null | grep wallet.db -c)
setupStep=$(sudo cat "/home/admin/.setup") if [ ${walletExists} -eq 0 ]; then
if [ ${setupStep} -lt 65 ]; then
# setup state signals, that no wallet has been created yet # setup state signals, that no wallet has been created yet
dialog --backtitle "RaspiBlitz - LND Lightning Wallet" --msgbox " dialog --backtitle "RaspiBlitz - LND Lightning Wallet" --msgbox "
${network} and Lighthing Services are installed. ${network} and Lighthing Services are installed.
@ -122,6 +124,7 @@ Press OK and follow the 'Helping Instructions'.
# set SetupState to 75 (mid thru this process) # set SetupState to 75 (mid thru this process)
echo "65" > /home/admin/.setup echo "65" > /home/admin/.setup
fi fi
echo "--> lets wait 30 seconds for LND to get ready" echo "--> lets wait 30 seconds for LND to get ready"
sleep 30 sleep 30
@ -150,7 +153,6 @@ fi
###### Unlock Wallet (if needed) ###### Unlock Wallet (if needed)
echo "*** Check Wallet Lock ***" echo "*** Check Wallet Lock ***"
chain=$(${network}-cli -datadir=/home/bitcoin/.${network} getblockchaininfo | jq -r '.chain')
locked=$(sudo tail -n 1 /mnt/hdd/lnd/logs/${network}/${chain}net/lnd.log | grep -c unlock) locked=$(sudo tail -n 1 /mnt/hdd/lnd/logs/${network}/${chain}net/lnd.log | grep -c unlock)
if [ ${locked} -gt 0 ]; then if [ ${locked} -gt 0 ]; then
echo "OK - Wallet is locked ... starting unlocking dialog" echo "OK - Wallet is locked ... starting unlocking dialog"
@ -163,7 +165,6 @@ fi
echo "" echo ""
echo "*** Check LND Sync ***" echo "*** Check LND Sync ***"
item=0 item=0
chain="$(${network}-cli -datadir=/home/bitcoin/.${network} getblockchaininfo | jq -r '.chain')"
lndSyncing=$(sudo -u bitcoin lncli getinfo | jq -r '.synced_to_chain' | grep -c true) lndSyncing=$(sudo -u bitcoin lncli getinfo | jq -r '.synced_to_chain' | grep -c true)
if [ ${lndSyncing} -eq 0 ]; then if [ ${lndSyncing} -eq 0 ]; then
echo "OK - wait for LND to be synced" echo "OK - wait for LND to be synced"

116
home.admin/95switchMainTest.sh

@ -0,0 +1,116 @@
#!/usr/bin/env bash
# based on pull request from vnnkl
# load network
network=`cat .network`
echo ""
echo "*** Switch between Testnet/Mainnet ***"
# allow only on bitcoin network
if [ "${network}" = "bitcoin" ]; then
echo "Bitcoin network can be switched between testnet/mainnet ..."
else
echo "FAIL - Only Bitcoin Network can be switched between man/tast at the moment."
exit 1
fi
NETWORK_CONFIG="/home/bitcoin/.${network}/${network}.conf"
NETWORK_TEMPLATE="/home/admin/assets/${network}.conf"
LND_CONFIG="/home/bitcoin/.lnd/lnd.conf"
LND_TEMPLATE="/home/admin/assets/lnd.${network}.conf"
echo "NETWORK_CONFIG(${NETWORK_CONFIG})"
echo "LND_CONFIG(${LND_CONFIG})"
echo "NETWORK_TEMPLATE(${NETWORK_TEMPLATE})"
echo "LND_TEMPLATE(${LND_TEMPLATE})"
# function to detect main/testnet
function isMainnet(){
grep "^#testnet=1$" -q $NETWORK_CONFIG && return 1
return 0
}
function switchToMainnet {
echo "switching to mainnet"
sed -i 's/^testnet=1/#testnet=1/g' $NETWORK_CONFIG
sed -i 's/^testnet=1/#testnet=1/g' $NETWORK_TEMPLATE
sed -i 's/^${network}.testnet=1/#${network}.testnet=1/g' $LND_CONFIG
sed -i 's/^#${network}.mainnet=1/${network}.mainnet=1/g' $LND_CONFIG
sed -i 's/^${network}.testnet=1/#${network}.testnet=1/g' $LND_TEMPLATE
sed -i 's/^#${network}.mainnet=1/${network}.mainnet=1/g' $LND_TEMPLATE
echo "OK switched to mainnet"
}
function switchToTestnet {
echo "switching to testnet"
sed -i 's/^#testnet=1/testnet=1/g' $NETWORK_CONFIG
sed -i 's/^#testnet=1/testnet=1/g' $NETWORK_TEMPLATE
sed -i 's/^#${network}.testnet=1/${network}.testnet=1/g' $LND_CONFIG
sed -i 's/^${network}.mainnet=1/#${network}.mainnet=1/g' $LND_CONFIG
sed -i 's/^#${network}.testnet=1/${network}.testnet=1/g' $LND_TEMPLATE
sed -i 's/^${network}.mainnet=1/#${network}.mainnet=1/g' $LND_TEMPLATE
echo "OK switched to testnet"
}
# LND Service
lndInstalled=$(systemctl status lnd.service | grep loaded -c)
if [ ${lndInstalled} -gt 0 ]; then
echo "check for open channels"
openChannels=$(lncli listchannels 2>/dev/null | grep chan_id -c)
if [ ${openChannels} -gt 0 ]; then
echo "FAIL - You have still open channels and could loose funds !! - close those first with lncli closeallchannels"
exit 1
else
echo "no open channels found"
fi
echo "stopping lnd client"
systemctl stop lnd
sleep 4
else
echo "LND not running"
fi
# NETWORK Service
networkInstalled=$(systemctl status ${network}d.service | grep loaded -c)
if [ ${networkInstalled} -gt 0 ]; then
echo "stopping bitcoind client"
systemctl stop bitcoind
sleep 4
else
echo "Network ${network} not running"
fi
# TURN THE SWITCH
isMainnet
if [ $? -eq 1 ]; then
echo "switching from mainnet to testnet"
switchToTestnet
else
echo "switching from testnet to mainnet"
switchToMainnet
fi
echo "copying over config to bitcoin user"
cp $NETWORK_CONFIG /home/admin/.${network}/
# restarting network
if [ ${networkInstalled} -gt 0 ]; then
# start network
systemctl start bitcoind
echo "started ${network}d back up, giving it a 120 SECONDS to prepare"
sleep 120
# set setup info again
echo "60" > /home/admin/.setup
# run again the complete LND init procedure
./70initLND.sh
else
echo "No starting of network, because it was not running before"
fi

52
home.admin/95switchNetEnv.sh

@ -1,52 +0,0 @@
#!/usr/bin/env bash
BITCOIN_CONFIG="/home/bitcoin/.bitcoin/bitcoin.conf"
LND_CONFIG="/home/bitcoin/.lnd/lnd.conf"
# function to detect main/testnet
function isMainnet(){
grep "^#testnet=1$" -q $BITCOIN_CONFIG && return 1
return 0
}
function switchToMainnet {
echo "switching to mainnet"
sed -i 's/^testnet=1/#testnet=1/g' $BITCOIN_CONFIG && \
sed -i 's/^bitcoin.testnet=1/#bitcoin.testnet=1/g' $LND_CONFIG && \
sed -i 's/^#bitcoin.mainnet=1/bitcoin.mainnet=1/g' $LND_CONFIG
echo "switched to mainnet"
}
function switchToTestnet {
echo "switching to testnet"
sed -i 's/^#testnet=1/testnet=1/g' $BITCOIN_CONFIG && \
sed -i 's/^#bitcoin.testnet=1/bitcoin.testnet=1/g' $LND_CONFIG && \
sed -i 's/^bitcoin.mainnet=1/#bitcoin.mainnet=1/g' $LND_CONFIG
echo "switched to testnet"
}
# change to test: check both configs for commented out testnet arguments and mainnet
echo "stopping lnd client"
systemctl stop lnd
sleep 4
echo "stopping bitcoind client"
systemctl stop bitcoind
sleep 4
isMainnet
if [ $? -eq 1 ]; then
echo "switching from mainnet to testnet"
switchToTestnet
else
echo "switching from testnet to mainnet"
switchToMainnet
fi
echo "copying over config to bitcoin user"
cp $BITCOIN_CONFIG /home/admin/.bitcoin/
systemctl start bitcoind
echo "started bitcoind back up, giving it a minute to come up"
sleep 60
systemctl start lnd
echo "started lnd back up, giving it a minute, you will have to unlock your wallet"
sleep 60
echo "finished config switch - started back up"
echo "you will still have to unlock your LND wallet"
./00mainMenu.sh

53
home.admin/BBcloseAllChannels.sh

@ -0,0 +1,53 @@
#!/bin/bash
# load network and chain info
network=`cat .network`
chain=$(${network}-cli -datadir=/home/bitcoin/.${network} getblockchaininfo | jq -r '.chain')
command="lncli closeallchannels -f"
clear
echo "***********************************"
echo "Closing All Channels (EXPERIMENTAL)"
echo "***********************************"
echo ""
echo "COMMAND LINE: "
echo $command
echo ""
echo "RESULT:"
# PRECHECK) check if chain is in sync
chainInSync=$(lncli getinfo | grep '"synced_to_chain": true' -c)
if [ ${chainInSync} -eq 0 ]; then
command=""
result="FAIL PRECHECK - lncli getinfo shows 'synced_to_chain': false - wait until chain is sync "
fi
# TODO PRECHECK) are any channels open at all
# TODO PRECHECK) are there INACTIVE channels that would need a force close (and manual YES)
# remember that for info below
# execute command
if [ ${#command} -gt 0 ]; then
result=$($command)
fi
# on no result TODO: check if there is any result at all
if [ ${#result} -eq 0 ]; then
echo "Sorry something went wrong - thats unusual."
echo ""
exit 1
fi
# when result is available
echo "$result"
# TODO parse out closing transactions and monitor those with blockchain for confirmations
# TODO give final info - let user know if its now safe to update RaspiBlitz or change test/main
# ask to make sure user has list for seed words still safe
echo ""
echo "******************************"
echo "INFO"
echo "******************************"

11
home.admin/BBfundWallet.sh

@ -2,7 +2,7 @@
# load network and chain info # load network and chain info
network=`cat .network` network=`cat .network`
chain=$(${network}-cli -datadir=/home/bitcoin/.${network} getblockchaininfo 2>/dev/null | jq -r '.chain') chain=$(${network}-cli -datadir=/home/bitcoin/.${network} getblockchaininfo | jq -r '.chain')
command="lncli newaddress np2wkh" command="lncli newaddress np2wkh"
@ -16,8 +16,17 @@ echo $command
echo "" echo ""
echo "RESULT:" echo "RESULT:"
# PRECHECK) check if chain is in sync
chainInSync=$(lncli getinfo | grep '"synced_to_chain": true' -c)
if [ ${chainInSync} -eq 0 ]; then
command=""
result="FAIL PRECHECK - lncli getinfo shows 'synced_to_chain': false - wait until chain is sync "
fi
# execute command # execute command
if [ ${#command} -gt 0 ]; then
result=$($command) result=$($command)
fi
# on no result # on no result
if [ ${#result} -eq 0 ]; then if [ ${#result} -eq 0 ]; then

Loading…
Cancel
Save