#!/bin/bash _temp="./download/dialog.$$" ## get basic info source /home/admin/raspiblitz.info 2>/dev/null # welcome and ask for name of RaspiBlitz result="" while [ ${#result} -eq 0 ] do l1="Please enter the name of your new RaspiBlitz:\n" l2="one word, keep characters basic & not too long" dialog --backtitle "RaspiBlitz - Setup (${network}/${chain})" --inputbox "$l1$l2" 11 52 2>$_temp result=$( cat $_temp | tr -dc '[:alnum:]-.' | tr -d ' ' ) shred $_temp done # set lightning alias sed -i "s/^alias=.*/alias=${result}/g" /home/admin/assets/lnd.${network}.conf # store hostname for later - to be set right before the next reboot # work around - because without a reboot the hostname seems not updates in the whole system valueExistsInInfoFile=$(sudo cat /home/admin/raspiblitz.info | grep -c "hostname=") if [ ${valueExistsInInfoFile} -eq 0 ]; then # update sed -i "s/^hostname=.*/hostname=${result}/g" /home/admin/raspiblitz.info else # add echo "hostname=${result}" >> /home/admin/raspiblitz.info fi passwordValid=0 result="" while [ ${passwordValid} -eq 0 ] do # show password info dialog dialog --backtitle "RaspiBlitz - Setup (${network}/${chain})" --msgbox "RaspiBlitz uses 4 different passwords. Referenced as password A, B, C and D. A) Master User Password B) Blockchain RPC Password C) LND Wallet Password D) LND Seed Password Choose now 4 new passwords - all min 8 chars, no spaces and only special characters - or . Write them down & store them in a safe place. " 15 52 # ask user for new password A dialog --backtitle "RaspiBlitz - Setup (${network}/${chain})"\ --inputbox "Please enter your Master/Admin Password A:\n!!! This is new password to login per SSH !!!" 10 52 2>$_temp # get user input result=$( cat $_temp ) shred $_temp passwordValid=1 clearedResult=$(echo "${result}" | tr -dc '[:alnum:]-.' | tr -d ' ') if [ ${#clearedResult} != ${#result} ] || [ ${#clearedResult} -eq 0 ]; then clear echo "FAIL - Password contained not allowed chars (see next screen)" echo "Press ENTER to continue .." read key passwordValid=0 else # change user passwords and then change hostname echo "pi:$result" | sudo chpasswd echo "root:$result" | sudo chpasswd echo "bitcoin:$result" | sudo chpasswd echo "admin:$result" | sudo chpasswd sleep 1 # sucess info dialog dialog --backtitle "RaspiBlitz" --msgbox "OK - password changed to '$result'\nfor all users pi, admin, root & bitcoin" 6 52 # repeat until user input is nit length 0 result="" dialog --backtitle "RaspiBlitz - Setup (${network}/${chain})"\ --inputbox "Enter your RPC Password B:" 9 52 2>$_temp result=$( cat $_temp ) shred $_temp clearedResult=$(echo "${result}" | tr -dc '[:alnum:]-.' | tr -d ' ') if [ ${#clearedResult} != ${#result} ] || [ ${#clearedResult} -eq 0 ]; then clear echo "FAIL - Password contained not allowed chars (see next screen)" echo "Press ENTER to continue to start again" read key passwordValid=0 else # set Blockchain RPC Password (for admin cli & template for user bitcoin) sed -i "s/^rpcpassword=.*/rpcpassword=${result}/g" /home/admin/assets/${network}.conf sed -i "s/^${network}d.rpcpass=.*/${network}d.rpcpass=${result}/g" /home/admin/assets/lnd.${network}.conf # success info dialog dialog --backtitle "RaspiBlitz - Setup (${network}/${chain})" --msgbox "OK - RPC password changed to '$result'\n\nNow starting the Setup of your RaspiBlitz." 7 52 clear fi fi done