mirror of
https://github.com/community-scripts/ProxmoxVE.git
synced 2026-06-09 00:55:14 +02:00
68af0f5b41
* homelable: preserve MCP server config across updates The update path runs CLEAN_INSTALL=1 fetch_and_deploy_gh_release, which wipes /opt/homelable before redeploying. The backup/restore only covers backend/.env and data/, so an optionally-installed MCP server (set up via Pouzor/homelable's own scripts/lxc-mcp-install.sh, which targets exactly this LXC and lives in /opt/homelable/mcp) loses its .env and .venv on every update. The homelable-mcp service then keeps running on deleted inodes and dies at the next restart. Back up mcp/.env when present, and after the deploy restore it, rebuild the venv (same uv pattern as the backend), restore ownership and restart the service. Fully conditional: installs without the MCP are unaffected. * homelable: remove comments per maintainer review
96 lines
3.0 KiB
Bash
96 lines
3.0 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: MickLesk
|
|
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
|
|
# Source: https://github.com/Pouzor/homelable
|
|
|
|
APP="Homelable"
|
|
var_tags="${var_tags:-monitoring;network;visualization}"
|
|
var_cpu="${var_cpu:-2}"
|
|
var_ram="${var_ram:-2048}"
|
|
var_disk="${var_disk:-8}"
|
|
var_os="${var_os:-debian}"
|
|
var_version="${var_version:-13}"
|
|
var_arm64="${var_arm64:-no}"
|
|
var_unprivileged="${var_unprivileged:-1}"
|
|
|
|
header_info "$APP"
|
|
variables
|
|
color
|
|
catch_errors
|
|
|
|
function update_script() {
|
|
header_info
|
|
check_container_storage
|
|
check_container_resources
|
|
|
|
if [[ ! -d /opt/homelable ]]; then
|
|
msg_error "No ${APP} Installation Found!"
|
|
exit
|
|
fi
|
|
|
|
if check_for_gh_release "homelable" "Pouzor/homelable"; then
|
|
msg_info "Stopping Service"
|
|
systemctl stop homelable
|
|
msg_ok "Stopped Service"
|
|
|
|
msg_info "Backing up Configuration and Data"
|
|
cp /opt/homelable/backend/.env /opt/homelable.env.bak
|
|
cp -r /opt/homelable/data /opt/homelable_data_bak
|
|
if [[ -f /opt/homelable/mcp/.env ]]; then
|
|
cp -a /opt/homelable/mcp/.env /opt/homelable-mcp.env.bak
|
|
fi
|
|
msg_ok "Backed up Configuration and Data"
|
|
|
|
CLEAN_INSTALL=1 fetch_and_deploy_gh_release "homelable" "Pouzor/homelable" "tarball" "latest" "/opt/homelable"
|
|
|
|
msg_info "Updating Python Dependencies"
|
|
cd /opt/homelable/backend
|
|
$STD uv venv --clear /opt/homelable/backend/.venv
|
|
$STD uv pip install --python /opt/homelable/backend/.venv/bin/python -r requirements.txt
|
|
msg_ok "Updated Python Dependencies"
|
|
|
|
msg_info "Rebuilding Frontend"
|
|
cd /opt/homelable/frontend
|
|
$STD npm ci
|
|
$STD npm run build
|
|
msg_ok "Rebuilt Frontend"
|
|
|
|
msg_info "Restoring Configuration and Data"
|
|
cp /opt/homelable.env.bak /opt/homelable/backend/.env
|
|
cp -r /opt/homelable_data_bak/. /opt/homelable/data/
|
|
rm -f /opt/homelable.env.bak
|
|
rm -rf /opt/homelable_data_bak
|
|
msg_ok "Restored Configuration and Data"
|
|
|
|
if [[ -f /opt/homelable-mcp.env.bak ]]; then
|
|
msg_info "Restoring MCP Server"
|
|
cp -a /opt/homelable-mcp.env.bak /opt/homelable/mcp/.env
|
|
rm -f /opt/homelable-mcp.env.bak
|
|
MCP_OWNER=$(stat -c '%U' /opt/homelable/mcp/.env)
|
|
cd /opt/homelable/mcp
|
|
$STD uv venv --clear /opt/homelable/mcp/.venv
|
|
$STD uv pip install --python /opt/homelable/mcp/.venv/bin/python -r requirements.txt
|
|
chown -R "$MCP_OWNER":"$MCP_OWNER" /opt/homelable/mcp
|
|
systemctl restart homelable-mcp
|
|
msg_ok "Restored MCP Server"
|
|
fi
|
|
|
|
msg_info "Starting Service"
|
|
systemctl start homelable
|
|
msg_ok "Started Service"
|
|
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}http://${IP}:3000${CL}"
|