From d050d1eaeaf1a208548817bd444cb49959f4de81 Mon Sep 17 00:00:00 2001 From: Don Locke Date: Tue, 1 Apr 2025 17:08:21 -0600 Subject: [PATCH 01/21] add AllStarLink Script --- ct/allstarlink.sh | 44 +++++++++++++++++++ ct/headers/allstarlink | 5 +++ frontend/public/json/allstarlink.json | 39 +++++++++++++++++ install/allstarlink-install.sh | 62 +++++++++++++++++++++++++++ 4 files changed, 150 insertions(+) create mode 100644 ct/allstarlink.sh create mode 100644 ct/headers/allstarlink create mode 100644 frontend/public/json/allstarlink.json create mode 100644 install/allstarlink-install.sh diff --git a/ct/allstarlink.sh b/ct/allstarlink.sh new file mode 100644 index 0000000..b9e6106 --- /dev/null +++ b/ct/allstarlink.sh @@ -0,0 +1,44 @@ +#!/usr/bin/env bash +source <(curl -s https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/build.func) +# Copyright (c) 2021-2025 community-scripts ORG +# Author: Don Locke (DonLocke) +# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE +# Source: https://github.com/AllStarLink + +APP="AllStarLink" +var_tags="radio" +var_cpu="1" +var_ram="512" +var_disk="8" +var_os="debian" +var_version="12" +var_unprivileged="1" + +header_info "$APP" +variables +color +catch_errors + +function update_script() { + header_info + check_container_storage + check_container_resources + if [[ ! -d /etc/asterisk ]]; then + msg_error "No ${APP} Installation Found!" + exit + fi + msg_info "Updating $APP LXC" + $STD apt-get update + $STD DEBIAN_FRONTEND=noninteractive apt-get -y upgrade + msg_ok "Updated $APP LXC" + exit +} + +start +build_container +description + +msg_ok "Completed Successfully!\n" +echo -e "${CREATING}${GN}${APP} setup has been successfully initialized!${CL}" +echo -e "${INFO}${YW} Access it using the following URL:${CL}" +echo -e "${TAB}${GATEWAY}${BGN}http://${IP}/allmon3${CL}" diff --git a/ct/headers/allstarlink b/ct/headers/allstarlink new file mode 100644 index 0000000..9b97c4a --- /dev/null +++ b/ct/headers/allstarlink @@ -0,0 +1,5 @@ + ___ ____ ____ __ __ _ __ + / | / / / ___// /_____ ______/ / (_)___ / /__ + / /| | / / /\__ \/ __/ __ `/ ___/ / / / __ \/ //_/ + / ___ |/ / /___/ / /_/ /_/ / / / /___/ / / / / ,< +/_/ |_/_/_/_____/\__/\__,_/_/ /_____/_/_/ /_/_/|_| diff --git a/frontend/public/json/allstarlink.json b/frontend/public/json/allstarlink.json new file mode 100644 index 0000000..515c463 --- /dev/null +++ b/frontend/public/json/allstarlink.json @@ -0,0 +1,39 @@ +{ + "name": "AllStarLink", + "slug": "allstarlink", + "categories": [ + 24 + ], + "date_created": "2025-3-30", + "type": "ct", + "updateable": true, + "privileged": false, + "interface_port": 80, + "documentation": "https://allstarlink.github.io/", + "website": "https://www.allstarlink.org/", + "logo": "https://raw.githubusercontent.com/AllStarLink/ASL3-Manual/blob/main/docs/assets/allstar-logo-small.png", + "description": "AllStarLink is a network of Amateur Radio repeaters, remote base stations and hot spots accessible to each other via Voice over Internet Protocol.", + "install_methods": [ + { + "type": "default", + "script": "ct/allstarlink.sh", + "resources": { + "cpu": 1, + "ram": 512, + "hdd": 8, + "os": "debian", + "version": "12" + } + } + ], + "default_credentials": { + "username": null, + "password": null + }, + "notes": [ + { + "text": "Options to Install Allmon3", + "type": "info" + } + ] +} diff --git a/install/allstarlink-install.sh b/install/allstarlink-install.sh new file mode 100644 index 0000000..38d327e --- /dev/null +++ b/install/allstarlink-install.sh @@ -0,0 +1,62 @@ +#!/usr/bin/env bash + +# Copyright (c) 2021-2025 community-scripts ORG +# Author: Don Locke (DonLocke) +# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE +# Source: https://github.com/AllStarLink + +source /dev/stdin <<<"$FUNCTIONS_FILE_PATH" +color +verb_ip6 +catch_errors +setting_up_container +network_check +update_os + +msg_info "Adding ASL Package Repository" +wget -q -P /tmp https://repo.allstarlink.org/public/asl-apt-repos.deb12_all.deb +$STD dpkg -i /tmp/asl-apt-repos.deb12_all.deb +$STD apt-get update +msg_ok "Added ASL Package Repository" + +msg_info "Installing AllStarLink" +$STD apt-get install -y asl3 +msg_ok "Installed AllStarLink" + +msg_info "Configuring AllStarLink" +sed -i "/secret /s/= .*/= $(openssl rand -base64 18 | tr -dc 'a-zA-Z0-9' | head -c13)/" /etc/asterisk/manager.conf +msg_ok "Configured AllStarLink" + +read -r -p "Would you like to set up AllStarLink Node now? " prompt +if [[ ${prompt,,} =~ ^(y|yes)$ ]]; then + node-setup +else + msg_warn "You will need to run \`node-setup\` before you can connect to the AllStarLink Network." +fi + +read -r -p "Would you like to add Allmon3? " prompt +if [[ ${prompt,,} =~ ^(y|yes)$ ]]; then + msg_info "Installing Allmon3" + $STD apt-get install -y allmon3 + msg_ok "Installed Allmon3" + + NODE=$(grep -oP '^\[\d+\]\(node-main\)' /etc/asterisk/rpt.conf | grep -oP '\d+') + if [[ -n $NODE ]]; then + msg_info "Configuring Allmon3" + sed -i "s/;\[1999\]/\[$NODE\]/" /etc/allmon3/allmon3.ini + sed -i "s/;host/host/" /etc/allmon3/allmon3.ini + sed -i "s/;user/user/" /etc/allmon3/allmon3.ini + sed -i "s/;pass=.*/pass=$(sed -ne 's/^secret = //p' /etc/asterisk/manager.conf)/" /etc/allmon3/allmon3.ini + systemctl restart allmon3 + msg_ok "Configured Allmon3" + fi +fi + +motd_ssh +customize + +msg_info "Cleaning up" +rm -f /tmp/asl-apt-repos.deb12_all.deb +$STD apt-get -y autoremove +$STD apt-get -y autoclean +msg_ok "Cleaned" From 7404c6dda46f52fd590ea3bbe12cba0baac0287e Mon Sep 17 00:00:00 2001 From: Don Locke Date: Wed, 2 Apr 2025 14:04:27 -0600 Subject: [PATCH 02/21] Remove Header --- ct/headers/allstarlink | 5 ----- 1 file changed, 5 deletions(-) delete mode 100644 ct/headers/allstarlink diff --git a/ct/headers/allstarlink b/ct/headers/allstarlink deleted file mode 100644 index 9b97c4a..0000000 --- a/ct/headers/allstarlink +++ /dev/null @@ -1,5 +0,0 @@ - ___ ____ ____ __ __ _ __ - / | / / / ___// /_____ ______/ / (_)___ / /__ - / /| | / / /\__ \/ __/ __ `/ ___/ / / / __ \/ //_/ - / ___ |/ / /___/ / /_/ /_/ / / / /___/ / / / / ,< -/_/ |_/_/_/_____/\__/\__,_/_/ /_____/_/_/ /_/_/|_| From 53559fb0b7ba0ef7fdf35b021cfd4f007dc06498 Mon Sep 17 00:00:00 2001 From: CanbiZ <47820557+MickLesk@users.noreply.github.com> Date: Wed, 2 Apr 2025 23:24:38 +0200 Subject: [PATCH 03/21] Update VE -> VED MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Slaviša Arežina <58952836+tremor021@users.noreply.github.com> --- ct/allstarlink.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ct/allstarlink.sh b/ct/allstarlink.sh index b9e6106..b331818 100644 --- a/ct/allstarlink.sh +++ b/ct/allstarlink.sh @@ -1,5 +1,5 @@ #!/usr/bin/env bash -source <(curl -s https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/build.func) +source <(curl -s https://raw.githubusercontent.com/community-scripts/ProxmoxVED/main/misc/build.func) # Copyright (c) 2021-2025 community-scripts ORG # Author: Don Locke (DonLocke) # License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE From bb598f86219374865185533b5389a1303fa68967 Mon Sep 17 00:00:00 2001 From: Don Locke <75755573+DonLocke@users.noreply.github.com> Date: Thu, 3 Apr 2025 11:17:02 -0600 Subject: [PATCH 04/21] change wget to curl MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Slaviša Arežina <58952836+tremor021@users.noreply.github.com> --- install/allstarlink-install.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/install/allstarlink-install.sh b/install/allstarlink-install.sh index 38d327e..1393033 100644 --- a/install/allstarlink-install.sh +++ b/install/allstarlink-install.sh @@ -14,7 +14,7 @@ network_check update_os msg_info "Adding ASL Package Repository" -wget -q -P /tmp https://repo.allstarlink.org/public/asl-apt-repos.deb12_all.deb +curl -fsSL "https://repo.allstarlink.org/public/asl-apt-repos.deb12_all.deb" -o /tmp/asl-apt-repos.deb12_all.deb $STD dpkg -i /tmp/asl-apt-repos.deb12_all.deb $STD apt-get update msg_ok "Added ASL Package Repository" From 19c6317fe1b80ed042ad5e78da1d21b03abdef27 Mon Sep 17 00:00:00 2001 From: Don Locke Date: Sat, 5 Apr 2025 17:34:26 -0600 Subject: [PATCH 05/21] Switch to VM --- ct/allstarlink.sh | 44 --- frontend/public/json/allstarlink.json | 20 +- install/allstarlink-install.sh | 62 ---- vm/allstarlink-vm.sh | 509 ++++++++++++++++++++++++++ vm/update/allstarlink.sh | 20 + 5 files changed, 539 insertions(+), 116 deletions(-) delete mode 100644 ct/allstarlink.sh delete mode 100644 install/allstarlink-install.sh create mode 100644 vm/allstarlink-vm.sh create mode 100644 vm/update/allstarlink.sh diff --git a/ct/allstarlink.sh b/ct/allstarlink.sh deleted file mode 100644 index b331818..0000000 --- a/ct/allstarlink.sh +++ /dev/null @@ -1,44 +0,0 @@ -#!/usr/bin/env bash -source <(curl -s https://raw.githubusercontent.com/community-scripts/ProxmoxVED/main/misc/build.func) -# Copyright (c) 2021-2025 community-scripts ORG -# Author: Don Locke (DonLocke) -# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE -# Source: https://github.com/AllStarLink - -APP="AllStarLink" -var_tags="radio" -var_cpu="1" -var_ram="512" -var_disk="8" -var_os="debian" -var_version="12" -var_unprivileged="1" - -header_info "$APP" -variables -color -catch_errors - -function update_script() { - header_info - check_container_storage - check_container_resources - if [[ ! -d /etc/asterisk ]]; then - msg_error "No ${APP} Installation Found!" - exit - fi - msg_info "Updating $APP LXC" - $STD apt-get update - $STD DEBIAN_FRONTEND=noninteractive apt-get -y upgrade - msg_ok "Updated $APP LXC" - exit -} - -start -build_container -description - -msg_ok "Completed Successfully!\n" -echo -e "${CREATING}${GN}${APP} setup has been successfully initialized!${CL}" -echo -e "${INFO}${YW} Access it using the following URL:${CL}" -echo -e "${TAB}${GATEWAY}${BGN}http://${IP}/allmon3${CL}" diff --git a/frontend/public/json/allstarlink.json b/frontend/public/json/allstarlink.json index 515c463..b16e02c 100644 --- a/frontend/public/json/allstarlink.json +++ b/frontend/public/json/allstarlink.json @@ -1,14 +1,14 @@ { "name": "AllStarLink", - "slug": "allstarlink", + "slug": "allstarlink-vm", "categories": [ 24 ], "date_created": "2025-3-30", - "type": "ct", + "type": "vm", "updateable": true, "privileged": false, - "interface_port": 80, + "interface_port": null, "documentation": "https://allstarlink.github.io/", "website": "https://www.allstarlink.org/", "logo": "https://raw.githubusercontent.com/AllStarLink/ASL3-Manual/blob/main/docs/assets/allstar-logo-small.png", @@ -16,10 +16,10 @@ "install_methods": [ { "type": "default", - "script": "ct/allstarlink.sh", + "script": "vm/allstarlink-vm.sh", "resources": { - "cpu": 1, - "ram": 512, + "cpu": 2, + "ram": 2048, "hdd": 8, "os": "debian", "version": "12" @@ -31,9 +31,9 @@ "password": null }, "notes": [ - { - "text": "Options to Install Allmon3", - "type": "info" - } + { + "text": "Options to Install Allmon3", + "type": "info" + } ] } diff --git a/install/allstarlink-install.sh b/install/allstarlink-install.sh deleted file mode 100644 index 1393033..0000000 --- a/install/allstarlink-install.sh +++ /dev/null @@ -1,62 +0,0 @@ -#!/usr/bin/env bash - -# Copyright (c) 2021-2025 community-scripts ORG -# Author: Don Locke (DonLocke) -# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE -# Source: https://github.com/AllStarLink - -source /dev/stdin <<<"$FUNCTIONS_FILE_PATH" -color -verb_ip6 -catch_errors -setting_up_container -network_check -update_os - -msg_info "Adding ASL Package Repository" -curl -fsSL "https://repo.allstarlink.org/public/asl-apt-repos.deb12_all.deb" -o /tmp/asl-apt-repos.deb12_all.deb -$STD dpkg -i /tmp/asl-apt-repos.deb12_all.deb -$STD apt-get update -msg_ok "Added ASL Package Repository" - -msg_info "Installing AllStarLink" -$STD apt-get install -y asl3 -msg_ok "Installed AllStarLink" - -msg_info "Configuring AllStarLink" -sed -i "/secret /s/= .*/= $(openssl rand -base64 18 | tr -dc 'a-zA-Z0-9' | head -c13)/" /etc/asterisk/manager.conf -msg_ok "Configured AllStarLink" - -read -r -p "Would you like to set up AllStarLink Node now? " prompt -if [[ ${prompt,,} =~ ^(y|yes)$ ]]; then - node-setup -else - msg_warn "You will need to run \`node-setup\` before you can connect to the AllStarLink Network." -fi - -read -r -p "Would you like to add Allmon3? " prompt -if [[ ${prompt,,} =~ ^(y|yes)$ ]]; then - msg_info "Installing Allmon3" - $STD apt-get install -y allmon3 - msg_ok "Installed Allmon3" - - NODE=$(grep -oP '^\[\d+\]\(node-main\)' /etc/asterisk/rpt.conf | grep -oP '\d+') - if [[ -n $NODE ]]; then - msg_info "Configuring Allmon3" - sed -i "s/;\[1999\]/\[$NODE\]/" /etc/allmon3/allmon3.ini - sed -i "s/;host/host/" /etc/allmon3/allmon3.ini - sed -i "s/;user/user/" /etc/allmon3/allmon3.ini - sed -i "s/;pass=.*/pass=$(sed -ne 's/^secret = //p' /etc/asterisk/manager.conf)/" /etc/allmon3/allmon3.ini - systemctl restart allmon3 - msg_ok "Configured Allmon3" - fi -fi - -motd_ssh -customize - -msg_info "Cleaning up" -rm -f /tmp/asl-apt-repos.deb12_all.deb -$STD apt-get -y autoremove -$STD apt-get -y autoclean -msg_ok "Cleaned" diff --git a/vm/allstarlink-vm.sh b/vm/allstarlink-vm.sh new file mode 100644 index 0000000..9d7675e --- /dev/null +++ b/vm/allstarlink-vm.sh @@ -0,0 +1,509 @@ +#!/usr/bin/env bash + +# Copyright (c) 2021-2025 community-scripts ORG +# Author: Don Locke (DonLocke) +# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE +# Source: https://github.com/AllStarLink + +source /dev/stdin <<<$(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVED/main/misc/api.func) + +function header_info { + clear + cat <<"EOF" + ___ ____ ____ __ __ _ __ _ ____ ___ + / | / / / ___// /_____ ______/ / (_)___ / /__ | | / / |/ / + / /| | / / /\__ \/ __/ __ `/ ___/ / / / __ \/ //_/ | | / / /|_/ / + / ___ |/ / /___/ / /_/ /_/ / / / /___/ / / / / ,< | |/ / / / / +/_/ |_/_/_/_____/\__/\__,_/_/ /_____/_/_/ /_/_/|_| |___/_/ /_/ + +EOF +} +header_info +echo -e "\n Loading..." +GEN_MAC=02:$(openssl rand -hex 5 | awk '{print toupper($0)}' | sed 's/\(..\)/\1:/g; s/.$//') +NEXTID=$(pvesh get /cluster/nextid) +RANDOM_UUID="$(cat /proc/sys/kernel/random/uuid)" +METHOD="" +NSAPP="debian12vm" +var_os="debian" +var_version="12" +DISK_SIZE="8G" + +YW=$(echo "\033[33m") +BL=$(echo "\033[36m") +HA=$(echo "\033[1;34m") +RD=$(echo "\033[01;31m") +BGN=$(echo "\033[4;92m") +GN=$(echo "\033[1;92m") +DGN=$(echo "\033[32m") +CL=$(echo "\033[m") +BFR="\\r\\033[K" +HOLD="-" +CM="${GN}✓${CL}" +CROSS="${RD}✗${CL}" +THIN="discard=on,ssd=1," +set -e +trap 'error_handler $LINENO "$BASH_COMMAND"' ERR +trap cleanup EXIT +trap 'post_update_to_api "failed" "INTERRUPTED"' SIGINT +trap 'post_update_to_api "failed" "TERMINATED"' SIGTERM +function error_handler() { + local exit_code="$?" + local line_number="$1" + local command="$2" + post_update_to_api "failed" "${command}" + local error_message="${RD}[ERROR]${CL} in line ${RD}$line_number${CL}: exit code ${RD}$exit_code${CL}: while executing command ${YW}$command${CL}" + echo -e "\n$error_message\n" + cleanup_vmid +} + +function cleanup_vmid() { + if qm status $VMID &>/dev/null; then + qm stop $VMID &>/dev/null + qm destroy $VMID &>/dev/null + fi +} + +function cleanup() { + popd >/dev/null + rm -rf $TEMP_DIR +} + +TEMP_DIR=$(mktemp -d) +pushd $TEMP_DIR >/dev/null +if whiptail --backtitle "Proxmox VE Helper Scripts" --title "AllStarLink VM" --yesno "This will create a New AllStarLink VM. Proceed?" 10 58; then + : +else + header_info && echo -e "⚠ User exited script \n" && exit +fi + +function msg_info() { + local msg="$1" + echo -ne " ${HOLD} ${YW}${msg}..." +} + +function msg_ok() { + local msg="$1" + echo -e "${BFR} ${CM} ${GN}${msg}${CL}" +} + +function msg_error() { + local msg="$1" + echo -e "${BFR} ${CROSS} ${RD}${msg}${CL}" +} + +function check_root() { + if [[ "$(id -u)" -ne 0 || $(ps -o comm= -p $PPID) == "sudo" ]]; then + clear + msg_error "Please run this script as root." + echo -e "\nExiting..." + sleep 2 + exit + fi +} + +function pve_check() { + if ! pveversion | grep -Eq "pve-manager/8\.[1-3](\.[0-9]+)*"; then + msg_error "This version of Proxmox Virtual Environment is not supported" + echo -e "Requires Proxmox Virtual Environment Version 8.1 or later." + echo -e "Exiting..." + sleep 2 + exit + fi +} + +function arch_check() { + if [ "$(dpkg --print-architecture)" != "amd64" ]; then + if [ "$(dpkg --print-architecture)" != "arm64" ]; then + msg_error "This script will not work with your CPU Architekture \n" + echo -e "Exiting..." + sleep 2 + exit + fi + fi +} + +function ssh_check() { + if command -v pveversion >/dev/null 2>&1; then + if [ -n "${SSH_CLIENT:+x}" ]; then + if whiptail --backtitle "Proxmox VE Helper Scripts" --defaultno --title "SSH DETECTED" --yesno "It's suggested to use the Proxmox shell instead of SSH, since SSH can create issues while gathering variables. Would you like to proceed with using SSH?" 10 62; then + echo "you've been warned" + else + clear + exit + fi + fi + fi +} + +function exit-script() { + clear + echo -e "⚠ User exited script \n" + exit +} + +function default_settings() { + VMID="$NEXTID" + FORMAT=",efitype=4m" + MACHINE="" + DISK_CACHE="" + HN="allstarlink" + CPU_TYPE="" + CORE_COUNT="2" + RAM_SIZE="2048" + BRG="vmbr0" + MAC="$GEN_MAC" + VLAN="" + MTU="" + START_VM="yes" + METHOD="default" + echo -e "${DGN}Using Virtual Machine ID: ${BGN}${VMID}${CL}" + echo -e "${DGN}Using Machine Type: ${BGN}i440fx${CL}" + echo -e "${DGN}Using Disk Cache: ${BGN}None${CL}" + echo -e "${DGN}Using Hostname: ${BGN}${HN}${CL}" + echo -e "${DGN}Using CPU Model: ${BGN}KVM64${CL}" + echo -e "${DGN}Allocated Cores: ${BGN}${CORE_COUNT}${CL}" + echo -e "${DGN}Allocated RAM: ${BGN}${RAM_SIZE}${CL}" + echo -e "${DGN}Using Bridge: ${BGN}${BRG}${CL}" + echo -e "${DGN}Using MAC Address: ${BGN}${MAC}${CL}" + echo -e "${DGN}Using VLAN: ${BGN}Default${CL}" + echo -e "${DGN}Using Interface MTU Size: ${BGN}Default${CL}" + echo -e "${DGN}Start VM when completed: ${BGN}yes${CL}" + echo -e "${BL}Creating a AllStarLink VM using the above default settings${CL}" +} + +function advanced_settings() { + METHOD="advanced" + while true; do + if VMID=$(whiptail --backtitle "Proxmox VE Helper Scripts" --inputbox "Set Virtual Machine ID" 8 58 $NEXTID --title "VIRTUAL MACHINE ID" --cancel-button Exit-Script 3>&1 1>&2 2>&3); then + if [ -z "$VMID" ]; then + VMID="$NEXTID" + fi + if pct status "$VMID" &>/dev/null || qm status "$VMID" &>/dev/null; then + echo -e "${CROSS}${RD} ID $VMID is already in use${CL}" + sleep 2 + continue + fi + echo -e "${DGN}Virtual Machine ID: ${BGN}$VMID${CL}" + break + else + exit-script + fi + done + + if MACH=$(whiptail --backtitle "Proxmox VE Helper Scripts" --title "MACHINE TYPE" --radiolist --cancel-button Exit-Script "Choose Type" 10 58 2 \ + "i440fx" "Machine i440fx" ON \ + "q35" "Machine q35" OFF \ + 3>&1 1>&2 2>&3); then + if [ $MACH = q35 ]; then + echo -e "${DGN}Using Machine Type: ${BGN}$MACH${CL}" + FORMAT="" + MACHINE=" -machine q35" + else + echo -e "${DGN}Using Machine Type: ${BGN}$MACH${CL}" + FORMAT=",efitype=4m" + MACHINE="" + fi + else + exit-script + fi + + if DISK_CACHE=$(whiptail --backtitle "Proxmox VE Helper Scripts" --title "DISK CACHE" --radiolist "Choose" --cancel-button Exit-Script 10 58 2 \ + "0" "None (Default)" ON \ + "1" "Write Through" OFF \ + 3>&1 1>&2 2>&3); then + if [ $DISK_CACHE = "1" ]; then + echo -e "${DGN}Using Disk Cache: ${BGN}Write Through${CL}" + DISK_CACHE="cache=writethrough," + else + echo -e "${DGN}Using Disk Cache: ${BGN}None${CL}" + DISK_CACHE="" + fi + else + exit-script + fi + + if VM_NAME=$(whiptail --backtitle "Proxmox VE Helper Scripts" --inputbox "Set Hostname" 8 58 allstarlink --title "HOSTNAME" --cancel-button Exit-Script 3>&1 1>&2 2>&3); then + if [ -z $VM_NAME ]; then + HN="allstarlink" + echo -e "${DGN}Using Hostname: ${BGN}$HN${CL}" + else + HN=$(echo ${VM_NAME,,} | tr -d ' ') + echo -e "${DGN}Using Hostname: ${BGN}$HN${CL}" + fi + else + exit-script + fi + + if CPU_TYPE1=$(whiptail --backtitle "Proxmox VE Helper Scripts" --title "CPU MODEL" --radiolist "Choose" --cancel-button Exit-Script 10 58 2 \ + "0" "KVM64 (Default)" ON \ + "1" "Host" OFF \ + 3>&1 1>&2 2>&3); then + if [ $CPU_TYPE1 = "1" ]; then + echo -e "${DGN}Using CPU Model: ${BGN}Host${CL}" + CPU_TYPE=" -cpu host" + else + echo -e "${DGN}Using CPU Model: ${BGN}KVM64${CL}" + CPU_TYPE="" + fi + else + exit-script + fi + + if CORE_COUNT=$(whiptail --backtitle "Proxmox VE Helper Scripts" --inputbox "Allocate CPU Cores" 8 58 2 --title "CORE COUNT" --cancel-button Exit-Script 3>&1 1>&2 2>&3); then + if [ -z $CORE_COUNT ]; then + CORE_COUNT="2" + echo -e "${DGN}Allocated Cores: ${BGN}$CORE_COUNT${CL}" + else + echo -e "${DGN}Allocated Cores: ${BGN}$CORE_COUNT${CL}" + fi + else + exit-script + fi + + if RAM_SIZE=$(whiptail --backtitle "Proxmox VE Helper Scripts" --inputbox "Allocate RAM in MiB" 8 58 2048 --title "RAM" --cancel-button Exit-Script 3>&1 1>&2 2>&3); then + if [ -z $RAM_SIZE ]; then + RAM_SIZE="4096" + echo -e "${DGN}Allocated RAM: ${BGN}$RAM_SIZE${CL}" + else + echo -e "${DGN}Allocated RAM: ${BGN}$RAM_SIZE${CL}" + fi + else + exit-script + fi + + if BRG=$(whiptail --backtitle "Proxmox VE Helper Scripts" --inputbox "Set a Bridge" 8 58 vmbr0 --title "BRIDGE" --cancel-button Exit-Script 3>&1 1>&2 2>&3); then + if [ -z $BRG ]; then + BRG="vmbr0" + echo -e "${DGN}Using Bridge: ${BGN}$BRG${CL}" + else + echo -e "${DGN}Using Bridge: ${BGN}$BRG${CL}" + fi + else + exit-script + fi + + if MAC1=$(whiptail --backtitle "Proxmox VE Helper Scripts" --inputbox "Set a MAC Address" 8 58 $GEN_MAC --title "MAC ADDRESS" --cancel-button Exit-Script 3>&1 1>&2 2>&3); then + if [ -z $MAC1 ]; then + MAC="$GEN_MAC" + echo -e "${DGN}Using MAC Address: ${BGN}$MAC${CL}" + else + MAC="$MAC1" + echo -e "${DGN}Using MAC Address: ${BGN}$MAC1${CL}" + fi + else + exit-script + fi + + if VLAN1=$(whiptail --backtitle "Proxmox VE Helper Scripts" --inputbox "Set a Vlan(leave blank for default)" 8 58 --title "VLAN" --cancel-button Exit-Script 3>&1 1>&2 2>&3); then + if [ -z $VLAN1 ]; then + VLAN1="Default" + VLAN="" + echo -e "${DGN}Using Vlan: ${BGN}$VLAN1${CL}" + else + VLAN=",tag=$VLAN1" + echo -e "${DGN}Using Vlan: ${BGN}$VLAN1${CL}" + fi + else + exit-script + fi + + if MTU1=$(whiptail --backtitle "Proxmox VE Helper Scripts" --inputbox "Set Interface MTU Size (leave blank for default)" 8 58 --title "MTU SIZE" --cancel-button Exit-Script 3>&1 1>&2 2>&3); then + if [ -z $MTU1 ]; then + MTU1="Default" + MTU="" + echo -e "${DGN}Using Interface MTU Size: ${BGN}$MTU1${CL}" + else + MTU=",mtu=$MTU1" + echo -e "${DGN}Using Interface MTU Size: ${BGN}$MTU1${CL}" + fi + else + exit-script + fi + + if (whiptail --backtitle "Proxmox VE Helper Scripts" --title "START VIRTUAL MACHINE" --yesno "Start VM when completed?" 10 58); then + echo -e "${DGN}Start VM when completed: ${BGN}yes${CL}" + START_VM="yes" + else + echo -e "${DGN}Start VM when completed: ${BGN}no${CL}" + START_VM="no" + fi + + if (whiptail --backtitle "Proxmox VE Helper Scripts" --title "ADVANCED SETTINGS COMPLETE" --yesno "Ready to create a AllStarLink VM?" --no-button Do-Over 10 58); then + echo -e "${RD}Creating a AllStarLink VM using the above advanced settings${CL}" + else + header_info + echo -e "${RD}Using Advanced Settings${CL}" + advanced_settings + fi +} + +function start_script() { + if (whiptail --backtitle "Proxmox VE Helper Scripts" --title "SETTINGS" --yesno "Use Default Settings?" --no-button Advanced 10 58); then + header_info + echo -e "${BL}Using Default Settings${CL}" + default_settings + else + header_info + echo -e "${RD}Using Advanced Settings${CL}" + advanced_settings + fi +} + +check_root +arch_check +pve_check +ssh_check +start_script +post_to_api_vm + +msg_info "Validating Storage" +while read -r line; do + TAG=$(echo $line | awk '{print $1}') + TYPE=$(echo $line | awk '{printf "%-10s", $2}') + FREE=$(echo $line | numfmt --field 4-6 --from-unit=K --to=iec --format %.2f | awk '{printf( "%9sB", $6)}') + ITEM=" Type: $TYPE Free: $FREE " + OFFSET=2 + if [[ $((${#ITEM} + $OFFSET)) -gt ${MSG_MAX_LENGTH:-} ]]; then + MSG_MAX_LENGTH=$((${#ITEM} + $OFFSET)) + fi + STORAGE_MENU+=("$TAG" "$ITEM" "OFF") +done < <(pvesm status -content images | awk 'NR>1') +VALID=$(pvesm status -content images | awk 'NR>1') +if [ -z "$VALID" ]; then + msg_error "Unable to detect a valid storage location." + exit +elif [ $((${#STORAGE_MENU[@]} / 3)) -eq 1 ]; then + STORAGE=${STORAGE_MENU[0]} +else + while [ -z "${STORAGE:+x}" ]; do + STORAGE=$(whiptail --backtitle "Proxmox VE Helper Scripts" --title "Storage Pools" --radiolist \ + "Which storage pool you would like to use for ${HN}?\nTo make a selection, use the Spacebar.\n" \ + 16 $(($MSG_MAX_LENGTH + 23)) 6 \ + "${STORAGE_MENU[@]}" 3>&1 1>&2 2>&3) || exit + done +fi +msg_ok "Using ${CL}${BL}$STORAGE${CL} ${GN}for Storage Location." +msg_ok "Virtual Machine ID is ${CL}${BL}$VMID${CL}." +msg_info "Retrieving the URL for the Debian 12 Qcow2 Disk Image" +URL="https://cloud.debian.org/images/cloud/bookworm/latest/debian-12-nocloud-$(dpkg --print-architecture).qcow2" +sleep 2 +msg_ok "${CL}${BL}${URL}${CL}" +curl -fsSL -o "$(basename "$URL")" "$URL" +echo -en "\e[1A\e[0K" +FILE=$(basename $URL) +msg_ok "Downloaded ${CL}${BL}${FILE}${CL}" + +STORAGE_TYPE=$(pvesm status -storage $STORAGE | awk 'NR>1 {print $2}') +case $STORAGE_TYPE in +nfs | dir) + DISK_EXT=".qcow2" + DISK_REF="$VMID/" + DISK_IMPORT="-format qcow2" + THIN="" + ;; +btrfs) + DISK_EXT=".raw" + DISK_REF="$VMID/" + DISK_IMPORT="-format raw" + FORMAT=",efitype=4m" + THIN="" + ;; +esac +for i in {0,1}; do + disk="DISK$i" + eval DISK${i}=vm-${VMID}-disk-${i}${DISK_EXT:-} + eval DISK${i}_REF=${STORAGE}:${DISK_REF:-}${!disk} +done + +#TODO Custom stuff + +msg_info "Installing Pre-Requisite libguestfs-tools onto Host" +apt-get -qq update && apt-get -qq install libguestfs-tools lsb-release -y >/dev/null +msg_ok "Installed libguestfs-tools successfully" + +msg_info "Adding ASL Package Repository" +virt-customize -q -a "${FILE}" \ + --run-command "curl -fsSL https://repo.allstarlink.org/public/asl-apt-repos.deb12_all.deb -o /tmp/asl-apt-repos.deb12_all.deb" \ + --run-command "dpkg -i /tmp/asl-apt-repos.deb12_all.deb" \ + --update \ + --run-command "rm -f /tmp/asl-apt-repos.deb12_all.deb" >/dev/null +msg_ok "Added ASL Package Repository" + +msg_info "Installing AllStarLink" +virt-customize -q -a "${FILE}" \ + --install asl3 \ + --run-command "sed -i \"/secret /s/= .*/= $(openssl rand -base64 18 | tr -dc 'a-zA-Z0-9' | head -c13)/\" /etc/asterisk/manager.conf" \ + --firstboot-command "node-setup" >/dev/null +msg_ok "Installed AllStarLink" + +if (whiptail --backtitle "Proxmox VE Helper Scripts" --title "SETTINGS" --yesno "Would you like to add Allmon3?" --no-button Advanced 10 58); then + msg_info "Installing Allmon3" + virt-customize -q -a "${FILE}" \ + --install allmon3 \ + --firstboot-command "sed -i \"s/;\[1999\]/\[$(grep -oP '^\[\d+\]\(node-main\)' /etc/asterisk/rpt.conf | grep -oP '\d+')\]/\" /etc/allmon3/allmon3.ini" \ + --firstboot-command "sed -i \"s/;host/host/\" /etc/allmon3/allmon3.ini" \ + --firstboot-command "sed -i \"s/;user/user/\" /etc/allmon3/allmon3.ini" \ + --firstboot-command "sed -i \"s/;pass=.*/pass=$(sed -ne 's/^secret = //p' /etc/asterisk/manager.conf)/\" /etc/allmon3/allmon3.ini" \ + --firstboot-command "systemctl restart allmon3" >/dev/null + msg_ok "Installed Allmon3" +fi + +virt-customize -q -a "${FILE}" \ + --touch /usr/bin/update \ + --write "bash -c \"\$(curl -fsSL https://github.com/community-scripts/ProxmoxVED/raw/main/vm/update/allstarlink.sh)\"":/usr/bin/update \ + --chmod 755:/usr/bin/update + +msg_info "Creating a AllStarLink VM" +qm create $VMID -agent 1${MACHINE} -tablet 0 -localtime 1 -bios ovmf${CPU_TYPE} -cores $CORE_COUNT -memory $RAM_SIZE \ + -name $HN -tags community-script,debian12,allstarlink -net0 virtio,bridge=$BRG,macaddr=$MAC$VLAN$MTU -onboot 1 -ostype l26 -scsihw virtio-scsi-pci +pvesm alloc $STORAGE $VMID $DISK0 4M 1>&/dev/null +qm importdisk $VMID ${FILE} $STORAGE ${DISK_IMPORT:-} 1>&/dev/null +qm set $VMID \ + -efidisk0 ${DISK0_REF}${FORMAT} \ + -scsi0 ${DISK1_REF},${DISK_CACHE}${THIN}size=2G \ + -boot order=scsi0 \ + -serial0 socket >/dev/null +qm resize $VMID scsi0 8G >/dev/null +qm set $VMID --agent enabled=1 >/dev/null + +DESCRIPTION=$( + cat < + + Logo + + +

