mirror of
https://github.com/community-scripts/ProxmoxVE.git
synced 2026-03-07 03:15:57 +01:00
Compare commits
1 Commits
bump/node-
...
ci/check-n
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
1d9d6ea848 |
341
.github/workflows/check-node-versions.yml
generated
vendored
Normal file
341
.github/workflows/check-node-versions.yml
generated
vendored
Normal file
@@ -0,0 +1,341 @@
|
|||||||
|
name: Check Node.js Version Drift
|
||||||
|
|
||||||
|
on:
|
||||||
|
workflow_dispatch:
|
||||||
|
schedule:
|
||||||
|
# Runs weekly on Monday at 06:00 UTC
|
||||||
|
- cron: "0 6 * * 1"
|
||||||
|
|
||||||
|
permissions:
|
||||||
|
contents: read
|
||||||
|
issues: write
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
check-node-versions:
|
||||||
|
if: github.repository == 'community-scripts/ProxmoxVE'
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Checkout Repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
ref: main
|
||||||
|
|
||||||
|
- name: Install dependencies
|
||||||
|
run: |
|
||||||
|
sudo apt-get update -qq
|
||||||
|
sudo apt-get install -y -qq jq curl > /dev/null 2>&1
|
||||||
|
|
||||||
|
- name: Check upstream Node.js versions
|
||||||
|
id: check
|
||||||
|
env:
|
||||||
|
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
run: |
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
echo "================================================"
|
||||||
|
echo " Checking Node.js version drift in install scripts"
|
||||||
|
echo "================================================"
|
||||||
|
|
||||||
|
# Alpine version -> Node major cache (populated on demand)
|
||||||
|
declare -A ALPINE_NODE_CACHE
|
||||||
|
|
||||||
|
# Resolve Node.js major version from Alpine package registry
|
||||||
|
# Usage: resolve_alpine_node "3.21" => sets REPLY to major version (e.g. "22")
|
||||||
|
resolve_alpine_node() {
|
||||||
|
local alpine_ver="$1"
|
||||||
|
if [[ -n "${ALPINE_NODE_CACHE[$alpine_ver]+x}" ]]; then
|
||||||
|
REPLY="${ALPINE_NODE_CACHE[$alpine_ver]}"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
local url="https://pkgs.alpinelinux.org/package/v${alpine_ver}/main/x86_64/nodejs"
|
||||||
|
local page
|
||||||
|
page=$(curl -sf "$url" 2>/dev/null || echo "")
|
||||||
|
local full_ver=""
|
||||||
|
if [[ -n "$page" ]]; then
|
||||||
|
# Parse: "Version | 24.13.0-r1" or similar table row
|
||||||
|
full_ver=$(echo "$page" | grep -oP 'Version\s*\|\s*\K[0-9]+\.[0-9]+\.[0-9]+' | head -1 || echo "")
|
||||||
|
if [[ -z "$full_ver" ]]; then
|
||||||
|
# Fallback: look for version pattern after "Version"
|
||||||
|
full_ver=$(echo "$page" | grep -oP '(?<=Version</td><td>)[0-9]+\.[0-9]+\.[0-9]+' | head -1 || echo "")
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
local major=""
|
||||||
|
if [[ -n "$full_ver" ]]; then
|
||||||
|
major="${full_ver%%.*}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
ALPINE_NODE_CACHE[$alpine_ver]="$major"
|
||||||
|
REPLY="$major"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Extract Node major from a Dockerfile content
|
||||||
|
# Sets: DF_NODE_MAJOR, DF_SOURCE (description of where we found it)
|
||||||
|
extract_dockerfile_node() {
|
||||||
|
local content="$1"
|
||||||
|
DF_NODE_MAJOR=""
|
||||||
|
DF_SOURCE=""
|
||||||
|
|
||||||
|
# 1) FROM node:XX (e.g. node:24-alpine, node:22.9.0-bookworm-slim, node:20)
|
||||||
|
local node_from
|
||||||
|
node_from=$(echo "$content" | grep -oP '(?i)FROM\s+(--platform=[^\s]+\s+)?node:\K[0-9]+' | head -1 || echo "")
|
||||||
|
if [[ -n "$node_from" ]]; then
|
||||||
|
DF_NODE_MAJOR="$node_from"
|
||||||
|
DF_SOURCE="FROM node:${node_from}"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
# 2) nodesource/setup_XX.x
|
||||||
|
local nodesource
|
||||||
|
nodesource=$(echo "$content" | grep -oP 'nodesource/setup_\K[0-9]+' | head -1 || echo "")
|
||||||
|
if [[ -n "$nodesource" ]]; then
|
||||||
|
DF_NODE_MAJOR="$nodesource"
|
||||||
|
DF_SOURCE="nodesource/setup_${nodesource}.x"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
# 3) FROM alpine:X.Y — resolve via Alpine packages
|
||||||
|
local alpine_ver
|
||||||
|
alpine_ver=$(echo "$content" | grep -oP '(?i)FROM\s+(--platform=[^\s]+\s+)?alpine:\K[0-9]+\.[0-9]+' | head -1 || echo "")
|
||||||
|
if [[ -n "$alpine_ver" ]]; then
|
||||||
|
resolve_alpine_node "$alpine_ver"
|
||||||
|
if [[ -n "$REPLY" ]]; then
|
||||||
|
DF_NODE_MAJOR="$REPLY"
|
||||||
|
DF_SOURCE="alpine:${alpine_ver} (pkg: nodejs ${DF_NODE_MAJOR})"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Extract Node major from engines.node in package.json
|
||||||
|
# Sets: ENGINES_NODE_RAW (raw string), ENGINES_MIN_MAJOR
|
||||||
|
extract_engines_node() {
|
||||||
|
local content="$1"
|
||||||
|
ENGINES_NODE_RAW=""
|
||||||
|
ENGINES_MIN_MAJOR=""
|
||||||
|
|
||||||
|
ENGINES_NODE_RAW=$(echo "$content" | jq -r '.engines.node // empty' 2>/dev/null || echo "")
|
||||||
|
if [[ -z "$ENGINES_NODE_RAW" ]]; then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Extract the first number (major) from the constraint
|
||||||
|
# Handles: ">=24.13.1", "^22", ">=18.0.0", ">=18.15.0 <19 || ^20", etc.
|
||||||
|
ENGINES_MIN_MAJOR=$(echo "$ENGINES_NODE_RAW" | grep -oP '\d+' | head -1 || echo "")
|
||||||
|
}
|
||||||
|
|
||||||
|
# Collect results
|
||||||
|
declare -a issue_scripts=()
|
||||||
|
declare -a report_lines=()
|
||||||
|
total=0
|
||||||
|
checked=0
|
||||||
|
drift_count=0
|
||||||
|
|
||||||
|
for script in install/*-install.sh; do
|
||||||
|
[[ ! -f "$script" ]] && continue
|
||||||
|
if ! grep -q 'setup_nodejs' "$script"; then
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
|
||||||
|
total=$((total + 1))
|
||||||
|
slug=$(basename "$script" | sed 's/-install\.sh$//')
|
||||||
|
|
||||||
|
# Extract Source URL (GitHub only)
|
||||||
|
source_url=$(head -20 "$script" | grep -oP '(?<=# Source: )https://github\.com/[^\s]+' | head -1 || echo "")
|
||||||
|
if [[ -z "$source_url" ]]; then
|
||||||
|
report_lines+=("| \`$slug\` | — | — | — | — | ⏭️ No GitHub source |")
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
|
||||||
|
repo=$(echo "$source_url" | sed -E 's|https://github\.com/||; s|/$||; s|\.git$||')
|
||||||
|
if [[ -z "$repo" || "$repo" != */* ]]; then
|
||||||
|
report_lines+=("| \`$slug\` | — | — | — | — | ⏭️ Invalid repo |")
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
|
||||||
|
checked=$((checked + 1))
|
||||||
|
|
||||||
|
# Extract our NODE_VERSION
|
||||||
|
our_version=$(grep -oP 'NODE_VERSION="(\d+)"' "$script" | head -1 | grep -oP '\d+' || echo "")
|
||||||
|
if [[ -z "$our_version" ]]; then
|
||||||
|
if grep -q 'NODE_VERSION=\$(' "$script"; then
|
||||||
|
our_version="dynamic"
|
||||||
|
else
|
||||||
|
our_version="unset"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Fetch upstream Dockerfile
|
||||||
|
df_content=""
|
||||||
|
for branch in main master dev; do
|
||||||
|
df_content=$(curl -sf "https://raw.githubusercontent.com/${repo}/${branch}/Dockerfile" 2>/dev/null || echo "")
|
||||||
|
[[ -n "$df_content" ]] && break
|
||||||
|
done
|
||||||
|
|
||||||
|
DF_NODE_MAJOR=""
|
||||||
|
DF_SOURCE=""
|
||||||
|
if [[ -n "$df_content" ]]; then
|
||||||
|
extract_dockerfile_node "$df_content"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Fetch upstream package.json
|
||||||
|
pkg_content=""
|
||||||
|
for branch in main master dev; do
|
||||||
|
pkg_content=$(curl -sf "https://raw.githubusercontent.com/${repo}/${branch}/package.json" 2>/dev/null || echo "")
|
||||||
|
[[ -n "$pkg_content" ]] && break
|
||||||
|
done
|
||||||
|
|
||||||
|
ENGINES_NODE_RAW=""
|
||||||
|
ENGINES_MIN_MAJOR=""
|
||||||
|
if [[ -n "$pkg_content" ]]; then
|
||||||
|
extract_engines_node "$pkg_content"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Determine upstream recommended major version
|
||||||
|
upstream_major=""
|
||||||
|
upstream_hint=""
|
||||||
|
|
||||||
|
if [[ -n "$DF_NODE_MAJOR" ]]; then
|
||||||
|
upstream_major="$DF_NODE_MAJOR"
|
||||||
|
upstream_hint="$DF_SOURCE"
|
||||||
|
elif [[ -n "$ENGINES_MIN_MAJOR" ]]; then
|
||||||
|
upstream_major="$ENGINES_MIN_MAJOR"
|
||||||
|
upstream_hint="engines: $ENGINES_NODE_RAW"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Build display values
|
||||||
|
engines_display="${ENGINES_NODE_RAW:-—}"
|
||||||
|
dockerfile_display="${DF_SOURCE:-—}"
|
||||||
|
|
||||||
|
# Compare
|
||||||
|
status="✅"
|
||||||
|
if [[ "$our_version" == "dynamic" ]]; then
|
||||||
|
status="🔄 Dynamic"
|
||||||
|
elif [[ "$our_version" == "unset" ]]; then
|
||||||
|
status="⚠️ NODE_VERSION not set"
|
||||||
|
issue_scripts+=("$slug|$our_version|$upstream_major|$upstream_hint|$repo")
|
||||||
|
drift_count=$((drift_count + 1))
|
||||||
|
elif [[ -n "$upstream_major" && "$our_version" != "$upstream_major" ]]; then
|
||||||
|
status="🔸 Drift → upstream=$upstream_major ($upstream_hint)"
|
||||||
|
issue_scripts+=("$slug|$our_version|$upstream_major|$upstream_hint|$repo")
|
||||||
|
drift_count=$((drift_count + 1))
|
||||||
|
fi
|
||||||
|
|
||||||
|
report_lines+=("| \`$slug\` | $our_version | $engines_display | $dockerfile_display | [$repo](https://github.com/$repo) | $status |")
|
||||||
|
|
||||||
|
# Rate-limit to avoid GitHub secondary rate limits
|
||||||
|
sleep 0.3
|
||||||
|
|
||||||
|
done
|
||||||
|
|
||||||
|
# Print summary
|
||||||
|
echo ""
|
||||||
|
echo "========================================="
|
||||||
|
echo " Total scripts with setup_nodejs: $total"
|
||||||
|
echo " Checked (with GitHub source): $checked"
|
||||||
|
echo " Version drift detected: $drift_count"
|
||||||
|
echo "========================================="
|
||||||
|
|
||||||
|
# Export
|
||||||
|
{
|
||||||
|
echo "drift_count=$drift_count"
|
||||||
|
echo "total=$total"
|
||||||
|
echo "checked=$checked"
|
||||||
|
} >> "$GITHUB_OUTPUT"
|
||||||
|
|
||||||
|
# Save issue details for next step
|
||||||
|
printf '%s\n' "${issue_scripts[@]}" > /tmp/drift_scripts.txt 2>/dev/null || touch /tmp/drift_scripts.txt
|
||||||
|
|
||||||
|
# Save full report
|
||||||
|
{
|
||||||
|
echo "## Node.js Version Drift Report"
|
||||||
|
echo ""
|
||||||
|
echo "**Generated:** $(date -u +%Y-%m-%dT%H:%M:%SZ)"
|
||||||
|
echo "**Scripts checked:** $total | **With GitHub source:** $checked | **Drift detected:** $drift_count"
|
||||||
|
echo ""
|
||||||
|
echo "| Script | Our Version | engines.node | Dockerfile | Upstream Repo | Status |"
|
||||||
|
echo "|--------|-------------|-------------|------------|---------------|--------|"
|
||||||
|
printf '%s\n' "${report_lines[@]}" | sort
|
||||||
|
} > /tmp/drift_report.md
|
||||||
|
|
||||||
|
cat /tmp/drift_report.md
|
||||||
|
|
||||||
|
- name: Create or update summary issue
|
||||||
|
if: steps.check.outputs.drift_count != '0'
|
||||||
|
env:
|
||||||
|
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
run: |
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
TITLE="[Automated] Node.js Version Drift Report"
|
||||||
|
DATE=$(date -u +%Y-%m-%d)
|
||||||
|
DRIFT_COUNT="${{ steps.check.outputs.drift_count }}"
|
||||||
|
TOTAL="${{ steps.check.outputs.total }}"
|
||||||
|
CHECKED="${{ steps.check.outputs.checked }}"
|
||||||
|
|
||||||
|
# Build checklist from drift data
|
||||||
|
CHECKLIST=""
|
||||||
|
while IFS='|' read -r slug our_version upstream_major upstream_hint repo; do
|
||||||
|
[[ -z "$slug" ]] && continue
|
||||||
|
CHECKLIST+="- [ ] **\`${slug}\`** — ours: \`${our_version}\` → upstream: \`${upstream_major}\` (${upstream_hint}) — [repo](https://github.com/${repo})"$'\n'
|
||||||
|
done < /tmp/drift_scripts.txt
|
||||||
|
|
||||||
|
# Build full report table
|
||||||
|
REPORT=$(cat /tmp/drift_report.md)
|
||||||
|
|
||||||
|
BODY=$(cat <<ISSUE_EOF
|
||||||
|
## Node.js Version Drift Report — ${DATE}
|
||||||
|
|
||||||
|
**${DRIFT_COUNT}** script(s) with version drift detected (out of ${CHECKED} checked / ${TOTAL} total).
|
||||||
|
|
||||||
|
### Scripts requiring investigation
|
||||||
|
|
||||||
|
${CHECKLIST}
|
||||||
|
|
||||||
|
### How to resolve
|
||||||
|
|
||||||
|
1. Check upstream Dockerfile / package.json to confirm the required Node.js version
|
||||||
|
2. Test the script with the new Node version
|
||||||
|
3. Update \`NODE_VERSION\` in \`install/<slug>-install.sh\`
|
||||||
|
4. Update \`NODE_VERSION\` in \`ct/<slug>.sh\` (update section) if applicable
|
||||||
|
5. Check off the item above once done
|
||||||
|
|
||||||
|
<details>
|
||||||
|
<summary>Full report</summary>
|
||||||
|
|
||||||
|
${REPORT}
|
||||||
|
|
||||||
|
</details>
|
||||||
|
|
||||||
|
---
|
||||||
|
*This issue is automatically created/updated weekly by the Node.js version drift check workflow.*
|
||||||
|
*Last updated: ${DATE}*
|
||||||
|
ISSUE_EOF
|
||||||
|
)
|
||||||
|
|
||||||
|
# Check if a matching open issue already exists
|
||||||
|
EXISTING=$(gh issue list --state open --label "automated,dependencies" --search "\"[Automated] Node.js Version Drift Report\"" --json number --jq '.[0].number // empty' 2>/dev/null || echo "")
|
||||||
|
|
||||||
|
if [[ -n "$EXISTING" ]]; then
|
||||||
|
gh issue edit "$EXISTING" --body "$BODY"
|
||||||
|
echo "Updated existing issue #$EXISTING"
|
||||||
|
else
|
||||||
|
gh issue create \
|
||||||
|
--title "$TITLE" \
|
||||||
|
--body "$BODY" \
|
||||||
|
--label "automated,dependencies"
|
||||||
|
echo "Created new summary issue"
|
||||||
|
fi
|
||||||
|
|
||||||
|
- name: Close issue if no drift
|
||||||
|
if: steps.check.outputs.drift_count == '0'
|
||||||
|
env:
|
||||||
|
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
run: |
|
||||||
|
EXISTING=$(gh issue list --state open --label "automated,dependencies" --search "\"[Automated] Node.js Version Drift Report\"" --json number --jq '.[0].number // empty' 2>/dev/null || echo "")
|
||||||
|
if [[ -n "$EXISTING" ]]; then
|
||||||
|
gh issue close "$EXISTING" --comment "All Node.js versions are in sync with upstream. Closing automatically."
|
||||||
|
echo "Closed issue #$EXISTING"
|
||||||
|
fi
|
||||||
@@ -20,28 +20,26 @@ color
|
|||||||
catch_errors
|
catch_errors
|
||||||
|
|
||||||
function update_script() {
|
function update_script() {
|
||||||
header_info
|
header_info
|
||||||
check_container_storage
|
check_container_storage
|
||||||
check_container_resources
|
check_container_resources
|
||||||
|
|
||||||
NODE_VERSION="24" setup_nodejs
|
if command -v cross-seed &>/dev/null; then
|
||||||
|
current_version=$(cross-seed --version)
|
||||||
if command -v cross-seed &>/dev/null; then
|
latest_version=$(npm show cross-seed version)
|
||||||
current_version=$(cross-seed --version)
|
if [ "$current_version" != "$latest_version" ]; then
|
||||||
latest_version=$(npm show cross-seed version)
|
msg_info "Updating cross-seed from version v${current_version} to v${latest_version}"
|
||||||
if [ "$current_version" != "$latest_version" ]; then
|
$STD npm install -g cross-seed@latest
|
||||||
msg_info "Updating cross-seed from version v${current_version} to v${latest_version}"
|
systemctl restart cross-seed
|
||||||
$STD npm install -g cross-seed@latest
|
msg_ok "Updated successfully!"
|
||||||
systemctl restart cross-seed
|
else
|
||||||
msg_ok "Updated successfully!"
|
msg_ok "cross-seed is already at v${current_version}"
|
||||||
|
fi
|
||||||
else
|
else
|
||||||
msg_ok "cross-seed is already at v${current_version}"
|
msg_error "No cross-seed Installation Found!"
|
||||||
|
exit
|
||||||
fi
|
fi
|
||||||
else
|
|
||||||
msg_error "No cross-seed Installation Found!"
|
|
||||||
exit
|
exit
|
||||||
fi
|
|
||||||
exit
|
|
||||||
}
|
}
|
||||||
|
|
||||||
start
|
start
|
||||||
|
|||||||
@@ -28,8 +28,6 @@ function update_script() {
|
|||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
|
|
||||||
NODE_VERSION="24" NODE_MODULE="yarn" setup_nodejs
|
|
||||||
|
|
||||||
if check_for_gh_release "manyfold" "manyfold3d/manyfold"; then
|
if check_for_gh_release "manyfold" "manyfold3d/manyfold"; then
|
||||||
msg_info "Stopping Services"
|
msg_info "Stopping Services"
|
||||||
systemctl stop manyfold.target manyfold-rails.1 manyfold-default_worker.1 manyfold-performance_worker.1
|
systemctl stop manyfold.target manyfold-rails.1 manyfold-default_worker.1 manyfold-performance_worker.1
|
||||||
|
|||||||
@@ -29,7 +29,7 @@ function update_script() {
|
|||||||
fi
|
fi
|
||||||
$STD apt update
|
$STD apt update
|
||||||
$STD apt upgrade -y
|
$STD apt upgrade -y
|
||||||
NODE_VERSION="24" NODE_MODULE="matterbridge" setup_nodejs
|
NODE_VERSION="22" NODE_MODULE="matterbridge" setup_nodejs
|
||||||
msg_ok "Updated successfully!"
|
msg_ok "Updated successfully!"
|
||||||
exit
|
exit
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -29,8 +29,6 @@ function update_script() {
|
|||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
|
|
||||||
NODE_VERSION="24" setup_nodejs
|
|
||||||
|
|
||||||
if check_for_gh_release "pangolin" "fosrl/pangolin"; then
|
if check_for_gh_release "pangolin" "fosrl/pangolin"; then
|
||||||
msg_info "Stopping Service"
|
msg_info "Stopping Service"
|
||||||
systemctl stop pangolin
|
systemctl stop pangolin
|
||||||
|
|||||||
82
ct/romm.sh
82
ct/romm.sh
@@ -20,50 +20,48 @@ color
|
|||||||
catch_errors
|
catch_errors
|
||||||
|
|
||||||
function update_script() {
|
function update_script() {
|
||||||
header_info
|
header_info
|
||||||
check_container_storage
|
check_container_storage
|
||||||
check_container_resources
|
check_container_resources
|
||||||
|
|
||||||
if [[ ! -d /opt/romm ]]; then
|
if [[ ! -d /opt/romm ]]; then
|
||||||
msg_error "No ${APP} Installation Found!"
|
msg_error "No ${APP} Installation Found!"
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
|
||||||
|
if check_for_gh_release "romm" "rommapp/romm"; then
|
||||||
|
msg_info "Stopping Services"
|
||||||
|
systemctl stop romm-backend romm-worker romm-scheduler romm-watcher
|
||||||
|
msg_ok "Stopped Services"
|
||||||
|
|
||||||
|
msg_info "Backing up configuration"
|
||||||
|
cp /opt/romm/.env /opt/romm/.env.backup
|
||||||
|
msg_ok "Backed up configuration"
|
||||||
|
|
||||||
|
fetch_and_deploy_gh_release "romm" "rommapp/romm" "tarball" "latest" "/opt/romm"
|
||||||
|
|
||||||
|
msg_info "Updating ROMM"
|
||||||
|
cp /opt/romm/.env.backup /opt/romm/.env
|
||||||
|
cd /opt/romm
|
||||||
|
$STD uv sync --all-extras
|
||||||
|
cd /opt/romm/backend
|
||||||
|
$STD uv run alembic upgrade head
|
||||||
|
cd /opt/romm/frontend
|
||||||
|
$STD npm install
|
||||||
|
$STD npm run build
|
||||||
|
# Merge static assets into dist folder
|
||||||
|
cp -rf /opt/romm/frontend/assets/* /opt/romm/frontend/dist/assets/
|
||||||
|
mkdir -p /opt/romm/frontend/dist/assets/romm
|
||||||
|
ln -sfn /var/lib/romm/resources /opt/romm/frontend/dist/assets/romm/resources
|
||||||
|
ln -sfn /var/lib/romm/assets /opt/romm/frontend/dist/assets/romm/assets
|
||||||
|
msg_ok "Updated ROMM"
|
||||||
|
|
||||||
|
msg_info "Starting Services"
|
||||||
|
systemctl start romm-backend romm-worker romm-scheduler romm-watcher
|
||||||
|
msg_ok "Started Services"
|
||||||
|
msg_ok "Updated successfully"
|
||||||
|
fi
|
||||||
exit
|
exit
|
||||||
fi
|
|
||||||
|
|
||||||
NODE_VERSION="24" setup_nodejs
|
|
||||||
|
|
||||||
if check_for_gh_release "romm" "rommapp/romm"; then
|
|
||||||
msg_info "Stopping Services"
|
|
||||||
systemctl stop romm-backend romm-worker romm-scheduler romm-watcher
|
|
||||||
msg_ok "Stopped Services"
|
|
||||||
|
|
||||||
msg_info "Backing up configuration"
|
|
||||||
cp /opt/romm/.env /opt/romm/.env.backup
|
|
||||||
msg_ok "Backed up configuration"
|
|
||||||
|
|
||||||
fetch_and_deploy_gh_release "romm" "rommapp/romm" "tarball" "latest" "/opt/romm"
|
|
||||||
|
|
||||||
msg_info "Updating ROMM"
|
|
||||||
cp /opt/romm/.env.backup /opt/romm/.env
|
|
||||||
cd /opt/romm
|
|
||||||
$STD uv sync --all-extras
|
|
||||||
cd /opt/romm/backend
|
|
||||||
$STD uv run alembic upgrade head
|
|
||||||
cd /opt/romm/frontend
|
|
||||||
$STD npm install
|
|
||||||
$STD npm run build
|
|
||||||
# Merge static assets into dist folder
|
|
||||||
cp -rf /opt/romm/frontend/assets/* /opt/romm/frontend/dist/assets/
|
|
||||||
mkdir -p /opt/romm/frontend/dist/assets/romm
|
|
||||||
ln -sfn /var/lib/romm/resources /opt/romm/frontend/dist/assets/romm/resources
|
|
||||||
ln -sfn /var/lib/romm/assets /opt/romm/frontend/dist/assets/romm/assets
|
|
||||||
msg_ok "Updated ROMM"
|
|
||||||
|
|
||||||
msg_info "Starting Services"
|
|
||||||
systemctl start romm-backend romm-worker romm-scheduler romm-watcher
|
|
||||||
msg_ok "Started Services"
|
|
||||||
msg_ok "Updated successfully"
|
|
||||||
fi
|
|
||||||
exit
|
|
||||||
}
|
}
|
||||||
|
|
||||||
start
|
start
|
||||||
|
|||||||
@@ -28,8 +28,6 @@ function update_script() {
|
|||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
|
|
||||||
NODE_VERSION="24" setup_nodejs
|
|
||||||
|
|
||||||
if check_for_gh_release "snowshare" "TuroYT/snowshare"; then
|
if check_for_gh_release "snowshare" "TuroYT/snowshare"; then
|
||||||
msg_info "Stopping Service"
|
msg_info "Stopping Service"
|
||||||
systemctl stop snowshare
|
systemctl stop snowshare
|
||||||
|
|||||||
@@ -33,7 +33,7 @@ function update_script() {
|
|||||||
$STD apt upgrade -y
|
$STD apt upgrade -y
|
||||||
msg_ok "Updated LXC Container"
|
msg_ok "Updated LXC Container"
|
||||||
|
|
||||||
NODE_VERSION="24" NODE_MODULE="verdaccio" setup_nodejs
|
NODE_VERSION="22" NODE_MODULE="verdaccio" setup_nodejs
|
||||||
systemctl restart verdaccio
|
systemctl restart verdaccio
|
||||||
msg_ok "Updated successfully!"
|
msg_ok "Updated successfully!"
|
||||||
exit
|
exit
|
||||||
|
|||||||
@@ -13,7 +13,7 @@ setting_up_container
|
|||||||
network_check
|
network_check
|
||||||
update_os
|
update_os
|
||||||
|
|
||||||
NODE_VERSION="24" setup_nodejs
|
NODE_VERSION="22" setup_nodejs
|
||||||
|
|
||||||
msg_info "Setup Cross-Seed"
|
msg_info "Setup Cross-Seed"
|
||||||
$STD npm install cross-seed@latest -g
|
$STD npm install cross-seed@latest -g
|
||||||
|
|||||||
@@ -26,7 +26,7 @@ msg_ok "Installed Dependencies"
|
|||||||
setup_imagemagick
|
setup_imagemagick
|
||||||
PG_VERSION="16" setup_postgresql
|
PG_VERSION="16" setup_postgresql
|
||||||
PG_DB_NAME="manyfold" PG_DB_USER="manyfold" setup_postgresql_db
|
PG_DB_NAME="manyfold" PG_DB_USER="manyfold" setup_postgresql_db
|
||||||
NODE_VERSION="24" NODE_MODULE="yarn" setup_nodejs
|
NODE_VERSION="22" NODE_MODULE="yarn" setup_nodejs
|
||||||
|
|
||||||
fetch_and_deploy_gh_release "manyfold" "manyfold3d/manyfold" "tarball" "latest" "/opt/manyfold/app"
|
fetch_and_deploy_gh_release "manyfold" "manyfold3d/manyfold" "tarball" "latest" "/opt/manyfold/app"
|
||||||
|
|
||||||
|
|||||||
@@ -15,7 +15,7 @@ update_os
|
|||||||
|
|
||||||
msg_info "Install Matterbridge"
|
msg_info "Install Matterbridge"
|
||||||
mkdir -p /root/Matterbridge
|
mkdir -p /root/Matterbridge
|
||||||
NODE_VERSION="24" NODE_MODULE="matterbridge" setup_nodejs
|
NODE_VERSION="22" NODE_MODULE="matterbridge" setup_nodejs
|
||||||
msg_ok "Installed Matterbridge"
|
msg_ok "Installed Matterbridge"
|
||||||
|
|
||||||
msg_info "Creating Service"
|
msg_info "Creating Service"
|
||||||
|
|||||||
@@ -14,7 +14,7 @@ network_check
|
|||||||
update_os
|
update_os
|
||||||
|
|
||||||
fetch_and_deploy_gh_release "nodecast-tv" "technomancer702/nodecast-tv"
|
fetch_and_deploy_gh_release "nodecast-tv" "technomancer702/nodecast-tv"
|
||||||
NODE_VERSION="20" setup_nodejs
|
setup_nodejs
|
||||||
|
|
||||||
msg_info "Installing Dependencies"
|
msg_info "Installing Dependencies"
|
||||||
$STD apt install -y ffmpeg
|
$STD apt install -y ffmpeg
|
||||||
|
|||||||
@@ -19,7 +19,7 @@ $STD apt install -y \
|
|||||||
iptables
|
iptables
|
||||||
msg_ok "Installed Dependencies"
|
msg_ok "Installed Dependencies"
|
||||||
|
|
||||||
NODE_VERSION="24" setup_nodejs
|
NODE_VERSION="22" setup_nodejs
|
||||||
fetch_and_deploy_gh_release "pangolin" "fosrl/pangolin" "tarball"
|
fetch_and_deploy_gh_release "pangolin" "fosrl/pangolin" "tarball"
|
||||||
fetch_and_deploy_gh_release "gerbil" "fosrl/gerbil" "singlefile" "latest" "/usr/bin" "gerbil_linux_amd64"
|
fetch_and_deploy_gh_release "gerbil" "fosrl/gerbil" "singlefile" "latest" "/usr/bin" "gerbil_linux_amd64"
|
||||||
fetch_and_deploy_gh_release "traefik" "traefik/traefik" "prebuild" "latest" "/usr/bin" "traefik_v*_linux_amd64.tar.gz"
|
fetch_and_deploy_gh_release "traefik" "traefik/traefik" "prebuild" "latest" "/usr/bin" "traefik_v*_linux_amd64.tar.gz"
|
||||||
|
|||||||
@@ -42,7 +42,7 @@ $STD apt install -y \
|
|||||||
msg_ok "Installed Dependencies"
|
msg_ok "Installed Dependencies"
|
||||||
|
|
||||||
PYTHON_VERSION="3.13" setup_uv
|
PYTHON_VERSION="3.13" setup_uv
|
||||||
NODE_VERSION="24" setup_nodejs
|
NODE_VERSION="22" setup_nodejs
|
||||||
setup_mariadb
|
setup_mariadb
|
||||||
MARIADB_DB_NAME="romm" MARIADB_DB_USER="romm" setup_mariadb_db
|
MARIADB_DB_NAME="romm" MARIADB_DB_USER="romm" setup_mariadb_db
|
||||||
|
|
||||||
|
|||||||
@@ -13,7 +13,7 @@ setting_up_container
|
|||||||
network_check
|
network_check
|
||||||
update_os
|
update_os
|
||||||
|
|
||||||
NODE_VERSION="24" setup_nodejs
|
NODE_VERSION="22" setup_nodejs
|
||||||
PG_VERSION="17" setup_postgresql
|
PG_VERSION="17" setup_postgresql
|
||||||
PG_DB_USER="snowshare" PG_DB_NAME="snowshare" setup_postgresql_db
|
PG_DB_USER="snowshare" PG_DB_NAME="snowshare" setup_postgresql_db
|
||||||
fetch_and_deploy_gh_release "snowshare" "TuroYT/snowshare" "tarball"
|
fetch_and_deploy_gh_release "snowshare" "TuroYT/snowshare" "tarball"
|
||||||
|
|||||||
@@ -17,7 +17,7 @@ msg_info "Installing Dependencies"
|
|||||||
$STD apt install -y build-essential
|
$STD apt install -y build-essential
|
||||||
msg_ok "Installed Dependencies"
|
msg_ok "Installed Dependencies"
|
||||||
|
|
||||||
NODE_VERSION="24" NODE_MODULE="verdaccio" setup_nodejs
|
NODE_VERSION="22" NODE_MODULE="verdaccio" setup_nodejs
|
||||||
|
|
||||||
msg_info "Configuring Verdaccio"
|
msg_info "Configuring Verdaccio"
|
||||||
mkdir -p /opt/verdaccio/config
|
mkdir -p /opt/verdaccio/config
|
||||||
|
|||||||
@@ -23,7 +23,7 @@ $STD apt install -y \
|
|||||||
msg_ok "Installed Dependencies"
|
msg_ok "Installed Dependencies"
|
||||||
|
|
||||||
setup_rust
|
setup_rust
|
||||||
NODE_VERSION="20" NODE_MODULE="pnpm" setup_nodejs
|
NODE_MODULE="pnpm" setup_nodejs
|
||||||
fetch_and_deploy_gh_release "wealthfolio" "afadil/wealthfolio" "tarball"
|
fetch_and_deploy_gh_release "wealthfolio" "afadil/wealthfolio" "tarball"
|
||||||
|
|
||||||
msg_info "Building Frontend (patience)"
|
msg_info "Building Frontend (patience)"
|
||||||
|
|||||||
Reference in New Issue
Block a user