Browse Source

switched on lnd.initwallet.py

master
Christian Rotzoll 6 years ago
parent
commit
3b00d72378
  1. 2
      build_sdcard.sh
  2. 248
      home.admin/70initLND.sh
  3. 10
      home.admin/config.scripts/lnd.initwallet.py

2
build_sdcard.sh

@ -538,7 +538,7 @@ sudo update-alternatives --install /usr/bin/python python /usr/bin/python2.7 2
sudo update-alternatives --install /usr/bin/python python /usr/bin/python3.5 1 sudo update-alternatives --install /usr/bin/python python /usr/bin/python3.5 1
echo "to switch between python2/3: sudo update-alternatives --config python" echo "to switch between python2/3: sudo update-alternatives --config python"
sudo apt-get -f -y install virtualenv sudo apt-get -f -y install virtualenv
sudo -u admin bash -c "cd; virtualenv python-env-lnd; source /home/admin/python-env-lnd/bin/activate; pip install grpcio grpcio-tools googleapis-common-protos" sudo -u admin bash -c "cd; virtualenv python-env-lnd; source /home/admin/python-env-lnd/bin/activate; pip install grpcio grpcio-tools googleapis-common-protos pathlib2"
echo "" echo ""
# Go is needed for ZAP connect later # Go is needed for ZAP connect later

248
home.admin/70initLND.sh

