mirror of
https://github.com/community-scripts/ProxmoxVE.git
synced 2026-04-04 01:03:00 +02:00
Compare commits
2 Commits
copilot/fi
...
fix/tools-
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
2667f603e5 | ||
|
|
a53fef912c |
145
.github/changelogs/2026/03.md
generated
vendored
145
.github/changelogs/2026/03.md
generated
vendored
@@ -1,148 +1,3 @@
|
|||||||
## 2026-03-28
|
|
||||||
|
|
||||||
### 🚀 Updated Scripts
|
|
||||||
|
|
||||||
- #### 🐞 Bug Fixes
|
|
||||||
|
|
||||||
- Fix: Update gokapi binary name for v2.2.4+ and add migration step [@krazos](https://github.com/krazos) ([#13377](https://github.com/community-scripts/ProxmoxVE/pull/13377))
|
|
||||||
- Fix: update gokapi asset matching for v2.2.4+ naming convention [@krazos](https://github.com/krazos) ([#13369](https://github.com/community-scripts/ProxmoxVE/pull/13369))
|
|
||||||
- Tandoor Recipes: Add missing env variable [@tremor021](https://github.com/tremor021) ([#13365](https://github.com/community-scripts/ProxmoxVE/pull/13365))
|
|
||||||
|
|
||||||
- #### ✨ New Features
|
|
||||||
|
|
||||||
- FileFlows: add option to install Node [@tremor021](https://github.com/tremor021) ([#13368](https://github.com/community-scripts/ProxmoxVE/pull/13368))
|
|
||||||
|
|
||||||
## 2026-03-27
|
|
||||||
|
|
||||||
### 🆕 New Scripts
|
|
||||||
|
|
||||||
- Matter-Server ([#13355](https://github.com/community-scripts/ProxmoxVE/pull/13355))
|
|
||||||
- GeoPulse ([#13320](https://github.com/community-scripts/ProxmoxVE/pull/13320))
|
|
||||||
|
|
||||||
### 🚀 Updated Scripts
|
|
||||||
|
|
||||||
- #### 🐞 Bug Fixes
|
|
||||||
|
|
||||||
- RevealJS: Switch from gulp to vite [@tremor021](https://github.com/tremor021) ([#13336](https://github.com/community-scripts/ProxmoxVE/pull/13336))
|
|
||||||
|
|
||||||
- #### ✨ New Features
|
|
||||||
|
|
||||||
- Dispatcharr add custom Postgres port support for upgrade [@MickLesk](https://github.com/MickLesk) ([#13347](https://github.com/community-scripts/ProxmoxVE/pull/13347))
|
|
||||||
- Immich: bump to v2.6.3 [@MickLesk](https://github.com/MickLesk) ([#13324](https://github.com/community-scripts/ProxmoxVE/pull/13324))
|
|
||||||
|
|
||||||
### 🧰 Tools
|
|
||||||
|
|
||||||
- #### ✨ New Features
|
|
||||||
|
|
||||||
- Refactor/Feature-Bump/Security: Update-Cron-LXCs (Now Local Mode!) [@MickLesk](https://github.com/MickLesk) ([#13339](https://github.com/community-scripts/ProxmoxVE/pull/13339))
|
|
||||||
|
|
||||||
## 2026-03-26
|
|
||||||
|
|
||||||
### 🆕 New Scripts
|
|
||||||
|
|
||||||
- BirdNET ([#13313](https://github.com/community-scripts/ProxmoxVE/pull/13313))
|
|
||||||
|
|
||||||
### 🚀 Updated Scripts
|
|
||||||
|
|
||||||
- #### 🐞 Bug Fixes
|
|
||||||
|
|
||||||
- Immich: Bump to 2.6.2 | use start.sh in service, ensure DB_HOSTNAME in .env | Fix Rights Issue with ZFS Shares [@MickLesk](https://github.com/MickLesk) ([#13199](https://github.com/community-scripts/ProxmoxVE/pull/13199))
|
|
||||||
|
|
||||||
- #### ✨ New Features
|
|
||||||
|
|
||||||
- SparkyFitness: add garmin microservice as addon [@tomfrenzel](https://github.com/tomfrenzel) ([#12642](https://github.com/community-scripts/ProxmoxVE/pull/12642))
|
|
||||||
- Frigate: bump to v0.17.1 & change build order [@MickLesk](https://github.com/MickLesk) ([#13304](https://github.com/community-scripts/ProxmoxVE/pull/13304))
|
|
||||||
|
|
||||||
### 💾 Core
|
|
||||||
|
|
||||||
- #### 🐞 Bug Fixes
|
|
||||||
|
|
||||||
- tools.func: pin npm to 11.11.0 to work around Node.js 22.22.2 regression [@MickLesk](https://github.com/MickLesk) ([#13296](https://github.com/community-scripts/ProxmoxVE/pull/13296))
|
|
||||||
|
|
||||||
- #### ✨ New Features
|
|
||||||
|
|
||||||
- core: APT/APK Mirror Fallback for CDN Failures [@MickLesk](https://github.com/MickLesk) ([#13316](https://github.com/community-scripts/ProxmoxVE/pull/13316))
|
|
||||||
- core/tools: replace generic return 1 exit_codes with more specific exit_codes [@MickLesk](https://github.com/MickLesk) ([#13311](https://github.com/community-scripts/ProxmoxVE/pull/13311))
|
|
||||||
|
|
||||||
- #### 🔧 Refactor
|
|
||||||
|
|
||||||
- core: use /usr/bin/install to prevent function shadowing [@MickLesk](https://github.com/MickLesk) ([#13299](https://github.com/community-scripts/ProxmoxVE/pull/13299))
|
|
||||||
|
|
||||||
### 🧰 Tools
|
|
||||||
|
|
||||||
- #### 🐞 Bug Fixes
|
|
||||||
|
|
||||||
- SparkyFitness-Garmin: fix app name [@tomfrenzel](https://github.com/tomfrenzel) ([#13325](https://github.com/community-scripts/ProxmoxVE/pull/13325))
|
|
||||||
|
|
||||||
## 2026-03-25
|
|
||||||
|
|
||||||
### 🚀 Updated Scripts
|
|
||||||
|
|
||||||
- #### ✨ New Features
|
|
||||||
|
|
||||||
- Komodo v2: migrate env vars to v2 and update source [@MickLesk](https://github.com/MickLesk) ([#13262](https://github.com/community-scripts/ProxmoxVE/pull/13262))
|
|
||||||
|
|
||||||
### 💾 Core
|
|
||||||
|
|
||||||
- #### 🔧 Refactor
|
|
||||||
|
|
||||||
- core: make shell command substitutions safe with || true [@MickLesk](https://github.com/MickLesk) ([#13279](https://github.com/community-scripts/ProxmoxVE/pull/13279))
|
|
||||||
|
|
||||||
## 2026-03-24
|
|
||||||
|
|
||||||
### 🆕 New Scripts
|
|
||||||
|
|
||||||
- Homebrew (Addon) ([#13249](https://github.com/community-scripts/ProxmoxVE/pull/13249))
|
|
||||||
- NextExplorer ([#13252](https://github.com/community-scripts/ProxmoxVE/pull/13252))
|
|
||||||
|
|
||||||
### 🚀 Updated Scripts
|
|
||||||
|
|
||||||
- #### ✨ New Features
|
|
||||||
|
|
||||||
- Turnkey: modernize turnkey.sh with shared libraries [@MickLesk](https://github.com/MickLesk) ([#13242](https://github.com/community-scripts/ProxmoxVE/pull/13242))
|
|
||||||
|
|
||||||
- #### 🔧 Refactor
|
|
||||||
|
|
||||||
- chore: replace helper-scripts.com with community-scripts.com [@MickLesk](https://github.com/MickLesk) ([#13244](https://github.com/community-scripts/ProxmoxVE/pull/13244))
|
|
||||||
|
|
||||||
### 🗑️ Deleted Scripts
|
|
||||||
|
|
||||||
- Remove: Booklore [@MickLesk](https://github.com/MickLesk) ([#13265](https://github.com/community-scripts/ProxmoxVE/pull/13265))
|
|
||||||
|
|
||||||
## 2026-03-23
|
|
||||||
|
|
||||||
### 🚀 Updated Scripts
|
|
||||||
|
|
||||||
- #### 🔧 Refactor
|
|
||||||
|
|
||||||
- core: harden shell scripts against injection and insecure permissions [@MickLesk](https://github.com/MickLesk) ([#13239](https://github.com/community-scripts/ProxmoxVE/pull/13239))
|
|
||||||
|
|
||||||
## 2026-03-22
|
|
||||||
|
|
||||||
### 🆕 New Scripts
|
|
||||||
|
|
||||||
- versitygw ([#13180](https://github.com/community-scripts/ProxmoxVE/pull/13180))
|
|
||||||
|
|
||||||
### 🚀 Updated Scripts
|
|
||||||
|
|
||||||
- #### 🐞 Bug Fixes
|
|
||||||
|
|
||||||
- Adventurelog: pin DRF <3.15 to fix coreapi module removal [@MickLesk](https://github.com/MickLesk) ([#13194](https://github.com/community-scripts/ProxmoxVE/pull/13194))
|
|
||||||
|
|
||||||
- #### ✨ New Features
|
|
||||||
|
|
||||||
- ConvertX: add libreoffice-writer for ODT/document conversions [@MickLesk](https://github.com/MickLesk) ([#13196](https://github.com/community-scripts/ProxmoxVE/pull/13196))
|
|
||||||
|
|
||||||
- #### 🔧 Refactor
|
|
||||||
|
|
||||||
- iSponsorblockTV: add AVX CPU check before installation [@MickLesk](https://github.com/MickLesk) ([#13197](https://github.com/community-scripts/ProxmoxVE/pull/13197))
|
|
||||||
|
|
||||||
### 💾 Core
|
|
||||||
|
|
||||||
- #### 🐞 Bug Fixes
|
|
||||||
|
|
||||||
- core: guard against empty IPv6 address in static mode [@MickLesk](https://github.com/MickLesk) ([#13195](https://github.com/community-scripts/ProxmoxVE/pull/13195))
|
|
||||||
|
|
||||||
## 2026-03-21
|
## 2026-03-21
|
||||||
|
|
||||||
### 🚀 Updated Scripts
|
### 🚀 Updated Scripts
|
||||||
|
|||||||
360
CHANGELOG.md
360
CHANGELOG.md
@@ -29,9 +29,6 @@ Exercise vigilance regarding copycat or coat-tailing sites that seek to exploit
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -45,7 +42,7 @@ Exercise vigilance regarding copycat or coat-tailing sites that seek to exploit
|
|||||||
|
|
||||||
|
|
||||||
<details>
|
<details>
|
||||||
<summary><h4>March (28 entries)</h4></summary>
|
<summary><h4>March (21 entries)</h4></summary>
|
||||||
|
|
||||||
[View March 2026 Changelog](.github/changelogs/2026/03.md)
|
[View March 2026 Changelog](.github/changelogs/2026/03.md)
|
||||||
|
|
||||||
@@ -429,104 +426,8 @@ Exercise vigilance regarding copycat or coat-tailing sites that seek to exploit
|
|||||||
|
|
||||||
</details>
|
</details>
|
||||||
|
|
||||||
## 2026-04-01
|
|
||||||
|
|
||||||
### 🆕 New Scripts
|
|
||||||
|
|
||||||
- DrawDB ([#13454](https://github.com/community-scripts/ProxmoxVE/pull/13454))
|
|
||||||
|
|
||||||
### 🧰 Tools
|
|
||||||
|
|
||||||
- #### 🐞 Bug Fixes
|
|
||||||
|
|
||||||
- Filebrowser: make noauth setup use correct database [@MickLesk](https://github.com/MickLesk) ([#13457](https://github.com/community-scripts/ProxmoxVE/pull/13457))
|
|
||||||
|
|
||||||
## 2026-03-31
|
|
||||||
|
|
||||||
### 🚀 Updated Scripts
|
|
||||||
|
|
||||||
- #### 🐞 Bug Fixes
|
|
||||||
|
|
||||||
- Graylog: set vm.max_map_count on host for OpenSearch [@MickLesk](https://github.com/MickLesk) ([#13441](https://github.com/community-scripts/ProxmoxVE/pull/13441))
|
|
||||||
- Koillection: ensure newline before appending to .env.local [@MickLesk](https://github.com/MickLesk) ([#13440](https://github.com/community-scripts/ProxmoxVE/pull/13440))
|
|
||||||
|
|
||||||
### 💾 Core
|
|
||||||
|
|
||||||
- #### 🔧 Refactor
|
|
||||||
|
|
||||||
- core: skip empty gateway value in network config [@MickLesk](https://github.com/MickLesk) ([#13442](https://github.com/community-scripts/ProxmoxVE/pull/13442))
|
|
||||||
|
|
||||||
## 2026-03-30
|
|
||||||
|
|
||||||
### 🆕 New Scripts
|
|
||||||
|
|
||||||
- Bambuddy ([#13411](https://github.com/community-scripts/ProxmoxVE/pull/13411))
|
|
||||||
|
|
||||||
### 🚀 Updated Scripts
|
|
||||||
|
|
||||||
- #### 💥 Breaking Changes
|
|
||||||
|
|
||||||
- Rename: BirdNET > BirdNET-Go [@MickLesk](https://github.com/MickLesk) ([#13410](https://github.com/community-scripts/ProxmoxVE/pull/13410))
|
|
||||||
|
|
||||||
## 2026-03-29
|
|
||||||
|
|
||||||
### 🆕 New Scripts
|
|
||||||
|
|
||||||
- YOURLS ([#13379](https://github.com/community-scripts/ProxmoxVE/pull/13379))
|
|
||||||
|
|
||||||
### 🚀 Updated Scripts
|
|
||||||
|
|
||||||
- #### 🐞 Bug Fixes
|
|
||||||
|
|
||||||
- fix(victoriametrics): use jq to filter releases [@Joery-M](https://github.com/Joery-M) ([#13393](https://github.com/community-scripts/ProxmoxVE/pull/13393))
|
|
||||||
- Ollama: add error handling for Intel GPG key imports [@MickLesk](https://github.com/MickLesk) ([#13397](https://github.com/community-scripts/ProxmoxVE/pull/13397))
|
|
||||||
- Immich: ignore Redis connection error on maintenance mode disable [@MickLesk](https://github.com/MickLesk) ([#13398](https://github.com/community-scripts/ProxmoxVE/pull/13398))
|
|
||||||
- NPM: unmask openresty after migration from package [@MickLesk](https://github.com/MickLesk) ([#13399](https://github.com/community-scripts/ProxmoxVE/pull/13399))
|
|
||||||
|
|
||||||
## 2026-03-28
|
|
||||||
|
|
||||||
### 🚀 Updated Scripts
|
|
||||||
|
|
||||||
- #### 🐞 Bug Fixes
|
|
||||||
|
|
||||||
- Fix: Update gokapi binary name for v2.2.4+ and add migration step [@krazos](https://github.com/krazos) ([#13377](https://github.com/community-scripts/ProxmoxVE/pull/13377))
|
|
||||||
- Fix: update gokapi asset matching for v2.2.4+ naming convention [@krazos](https://github.com/krazos) ([#13369](https://github.com/community-scripts/ProxmoxVE/pull/13369))
|
|
||||||
- Tandoor Recipes: Add missing env variable [@tremor021](https://github.com/tremor021) ([#13365](https://github.com/community-scripts/ProxmoxVE/pull/13365))
|
|
||||||
|
|
||||||
- #### ✨ New Features
|
|
||||||
|
|
||||||
- FileFlows: add option to install Node [@tremor021](https://github.com/tremor021) ([#13368](https://github.com/community-scripts/ProxmoxVE/pull/13368))
|
|
||||||
|
|
||||||
## 2026-03-27
|
|
||||||
|
|
||||||
### 🆕 New Scripts
|
|
||||||
|
|
||||||
- Matter-Server ([#13355](https://github.com/community-scripts/ProxmoxVE/pull/13355))
|
|
||||||
- GeoPulse ([#13320](https://github.com/community-scripts/ProxmoxVE/pull/13320))
|
|
||||||
|
|
||||||
### 🚀 Updated Scripts
|
|
||||||
|
|
||||||
- #### 🐞 Bug Fixes
|
|
||||||
|
|
||||||
- RevealJS: Switch from gulp to vite [@tremor021](https://github.com/tremor021) ([#13336](https://github.com/community-scripts/ProxmoxVE/pull/13336))
|
|
||||||
|
|
||||||
- #### ✨ New Features
|
|
||||||
|
|
||||||
- Dispatcharr add custom Postgres port support for upgrade [@MickLesk](https://github.com/MickLesk) ([#13347](https://github.com/community-scripts/ProxmoxVE/pull/13347))
|
|
||||||
- Immich: bump to v2.6.3 [@MickLesk](https://github.com/MickLesk) ([#13324](https://github.com/community-scripts/ProxmoxVE/pull/13324))
|
|
||||||
|
|
||||||
### 🧰 Tools
|
|
||||||
|
|
||||||
- #### ✨ New Features
|
|
||||||
|
|
||||||
- Refactor/Feature-Bump/Security: Update-Cron-LXCs (Now Local Mode!) [@MickLesk](https://github.com/MickLesk) ([#13339](https://github.com/community-scripts/ProxmoxVE/pull/13339))
|
|
||||||
|
|
||||||
## 2026-03-26
|
## 2026-03-26
|
||||||
|
|
||||||
### 🆕 New Scripts
|
|
||||||
|
|
||||||
- BirdNET ([#13313](https://github.com/community-scripts/ProxmoxVE/pull/13313))
|
|
||||||
|
|
||||||
### 🚀 Updated Scripts
|
### 🚀 Updated Scripts
|
||||||
|
|
||||||
- #### 🐞 Bug Fixes
|
- #### 🐞 Bug Fixes
|
||||||
@@ -536,7 +437,6 @@ Exercise vigilance regarding copycat or coat-tailing sites that seek to exploit
|
|||||||
- #### ✨ New Features
|
- #### ✨ New Features
|
||||||
|
|
||||||
- SparkyFitness: add garmin microservice as addon [@tomfrenzel](https://github.com/tomfrenzel) ([#12642](https://github.com/community-scripts/ProxmoxVE/pull/12642))
|
- SparkyFitness: add garmin microservice as addon [@tomfrenzel](https://github.com/tomfrenzel) ([#12642](https://github.com/community-scripts/ProxmoxVE/pull/12642))
|
||||||
- Frigate: bump to v0.17.1 & change build order [@MickLesk](https://github.com/MickLesk) ([#13304](https://github.com/community-scripts/ProxmoxVE/pull/13304))
|
|
||||||
|
|
||||||
### 💾 Core
|
### 💾 Core
|
||||||
|
|
||||||
@@ -544,21 +444,10 @@ Exercise vigilance regarding copycat or coat-tailing sites that seek to exploit
|
|||||||
|
|
||||||
- tools.func: pin npm to 11.11.0 to work around Node.js 22.22.2 regression [@MickLesk](https://github.com/MickLesk) ([#13296](https://github.com/community-scripts/ProxmoxVE/pull/13296))
|
- tools.func: pin npm to 11.11.0 to work around Node.js 22.22.2 regression [@MickLesk](https://github.com/MickLesk) ([#13296](https://github.com/community-scripts/ProxmoxVE/pull/13296))
|
||||||
|
|
||||||
- #### ✨ New Features
|
|
||||||
|
|
||||||
- core: APT/APK Mirror Fallback for CDN Failures [@MickLesk](https://github.com/MickLesk) ([#13316](https://github.com/community-scripts/ProxmoxVE/pull/13316))
|
|
||||||
- core/tools: replace generic return 1 exit_codes with more specific exit_codes [@MickLesk](https://github.com/MickLesk) ([#13311](https://github.com/community-scripts/ProxmoxVE/pull/13311))
|
|
||||||
|
|
||||||
- #### 🔧 Refactor
|
- #### 🔧 Refactor
|
||||||
|
|
||||||
- core: use /usr/bin/install to prevent function shadowing [@MickLesk](https://github.com/MickLesk) ([#13299](https://github.com/community-scripts/ProxmoxVE/pull/13299))
|
- core: use /usr/bin/install to prevent function shadowing [@MickLesk](https://github.com/MickLesk) ([#13299](https://github.com/community-scripts/ProxmoxVE/pull/13299))
|
||||||
|
|
||||||
### 🧰 Tools
|
|
||||||
|
|
||||||
- #### 🐞 Bug Fixes
|
|
||||||
|
|
||||||
- SparkyFitness-Garmin: fix app name [@tomfrenzel](https://github.com/tomfrenzel) ([#13325](https://github.com/community-scripts/ProxmoxVE/pull/13325))
|
|
||||||
|
|
||||||
## 2026-03-25
|
## 2026-03-25
|
||||||
|
|
||||||
### 🚀 Updated Scripts
|
### 🚀 Updated Scripts
|
||||||
@@ -1200,4 +1089,249 @@ Exercise vigilance regarding copycat or coat-tailing sites that seek to exploit
|
|||||||
- #### ✨ New Features
|
- #### ✨ New Features
|
||||||
|
|
||||||
- core: graceful fallback for apt-get update failures [@MickLesk](https://github.com/MickLesk) ([#12386](https://github.com/community-scripts/ProxmoxVE/pull/12386))
|
- core: graceful fallback for apt-get update failures [@MickLesk](https://github.com/MickLesk) ([#12386](https://github.com/community-scripts/ProxmoxVE/pull/12386))
|
||||||
- core: Improve error outputs across core functions [@MickLesk](https://github.com/MickLesk) ([#12378](https://github.com/community-scripts/ProxmoxVE/pull/12378))
|
- core: Improve error outputs across core functions [@MickLesk](https://github.com/MickLesk) ([#12378](https://github.com/community-scripts/ProxmoxVE/pull/12378))
|
||||||
|
|
||||||
|
## 2026-02-26
|
||||||
|
|
||||||
|
### 🆕 New Scripts
|
||||||
|
|
||||||
|
- Kima-Hub ([#12319](https://github.com/community-scripts/ProxmoxVE/pull/12319))
|
||||||
|
|
||||||
|
### 🚀 Updated Scripts
|
||||||
|
|
||||||
|
- #### 🐞 Bug Fixes
|
||||||
|
|
||||||
|
- tools.func: update glx alternatives / nvidia alternative if nvidia glx are missing [@MickLesk](https://github.com/MickLesk) ([#12372](https://github.com/community-scripts/ProxmoxVE/pull/12372))
|
||||||
|
- hotfix: overseer version [@CrazyWolf13](https://github.com/CrazyWolf13) ([#12366](https://github.com/community-scripts/ProxmoxVE/pull/12366))
|
||||||
|
|
||||||
|
- #### ✨ New Features
|
||||||
|
|
||||||
|
- Add ffmpeg for booklore (ffprobe) [@MickLesk](https://github.com/MickLesk) ([#12371](https://github.com/community-scripts/ProxmoxVE/pull/12371))
|
||||||
|
- [QOL] Immich: add warning regarding library compilation time [@vhsdream](https://github.com/vhsdream) ([#12345](https://github.com/community-scripts/ProxmoxVE/pull/12345))
|
||||||
|
|
||||||
|
### 🧰 Tools
|
||||||
|
|
||||||
|
- #### 🐞 Bug Fixes
|
||||||
|
|
||||||
|
- Improves adguardhome-sync addon when running on alpine LXCs [@Darkangeel-hd](https://github.com/Darkangeel-hd) ([#12362](https://github.com/community-scripts/ProxmoxVE/pull/12362))
|
||||||
|
|
||||||
|
- #### ✨ New Features
|
||||||
|
|
||||||
|
- Add Alpine support and improve Tailscale install [@MickLesk](https://github.com/MickLesk) ([#12370](https://github.com/community-scripts/ProxmoxVE/pull/12370))
|
||||||
|
|
||||||
|
### 📚 Documentation
|
||||||
|
|
||||||
|
- fix wrong link on contributions README.md [@Darkangeel-hd](https://github.com/Darkangeel-hd) ([#12363](https://github.com/community-scripts/ProxmoxVE/pull/12363))
|
||||||
|
|
||||||
|
### 📂 Github
|
||||||
|
|
||||||
|
- github: add workflow to autom. close unauthorized new-script PRs [@MickLesk](https://github.com/MickLesk) ([#12356](https://github.com/community-scripts/ProxmoxVE/pull/12356))
|
||||||
|
|
||||||
|
## 2026-02-25
|
||||||
|
|
||||||
|
### 🆕 New Scripts
|
||||||
|
|
||||||
|
- Zerobyte ([#12321](https://github.com/community-scripts/ProxmoxVE/pull/12321))
|
||||||
|
|
||||||
|
### 🚀 Updated Scripts
|
||||||
|
|
||||||
|
- #### 🐞 Bug Fixes
|
||||||
|
|
||||||
|
- fix: overseer migration [@CrazyWolf13](https://github.com/CrazyWolf13) ([#12340](https://github.com/community-scripts/ProxmoxVE/pull/12340))
|
||||||
|
- add: vikunja: daemon reload [@CrazyWolf13](https://github.com/CrazyWolf13) ([#12323](https://github.com/community-scripts/ProxmoxVE/pull/12323))
|
||||||
|
- opnsense-VM: Use ip link to verify bridge existence [@MickLesk](https://github.com/MickLesk) ([#12329](https://github.com/community-scripts/ProxmoxVE/pull/12329))
|
||||||
|
- wger: Use $http_host for proxy Host header [@MickLesk](https://github.com/MickLesk) ([#12327](https://github.com/community-scripts/ProxmoxVE/pull/12327))
|
||||||
|
- Passbolt: Update Nginx config `client_max_body_size` [@tremor021](https://github.com/tremor021) ([#12313](https://github.com/community-scripts/ProxmoxVE/pull/12313))
|
||||||
|
- Zammad: configure Elasticsearch before zammad start [@MickLesk](https://github.com/MickLesk) ([#12308](https://github.com/community-scripts/ProxmoxVE/pull/12308))
|
||||||
|
|
||||||
|
- #### 🔧 Refactor
|
||||||
|
|
||||||
|
- OpenProject: Various fixes [@tremor021](https://github.com/tremor021) ([#12246](https://github.com/community-scripts/ProxmoxVE/pull/12246))
|
||||||
|
|
||||||
|
### 💾 Core
|
||||||
|
|
||||||
|
- #### 🐞 Bug Fixes
|
||||||
|
|
||||||
|
- Fix detection of ssh keys [@1-tempest](https://github.com/1-tempest) ([#12230](https://github.com/community-scripts/ProxmoxVE/pull/12230))
|
||||||
|
|
||||||
|
- #### ✨ New Features
|
||||||
|
|
||||||
|
- tools.func: Improve GitHub/Codeberg API error handling and error output [@MickLesk](https://github.com/MickLesk) ([#12330](https://github.com/community-scripts/ProxmoxVE/pull/12330))
|
||||||
|
|
||||||
|
- #### 🔧 Refactor
|
||||||
|
|
||||||
|
- core: remove duplicate traps, consolidate error handling and harden signal traps [@MickLesk](https://github.com/MickLesk) ([#12316](https://github.com/community-scripts/ProxmoxVE/pull/12316))
|
||||||
|
|
||||||
|
### 📂 Github
|
||||||
|
|
||||||
|
- github: improvements for node drift wf [@MickLesk](https://github.com/MickLesk) ([#12309](https://github.com/community-scripts/ProxmoxVE/pull/12309))
|
||||||
|
|
||||||
|
## 2026-02-24
|
||||||
|
|
||||||
|
### 🚀 Updated Scripts
|
||||||
|
|
||||||
|
- several scripts: add additional github link in source [@MickLesk](https://github.com/MickLesk) ([#12282](https://github.com/community-scripts/ProxmoxVE/pull/12282))
|
||||||
|
- adds further documentation during the installation script. [@d12rio](https://github.com/d12rio) ([#12248](https://github.com/community-scripts/ProxmoxVE/pull/12248))
|
||||||
|
|
||||||
|
- #### 🐞 Bug Fixes
|
||||||
|
|
||||||
|
- [Fix] PatchMon: remove VITE_API_URL from frontend env [@vhsdream](https://github.com/vhsdream) ([#12294](https://github.com/community-scripts/ProxmoxVE/pull/12294))
|
||||||
|
- fix(searxng): remove orphaned fi causing syntax error [@mark-jeffrey](https://github.com/mark-jeffrey) ([#12283](https://github.com/community-scripts/ProxmoxVE/pull/12283))
|
||||||
|
- Refactor n8n [@MickLesk](https://github.com/MickLesk) ([#12264](https://github.com/community-scripts/ProxmoxVE/pull/12264))
|
||||||
|
- Firefly: PHP bump [@tremor021](https://github.com/tremor021) ([#12247](https://github.com/community-scripts/ProxmoxVE/pull/12247))
|
||||||
|
|
||||||
|
- #### ✨ New Features
|
||||||
|
|
||||||
|
- Databasus: add mariadb path for mysql/mariadb backups | add mongodb database tools [@MickLesk](https://github.com/MickLesk) ([#12259](https://github.com/community-scripts/ProxmoxVE/pull/12259))
|
||||||
|
- make searxng updateable [@shtefko](https://github.com/shtefko) ([#12207](https://github.com/community-scripts/ProxmoxVE/pull/12207))
|
||||||
|
|
||||||
|
- #### 💥 Breaking Changes
|
||||||
|
|
||||||
|
- fix: wealthfolio for v3 [@CrazyWolf13](https://github.com/CrazyWolf13) ([#11765](https://github.com/community-scripts/ProxmoxVE/pull/11765))
|
||||||
|
|
||||||
|
- #### 🔧 Refactor
|
||||||
|
|
||||||
|
- bump various scripts from Node 22 to 24 [@MickLesk](https://github.com/MickLesk) ([#12265](https://github.com/community-scripts/ProxmoxVE/pull/12265))
|
||||||
|
|
||||||
|
### 💾 Core
|
||||||
|
|
||||||
|
- #### 🐞 Bug Fixes
|
||||||
|
|
||||||
|
- core: fix broken "command not found" after err_trap [@MickLesk](https://github.com/MickLesk) ([#12280](https://github.com/community-scripts/ProxmoxVE/pull/12280))
|
||||||
|
|
||||||
|
- #### ✨ New Features
|
||||||
|
|
||||||
|
- tools.func: add get_latest_gh_tag helper function [@MickLesk](https://github.com/MickLesk) ([#12261](https://github.com/community-scripts/ProxmoxVE/pull/12261))
|
||||||
|
|
||||||
|
### 🧰 Tools
|
||||||
|
|
||||||
|
- Arcane ([#12263](https://github.com/community-scripts/ProxmoxVE/pull/12263))
|
||||||
|
|
||||||
|
### 📂 Github
|
||||||
|
|
||||||
|
- github: add weekly Node.js version drift check workflow [@MickLesk](https://github.com/MickLesk) ([#12267](https://github.com/community-scripts/ProxmoxVE/pull/12267))
|
||||||
|
- add: workflow to close stale PRs [@CrazyWolf13](https://github.com/CrazyWolf13) ([#12243](https://github.com/community-scripts/ProxmoxVE/pull/12243))
|
||||||
|
|
||||||
|
## 2026-02-23
|
||||||
|
|
||||||
|
### 🆕 New Scripts
|
||||||
|
|
||||||
|
- SeaweedFS ([#12220](https://github.com/community-scripts/ProxmoxVE/pull/12220))
|
||||||
|
- Sonobarr ([#12221](https://github.com/community-scripts/ProxmoxVE/pull/12221))
|
||||||
|
- SparkyFitness ([#12185](https://github.com/community-scripts/ProxmoxVE/pull/12185))
|
||||||
|
- Frigate v16.4 [@MickLesk](https://github.com/MickLesk) ([#11887](https://github.com/community-scripts/ProxmoxVE/pull/11887))
|
||||||
|
|
||||||
|
### 🚀 Updated Scripts
|
||||||
|
|
||||||
|
- #### ✨ New Features
|
||||||
|
|
||||||
|
- memos: unpin version due new release artifacts [@MickLesk](https://github.com/MickLesk) ([#12224](https://github.com/community-scripts/ProxmoxVE/pull/12224))
|
||||||
|
- core: Enhance signal handling, reported "status" and logs [@MickLesk](https://github.com/MickLesk) ([#12216](https://github.com/community-scripts/ProxmoxVE/pull/12216))
|
||||||
|
|
||||||
|
- #### 🔧 Refactor
|
||||||
|
|
||||||
|
- booklore v2: embed frontend, bump Java to 25, remove nginx [@MickLesk](https://github.com/MickLesk) ([#12223](https://github.com/community-scripts/ProxmoxVE/pull/12223))
|
||||||
|
|
||||||
|
### 🗑️ Deleted Scripts
|
||||||
|
|
||||||
|
- Remove: Huntarr (deprecated & Security) [@michelroegl-brunner](https://github.com/michelroegl-brunner) ([#12226](https://github.com/community-scripts/ProxmoxVE/pull/12226))
|
||||||
|
|
||||||
|
### 💾 Core
|
||||||
|
|
||||||
|
- #### 🔧 Refactor
|
||||||
|
|
||||||
|
- core: Improve error handling and logging for LXC builds [@MickLesk](https://github.com/MickLesk) ([#12208](https://github.com/community-scripts/ProxmoxVE/pull/12208))
|
||||||
|
|
||||||
|
### 🌐 Website
|
||||||
|
|
||||||
|
- #### 🐞 Bug Fixes
|
||||||
|
|
||||||
|
- calibre-web: update default credentials [@LaevaertK](https://github.com/LaevaertK) ([#12201](https://github.com/community-scripts/ProxmoxVE/pull/12201))
|
||||||
|
|
||||||
|
- #### 📝 Script Information
|
||||||
|
|
||||||
|
- chore: update Frigate documentation and website URLs [@JohnICB](https://github.com/JohnICB) ([#12218](https://github.com/community-scripts/ProxmoxVE/pull/12218))
|
||||||
|
|
||||||
|
## 2026-02-22
|
||||||
|
|
||||||
|
### 🆕 New Scripts
|
||||||
|
|
||||||
|
- Gramps-Web ([#12157](https://github.com/community-scripts/ProxmoxVE/pull/12157))
|
||||||
|
|
||||||
|
### 🚀 Updated Scripts
|
||||||
|
|
||||||
|
- #### 🐞 Bug Fixes
|
||||||
|
|
||||||
|
- fix: Apache Guacamole - bump to Temurin JDK 17 to resolve Debian 13 (Trixie) install failure [@Copilot](https://github.com/Copilot) ([#12161](https://github.com/community-scripts/ProxmoxVE/pull/12161))
|
||||||
|
- Docker-VM: add error handling for virt-customize finalization [@MickLesk](https://github.com/MickLesk) ([#12127](https://github.com/community-scripts/ProxmoxVE/pull/12127))
|
||||||
|
- [Fix] Sure: add Sidekiq service [@vhsdream](https://github.com/vhsdream) ([#12186](https://github.com/community-scripts/ProxmoxVE/pull/12186))
|
||||||
|
|
||||||
|
- #### ✨ New Features
|
||||||
|
|
||||||
|
- Refactor & Bump to v2: Plex [@MickLesk](https://github.com/MickLesk) ([#12179](https://github.com/community-scripts/ProxmoxVE/pull/12179))
|
||||||
|
|
||||||
|
- #### 🔧 Refactor
|
||||||
|
|
||||||
|
- karakeep: bump to node 24 [@CrazyWolf13](https://github.com/CrazyWolf13) ([#12183](https://github.com/community-scripts/ProxmoxVE/pull/12183))
|
||||||
|
|
||||||
|
### 💾 Core
|
||||||
|
|
||||||
|
- #### ✨ New Features
|
||||||
|
|
||||||
|
- tools.func: add GitHub API rate-limit detection and GITHUB_TOKEN support [@MickLesk](https://github.com/MickLesk) ([#12176](https://github.com/community-scripts/ProxmoxVE/pull/12176))
|
||||||
|
|
||||||
|
### 🧰 Tools
|
||||||
|
|
||||||
|
- CR*NMASTER ([#12065](https://github.com/community-scripts/ProxmoxVE/pull/12065))
|
||||||
|
|
||||||
|
- #### 🔧 Refactor
|
||||||
|
|
||||||
|
- Update package management commands in clean-lxcs.sh [@heinemannj](https://github.com/heinemannj) ([#12166](https://github.com/community-scripts/ProxmoxVE/pull/12166))
|
||||||
|
|
||||||
|
### ❔ Uncategorized
|
||||||
|
|
||||||
|
- calibre-web: Update logo URL [@MickLesk](https://github.com/MickLesk) ([#12178](https://github.com/community-scripts/ProxmoxVE/pull/12178))
|
||||||
|
|
||||||
|
## 2026-02-21
|
||||||
|
|
||||||
|
### 🚀 Updated Scripts
|
||||||
|
|
||||||
|
- #### 🐞 Bug Fixes
|
||||||
|
|
||||||
|
- Pangolin: restore config before db migration, use drizzle-kit push [@MickLesk](https://github.com/MickLesk) ([#12130](https://github.com/community-scripts/ProxmoxVE/pull/12130))
|
||||||
|
- PLANKA: fix msg's [@danielalanbates](https://github.com/danielalanbates) ([#12143](https://github.com/community-scripts/ProxmoxVE/pull/12143))
|
||||||
|
|
||||||
|
### 🌐 Website
|
||||||
|
|
||||||
|
- #### 📝 Script Information
|
||||||
|
|
||||||
|
- MediaManager: Update documentation URL [@tremor021](https://github.com/tremor021) ([#12154](https://github.com/community-scripts/ProxmoxVE/pull/12154))
|
||||||
|
|
||||||
|
## 2026-02-20
|
||||||
|
|
||||||
|
### 🆕 New Scripts
|
||||||
|
|
||||||
|
- Sure ([#12114](https://github.com/community-scripts/ProxmoxVE/pull/12114))
|
||||||
|
- Calibre-Web ([#12115](https://github.com/community-scripts/ProxmoxVE/pull/12115))
|
||||||
|
|
||||||
|
### 🚀 Updated Scripts
|
||||||
|
|
||||||
|
- #### 🐞 Bug Fixes
|
||||||
|
|
||||||
|
- Zammad: fix Elasticsearch JVM config and add daemon-reload [@MickLesk](https://github.com/MickLesk) ([#12125](https://github.com/community-scripts/ProxmoxVE/pull/12125))
|
||||||
|
- Huntarr: add build-essential for native pip dependencies [@MickLesk](https://github.com/MickLesk) ([#12126](https://github.com/community-scripts/ProxmoxVE/pull/12126))
|
||||||
|
- Dokploy: fix update function [@vhsdream](https://github.com/vhsdream) ([#12116](https://github.com/community-scripts/ProxmoxVE/pull/12116))
|
||||||
|
|
||||||
|
- #### 💥 Breaking Changes
|
||||||
|
|
||||||
|
- recyclarr: adjust paths for v8.0 breaking changes [@MickLesk](https://github.com/MickLesk) ([#12129](https://github.com/community-scripts/ProxmoxVE/pull/12129))
|
||||||
|
|
||||||
|
- #### 🔧 Refactor
|
||||||
|
|
||||||
|
- Planka: migrate data paths to new v2 directory structure [@MickLesk](https://github.com/MickLesk) ([#12128](https://github.com/community-scripts/ProxmoxVE/pull/12128))
|
||||||
|
|
||||||
|
### 🌐 Website
|
||||||
|
|
||||||
|
- #### 📝 Script Information
|
||||||
|
|
||||||
|
- fixen broken link to dawarich documentation [@RiX012](https://github.com/RiX012) ([#12103](https://github.com/community-scripts/ProxmoxVE/pull/12103))
|
||||||
@@ -1,78 +0,0 @@
|
|||||||
#!/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: Adrian-RDA
|
|
||||||
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
|
|
||||||
# Source: https://github.com/maziggy/bambuddy
|
|
||||||
|
|
||||||
APP="Bambuddy"
|
|
||||||
var_tags="${var_tags:-media;3d-printing}"
|
|
||||||
var_cpu="${var_cpu:-2}"
|
|
||||||
var_ram="${var_ram:-2048}"
|
|
||||||
var_disk="${var_disk:-10}"
|
|
||||||
var_os="${var_os:-debian}"
|
|
||||||
var_version="${var_version:-13}"
|
|
||||||
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/bambuddy ]]; then
|
|
||||||
msg_error "No ${APP} Installation Found!"
|
|
||||||
exit
|
|
||||||
fi
|
|
||||||
|
|
||||||
if check_for_gh_release "bambuddy" "maziggy/bambuddy"; then
|
|
||||||
msg_info "Stopping Service"
|
|
||||||
systemctl stop bambuddy
|
|
||||||
msg_ok "Stopped Service"
|
|
||||||
|
|
||||||
msg_info "Backing up Configuration and Data"
|
|
||||||
cp /opt/bambuddy/.env /opt/bambuddy.env.bak
|
|
||||||
cp -r /opt/bambuddy/data /opt/bambuddy_data_bak
|
|
||||||
msg_ok "Backed up Configuration and Data"
|
|
||||||
|
|
||||||
CLEAN_INSTALL=1 fetch_and_deploy_gh_release "bambuddy" "maziggy/bambuddy" "tarball" "latest" "/opt/bambuddy"
|
|
||||||
|
|
||||||
msg_info "Updating Python Dependencies"
|
|
||||||
cd /opt/bambuddy
|
|
||||||
$STD uv venv
|
|
||||||
$STD uv pip install -r requirements.txt
|
|
||||||
msg_ok "Updated Python Dependencies"
|
|
||||||
|
|
||||||
msg_info "Rebuilding Frontend"
|
|
||||||
cd /opt/bambuddy/frontend
|
|
||||||
$STD npm install
|
|
||||||
$STD npm run build
|
|
||||||
msg_ok "Rebuilt Frontend"
|
|
||||||
|
|
||||||
msg_info "Restoring Configuration and Data"
|
|
||||||
cp /opt/bambuddy.env.bak /opt/bambuddy/.env
|
|
||||||
cp -r /opt/bambuddy_data_bak/. /opt/bambuddy/data/
|
|
||||||
rm -f /opt/bambuddy.env.bak
|
|
||||||
rm -rf /opt/bambuddy_data_bak
|
|
||||||
msg_ok "Restored Configuration and Data"
|
|
||||||
|
|
||||||
msg_info "Starting Service"
|
|
||||||
systemctl start bambuddy
|
|
||||||
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 "${TAB}${GATEWAY}${BGN}http://${IP}:8000${CL}"
|
|
||||||
@@ -1,63 +0,0 @@
|
|||||||
#!/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 (CanbiZ)
|
|
||||||
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
|
|
||||||
# Source: https://github.com/tphakala/birdnet-go
|
|
||||||
|
|
||||||
APP="BirdNET-Go"
|
|
||||||
var_tags="${var_tags:-monitoring;ai;nature}"
|
|
||||||
var_cpu="${var_cpu:-4}"
|
|
||||||
var_ram="${var_ram:-2048}"
|
|
||||||
var_disk="${var_disk:-12}"
|
|
||||||
var_os="${var_os:-debian}"
|
|
||||||
var_version="${var_version:-13}"
|
|
||||||
var_unprivileged="${var_unprivileged:-1}"
|
|
||||||
var_gpu="${var_gpu:-no}"
|
|
||||||
|
|
||||||
header_info "$APP"
|
|
||||||
variables
|
|
||||||
color
|
|
||||||
catch_errors
|
|
||||||
|
|
||||||
function update_script() {
|
|
||||||
header_info
|
|
||||||
check_container_storage
|
|
||||||
check_container_resources
|
|
||||||
|
|
||||||
if [[ ! -f /usr/local/bin/birdnet-go ]]; then
|
|
||||||
msg_error "No ${APP} Installation Found!"
|
|
||||||
exit
|
|
||||||
fi
|
|
||||||
|
|
||||||
if check_for_gh_release "birdnet" "tphakala/birdnet-go"; then
|
|
||||||
msg_info "Stopping Service"
|
|
||||||
systemctl stop birdnet
|
|
||||||
msg_ok "Stopped Service"
|
|
||||||
|
|
||||||
fetch_and_deploy_gh_release "birdnet" "tphakala/birdnet-go" "prebuild" "latest" "/opt/birdnet" "birdnet-go-linux-amd64.tar.gz"
|
|
||||||
|
|
||||||
msg_info "Deploying Binary"
|
|
||||||
cp /opt/birdnet/birdnet-go /usr/local/bin/birdnet-go
|
|
||||||
chmod +x /usr/local/bin/birdnet-go
|
|
||||||
cp -r /opt/birdnet/libtensorflowlite_c.so /usr/local/lib/ || true
|
|
||||||
ldconfig
|
|
||||||
msg_ok "Deployed Binary"
|
|
||||||
|
|
||||||
msg_info "Starting Service"
|
|
||||||
systemctl start birdnet
|
|
||||||
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 "${TAB}${GATEWAY}${BGN}http://${IP}:8080${CL}"
|
|
||||||
@@ -70,7 +70,7 @@ function update_script() {
|
|||||||
source /opt/dispatcharr/.env
|
source /opt/dispatcharr/.env
|
||||||
set +o allexport
|
set +o allexport
|
||||||
if [[ -n "$POSTGRES_DB" ]] && [[ -n "$POSTGRES_USER" ]] && [[ -n "$POSTGRES_PASSWORD" ]]; then
|
if [[ -n "$POSTGRES_DB" ]] && [[ -n "$POSTGRES_USER" ]] && [[ -n "$POSTGRES_PASSWORD" ]]; then
|
||||||
PGPASSWORD=$POSTGRES_PASSWORD pg_dump -U "$POSTGRES_USER" -h "${POSTGRES_HOST:-localhost}" -p "${POSTGRES_PORT:-5432}" "$POSTGRES_DB" >/tmp/dispatcharr_db_$(date +%F).sql
|
PGPASSWORD=$POSTGRES_PASSWORD pg_dump -U $POSTGRES_USER -h ${POSTGRES_HOST:-localhost} $POSTGRES_DB >/tmp/dispatcharr_db_$(date +%F).sql
|
||||||
msg_info "Database backup created"
|
msg_info "Database backup created"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|||||||
53
ct/drawdb.sh
53
ct/drawdb.sh
@@ -1,53 +0,0 @@
|
|||||||
#!/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/drawdb-io/drawdb
|
|
||||||
|
|
||||||
APP="DrawDB"
|
|
||||||
var_tags="${var_tags:-database;dev-tools}"
|
|
||||||
var_cpu="${var_cpu:-2}"
|
|
||||||
var_ram="${var_ram:-6144}"
|
|
||||||
var_disk="${var_disk:-5}"
|
|
||||||
var_os="${var_os:-debian}"
|
|
||||||
var_version="${var_version:-13}"
|
|
||||||
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/drawdb ]]; then
|
|
||||||
msg_error "No ${APP} Installation Found!"
|
|
||||||
exit
|
|
||||||
fi
|
|
||||||
|
|
||||||
if check_for_gh_tag "drawdb" "drawdb-io/drawdb"; then
|
|
||||||
CLEAN_INSTALL=1 fetch_and_deploy_gh_tag "drawdb" "drawdb-io/drawdb" "latest" "/opt/drawdb"
|
|
||||||
|
|
||||||
msg_info "Rebuilding Frontend"
|
|
||||||
cd /opt/drawdb
|
|
||||||
$STD npm ci
|
|
||||||
NODE_OPTIONS="--max-old-space-size=4096" $STD npm run build
|
|
||||||
sed -i '/<head>/a <script>if(!crypto.randomUUID){crypto.randomUUID=function(){return([1e7]+-1e3+-4e3+-8e3+-1e11).replace(/[018]/g,function(c){return(c^(crypto.getRandomValues(new Uint8Array(1))[0]&(15>>c/4))).toString(16)})}};</script>' /opt/drawdb/dist/index.html
|
|
||||||
msg_ok "Rebuilt Frontend"
|
|
||||||
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 "${TAB}${GATEWAY}${BGN}http://${IP}:3000${CL}"
|
|
||||||
@@ -29,11 +29,11 @@ function update_script() {
|
|||||||
msg_error "No ${APP} Installation Found!"
|
msg_error "No ${APP} Installation Found!"
|
||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
|
|
||||||
update_available=$(curl -fsSL -X 'GET' "http://localhost:19200/api/status/update-available" -H 'accept: application/json' | jq .UpdateAvailable)
|
update_available=$(curl -fsSL -X 'GET' "http://localhost:19200/api/status/update-available" -H 'accept: application/json' | jq .UpdateAvailable)
|
||||||
if [[ "${update_available}" == "true" ]]; then
|
if [[ "${update_available}" == "true" ]]; then
|
||||||
msg_info "Stopping Service"
|
msg_info "Stopping Service"
|
||||||
systemctl stop fileflows*
|
systemctl stop fileflows
|
||||||
msg_info "Stopped Service"
|
msg_info "Stopped Service"
|
||||||
|
|
||||||
msg_info "Creating Backup"
|
msg_info "Creating Backup"
|
||||||
@@ -45,7 +45,7 @@ function update_script() {
|
|||||||
fetch_and_deploy_from_url "https://fileflows.com/downloads/zip" "/opt/fileflows"
|
fetch_and_deploy_from_url "https://fileflows.com/downloads/zip" "/opt/fileflows"
|
||||||
|
|
||||||
msg_info "Starting Service"
|
msg_info "Starting Service"
|
||||||
systemctl start fileflows*
|
systemctl start fileflows
|
||||||
msg_ok "Started Service"
|
msg_ok "Started Service"
|
||||||
msg_ok "Updated successfully!"
|
msg_ok "Updated successfully!"
|
||||||
else
|
else
|
||||||
|
|||||||
@@ -1,71 +0,0 @@
|
|||||||
#!/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: CrazyWolf13
|
|
||||||
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
|
|
||||||
# Source: https://github.com/tess1o/geopulse
|
|
||||||
|
|
||||||
APP="GeoPulse"
|
|
||||||
var_tags="${var_tags:-location;tracking;gps}"
|
|
||||||
var_cpu="${var_cpu:-2}"
|
|
||||||
var_ram="${var_ram:-1024}"
|
|
||||||
var_disk="${var_disk:-8}"
|
|
||||||
var_os="${var_os:-debian}"
|
|
||||||
var_version="${var_version:-13}"
|
|
||||||
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 /opt/geopulse/backend/geopulse-backend ]]; then
|
|
||||||
msg_error "No ${APP} Installation Found!"
|
|
||||||
exit
|
|
||||||
fi
|
|
||||||
|
|
||||||
if check_for_gh_release "geopulse-backend" "tess1o/geopulse"; then
|
|
||||||
msg_info "Stopping Service"
|
|
||||||
systemctl stop geopulse-backend
|
|
||||||
msg_ok "Stopped Service"
|
|
||||||
|
|
||||||
if [[ "$(uname -m)" == "aarch64" ]]; then
|
|
||||||
if grep -qi "raspberry\|bcm" /proc/cpuinfo 2>/dev/null; then
|
|
||||||
BINARY_PATTERN="geopulse-backend-native-arm64-compat-*"
|
|
||||||
else
|
|
||||||
BINARY_PATTERN="geopulse-backend-native-arm64-[!c]*"
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
if grep -q avx2 /proc/cpuinfo && grep -q bmi2 /proc/cpuinfo && grep -q fma /proc/cpuinfo; then
|
|
||||||
BINARY_PATTERN="geopulse-backend-native-amd64-[!c]*"
|
|
||||||
else
|
|
||||||
BINARY_PATTERN="geopulse-backend-native-amd64-compat-*"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
fetch_and_deploy_gh_release "geopulse-backend" "tess1o/geopulse" "singlefile" "latest" "/opt/geopulse/backend" "${BINARY_PATTERN}"
|
|
||||||
fetch_and_deploy_gh_release "geopulse-frontend" "tess1o/geopulse" "prebuild" "latest" "/var/www/geopulse" "geopulse-frontend-*.tar.gz"
|
|
||||||
|
|
||||||
msg_info "Starting Service"
|
|
||||||
systemctl start geopulse-backend
|
|
||||||
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 "${TAB}${GATEWAY}${BGN}http://${IP}${CL}"
|
|
||||||
echo -e "${INFO}${YW} To create an admin account, run:${CL}"
|
|
||||||
echo -e "${TAB}${BGN}/usr/local/bin/create-geopulse-admin${CL}"
|
|
||||||
11
ct/gokapi.sh
11
ct/gokapi.sh
@@ -32,16 +32,7 @@ function update_script() {
|
|||||||
systemctl stop gokapi
|
systemctl stop gokapi
|
||||||
msg_ok "Stopped Service"
|
msg_ok "Stopped Service"
|
||||||
|
|
||||||
fetch_and_deploy_gh_release "gokapi" "Forceu/Gokapi" "prebuild" "latest" "/opt/gokapi" "*linux*amd64.zip"
|
fetch_and_deploy_gh_release "gokapi" "Forceu/Gokapi" "prebuild" "latest" "/opt/gokapi" "gokapi-linux_amd64.zip"
|
||||||
|
|
||||||
# Migrate from pre-v2.2.4 binary name (gokapi-linux_amd64 -> gokapi)
|
|
||||||
if [[ -f /opt/gokapi/gokapi-linux_amd64 ]]; then
|
|
||||||
rm -f /opt/gokapi/gokapi-linux_amd64
|
|
||||||
fi
|
|
||||||
if grep -q "gokapi-linux_amd64" /etc/systemd/system/gokapi.service 2>/dev/null; then
|
|
||||||
sed -i 's|gokapi-linux_amd64|gokapi|g' /etc/systemd/system/gokapi.service
|
|
||||||
systemctl daemon-reload
|
|
||||||
fi
|
|
||||||
|
|
||||||
msg_info "Starting Service"
|
msg_info "Starting Service"
|
||||||
systemctl start gokapi
|
systemctl start gokapi
|
||||||
|
|||||||
@@ -64,12 +64,6 @@ function update_script() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
start
|
start
|
||||||
|
|
||||||
if [[ $(sysctl -n vm.max_map_count 2>/dev/null) -lt 262144 ]]; then
|
|
||||||
sysctl -w vm.max_map_count=262144 >/dev/null 2>&1
|
|
||||||
echo "vm.max_map_count=262144" >/etc/sysctl.d/graylog.conf
|
|
||||||
fi
|
|
||||||
|
|
||||||
build_container
|
build_container
|
||||||
description
|
description
|
||||||
|
|
||||||
|
|||||||
@@ -1,6 +0,0 @@
|
|||||||
____ __ __ __
|
|
||||||
/ __ )____ _____ ___ / /_ __ ______/ /___/ /_ __
|
|
||||||
/ __ / __ `/ __ `__ \/ __ \/ / / / __ / __ / / / /
|
|
||||||
/ /_/ / /_/ / / / / / / /_/ / /_/ / /_/ / /_/ / /_/ /
|
|
||||||
/_____/\__,_/_/ /_/ /_/_.___/\__,_/\__,_/\__,_/\__, /
|
|
||||||
/____/
|
|
||||||
@@ -1,6 +0,0 @@
|
|||||||
____ _ ___ ______________ ______
|
|
||||||
/ __ )(_)________/ / | / / ____/_ __/ / ____/___
|
|
||||||
/ __ / / ___/ __ / |/ / __/ / /_____/ / __/ __ \
|
|
||||||
/ /_/ / / / / /_/ / /| / /___ / /_____/ /_/ / /_/ /
|
|
||||||
/_____/_/_/ \__,_/_/ |_/_____/ /_/ \____/\____/
|
|
||||||
|
|
||||||
@@ -1,6 +0,0 @@
|
|||||||
____ ____ ____
|
|
||||||
/ __ \_________ __ __/ __ \/ __ )
|
|
||||||
/ / / / ___/ __ `/ | /| / / / / / __ |
|
|
||||||
/ /_/ / / / /_/ /| |/ |/ / /_/ / /_/ /
|
|
||||||
/_____/_/ \__,_/ |__/|__/_____/_____/
|
|
||||||
|
|
||||||
@@ -1,6 +0,0 @@
|
|||||||
______ ____ __
|
|
||||||
/ ____/__ ____ / __ \__ __/ /_______
|
|
||||||
/ / __/ _ \/ __ \/ /_/ / / / / / ___/ _ \
|
|
||||||
/ /_/ / __/ /_/ / ____/ /_/ / (__ ) __/
|
|
||||||
\____/\___/\____/_/ \__,_/_/____/\___/
|
|
||||||
|
|
||||||
@@ -1,6 +0,0 @@
|
|||||||
__ ___ __ __ _____
|
|
||||||
/ |/ /___ _/ /_/ /____ _____ / ___/___ ______ _____ _____
|
|
||||||
/ /|_/ / __ `/ __/ __/ _ \/ ___/_____\__ \/ _ \/ ___/ | / / _ \/ ___/
|
|
||||||
/ / / / /_/ / /_/ /_/ __/ / /_____/__/ / __/ / | |/ / __/ /
|
|
||||||
/_/ /_/\__,_/\__/\__/\___/_/ /____/\___/_/ |___/\___/_/
|
|
||||||
|
|
||||||
@@ -1,6 +0,0 @@
|
|||||||
__ ______ __ ______ __ _____
|
|
||||||
\ \/ / __ \/ / / / __ \/ / / ___/
|
|
||||||
\ / / / / / / / /_/ / / \__ \
|
|
||||||
/ / /_/ / /_/ / _, _/ /______/ /
|
|
||||||
/_/\____/\____/_/ |_/_____/____/
|
|
||||||
|
|
||||||
@@ -109,7 +109,7 @@ EOF
|
|||||||
msg_ok "Image-processing libraries up to date"
|
msg_ok "Image-processing libraries up to date"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
RELEASE="v2.6.3"
|
RELEASE="v2.6.2"
|
||||||
if check_for_gh_release "Immich" "immich-app/immich" "${RELEASE}" "each release is tested individually before the version is updated. Please do not open issues for this"; then
|
if check_for_gh_release "Immich" "immich-app/immich" "${RELEASE}" "each release is tested individually before the version is updated. Please do not open issues for this"; then
|
||||||
if [[ $(cat ~/.immich) > "2.5.1" ]]; then
|
if [[ $(cat ~/.immich) > "2.5.1" ]]; then
|
||||||
msg_info "Enabling Maintenance Mode"
|
msg_info "Enabling Maintenance Mode"
|
||||||
@@ -283,7 +283,7 @@ EOF
|
|||||||
if [[ "${MAINT_MODE:-0}" == 1 ]]; then
|
if [[ "${MAINT_MODE:-0}" == 1 ]]; then
|
||||||
msg_info "Disabling Maintenance Mode"
|
msg_info "Disabling Maintenance Mode"
|
||||||
cd /opt/immich/app/bin
|
cd /opt/immich/app/bin
|
||||||
$STD ./immich-admin disable-maintenance-mode || true
|
$STD ./immich-admin disable-maintenance-mode
|
||||||
unset MAINT_MODE
|
unset MAINT_MODE
|
||||||
$STD cd -
|
$STD cd -
|
||||||
msg_ok "Disabled Maintenance Mode"
|
msg_ok "Disabled Maintenance Mode"
|
||||||
|
|||||||
@@ -48,9 +48,7 @@ function update_script() {
|
|||||||
|
|
||||||
# Ensure APP_RUNTIME is in .env.local for CLI commands (upgrades from older versions)
|
# Ensure APP_RUNTIME is in .env.local for CLI commands (upgrades from older versions)
|
||||||
if ! grep -q "APP_RUNTIME" /opt/koillection/.env.local 2>/dev/null; then
|
if ! grep -q "APP_RUNTIME" /opt/koillection/.env.local 2>/dev/null; then
|
||||||
# Ensure file ends with newline before appending to avoid concatenation
|
echo 'APP_RUNTIME="Symfony\Component\Runtime\SymfonyRuntime"' >> /opt/koillection/.env.local
|
||||||
[[ -s /opt/koillection/.env.local && -n "$(tail -c 1 /opt/koillection/.env.local)" ]] && echo "" >>/opt/koillection/.env.local
|
|
||||||
echo 'APP_RUNTIME="Symfony\Component\Runtime\SymfonyRuntime"' >>/opt/koillection/.env.local
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
export COMPOSER_ALLOW_SUPERUSER=1
|
export COMPOSER_ALLOW_SUPERUSER=1
|
||||||
|
|||||||
@@ -1,60 +0,0 @@
|
|||||||
#!/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 (CanbiZ)
|
|
||||||
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
|
|
||||||
# Source: https://github.com/matter-js/python-matter-server
|
|
||||||
|
|
||||||
APP="Matter-Server"
|
|
||||||
var_tags="${var_tags:-matter;iot;smart-home}"
|
|
||||||
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_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/matter-server ]]; then
|
|
||||||
msg_error "No ${APP} Installation Found!"
|
|
||||||
exit
|
|
||||||
fi
|
|
||||||
|
|
||||||
if check_for_gh_release "matter-server" "matter-js/python-matter-server"; then
|
|
||||||
msg_info "Stopping Service"
|
|
||||||
systemctl stop matter-server
|
|
||||||
msg_ok "Stopped Service"
|
|
||||||
|
|
||||||
msg_info "Updating Matter Server"
|
|
||||||
MATTER_VERSION=$(get_latest_github_release "matter-js/python-matter-server")
|
|
||||||
$STD uv pip install --python /opt/matter-server/.venv/bin/python --upgrade "python-matter-server[server]==${MATTER_VERSION}"
|
|
||||||
echo "${MATTER_VERSION}" >~/.matter-server
|
|
||||||
msg_ok "Updated Matter Server"
|
|
||||||
|
|
||||||
fetch_and_deploy_gh_release "chip-ota-provider-app" "home-assistant-libs/matter-linux-ota-provider" "singlefile" "latest" "/usr/local/bin" "chip-ota-provider-app-x86-64"
|
|
||||||
|
|
||||||
msg_info "Starting Service"
|
|
||||||
systemctl start matter-server
|
|
||||||
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} Matter Server WebSocket API is running on port 5580.${CL}"
|
|
||||||
echo -e "${TAB}${GATEWAY}${BGN}ws://${IP}:5580/ws${CL}"
|
|
||||||
@@ -28,6 +28,11 @@ function update_script() {
|
|||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if [[ $(grep -E '^VERSION_ID=' /etc/os-release) == *"12"* ]]; then
|
||||||
|
msg_error "Wrong Debian version detected!"
|
||||||
|
msg_error "Please create a snapshot first. You must upgrade your LXC to Debian Trixie before updating. Visit: https://github.com/community-scripts/ProxmoxVE/discussions/7489"
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
|
||||||
if command -v node &>/dev/null; then
|
if command -v node &>/dev/null; then
|
||||||
CURRENT_NODE_VERSION=$(node --version | cut -d'v' -f2 | cut -d'.' -f1)
|
CURRENT_NODE_VERSION=$(node --version | cut -d'v' -f2 | cut -d'.' -f1)
|
||||||
@@ -93,7 +98,6 @@ ExecStart=/usr/local/openresty/nginx/sbin/nginx -g 'daemon off;'
|
|||||||
WantedBy=multi-user.target
|
WantedBy=multi-user.target
|
||||||
EOF
|
EOF
|
||||||
systemctl daemon-reload
|
systemctl daemon-reload
|
||||||
systemctl unmask openresty 2>/dev/null || true
|
|
||||||
systemctl restart openresty
|
systemctl restart openresty
|
||||||
msg_ok "Built OpenResty"
|
msg_ok "Built OpenResty"
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -40,7 +40,7 @@ function update_script() {
|
|||||||
cd /opt/revealjs
|
cd /opt/revealjs
|
||||||
$STD npm install
|
$STD npm install
|
||||||
cp -f /opt/index.html /opt/revealjs
|
cp -f /opt/index.html /opt/revealjs
|
||||||
sed -i 's/"vite"/"vite --host"/g' package.json
|
sed -i '25s/localhost/0.0.0.0/g' /opt/revealjs/gulpfile.js
|
||||||
rm -f /opt/index.html
|
rm -f /opt/index.html
|
||||||
msg_ok "Updated RevealJS"
|
msg_ok "Updated RevealJS"
|
||||||
|
|
||||||
|
|||||||
@@ -33,10 +33,6 @@ function update_script() {
|
|||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if ! grep -q "^ALLOWED_HOSTS=" /opt/tandoor/.env; then
|
|
||||||
echo "ALLOWED_HOSTS=${LOCAL_IP}" >>/opt/tandoor/.env
|
|
||||||
fi
|
|
||||||
|
|
||||||
if check_for_gh_release "tandoor" "TandoorRecipes/recipes"; then
|
if check_for_gh_release "tandoor" "TandoorRecipes/recipes"; then
|
||||||
msg_info "Stopping Service"
|
msg_info "Stopping Service"
|
||||||
systemctl stop tandoor
|
systemctl stop tandoor
|
||||||
|
|||||||
@@ -34,26 +34,24 @@ function update_script() {
|
|||||||
[[ -f /etc/systemd/system/victoriametrics-logs.service ]] && systemctl stop victoriametrics-logs
|
[[ -f /etc/systemd/system/victoriametrics-logs.service ]] && systemctl stop victoriametrics-logs
|
||||||
msg_ok "Stopped Service"
|
msg_ok "Stopped Service"
|
||||||
|
|
||||||
victoriametrics_release=$(curl -fsSL "https://api.github.com/repos/VictoriaMetrics/VictoriaMetrics/releases" |
|
victoriametrics_filename=$(curl -fsSL "https://api.github.com/repos/VictoriaMetrics/VictoriaMetrics/releases/latest" |
|
||||||
jq -r '.[] | select(.assets[].name | match("^victoria-metrics-linux-amd64-v[0-9.]+.tar.gz$")) | .tag_name' |
|
jq -r '.assets[].name' |
|
||||||
head -n 1)
|
grep -E '^victoria-metrics-linux-amd64-v[0-9.]+\.tar\.gz$')
|
||||||
|
vmutils_filename=$(curl -fsSL "https://api.github.com/repos/VictoriaMetrics/VictoriaMetrics/releases/latest" |
|
||||||
|
jq -r '.assets[].name' |
|
||||||
|
grep -E '^vmutils-linux-amd64-v[0-9.]+\.tar\.gz$')
|
||||||
|
|
||||||
msg_debug "Using release $victoriametrics_release"
|
fetch_and_deploy_gh_release "victoriametrics" "VictoriaMetrics/VictoriaMetrics" "prebuild" "latest" "/opt/victoriametrics" "$victoriametrics_filename"
|
||||||
|
fetch_and_deploy_gh_release "vmutils" "VictoriaMetrics/VictoriaMetrics" "prebuild" "latest" "/opt/victoriametrics" "$vmutils_filename"
|
||||||
victoriametrics_filename="victoria-metrics-linux-amd64-${victoriametrics_release}.tar.gz"
|
|
||||||
vmutils_filename="vmutils-linux-amd64-${victoriametrics_release}.tar.gz"
|
|
||||||
|
|
||||||
fetch_and_deploy_gh_release "victoriametrics" "VictoriaMetrics/VictoriaMetrics" "prebuild" "$victoriametrics_release" "/opt/victoriametrics" "$victoriametrics_filename"
|
|
||||||
fetch_and_deploy_gh_release "vmutils" "VictoriaMetrics/VictoriaMetrics" "prebuild" "$victoriametrics_release" "/opt/victoriametrics" "$vmutils_filename"
|
|
||||||
|
|
||||||
if [[ -f /etc/systemd/system/victoriametrics-logs.service ]]; then
|
if [[ -f /etc/systemd/system/victoriametrics-logs.service ]]; then
|
||||||
vmlogs_filename=$(curl -fsSL "https://api.github.com/repos/VictoriaMetrics/VictoriaLogs/releases/latest" |
|
vmlogs_filename=$(curl -fsSL "https://api.github.com/repos/VictoriaMetrics/VictoriaLogs/releases/latest" |
|
||||||
jq -r '.assets[].name' |
|
jq -r '.assets[].name' |
|
||||||
grep -E '^victoria-logs-linux-amd64-v[0-9.]+\.tar\.gz$')
|
grep -E '^victoria-logs-linux-amd64-v[0-9.]+\.tar\.gz$')
|
||||||
vlutils_filename=$(curl -fsSL "https://api.github.com/repos/VictoriaMetrics/VictoriaLogs/releases/latest" |
|
vlutils_filename=$(curl -fsSL "https://api.github.com/repos/VictoriaMetrics/VictoriaLogs/releases/latest" |
|
||||||
jq -r '.assets[].name' |
|
jq -r '.assets[].name' |
|
||||||
grep -E '^vlutils-linux-amd64-v[0-9.]+\.tar\.gz$')
|
grep -E '^vlutils-linux-amd64-v[0-9.]+\.tar\.gz$')
|
||||||
|
|
||||||
fetch_and_deploy_gh_release "victorialogs" "VictoriaMetrics/VictoriaLogs" "prebuild" "latest" "/opt/victoriametrics" "$vmlogs_filename"
|
fetch_and_deploy_gh_release "victorialogs" "VictoriaMetrics/VictoriaLogs" "prebuild" "latest" "/opt/victoriametrics" "$vmlogs_filename"
|
||||||
fetch_and_deploy_gh_release "vlutils" "VictoriaMetrics/VictoriaLogs" "prebuild" "latest" "/opt/victoriametrics" "$vlutils_filename"
|
fetch_and_deploy_gh_release "vlutils" "VictoriaMetrics/VictoriaLogs" "prebuild" "latest" "/opt/victoriametrics" "$vlutils_filename"
|
||||||
fi
|
fi
|
||||||
|
|||||||
66
ct/yourls.sh
66
ct/yourls.sh
@@ -1,66 +0,0 @@
|
|||||||
#!/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 (CanbiZ)
|
|
||||||
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
|
|
||||||
# Source: https://yourls.org/
|
|
||||||
|
|
||||||
APP="YOURLS"
|
|
||||||
var_tags="${var_tags:-url-shortener;php}"
|
|
||||||
var_cpu="${var_cpu:-1}"
|
|
||||||
var_ram="${var_ram:-512}"
|
|
||||||
var_disk="${var_disk:-4}"
|
|
||||||
var_os="${var_os:-debian}"
|
|
||||||
var_version="${var_version:-13}"
|
|
||||||
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 /opt/yourls/yourls-loader.php ]]; then
|
|
||||||
msg_error "No ${APP} Installation Found!"
|
|
||||||
exit
|
|
||||||
fi
|
|
||||||
|
|
||||||
if check_for_gh_release "yourls" "YOURLS/YOURLS"; then
|
|
||||||
msg_info "Stopping Service"
|
|
||||||
systemctl stop nginx
|
|
||||||
msg_ok "Stopped Service"
|
|
||||||
|
|
||||||
msg_info "Backing up Configuration"
|
|
||||||
cp -r /opt/yourls/user /opt/yourls_user.bak
|
|
||||||
msg_ok "Backed up Configuration"
|
|
||||||
|
|
||||||
CLEAN_INSTALL=1 fetch_and_deploy_gh_release "yourls" "YOURLS/YOURLS" "tarball"
|
|
||||||
chown -R www-data:www-data /opt/yourls
|
|
||||||
|
|
||||||
msg_info "Restoring Configuration"
|
|
||||||
cp -r /opt/yourls_user.bak/. /opt/yourls/user/
|
|
||||||
rm -rf /opt/yourls_user.bak
|
|
||||||
msg_ok "Restored Configuration"
|
|
||||||
|
|
||||||
msg_info "Starting Service"
|
|
||||||
systemctl start nginx
|
|
||||||
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} First, complete the database setup at:${CL}"
|
|
||||||
echo -e "${TAB}${GATEWAY}${BGN}http://${IP}/admin/install.php${CL}"
|
|
||||||
echo -e "${INFO}${YW} Admin credentials are in the install log:${CL}"
|
|
||||||
echo -e "${TAB}${GATEWAY}${BGN}grep -A2 'admin' /opt/yourls/user/config.php${CL}"
|
|
||||||
@@ -50,7 +50,7 @@ function update_script() {
|
|||||||
rm -rf /opt/zigbee2mqtt/data
|
rm -rf /opt/zigbee2mqtt/data
|
||||||
mv /opt/z2m_backup/data /opt/zigbee2mqtt
|
mv /opt/z2m_backup/data /opt/zigbee2mqtt
|
||||||
cd /opt/zigbee2mqtt
|
cd /opt/zigbee2mqtt
|
||||||
grep -q "^packageImportMethod" ./pnpm-workspace.yaml 2>/dev/null || echo "packageImportMethod: hardlink" >>./pnpm-workspace.yaml
|
grep -q "^packageImportMethod" ./pnpm-workspace.yaml || echo "packageImportMethod: hardlink" >>./pnpm-workspace.yaml
|
||||||
$STD pnpm install --frozen-lockfile
|
$STD pnpm install --frozen-lockfile
|
||||||
$STD pnpm build
|
$STD pnpm build
|
||||||
rm -rf /opt/z2m_backup
|
rm -rf /opt/z2m_backup
|
||||||
|
|||||||
@@ -1,67 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
|
|
||||||
# Copyright (c) 2021-2026 community-scripts ORG
|
|
||||||
# Author: Adrian-RDA
|
|
||||||
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
|
|
||||||
# Source: https://github.com/maziggy/bambuddy
|
|
||||||
|
|
||||||
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 libglib2.0-0
|
|
||||||
msg_ok "Installed Dependencies"
|
|
||||||
|
|
||||||
PYTHON_VERSION="3.13" setup_uv
|
|
||||||
NODE_VERSION="22" setup_nodejs
|
|
||||||
fetch_and_deploy_gh_release "bambuddy" "maziggy/bambuddy" "tarball" "latest" "/opt/bambuddy"
|
|
||||||
|
|
||||||
msg_info "Setting up Python Environment"
|
|
||||||
cd /opt/bambuddy
|
|
||||||
$STD uv venv
|
|
||||||
$STD uv pip install -r requirements.txt
|
|
||||||
msg_ok "Set up Python Environment"
|
|
||||||
|
|
||||||
msg_info "Building Frontend"
|
|
||||||
cd /opt/bambuddy/frontend
|
|
||||||
$STD npm install
|
|
||||||
$STD npm run build
|
|
||||||
msg_ok "Built Frontend"
|
|
||||||
|
|
||||||
msg_info "Configuring Bambuddy"
|
|
||||||
mkdir -p /opt/bambuddy/data /opt/bambuddy/logs
|
|
||||||
cat <<EOF >/opt/bambuddy/.env
|
|
||||||
DEBUG=false
|
|
||||||
LOG_LEVEL=INFO
|
|
||||||
LOG_TO_FILE=true
|
|
||||||
EOF
|
|
||||||
msg_ok "Configured Bambuddy"
|
|
||||||
|
|
||||||
msg_info "Creating Service"
|
|
||||||
cat <<EOF >/etc/systemd/system/bambuddy.service
|
|
||||||
[Unit]
|
|
||||||
Description=Bambuddy - Bambu Lab Print Management
|
|
||||||
Documentation=https://github.com/maziggy/bambuddy
|
|
||||||
After=network.target
|
|
||||||
|
|
||||||
[Service]
|
|
||||||
Type=simple
|
|
||||||
WorkingDirectory=/opt/bambuddy
|
|
||||||
ExecStart=/opt/bambuddy/.venv/bin/uvicorn backend.app.main:app --host 0.0.0.0 --port 8000
|
|
||||||
Restart=on-failure
|
|
||||||
RestartSec=5
|
|
||||||
|
|
||||||
[Install]
|
|
||||||
WantedBy=multi-user.target
|
|
||||||
EOF
|
|
||||||
systemctl enable -q --now bambuddy
|
|
||||||
msg_ok "Created Service"
|
|
||||||
|
|
||||||
motd_ssh
|
|
||||||
customize
|
|
||||||
cleanup_lxc
|
|
||||||
@@ -1,56 +0,0 @@
|
|||||||
#!/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://github.com/tphakala/birdnet-go
|
|
||||||
|
|
||||||
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 \
|
|
||||||
libasound2 \
|
|
||||||
sox \
|
|
||||||
alsa-utils \
|
|
||||||
ffmpeg
|
|
||||||
msg_ok "Installed Dependencies"
|
|
||||||
|
|
||||||
fetch_and_deploy_gh_release "birdnet" "tphakala/birdnet-go" "prebuild" "latest" "/opt/birdnet" "birdnet-go-linux-amd64.tar.gz"
|
|
||||||
|
|
||||||
msg_info "Setting up BirdNET-Go"
|
|
||||||
cp /opt/birdnet/birdnet-go /usr/local/bin/birdnet-go
|
|
||||||
chmod +x /usr/local/bin/birdnet-go
|
|
||||||
cp -r /opt/birdnet/libtensorflowlite_c.so /usr/local/lib/ || true
|
|
||||||
ldconfig
|
|
||||||
mkdir -p /opt/birdnet/data/clips
|
|
||||||
msg_ok "Set up BirdNET-Go"
|
|
||||||
|
|
||||||
msg_info "Creating Service"
|
|
||||||
cat <<EOF >/etc/systemd/system/birdnet.service
|
|
||||||
[Unit]
|
|
||||||
Description=BirdNET
|
|
||||||
After=network.target
|
|
||||||
|
|
||||||
[Service]
|
|
||||||
Type=simple
|
|
||||||
User=root
|
|
||||||
WorkingDirectory=/opt/birdnet/data
|
|
||||||
ExecStart=/usr/local/bin/birdnet-go realtime
|
|
||||||
Restart=on-failure
|
|
||||||
RestartSec=5
|
|
||||||
|
|
||||||
[Install]
|
|
||||||
WantedBy=multi-user.target
|
|
||||||
EOF
|
|
||||||
systemctl enable -q --now birdnet
|
|
||||||
msg_ok "Created Service"
|
|
||||||
|
|
||||||
motd_ssh
|
|
||||||
customize
|
|
||||||
cleanup_lxc
|
|
||||||
@@ -1,52 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
|
|
||||||
# Copyright (c) 2021-2026 community-scripts ORG
|
|
||||||
# Author: MickLesk
|
|
||||||
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
|
|
||||||
# Source: https://github.com/drawdb-io/drawdb
|
|
||||||
|
|
||||||
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 nginx
|
|
||||||
msg_ok "Installed Dependencies"
|
|
||||||
|
|
||||||
NODE_VERSION="20" setup_nodejs
|
|
||||||
fetch_and_deploy_gh_tag "drawdb" "drawdb-io/drawdb" "latest" "/opt/drawdb"
|
|
||||||
|
|
||||||
msg_info "Building Frontend"
|
|
||||||
cd /opt/drawdb
|
|
||||||
$STD npm ci
|
|
||||||
NODE_OPTIONS="--max-old-space-size=4096" $STD npm run build
|
|
||||||
msg_ok "Built Frontend"
|
|
||||||
|
|
||||||
msg_info "Applying crypto.randomUUID Polyfill"
|
|
||||||
sed -i '/<head>/a <script>if(!crypto.randomUUID){crypto.randomUUID=function(){return([1e7]+-1e3+-4e3+-8e3+-1e11).replace(/[018]/g,function(c){return(c^(crypto.getRandomValues(new Uint8Array(1))[0]&(15>>c/4))).toString(16)})}};</script>' /opt/drawdb/dist/index.html
|
|
||||||
msg_ok "Applied Polyfill"
|
|
||||||
|
|
||||||
msg_info "Configuring Nginx"
|
|
||||||
cat <<EOF >/etc/nginx/conf.d/drawdb.conf
|
|
||||||
server {
|
|
||||||
listen 3000;
|
|
||||||
server_name _;
|
|
||||||
root /opt/drawdb/dist;
|
|
||||||
|
|
||||||
location / {
|
|
||||||
try_files \$uri /index.html;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
EOF
|
|
||||||
rm -f /etc/nginx/sites-enabled/default
|
|
||||||
systemctl enable -q --now nginx
|
|
||||||
systemctl reload nginx
|
|
||||||
msg_ok "Configured Nginx"
|
|
||||||
|
|
||||||
motd_ssh
|
|
||||||
customize
|
|
||||||
cleanup_lxc
|
|
||||||
@@ -33,25 +33,13 @@ msg_ok "Installed ASP.NET Core Runtime"
|
|||||||
|
|
||||||
fetch_and_deploy_from_url "https://fileflows.com/downloads/zip" "/opt/fileflows"
|
fetch_and_deploy_from_url "https://fileflows.com/downloads/zip" "/opt/fileflows"
|
||||||
|
|
||||||
|
msg_info "Setup FileFlows"
|
||||||
$STD ln -svf /usr/bin/ffmpeg /usr/local/bin/ffmpeg
|
$STD ln -svf /usr/bin/ffmpeg /usr/local/bin/ffmpeg
|
||||||
$STD ln -svf /usr/bin/ffprobe /usr/local/bin/ffprobe
|
$STD ln -svf /usr/bin/ffprobe /usr/local/bin/ffprobe
|
||||||
|
cd /opt/fileflows/Server
|
||||||
read -r -p "${TAB3}Do you want to install FileFlows Server or Node? (S/N): " install_server
|
dotnet FileFlows.Server.dll --systemd install --root true
|
||||||
|
systemctl enable -q --now fileflows
|
||||||
if [[ "$install_server" =~ ^[Ss]$ ]]; then
|
msg_ok "Setup FileFlows"
|
||||||
msg_info "Installing FileFlows Server"
|
|
||||||
cd /opt/fileflows/Server
|
|
||||||
$STD dotnet FileFlows.Server.dll --systemd install --root true
|
|
||||||
systemctl enable -q --now fileflows
|
|
||||||
msg_ok "Installed FileFlows Server"
|
|
||||||
else
|
|
||||||
msg_info "Installing FileFlows Node"
|
|
||||||
cd /opt/fileflows/Node
|
|
||||||
$STD dotnet FileFlows.Node.dll
|
|
||||||
$STD dotnet FileFlows.Node.dll --systemd install --root true
|
|
||||||
systemctl enable -q --now fileflows-node
|
|
||||||
msg_ok "Installed FileFlows Node"
|
|
||||||
fi
|
|
||||||
|
|
||||||
motd_ssh
|
motd_ssh
|
||||||
customize
|
customize
|
||||||
|
|||||||
@@ -110,7 +110,7 @@ export AUTOGRAPH_VERBOSITY=0
|
|||||||
export GLOG_minloglevel=3
|
export GLOG_minloglevel=3
|
||||||
export GLOG_logtostderr=0
|
export GLOG_logtostderr=0
|
||||||
|
|
||||||
fetch_and_deploy_gh_release "frigate" "blakeblackshear/frigate" "tarball" "v0.17.1" "/opt/frigate"
|
fetch_and_deploy_gh_release "frigate" "blakeblackshear/frigate" "tarball" "v0.17.0" "/opt/frigate"
|
||||||
|
|
||||||
msg_info "Building Nginx"
|
msg_info "Building Nginx"
|
||||||
$STD bash /opt/frigate/docker/main/build_nginx.sh
|
$STD bash /opt/frigate/docker/main/build_nginx.sh
|
||||||
@@ -182,6 +182,23 @@ cp /opt/frigate/audio-labelmap.txt /audio-labelmap.txt
|
|||||||
rm -f /tmp/yamnet.tar.gz
|
rm -f /tmp/yamnet.tar.gz
|
||||||
msg_ok "Downloaded Audio Model"
|
msg_ok "Downloaded Audio Model"
|
||||||
|
|
||||||
|
msg_info "Installing HailoRT Runtime"
|
||||||
|
$STD bash /opt/frigate/docker/main/install_hailort.sh
|
||||||
|
cp -a /opt/frigate/docker/main/rootfs/. /
|
||||||
|
sed -i '/^.*unset DEBIAN_FRONTEND.*$/d' /opt/frigate/docker/main/install_deps.sh
|
||||||
|
echo "libedgetpu1-max libedgetpu/accepted-eula boolean true" | debconf-set-selections
|
||||||
|
echo "libedgetpu1-max libedgetpu/install-confirm-max boolean true" | debconf-set-selections
|
||||||
|
echo 'force-overwrite' >/etc/dpkg/dpkg.cfg.d/force-overwrite
|
||||||
|
$STD bash /opt/frigate/docker/main/install_deps.sh
|
||||||
|
rm -f /etc/dpkg/dpkg.cfg.d/force-overwrite
|
||||||
|
$STD pip3 install -U /wheels/*.whl
|
||||||
|
ldconfig
|
||||||
|
msg_ok "Installed HailoRT Runtime"
|
||||||
|
|
||||||
|
msg_info "Installing MemryX Runtime"
|
||||||
|
$STD bash /opt/frigate/docker/main/install_memryx.sh
|
||||||
|
msg_ok "Installed MemryX Runtime"
|
||||||
|
|
||||||
msg_info "Installing OpenVino"
|
msg_info "Installing OpenVino"
|
||||||
$STD pip3 install -r /opt/frigate/docker/main/requirements-ov.txt
|
$STD pip3 install -r /opt/frigate/docker/main/requirements-ov.txt
|
||||||
msg_ok "Installed OpenVino"
|
msg_ok "Installed OpenVino"
|
||||||
@@ -211,23 +228,6 @@ else
|
|||||||
msg_warn "OpenVino build failed (CPU may not support required instructions). Frigate will use CPU model."
|
msg_warn "OpenVino build failed (CPU may not support required instructions). Frigate will use CPU model."
|
||||||
fi
|
fi
|
||||||
|
|
||||||
msg_info "Installing HailoRT Runtime"
|
|
||||||
$STD bash /opt/frigate/docker/main/install_hailort.sh
|
|
||||||
cp -a /opt/frigate/docker/main/rootfs/. /
|
|
||||||
sed -i '/^.*unset DEBIAN_FRONTEND.*$/d' /opt/frigate/docker/main/install_deps.sh
|
|
||||||
echo "libedgetpu1-max libedgetpu/accepted-eula boolean true" | debconf-set-selections
|
|
||||||
echo "libedgetpu1-max libedgetpu/install-confirm-max boolean true" | debconf-set-selections
|
|
||||||
echo 'force-overwrite' >/etc/dpkg/dpkg.cfg.d/force-overwrite
|
|
||||||
$STD bash /opt/frigate/docker/main/install_deps.sh
|
|
||||||
rm -f /etc/dpkg/dpkg.cfg.d/force-overwrite
|
|
||||||
$STD pip3 install -U /wheels/*.whl
|
|
||||||
ldconfig
|
|
||||||
msg_ok "Installed HailoRT Runtime"
|
|
||||||
|
|
||||||
msg_info "Installing MemryX Runtime"
|
|
||||||
$STD bash /opt/frigate/docker/main/install_memryx.sh
|
|
||||||
msg_ok "Installed MemryX Runtime"
|
|
||||||
|
|
||||||
msg_info "Building Frigate Application (Patience)"
|
msg_info "Building Frigate Application (Patience)"
|
||||||
cd /opt/frigate
|
cd /opt/frigate
|
||||||
$STD pip3 install -r /opt/frigate/docker/main/requirements-dev.txt
|
$STD pip3 install -r /opt/frigate/docker/main/requirements-dev.txt
|
||||||
|
|||||||
@@ -1,205 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
|
|
||||||
# Copyright (c) 2021-2026 community-scripts ORG
|
|
||||||
# Author: CrazyWolf13
|
|
||||||
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
|
|
||||||
# Source: https://github.com/tess1o/geopulse
|
|
||||||
|
|
||||||
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 \
|
|
||||||
openssl \
|
|
||||||
nginx
|
|
||||||
msg_ok "Installed Dependencies"
|
|
||||||
|
|
||||||
PG_VERSION="17" PG_MODULES="postgis" setup_postgresql
|
|
||||||
PG_DB_NAME="geopulse" PG_DB_USER="geopulse" PG_DB_EXTENSIONS="postgis,postgis_topology" setup_postgresql_db
|
|
||||||
|
|
||||||
msg_info "Generating Security Keys"
|
|
||||||
mkdir -p /opt/geopulse/{backend,keys}
|
|
||||||
mkdir -p /etc/geopulse /var/www/geopulse /var/lib/geopulse/dumps
|
|
||||||
mkdir -p /var/log/geopulse/{backend,nginx}
|
|
||||||
openssl genpkey -algorithm RSA -out /opt/geopulse/keys/jwt-private-key.pem 2>/dev/null
|
|
||||||
openssl rsa -pubout -in /opt/geopulse/keys/jwt-private-key.pem -out /opt/geopulse/keys/jwt-public-key.pem 2>/dev/null
|
|
||||||
openssl rand -base64 32 >/opt/geopulse/keys/ai-encryption-key.txt
|
|
||||||
chmod 640 /opt/geopulse/keys/jwt-private-key.pem /opt/geopulse/keys/jwt-public-key.pem /opt/geopulse/keys/ai-encryption-key.txt
|
|
||||||
msg_ok "Generated Security Keys"
|
|
||||||
|
|
||||||
if [[ "$(uname -m)" == "aarch64" ]]; then
|
|
||||||
if grep -qi "raspberry\|bcm" /proc/cpuinfo 2>/dev/null; then
|
|
||||||
BINARY_PATTERN="geopulse-backend-native-arm64-compat-*"
|
|
||||||
else
|
|
||||||
BINARY_PATTERN="geopulse-backend-native-arm64-[!c]*"
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
if grep -q avx2 /proc/cpuinfo && grep -q bmi2 /proc/cpuinfo && grep -q fma /proc/cpuinfo; then
|
|
||||||
BINARY_PATTERN="geopulse-backend-native-amd64-[!c]*"
|
|
||||||
else
|
|
||||||
BINARY_PATTERN="geopulse-backend-native-amd64-compat-*"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
fetch_and_deploy_gh_release "geopulse-backend" "tess1o/geopulse" "singlefile" "latest" "/opt/geopulse/backend" "${BINARY_PATTERN}"
|
|
||||||
fetch_and_deploy_gh_release "geopulse-frontend" "tess1o/geopulse" "prebuild" "latest" "/var/www/geopulse" "geopulse-frontend-*.tar.gz"
|
|
||||||
|
|
||||||
msg_info "Configuring GeoPulse"
|
|
||||||
cat <<EOF >/etc/geopulse/geopulse.env
|
|
||||||
GEOPULSE_PUBLIC_BASE_URL=http://${LOCAL_IP}
|
|
||||||
GEOPULSE_UI_URL=http://${LOCAL_IP}
|
|
||||||
GEOPULSE_CORS_ENABLED=false
|
|
||||||
GEOPULSE_CORS_ORIGINS=
|
|
||||||
QUARKUS_HTTP_PORT=8080
|
|
||||||
GEOPULSE_POSTGRES_URL=jdbc:postgresql://localhost:5432/${PG_DB_NAME}
|
|
||||||
GEOPULSE_POSTGRES_HOST=localhost
|
|
||||||
GEOPULSE_POSTGRES_PORT=5432
|
|
||||||
GEOPULSE_POSTGRES_DB=${PG_DB_NAME}
|
|
||||||
GEOPULSE_POSTGRES_USERNAME=${PG_DB_USER}
|
|
||||||
GEOPULSE_POSTGRES_PASSWORD=${PG_DB_PASS}
|
|
||||||
GEOPULSE_JWT_PRIVATE_KEY_LOCATION=file:/opt/geopulse/keys/jwt-private-key.pem
|
|
||||||
GEOPULSE_JWT_PUBLIC_KEY_LOCATION=file:/opt/geopulse/keys/jwt-public-key.pem
|
|
||||||
GEOPULSE_AI_ENCRYPTION_KEY_LOCATION=file:/opt/geopulse/keys/ai-encryption-key.txt
|
|
||||||
QUARKUS_LOG_FILE_ENABLE=true
|
|
||||||
QUARKUS_LOG_FILE_PATH=/var/log/geopulse/backend/geopulse.log
|
|
||||||
QUARKUS_LOG_FILE_ROTATION_MAX_FILE_SIZE=10M
|
|
||||||
QUARKUS_LOG_FILE_ROTATION_MAX_BACKUP_INDEX=5
|
|
||||||
EOF
|
|
||||||
chmod 640 /etc/geopulse/geopulse.env
|
|
||||||
msg_ok "Configured GeoPulse"
|
|
||||||
|
|
||||||
msg_info "Creating Service"
|
|
||||||
cat <<EOF >/etc/systemd/system/geopulse-backend.service
|
|
||||||
[Unit]
|
|
||||||
Description=GeoPulse Backend
|
|
||||||
After=network.target postgresql.service
|
|
||||||
Wants=postgresql.service
|
|
||||||
|
|
||||||
[Service]
|
|
||||||
Type=simple
|
|
||||||
User=root
|
|
||||||
WorkingDirectory=/opt/geopulse/backend
|
|
||||||
EnvironmentFile=/etc/geopulse/geopulse.env
|
|
||||||
ExecStart=/opt/geopulse/backend/geopulse-backend -Dquarkus.http.host=0.0.0.0 -XX:MaximumHeapSizePercent=70 -XX:MaximumYoungGenerationSizePercent=15
|
|
||||||
Restart=on-failure
|
|
||||||
RestartSec=10
|
|
||||||
StandardOutput=append:/var/log/geopulse/backend/geopulse-stdout.log
|
|
||||||
StandardError=append:/var/log/geopulse/backend/geopulse-stderr.log
|
|
||||||
|
|
||||||
[Install]
|
|
||||||
WantedBy=multi-user.target
|
|
||||||
EOF
|
|
||||||
systemctl enable -q --now geopulse-backend
|
|
||||||
msg_ok "Created Service"
|
|
||||||
|
|
||||||
msg_info "Configuring Nginx"
|
|
||||||
mkdir -p /var/cache/nginx/osm_tiles
|
|
||||||
cat <<'EOF' >/etc/nginx/sites-available/geopulse.conf
|
|
||||||
proxy_cache_path /var/cache/nginx/osm_tiles levels=1:2 keys_zone=osm_cache:100m max_size=10g inactive=30d use_temp_path=off;
|
|
||||||
|
|
||||||
map $uri $osm_subdomain {
|
|
||||||
~^/osm/tiles/a/ "a";
|
|
||||||
~^/osm/tiles/b/ "b";
|
|
||||||
~^/osm/tiles/c/ "c";
|
|
||||||
default "a";
|
|
||||||
}
|
|
||||||
|
|
||||||
server {
|
|
||||||
listen 80;
|
|
||||||
server_name _;
|
|
||||||
|
|
||||||
root /var/www/geopulse;
|
|
||||||
index index.html;
|
|
||||||
|
|
||||||
client_max_body_size 100M;
|
|
||||||
|
|
||||||
gzip on;
|
|
||||||
gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;
|
|
||||||
gzip_comp_level 6;
|
|
||||||
gzip_min_length 1000;
|
|
||||||
|
|
||||||
location ~* ^/(?!osm/).*\.(jpg|jpeg|png|gif|ico|css|js)$ {
|
|
||||||
expires 1y;
|
|
||||||
add_header Cache-Control "public, max-age=31536000";
|
|
||||||
}
|
|
||||||
|
|
||||||
location ^~ /osm/tiles/ {
|
|
||||||
resolver 8.8.8.8 valid=300s;
|
|
||||||
resolver_timeout 10s;
|
|
||||||
rewrite ^/osm/tiles/[abc]/(.*)$ /$1 break;
|
|
||||||
proxy_pass https://$osm_subdomain.tile.openstreetmap.org;
|
|
||||||
proxy_cache osm_cache;
|
|
||||||
proxy_cache_key "$scheme$proxy_host$uri";
|
|
||||||
proxy_cache_valid 200 30d;
|
|
||||||
proxy_cache_valid 404 1m;
|
|
||||||
proxy_cache_valid 502 503 504 1m;
|
|
||||||
proxy_ignore_headers Cache-Control Expires Set-Cookie;
|
|
||||||
proxy_cache_use_stale error timeout updating http_500 http_502 http_503 http_504;
|
|
||||||
proxy_cache_background_update on;
|
|
||||||
proxy_cache_lock on;
|
|
||||||
proxy_set_header Cookie "";
|
|
||||||
proxy_set_header Authorization "";
|
|
||||||
proxy_set_header User-Agent "GeoPulse/1.0";
|
|
||||||
proxy_set_header Host $osm_subdomain.tile.openstreetmap.org;
|
|
||||||
proxy_http_version 1.1;
|
|
||||||
proxy_set_header Connection "";
|
|
||||||
proxy_connect_timeout 10s;
|
|
||||||
proxy_read_timeout 10s;
|
|
||||||
expires 30d;
|
|
||||||
add_header Cache-Control "public, immutable";
|
|
||||||
add_header X-Cache-Status $upstream_cache_status always;
|
|
||||||
}
|
|
||||||
|
|
||||||
location /api/ {
|
|
||||||
proxy_pass http://localhost:8080/api/;
|
|
||||||
proxy_connect_timeout 3600s;
|
|
||||||
proxy_send_timeout 3600s;
|
|
||||||
proxy_read_timeout 3600s;
|
|
||||||
proxy_set_header Host $host;
|
|
||||||
proxy_set_header X-Real-IP $remote_addr;
|
|
||||||
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
|
||||||
proxy_set_header X-Forwarded-Proto $scheme;
|
|
||||||
}
|
|
||||||
|
|
||||||
location / {
|
|
||||||
try_files $uri $uri/ /index.html;
|
|
||||||
}
|
|
||||||
|
|
||||||
add_header X-Frame-Options "SAMEORIGIN" always;
|
|
||||||
add_header X-Content-Type-Options "nosniff" always;
|
|
||||||
add_header X-XSS-Protection "1; mode=block" always;
|
|
||||||
|
|
||||||
access_log /var/log/geopulse/nginx/access.log;
|
|
||||||
error_log /var/log/geopulse/nginx/error.log;
|
|
||||||
}
|
|
||||||
EOF
|
|
||||||
ln -sf /etc/nginx/sites-available/geopulse.conf /etc/nginx/sites-enabled/
|
|
||||||
rm -f /etc/nginx/sites-enabled/default
|
|
||||||
systemctl enable -q --now nginx
|
|
||||||
systemctl reload nginx
|
|
||||||
msg_ok "Configured Nginx"
|
|
||||||
|
|
||||||
msg_info "Creating Admin Helper"
|
|
||||||
cat <<'EOF' >/usr/local/bin/create-geopulse-admin
|
|
||||||
#!/usr/bin/env bash
|
|
||||||
read -rp "Enter admin email address: " ADMIN_EMAIL
|
|
||||||
if [[ -z "$ADMIN_EMAIL" ]]; then
|
|
||||||
echo "No email provided. Aborting."
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
sed -i '/^GEOPULSE_ADMIN_EMAIL=/d' /etc/geopulse/geopulse.env
|
|
||||||
echo "GEOPULSE_ADMIN_EMAIL=${ADMIN_EMAIL}" >>/etc/geopulse/geopulse.env
|
|
||||||
systemctl restart geopulse-backend
|
|
||||||
echo "Admin email set to '${ADMIN_EMAIL}'. Register with this email in the GeoPulse UI to receive admin privileges."
|
|
||||||
EOF
|
|
||||||
chmod +x /usr/local/bin/create-geopulse-admin
|
|
||||||
msg_ok "Created Admin Helper"
|
|
||||||
|
|
||||||
motd_ssh
|
|
||||||
customize
|
|
||||||
cleanup_lxc
|
|
||||||
@@ -13,11 +13,11 @@ setting_up_container
|
|||||||
network_check
|
network_check
|
||||||
update_os
|
update_os
|
||||||
|
|
||||||
fetch_and_deploy_gh_release "gokapi" "Forceu/Gokapi" "prebuild" "latest" "/opt/gokapi" "*linux*amd64.zip"
|
fetch_and_deploy_gh_release "gokapi" "Forceu/Gokapi" "prebuild" "latest" "/opt/gokapi" "gokapi-linux_amd64.zip"
|
||||||
|
|
||||||
msg_info "Configuring Gokapi"
|
msg_info "Configuring Gokapi"
|
||||||
mkdir -p /opt/gokapi/{data,config}
|
mkdir -p /opt/gokapi/{data,config}
|
||||||
chmod +x /opt/gokapi/gokapi
|
chmod +x /opt/gokapi/gokapi-linux_amd64
|
||||||
msg_ok "Configured Gokapi"
|
msg_ok "Configured Gokapi"
|
||||||
|
|
||||||
msg_info "Creating Service"
|
msg_info "Creating Service"
|
||||||
@@ -29,7 +29,7 @@ Description=gokapi
|
|||||||
Type=simple
|
Type=simple
|
||||||
Environment=GOKAPI_DATA_DIR=/opt/gokapi/data
|
Environment=GOKAPI_DATA_DIR=/opt/gokapi/data
|
||||||
Environment=GOKAPI_CONFIG_DIR=/opt/gokapi/config
|
Environment=GOKAPI_CONFIG_DIR=/opt/gokapi/config
|
||||||
ExecStart=/opt/gokapi/gokapi
|
ExecStart=/opt/gokapi/gokapi-linux_amd64
|
||||||
|
|
||||||
[Install]
|
[Install]
|
||||||
WantedBy=multi-user.target
|
WantedBy=multi-user.target
|
||||||
|
|||||||
@@ -295,7 +295,7 @@ ML_DIR="${APP_DIR}/machine-learning"
|
|||||||
GEO_DIR="${INSTALL_DIR}/geodata"
|
GEO_DIR="${INSTALL_DIR}/geodata"
|
||||||
mkdir -p {"${APP_DIR}","${UPLOAD_DIR}","${GEO_DIR}","${INSTALL_DIR}"/cache}
|
mkdir -p {"${APP_DIR}","${UPLOAD_DIR}","${GEO_DIR}","${INSTALL_DIR}"/cache}
|
||||||
|
|
||||||
fetch_and_deploy_gh_release "Immich" "immich-app/immich" "tarball" "v2.6.3" "$SRC_DIR"
|
fetch_and_deploy_gh_release "Immich" "immich-app/immich" "tarball" "v2.6.2" "$SRC_DIR"
|
||||||
PNPM_VERSION="$(jq -r '.packageManager | split("@")[1] | split("+")[0]' ${SRC_DIR}/package.json)"
|
PNPM_VERSION="$(jq -r '.packageManager | split("@")[1] | split("+")[0]' ${SRC_DIR}/package.json)"
|
||||||
NODE_VERSION="24" NODE_MODULE="pnpm@${PNPM_VERSION}" setup_nodejs
|
NODE_VERSION="24" NODE_MODULE="pnpm@${PNPM_VERSION}" setup_nodejs
|
||||||
|
|
||||||
|
|||||||
@@ -1,72 +0,0 @@
|
|||||||
#!/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://github.com/matter-js/python-matter-server
|
|
||||||
|
|
||||||
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 \
|
|
||||||
libuv1 \
|
|
||||||
libjson-c5 \
|
|
||||||
libnl-3-200 \
|
|
||||||
libnl-route-3-200 \
|
|
||||||
iputils-ping \
|
|
||||||
iproute2
|
|
||||||
msg_ok "Installed Dependencies"
|
|
||||||
|
|
||||||
UV_PYTHON="3.12" setup_uv
|
|
||||||
|
|
||||||
msg_info "Setting up Matter Server"
|
|
||||||
mkdir -p /opt/matter-server/data/credentials
|
|
||||||
if [ -L /data ]; then
|
|
||||||
rm -f /data
|
|
||||||
fi
|
|
||||||
if [ ! -e /data ]; then
|
|
||||||
ln -s /opt/matter-server/data /data
|
|
||||||
fi
|
|
||||||
$STD uv venv /opt/matter-server/.venv
|
|
||||||
MATTER_VERSION=$(get_latest_github_release "matter-js/python-matter-server")
|
|
||||||
$STD uv pip install --python /opt/matter-server/.venv/bin/python "python-matter-server[server]==${MATTER_VERSION}"
|
|
||||||
echo "${MATTER_VERSION}" >~/.matter-server
|
|
||||||
msg_ok "Set up Matter Server"
|
|
||||||
|
|
||||||
fetch_and_deploy_gh_release "chip-ota-provider-app" "home-assistant-libs/matter-linux-ota-provider" "singlefile" "latest" "/usr/local/bin" "chip-ota-provider-app-x86-64"
|
|
||||||
|
|
||||||
msg_info "Configuring Network"
|
|
||||||
cat <<EOF >/etc/sysctl.d/99-matter.conf
|
|
||||||
net.ipv4.igmp_max_memberships=1024
|
|
||||||
EOF
|
|
||||||
$STD sysctl -p /etc/sysctl.d/99-matter.conf
|
|
||||||
msg_ok "Configured Network"
|
|
||||||
|
|
||||||
msg_info "Creating Service"
|
|
||||||
cat <<EOF >/etc/systemd/system/matter-server.service
|
|
||||||
[Unit]
|
|
||||||
Description=Matter Server
|
|
||||||
After=network.target
|
|
||||||
|
|
||||||
[Service]
|
|
||||||
Type=simple
|
|
||||||
User=root
|
|
||||||
ExecStart=/opt/matter-server/.venv/bin/matter-server --storage-path /data --paa-root-cert-dir /data/credentials
|
|
||||||
Restart=on-failure
|
|
||||||
RestartSec=5
|
|
||||||
|
|
||||||
[Install]
|
|
||||||
WantedBy=multi-user.target
|
|
||||||
EOF
|
|
||||||
systemctl enable -q --now matter-server
|
|
||||||
msg_ok "Created Service"
|
|
||||||
|
|
||||||
motd_ssh
|
|
||||||
customize
|
|
||||||
cleanup_lxc
|
|
||||||
@@ -22,7 +22,7 @@ msg_ok "Installed Dependencies"
|
|||||||
|
|
||||||
msg_info "Setting up Intel® Repositories"
|
msg_info "Setting up Intel® Repositories"
|
||||||
mkdir -p /usr/share/keyrings
|
mkdir -p /usr/share/keyrings
|
||||||
curl -fsSL https://repositories.intel.com/gpu/intel-graphics.key | gpg --dearmor -o /usr/share/keyrings/intel-graphics.gpg 2>/dev/null || true
|
curl -fsSL https://repositories.intel.com/gpu/intel-graphics.key | gpg --dearmor -o /usr/share/keyrings/intel-graphics.gpg
|
||||||
cat <<EOF >/etc/apt/sources.list.d/intel-gpu.sources
|
cat <<EOF >/etc/apt/sources.list.d/intel-gpu.sources
|
||||||
Types: deb
|
Types: deb
|
||||||
URIs: https://repositories.intel.com/gpu/ubuntu
|
URIs: https://repositories.intel.com/gpu/ubuntu
|
||||||
@@ -31,7 +31,7 @@ Components: client
|
|||||||
Architectures: amd64 i386
|
Architectures: amd64 i386
|
||||||
Signed-By: /usr/share/keyrings/intel-graphics.gpg
|
Signed-By: /usr/share/keyrings/intel-graphics.gpg
|
||||||
EOF
|
EOF
|
||||||
curl -fsSL https://apt.repos.intel.com/intel-gpg-keys/GPG-PUB-KEY-INTEL-SW-PRODUCTS.PUB | gpg --dearmor -o /usr/share/keyrings/oneapi-archive-keyring.gpg 2>/dev/null || true
|
curl -fsSL https://apt.repos.intel.com/intel-gpg-keys/GPG-PUB-KEY-INTEL-SW-PRODUCTS.PUB | gpg --dearmor -o /usr/share/keyrings/oneapi-archive-keyring.gpg
|
||||||
cat <<EOF >/etc/apt/sources.list.d/oneAPI.sources
|
cat <<EOF >/etc/apt/sources.list.d/oneAPI.sources
|
||||||
Types: deb
|
Types: deb
|
||||||
URIs: https://apt.repos.intel.com/oneapi
|
URIs: https://apt.repos.intel.com/oneapi
|
||||||
|
|||||||
@@ -19,7 +19,7 @@ fetch_and_deploy_gh_release "revealjs" "hakimel/reveal.js" "tarball"
|
|||||||
msg_info "Configuring ${APPLICATION}"
|
msg_info "Configuring ${APPLICATION}"
|
||||||
cd /opt/revealjs
|
cd /opt/revealjs
|
||||||
$STD npm install
|
$STD npm install
|
||||||
sed -i 's/"vite"/"vite --host"/g' package.json
|
sed -i '25s/localhost/0.0.0.0/g' /opt/revealjs/gulpfile.js
|
||||||
msg_ok "Setup ${APPLICATION}"
|
msg_ok "Setup ${APPLICATION}"
|
||||||
|
|
||||||
msg_info "Creating Service"
|
msg_info "Creating Service"
|
||||||
|
|||||||
@@ -47,7 +47,6 @@ $STD yarn install
|
|||||||
$STD yarn build
|
$STD yarn build
|
||||||
cat <<EOF >/opt/tandoor/.env
|
cat <<EOF >/opt/tandoor/.env
|
||||||
SECRET_KEY=$SECRET_KEY
|
SECRET_KEY=$SECRET_KEY
|
||||||
ALLOWED_HOSTS=$LOCAL_IP
|
|
||||||
TZ=Europe/Berlin
|
TZ=Europe/Berlin
|
||||||
|
|
||||||
DB_ENGINE=django.db.backends.postgresql
|
DB_ENGINE=django.db.backends.postgresql
|
||||||
|
|||||||
@@ -14,16 +14,16 @@ network_check
|
|||||||
update_os
|
update_os
|
||||||
|
|
||||||
msg_info "Getting latest version of VictoriaMetrics"
|
msg_info "Getting latest version of VictoriaMetrics"
|
||||||
|
victoriametrics_filename=$(curl -fsSL "https://api.github.com/repos/VictoriaMetrics/VictoriaMetrics/releases/latest" |
|
||||||
|
jq -r '.assets[].name' |
|
||||||
|
grep -E '^victoria-metrics-linux-amd64-v[0-9.]+\.tar\.gz$')
|
||||||
|
vmutils_filename=$(curl -fsSL "https://api.github.com/repos/VictoriaMetrics/VictoriaMetrics/releases/latest" |
|
||||||
|
jq -r '.assets[].name' |
|
||||||
|
grep -E '^vmutils-linux-amd64-v[0-9.]+\.tar\.gz$')
|
||||||
|
msg_ok "Got latest version of VictoriaMetrics"
|
||||||
|
|
||||||
victoriametrics_release=$(curl -fsSL "https://api.github.com/repos/VictoriaMetrics/VictoriaMetrics/releases" |
|
fetch_and_deploy_gh_release "victoriametrics" "VictoriaMetrics/VictoriaMetrics" "prebuild" "latest" "/opt/victoriametrics" "$victoriametrics_filename"
|
||||||
jq -r '.[] | select(.assets[].name | match("^victoria-metrics-linux-amd64-v[0-9.]+.tar.gz$")) | .tag_name' |
|
fetch_and_deploy_gh_release "vmutils" "VictoriaMetrics/VictoriaMetrics" "prebuild" "latest" "/opt/victoriametrics" "$vmutils_filename"
|
||||||
head -n 1)
|
|
||||||
victoriametrics_filename="victoria-metrics-linux-amd64-${victoriametrics_release}.tar.gz"
|
|
||||||
vmutils_filename="vmutils-linux-amd64-${victoriametrics_release}.tar.gz"
|
|
||||||
msg_ok "Got version $victoriametrics_release of VictoriaMetrics"
|
|
||||||
|
|
||||||
fetch_and_deploy_gh_release "victoriametrics" "VictoriaMetrics/VictoriaMetrics" "prebuild" "$victoriametrics_release" "/opt/victoriametrics" "$victoriametrics_filename"
|
|
||||||
fetch_and_deploy_gh_release "vmutils" "VictoriaMetrics/VictoriaMetrics" "prebuild" "$victoriametrics_release" "/opt/victoriametrics" "$vmutils_filename"
|
|
||||||
|
|
||||||
read -r -p "${TAB3}Would you like to add VictoriaLogs? <y/N> " prompt
|
read -r -p "${TAB3}Would you like to add VictoriaLogs? <y/N> " prompt
|
||||||
|
|
||||||
|
|||||||
@@ -1,91 +0,0 @@
|
|||||||
#!/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://yourls.org/
|
|
||||||
|
|
||||||
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 nginx
|
|
||||||
msg_ok "Installed Dependencies"
|
|
||||||
|
|
||||||
setup_mariadb
|
|
||||||
MARIADB_DB_NAME="yourls" MARIADB_DB_USER="yourls" setup_mariadb_db
|
|
||||||
PHP_VERSION="8.3" PHP_FPM="YES" PHP_MODULE="mysql,mbstring,gd,xml,curl" setup_php
|
|
||||||
|
|
||||||
fetch_and_deploy_gh_release "yourls" "YOURLS/YOURLS" "tarball"
|
|
||||||
|
|
||||||
msg_info "Configuring YOURLS"
|
|
||||||
COOKIEKEY=$(openssl rand -hex 24)
|
|
||||||
YOURLS_PASS=$(openssl rand -base64 12 | tr -dc 'a-zA-Z0-9' | cut -c1-16)
|
|
||||||
cat <<EOF >/opt/yourls/user/config.php
|
|
||||||
<?php
|
|
||||||
define( 'YOURLS_DB_USER', '${MARIADB_DB_USER}' );
|
|
||||||
define( 'YOURLS_DB_PASS', '${MARIADB_DB_PASS}' );
|
|
||||||
define( 'YOURLS_DB_NAME', '${MARIADB_DB_NAME}' );
|
|
||||||
define( 'YOURLS_DB_HOST', 'localhost' );
|
|
||||||
define( 'YOURLS_DB_PREFIX', 'yourls_' );
|
|
||||||
define( 'YOURLS_SITE', 'http://${LOCAL_IP}' );
|
|
||||||
define( 'YOURLS_LANG', '' );
|
|
||||||
define( 'YOURLS_UNIQUE_URLS', true );
|
|
||||||
define( 'YOURLS_PRIVATE', true );
|
|
||||||
define( 'YOURLS_COOKIEKEY', '${COOKIEKEY}' );
|
|
||||||
\$yourls_user_passwords = [
|
|
||||||
'admin' => '${YOURLS_PASS}',
|
|
||||||
];
|
|
||||||
define( 'YOURLS_URL_CONVERT', 36 );
|
|
||||||
define( 'YOURLS_DEBUG', false );
|
|
||||||
EOF
|
|
||||||
chown -R www-data:www-data /opt/yourls
|
|
||||||
msg_ok "Configured YOURLS"
|
|
||||||
|
|
||||||
msg_info "Configuring Nginx"
|
|
||||||
cat <<EOF >/etc/nginx/sites-available/yourls
|
|
||||||
server {
|
|
||||||
listen 80 default_server;
|
|
||||||
server_name _;
|
|
||||||
root /opt/yourls;
|
|
||||||
index index.php;
|
|
||||||
|
|
||||||
location / {
|
|
||||||
try_files \$uri \$uri/ /yourls-loader.php\$is_args\$args;
|
|
||||||
}
|
|
||||||
|
|
||||||
location ~ \.php\$ {
|
|
||||||
try_files \$uri =404;
|
|
||||||
fastcgi_split_path_info ^(.+\.php)(/.+)\$;
|
|
||||||
fastcgi_pass unix:/run/php/php8.3-fpm.sock;
|
|
||||||
fastcgi_index index.php;
|
|
||||||
include fastcgi_params;
|
|
||||||
fastcgi_param SCRIPT_FILENAME \$document_root\$fastcgi_script_name;
|
|
||||||
fastcgi_param PATH_INFO \$fastcgi_path_info;
|
|
||||||
}
|
|
||||||
|
|
||||||
location ~* \.(jpg|jpeg|gif|css|png|js|ico|woff|woff2)\$ {
|
|
||||||
access_log off;
|
|
||||||
expires max;
|
|
||||||
}
|
|
||||||
|
|
||||||
location ~ /\.ht {
|
|
||||||
deny all;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
EOF
|
|
||||||
ln -sf /etc/nginx/sites-available/yourls /etc/nginx/sites-enabled/yourls
|
|
||||||
rm -f /etc/nginx/sites-enabled/default
|
|
||||||
$STD nginx -t
|
|
||||||
systemctl enable -q --now nginx
|
|
||||||
systemctl reload nginx
|
|
||||||
msg_ok "Configured Nginx"
|
|
||||||
|
|
||||||
motd_ssh
|
|
||||||
customize
|
|
||||||
cleanup_lxc
|
|
||||||
@@ -135,34 +135,10 @@ network_check() {
|
|||||||
trap 'error_handler $LINENO "$BASH_COMMAND"' ERR
|
trap 'error_handler $LINENO "$BASH_COMMAND"' ERR
|
||||||
}
|
}
|
||||||
|
|
||||||
# This function updates the Container OS by running apk upgrade with mirror fallback
|
# This function updates the Container OS by running apt-get update and upgrade
|
||||||
update_os() {
|
update_os() {
|
||||||
msg_info "Updating Container OS"
|
msg_info "Updating Container OS"
|
||||||
if ! $STD apk -U upgrade; then
|
$STD apk -U upgrade
|
||||||
msg_warn "apk update failed (dl-cdn.alpinelinux.org), trying alternate mirrors..."
|
|
||||||
local alpine_mirrors="mirror.init7.net ftp.halifax.rwth-aachen.de mirrors.edge.kernel.org alpine.mirror.wearetriple.com mirror.leaseweb.com uk.alpinelinux.org dl-2.alpinelinux.org dl-4.alpinelinux.org"
|
|
||||||
local apk_ok=false
|
|
||||||
for m in $(printf '%s\n' $alpine_mirrors | shuf); do
|
|
||||||
if timeout 2 bash -c "echo >/dev/tcp/$m/80" 2>/dev/null; then
|
|
||||||
msg_custom "${INFO}" "${YW}" "Attempting mirror: ${m}"
|
|
||||||
cat <<EOF >/etc/apk/repositories
|
|
||||||
http://$m/alpine/latest-stable/main
|
|
||||||
http://$m/alpine/latest-stable/community
|
|
||||||
EOF
|
|
||||||
if $STD apk -U upgrade; then
|
|
||||||
msg_ok "CDN set to ${m}: tests passed"
|
|
||||||
apk_ok=true
|
|
||||||
break
|
|
||||||
else
|
|
||||||
msg_warn "Mirror ${m} failed"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
if [[ "$apk_ok" != true ]]; then
|
|
||||||
msg_error "All Alpine mirrors failed. Check network or try again later."
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
local tools_content
|
local tools_content
|
||||||
tools_content=$(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/tools.func) || {
|
tools_content=$(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/tools.func) || {
|
||||||
msg_error "Failed to download tools.func"
|
msg_error "Failed to download tools.func"
|
||||||
|
|||||||
163
misc/build.func
163
misc/build.func
@@ -3530,7 +3530,6 @@ build_container() {
|
|||||||
# Gateway
|
# Gateway
|
||||||
if [[ -n "$GATE" ]]; then
|
if [[ -n "$GATE" ]]; then
|
||||||
case "$GATE" in
|
case "$GATE" in
|
||||||
,gw=) ;;
|
|
||||||
,gw=*) NET_STRING+="$GATE" ;;
|
,gw=*) NET_STRING+="$GATE" ;;
|
||||||
*) NET_STRING+=",gw=$GATE" ;;
|
*) NET_STRING+=",gw=$GATE" ;;
|
||||||
esac
|
esac
|
||||||
@@ -4089,31 +4088,8 @@ https://dl-cdn.alpinelinux.org/alpine/latest-stable/main
|
|||||||
https://dl-cdn.alpinelinux.org/alpine/latest-stable/community
|
https://dl-cdn.alpinelinux.org/alpine/latest-stable/community
|
||||||
EOF'
|
EOF'
|
||||||
pct exec "$CTID" -- ash -c "apk add bash newt curl openssh nano mc ncurses jq" >>"$BUILD_LOG" 2>&1 || {
|
pct exec "$CTID" -- ash -c "apk add bash newt curl openssh nano mc ncurses jq" >>"$BUILD_LOG" 2>&1 || {
|
||||||
msg_warn "apk install failed (dl-cdn.alpinelinux.org), trying alternate mirrors..."
|
msg_error "Failed to install base packages in Alpine container"
|
||||||
local alpine_exit=0
|
install_exit_code=1
|
||||||
pct exec "$CTID" -- ash -c '
|
|
||||||
ALPINE_MIRRORS="mirror.init7.net ftp.halifax.rwth-aachen.de mirrors.edge.kernel.org alpine.mirror.wearetriple.com mirror.leaseweb.com uk.alpinelinux.org dl-2.alpinelinux.org dl-4.alpinelinux.org"
|
|
||||||
for m in $(printf "%s\n" $ALPINE_MIRRORS | shuf); do
|
|
||||||
if wget -q --spider --timeout=2 "http://$m/alpine/latest-stable/main/" 2>/dev/null; then
|
|
||||||
echo " Attempting mirror: $m"
|
|
||||||
cat <<EOF >/etc/apk/repositories
|
|
||||||
http://$m/alpine/latest-stable/main
|
|
||||||
http://$m/alpine/latest-stable/community
|
|
||||||
EOF
|
|
||||||
if apk update >/dev/null 2>&1 && apk add bash newt curl openssh nano mc ncurses jq >/dev/null 2>&1; then
|
|
||||||
echo " CDN set to $m: tests passed"
|
|
||||||
exit 0
|
|
||||||
else
|
|
||||||
echo " Mirror $m failed"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
exit 2
|
|
||||||
' && alpine_exit=0 || alpine_exit=$?
|
|
||||||
if [[ $alpine_exit -ne 0 ]]; then
|
|
||||||
msg_error "Failed to install base packages in Alpine container"
|
|
||||||
install_exit_code=1
|
|
||||||
fi
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
sleep 3
|
sleep 3
|
||||||
@@ -4139,140 +4115,9 @@ EOF
|
|||||||
msg_warn "Skipping timezone setup – zone '$tz' not found in container"
|
msg_warn "Skipping timezone setup – zone '$tz' not found in container"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Detect broken DNS resolver (e.g. Tailscale MagicDNS) and inject public DNS
|
|
||||||
if ! pct exec "$CTID" -- bash -c "getent hosts deb.debian.org >/dev/null 2>&1 && getent hosts archive.ubuntu.com >/dev/null 2>&1"; then
|
|
||||||
msg_warn "APT repository DNS resolution failed in container, injecting public DNS servers"
|
|
||||||
pct exec "$CTID" -- bash -c "echo -e 'nameserver 8.8.8.8\nnameserver 1.1.1.1' >/etc/resolv.conf"
|
|
||||||
fi
|
|
||||||
|
|
||||||
pct exec "$CTID" -- bash -c "apt-get update 2>&1 && apt-get install -y sudo curl mc gnupg2 jq 2>&1" >>"$BUILD_LOG" 2>&1 || {
|
pct exec "$CTID" -- bash -c "apt-get update 2>&1 && apt-get install -y sudo curl mc gnupg2 jq 2>&1" >>"$BUILD_LOG" 2>&1 || {
|
||||||
local failed_mirror
|
msg_error "apt-get base packages installation failed"
|
||||||
failed_mirror=$(pct exec "$CTID" -- bash -c "grep -m1 -oP '(?<=URIs: https?://)[^/]+' /etc/apt/sources.list.d/debian.sources 2>/dev/null || grep -m1 -oP '(?<=deb https?://)[^/]+' /etc/apt/sources.list 2>/dev/null" 2>/dev/null || echo "unknown")
|
install_exit_code=1
|
||||||
msg_warn "apt-get update failed (${failed_mirror}), trying alternate mirrors..."
|
|
||||||
local mirror_exit=0
|
|
||||||
pct exec "$CTID" -- bash -c '
|
|
||||||
APT_BASE="sudo curl mc gnupg2 jq"
|
|
||||||
DISTRO=$(. /etc/os-release 2>/dev/null && echo "$ID" || echo "debian")
|
|
||||||
|
|
||||||
if [ "$DISTRO" = "ubuntu" ]; then
|
|
||||||
EU_MIRRORS="de.archive.ubuntu.com fr.archive.ubuntu.com se.archive.ubuntu.com nl.archive.ubuntu.com it.archive.ubuntu.com ch.archive.ubuntu.com mirrors.xtom.de"
|
|
||||||
US_MIRRORS="us.archive.ubuntu.com archive.ubuntu.com mirrors.edge.kernel.org mirror.csclub.uwaterloo.ca mirrors.ocf.berkeley.edu mirror.math.princeton.edu"
|
|
||||||
AP_MIRRORS="au.archive.ubuntu.com jp.archive.ubuntu.com kr.archive.ubuntu.com tw.archive.ubuntu.com mirror.aarnet.edu.au"
|
|
||||||
else
|
|
||||||
EU_MIRRORS="ftp.de.debian.org ftp.fr.debian.org ftp.nl.debian.org ftp.uk.debian.org ftp.ch.debian.org ftp.se.debian.org ftp.it.debian.org ftp.fau.de ftp.halifax.rwth-aachen.de debian.mirror.lrz.de mirror.init7.net debian.ethz.ch mirrors.dotsrc.org debian.mirrors.ovh.net"
|
|
||||||
US_MIRRORS="ftp.us.debian.org ftp.ca.debian.org debian.csail.mit.edu mirrors.ocf.berkeley.edu mirrors.wikimedia.org debian.osuosl.org mirror.cogentco.com"
|
|
||||||
AP_MIRRORS="ftp.au.debian.org ftp.jp.debian.org ftp.tw.debian.org ftp.kr.debian.org ftp.hk.debian.org ftp.sg.debian.org mirror.aarnet.edu.au mirror.nitc.ac.in"
|
|
||||||
fi
|
|
||||||
|
|
||||||
TZ=$(cat /etc/timezone 2>/dev/null || echo "UTC")
|
|
||||||
case "$TZ" in
|
|
||||||
Europe/*|Arctic/*) REGIONAL="$EU_MIRRORS"; OTHERS="$US_MIRRORS $AP_MIRRORS" ;;
|
|
||||||
America/*) REGIONAL="$US_MIRRORS"; OTHERS="$EU_MIRRORS $AP_MIRRORS" ;;
|
|
||||||
Asia/*|Australia/*|Pacific/*) REGIONAL="$AP_MIRRORS"; OTHERS="$EU_MIRRORS $US_MIRRORS" ;;
|
|
||||||
*) REGIONAL=""; OTHERS="$EU_MIRRORS $US_MIRRORS $AP_MIRRORS" ;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
echo "Acquire::By-Hash \"no\";" >/etc/apt/apt.conf.d/99no-by-hash
|
|
||||||
|
|
||||||
try_mirrors() {
|
|
||||||
for src in /etc/apt/sources.list.d/debian.sources /etc/apt/sources.list; do
|
|
||||||
[ -f "$src" ] && sed -i "s|URIs: http[s]*://[^/]*/|URIs: http://${1}/|g; s|deb http[s]*://[^/]*/|deb http://${1}/|g" "$src"
|
|
||||||
done
|
|
||||||
rm -rf /var/lib/apt/lists/*
|
|
||||||
APT_OUT=$(apt-get update 2>&1)
|
|
||||||
APT_RC=$?
|
|
||||||
if echo "$APT_OUT" | grep -qi "hashsum\|hash sum"; then
|
|
||||||
echo " Mirror $1 failed (hash mismatch)"
|
|
||||||
return 1
|
|
||||||
elif echo "$APT_OUT" | grep -qi "SSL\|certificate"; then
|
|
||||||
echo " Mirror $1 failed (SSL/certificate error)"
|
|
||||||
return 1
|
|
||||||
elif [ $APT_RC -ne 0 ]; then
|
|
||||||
echo " Mirror $1 failed (apt-get update error)"
|
|
||||||
return 1
|
|
||||||
elif apt-get install -y $APT_BASE >/dev/null 2>&1; then
|
|
||||||
echo " CDN set to $1: tests passed"
|
|
||||||
return 0
|
|
||||||
else
|
|
||||||
echo " Mirror $1 failed (package install error)"
|
|
||||||
return 1
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
scan_reachable() {
|
|
||||||
local result=""
|
|
||||||
for m in $1; do
|
|
||||||
if timeout 2 bash -c "echo >/dev/tcp/$m/80" 2>/dev/null; then
|
|
||||||
result="$result $m"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
echo "$result" | xargs
|
|
||||||
}
|
|
||||||
|
|
||||||
# Phase 1: Scan global mirrors first (independent of local CDN issues)
|
|
||||||
OTHERS_OK=$(scan_reachable "$OTHERS")
|
|
||||||
OTHERS_PICK=$(printf "%s\n" $OTHERS_OK | shuf | head -3 | xargs)
|
|
||||||
|
|
||||||
for mirror in $OTHERS_PICK; do
|
|
||||||
echo " Attempting mirror: $mirror"
|
|
||||||
try_mirrors "$mirror" && exit 0
|
|
||||||
done
|
|
||||||
|
|
||||||
# Phase 2: Try primary mirror
|
|
||||||
if [ "$DISTRO" = "ubuntu" ]; then
|
|
||||||
PRIMARY="archive.ubuntu.com"
|
|
||||||
else
|
|
||||||
PRIMARY="ftp.debian.org"
|
|
||||||
fi
|
|
||||||
if timeout 2 bash -c "echo >/dev/tcp/$PRIMARY/80" 2>/dev/null; then
|
|
||||||
echo " Attempting mirror: $PRIMARY"
|
|
||||||
try_mirrors "$PRIMARY" && exit 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Phase 3: Fall back to regional mirrors
|
|
||||||
REGIONAL_OK=$(scan_reachable "$REGIONAL")
|
|
||||||
REGIONAL_PICK=$(printf "%s\n" $REGIONAL_OK | shuf | head -3 | xargs)
|
|
||||||
|
|
||||||
for mirror in $REGIONAL_PICK; do
|
|
||||||
echo " Attempting mirror: $mirror"
|
|
||||||
try_mirrors "$mirror" && exit 0
|
|
||||||
done
|
|
||||||
|
|
||||||
exit 2
|
|
||||||
' && mirror_exit=0 || mirror_exit=$?
|
|
||||||
if [[ $mirror_exit -eq 2 ]]; then
|
|
||||||
msg_warn "Multiple mirrors failed (possible CDN synchronization issue)."
|
|
||||||
if [[ "$var_os" == "ubuntu" ]]; then
|
|
||||||
msg_warn "Find Ubuntu mirrors at: https://launchpad.net/ubuntu/+archivemirrors"
|
|
||||||
else
|
|
||||||
msg_warn "Find Debian mirrors at: https://www.debian.org/mirror/list"
|
|
||||||
fi
|
|
||||||
local custom_mirror=""
|
|
||||||
while true; do
|
|
||||||
read -rp " Enter a mirror hostname (or 'skip' to abort): " custom_mirror </dev/tty
|
|
||||||
[[ -z "$custom_mirror" ]] && continue
|
|
||||||
[[ "$custom_mirror" == "skip" ]] && break
|
|
||||||
[[ ! "$custom_mirror" =~ ^[a-zA-Z0-9._-]+$ ]] && {
|
|
||||||
msg_warn "Invalid hostname format."
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
pct exec "$CTID" -- bash -c "
|
|
||||||
for src in /etc/apt/sources.list.d/debian.sources /etc/apt/sources.list; do
|
|
||||||
[ -f \"\$src\" ] && sed -i \"s|URIs: http[s]*://[^/]*/|URIs: http://${custom_mirror}/|g; s|deb http[s]*://[^/]*/|deb http://${custom_mirror}/|g\" \"\$src\"
|
|
||||||
done
|
|
||||||
rm -rf /var/lib/apt/lists/*
|
|
||||||
apt-get update >/dev/null 2>&1 && apt-get install -y sudo curl mc gnupg2 jq >/dev/null 2>&1
|
|
||||||
" && break
|
|
||||||
msg_warn "Mirror '${custom_mirror}' also failed. Try another or type 'skip'."
|
|
||||||
done
|
|
||||||
if [[ "$custom_mirror" == "skip" ]]; then
|
|
||||||
msg_error "apt-get base packages installation failed"
|
|
||||||
install_exit_code=1
|
|
||||||
fi
|
|
||||||
elif [[ $mirror_exit -ne 0 ]]; then
|
|
||||||
msg_error "apt-get base packages installation failed"
|
|
||||||
install_exit_code=1
|
|
||||||
fi
|
|
||||||
}
|
}
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|||||||
@@ -210,173 +210,6 @@ network_check() {
|
|||||||
# SECTION 3: OS UPDATE & PACKAGE MANAGEMENT
|
# SECTION 3: OS UPDATE & PACKAGE MANAGEMENT
|
||||||
# ==============================================================================
|
# ==============================================================================
|
||||||
|
|
||||||
# ------------------------------------------------------------------------------
|
|
||||||
# apt_update_safe()
|
|
||||||
#
|
|
||||||
# - Runs apt-get update with CDN mirror fallback
|
|
||||||
# - On failure, detects distro (Debian/Ubuntu) and tries alternate mirrors
|
|
||||||
# - Three-phase approach: global mirrors → primary mirror → regional mirrors
|
|
||||||
# - Falls back to manual user prompt if all auto mirrors fail
|
|
||||||
# - Detects hash mismatch, SSL errors, and generic apt failures
|
|
||||||
# ------------------------------------------------------------------------------
|
|
||||||
apt_update_safe() {
|
|
||||||
if $STD apt-get update; then
|
|
||||||
return 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
local failed_mirror
|
|
||||||
failed_mirror=$(grep -m1 -oP '(?<=URIs: https?://)[^/]+' /etc/apt/sources.list.d/debian.sources 2>/dev/null || grep -m1 -oP '(?<=deb https?://)[^/]+' /etc/apt/sources.list 2>/dev/null || echo "unknown")
|
|
||||||
msg_warn "apt-get update failed (${failed_mirror}), trying alternate mirrors..."
|
|
||||||
|
|
||||||
local distro
|
|
||||||
distro=$(. /etc/os-release 2>/dev/null && echo "$ID" || echo "debian")
|
|
||||||
|
|
||||||
local eu_mirrors us_mirrors ap_mirrors
|
|
||||||
if [[ "$distro" == "ubuntu" ]]; then
|
|
||||||
eu_mirrors="de.archive.ubuntu.com fr.archive.ubuntu.com se.archive.ubuntu.com nl.archive.ubuntu.com it.archive.ubuntu.com ch.archive.ubuntu.com mirrors.xtom.de"
|
|
||||||
us_mirrors="us.archive.ubuntu.com archive.ubuntu.com mirrors.edge.kernel.org mirror.csclub.uwaterloo.ca mirrors.ocf.berkeley.edu mirror.math.princeton.edu"
|
|
||||||
ap_mirrors="au.archive.ubuntu.com jp.archive.ubuntu.com kr.archive.ubuntu.com tw.archive.ubuntu.com mirror.aarnet.edu.au"
|
|
||||||
else
|
|
||||||
eu_mirrors="ftp.de.debian.org ftp.fr.debian.org ftp.nl.debian.org ftp.uk.debian.org ftp.ch.debian.org ftp.se.debian.org ftp.it.debian.org ftp.fau.de ftp.halifax.rwth-aachen.de debian.mirror.lrz.de mirror.init7.net debian.ethz.ch mirrors.dotsrc.org debian.mirrors.ovh.net"
|
|
||||||
us_mirrors="ftp.us.debian.org ftp.ca.debian.org debian.csail.mit.edu mirrors.ocf.berkeley.edu mirrors.wikimedia.org debian.osuosl.org mirror.cogentco.com"
|
|
||||||
ap_mirrors="ftp.au.debian.org ftp.jp.debian.org ftp.tw.debian.org ftp.kr.debian.org ftp.hk.debian.org ftp.sg.debian.org mirror.aarnet.edu.au mirror.nitc.ac.in"
|
|
||||||
fi
|
|
||||||
|
|
||||||
local tz regional others
|
|
||||||
tz=$(cat /etc/timezone 2>/dev/null || echo "UTC")
|
|
||||||
case "$tz" in
|
|
||||||
Europe/* | Arctic/*)
|
|
||||||
regional="$eu_mirrors"
|
|
||||||
others="$us_mirrors $ap_mirrors"
|
|
||||||
;;
|
|
||||||
America/*)
|
|
||||||
regional="$us_mirrors"
|
|
||||||
others="$eu_mirrors $ap_mirrors"
|
|
||||||
;;
|
|
||||||
Asia/* | Australia/* | Pacific/*)
|
|
||||||
regional="$ap_mirrors"
|
|
||||||
others="$eu_mirrors $us_mirrors"
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
regional=""
|
|
||||||
others="$eu_mirrors $us_mirrors $ap_mirrors"
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
echo 'Acquire::By-Hash "no";' >/etc/apt/apt.conf.d/99no-by-hash
|
|
||||||
|
|
||||||
_try_apt_mirror() {
|
|
||||||
local m=$1
|
|
||||||
for src in /etc/apt/sources.list.d/debian.sources /etc/apt/sources.list; do
|
|
||||||
[[ -f "$src" ]] && sed -i "s|URIs: http[s]*://[^/]*/|URIs: http://${m}/|g; s|deb http[s]*://[^/]*/|deb http://${m}/|g" "$src"
|
|
||||||
done
|
|
||||||
rm -rf /var/lib/apt/lists/*
|
|
||||||
local out
|
|
||||||
out=$(apt-get update 2>&1)
|
|
||||||
if echo "$out" | grep -qi "hashsum\|hash sum"; then
|
|
||||||
msg_warn "Mirror ${m} failed (hash mismatch)"
|
|
||||||
return 1
|
|
||||||
elif echo "$out" | grep -qi "SSL\|certificate"; then
|
|
||||||
msg_warn "Mirror ${m} failed (SSL/certificate error)"
|
|
||||||
return 1
|
|
||||||
elif echo "$out" | grep -q "^E:"; then
|
|
||||||
msg_warn "Mirror ${m} failed (apt-get update error)"
|
|
||||||
return 1
|
|
||||||
else
|
|
||||||
msg_ok "CDN set to ${m}: tests passed"
|
|
||||||
return 0
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
_scan_reachable() {
|
|
||||||
local result=""
|
|
||||||
for m in $1; do
|
|
||||||
if timeout 2 bash -c "echo >/dev/tcp/$m/80" 2>/dev/null; then
|
|
||||||
result="$result $m"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
echo "$result" | xargs
|
|
||||||
}
|
|
||||||
|
|
||||||
local apt_ok=false
|
|
||||||
|
|
||||||
# Phase 1: Scan global mirrors first (independent of local CDN issues)
|
|
||||||
local others_ok
|
|
||||||
others_ok=$(_scan_reachable "$others")
|
|
||||||
local others_pick
|
|
||||||
others_pick=$(printf '%s\n' $others_ok | shuf | head -3 | xargs)
|
|
||||||
|
|
||||||
for mirror in $others_pick; do
|
|
||||||
msg_custom "${INFO}" "${YW}" "Attempting mirror: ${mirror}"
|
|
||||||
if _try_apt_mirror "$mirror"; then
|
|
||||||
apt_ok=true
|
|
||||||
break
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
# Phase 2: Try primary mirror
|
|
||||||
if [[ "$apt_ok" != true ]]; then
|
|
||||||
local primary
|
|
||||||
if [[ "$distro" == "ubuntu" ]]; then
|
|
||||||
primary="archive.ubuntu.com"
|
|
||||||
else
|
|
||||||
primary="ftp.debian.org"
|
|
||||||
fi
|
|
||||||
if timeout 2 bash -c "echo >/dev/tcp/$primary/80" 2>/dev/null; then
|
|
||||||
msg_custom "${INFO}" "${YW}" "Attempting mirror: ${primary}"
|
|
||||||
if _try_apt_mirror "$primary"; then
|
|
||||||
apt_ok=true
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Phase 3: Fall back to regional mirrors
|
|
||||||
if [[ "$apt_ok" != true ]]; then
|
|
||||||
local regional_ok
|
|
||||||
regional_ok=$(_scan_reachable "$regional")
|
|
||||||
local regional_pick
|
|
||||||
regional_pick=$(printf '%s\n' $regional_ok | shuf | head -3 | xargs)
|
|
||||||
|
|
||||||
for mirror in $regional_pick; do
|
|
||||||
msg_custom "${INFO}" "${YW}" "Attempting mirror: ${mirror}"
|
|
||||||
if _try_apt_mirror "$mirror"; then
|
|
||||||
apt_ok=true
|
|
||||||
break
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Phase 4: All auto mirrors failed, prompt user
|
|
||||||
if [[ "$apt_ok" != true ]]; then
|
|
||||||
msg_warn "Multiple mirrors failed (possible CDN synchronization issue)."
|
|
||||||
if [[ "$distro" == "ubuntu" ]]; then
|
|
||||||
msg_warn "Find Ubuntu mirrors at: https://launchpad.net/ubuntu/+archivemirrors"
|
|
||||||
else
|
|
||||||
msg_warn "Find Debian mirrors at: https://www.debian.org/mirror/list"
|
|
||||||
fi
|
|
||||||
local custom_mirror
|
|
||||||
while true; do
|
|
||||||
read -rp " Enter a mirror hostname (or 'skip' to abort): " custom_mirror </dev/tty
|
|
||||||
[[ -z "$custom_mirror" ]] && continue
|
|
||||||
[[ "$custom_mirror" == "skip" ]] && break
|
|
||||||
[[ ! "$custom_mirror" =~ ^[a-zA-Z0-9._-]+$ ]] && {
|
|
||||||
msg_warn "Invalid hostname format."
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
if _try_apt_mirror "$custom_mirror"; then
|
|
||||||
apt_ok=true
|
|
||||||
break
|
|
||||||
fi
|
|
||||||
msg_warn "Mirror '${custom_mirror}' also failed. Try another or type 'skip'."
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ "$apt_ok" != true ]]; then
|
|
||||||
msg_error "All mirrors failed. Check network or try again later."
|
|
||||||
return 1
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# ------------------------------------------------------------------------------
|
# ------------------------------------------------------------------------------
|
||||||
# update_os()
|
# update_os()
|
||||||
#
|
#
|
||||||
|
|||||||
@@ -131,10 +131,9 @@ if [[ "${install_prompt,,}" =~ ^(y|yes)$ ]]; then
|
|||||||
cd /usr/local/community-scripts
|
cd /usr/local/community-scripts
|
||||||
filebrowser config init -a '0.0.0.0' -p "$PORT" -d "$DB_PATH" &>/dev/null
|
filebrowser config init -a '0.0.0.0' -p "$PORT" -d "$DB_PATH" &>/dev/null
|
||||||
filebrowser config set -a '0.0.0.0' -p "$PORT" -d "$DB_PATH" &>/dev/null
|
filebrowser config set -a '0.0.0.0' -p "$PORT" -d "$DB_PATH" &>/dev/null
|
||||||
filebrowser config set --auth.method=noauth --database "$DB_PATH" &>/dev/null
|
filebrowser config init --auth.method=noauth &>/dev/null
|
||||||
if ! filebrowser users update 1 --perm.admin --database "$DB_PATH" &>/dev/null; then
|
filebrowser config set --auth.method=noauth &>/dev/null
|
||||||
filebrowser users add admin community-scripts.org --perm.admin --database "$DB_PATH" &>/dev/null
|
filebrowser users add ID 1 --perm.admin &>/dev/null
|
||||||
fi
|
|
||||||
msg_ok "No Authentication configured"
|
msg_ok "No Authentication configured"
|
||||||
else
|
else
|
||||||
msg_info "Setting up default authentication"
|
msg_info "Setting up default authentication"
|
||||||
|
|||||||
@@ -24,7 +24,7 @@ load_functions
|
|||||||
# ==============================================================================
|
# ==============================================================================
|
||||||
# CONFIGURATION
|
# CONFIGURATION
|
||||||
# ==============================================================================
|
# ==============================================================================
|
||||||
APP="SparkyFitness-Garmin"
|
APP="SparkyFitness Garmin Microservice"
|
||||||
APP_TYPE="addon"
|
APP_TYPE="addon"
|
||||||
INSTALL_PATH="/opt/sparkyfitness-garmin"
|
INSTALL_PATH="/opt/sparkyfitness-garmin"
|
||||||
CONFIG_PATH="/etc/sparkyfitness-garmin/.env"
|
CONFIG_PATH="/etc/sparkyfitness-garmin/.env"
|
||||||
|
|||||||
@@ -1,6 +0,0 @@
|
|||||||
_____ __ _______ __ ______ _
|
|
||||||
/ ___/____ ____ ______/ /____ __/ ____(_) /_____ ___ __________ / ____/___ __________ ___ (_)___
|
|
||||||
\__ \/ __ \/ __ `/ ___/ //_/ / / / /_ / / __/ __ \/ _ \/ ___/ ___/_____/ / __/ __ `/ ___/ __ `__ \/ / __ \
|
|
||||||
___/ / /_/ / /_/ / / / ,< / /_/ / __/ / / /_/ / / / __(__ |__ )_____/ /_/ / /_/ / / / / / / / / / / / /
|
|
||||||
/____/ .___/\__,_/_/ /_/|_|\__, /_/ /_/\__/_/ /_/\___/____/____/ \____/\__,_/_/ /_/ /_/ /_/_/_/ /_/
|
|
||||||
/_/ /____/
|
|
||||||
6
tools/headers/sparkyfitnessgarmin
Normal file
6
tools/headers/sparkyfitnessgarmin
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
_____ __ _______ __ ______ _ __ ____ _
|
||||||
|
/ ___/____ ____ ______/ /____ __/ ____(_) /_____ ___ __________ / ____/___ __________ ___ (_)___ / |/ (_)_____________ ________ ______ __(_)_______
|
||||||
|
\__ \/ __ \/ __ `/ ___/ //_/ / / / /_ / / __/ __ \/ _ \/ ___/ ___/ / / __/ __ `/ ___/ __ `__ \/ / __ \ / /|_/ / / ___/ ___/ __ \/ ___/ _ \/ ___/ | / / / ___/ _ \
|
||||||
|
___/ / /_/ / /_/ / / / ,< / /_/ / __/ / / /_/ / / / __(__ |__ ) / /_/ / /_/ / / / / / / / / / / / / / / / / / /__/ / / /_/ (__ ) __/ / | |/ / / /__/ __/
|
||||||
|
/____/ .___/\__,_/_/ /_/|_|\__, /_/ /_/\__/_/ /_/\___/____/____/ \____/\__,_/_/ /_/ /_/ /_/_/_/ /_/ /_/ /_/_/\___/_/ \____/____/\___/_/ |___/_/\___/\___/
|
||||||
|
/_/ /____/
|
||||||
@@ -1,24 +1,11 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
# Copyright (c) 2021-2026 community-scripts ORG
|
# Copyright (c) 2021-2026 tteck
|
||||||
# Author: MickLesk (CanbiZ)
|
# Author: tteck (tteckster)
|
||||||
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
|
# License: MIT
|
||||||
#
|
# https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
|
||||||
# This script manages a local cron job for automatic LXC container OS updates.
|
|
||||||
# The update script is downloaded once, displayed for review, and installed
|
|
||||||
# locally. Cron runs the local copy — no remote code execution at runtime.
|
|
||||||
#
|
|
||||||
# bash -c "$(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/tools/pve/cron-update-lxcs.sh)"
|
# bash -c "$(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/tools/pve/cron-update-lxcs.sh)"
|
||||||
|
|
||||||
set -euo pipefail
|
|
||||||
|
|
||||||
REPO_URL="https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main"
|
|
||||||
SCRIPT_URL="${REPO_URL}/tools/pve/update-lxcs-cron.sh"
|
|
||||||
LOCAL_SCRIPT="/usr/local/bin/update-lxcs.sh"
|
|
||||||
CONF_FILE="/etc/update-lxcs.conf"
|
|
||||||
LOG_FILE="/var/log/update-lxcs-cron.log"
|
|
||||||
CRON_ENTRY="0 0 * * 0 ${LOCAL_SCRIPT} >>${LOG_FILE} 2>&1"
|
|
||||||
|
|
||||||
clear
|
clear
|
||||||
cat <<"EOF"
|
cat <<"EOF"
|
||||||
______ __ __ __ __ __ _ ________
|
______ __ __ __ __ __ _ ________
|
||||||
@@ -29,322 +16,41 @@ cat <<"EOF"
|
|||||||
/_/
|
/_/
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
info() { echo -e "\n \e[36m[Info]\e[0m $1"; }
|
add() {
|
||||||
ok() { echo -e " \e[32m[OK]\e[0m $1"; }
|
|
||||||
err() { echo -e " \e[31m[Error]\e[0m $1" >&2; }
|
|
||||||
|
|
||||||
confirm() {
|
|
||||||
local prompt="${1:-Proceed?}"
|
|
||||||
while true; do
|
while true; do
|
||||||
read -rp " ${prompt} (y/n): " yn
|
read -p "This script will add a crontab schedule that updates all LXCs every Sunday at midnight. Proceed(y/n)?" yn
|
||||||
case $yn in
|
case $yn in
|
||||||
[Yy]*) return 0 ;;
|
[Yy]*) break ;;
|
||||||
[Nn]*) return 1 ;;
|
[Nn]*) exit ;;
|
||||||
*) echo " Please answer yes or no." ;;
|
*) echo "Please answer yes or no." ;;
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
}
|
sh -c '(crontab -l -u root 2>/dev/null; echo "0 0 * * 0 PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin /bin/bash -c \"\$(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/tools/pve/update-lxcs-cron.sh)\" >>/var/log/update-lxcs-cron.log 2>/dev/null") | crontab -u root -'
|
||||||
|
clear
|
||||||
download_script() {
|
echo -e "\n To view Cron Update LXCs logs: cat /var/log/update-lxcs-cron.log"
|
||||||
local tmp
|
|
||||||
tmp=$(mktemp)
|
|
||||||
if ! curl -fsSL -o "$tmp" "$SCRIPT_URL"; then
|
|
||||||
err "Failed to download script from:\n ${SCRIPT_URL}"
|
|
||||||
rm -f "$tmp"
|
|
||||||
return 1
|
|
||||||
fi
|
|
||||||
echo "$tmp"
|
|
||||||
}
|
|
||||||
|
|
||||||
review_script() {
|
|
||||||
local file="$1"
|
|
||||||
local hash
|
|
||||||
hash=$(sha256sum "$file" | awk '{print $1}')
|
|
||||||
echo ""
|
|
||||||
echo -e " \e[1;33m─── Script Content ───────────────────────────────────────────\e[0m"
|
|
||||||
cat "$file"
|
|
||||||
echo -e " \e[1;33m──────────────────────────────────────────────────────────────\e[0m"
|
|
||||||
echo -e " \e[36mSHA256:\e[0m ${hash}"
|
|
||||||
echo -e " \e[36mSource:\e[0m ${SCRIPT_URL}"
|
|
||||||
echo ""
|
|
||||||
}
|
|
||||||
|
|
||||||
remove_legacy_cron() {
|
|
||||||
if crontab -l -u root 2>/dev/null | grep -q "update-lxcs-cron.sh"; then
|
|
||||||
(crontab -l -u root 2>/dev/null | grep -v "update-lxcs-cron.sh") | crontab -u root -
|
|
||||||
ok "Removed legacy curl-based cron entry"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
add() {
|
|
||||||
info "Downloading update script..."
|
|
||||||
local tmp
|
|
||||||
tmp=$(download_script) || exit 1
|
|
||||||
|
|
||||||
local hash
|
|
||||||
hash=$(sha256sum "$tmp" | awk '{print $1}')
|
|
||||||
echo ""
|
|
||||||
echo -e " \e[1;33m─── Installation Summary ─────────────────────────────────────\e[0m"
|
|
||||||
echo -e " \e[36mSource:\e[0m ${SCRIPT_URL}"
|
|
||||||
echo -e " \e[36mSHA256:\e[0m ${hash}"
|
|
||||||
echo -e " \e[36mInstall to:\e[0m ${LOCAL_SCRIPT}"
|
|
||||||
echo -e " \e[36mConfig:\e[0m ${CONF_FILE}"
|
|
||||||
echo -e " \e[36mLog file:\e[0m ${LOG_FILE}"
|
|
||||||
echo -e " \e[36mCron schedule:\e[0m Every Sunday at midnight (0 0 * * 0)"
|
|
||||||
echo -e " \e[1;33m──────────────────────────────────────────────────────────────\e[0m"
|
|
||||||
echo ""
|
|
||||||
|
|
||||||
if confirm "Review script content before installing?"; then
|
|
||||||
review_script "$tmp"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! confirm "Install this script and activate cron schedule?"; then
|
|
||||||
rm -f "$tmp"
|
|
||||||
echo " Aborted."
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
remove_legacy_cron
|
|
||||||
|
|
||||||
install -m 0755 "$tmp" "$LOCAL_SCRIPT"
|
|
||||||
rm -f "$tmp"
|
|
||||||
ok "Installed script to ${LOCAL_SCRIPT}"
|
|
||||||
|
|
||||||
if [[ ! -f "$CONF_FILE" ]]; then
|
|
||||||
cat >"$CONF_FILE" <<'CONF'
|
|
||||||
# Configuration for automatic LXC container OS updates.
|
|
||||||
# Add container IDs to exclude from updates (comma-separated):
|
|
||||||
# EXCLUDE=100,101,102
|
|
||||||
EXCLUDE=
|
|
||||||
CONF
|
|
||||||
ok "Created config ${CONF_FILE}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
(
|
|
||||||
crontab -l -u root 2>/dev/null | grep -v "${LOCAL_SCRIPT}" || true
|
|
||||||
echo "${CRON_ENTRY}"
|
|
||||||
) | crontab -u root -
|
|
||||||
ok "Added cron schedule: Every Sunday at midnight"
|
|
||||||
echo ""
|
|
||||||
echo -e " \e[36mLocal script:\e[0m ${LOCAL_SCRIPT}"
|
|
||||||
echo -e " \e[36mConfig:\e[0m ${CONF_FILE}"
|
|
||||||
echo -e " \e[36mLog file:\e[0m ${LOG_FILE}"
|
|
||||||
echo ""
|
|
||||||
}
|
}
|
||||||
|
|
||||||
remove() {
|
remove() {
|
||||||
if crontab -l -u root 2>/dev/null | grep -q "${LOCAL_SCRIPT}"; then
|
(crontab -l | grep -v "update-lxcs-cron.sh") | crontab -
|
||||||
(crontab -l -u root 2>/dev/null | grep -v "${LOCAL_SCRIPT}") | crontab -u root -
|
rm -rf /var/log/update-lxcs-cron.log
|
||||||
ok "Removed cron schedule"
|
echo "Removed Crontab Schedule from Proxmox VE"
|
||||||
fi
|
|
||||||
remove_legacy_cron
|
|
||||||
[[ -f "$LOCAL_SCRIPT" ]] && rm -f "$LOCAL_SCRIPT" && ok "Removed ${LOCAL_SCRIPT}"
|
|
||||||
[[ -f "$LOG_FILE" ]] && rm -f "$LOG_FILE" && ok "Removed ${LOG_FILE}"
|
|
||||||
echo -e "\n Cron Update LXCs has been fully removed."
|
|
||||||
echo -e " \e[90mNote: ${CONF_FILE} was kept (remove manually if desired).\e[0m"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
update_script() {
|
OPTIONS=(Add "Add Crontab Schedule"
|
||||||
if [[ ! -f "$LOCAL_SCRIPT" ]]; then
|
Remove "Remove Crontab Schedule")
|
||||||
err "No local script found at ${LOCAL_SCRIPT}. Use 'Add' first."
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
info "Downloading latest version..."
|
CHOICE=$(whiptail --backtitle "Proxmox VE Helper Scripts" --title "Cron Update LXCs" --menu "Select an option:" 10 58 2 \
|
||||||
local tmp
|
"${OPTIONS[@]}" 3>&1 1>&2 2>&3)
|
||||||
tmp=$(download_script) || exit 1
|
|
||||||
|
|
||||||
if command -v diff &>/dev/null; then
|
|
||||||
local changes
|
|
||||||
changes=$(diff --color=auto "$LOCAL_SCRIPT" "$tmp" 2>/dev/null || true)
|
|
||||||
if [[ -z "$changes" ]]; then
|
|
||||||
ok "Script is already up-to-date (no changes)."
|
|
||||||
rm -f "$tmp"
|
|
||||||
return
|
|
||||||
fi
|
|
||||||
echo ""
|
|
||||||
echo -e " \e[1;33m─── Changes ──────────────────────────────────────────────────\e[0m"
|
|
||||||
echo "$changes"
|
|
||||||
echo -e " \e[1;33m──────────────────────────────────────────────────────────────\e[0m"
|
|
||||||
else
|
|
||||||
review_script "$tmp"
|
|
||||||
fi
|
|
||||||
|
|
||||||
local new_hash old_hash
|
|
||||||
new_hash=$(sha256sum "$tmp" | awk '{print $1}')
|
|
||||||
old_hash=$(sha256sum "$LOCAL_SCRIPT" | awk '{print $1}')
|
|
||||||
echo -e " \e[36mCurrent SHA256:\e[0m ${old_hash}"
|
|
||||||
echo -e " \e[36mNew SHA256:\e[0m ${new_hash}"
|
|
||||||
echo ""
|
|
||||||
|
|
||||||
if ! confirm "Apply update?"; then
|
|
||||||
rm -f "$tmp"
|
|
||||||
echo " Aborted."
|
|
||||||
return
|
|
||||||
fi
|
|
||||||
|
|
||||||
install -m 0755 "$tmp" "$LOCAL_SCRIPT"
|
|
||||||
rm -f "$tmp"
|
|
||||||
ok "Updated ${LOCAL_SCRIPT}"
|
|
||||||
}
|
|
||||||
|
|
||||||
view_script() {
|
|
||||||
if [[ ! -f "$LOCAL_SCRIPT" ]]; then
|
|
||||||
err "No local script found at ${LOCAL_SCRIPT}. Use 'Add' first."
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
local view_choice
|
|
||||||
view_choice=$(whiptail --backtitle "Proxmox VE Helper Scripts" --title "View Script" --menu "What do you want to view?" 12 60 3 \
|
|
||||||
"Worker" "Installed update script (${LOCAL_SCRIPT##*/})" \
|
|
||||||
"Cron" "Cron schedule & configuration" \
|
|
||||||
"Both" "Show everything" \
|
|
||||||
3>&1 1>&2 2>&3) || return 0
|
|
||||||
|
|
||||||
case "$view_choice" in
|
|
||||||
"Worker") view_worker_script ;;
|
|
||||||
"Cron") view_cron_config ;;
|
|
||||||
"Both") view_cron_config && echo "" && view_worker_script ;;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
view_worker_script() {
|
|
||||||
local hash
|
|
||||||
hash=$(sha256sum "$LOCAL_SCRIPT" | awk '{print $1}')
|
|
||||||
echo ""
|
|
||||||
echo -e " \e[1;33m─── ${LOCAL_SCRIPT} ───\e[0m"
|
|
||||||
cat "$LOCAL_SCRIPT"
|
|
||||||
echo -e " \e[1;33m──────────────────────────────────────────────────────────────\e[0m"
|
|
||||||
echo -e " \e[36mSHA256:\e[0m ${hash}"
|
|
||||||
echo -e " \e[36mInstalled:\e[0m $(stat -c '%y' "$LOCAL_SCRIPT" 2>/dev/null | cut -d. -f1)"
|
|
||||||
echo ""
|
|
||||||
}
|
|
||||||
|
|
||||||
view_cron_config() {
|
|
||||||
echo ""
|
|
||||||
echo -e " \e[1;33m─── Cron Configuration ───────────────────────────────────────\e[0m"
|
|
||||||
if crontab -l -u root 2>/dev/null | grep -q "${LOCAL_SCRIPT}"; then
|
|
||||||
local entry
|
|
||||||
entry=$(crontab -l -u root 2>/dev/null | grep "${LOCAL_SCRIPT}")
|
|
||||||
echo -e " \e[36mCron entry:\e[0m ${entry}"
|
|
||||||
local schedule
|
|
||||||
schedule=$(echo "$entry" | awk '{print $1,$2,$3,$4,$5}')
|
|
||||||
echo -e " \e[36mSchedule:\e[0m ${schedule} ($(cron_to_human "$schedule"))"
|
|
||||||
else
|
|
||||||
echo -e " \e[31mCron:\e[0m Not configured"
|
|
||||||
fi
|
|
||||||
if [[ -f "$CONF_FILE" ]]; then
|
|
||||||
echo -e " \e[36mConfig file:\e[0m ${CONF_FILE}"
|
|
||||||
local excludes
|
|
||||||
excludes=$(grep -oP '^\s*EXCLUDE\s*=\s*\K.*' "$CONF_FILE" 2>/dev/null || true)
|
|
||||||
echo -e " \e[36mExcluded:\e[0m ${excludes:-(none)}"
|
|
||||||
echo ""
|
|
||||||
echo -e " \e[90m--- ${CONF_FILE} ---\e[0m"
|
|
||||||
cat "$CONF_FILE"
|
|
||||||
else
|
|
||||||
echo -e " \e[36mConfig file:\e[0m (not created yet)"
|
|
||||||
fi
|
|
||||||
if [[ -f "$LOG_FILE" ]]; then
|
|
||||||
local log_size
|
|
||||||
log_size=$(du -h "$LOG_FILE" | awk '{print $1}')
|
|
||||||
echo -e " \e[36mLog file:\e[0m ${LOG_FILE} (${log_size})"
|
|
||||||
fi
|
|
||||||
echo -e " \e[1;33m──────────────────────────────────────────────────────────────\e[0m"
|
|
||||||
echo ""
|
|
||||||
}
|
|
||||||
|
|
||||||
cron_to_human() {
|
|
||||||
local schedule="$1"
|
|
||||||
case "$schedule" in
|
|
||||||
"0 0 * * 0") echo "Every Sunday at midnight" ;;
|
|
||||||
"0 0 * * *") echo "Daily at midnight" ;;
|
|
||||||
"0 * * * *") echo "Every hour" ;;
|
|
||||||
*) echo "Custom schedule" ;;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
show_status() {
|
|
||||||
echo ""
|
|
||||||
if [[ -f "$LOCAL_SCRIPT" ]]; then
|
|
||||||
local hash
|
|
||||||
hash=$(sha256sum "$LOCAL_SCRIPT" | awk '{print $1}')
|
|
||||||
ok "Script installed: ${LOCAL_SCRIPT}"
|
|
||||||
echo -e " \e[36mSHA256:\e[0m ${hash}"
|
|
||||||
echo -e " \e[36mInstalled:\e[0m $(stat -c '%y' "$LOCAL_SCRIPT" 2>/dev/null | cut -d. -f1)"
|
|
||||||
else
|
|
||||||
err "Script not installed"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if crontab -l -u root 2>/dev/null | grep -q "${LOCAL_SCRIPT}"; then
|
|
||||||
local schedule
|
|
||||||
schedule=$(crontab -l -u root 2>/dev/null | grep "${LOCAL_SCRIPT}" | awk '{print $1,$2,$3,$4,$5}')
|
|
||||||
ok "Cron active: ${schedule}"
|
|
||||||
else
|
|
||||||
err "Cron not configured"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ -f "$CONF_FILE" ]]; then
|
|
||||||
local excludes
|
|
||||||
excludes=$(grep -oP '^\s*EXCLUDE\s*=\s*\K.*' "$CONF_FILE" 2>/dev/null || echo "(none)")
|
|
||||||
echo -e " \e[36mExcluded:\e[0m ${excludes:-"(none)"}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ -f "$LOG_FILE" ]]; then
|
|
||||||
local log_size last_run
|
|
||||||
log_size=$(du -h "$LOG_FILE" | awk '{print $1}')
|
|
||||||
last_run=$(grep -oP '^\s+\K\w.*' "$LOG_FILE" | tail -1)
|
|
||||||
echo -e " \e[36mLog file:\e[0m ${LOG_FILE} (${log_size})"
|
|
||||||
[[ -n "${last_run:-}" ]] && echo -e " \e[36mLast run:\e[0m ${last_run}"
|
|
||||||
else
|
|
||||||
echo -e " \e[36mLog file:\e[0m (no runs yet)"
|
|
||||||
fi
|
|
||||||
echo ""
|
|
||||||
}
|
|
||||||
|
|
||||||
run_now() {
|
|
||||||
if [[ ! -f "$LOCAL_SCRIPT" ]]; then
|
|
||||||
err "No local script found at ${LOCAL_SCRIPT}. Use 'Add' first."
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
info "Running update script now..."
|
|
||||||
bash "$LOCAL_SCRIPT" | tee -a "$LOG_FILE"
|
|
||||||
ok "Run completed. Log appended to ${LOG_FILE}"
|
|
||||||
}
|
|
||||||
|
|
||||||
rotate_log() {
|
|
||||||
if [[ ! -f "$LOG_FILE" ]]; then
|
|
||||||
info "No log file to rotate."
|
|
||||||
return
|
|
||||||
fi
|
|
||||||
local log_size
|
|
||||||
log_size=$(stat -c '%s' "$LOG_FILE" 2>/dev/null || echo 0)
|
|
||||||
local log_size_h
|
|
||||||
log_size_h=$(du -h "$LOG_FILE" | awk '{print $1}')
|
|
||||||
if confirm "Rotate log file? (current size: ${log_size_h})"; then
|
|
||||||
mv "$LOG_FILE" "${LOG_FILE}.old"
|
|
||||||
ok "Rotated: ${LOG_FILE} → ${LOG_FILE}.old"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
OPTIONS=(
|
|
||||||
Add "Download, review & install cron schedule"
|
|
||||||
Remove "Remove cron schedule & local script"
|
|
||||||
Update "Update local script from repository"
|
|
||||||
Status "Show installation status & last run"
|
|
||||||
Run "Run update script now (manual trigger)"
|
|
||||||
View "View cron config & installed script"
|
|
||||||
Rotate "Rotate log file"
|
|
||||||
)
|
|
||||||
|
|
||||||
CHOICE=$(whiptail --backtitle "Proxmox VE Helper Scripts" --title "Cron Update LXCs" --menu "Select an option:" 16 68 7 \
|
|
||||||
"${OPTIONS[@]}" 3>&1 1>&2 2>&3) || exit 0
|
|
||||||
|
|
||||||
case $CHOICE in
|
case $CHOICE in
|
||||||
"Add") add ;;
|
"Add")
|
||||||
"Remove") remove ;;
|
add
|
||||||
"Update") update_script ;;
|
;;
|
||||||
"Status") show_status ;;
|
"Remove")
|
||||||
"Run") run_now ;;
|
remove
|
||||||
"View") view_script ;;
|
;;
|
||||||
"Rotate") rotate_log ;;
|
*)
|
||||||
|
echo "Exiting..."
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
esac
|
esac
|
||||||
|
|||||||
@@ -1,43 +1,23 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
# Copyright (c) 2021-2026 community-scripts ORG
|
# Copyright (c) 2021-2026 tteck
|
||||||
# Author: MickLesk (CanbiZ)
|
# Author: tteck (tteckster)
|
||||||
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
|
# License: MIT
|
||||||
#
|
# https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
|
||||||
# This script is installed locally by cron-update-lxcs.sh and executed
|
|
||||||
# by cron. It updates all LXC containers using their native package manager.
|
|
||||||
|
|
||||||
CONF_FILE="/etc/update-lxcs.conf"
|
|
||||||
|
|
||||||
echo -e "\n $(date)"
|
echo -e "\n $(date)"
|
||||||
|
|
||||||
# Collect excluded containers from arguments
|
|
||||||
excluded_containers=("$@")
|
excluded_containers=("$@")
|
||||||
|
|
||||||
# Merge exclusions from config file if it exists
|
|
||||||
if [[ -f "$CONF_FILE" ]]; then
|
|
||||||
conf_exclude=$(grep -oP '^\s*EXCLUDE\s*=\s*\K[0-9,]+' "$CONF_FILE" 2>/dev/null || true)
|
|
||||||
IFS=',' read -ra conf_ids <<<"$conf_exclude"
|
|
||||||
for id in "${conf_ids[@]}"; do
|
|
||||||
id="${id// /}"
|
|
||||||
[[ -n "$id" ]] && excluded_containers+=("$id")
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
|
|
||||||
function update_container() {
|
function update_container() {
|
||||||
local container=$1
|
container=$1
|
||||||
local name
|
name=$(pct exec "$container" hostname)
|
||||||
name=$(pct exec "$container" hostname 2>/dev/null || echo "unknown")
|
echo -e "\n [Info] Updating $container : $name \n"
|
||||||
local os
|
|
||||||
os=$(pct config "$container" | awk '/^ostype/ {print $2}')
|
os=$(pct config "$container" | awk '/^ostype/ {print $2}')
|
||||||
echo -e "\n [Info] Updating $container : $name (os: $os)"
|
|
||||||
case "$os" in
|
case "$os" in
|
||||||
alpine) pct exec "$container" -- ash -c "apk -U upgrade" ;;
|
alpine) pct exec "$container" -- ash -c "apk -U upgrade" ;;
|
||||||
archlinux) pct exec "$container" -- bash -c "pacman -Syyu --noconfirm" ;;
|
archlinux) pct exec "$container" -- bash -c "pacman -Syyu --noconfirm" ;;
|
||||||
fedora | rocky | centos | alma) pct exec "$container" -- bash -c "dnf -y update && dnf -y upgrade" ;;
|
fedora | rocky | centos | alma) pct exec "$container" -- bash -c "dnf -y update && dnf -y upgrade" ;;
|
||||||
ubuntu | debian | devuan) pct exec "$container" -- bash -c "apt-get update && DEBIAN_FRONTEND=noninteractive apt-get -o Dpkg::Options::='--force-confold' dist-upgrade -y; rm -rf /usr/lib/python3.*/EXTERNALLY-MANAGED" ;;
|
ubuntu | debian | devuan) pct exec "$container" -- bash -c "apt-get update && DEBIAN_FRONTEND=noninteractive apt-get -o Dpkg::Options::="--force-confold" dist-upgrade -y; rm -rf /usr/lib/python3.*/EXTERNALLY-MANAGED" ;;
|
||||||
opensuse) pct exec "$container" -- bash -c "zypper ref && zypper --non-interactive dup" ;;
|
opensuse) pct exec "$container" -- bash -c "zypper ref && zypper --non-interactive dup" ;;
|
||||||
*) echo " [Warn] Unknown OS type '$os' for container $container, skipping" ;;
|
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -54,19 +34,16 @@ for container in $(pct list | awk '{if(NR>1) print $1}'); do
|
|||||||
sleep 1
|
sleep 1
|
||||||
else
|
else
|
||||||
status=$(pct status "$container")
|
status=$(pct status "$container")
|
||||||
if pct config "$container" 2>/dev/null | grep -q "^template:"; then
|
template=$(pct config "$container" | grep -q "template:" && echo "true" || echo "false")
|
||||||
echo -e "[Info] Skipping template $container"
|
if [ "$template" == "false" ] && [ "$status" == "status: stopped" ]; then
|
||||||
continue
|
|
||||||
fi
|
|
||||||
if [ "$status" == "status: stopped" ]; then
|
|
||||||
echo -e "[Info] Starting $container"
|
echo -e "[Info] Starting $container"
|
||||||
pct start "$container"
|
pct start "$container"
|
||||||
sleep 5
|
sleep 5
|
||||||
update_container "$container" || echo " [Error] Update failed for $container"
|
update_container "$container"
|
||||||
echo -e "[Info] Shutting down $container"
|
echo -e "[Info] Shutting down $container"
|
||||||
pct shutdown "$container" --timeout 60 &
|
pct shutdown "$container" &
|
||||||
elif [ "$status" == "status: running" ]; then
|
elif [ "$status" == "status: running" ]; then
|
||||||
update_container "$container" || echo " [Error] Update failed for $container"
|
update_container "$container"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|||||||
Reference in New Issue
Block a user