* core: add progress; fix exit status Introduce post_progress_to_api() in alpine-install.func and install.func to send a lightweight, fire-and-forget telemetry ping (HTTP POST) that updates an existing telemetry record to "configuring" when DIAGNOSTICS=yes and RANDOM_UUID is set. The function is non-blocking (curl -m 5, errors ignored) and is invoked during container setup and after OS updates to signal active progress. Also adjust api_exit_script() in build.func to report success (post_update_to_api "done" "0") for cases where the script exited normally but a completion status wasn't posted, instead of reporting failure. * Safer tools.func load and improved error handling Replace process-substitution sourcing of tools.func with an explicit curl -> variable -> source via /dev/stdin, adding failure messages and a check that expected functions (e.g. fetch_and_deploy_gh_release) are present (misc/alpine-install.func, misc/install.func). Add categorize_error mapping for exit code 10 -> "config" (misc/api.func). Tweak build.func: minor pipeline formatting and change the ERR trap to capture the actual exit code and only call ensure_log_on_host/post_update on non-zero exits, preventing erroneous failure reporting. * tools: add data init and auto-reporting to tools and pve section Introduce telemetry helpers in misc/api.func: _telemetry_report_exit (reports success/failure via post_tool_to_api/post_addon_to_api) and init_tool_telemetry (reads DIAGNOSTICS, starts install timer and installs an EXIT trap to auto-report). Integrate telemetry into many tools/addon and tools/pve scripts by sourcing the remote api.func and calling init_tool_telemetry (guarded with declare -f). Also apply a minor arithmetic formatting tweak in misc/build.func for RECOVERY_ATTEMPT.
120 lines
3.9 KiB
Bash
120 lines
3.9 KiB
Bash
#!/usr/bin/env bash
|
|
|
|
# Copyright (c) 2021-2026 community-scripts ORG
|
|
# Author: MickLesk (CanbiZ)
|
|
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
|
|
|
|
function header_info {
|
|
clear
|
|
cat <<"EOF"
|
|
____ __ _ ________ ____ __ __
|
|
/ __ \_________ _ ______ ___ ____ _ __ / / | |/ / ____/ / __ \___ / /__ / /____
|
|
/ /_/ / ___/ __ \| |/_/ __ `__ \/ __ \| |/_/ / / | / / / / / / _ \/ / _ \/ __/ _ \
|
|
/ ____/ / / /_/ /> </ / / / / / /_/ /> < / /___/ / /___ / /_/ / __/ / __/ /_/ __/
|
|
/_/ /_/ \____/_/|_/_/ /_/ /_/\____/_/|_| /_____/_/|_\____/ /_____/\___/_/\___/\__/\___/
|
|
|
|
EOF
|
|
}
|
|
|
|
spinner() {
|
|
local pid=$1
|
|
local delay=0.1
|
|
local spinstr='|/-\'
|
|
while ps -p $pid >/dev/null; do
|
|
printf " [%c] " "$spinstr"
|
|
spinstr=${spinstr#?}${spinstr%"${spinstr#?}"}
|
|
sleep $delay
|
|
printf "\r"
|
|
done
|
|
printf " \r"
|
|
}
|
|
|
|
set -eEuo pipefail
|
|
YW=$(echo "\033[33m")
|
|
BL=$(echo "\033[36m")
|
|
RD=$(echo "\033[01;31m")
|
|
GN=$(echo "\033[1;92m")
|
|
CL=$(echo "\033[m")
|
|
TAB=" "
|
|
CM="${TAB}✔️${TAB}${CL}"
|
|
|
|
# Telemetry
|
|
source <(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/api.func) 2>/dev/null || true
|
|
declare -f init_tool_telemetry &>/dev/null && init_tool_telemetry "lxc-delete" "tool"
|
|
|
|
header_info
|
|
echo "Loading..."
|
|
whiptail --backtitle "Proxmox VE Helper Scripts" --title "Proxmox VE LXC Deletion" --yesno "This will delete LXC containers. Proceed?" 10 58
|
|
|
|
NODE=$(hostname)
|
|
containers=$(pct list | tail -n +2 | awk '{print $0 " " $4}')
|
|
|
|
if [ -z "$containers" ]; then
|
|
whiptail --title "LXC Container Delete" --msgbox "No LXC containers available!" 10 60
|
|
exit 1
|
|
fi
|
|
|
|
menu_items=("ALL" "Delete ALL containers" "OFF") # Add as first option
|
|
FORMAT="%-10s %-15s %-10s"
|
|
|
|
while read -r container; do
|
|
container_id=$(echo $container | awk '{print $1}')
|
|
container_name=$(echo $container | awk '{print $2}')
|
|
container_status=$(echo $container | awk '{print $3}')
|
|
formatted_line=$(printf "$FORMAT" "$container_name" "$container_status")
|
|
menu_items+=("$container_id" "$formatted_line" "OFF")
|
|
done <<<"$containers"
|
|
|
|
CHOICES=$(whiptail --title "LXC Container Delete" \
|
|
--checklist "Select LXC containers to delete:" 25 60 13 \
|
|
"${menu_items[@]}" 3>&2 2>&1 1>&3)
|
|
|
|
if [ -z "$CHOICES" ]; then
|
|
whiptail --title "LXC Container Delete" \
|
|
--msgbox "No containers selected!" 10 60
|
|
exit 1
|
|
fi
|
|
|
|
read -p "Delete containers manually or automatically? (Default: manual) m/a: " DELETE_MODE
|
|
DELETE_MODE=${DELETE_MODE:-m}
|
|
|
|
selected_ids=$(echo "$CHOICES" | tr -d '"' | tr -s ' ' '\n')
|
|
|
|
# If "ALL" is selected, override with all container IDs
|
|
if echo "$selected_ids" | grep -q "^ALL$"; then
|
|
selected_ids=$(echo "$containers" | awk '{print $1}')
|
|
fi
|
|
|
|
for container_id in $selected_ids; do
|
|
status=$(pct status $container_id)
|
|
|
|
if [ "$status" == "status: running" ]; then
|
|
echo -e "${BL}[Info]${GN} Stopping container $container_id...${CL}"
|
|
pct stop $container_id &
|
|
sleep 5
|
|
echo -e "${BL}[Info]${GN} Container $container_id stopped.${CL}"
|
|
fi
|
|
|
|
if [[ "$DELETE_MODE" == "a" ]]; then
|
|
echo -e "${BL}[Info]${GN} Automatically deleting container $container_id...${CL}"
|
|
pct destroy "$container_id" -f &
|
|
pid=$!
|
|
spinner $pid
|
|
[ $? -eq 0 ] && echo "Container $container_id deleted." || whiptail --title "Error" --msgbox "Failed to delete container $container_id." 10 60
|
|
else
|
|
read -p "Delete container $container_id? (y/N): " CONFIRM
|
|
if [[ "$CONFIRM" =~ ^[Yy]$ ]]; then
|
|
echo -e "${BL}[Info]${GN} Deleting container $container_id...${CL}"
|
|
pct destroy "$container_id" -f &
|
|
pid=$!
|
|
spinner $pid
|
|
[ $? -eq 0 ] && echo "Container $container_id deleted." || whiptail --title "Error" --msgbox "Failed to delete container $container_id." 10 60
|
|
else
|
|
echo -e "${BL}[Info]${RD} Skipping container $container_id...${CL}"
|
|
fi
|
|
fi
|
|
done
|
|
|
|
header_info
|
|
echo -e "${GN}Deletion process completed.${CL}\n"
|