#!/bin/bash # command info if [ $# -eq 0 ] || [ "$1" = "-h" ] || [ "$1" = "-help" ]; then echo "small config script to set a dynamic domain like freeDNS" echo "internet.dyndomain.sh [on|off] [?domainName] [?updateURL]" exit 1 fi # 1. parameter [on|off] turn="off" if [ "$1" = "1" ] || [ "$1" = "on" ]; then turn="on"; fi # 2. parameter [?domainName] dynDomain=$2 # 3. parameter [?domainName] updateDynDomain=$3 # run interactive if 'turn on' && no further parameters if [ "${turn}" = "on" ] && [ ${#dynDomain} -eq 0 ]; then dialog --backtitle "DynamicDNS" --inputbox "ENTER the Dynamic Domain Name: For more details see chapter in GitHub README 'Public Domain with DynamicDNS' https://github.com/rootzoll/raspiblitz example: freedns.afraid.org " 13 52 2>./.tmp dynDomain=$( cat ./.tmp ) if [ ${#dynDomain} -eq 0 ]; then echo "FAIL input cannot be empty" exit 1 fi dialog --backtitle "DynamicDNS" --inputbox "OPTIONAL Public IP Update URL: The RaspiBlitz will call this URL regularly. 4 service freedns.afraid.org use 'DirectURL' " 10 52 2>./.tmp dynUpdateUrl=$( cat ./.tmp ) shred ./.tmp fi # config file configFile="/mnt/hdd/raspiblitz.conf" # lnd conf file lndConfig="/mnt/hdd/lnd/lnd.conf" # check if config file exists configExists=$(ls ${configFile} | grep -c '.conf') if [ ${configExists} -eq 0 ]; then echo "FAIL - missing ${configFile}" exit 1 fi # make sure entry line for 'dynDomain' exists entryExists=$(cat ${configFile} | grep -c 'dynDomain=') if [ ${entryExists} -eq 0 ]; then echo "dynDomain=" >> ${configFile} fi # make sure entry line for 'dynUpdateUrl' exists entryExists=$(cat ${configFile} | grep -c 'dynUpdateUrl') if [ ${entryExists} -eq 0 ]; then echo "dynUpdateUrl=" >> ${configFile} fi # stop services echo "making sure services are not running" sudo systemctl stop lnd 2>/dev/null # switch on if [ "$1" = "1" ] || [ "$1" = "on" ]; then echo "switching the DynamicDNS ON" echo "dynDomain(${dynDomain})" echo "dynUpdateUrl(${dynUpdateUrl})" # setting value in raspi blitz config sudo sed -i "s/^dynDomain=.*/dynDomain='${dynDomain}'/g" /mnt/hdd/raspiblitz.conf sudo sed -i "s/^dynUpdateUrl=.*/dynUpdateUrl='${dynUpdateUrl}'/g" /mnt/hdd/raspiblitz.conf echo "changing lnd.conf" # lnd.conf: uncomment tlsextradomain (just if it is still uncommented) sudo sed -i "s/^#tlsextradomain=.*/tlsextradomain=/g" /mnt/hdd/lnd/lnd.conf # lnd.conf: domain value sudo sed -i "s/^tlsextradomain=.*/tlsextradomain=${dynDomain}/g" /mnt/hdd/lnd/lnd.conf echo "DynamicDNS is now ON" fi # switch off if [ "$1" = "0" ] || [ "$1" = "off" ]; then echo "switching DynamicDNS OFF" # setting value in raspi blitz config sudo sed -i "s/^dynDomain=.*/dynDomain=/g" /mnt/hdd/raspiblitz.conf sudo sed -i "s/^dynUpdateUrl=.*/dynUpdateUrl=/g" /mnt/hdd/raspiblitz.conf echo "changing lnd.conf" # lnd.conf: comment tlsextradomain out sudo sed -i "s/^tlsextradomain=.*/#tlsextradomain=/g" /mnt/hdd/lnd/lnd.conf echo "DynamicDNS is now OFF" fi echo "deleting TLSCert" sudo rm /mnt/hdd/lnd/tls.* 2>/dev/null echo "let lnd generate new TLSCert" sudo systemctl restart lnd echo "wait until generated" newCertExists=0 count=0 while [ ${newCertExists} -eq 0 ] do count=$(($count + 1)) echo "(${count}/60) check for cert" if [ ${count} -gt 60 ]; then echo "FAIL - was not able to generate new LND certs" exit 1 fi newCertExists=$(sudo ls /mnt/hdd/lnd/tls.cert 2>/dev/null | grep -c '.cert') sleep 2 done echo "copy new cert to admin user" sudo cp /mnt/hdd/lnd/tls.cert /home/admin/.lnd echo "may needs reboot to run normal again" exit 0