mirror of
https://github.com/community-scripts/ProxmoxVE.git
synced 2026-03-03 18:15:53 +00:00
* fix(error-handler): prevent silent() from re-enabling error handling during recovery Root cause: silent() (core.func) unconditionally calls set -Eeuo pipefail and trap 'error_handler' ERR after every command. When build_container() intentionally disables error handling for its recovery section, any intermediate call through silent()/ re-enables it. This causes the grep/sed pipeline for missing_cmd extraction to trigger error_handler (grep returns exit code 1 on no match + pipefail = fatal). Fixes: 1. silent(): Save errexit state before disabling, only restore if it was active. Callers that intentionally disabled error handling (e.g. build_container recovery) are no longer silently re-enabled. 2. build.func: Add || true to missing_cmd grep pipeline as defense-in-depth against pipeline failure propagation. 3. build.func: Add explicit set +Eeuo pipefail / trap - ERR after post_update_to_api() call, before error classification grep/sed section. 4. build.func: Remove stale global combined_log variable from variables() that used a different path format (/tmp/install-SESSION-combined.log) than the actual local variable (/tmp/NSAPP-CTID-SESSION.log). The global was never written to and caused confusion when error_handler displayed it. * Update build.func * chore(install): add Github source links to all setup_nodejs scripts 52 install scripts had a project website in '# Source:' but no GitHub link. Merged the GitHub repo URL into the Source header as: # Source: https://website.com/ | Github: https://github.com/OWNER/REPO Repos sourced from fetch_and_deploy_gh_release calls, get_latest_github_release calls, or known project repos for npm/pip installed apps. Two scripts (fumadocs, pve-scripts-local) had no Source line at all — added one. Shinobi skipped (GitLab-only, no GitHub repo). * chore(install): add Github source links to all fetch_and_deploy scripts 77 additional install scripts had fetch_and_deploy_gh_release calls but no GitHub link in the Source header. Merged the primary app repo into the Source header as: # Source: https://website.com/ | Github: https://github.com/OWNER/REPO Where multiple fetch_and_deploy calls existed (app + dependency), the primary app repo was selected: - ersatztv: ErsatzTV/ErsatzTV (not ffmpeg) - firefly: firefly-iii/firefly-iii (not data-importer) - komga: gotson/komga (not kepubify dep) - sabnzbd: sabnzbd/sabnzbd (not par2cmdline-turbo dep) - signoz: SigNoz/signoz (not otel-collector) - tunarr: chrisbenincasa/tunarr (not ffmpeg dep) Also fixed cosmos-install.sh double https:// in Source URL. Skipped: autocaliweb (source already on codeberg, GitHub repos are deps only) * revert: restore misc/build.func and misc/core.func to main state These error-handler fixes belong to fix/error-handler-recovery, not to this sources-only branch. * chore(ct,tools): sync Source headers with install/ and add Github links to addon scripts
147 lines
3.6 KiB
Bash
147 lines
3.6 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
|
|
# Source: https://healthchecks.io/ | Github: https://github.com/healthchecks/healthchecks
|
|
|
|
source /dev/stdin <<<"$FUNCTIONS_FILE_PATH"
|
|
color
|
|
verb_ip6
|
|
catch_errors
|
|
setting_up_container
|
|
network_check
|
|
update_os
|
|
|
|
msg_info "Installing Dependencies"
|
|
$STD apt install -y \
|
|
gcc \
|
|
python3 \
|
|
python3-dev \
|
|
python3-venv \
|
|
libpq-dev \
|
|
libcurl4-openssl-dev \
|
|
libssl-dev \
|
|
caddy
|
|
|
|
mkdir -p ~/.config/pip
|
|
cat >~/.config/pip/pip.conf <<EOF
|
|
[global]
|
|
break-system-packages = true
|
|
EOF
|
|
msg_ok "Installed Dependencies"
|
|
|
|
PG_VERSION=16 setup_postgresql
|
|
PG_DB_NAME="healthchecks_db" PG_DB_USER="hc_user" PG_DB_PASS=$(openssl rand -base64 18 | tr -dc 'a-zA-Z0-9' | cut -c1-13) setup_postgresql_db
|
|
|
|
msg_info "Setup Keys (Admin / Secret)"
|
|
SECRET_KEY="$(openssl rand -base64 32 | tr -dc 'a-zA-Z0-9' | cut -c1-32)"
|
|
ADMIN_EMAIL="admin@helper-scripts.local"
|
|
ADMIN_PASSWORD="$PG_DB_PASS"
|
|
{
|
|
echo "healthchecks Admin Email: $ADMIN_EMAIL"
|
|
echo "healthchecks Admin Password: $ADMIN_PASSWORD"
|
|
} >>~/healthchecks.creds
|
|
msg_ok "Set up Keys"
|
|
|
|
fetch_and_deploy_gh_release "healthchecks" "healthchecks/healthchecks" "tarball"
|
|
|
|
msg_info "Installing Healthchecks (venv)"
|
|
cd /opt/healthchecks
|
|
python3 -m venv venv
|
|
source venv/bin/activate
|
|
|
|
$STD pip install --upgrade pip wheel
|
|
$STD pip install gunicorn -r requirements.txt
|
|
msg_ok "Installed Python packages"
|
|
|
|
cat <<EOF >/opt/healthchecks/hc/local_settings.py
|
|
DEBUG = False
|
|
|
|
ALLOWED_HOSTS = ["${LOCAL_IP}", "127.0.0.1", "localhost"]
|
|
CSRF_TRUSTED_ORIGINS = ["http://${LOCAL_IP}", "https://${LOCAL_IP}"]
|
|
|
|
SECRET_KEY = "${SECRET_KEY}"
|
|
|
|
SITE_ROOT = "http://${LOCAL_IP}:8000"
|
|
SITE_NAME = "MyChecks"
|
|
DEFAULT_FROM_EMAIL = "healthchecks@${LOCAL_IP}"
|
|
|
|
STATIC_ROOT = "/opt/healthchecks/static-collected"
|
|
COMPRESS_OFFLINE = True
|
|
|
|
DATABASES = {
|
|
'default': {
|
|
'ENGINE': 'django.db.backends.postgresql',
|
|
'NAME': '${PG_DB_NAME}',
|
|
'USER': '${PG_DB_USER}',
|
|
'PASSWORD': '${PG_DB_PASS}',
|
|
'HOST': '127.0.0.1',
|
|
'PORT': '5432',
|
|
'TEST': {'CHARSET': 'UTF8'}
|
|
}
|
|
}
|
|
EOF
|
|
|
|
msg_info "Running Django setup"
|
|
$STD python manage.py makemigrations
|
|
$STD python manage.py migrate --noinput
|
|
$STD python manage.py collectstatic --noinput
|
|
$STD python manage.py compress
|
|
|
|
$STD python manage.py shell <<EOF
|
|
from django.contrib.auth import get_user_model
|
|
User = get_user_model()
|
|
if not User.objects.filter(email="${ADMIN_EMAIL}").exists():
|
|
User.objects.create_superuser("${ADMIN_EMAIL}", "${ADMIN_EMAIL}", "${ADMIN_PASSWORD}")
|
|
EOF
|
|
msg_ok "Configured Django"
|
|
|
|
msg_info "Configuring Caddy"
|
|
cat <<EOF >/etc/caddy/Caddyfile
|
|
{
|
|
email admin@example.com
|
|
}
|
|
|
|
${LOCAL_IP} {
|
|
reverse_proxy 127.0.0.1:8000
|
|
}
|
|
EOF
|
|
msg_ok "Configured Caddy"
|
|
|
|
msg_info "Creating systemd services"
|
|
cat <<EOF >/etc/systemd/system/healthchecks.service
|
|
[Unit]
|
|
Description=Healthchecks Service
|
|
After=network.target postgresql.service
|
|
|
|
[Service]
|
|
WorkingDirectory=/opt/healthchecks/
|
|
ExecStart=/opt/healthchecks/venv/bin/gunicorn hc.wsgi:application --bind 127.0.0.1:8000
|
|
Restart=always
|
|
|
|
[Install]
|
|
WantedBy=multi-user.target
|
|
EOF
|
|
|
|
cat <<EOF >/etc/systemd/system/healthchecks-sendalerts.service
|
|
[Unit]
|
|
Description=Healthchecks Sendalerts Service
|
|
After=network.target postgresql.service healthchecks.service
|
|
|
|
[Service]
|
|
WorkingDirectory=/opt/healthchecks/
|
|
ExecStart=/opt/healthchecks/venv/bin/python manage.py sendalerts
|
|
Restart=always
|
|
|
|
[Install]
|
|
WantedBy=multi-user.target
|
|
EOF
|
|
|
|
systemctl enable -q --now healthchecks healthchecks-sendalerts caddy
|
|
systemctl reload caddy
|
|
msg_ok "Created Services"
|
|
|
|
motd_ssh
|
|
customize
|
|
cleanup_lxc
|