Files
ProxmoxVE/ct/netbox.sh
T
MickLesk a1f4bc3240 refactor(ct): migrate manual update backups to create_backup (batch 1)
Replace ad-hoc mv/cp .bak patterns with create_backup/restore_backup across
58 update scripts so failed updates can roll back via the shared ERR trap.

Co-authored-by: Cursor <cursoragent@cursor.com>
2026-06-19 23:35:15 +02:00

63 lines
1.8 KiB
Bash

#!/usr/bin/env bash
source <(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/build.func)
# Copyright (c) 2021-2026 community-scripts ORG
# Author: bvdberg01
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
# Source: https://netboxlabs.com/ | Github: https://github.com/netbox-community/netbox
APP="NetBox"
var_tags="${var_tags:-network}"
var_cpu="${var_cpu:-2}"
var_ram="${var_ram:-2048}"
var_disk="${var_disk:-4}"
var_os="${var_os:-debian}"
var_version="${var_version:-13}"
var_arm64="${var_arm64:-yes}"
var_unprivileged="${var_unprivileged:-1}"
header_info "$APP"
variables
color
catch_errors
function update_script() {
header_info
check_container_storage
check_container_resources
if [[ ! -f /etc/systemd/system/netbox.service ]]; then
msg_error "No ${APP} Installation Found!"
exit
fi
if check_for_gh_release "netbox" "netbox-community/netbox"; then
msg_info "Stopping Services"
systemctl stop netbox netbox-rq
msg_ok "Stopped Services"
create_backup /opt/netbox/netbox/netbox/configuration.py \
/opt/netbox/netbox/media /opt/netbox/netbox/scripts /opt/netbox/netbox/reports \
/opt/netbox/gunicorn.py /opt/netbox/local_requirements.txt \
/opt/netbox/netbox/netbox/ldap_config.py
CLEAN_INSTALL=1 fetch_and_deploy_gh_release "netbox" "netbox-community/netbox" "tarball"
restore_backup
$STD /opt/netbox/upgrade.sh
msg_info "Starting Services"
systemctl start netbox netbox-rq
msg_ok "Started Services"
msg_ok "Updated successfully!"
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 "${GATEWAY}${BGN}https://${IP}${CL}"