AllStarLink VM

+ +

+ + spend Coffee + +

+ + + + GitHub + + + + Discussions + + + + Issues + + +EOF +) +qm set "$VMID" -description "$DESCRIPTION" >/dev/null + +msg_ok "Created a AllStarLink VM ${CL}${BL}(${HN})" +if [ "$START_VM" == "yes" ]; then + msg_info "Starting AllStarLink VM" + qm start $VMID + msg_ok "Started AllStarLink VM" +fi +post_update_to_api "done" "none" +msg_ok "Completed Successfully!\n" diff --git a/vm/update/allstarlink.sh b/vm/update/allstarlink.sh new file mode 100644 index 0000000..dd369a4 --- /dev/null +++ b/vm/update/allstarlink.sh @@ -0,0 +1,20 @@ +#!/usr/bin/env bash + +# Copyright (c) 2021-2025 community-scripts ORG +# Author: Don Locke (DonLocke) +# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE +# Source: https://github.com/AllStarLink + +APP="AllStarLink" + +header_info + +if [[ ! -d /etc/asterisk ]]; then +msg_error "No ${APP} Installation Found!" +exit +fi +msg_info "Updating $APP VM" +$STD apt-get update +$STD DEBIAN_FRONTEND=noninteractive apt-get -y upgrade +msg_ok "Updated $APP VM" +exit From 4d3ff9a02574bb2bea3da10aa06729b333f3ca3c Mon Sep 17 00:00:00 2001 From: Don Locke Date: Sat, 5 Apr 2025 18:24:35 -0600 Subject: [PATCH 06/21] Update Script --- vm/allstarlink-vm.sh | 21 ++++++++------------- 1 file changed, 8 insertions(+), 13 deletions(-) diff --git a/vm/allstarlink-vm.sh b/vm/allstarlink-vm.sh index 9d7675e..b74cf05 100644 --- a/vm/allstarlink-vm.sh +++ b/vm/allstarlink-vm.sh @@ -416,8 +416,6 @@ for i in {0,1}; do eval DISK${i}_REF=${STORAGE}:${DISK_REF:-}${!disk} done -#TODO Custom stuff - msg_info "Installing Pre-Requisite libguestfs-tools onto Host" apt-get -qq update && apt-get -qq install libguestfs-tools lsb-release -y >/dev/null msg_ok "Installed libguestfs-tools successfully" @@ -430,29 +428,26 @@ virt-customize -q -a "${FILE}" \ --run-command "rm -f /tmp/asl-apt-repos.deb12_all.deb" >/dev/null msg_ok "Added ASL Package Repository" -msg_info "Installing AllStarLink" +msg_info "Installing AllStarLink (patience)" virt-customize -q -a "${FILE}" \ --install asl3 \ - --run-command "sed -i \"/secret /s/= .*/= $(openssl rand -base64 18 | tr -dc 'a-zA-Z0-9' | head -c13)/\" /etc/asterisk/manager.conf" \ - --firstboot-command "node-setup" >/dev/null + --run-command "sed -i \"/secret /s/= .*/= $(openssl rand -base64 18 | tr -dc 'a-zA-Z0-9' | head -c13)/\" /etc/asterisk/manager.conf" >/dev/null msg_ok "Installed AllStarLink" -if (whiptail --backtitle "Proxmox VE Helper Scripts" --title "SETTINGS" --yesno "Would you like to add Allmon3?" --no-button Advanced 10 58); then +if (whiptail --backtitle "Proxmox VE Helper Scripts" --title "SETTINGS" --yesno "Would you like to add Allmon3?" 10 58); then msg_info "Installing Allmon3" virt-customize -q -a "${FILE}" \ --install allmon3 \ - --firstboot-command "sed -i \"s/;\[1999\]/\[$(grep -oP '^\[\d+\]\(node-main\)' /etc/asterisk/rpt.conf | grep -oP '\d+')\]/\" /etc/allmon3/allmon3.ini" \ - --firstboot-command "sed -i \"s/;host/host/\" /etc/allmon3/allmon3.ini" \ - --firstboot-command "sed -i \"s/;user/user/\" /etc/allmon3/allmon3.ini" \ - --firstboot-command "sed -i \"s/;pass=.*/pass=$(sed -ne 's/^secret = //p' /etc/asterisk/manager.conf)/\" /etc/allmon3/allmon3.ini" \ - --firstboot-command "systemctl restart allmon3" >/dev/null + --run-command "sed -i \"s/;pass=.*/;pass=\$(sed -ne 's/^secret = //p' /etc/asterisk/manager.conf)/\" /etc/allmon3/allmon3.ini" >/dev/null msg_ok "Installed Allmon3" fi +msg_info "Installing Update Script" virt-customize -q -a "${FILE}" \ --touch /usr/bin/update \ - --write "bash -c \"\$(curl -fsSL https://github.com/community-scripts/ProxmoxVED/raw/main/vm/update/allstarlink.sh)\"":/usr/bin/update \ - --chmod 755:/usr/bin/update + --write /usr/bin/update:"bash -c \"\$(curl -fsSL https://github.com/community-scripts/ProxmoxVED/raw/main/vm/update/allstarlink.sh)\"" \ + --chmod 755:/usr/bin/update >/dev/null +msg_ok "Installed Update Script" msg_info "Creating a AllStarLink VM" qm create $VMID -agent 1${MACHINE} -tablet 0 -localtime 1 -bios ovmf${CPU_TYPE} -cores $CORE_COUNT -memory $RAM_SIZE \ From 17a602dc54358adc70bdd33c3e52506897f4e1ff Mon Sep 17 00:00:00 2001 From: Don Locke Date: Sat, 5 Apr 2025 18:32:16 -0600 Subject: [PATCH 07/21] Remove Update script --- frontend/public/json/allstarlink.json | 2 +- vm/allstarlink-vm.sh | 7 ------- vm/update/allstarlink.sh | 20 -------------------- 3 files changed, 1 insertion(+), 28 deletions(-) delete mode 100644 vm/update/allstarlink.sh diff --git a/frontend/public/json/allstarlink.json b/frontend/public/json/allstarlink.json index b16e02c..c5d336e 100644 --- a/frontend/public/json/allstarlink.json +++ b/frontend/public/json/allstarlink.json @@ -6,7 +6,7 @@ ], "date_created": "2025-3-30", "type": "vm", - "updateable": true, + "updateable": false, "privileged": false, "interface_port": null, "documentation": "https://allstarlink.github.io/", diff --git a/vm/allstarlink-vm.sh b/vm/allstarlink-vm.sh index b74cf05..99d037e 100644 --- a/vm/allstarlink-vm.sh +++ b/vm/allstarlink-vm.sh @@ -442,13 +442,6 @@ if (whiptail --backtitle "Proxmox VE Helper Scripts" --title "SETTINGS" --yesno msg_ok "Installed Allmon3" fi -msg_info "Installing Update Script" -virt-customize -q -a "${FILE}" \ - --touch /usr/bin/update \ - --write /usr/bin/update:"bash -c \"\$(curl -fsSL https://github.com/community-scripts/ProxmoxVED/raw/main/vm/update/allstarlink.sh)\"" \ - --chmod 755:/usr/bin/update >/dev/null -msg_ok "Installed Update Script" - msg_info "Creating a AllStarLink VM" qm create $VMID -agent 1${MACHINE} -tablet 0 -localtime 1 -bios ovmf${CPU_TYPE} -cores $CORE_COUNT -memory $RAM_SIZE \ -name $HN -tags community-script,debian12,allstarlink -net0 virtio,bridge=$BRG,macaddr=$MAC$VLAN$MTU -onboot 1 -ostype l26 -scsihw virtio-scsi-pci diff --git a/vm/update/allstarlink.sh b/vm/update/allstarlink.sh deleted file mode 100644 index dd369a4..0000000 --- a/vm/update/allstarlink.sh +++ /dev/null @@ -1,20 +0,0 @@ -#!/usr/bin/env bash - -# Copyright (c) 2021-2025 community-scripts ORG -# Author: Don Locke (DonLocke) -# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE -# Source: https://github.com/AllStarLink - -APP="AllStarLink" - -header_info - -if [[ ! -d /etc/asterisk ]]; then -msg_error "No ${APP} Installation Found!" -exit -fi -msg_info "Updating $APP VM" -$STD apt-get update -$STD DEBIAN_FRONTEND=noninteractive apt-get -y upgrade -msg_ok "Updated $APP VM" -exit From 17b6f21a45905d6ad9a648e7bf667c6b336e9b07 Mon Sep 17 00:00:00 2001 From: Don Locke Date: Sat, 5 Apr 2025 18:34:25 -0600 Subject: [PATCH 08/21] Update tag --- vm/allstarlink-vm.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/vm/allstarlink-vm.sh b/vm/allstarlink-vm.sh index 99d037e..a0cbaf9 100644 --- a/vm/allstarlink-vm.sh +++ b/vm/allstarlink-vm.sh @@ -444,7 +444,7 @@ fi msg_info "Creating a AllStarLink VM" qm create $VMID -agent 1${MACHINE} -tablet 0 -localtime 1 -bios ovmf${CPU_TYPE} -cores $CORE_COUNT -memory $RAM_SIZE \ - -name $HN -tags community-script,debian12,allstarlink -net0 virtio,bridge=$BRG,macaddr=$MAC$VLAN$MTU -onboot 1 -ostype l26 -scsihw virtio-scsi-pci + -name $HN -tags community-script,debian12,radio -net0 virtio,bridge=$BRG,macaddr=$MAC$VLAN$MTU -onboot 1 -ostype l26 -scsihw virtio-scsi-pci pvesm alloc $STORAGE $VMID $DISK0 4M 1>&/dev/null qm importdisk $VMID ${FILE} $STORAGE ${DISK_IMPORT:-} 1>&/dev/null qm set $VMID \ From 235364518ad7a8ccb12ec8a8381102334d3aa26a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?N=C3=ADcolas=20Pastorello?= Date: Thu, 10 Apr 2025 15:57:01 -0300 Subject: [PATCH 09/21] Create jumpserver.json --- frontend/public/json/jumpserver.json | 34 ++++++++++++++++++++++++++++ 1 file changed, 34 insertions(+) create mode 100644 frontend/public/json/jumpserver.json diff --git a/frontend/public/json/jumpserver.json b/frontend/public/json/jumpserver.json new file mode 100644 index 0000000..cf1cdba --- /dev/null +++ b/frontend/public/json/jumpserver.json @@ -0,0 +1,34 @@ +{ + "name": "JumpServer", + "slug": "jumpserver", + "categories": [ + 6 + ], + "date_created": "2025-04-08", + "type": "ct", + "updateable": true, + "privileged": false, + "interface_port": 80, + "documentation": "https://www.jumpserver.com/docs", + "website": "https://www.jumpserver.com/", + "logo": "https://avatars.githubusercontent.com/u/68588906", + "description": "JumpServer is an open-source Privileged Access Management (PAM) tool that provides DevOps and IT teams with on-demand and secure access to SSH, RDP, Kubernetes, Database and RemoteApp endpoints through a web browser.", + "install_methods": [ + { + "type": "default", + "script": "ct/jumpserver.sh", + "resources": { + "cpu": 2, + "ram": 8192, + "hdd": 60, + "os": "debian", + "version": "12" + } + } + ], + "default_credentials": { + "username": "admin", + "password": "ChangeMe" + }, + "notes": [] +} From 3634a863b98d6289fa91d40cddf24e49a354987f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?N=C3=ADcolas=20Pastorello?= Date: Thu, 10 Apr 2025 15:57:25 -0300 Subject: [PATCH 10/21] Create jumpserver-install.sh --- install/jumpserver-install.sh | 49 +++++++++++++++++++++++++++++++++++ 1 file changed, 49 insertions(+) create mode 100644 install/jumpserver-install.sh diff --git a/install/jumpserver-install.sh b/install/jumpserver-install.sh new file mode 100644 index 0000000..41e7d66 --- /dev/null +++ b/install/jumpserver-install.sh @@ -0,0 +1,49 @@ +#!/usr/bin/env bash + +# Copyright (c) 2021-2025 community-scripts ORG +# Author: Nícolas Pastorello (opastorello) +# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE +# Source: https://jumpserver.com/ + +source /dev/stdin <<<"$FUNCTIONS_FILE_PATH" +color +verb_ip6 +catch_errors +setting_up_container +network_check +update_os + +msg_info "Installing Dependencies" +$STD apt-get install -y \ + curl \ + tar \ + iptables +msg_ok "Installed Dependencies" + +msg_info "Installing JumpServer" +cd /opt +RELEASE=$(curl -fsSL https://api.github.com/repos/jumpserver/installer/releases/latest | grep '"tag_name"' | sed -E 's/.*"tag_name": "([^"]+)".*/\1/') +curl -fsSL "https://github.com/jumpserver/installer/releases/download/${RELEASE}/jumpserver-installer-${RELEASE}.tar.gz" -o jumpserver-installer-${RELEASE}.tar.gz +$STD mkdir -p /opt/jumpserver +$STD tar -xzvf jumpserver-installer-${RELEASE}.tar.gz -C /opt/jumpserver --strip-components=1 +cd /opt/jumpserver +$STD ./jmsctl.sh install </opt/${APP}_version.txt +msg_ok "Installed JumpServer" + +motd_ssh +customize + +msg_info "Cleaning up" +rm -rf /opt/jumpserver-installer-${RELEASE}.tar.gz +$STD apt-get -y autoremove +$STD apt-get -y autoclean +msg_ok "Cleaned" From 6b02f6cf96de270a617fffd1aaf790550b2678fd Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?N=C3=ADcolas=20Pastorello?= Date: Thu, 10 Apr 2025 15:57:43 -0300 Subject: [PATCH 11/21] Create jumpserver.sh --- ct/jumpserver.sh | 67 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 67 insertions(+) create mode 100644 ct/jumpserver.sh diff --git a/ct/jumpserver.sh b/ct/jumpserver.sh new file mode 100644 index 0000000..4501ed9 --- /dev/null +++ b/ct/jumpserver.sh @@ -0,0 +1,67 @@ +#!/usr/bin/env bash +source <(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/build.func) +# Copyright (c) 2021-2025 community-scripts ORG +# Author: Nícolas Pastorello (opastorello) +# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE +# Source: https://jumpserver.com/ + +APP="JumpServer" +var_tags="bastion-host;pam" +var_cpu="2" +var_ram="8192" +var_disk="60" +var_os="debian" +var_version="12" +var_unprivileged="1" + +header_info "$APP" +variables +color +catch_errors + +function update_script() { + header_info + check_container_storage + check_container_resources + + if [[ ! -d /opt/jumpserver ]]; then + msg_error "No ${APP} Installation Found!" + exit + fi + RELEASE=$(curl -fsSL https://api.github.com/repos/jumpserver/installer/releases/latest | grep '"tag_name"' | sed -E 's/.*"tag_name": "([^"]+)".*/\1/') + if [[ ! -f /opt/${APP}_version.txt ]] || [[ "${RELEASE}" != "$(cat /opt/${APP}_version.txt)" ]]; then + msg_info "Updating ${APP} to ${RELEASE}" + if [[ -d /opt/jumpserver/config ]]; then + msg_info "Backing up /opt/jumpserver/config" + cp -r /opt/jumpserver/config /opt/jumpserver_config_backup + fi + echo "${RELEASE}" >/opt/${APP}_version.txt + rm -rf /opt/jumpserver + cd /opt + curl -fsSL "https://github.com/jumpserver/installer/releases/download/${RELEASE}/jumpserver-installer-${RELEASE}.tar.gz" -o jumpserver-installer-${RELEASE}.tar.gz + $STD mkdir -p /opt/jumpserver + $STD tar -xzvf jumpserver-installer-${RELEASE}.tar.gz -C /opt/jumpserver --strip-components=1 + if [[ -d /opt/jumpserver_config_backup ]]; then + msg_info "Restoring config backup" + cp -r /opt/jumpserver_config_backup /opt/jumpserver/config + rm -rf /opt/jumpserver_config_backup + fi + cd /opt/jumpserver + yes y | head -n 3 | $STD ./jmsctl.sh upgrade + $STD ./jmsctl.sh start + rm -rf /opt/jumpserver-installer-${RELEASE}.tar.gz + msg_ok "Updated Successfully" + else + msg_ok "No update required. ${APP} is already at ${RELEASE}." + fi + exit +} + +start +build_container +description + +msg_ok "Completed Successfully!\n" +echo -e "${CREATING}${GN}${APP} setup has been successfully initialized!${CL}" +echo -e "${INFO}${YW} Access it using the following URL:${CL}" +echo -e "${TAB}${GATEWAY}${BGN}http://${IP}:80${CL}" From 110eb3995e18d5c4dd1cd78a07469f14ad59cc12 Mon Sep 17 00:00:00 2001 From: CanbiZ <47820557+MickLesk@users.noreply.github.com> Date: Sat, 12 Apr 2025 19:32:07 +0200 Subject: [PATCH 12/21] Update ct/jumpserver.sh MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Slaviša Arežina <58952836+tremor021@users.noreply.github.com> --- ct/jumpserver.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ct/jumpserver.sh b/ct/jumpserver.sh index 4501ed9..7031e11 100644 --- a/ct/jumpserver.sh +++ b/ct/jumpserver.sh @@ -1,5 +1,5 @@ #!/usr/bin/env bash -source <(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/build.func) +source <(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVED/main/misc/build.func) # Copyright (c) 2021-2025 community-scripts ORG # Author: Nícolas Pastorello (opastorello) # License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE From 53fc40fe105ef222dbbf52fdc4c92cdf87af6a92 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?N=C3=ADcolas=20Pastorello?= Date: Sat, 12 Apr 2025 15:03:51 -0300 Subject: [PATCH 13/21] Update ct/jumpserver.sh MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Slaviša Arežina <58952836+tremor021@users.noreply.github.com> --- ct/jumpserver.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ct/jumpserver.sh b/ct/jumpserver.sh index 7031e11..184a327 100644 --- a/ct/jumpserver.sh +++ b/ct/jumpserver.sh @@ -3,7 +3,7 @@ source <(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxV # Copyright (c) 2021-2025 community-scripts ORG # Author: Nícolas Pastorello (opastorello) # License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE -# Source: https://jumpserver.com/ +# Source: https://github.com/jumpserver/jumpserver APP="JumpServer" var_tags="bastion-host;pam" From eb76b2aba73637de85abcc1e487bd41176b40382 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?N=C3=ADcolas=20Pastorello?= Date: Sat, 12 Apr 2025 15:03:59 -0300 Subject: [PATCH 14/21] Update ct/jumpserver.sh MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Slaviša Arežina <58952836+tremor021@users.noreply.github.com> --- ct/jumpserver.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ct/jumpserver.sh b/ct/jumpserver.sh index 184a327..f439cb5 100644 --- a/ct/jumpserver.sh +++ b/ct/jumpserver.sh @@ -39,7 +39,7 @@ function update_script() { rm -rf /opt/jumpserver cd /opt curl -fsSL "https://github.com/jumpserver/installer/releases/download/${RELEASE}/jumpserver-installer-${RELEASE}.tar.gz" -o jumpserver-installer-${RELEASE}.tar.gz - $STD mkdir -p /opt/jumpserver + mkdir -p /opt/jumpserver $STD tar -xzvf jumpserver-installer-${RELEASE}.tar.gz -C /opt/jumpserver --strip-components=1 if [[ -d /opt/jumpserver_config_backup ]]; then msg_info "Restoring config backup" From e0512ed2f71bf58108f2e7ae1af201fcb3af85b1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?N=C3=ADcolas=20Pastorello?= Date: Sat, 12 Apr 2025 15:04:12 -0300 Subject: [PATCH 15/21] Update frontend/public/json/jumpserver.json MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Slaviša Arežina <58952836+tremor021@users.noreply.github.com> --- frontend/public/json/jumpserver.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/frontend/public/json/jumpserver.json b/frontend/public/json/jumpserver.json index cf1cdba..2d0cf57 100644 --- a/frontend/public/json/jumpserver.json +++ b/frontend/public/json/jumpserver.json @@ -11,7 +11,7 @@ "interface_port": 80, "documentation": "https://www.jumpserver.com/docs", "website": "https://www.jumpserver.com/", - "logo": "https://avatars.githubusercontent.com/u/68588906", + "logo": "https://raw.githubusercontent.com/jumpserver/jumpserver/refs/heads/dev/apps/static/img/logo.png", "description": "JumpServer is an open-source Privileged Access Management (PAM) tool that provides DevOps and IT teams with on-demand and secure access to SSH, RDP, Kubernetes, Database and RemoteApp endpoints through a web browser.", "install_methods": [ { From 02ae2e010967b3f56f331adf51d99a8d0c36f508 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?N=C3=ADcolas=20Pastorello?= Date: Sat, 12 Apr 2025 15:04:19 -0300 Subject: [PATCH 16/21] Update install/jumpserver-install.sh MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Slaviša Arežina <58952836+tremor021@users.noreply.github.com> --- install/jumpserver-install.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/install/jumpserver-install.sh b/install/jumpserver-install.sh index 41e7d66..e9c11ca 100644 --- a/install/jumpserver-install.sh +++ b/install/jumpserver-install.sh @@ -3,7 +3,7 @@ # Copyright (c) 2021-2025 community-scripts ORG # Author: Nícolas Pastorello (opastorello) # License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE -# Source: https://jumpserver.com/ +# Source: https://github.com/jumpserver/jumpserver source /dev/stdin <<<"$FUNCTIONS_FILE_PATH" color From 86f1e8be33a759a48966538377e60226f852fc2a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?N=C3=ADcolas=20Pastorello?= Date: Sat, 12 Apr 2025 15:04:23 -0300 Subject: [PATCH 17/21] Update install/jumpserver-install.sh MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Slaviša Arežina <58952836+tremor021@users.noreply.github.com> --- install/jumpserver-install.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/install/jumpserver-install.sh b/install/jumpserver-install.sh index e9c11ca..4cc2539 100644 --- a/install/jumpserver-install.sh +++ b/install/jumpserver-install.sh @@ -24,7 +24,7 @@ msg_info "Installing JumpServer" cd /opt RELEASE=$(curl -fsSL https://api.github.com/repos/jumpserver/installer/releases/latest | grep '"tag_name"' | sed -E 's/.*"tag_name": "([^"]+)".*/\1/') curl -fsSL "https://github.com/jumpserver/installer/releases/download/${RELEASE}/jumpserver-installer-${RELEASE}.tar.gz" -o jumpserver-installer-${RELEASE}.tar.gz -$STD mkdir -p /opt/jumpserver +mkdir -p /opt/jumpserver $STD tar -xzvf jumpserver-installer-${RELEASE}.tar.gz -C /opt/jumpserver --strip-components=1 cd /opt/jumpserver $STD ./jmsctl.sh install < Date: Sun, 20 Apr 2025 18:42:27 -0300 Subject: [PATCH 18/21] Update ct/jumpserver.sh MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Slaviša Arežina <58952836+tremor021@users.noreply.github.com> --- ct/jumpserver.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ct/jumpserver.sh b/ct/jumpserver.sh index f439cb5..3874bfb 100644 --- a/ct/jumpserver.sh +++ b/ct/jumpserver.sh @@ -64,4 +64,4 @@ description msg_ok "Completed Successfully!\n" echo -e "${CREATING}${GN}${APP} setup has been successfully initialized!${CL}" echo -e "${INFO}${YW} Access it using the following URL:${CL}" -echo -e "${TAB}${GATEWAY}${BGN}http://${IP}:80${CL}" +echo -e "${TAB}${GATEWAY}${BGN}http://${IP}${CL}" From 86e004a3a7cbd5b237db8a05f861fcec4db5da78 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?N=C3=ADcolas=20Pastorello?= Date: Sun, 20 Apr 2025 22:53:27 -0300 Subject: [PATCH 19/21] Update jumpserver.sh --- ct/jumpserver.sh | 2 -- 1 file changed, 2 deletions(-) diff --git a/ct/jumpserver.sh b/ct/jumpserver.sh index 3874bfb..3ff61a2 100644 --- a/ct/jumpserver.sh +++ b/ct/jumpserver.sh @@ -32,7 +32,6 @@ function update_script() { if [[ ! -f /opt/${APP}_version.txt ]] || [[ "${RELEASE}" != "$(cat /opt/${APP}_version.txt)" ]]; then msg_info "Updating ${APP} to ${RELEASE}" if [[ -d /opt/jumpserver/config ]]; then - msg_info "Backing up /opt/jumpserver/config" cp -r /opt/jumpserver/config /opt/jumpserver_config_backup fi echo "${RELEASE}" >/opt/${APP}_version.txt @@ -42,7 +41,6 @@ function update_script() { mkdir -p /opt/jumpserver $STD tar -xzvf jumpserver-installer-${RELEASE}.tar.gz -C /opt/jumpserver --strip-components=1 if [[ -d /opt/jumpserver_config_backup ]]; then - msg_info "Restoring config backup" cp -r /opt/jumpserver_config_backup /opt/jumpserver/config rm -rf /opt/jumpserver_config_backup fi From ac8cd0135356f29114f64c319684bfc6da3bcd2d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?N=C3=ADcolas=20Pastorello?= Date: Tue, 22 Apr 2025 10:33:26 -0300 Subject: [PATCH 20/21] Update jumpserver-install.sh --- install/jumpserver-install.sh | 1 - 1 file changed, 1 deletion(-) diff --git a/install/jumpserver-install.sh b/install/jumpserver-install.sh index 4cc2539..adf969d 100644 --- a/install/jumpserver-install.sh +++ b/install/jumpserver-install.sh @@ -15,7 +15,6 @@ update_os msg_info "Installing Dependencies" $STD apt-get install -y \ - curl \ tar \ iptables msg_ok "Installed Dependencies" From e3748f6a8d6117b3653a9507c6c701526e54fa7f Mon Sep 17 00:00:00 2001 From: GitHub Actions Date: Mon, 5 May 2025 12:26:50 +0000 Subject: [PATCH 21/21] Update .app files --- ct/headers/jumpserver | 6 ++++++ 1 file changed, 6 insertions(+) create mode 100644 ct/headers/jumpserver diff --git a/ct/headers/jumpserver b/ct/headers/jumpserver new file mode 100644 index 0000000..66a463d --- /dev/null +++ b/ct/headers/jumpserver @@ -0,0 +1,6 @@ + __ _____ + / /_ ______ ___ ____ / ___/___ ______ _____ _____ + __ / / / / / __ `__ \/ __ \\__ \/ _ \/ ___/ | / / _ \/ ___/ +/ /_/ / /_/ / / / / / / /_/ /__/ / __/ / | |/ / __/ / +\____/\__,_/_/ /_/ /_/ .___/____/\___/_/ |___/\___/_/ + /_/