From 047357e61c907a1ce542cdfa14d0d799caff09c3 Mon Sep 17 00:00:00 2001 From: ben Date: Sun, 10 Sep 2023 03:26:19 +0000 Subject: [PATCH] Update 'root/usr/libexec/apps/btcpayserver/btcpayserver.sh' --- .../libexec/apps/btcpayserver/btcpayserver.sh | 110 +++++++++--------- 1 file changed, 58 insertions(+), 52 deletions(-) diff --git a/root/usr/libexec/apps/btcpayserver/btcpayserver.sh b/root/usr/libexec/apps/btcpayserver/btcpayserver.sh index c98a780..a6d62a5 100644 --- a/root/usr/libexec/apps/btcpayserver/btcpayserver.sh +++ b/root/usr/libexec/apps/btcpayserver/btcpayserver.sh @@ -1,36 +1,43 @@ #!/bin/sh -ACTION=${1} +APP_NAME="node-red" + +ACTION="${1}" shift 1 get_image() { - IMAGE_NAME=$(uci get btcpayserver.@btcpayserver[0].image_name 2>/dev/null) + do_install_detail } do_install_detail() { + local config port IMAGE_NAME username password LAN_IP config=$(uci get btcpayserver.@btcpayserver[0].config_path 2>/dev/null) port=$(uci get btcpayserver.@btcpayserver[0].port 2>/dev/null) IMAGE_NAME=$(uci get btcpayserver.@btcpayserver[0].image_name 2>/dev/null) + username=$(uci get btcpayserver.@btcpayserver[0].username 2>/dev/null) + password=$(uci get btcpayserver.@btcpayserver[0].password 2>/dev/null) + APP_NAME="node-red" - GEN_PASS=$(head -c14 /dev/urandom | tr -dc A-Za-z0-9) - GEN_PASS2=$(head -c14 /dev/urandom | tr -dc A-Za-z0-9) + GEN_PASS=$(< /dev/urandom tr -dc A-Za-z0-9 2>/dev/null | head -c 14; echo) + GEN_PASS2=$(< /dev/urandom tr -dc A-Za-z0-9 2>/dev/null | head -c 14; echo) LAN_IP=$(uci get network.lan.ipaddr) LAN_IP="${LAN_IP%/*}" - [ -z "$config" ] && { echo "config path is empty!"; exit 1; } - [ -z "$port" ] && port=8888 - [ -z "$IMAGE_NAME" ] && IMAGE_NAME=clightning -} + if [ -z "$config" ]; then + echo "config path is empty!" + exit 1 + fi -setup_btcpayserver() { - git clone https://github.com/btcpayserver/btcpayserver-docker /opt/docker2/compose/btcpayserver/btcpayserver-docker/ + [ -z "$port" ] && port=1880 + [ -z "$IMAGE_NAME" ] && IMAGE_NAME="btcpayserver/node-red:latest" - touch /opt/docker2/compose/btcpayserver/btcpayserver-docker/go.sh - chmod +x /opt/docker2/compose/btcpayserver/btcpayserver-docker/go.sh - cat > /opt/docker2/compose/btcpayserver/btcpayserver-docker/go.sh </dev/null + mkdir -p /opt/docker2/compose/btcpayserver/ + cat > /opt/docker2/compose/btcpayserver/satoshi.sh </dev/null) + [ -z "$IMAGE_NAME" ] && IMAGE_NAME="btcpayserver" + CONTAINER_IDS=$(docker ps -a --filter "ancestor=${IMAGE_NAME}" --format '{{.ID}}') + echo "Stopping and removing containers..." + for ID in $CONTAINER_IDS; do + docker stop "$ID" + docker rm "$ID" + done + docker rmi -f "$IMAGE_NAME" + rm -r /opt/docker2/compose/btcpayserver 2>/dev/null ;; - "start"|"stop"|"restart") - docker "${ACTION}" btcpayserver + "start" | "stop" | "restart") + APP_NAME="btcpayserver" + CONTAINER_IDS=$(docker ps -a --filter "ancestor=${APP_NAME}" --format '{{.ID}}') + for ID in $CONTAINER_IDS; do + docker "${ACTION}" "${ID}" + done ;; "status") - docker ps --all -f 'name=btcpayserver' --format '{{.State}}' + APP_NAME="btcpayserver" + CONTAINER_NAMES=$(docker ps -a --filter "name=${APP_NAME}" --format '{{.Names}}') + docker ps --all -f "name=${CONTAINER_NAMES}" --format '{{.Status}}' ;; "port") - docker ps --all -f 'name=btcpayserver' --format '{{.Ports}}' | grep -om1 '0.0.0.0:[0-9]*' | sed 's/0.0.0.0://' + APP_NAME="btcpayserver" + CONTAINER_NAMES=$(docker ps -a --filter "ancestor=${APP_NAME}" --format '{{.Names}}') + docker ps --all -f "name=${CONTAINER_NAMES}" --format '{{.Ports}}' | grep -o -m1 '0.0.0.0:[0-9]*' | sed 's/0.0.0.0://' ;; *) usage