raspiblitz/home.admin/config.scripts/network.txindex.sh

74 lines
2.2 KiB
Bash
Raw Normal View History

#!/bin/bash
# command info
if [ $# -eq 0 ] || [ "$1" = "-h" ] || [ "$1" = "-help" ]; then
echo "config script to switch txindex on or off"
echo "network.txindex.sh [on|off]"
exit 1
fi
2019-12-18 22:16:54 +01:00
source /mnt/hdd/raspiblitz.conf
source /mnt/hdd/${network}/${network}.conf
# add default value to bitcoin.conf if needed
if [ ${#txindex} -eq 0 ]; then
2019-12-18 22:16:54 +01:00
echo "txindex=0" >> /mnt/hdd/${network}/${network}.conf
2019-12-18 22:40:17 +01:00
source /mnt/hdd/${network}/${network}.conf
fi
if [ "$1" = "status" ]; then
echo "##### STATUS TXINDEX"
echo "txindex=${txindex}"
if [ ${txindex} -eq 0 ]; then
exit 0
fi
# try to gather if still indexing
2019-12-18 22:47:38 +01:00
indexedToBlock=$(sudo tail -n 100 /mnt/hdd/${network}/debug.log | grep "Syncing txindex with block chain from height" | tail -n 1 | cut -d " " -f 9 | sed 's/[^0-9]*//g')
2019-12-18 22:40:17 +01:00
blockchainHeight=$(sudo -u bitcoin ${network}-cli getblockchaininfo 2>/dev/null | jq -r '.blocks' | sed 's/[^0-9]*//g')
2019-12-18 23:56:55 +01:00
indexFinished=$(sudo tail -n 100 /mnt/hdd/${network}/debug.log | grep -c "txindex is enabled at height")
2019-12-18 22:45:20 +01:00
echo "indexedToBlock=${indexedToBlock}"
echo "blockchainHeight=${blockchainHeight}"
2019-12-18 23:56:55 +01:00
echo "indexFinished=${indexFinished}"
if [ ${#indexedToBlock} -eq 0 ] || [ ${indexFinished} -gt 0 ] || [ "${indexedToBlock}" = "${blockchainHeight}" ]; then
2019-12-18 22:45:20 +01:00
echo "isIndexed=1"
indexInfo="OK"
2019-12-18 22:40:17 +01:00
else
2019-12-18 22:45:20 +01:00
echo "isIndexed=0"
if [ ${#indexedToBlock} -gt 0 ]; then
indexInfo="Indexing ${indexedToBlock}/${blockchainHeight} (please wait)"
else
indexInfo="Indexing is running (please wait)"
fi
2019-12-18 22:45:49 +01:00
echo "indexInfo='${indexInfo}'"
2019-12-18 22:40:17 +01:00
fi
exit 0
fi
# switch on
if [ "$1" = "1" ] || [ "$1" = "on" ]; then
if [ ${txindex} == 0 ]; then
2019-12-18 22:16:54 +01:00
sudo sed -i "s/^txindex=.*/txindex=1/g" /mnt/hdd/${network}/${network}.conf
echo "switching txindex=1 and restarting ${network}d"
sudo systemctl restart ${network}d
echo "The indexing takes ~7h on an RPi4 with SSD"
2019-12-18 22:16:54 +01:00
echo "monitor with: sudo tail -n 20 -f /mnt/hdd/${network}/debug.log"
exit 0
else
echo "txindex is already active"
exit 0
fi
fi
# switch off
if [ "$1" = "0" ] || [ "$1" = "off" ]; then
2019-12-18 22:16:54 +01:00
sudo sed -i "s/^txindex=.*/txindex=0/g" /mnt/hdd/${network}/${network}.conf
sudo systemctl restart ${network}d
exit 0
fi
echo "FAIL - Unknown Parameter $1"
exit 1