2020-03-16 15:11:39 +01:00
#!/bin/bash
2021-12-14 23:34:35 +01:00
# https://github.com/cryptoadvance/specter-desktop
2020-03-16 15:11:39 +01:00
2022-02-10 15:49:19 +00:00
pinnedVersion = "1.8.1"
2020-11-04 18:33:25 +00:00
2020-03-16 15:11:39 +01:00
# command info
if [ $# -eq 0 ] || [ " $1 " = "-h" ] || [ " $1 " = "-help" ] ; then
2021-08-23 17:23:01 +01:00
echo "config script to switch Specter Desktop on, off, configure or update"
2021-09-21 19:57:45 +01:00
echo "bonus.specter.sh [status|on|off|config|update] <mainnet|testnet|signet>"
2020-11-04 18:33:25 +00:00
echo " installing the version $pinnedVersion by default "
2020-03-16 15:11:39 +01:00
exit 1
fi
2021-09-21 19:57:45 +01:00
echo " # bonus.specter.sh $1 $2 "
2021-12-20 11:40:34 +01:00
source /mnt/hdd/raspiblitz.conf
2021-09-21 19:57:45 +01:00
if [ $# -gt 1 ] ; then
CHAIN = $2
chain = ${ CHAIN : :- 3 }
fi
2020-03-16 15:11:39 +01:00
2020-10-08 20:52:37 +02:00
# get status key/values
if [ " $1 " = "status" ] ; then
if [ " ${ specter } " = "on" ] ; then
echo "configured=1"
2022-05-05 10:59:50 +02:00
installed = $( sudo ls /etc/systemd/system/specter.service 2>/dev/null | grep -c 'specter.service' )
echo " installed= ${ installed } "
2020-10-08 20:52:37 +02:00
# get network info
2021-08-04 00:18:30 +02:00
localip = $( hostname -I | awk '{print $1}' )
2021-08-23 17:23:01 +01:00
toraddress = $( sudo cat /mnt/hdd/tor/specter/hostname 2>/dev/null)
2020-12-15 16:57:30 +00:00
fingerprint = $( openssl x509 -in /home/specter/.specter/cert.pem -fingerprint -noout | cut -d"=" -f2)
2022-05-05 10:59:50 +02:00
echo " localIP=' ${ localip } ' "
echo "httpPort=''"
echo "httpsPort='25441'"
echo "httpsForced='1'"
echo "httpsSelfsigned='1'"
2020-10-08 20:52:37 +02:00
echo " toraddress=' ${ toraddress } ' "
echo " fingerprint=' ${ fingerprint } ' "
# check for error
2021-08-23 17:23:01 +01:00
serviceFailed = $( sudo systemctl status specter | grep -c 'inactive (dead)' )
2020-10-08 20:52:37 +02:00
if [ " ${ serviceFailed } " = "1" ] ; then
echo "error='Service Failed'"
exit 1
fi
else
echo "configured=0"
2022-05-05 10:59:50 +02:00
echo "installed=0"
2020-10-08 20:52:37 +02:00
fi
2021-12-14 23:34:35 +01:00
2020-10-08 20:52:37 +02:00
exit 0
fi
2020-03-16 15:11:39 +01:00
# show info menu
if [ " $1 " = "menu" ] ; then
# get status
echo "# collecting status info ... (please wait)"
2021-08-23 17:23:01 +01:00
source <( sudo /home/admin/config.scripts/bonus.specter.sh status)
2020-10-08 20:52:37 +02:00
echo " # toraddress: ${ toraddress } "
2020-03-16 15:11:39 +01:00
if [ " ${ runBehindTor } " = "on" ] && [ ${# toraddress } -gt 0 ] ; then
2021-08-23 17:23:01 +01:00
# Tor
2022-02-13 12:23:34 +00:00
sudo /home/admin/config.scripts/blitz.display.sh qr " ${ toraddress } "
2021-08-23 17:23:01 +01:00
whiptail --title " Specter Desktop " --msgbox " Open in your local web browser & accept self-signed cert:
2022-05-05 10:59:50 +02:00
https://${ localIP } :25441
2020-06-19 18:52:39 +01:00
2020-06-29 17:31:12 +02:00
SHA1 Thumb/Fingerprint:
${ fingerprint }
2020-03-16 15:11:39 +01:00
Login with the Pin being Password B. If you have connected to a different Bitcoin RPC Endpoint, the Pin is the configured RPCPassword.
2020-06-19 18:52:39 +01:00
2020-03-16 15:11:39 +01:00
Hidden Service address for TOR Browser ( QR see LCD) :
2020-10-08 20:52:37 +02:00
https://${ toraddress }
Unfortunately the camera is currently not usable via Tor, though.
" 18 74
2022-02-13 12:23:34 +00:00
sudo /home/admin/config.scripts/blitz.display.sh hide
2020-03-16 15:11:39 +01:00
else
# IP + Domain
2021-08-23 17:23:01 +01:00
whiptail --title " Specter Desktop " --msgbox " Open in your local web browser & accept self-signed cert:
2022-05-05 10:59:50 +02:00
https://${ localIP } :25441
2020-06-29 17:31:12 +02:00
SHA1 Thumb/Fingerprint:
${ fingerprint }
2020-10-08 20:52:37 +02:00
Login with the PIN being Password B. If you have connected to a different Bitcoin RPC Endpoint, the PIN is the configured RPCPassword.\n
2020-03-16 15:11:39 +01:00
Activate TOR to access the web block explorer from outside your local network.
2020-10-08 20:52:37 +02:00
" 15 74
2020-03-16 15:11:39 +01:00
fi
2020-06-06 22:23:50 +02:00
echo "# please wait ..."
2020-03-16 15:11:39 +01:00
exit 0
fi
2020-10-11 19:47:05 +01:00
# blockfilterindex
# add blockfilterindex with default value (0) to bitcoin.conf if missing
if ! grep -Eq "^blockfilterindex=.*" /mnt/hdd/${ network } /${ network } .conf; then
echo "blockfilterindex=0" | sudo tee -a /mnt/hdd/${ network } /${ network } .conf >/dev/null
fi
# set variable ${blockfilterindex}
source <( grep -E "^blockfilterindex=.*" /mnt/hdd/${ network } /${ network } .conf)
2021-08-23 17:23:01 +01:00
function configure_specter {
echo "# --> creating App-config"
if [ " ${ runBehindTor } " = "on" ] ; then
proxy = "socks5h://localhost:9050"
torOnly = "true"
tor_control_port = "9051"
else
proxy = ""
torOnly = "false"
tor_control_port = ""
fi
cat > /home/admin/config.json <<EOF
{
"auth" : {
"method" : "rpcpasswordaspin" ,
"password_min_chars" : 6,
2021-09-21 19:57:45 +01:00
"rate_limit" : 10,
"registration_link_timeout" : 1
2021-08-23 17:23:01 +01:00
} ,
"active_node_alias" : " raspiblitz_ ${ chain } net " ,
"proxy_url" : " ${ proxy } " ,
2021-09-21 19:57:45 +01:00
"only_tor" : " ${ torOnly } " ,
2021-08-23 17:23:01 +01:00
"tor_control_port" : " ${ tor_control_port } " ,
2021-09-21 19:57:45 +01:00
"tor_status" : true,
"hwi_bridge_url" : "/hwi/api/"
2021-08-23 17:23:01 +01:00
}
EOF
2021-09-21 19:57:45 +01:00
sudo mkdir -p /home/specter/.specter/nodes
2021-08-23 17:23:01 +01:00
sudo mv /home/admin/config.json /home/specter/.specter/config.json
2021-09-21 19:57:45 +01:00
sudo chown -RL specter:specter /home/specter/
2021-08-23 17:23:01 +01:00
echo " # Adding the raspiblitz_ ${ chain } net node to Specter "
RPCUSER = $( sudo cat /mnt/hdd/${ network } /${ network } .conf | grep rpcuser | cut -c 9-)
PASSWORD_B = $( sudo cat /mnt/hdd/${ network } /${ network } .conf | grep rpcpassword | cut -c 13-)
2021-09-21 19:57:45 +01:00
echo "# Connect Specter to the default mainnet node"
2021-12-14 23:34:35 +01:00
cat > /home/admin/default.json <<EOF
2021-08-23 17:23:01 +01:00
{
2021-09-21 19:57:45 +01:00
"name" : "raspiblitz_mainnet" ,
"alias" : "default" ,
"autodetect" : false,
"datadir" : "" ,
"user" : " ${ RPCUSER } " ,
"password" : " ${ PASSWORD_B } " ,
"port" : "8332" ,
"host" : "localhost" ,
"protocol" : "http" ,
"external_node" : true,
"fullpath" : "/home/specter/.specter/nodes/default.json"
}
EOF
sudo mv /home/admin/default.json /home/specter/.specter/nodes/default.json
sudo chown -RL specter:specter /home/specter/
if [ " ${ chain } " != "main" ] ; then
if [ " ${ chain } " = "test" ] ; then
portprefix = 1
elif [ " ${ chain } " = "sig" ] ; then
portprefix = 3
fi
PORT = " ${ portprefix } 8332 "
echo " # Connect Specter to the raspiblitz_ ${ chain } net node "
2021-12-14 23:34:35 +01:00
cat > /home/admin/raspiblitz_${ chain } net.json <<EOF
2021-09-21 19:57:45 +01:00
{
"name" : " raspiblitz_ ${ chain } net " ,
2021-08-23 17:23:01 +01:00
"alias" : " raspiblitz_ ${ chain } net " ,
"autodetect" : false,
"datadir" : "" ,
"user" : " ${ RPCUSER } " ,
"password" : " ${ PASSWORD_B } " ,
"port" : " ${ PORT } " ,
"host" : "localhost" ,
"protocol" : "http" ,
"external_node" : true,
"fullpath" : " /home/specter/.specter/nodes/raspiblitz_ ${ chain } net.json "
}
EOF
2021-09-21 19:57:45 +01:00
sudo mv /home/admin/raspiblitz_${ chain } net.json /home/specter/.specter/nodes/raspiblitz_${ chain } net.json
sudo chown -RL specter:specter /home/specter/
fi
2021-08-23 17:23:01 +01:00
}
2021-09-21 19:57:45 +01:00
2021-08-23 17:23:01 +01:00
# config
if [ " $1 " = "config" ] ; then
configure_specter
2021-09-21 19:57:45 +01:00
echo "# Restarting Specter - reload it's page to log in with the new settings"
sudo systemctl restart specter
exit 0
2021-08-23 17:23:01 +01:00
fi
2020-03-16 15:11:39 +01:00
# switch on
if [ " $1 " = "1" ] || [ " $1 " = "on" ] ; then
2021-08-23 17:23:01 +01:00
echo "# --> INSTALL Specter Desktop"
2020-03-16 15:11:39 +01:00
2021-08-23 17:23:01 +01:00
isInstalled = $( sudo ls /etc/systemd/system/specter.service 2>/dev/null | grep -c 'specter.service' || /bin/true)
2020-03-16 15:11:39 +01:00
if [ ${ isInstalled } -eq 0 ] ; then
2020-06-06 22:23:50 +02:00
echo "# --> Enable wallets in Bitcoin Core"
2020-06-30 14:05:03 +01:00
/home/admin/config.scripts/network.wallet.sh on
2020-03-16 15:11:39 +01:00
2020-06-06 22:23:50 +02:00
echo "# --> Installing prerequisites"
2021-01-10 17:08:58 +00:00
sudo apt update
2021-12-14 23:34:35 +01:00
sudo apt-get install -y virtualenv libffi-dev libusb-1.0.0-dev libudev-dev
2020-03-16 15:11:39 +01:00
2020-12-15 16:57:30 +00:00
sudo adduser --disabled-password --gecos "" specter
2022-05-05 10:59:50 +02:00
if [ " $( ls /home | grep -c "specter" ) " = = "0" ] ; then
echo "error='was not able to create user specter'"
exit 1
fi
2021-12-14 23:34:35 +01:00
2021-08-23 17:23:01 +01:00
echo "# add the user to the debian-tor group"
sudo usermod -a -G debian-tor specter
2020-12-15 16:57:30 +00:00
# store data on the disk
sudo mkdir -p /mnt/hdd/app-data/.specter 2>/dev/null
# move old Specter data to app-data (except .env)
sudo mv -f /home/bitcoin/.specter/* /mnt/hdd/app-data/.specter/ 2>/dev/null
sudo rm -rf /home/bitcoin/.specter 2>/dev/null
# symlink to specter user
sudo chown -R specter:specter /mnt/hdd/app-data/.specter
sudo ln -s /mnt/hdd/app-data/.specter /home/specter/ 2>/dev/null
sudo chown -R specter:specter /home/specter/.specter
2020-06-06 22:23:50 +02:00
echo "# --> creating a virtualenv"
2020-12-15 16:57:30 +00:00
sudo -u specter virtualenv --python= python3 /home/specter/.env
2020-03-16 15:11:39 +01:00
2020-06-06 22:23:50 +02:00
echo "# --> pip-installing specter"
2021-09-22 15:27:08 +01:00
sudo -u specter /home/specter/.env/bin/python3 -m pip install --upgrade cryptoadvance.specter= = $pinnedVersion || exit 1
# activating Authentication here ...
configure_specter
2020-03-16 15:11:39 +01:00
# Mandatory as the camera doesn't work without https
2020-06-06 22:23:50 +02:00
echo "# --> Creating self-signed certificate"
2020-06-29 19:45:13 +02:00
openssl req -x509 -newkey rsa:4096 -nodes -out /tmp/cert.pem -keyout /tmp/key.pem -days 365 -subj "/C=US/ST=Nooneknows/L=Springfield/O=Dis/CN=www.fakeurl.com"
2020-12-15 16:57:30 +00:00
sudo mv /tmp/cert.pem /home/specter/.specter
sudo chown -R specter:specter /home/specter/.specter/cert.pem
sudo mv /tmp/key.pem /home/specter/.specter
sudo chown -R specter:specter /home/specter/.specter/key.pem
2020-03-16 15:11:39 +01:00
# open firewall
2020-06-06 22:23:50 +02:00
echo "# --> Updating Firewall"
2021-08-23 17:23:01 +01:00
sudo ufw allow 25441 comment 'specter'
2020-06-06 22:17:16 +02:00
sudo ufw --force enable
2021-09-22 15:27:08 +01:00
echo
2020-03-16 15:11:39 +01:00
2020-06-06 22:23:50 +02:00
echo "# --> Installing udev-rules for hardware-wallets"
2021-12-14 23:34:35 +01:00
2020-09-20 19:07:38 +01:00
# Ledger
2020-03-16 15:11:39 +01:00
cat > /home/admin/20-hw1.rules <<EOF
HW.1 / Nano
2020-12-15 16:57:30 +00:00
SUBSYSTEMS = = "usb" , ATTRS{ idVendor} = = "2581" , ATTRS{ idProduct} = = "1b7c|2b7c|3b7c|4b7c" , TAG += "uaccess" , TAG += "udev-acl" , OWNER = "specter"
2020-03-16 15:11:39 +01:00
# Blue
2020-12-15 16:57:30 +00:00
SUBSYSTEMS = = "usb" , ATTRS{ idVendor} = = "2c97" , ATTRS{ idProduct} = = "0000|0000|0001|0002|0003|0004|0005|0006|0007|0008|0009|000a|000b|000c|000d|000e|000f|0010|0011|0012|0013|0014|0015|0016|0017|0018|0019|001a|001b|001c|001d|001e|001f" , TAG += "uaccess" , TAG += "udev-acl" , OWNER = "specter"
2020-03-16 15:11:39 +01:00
# Nano S
2020-12-15 16:57:30 +00:00
SUBSYSTEMS = = "usb" , ATTRS{ idVendor} = = "2c97" , ATTRS{ idProduct} = = "0001|1000|1001|1002|1003|1004|1005|1006|1007|1008|1009|100a|100b|100c|100d|100e|100f|1010|1011|1012|1013|1014|1015|1016|1017|1018|1019|101a|101b|101c|101d|101e|101f" , TAG += "uaccess" , TAG += "udev-acl" , OWNER = "specter"
2020-03-16 15:11:39 +01:00
# Aramis
2020-12-15 16:57:30 +00:00
SUBSYSTEMS = = "usb" , ATTRS{ idVendor} = = "2c97" , ATTRS{ idProduct} = = "0002|2000|2001|2002|2003|2004|2005|2006|2007|2008|2009|200a|200b|200c|200d|200e|200f|2010|2011|2012|2013|2014|2015|2016|2017|2018|2019|201a|201b|201c|201d|201e|201f" , TAG += "uaccess" , TAG += "udev-acl" , OWNER = "specter"
2020-03-16 15:11:39 +01:00
# HW2
2020-12-15 16:57:30 +00:00
SUBSYSTEMS = = "usb" , ATTRS{ idVendor} = = "2c97" , ATTRS{ idProduct} = = "0003|3000|3001|3002|3003|3004|3005|3006|3007|3008|3009|300a|300b|300c|300d|300e|300f|3010|3011|3012|3013|3014|3015|3016|3017|3018|3019|301a|301b|301c|301d|301e|301f" , TAG += "uaccess" , TAG += "udev-acl" , OWNER = "specter"
2020-03-16 15:11:39 +01:00
# Nano X
2020-12-15 16:57:30 +00:00
SUBSYSTEMS = = "usb" , ATTRS{ idVendor} = = "2c97" , ATTRS{ idProduct} = = "0004|4000|4001|4002|4003|4004|4005|4006|4007|4008|4009|400a|400b|400c|400d|400e|400f|4010|4011|4012|4013|4014|4015|4016|4017|4018|4019|401a|401b|401c|401d|401e|401f" , TAG += "uaccess" , TAG += "udev-acl" , OWNER = "specter"
2020-03-16 15:11:39 +01:00
EOF
2021-12-14 23:34:35 +01:00
2020-09-20 19:07:38 +01:00
# ColdCard
2020-03-16 15:11:39 +01:00
cat > /home/admin/51-coinkite.rules <<EOF
# Linux udev support file.
#
# This is a example udev file for HIDAPI devices which changes the permissions
# to 0666 (world readable/writable) for a specific device on Linux systems.
#
# - Copy this file into /etc/udev/rules.d and unplug and re-plug your Coldcard.
# - Udev does not have to be restarted.
#
# probably not needed:
SUBSYSTEMS = = "usb" , ATTRS{ idVendor} = = "d13e" , ATTRS{ idProduct} = = "cc10" , GROUP = "plugdev" , MODE = "0666"
# required:
# from <https://github.com/signal11/hidapi/blob/master/udev/99-hid.rules>
KERNEL = = "hidraw*" , ATTRS{ idVendor} = = "d13e" , ATTRS{ idProduct} = = "cc10" , GROUP = "plugdev" , MODE = "0666"
EOF
2021-12-14 23:34:35 +01:00
2020-09-20 19:07:38 +01:00
# Trezor
2020-03-16 15:11:39 +01:00
cat > /home/admin/51-trezor.rules <<EOF
# Trezor: The Original Hardware Wallet
# https://trezor.io/
#
# Put this file into /etc/udev/rules.d
#
# If you are creating a distribution package,
# put this into /usr/lib/udev/rules.d or /lib/udev/rules.d
# depending on your distribution
# Trezor
SUBSYSTEM = = "usb" , ATTR{ idVendor} = = "534c" , ATTR{ idProduct} = = "0001" , MODE = "0660" , GROUP = "plugdev" , TAG += "uaccess" , TAG += "udev-acl" , SYMLINK += "trezor%n"
KERNEL = = "hidraw*" , ATTRS{ idVendor} = = "534c" , ATTRS{ idProduct} = = "0001" , MODE = "0660" , GROUP = "plugdev" , TAG += "uaccess" , TAG += "udev-acl"
# Trezor v2
SUBSYSTEM = = "usb" , ATTR{ idVendor} = = "1209" , ATTR{ idProduct} = = "53c0" , MODE = "0660" , GROUP = "plugdev" , TAG += "uaccess" , TAG += "udev-acl" , SYMLINK += "trezor%n"
SUBSYSTEM = = "usb" , ATTR{ idVendor} = = "1209" , ATTR{ idProduct} = = "53c1" , MODE = "0660" , GROUP = "plugdev" , TAG += "uaccess" , TAG += "udev-acl" , SYMLINK += "trezor%n"
KERNEL = = "hidraw*" , ATTRS{ idVendor} = = "1209" , ATTRS{ idProduct} = = "53c1" , MODE = "0660" , GROUP = "plugdev" , TAG += "uaccess" , TAG += "udev-acl"
EOF
2021-12-14 23:34:35 +01:00
2020-09-20 19:07:38 +01:00
# KeepKey
2020-03-16 15:11:39 +01:00
cat > /home/admin/51-usb-keepkey.rules <<EOF
# KeepKey: Your Private Bitcoin Vault
# http://www.keepkey.com/
# Put this file into /usr/lib/udev/rules.d or /etc/udev/rules.d
# KeepKey HID Firmware/Bootloader
SUBSYSTEM = = "usb" , ATTR{ idVendor} = = "2b24" , ATTR{ idProduct} = = "0001" , MODE = "0666" , GROUP = "plugdev" , TAG += "uaccess" , TAG += "udev-acl" , SYMLINK += "keepkey%n"
KERNEL = = "hidraw*" , ATTRS{ idVendor} = = "2b24" , ATTRS{ idProduct} = = "0001" , MODE = "0666" , GROUP = "plugdev" , TAG += "uaccess" , TAG += "udev-acl"
# KeepKey WebUSB Firmware/Bootloader
SUBSYSTEM = = "usb" , ATTR{ idVendor} = = "2b24" , ATTR{ idProduct} = = "0002" , MODE = "0666" , GROUP = "plugdev" , TAG += "uaccess" , TAG += "udev-acl" , SYMLINK += "keepkey%n"
KERNEL = = "hidraw*" , ATTRS{ idVendor} = = "2b24" , ATTRS{ idProduct} = = "0002" , MODE = "0666" , GROUP = "plugdev" , TAG += "uaccess" , TAG += "udev-acl"
EOF
sudo mv /home/admin/20-hw1.rules /home/admin/51-coinkite.rules /home/admin/51-trezor.rules /home/admin/51-usb-keepkey.rules /etc/udev/rules.d/
sudo chown root:root /etc/udev/rules.d/*
sudo udevadm trigger
sudo udevadm control --reload-rules
2020-06-06 22:17:16 +02:00
sudo groupadd plugdev || /bin/true
2020-03-16 15:11:39 +01:00
sudo usermod -aG plugdev bitcoin
2020-12-15 16:57:30 +00:00
sudo usermod -aG plugdev specter
2020-03-16 15:11:39 +01:00
# install service
2021-08-23 17:23:01 +01:00
echo "# --> Install specter systemd service"
cat > /home/admin/specter.service <<EOF
# systemd unit for Specter Desktop
2020-03-16 15:11:39 +01:00
[ Unit]
2021-08-23 17:23:01 +01:00
Description = specter
2020-03-16 15:11:39 +01:00
Wants = ${ network } d.service
After = ${ network } d.service
[ Service]
2020-12-15 16:57:30 +00:00
ExecStart = /home/specter/.env/bin/python3 -m cryptoadvance.specter server --host 0.0.0.0 --cert= /home/specter/.specter/cert.pem --key= /home/specter/.specter/key.pem
User = specter
Environment = PATH = /home/specter/.specter.env/bin:/home/specter/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/sbin:/bin
2020-03-16 15:11:39 +01:00
Restart = always
TimeoutSec = 120
RestartSec = 30
StandardOutput = null
StandardError = journal
2021-08-04 00:18:30 +02:00
# Hardening measures
PrivateTmp = true
ProtectSystem = full
NoNewPrivileges = true
PrivateDevices = true
2020-03-16 15:11:39 +01:00
[ Install]
WantedBy = multi-user.target
EOF
2021-08-23 17:23:01 +01:00
sudo mv /home/admin/specter.service /etc/systemd/system/specter.service
sudo systemctl enable specter
2020-03-16 15:11:39 +01:00
2021-08-23 17:23:01 +01:00
echo "# --> OK - the specter service is now enabled and started"
2021-12-14 23:34:35 +01:00
else
2021-08-23 17:23:01 +01:00
echo "# --> specter already installed."
2020-03-16 15:11:39 +01:00
fi
# setting value in raspi blitz config
2021-12-14 23:34:35 +01:00
/home/admin/config.scripts/blitz.conf.sh set specter "on"
2020-03-16 15:11:39 +01:00
2020-06-06 22:17:16 +02:00
# Hidden Service for SERVICE if Tor is active
2020-03-16 15:11:39 +01:00
if [ " ${ runBehindTor } " = "on" ] ; then
2021-12-14 23:34:35 +01:00
# make sure to keep in sync with tor.network.sh script
2020-07-18 15:26:56 +02:00
# port 25441 is HTTPS with self-signed cert - specte only makes sense to be served over HTTPS
2021-12-14 23:34:35 +01:00
/home/admin/config.scripts/tor.onion-service.sh specter 443 25441
2020-03-16 15:11:39 +01:00
fi
2020-10-11 19:47:05 +01:00
# blockfilterindex on
# check txindex (parsed and sourced from bitcoin network config above)
2020-10-28 22:22:54 +01:00
if [ " ${ blockfilterindex } " = "0" ] ; then
2020-10-11 19:47:05 +01:00
sudo sed -i "s/^blockfilterindex=.*/blockfilterindex=1/g" /mnt/hdd/${ network } /${ network } .conf
2020-10-28 22:22:54 +01:00
echo "# switching blockfilterindex=1"
2021-03-18 22:14:05 +00:00
isBitcoinRunning = $( systemctl is-active ${ network } d | grep -c "^active" )
2020-10-28 22:22:54 +01:00
if [ ${ isBitcoinRunning } -eq 1 ] ; then
echo " # ${ network } d is running - so restarting "
sudo systemctl restart ${ network } d
else
echo " # ${ network } d is not running - so NOT restarting "
fi
echo "# The indexing takes ~10h on an RPi4 with SSD"
echo "# check with: sudo cat /mnt/hdd/bitcoin/debug.log | grep filter"
2020-10-11 19:47:05 +01:00
else
2020-10-28 22:22:54 +01:00
echo "# blockfilterindex is already active"
2020-10-11 19:47:05 +01:00
fi
2022-05-05 10:59:50 +02:00
# needed for API/WebUI as signal that install ran thru
echo "result='OK'"
2020-03-16 15:11:39 +01:00
exit 0
fi
# switch off
if [ " $1 " = "0" ] || [ " $1 " = "off" ] ; then
# setting value in raspi blitz config
2021-12-14 23:34:35 +01:00
/home/admin/config.scripts/blitz.conf.sh set specter "off"
2020-03-16 15:11:39 +01:00
2020-07-12 20:05:41 +02:00
# Hidden Service if Tor is active
if [ " ${ runBehindTor } " = "on" ] ; then
2022-05-05 10:59:50 +02:00
echo "# Removing Tor hidden service for specter ..."
2021-12-14 23:34:35 +01:00
/home/admin/config.scripts/tor.onion-service.sh off specter
2020-07-12 20:05:41 +02:00
fi
2021-08-23 17:23:01 +01:00
isInstalled = $( sudo ls /etc/systemd/system/specter.service 2>/dev/null | grep -c 'specter.service' )
2022-05-05 10:59:50 +02:00
if [ ${ isInstalled } -eq 0 ] ; then
echo "error='was not installed'"
exit 1
fi
2020-03-16 15:11:39 +01:00
2022-05-05 10:59:50 +02:00
# removing base systemd service & code
echo "# --> REMOVING Specter Desktop"
sudo systemctl stop specter
sudo systemctl disable specter
sudo rm /etc/systemd/system/specter.service
sudo -u specter /home/specter/.env/bin/python3 -m pip uninstall --yes cryptoadvance.specter 1>& 2
# get delete data status - either by parameter or if not set by user dialog
deleteData = ""
if [ " $2 " = = "--delete-data" ] ; then
deleteData = "1"
fi
if [ " $2 " = = "--keep-data" ] ; then
deleteData = "0"
fi
if [ " ${ deleteData } " = = "" ] ; then
deleteData = whiptail --defaultno --yesno "Do you want to delete all Data related to specter? This includes also Bitcoin-Core-Wallets managed by specter?" 0 0
fi
# execute on delete data
if [ " ${ deleteData } " = = "1" ] ; then
echo "# --> Removing wallets in core"
bitcoin-cli listwallets | jq -r .[ ] | tail -n +2
for i in $( bitcoin-cli listwallets | jq -r .[ ] | tail -n +2)
do
name = $( echo $i | cut -d"/" -f2)
bitcoin-cli unloadwallet specter/$name
done
echo "# --> Removing the /mnt/hdd/app-data/.specter"
sudo rm -rf /mnt/hdd/app-data/.specter
2021-12-14 23:34:35 +01:00
else
2022-05-05 10:59:50 +02:00
echo "# --> wallets in core are preserved on the disk (if exist)"
echo "# --> /mnt/hdd/app-data/.specter is preserved on the disk"
2020-03-16 15:11:39 +01:00
fi
2022-05-05 10:59:50 +02:00
echo "# --> Removing the specter user and home directory"
sudo userdel -rf specter
echo "# --> OK Specter Desktop removed."
# needed for API/WebUI as signal that install ran thru
echo "result='OK'"
2020-03-16 15:11:39 +01:00
exit 0
fi
2020-09-02 10:11:50 +01:00
# update
if [ " $1 " = "update" ] ; then
2021-08-23 17:23:01 +01:00
echo "# --> UPDATING Specter Desktop "
2020-12-15 16:57:30 +00:00
sudo -u specter /home/specter/.env/bin/python3 -m pip install --upgrade cryptoadvance.specter
2020-09-02 10:11:50 +01:00
echo "# --> Updated to the latest in https://pypi.org/project/cryptoadvance.specter/#history ***"
2021-08-23 17:23:01 +01:00
echo "# --> Restarting the specter.service"
sudo systemctl restart specter
2020-09-02 10:11:50 +01:00
exit 0
fi
2020-06-06 22:23:50 +02:00
echo "error='unknown parameter'"
2020-03-16 15:11:39 +01:00
exit 1