|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
# INFO : Does not need to be part of update/provision, because
|
|
|
|
# all data is already on HDD ready
|
|
|
|
|
|
|
|
# command info
|
|
|
|
if [ $# -eq 0 ] || [ "$1" = "-h" ] || [ "$1" = "-help" ]; then
|
|
|
|
echo "small config script to set a fixed domain or IP for LND"
|
|
|
|
echo "internet.setaddress.sh [on|off] [?address]"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
# 1. parameter [on|off]
|
|
|
|
mode="$1"
|
|
|
|
|
|
|
|
echo "number of args($#)"
|
|
|
|
|
|
|
|
# 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
|
|
|
|
|
|
|
|
# get hash of lnd.conf before edit (to detect if changed later)
|
|
|
|
md5HashBefore=$(sudo shasum -a 256 /mnt/hdd/lnd/lnd.conf)
|
|
|
|
|
|
|
|
# FIXED DOMAIN/IP
|
|
|
|
if [ "${mode}" = "on" ]; then
|
|
|
|
|
|
|
|
address=$2
|
|
|
|
if [ ${#address} -eq 0 ]; then
|
|
|
|
echo "missing parameter"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo "switching fixed LND Domain ON"
|
|
|
|
echo "address(${address})"
|
|
|
|
|
|
|
|
# setting value in raspi blitz config
|
|
|
|
sudo sed -i "s/^lndAddress=.*/lndAddress='${address}'/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=${address}/g" /mnt/hdd/lnd/lnd.conf
|
|
|
|
|
|
|
|
# refresh TLS cert
|
|
|
|
md5HashAfter=$(sudo shasum -a 256 /mnt/hdd/lnd/lnd.conf)
|
|
|
|
if [ "${md5HashAfter}" != "${md5HashBefore}" ]; then
|
|
|
|
echo "# lnd.conf changed - TLS certs need refreshing"
|
|
|
|
sudo /home/admin/config.scripts/lnd.newtlscert.sh
|
|
|
|
else
|
|
|
|
echo "# lnd.conf NOT changed - keep TLS certs"
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo "fixedAddress is now ON"
|
|
|
|
fi
|
|
|
|
|
|
|
|
# switch off
|
|
|
|
if [ "${mode}" = "off" ]; then
|
|
|
|
echo "switching fixedAddress OFF"
|
|
|
|
|
|
|
|
# stop services
|
|
|
|
echo "making sure services are not running"
|
|
|
|
sudo systemctl stop lnd 2>/dev/null
|
|
|
|
|
|
|
|
# setting value in raspi blitz config
|
|
|
|
sudo sed -i "s/^lndAddress=.*/lndAddress=''/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
|
|
|
|
|
|
|
|
# refresh TLS cert
|
|
|
|
md5HashAfter=$(sudo shasum -a 256 /mnt/hdd/lnd/lnd.conf)
|
|
|
|
if [ "${md5HashAfter}" != "${md5HashBefore}" ]; then
|
|
|
|
echo "# lnd.conf changed - TLS certs need refreshing"
|
|
|
|
sudo /home/admin/config.scripts/lnd.newtlscert.sh
|
|
|
|
else
|
|
|
|
echo "# lnd.conf NOT changed - keep TLS certs"
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo "fixedAddress is now OFF"
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo "may needs reboot to run normal again"
|
|
|
|
exit 0
|