@ -241,90 +241,9 @@ or having a complete LND rescue-backup from your old node.
fi fi
fi fi
clear # IF SEED and SCB - make user upload channel.backup file now
# and it will get automated activated after syns are ready
##### DEACTIVATED UNTIL config.scripts/lnd.initwallet.py WORKS # TODO: later activate directly with call to lnd.iniwallet.py
# # let user enter password c
# sudo shred /home/admin/.pass.tmp 2>/dev/null
# sudo /home/admin/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
#
# # get seed word list
# if [ "${CHOICE}" == "SEED+SCB" ] || [ "${CHOICE}" == "ONLYSEED" ]; 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 | sed 's/[^a-zA-Z0-9,]//g' )
# shred /home/admin/.seed.tmp
# echo "processing ... ${wordstring}"
#
# # check correct number of words
# IFS=',' read -r -a seedArray <<< "$wordstring"
# if [ ${#seedArray[@]} -eq 24 ]; then
# echo "OK - 24 words"
# else
# whiptail --title " WARNING " --msgbox "
#The word list has ${#seedArray[@]} words. But it must be 24.
#Please check your list and try again.
#
#Best is to write words in external editor
#and then copy and paste them into dialog.
#
#The Word list should look like this:
#wordone,wordtweo,wordthree, ...
#
#" 16 52
# /home/admin/70initLND.sh
# exit 1
# fi
#
# # ask if seed was protected by password D
# passwordD=""
# dialog --title "SEED PASSWORD" --yes-button "No extra Password" --no-button "Yes" --yesno "
#Are your seed words protected by an extra password?
#
#During wallet creation LND offers to set an extra password
#to protect the seed words. Most users did not set this.
# " 11 65
# if [ $? -eq 1 ]; then
# sudo shred /home/admin/.pass.tmp 2>/dev/null
# sudo /home/admin/config.scripts/blitz.setpassword.sh x "Enter extra Password D" /home/admin/.pass.tmp
# passwordD=`sudo cat /home/admin/.pass.tmp`
# sudo shred /home/admin/.pass.tmp 2>/dev/null
# fi
#
# fi
#
# if [ "${CHOICE}" == "ONLYSEED" ]; then
#
# # trigger wallet recovery
# source <(python /home/admin/config.scripts/lnd.initwallet.py seed ${passwordC} ${wordstring} ${passwordD})
#
# # on success the python script should return the seed words again
# if [ ${#seedwords} -gt 1 ]; then
# dialog --title " SUCCESS " --msgbox "
#Looks good :) LND was able to recover the wallet.
# " 7 53
# else
# if [ ${#err} -eq 0 ]; then
# echo
# echo "FAIL!! Unkown Error - check output above for any hints and report to development."
# echo "PRESS ENTER to try again."
# read key
# /home/admin/70initLND.sh
# exit 1
# else
# whiptail --title " FAIL " --msgbox "
#Something went wrong - see info below:
#${err}
#${errMore}
# " 13 72
# /home/admin/70initLND.sh
# exit 1
# fi
# fi
# fi
if [ "${CHOICE}" == "SEED+SCB" ]; then if [ "${CHOICE}" == "SEED+SCB" ]; then
# let lnd.rescue script do the upload process # let lnd.rescue script do the upload process
@ -341,63 +260,120 @@ or having a complete LND rescue-backup from your old node.
fi fi
fi fi
##### FALLBACK UNTIL config.scripts/lnd.initwallet.py WORKS clear
echo "****************************************************************************"
echo "* RECOVER LND WALLET BY SEED WORDS" # let user enter password c
echo "****************************************************************************" sudo shred /home/admin/.pass.tmp 2>/dev/null
echo "A) For 'Wallet Password' use your old PASSWORD C" sudo /home/admin/config.scripts/blitz.setpassword.sh x "Set your Password C for the LND Wallet Unlock" /home/admin/.pass.tmp
echo "B) For 'cipher seed mnemonic' answere 'y' and then enter your seed words" passwordC=`sudo cat /home/admin/.pass.tmp`
echo "C) On 'cipher seed passphrase' ONLY enter PASSWORD D if u used it on create" sudo shred /home/admin/.pass.tmp 2>/dev/null
echo "D) On 'address look-ahead' only enter more than 2500 had lots of channels"
echo "****************************************************************************" # get seed word list
echo "" if [ "${CHOICE}" == "SEED+SCB" ] || [ "${CHOICE}" == "ONLYSEED" ]; then
sudo -u bitcoin /usr/local/bin/lncli --chain=${network} --network=${chain}net create 2>/home/admin/.error.tmp
error=`cat /home/admin/.error.tmp` # dialog to enter
rm /home/admin/.error.tmp 2>/dev/null dialog --backtitle "RaspiBlitz - LND Recover" --inputbox "Please enter/paste the SEED WORD LIST:\n(just the words, seperated by paces, in correct order as numbered)" 9 78 2>/home/admin/.seed.tmp
wordstring=$( cat /home/admin/.seed.tmp | sed 's/[^a-zA-Z0-9,]//g' )
shred /home/admin/.seed.tmp
echo "processing ... ${wordstring}"
# check correct number of words
IFS=' ' read -r -a seedArray <<< "$wordstring"
if [ ${#seedArray[@]} -eq 24 ]; then
echo "OK - 24 words"
else
whiptail --title " WARNING " --msgbox "
The word list has ${#seedArray[@]} words. But it must be 24.
Please check your list and try again.
Best is to write words in external editor
and then copy and paste them into dialog.
The Word list should look like this:
wordone,wordtweo,wordthree, ...
" 16 52
/home/admin/70initLND.sh
exit 1
fi
# ask if seed was protected by password D
passwordD=""
dialog --title "SEED PASSWORD" --yes-button "No extra Password" --no-button "Yes" --yesno "
Are your seed words protected by an extra password?
During wallet creation LND offers to set an extra password
to protect the seed words. Most users did not set this.
" 11 65
if [ $? -eq 1 ]; then
sudo shred /home/admin/.pass.tmp 2>/dev/null
sudo /home/admin/config.scripts/blitz.setpassword.sh x "Enter extra Password D" /home/admin/.pass.tmp
passwordD=`sudo cat /home/admin/.pass.tmp`
sudo shred /home/admin/.pass.tmp 2>/dev/null
fi
if [ ${#error} -gt 0 ]; then
echo ""
echo "!!! FAIL !!! SOMETHING WENT WRONG:"
echo "${error}"
echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"
echo ""
echo "Press ENTER to retry ..."
read key
echo "Starting RETRY ..."
/home/admin/70initLND.sh
exit 1
fi fi
/home/admin/70initLND.sh # FOR NOW: let channel.backup file get activated by lncli after syncs
# LATER: make different call to lnd.initwallet.py
if [ "${CHOICE}" == "SEED+SCB" ] || [ "${CHOICE}" == "ONLYSEED" ]; then
# trigger wallet recovery
source <(python /home/admin/config.scripts/lnd.initwallet.py seed ${passwordC} ${wordstring} ${passwordD})
# check if wallet was created for real
if [ ${#err} -eq 0 ]; then
walletExists=$(sudo ls /mnt/hdd/lnd/data/chain/${network}/${chain}net/wallet.db 2>/dev/null | grep wallet.db -c)
if [ ${walletExists} -eq 0 ]; then
err="Was not able to create wallet (unknown error)."
fi
fi
# user feedback
if [ ${#err} -eq 0 ]; then
dialog --title " SUCCESS " --msgbox "
Looks good :) LND was able to recover the wallet.
" 7 53
else
whiptail --title " FAIL " --msgbox "
Something went wrong - see info below:
${err}
${errMore}
" 13 72
/home/admin/70initLND.sh
exit 1
fi
fi
##### DEACTIVATED UNTIL config.scripts/lnd.initwallet.py WORKS ##### FALLBACK UNTIL config.scripts/lnd.initwallet.py WORKS
# # trigger wallet recovery # echo "****************************************************************************"
# source <(python /home/admin/config.scripts/lnd.initwallet.py seed ${passwordC} ${wordstring} /home/admin/channel.backup ${passwordD}) # echo "* RECOVER LND WALLET BY SEED WORDS"
# echo "****************************************************************************"
# echo "A) For 'Wallet Password' use your old PASSWORD C"
# echo "B) For 'cipher seed mnemonic' answere 'y' and then enter your seed words"
# echo "C) On 'cipher seed passphrase' ONLY enter PASSWORD D if u used it on create"
# echo "D) On 'address look-ahead' only enter more than 2500 had lots of channels"
# echo "****************************************************************************"
# echo ""
# sudo -u bitcoin /usr/local/bin/lncli --chain=${network} --network=${chain}net create 2>/home/admin/.error.tmp
# error=`cat /home/admin/.error.tmp`
# rm /home/admin/.error.tmp 2>/dev/null
# #
# # WIN/FAIL User feedback # if [ ${#error} -gt 0 ]; then
# # on success the python script should return the seed words again # echo ""
# if [ ${#seedwords} -gt 1 ]; then # echo "!!! FAIL !!! SOMETHING WENT WRONG:"
# dialog --title " SUCCESS " --msgbox " # echo "${error}"
#Looks good :) LND was able to recover the wallet. # echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"
# " 7 53 # echo ""
# else # echo "Press ENTER to retry ..."
# if [ ${#err} -eq 0 ]; then # read key
# echo # echo "Starting RETRY ..."
# echo "FAIL!! Unkown Error - check output above for any hints and report to development." # /home/admin/70initLND.sh
# echo "PRESS ENTER to try again." # exit 1
# read key # fi
# /home/admin/70initLND.sh
# exit 1 /home/admin/70initLND.sh
# else
# whiptail --title " FAIL " --msgbox "
#Something went wrong - see info below:
#${err}
#${errMore}
# " 13 72
# /home/admin/70initLND.sh
# exit 1
# fi
# fi
fi # END OLD WALLET fi # END OLD WALLET
else else

10
home.admin/config.scripts/lnd.initwallet.py

@ -150,10 +150,11 @@ elif mode=="seed":
request = ln.InitWalletRequest( request = ln.InitWalletRequest(
wallet_password=walletpassword, wallet_password=walletpassword,
cipher_seed_mnemonic=seedwords, cipher_seed_mnemonic=seedwords,
recovery_window=2500, recovery_window=250,
aezeed_passphrase=seedpassword aezeed_passphrase=seedpassword
) )
print("seedwords='"+seedwords+"'")
try: try:
response = stub.InitWallet(request) response = stub.InitWallet(request)
except grpc.RpcError as rpc_error_call: except grpc.RpcError as rpc_error_call:
@ -171,8 +172,6 @@ elif mode=="seed":
elif mode=="scb": elif mode=="scb":
import binascii import binascii
with open(filepathSCB, 'rb') as f: with open(filepathSCB, 'rb') as f:
content = f.read() content = f.read()
@ -182,10 +181,11 @@ elif mode=="scb":
request = ln.InitWalletRequest( request = ln.InitWalletRequest(
wallet_password=walletpassword, wallet_password=walletpassword,
cipher_seed_mnemonic=seedwords, cipher_seed_mnemonic=seedwords,
recovery_window=2500, recovery_window=250,
aezeed_passphrase=seedpassword, aezeed_passphrase=seedpassword,
channel_backups=scbHexString channel_backups=scbHexString
) )
print("seedwords='"+seedwords+"'")
try: try:
response = stub.InitWallet(request) response = stub.InitWallet(request)

Loading…
Cancel
Save