mirror of
https://github.com/community-scripts/ProxmoxVE.git
synced 2026-03-06 10:55:56 +01:00
Compare commits
32 Commits
fix/addon-
...
add-script
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
a5af8ef166 | ||
|
|
0be065bbef | ||
|
|
10118f4350 | ||
|
|
ac435455a0 | ||
|
|
929cd08718 | ||
|
|
299e7bfabe | ||
|
|
3465f053f5 | ||
|
|
18801eb4ff | ||
|
|
87e14ba12f | ||
|
|
438a519c65 | ||
|
|
572ea7c2be | ||
|
|
fc8b5af5fe | ||
|
|
554dfc5b0e | ||
|
|
4855fdb50d | ||
|
|
4dbb536922 | ||
|
|
154f46d6b8 | ||
|
|
bb8ac9696f | ||
|
|
41b5e5d8b9 | ||
|
|
e07b2325c1 | ||
|
|
8c9c85c1c7 | ||
|
|
2d38e509f0 | ||
|
|
4396108113 | ||
|
|
f82c15ca98 | ||
|
|
1a09b112b6 | ||
|
|
c70c488648 | ||
|
|
91db277446 | ||
|
|
35ce20391c | ||
|
|
783ba03e92 | ||
|
|
e344d3661c | ||
|
|
c62418069d | ||
|
|
41611d2682 | ||
|
|
cf8043a22e |
18
CHANGELOG.md
18
CHANGELOG.md
@@ -410,18 +410,36 @@ Exercise vigilance regarding copycat or coat-tailing sites that seek to exploit
|
|||||||
|
|
||||||
</details>
|
</details>
|
||||||
|
|
||||||
|
## 2026-03-05
|
||||||
|
|
||||||
|
### 🆕 New Scripts
|
||||||
|
|
||||||
|
- Papra ([#12577](https://github.com/community-scripts/ProxmoxVE/pull/12577))
|
||||||
|
|
||||||
## 2026-03-04
|
## 2026-03-04
|
||||||
|
|
||||||
### 🚀 Updated Scripts
|
### 🚀 Updated Scripts
|
||||||
|
|
||||||
- #### 🐞 Bug Fixes
|
- #### 🐞 Bug Fixes
|
||||||
|
|
||||||
|
- fix: gitea-mirror [@CrazyWolf13](https://github.com/CrazyWolf13) ([#12549](https://github.com/community-scripts/ProxmoxVE/pull/12549))
|
||||||
- fix(immich): correct LibRaw clone URL to official upstream [@DenislavDenev](https://github.com/DenislavDenev) ([#12526](https://github.com/community-scripts/ProxmoxVE/pull/12526))
|
- fix(immich): correct LibRaw clone URL to official upstream [@DenislavDenev](https://github.com/DenislavDenev) ([#12526](https://github.com/community-scripts/ProxmoxVE/pull/12526))
|
||||||
|
- update: stirling-pdf: java 25 [@CrazyWolf13](https://github.com/CrazyWolf13) ([#12552](https://github.com/community-scripts/ProxmoxVE/pull/12552))
|
||||||
|
- Docmost: register NoopAuditService globally when EE submodule is missing [@MickLesk](https://github.com/MickLesk) ([#12551](https://github.com/community-scripts/ProxmoxVE/pull/12551))
|
||||||
|
- jellyseer/overseer migration corrupting /usr/bin/update [@MickLesk](https://github.com/MickLesk) ([#12539](https://github.com/community-scripts/ProxmoxVE/pull/12539))
|
||||||
|
- PowerDNS: use gsqlite3 backend instead of BIND [@MickLesk](https://github.com/MickLesk) ([#12538](https://github.com/community-scripts/ProxmoxVE/pull/12538))
|
||||||
|
- addon migrations: /usr/bin/update replacement to prevent syntax error [@MickLesk](https://github.com/MickLesk) ([#12540](https://github.com/community-scripts/ProxmoxVE/pull/12540))
|
||||||
|
|
||||||
|
- #### 🔧 Refactor
|
||||||
|
|
||||||
|
- Fluid-Calendar: NodeJS bump [@tremor021](https://github.com/tremor021) ([#12558](https://github.com/community-scripts/ProxmoxVE/pull/12558))
|
||||||
|
- Refactor: LiteLLM [@tremor021](https://github.com/tremor021) ([#12550](https://github.com/community-scripts/ProxmoxVE/pull/12550))
|
||||||
|
|
||||||
### 💾 Core
|
### 💾 Core
|
||||||
|
|
||||||
- #### 🐞 Bug Fixes
|
- #### 🐞 Bug Fixes
|
||||||
|
|
||||||
|
- tools: fall back to distro packages for psql [@MickLesk](https://github.com/MickLesk) ([#12542](https://github.com/community-scripts/ProxmoxVE/pull/12542))
|
||||||
- fix: whitelist var_searchdomain and fix the handling of var_ns and va… [@tommoyer](https://github.com/tommoyer) ([#12521](https://github.com/community-scripts/ProxmoxVE/pull/12521))
|
- fix: whitelist var_searchdomain and fix the handling of var_ns and va… [@tommoyer](https://github.com/tommoyer) ([#12521](https://github.com/community-scripts/ProxmoxVE/pull/12521))
|
||||||
|
|
||||||
## 2026-03-03
|
## 2026-03-03
|
||||||
|
|||||||
@@ -48,9 +48,11 @@ function update_script() {
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
msg_info "Migrating update function"
|
msg_info "Migrating update function"
|
||||||
cat <<'MIGRATION_EOF' >/usr/bin/update
|
TMP_UPDATE=$(mktemp)
|
||||||
|
cat <<'MIGRATION_EOF' >"$TMP_UPDATE"
|
||||||
bash -c "$(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/tools/addon/komodo.sh)"
|
bash -c "$(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/tools/addon/komodo.sh)"
|
||||||
MIGRATION_EOF
|
MIGRATION_EOF
|
||||||
|
mv "$TMP_UPDATE" /usr/bin/update
|
||||||
chmod +x /usr/bin/update
|
chmod +x /usr/bin/update
|
||||||
|
|
||||||
ln -sf /usr/bin/update /usr/bin/update_komodo 2>/dev/null || true
|
ln -sf /usr/bin/update /usr/bin/update_komodo 2>/dev/null || true
|
||||||
|
|||||||
@@ -46,9 +46,11 @@ function update_script() {
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
msg_info "Migrating update function"
|
msg_info "Migrating update function"
|
||||||
cat <<'MIGRATION_EOF' >/usr/bin/update
|
TMP_UPDATE=$(mktemp)
|
||||||
|
cat <<'MIGRATION_EOF' >"$TMP_UPDATE"
|
||||||
bash -c "$(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/tools/addon/coolify.sh)"
|
bash -c "$(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/tools/addon/coolify.sh)"
|
||||||
MIGRATION_EOF
|
MIGRATION_EOF
|
||||||
|
mv "$TMP_UPDATE" /usr/bin/update
|
||||||
chmod +x /usr/bin/update
|
chmod +x /usr/bin/update
|
||||||
|
|
||||||
ln -sf /usr/bin/update /usr/bin/update_coolify 2>/dev/null || true
|
ln -sf /usr/bin/update /usr/bin/update_coolify 2>/dev/null || true
|
||||||
|
|||||||
46
ct/ddclient.sh
Normal file
46
ct/ddclient.sh
Normal file
@@ -0,0 +1,46 @@
|
|||||||
|
#!/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: mitchscobell
|
||||||
|
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
|
||||||
|
# Source: https://ddclient.net/
|
||||||
|
|
||||||
|
APP="ddclient"
|
||||||
|
var_tags="${var_tags:-network}"
|
||||||
|
var_cpu="${var_cpu:-1}"
|
||||||
|
var_ram="${var_ram:-512}"
|
||||||
|
var_disk="${var_disk:-2}"
|
||||||
|
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 /etc/ddclient.conf ]]; then
|
||||||
|
msg_error "No ${APP} Installation Found!"
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
|
||||||
|
msg_info "Updating ddclient"
|
||||||
|
$STD apt update
|
||||||
|
$STD apt install --only-upgrade -y ddclient
|
||||||
|
$STD systemctl restart ddclient
|
||||||
|
msg_ok "Updated ddclient"
|
||||||
|
msg_ok "Updated successfully!"
|
||||||
|
exit
|
||||||
|
}
|
||||||
|
|
||||||
|
start
|
||||||
|
build_container
|
||||||
|
description
|
||||||
|
|
||||||
|
msg_ok "Completed successfully!\n"
|
||||||
|
echo -e "${CREATING}${GN}${APP} setup has been successfully initialized!${CL}"
|
||||||
@@ -48,9 +48,11 @@ function update_script() {
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
msg_info "Migrating update function"
|
msg_info "Migrating update function"
|
||||||
cat <<'MIGRATION_EOF' >/usr/bin/update
|
TMP_UPDATE=$(mktemp)
|
||||||
|
cat <<'MIGRATION_EOF' >"$TMP_UPDATE"
|
||||||
bash -c "$(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/tools/addon/dockge.sh)"
|
bash -c "$(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/tools/addon/dockge.sh)"
|
||||||
MIGRATION_EOF
|
MIGRATION_EOF
|
||||||
|
mv "$TMP_UPDATE" /usr/bin/update
|
||||||
chmod +x /usr/bin/update
|
chmod +x /usr/bin/update
|
||||||
|
|
||||||
ln -sf /usr/bin/update /usr/bin/update_dockge 2>/dev/null || true
|
ln -sf /usr/bin/update /usr/bin/update_dockge 2>/dev/null || true
|
||||||
|
|||||||
@@ -48,6 +48,17 @@ function update_script() {
|
|||||||
cd /opt/docmost
|
cd /opt/docmost
|
||||||
mv /opt/.env /opt/docmost/.env
|
mv /opt/.env /opt/docmost/.env
|
||||||
mv /opt/data /opt/docmost/data
|
mv /opt/data /opt/docmost/data
|
||||||
|
|
||||||
|
# Fix: Docmost EE (audit logs etc.) lives in a git submodule that is NOT
|
||||||
|
# included in GitHub tarballs. The community NoopAuditService exists but
|
||||||
|
# is only exported by CoreModule – child modules such as UserModule cannot
|
||||||
|
# resolve it. Making CoreModule @Global() exposes the token app-wide.
|
||||||
|
if [[ ! -f /opt/docmost/apps/server/src/ee/ee.module.ts ]] \
|
||||||
|
&& ! grep -q '@Global()' /opt/docmost/apps/server/src/core/core.module.ts 2>/dev/null; then
|
||||||
|
sed -i '/^ Module,$/a\ Global,' /opt/docmost/apps/server/src/core/core.module.ts
|
||||||
|
sed -i '/^@Module({$/i @Global()' /opt/docmost/apps/server/src/core/core.module.ts
|
||||||
|
fi
|
||||||
|
|
||||||
$STD pnpm install --force
|
$STD pnpm install --force
|
||||||
$STD pnpm build
|
$STD pnpm build
|
||||||
msg_ok "Updated ${APP}"
|
msg_ok "Updated ${APP}"
|
||||||
|
|||||||
@@ -46,9 +46,11 @@ function update_script() {
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
msg_info "Migrating update function"
|
msg_info "Migrating update function"
|
||||||
cat <<'MIGRATION_EOF' >/usr/bin/update
|
TMP_UPDATE=$(mktemp)
|
||||||
|
cat <<'MIGRATION_EOF' >"$TMP_UPDATE"
|
||||||
bash -c "$(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/tools/addon/dokploy.sh)"
|
bash -c "$(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/tools/addon/dokploy.sh)"
|
||||||
MIGRATION_EOF
|
MIGRATION_EOF
|
||||||
|
mv "$TMP_UPDATE" /usr/bin/update
|
||||||
chmod +x /usr/bin/update
|
chmod +x /usr/bin/update
|
||||||
|
|
||||||
ln -sf /usr/bin/update /usr/bin/update_dokploy 2>/dev/null || true
|
ln -sf /usr/bin/update /usr/bin/update_dokploy 2>/dev/null || true
|
||||||
|
|||||||
@@ -28,6 +28,9 @@ function update_script() {
|
|||||||
msg_error "No ${APP} Installation Found!"
|
msg_error "No ${APP} Installation Found!"
|
||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
NODE_VERSION="24" setup_nodejs
|
||||||
|
|
||||||
if check_for_gh_release "fluid-calendar" "dotnetfactory/fluid-calendar"; then
|
if check_for_gh_release "fluid-calendar" "dotnetfactory/fluid-calendar"; then
|
||||||
msg_info "Stopping Service"
|
msg_info "Stopping Service"
|
||||||
systemctl stop fluid-calendar
|
systemctl stop fluid-calendar
|
||||||
|
|||||||
@@ -87,6 +87,8 @@ EOF
|
|||||||
msg_ok "Old Enviroment fixed"
|
msg_ok "Old Enviroment fixed"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
ensure_dependencies git
|
||||||
|
|
||||||
if check_for_gh_release "gitea-mirror" "RayLabsHQ/gitea-mirror"; then
|
if check_for_gh_release "gitea-mirror" "RayLabsHQ/gitea-mirror"; then
|
||||||
msg_info "Stopping Services"
|
msg_info "Stopping Services"
|
||||||
systemctl stop gitea-mirror
|
systemctl stop gitea-mirror
|
||||||
@@ -94,7 +96,7 @@ EOF
|
|||||||
|
|
||||||
msg_info "Backup Data"
|
msg_info "Backup Data"
|
||||||
mkdir -p /opt/gitea-mirror-backup/data
|
mkdir -p /opt/gitea-mirror-backup/data
|
||||||
cp /opt/gitea-mirror/data/* /opt/gitea-mirror-backup/data/
|
cp -r /opt/gitea-mirror/data/* /opt/gitea-mirror-backup/data/
|
||||||
msg_ok "Backup Data"
|
msg_ok "Backup Data"
|
||||||
|
|
||||||
msg_info "Installing Bun"
|
msg_info "Installing Bun"
|
||||||
@@ -111,12 +113,11 @@ EOF
|
|||||||
$STD bun run setup
|
$STD bun run setup
|
||||||
$STD bun run build
|
$STD bun run build
|
||||||
APP_VERSION=$(grep -o '"version": *"[^"]*"' package.json | cut -d'"' -f4)
|
APP_VERSION=$(grep -o '"version": *"[^"]*"' package.json | cut -d'"' -f4)
|
||||||
|
sed -i.bak "s|^npm_package_version=.*|npm_package_version=${APP_VERSION}|" /opt/gitea-mirror.env
|
||||||
sudo sed -i.bak "s|^npm_package_version=.*|npm_package_version=${APP_VERSION}|" /opt/gitea-mirror.env
|
|
||||||
msg_ok "Updated and rebuilt ${APP}"
|
msg_ok "Updated and rebuilt ${APP}"
|
||||||
|
|
||||||
msg_info "Restoring Data"
|
msg_info "Restoring Data"
|
||||||
cp /opt/gitea-mirror-backup/data/* /opt/gitea-mirror/data
|
cp -r /opt/gitea-mirror-backup/data/* /opt/gitea-mirror/data
|
||||||
msg_ok "Restored Data"
|
msg_ok "Restored Data"
|
||||||
|
|
||||||
msg_info "Starting Service"
|
msg_info "Starting Service"
|
||||||
|
|||||||
6
ct/headers/papra
Normal file
6
ct/headers/papra
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
____
|
||||||
|
/ __ \____ _____ _________ _
|
||||||
|
/ /_/ / __ `/ __ \/ ___/ __ `/
|
||||||
|
/ ____/ /_/ / /_/ / / / /_/ /
|
||||||
|
/_/ \__,_/ .___/_/ \__,_/
|
||||||
|
/_/
|
||||||
@@ -45,14 +45,15 @@ function update_script() {
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
msg_info "Switching update script to Seerr"
|
msg_info "Switching update script to Seerr"
|
||||||
cat <<'EOF' >/usr/bin/update
|
TMP_UPDATE=$(mktemp)
|
||||||
#!/usr/bin/env bash
|
cat <<'EOF' >"$TMP_UPDATE"
|
||||||
bash -c "$(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/ct/seerr.sh)"
|
bash -c "$(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/ct/seerr.sh)"
|
||||||
EOF
|
EOF
|
||||||
|
mv "$TMP_UPDATE" /usr/bin/update
|
||||||
chmod +x /usr/bin/update
|
chmod +x /usr/bin/update
|
||||||
msg_ok "Switched update script to Seerr"
|
msg_ok "Switched update script to Seerr"
|
||||||
msg_warn "Please type 'update' again to complete the migration"
|
msg_warn "Please type 'update' again to complete the migration"
|
||||||
exit
|
exit 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
msg_info "Updating Jellyseerr"
|
msg_info "Updating Jellyseerr"
|
||||||
|
|||||||
@@ -52,9 +52,11 @@ function update_script() {
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
msg_info "Migrating update function"
|
msg_info "Migrating update function"
|
||||||
cat <<'MIGRATION_EOF' >/usr/bin/update
|
TMP_UPDATE=$(mktemp)
|
||||||
|
cat <<'MIGRATION_EOF' >"$TMP_UPDATE"
|
||||||
bash -c "$(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/tools/addon/komodo.sh)"
|
bash -c "$(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/tools/addon/komodo.sh)"
|
||||||
MIGRATION_EOF
|
MIGRATION_EOF
|
||||||
|
mv "$TMP_UPDATE" /usr/bin/update
|
||||||
chmod +x /usr/bin/update
|
chmod +x /usr/bin/update
|
||||||
|
|
||||||
ln -sf /usr/bin/update /usr/bin/update_komodo 2>/dev/null || true
|
ln -sf /usr/bin/update /usr/bin/update_komodo 2>/dev/null || true
|
||||||
|
|||||||
@@ -34,7 +34,7 @@ function update_script() {
|
|||||||
msg_ok "Stopped Service"
|
msg_ok "Stopped Service"
|
||||||
|
|
||||||
VENV_PATH="/opt/litellm/.venv"
|
VENV_PATH="/opt/litellm/.venv"
|
||||||
PYTHON_VERSION="3.13" setup_uv
|
PYTHON_VERSION="3.13" USE_UVX="YES" setup_uv
|
||||||
|
|
||||||
msg_info "Updating LiteLLM"
|
msg_info "Updating LiteLLM"
|
||||||
$STD "$VENV_PATH/bin/python" -m pip install --upgrade litellm[proxy] prisma
|
$STD "$VENV_PATH/bin/python" -m pip install --upgrade litellm[proxy] prisma
|
||||||
|
|||||||
@@ -44,10 +44,11 @@ function update_script() {
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
msg_info "Switching update script to Seerr"
|
msg_info "Switching update script to Seerr"
|
||||||
cat <<'EOF' >/usr/bin/update
|
TMP_UPDATE=$(mktemp)
|
||||||
#!/usr/bin/env bash
|
cat <<'EOF' >"$TMP_UPDATE"
|
||||||
bash -c "$(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/ct/seerr.sh)"
|
bash -c "$(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/ct/seerr.sh)"
|
||||||
EOF
|
EOF
|
||||||
|
mv "$TMP_UPDATE" /usr/bin/update
|
||||||
chmod +x /usr/bin/update
|
chmod +x /usr/bin/update
|
||||||
msg_ok "Switched update script to Seerr"
|
msg_ok "Switched update script to Seerr"
|
||||||
msg_warn "Please type 'update' again to complete the migration"
|
msg_warn "Please type 'update' again to complete the migration"
|
||||||
|
|||||||
68
ct/papra.sh
Normal file
68
ct/papra.sh
Normal file
@@ -0,0 +1,68 @@
|
|||||||
|
#!/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/papra-hq/papra
|
||||||
|
|
||||||
|
APP="Papra"
|
||||||
|
var_tags="${var_tags:-document-management}"
|
||||||
|
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/papra ]]; then
|
||||||
|
msg_error "No ${APP} Installation Found!"
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
|
||||||
|
if check_for_gh_release "papra" "papra-hq/papra"; then
|
||||||
|
msg_info "Stopping Service"
|
||||||
|
systemctl stop papra
|
||||||
|
msg_ok "Stopped Service"
|
||||||
|
|
||||||
|
msg_info "Backing up Configuration"
|
||||||
|
cp /opt/papra/apps/papra-server/.env /opt/papra_env.bak
|
||||||
|
msg_ok "Backed up Configuration"
|
||||||
|
|
||||||
|
CLEAN_INSTALL=1 fetch_and_deploy_gh_release "papra" "papra-hq/papra" "tarball"
|
||||||
|
|
||||||
|
msg_info "Building Application"
|
||||||
|
cd /opt/papra
|
||||||
|
cp /opt/papra_env.bak /opt/papra/apps/papra-server/.env
|
||||||
|
$STD pnpm install --frozen-lockfile
|
||||||
|
$STD pnpm --filter "@papra/app-client..." run build
|
||||||
|
$STD pnpm --filter "@papra/app-server..." run build
|
||||||
|
ln -sf /opt/papra/apps/papra-client/dist /opt/papra/apps/papra-server/public
|
||||||
|
rm -f /opt/papra_env.bak
|
||||||
|
msg_ok "Built Application"
|
||||||
|
|
||||||
|
msg_info "Starting Service"
|
||||||
|
systemctl start papra
|
||||||
|
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}:1221${CL}"
|
||||||
@@ -47,7 +47,10 @@ function update_script() {
|
|||||||
cp /opt/poweradmin_powerdns.db.bak /opt/poweradmin/powerdns.db
|
cp /opt/poweradmin_powerdns.db.bak /opt/poweradmin/powerdns.db
|
||||||
rm -rf /opt/poweradmin/install
|
rm -rf /opt/poweradmin/install
|
||||||
rm -f /opt/poweradmin_settings.php.bak /opt/poweradmin_powerdns.db.bak
|
rm -f /opt/poweradmin_settings.php.bak /opt/poweradmin_powerdns.db.bak
|
||||||
chown -R www-data:www-data /opt/poweradmin
|
chown -R www-data:pdns /opt/poweradmin
|
||||||
|
chmod 775 /opt/poweradmin
|
||||||
|
chown pdns:pdns /opt/poweradmin/powerdns.db
|
||||||
|
chmod 664 /opt/poweradmin/powerdns.db
|
||||||
msg_ok "Updated Poweradmin"
|
msg_ok "Updated Poweradmin"
|
||||||
|
|
||||||
msg_info "Restarting Services"
|
msg_info "Restarting Services"
|
||||||
|
|||||||
@@ -46,9 +46,11 @@ function update_script() {
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
msg_info "Migrating update function"
|
msg_info "Migrating update function"
|
||||||
cat <<'MIGRATION_EOF' >/usr/bin/update
|
TMP_UPDATE=$(mktemp)
|
||||||
|
cat <<'MIGRATION_EOF' >"$TMP_UPDATE"
|
||||||
bash -c "$(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/tools/addon/runtipi.sh)"
|
bash -c "$(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/tools/addon/runtipi.sh)"
|
||||||
MIGRATION_EOF
|
MIGRATION_EOF
|
||||||
|
mv "$TMP_UPDATE" /usr/bin/update
|
||||||
chmod +x /usr/bin/update
|
chmod +x /usr/bin/update
|
||||||
|
|
||||||
ln -sf /usr/bin/update /usr/bin/update_runtipi 2>/dev/null || true
|
ln -sf /usr/bin/update /usr/bin/update_runtipi 2>/dev/null || true
|
||||||
|
|||||||
@@ -35,7 +35,7 @@ function update_script() {
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
PYTHON_VERSION="3.12" setup_uv
|
PYTHON_VERSION="3.12" setup_uv
|
||||||
JAVA_VERSION="21" setup_java
|
JAVA_VERSION="25" setup_java
|
||||||
|
|
||||||
msg_info "Stopping Services"
|
msg_info "Stopping Services"
|
||||||
systemctl stop stirlingpdf libreoffice-listener unoserver
|
systemctl stop stirlingpdf libreoffice-listener unoserver
|
||||||
|
|||||||
44
frontend/public/json/ddclient.json
Normal file
44
frontend/public/json/ddclient.json
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
{
|
||||||
|
"name": "ddclient",
|
||||||
|
"slug": "ddclient",
|
||||||
|
"categories": [
|
||||||
|
4
|
||||||
|
],
|
||||||
|
"date_created": "2026-01-31",
|
||||||
|
"type": "ct",
|
||||||
|
"updateable": true,
|
||||||
|
"privileged": false,
|
||||||
|
"interface_port": null,
|
||||||
|
"documentation": "https://ddclient.net/",
|
||||||
|
"website": "https://ddclient.net/",
|
||||||
|
"logo": "https://cdn.jsdelivr.net/gh/selfhst/icons@main/webp/ddclient.webp",
|
||||||
|
"config_path": "/etc/ddclient.conf",
|
||||||
|
"description": "ddclient is a Perl client used to update dynamic DNS entries for accounts on a wide range of dynamic DNS service providers. It supports multiple protocols and providers, allowing automatic IP address updates for your domain names.",
|
||||||
|
"install_methods": [
|
||||||
|
{
|
||||||
|
"type": "default",
|
||||||
|
"script": "ct/ddclient.sh",
|
||||||
|
"resources": {
|
||||||
|
"cpu": 1,
|
||||||
|
"ram": 512,
|
||||||
|
"hdd": 2,
|
||||||
|
"os": "debian",
|
||||||
|
"version": "13"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"default_credentials": {
|
||||||
|
"username": null,
|
||||||
|
"password": null
|
||||||
|
},
|
||||||
|
"notes": [
|
||||||
|
{
|
||||||
|
"type": "info",
|
||||||
|
"text": "After installation, edit `/etc/ddclient.conf` with your dynamic DNS provider credentials"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "info",
|
||||||
|
"text": "Sample configuration is created for Namecheap but can be modified for other providers"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"generated": "2026-03-04T06:16:35Z",
|
"generated": "2026-03-05T12:12:30Z",
|
||||||
"versions": [
|
"versions": [
|
||||||
{
|
{
|
||||||
"slug": "2fauth",
|
"slug": "2fauth",
|
||||||
@@ -39,9 +39,9 @@
|
|||||||
{
|
{
|
||||||
"slug": "ampache",
|
"slug": "ampache",
|
||||||
"repo": "ampache/ampache",
|
"repo": "ampache/ampache",
|
||||||
"version": "7.9.1",
|
"version": "7.9.2",
|
||||||
"pinned": false,
|
"pinned": false,
|
||||||
"date": "2026-02-25T08:52:58Z"
|
"date": "2026-03-05T03:54:03Z"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"slug": "argus",
|
"slug": "argus",
|
||||||
@@ -193,9 +193,9 @@
|
|||||||
{
|
{
|
||||||
"slug": "checkmate",
|
"slug": "checkmate",
|
||||||
"repo": "bluewave-labs/Checkmate",
|
"repo": "bluewave-labs/Checkmate",
|
||||||
"version": "v3.4.0",
|
"version": "v3.5.0",
|
||||||
"pinned": false,
|
"pinned": false,
|
||||||
"date": "2026-02-20T21:08:55Z"
|
"date": "2026-03-04T19:51:22Z"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"slug": "cleanuparr",
|
"slug": "cleanuparr",
|
||||||
@@ -214,9 +214,9 @@
|
|||||||
{
|
{
|
||||||
"slug": "comfyui",
|
"slug": "comfyui",
|
||||||
"repo": "comfyanonymous/ComfyUI",
|
"repo": "comfyanonymous/ComfyUI",
|
||||||
"version": "v0.15.1",
|
"version": "v0.16.0",
|
||||||
"pinned": false,
|
"pinned": false,
|
||||||
"date": "2026-02-26T22:01:35Z"
|
"date": "2026-03-05T10:35:07Z"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"slug": "commafeed",
|
"slug": "commafeed",
|
||||||
@@ -298,9 +298,9 @@
|
|||||||
{
|
{
|
||||||
"slug": "docmost",
|
"slug": "docmost",
|
||||||
"repo": "docmost/docmost",
|
"repo": "docmost/docmost",
|
||||||
"version": "v0.70.0",
|
"version": "v0.70.1",
|
||||||
"pinned": false,
|
"pinned": false,
|
||||||
"date": "2026-03-03T20:33:08Z"
|
"date": "2026-03-04T12:54:49Z"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"slug": "domain-locker",
|
"slug": "domain-locker",
|
||||||
@@ -382,9 +382,9 @@
|
|||||||
{
|
{
|
||||||
"slug": "firefly",
|
"slug": "firefly",
|
||||||
"repo": "firefly-iii/firefly-iii",
|
"repo": "firefly-iii/firefly-iii",
|
||||||
"version": "v6.5.2",
|
"version": "v6.5.3",
|
||||||
"pinned": false,
|
"pinned": false,
|
||||||
"date": "2026-03-03T05:42:27Z"
|
"date": "2026-03-04T06:53:02Z"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"slug": "fladder",
|
"slug": "fladder",
|
||||||
@@ -438,9 +438,9 @@
|
|||||||
{
|
{
|
||||||
"slug": "ghostfolio",
|
"slug": "ghostfolio",
|
||||||
"repo": "ghostfolio/ghostfolio",
|
"repo": "ghostfolio/ghostfolio",
|
||||||
"version": "2.246.0",
|
"version": "2.247.0",
|
||||||
"pinned": false,
|
"pinned": false,
|
||||||
"date": "2026-03-03T19:37:20Z"
|
"date": "2026-03-04T07:48:00Z"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"slug": "gitea",
|
"slug": "gitea",
|
||||||
@@ -452,9 +452,9 @@
|
|||||||
{
|
{
|
||||||
"slug": "gitea-mirror",
|
"slug": "gitea-mirror",
|
||||||
"repo": "RayLabsHQ/gitea-mirror",
|
"repo": "RayLabsHQ/gitea-mirror",
|
||||||
"version": "v3.12.0",
|
"version": "v3.12.2",
|
||||||
"pinned": false,
|
"pinned": false,
|
||||||
"date": "2026-03-04T02:53:42Z"
|
"date": "2026-03-05T04:26:50Z"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"slug": "glance",
|
"slug": "glance",
|
||||||
@@ -473,9 +473,9 @@
|
|||||||
{
|
{
|
||||||
"slug": "gokapi",
|
"slug": "gokapi",
|
||||||
"repo": "Forceu/Gokapi",
|
"repo": "Forceu/Gokapi",
|
||||||
"version": "v2.2.2",
|
"version": "v2.2.3",
|
||||||
"pinned": false,
|
"pinned": false,
|
||||||
"date": "2026-01-31T21:11:27Z"
|
"date": "2026-03-04T21:29:16Z"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"slug": "gotify",
|
"slug": "gotify",
|
||||||
@@ -613,9 +613,9 @@
|
|||||||
{
|
{
|
||||||
"slug": "jackett",
|
"slug": "jackett",
|
||||||
"repo": "Jackett/Jackett",
|
"repo": "Jackett/Jackett",
|
||||||
"version": "v0.24.1275",
|
"version": "v0.24.1287",
|
||||||
"pinned": false,
|
"pinned": false,
|
||||||
"date": "2026-03-04T05:53:40Z"
|
"date": "2026-03-05T05:49:33Z"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"slug": "jellystat",
|
"slug": "jellystat",
|
||||||
@@ -669,9 +669,9 @@
|
|||||||
{
|
{
|
||||||
"slug": "kima-hub",
|
"slug": "kima-hub",
|
||||||
"repo": "Chevron7Locked/kima-hub",
|
"repo": "Chevron7Locked/kima-hub",
|
||||||
"version": "v1.6.1",
|
"version": "v1.6.2",
|
||||||
"pinned": false,
|
"pinned": false,
|
||||||
"date": "2026-03-03T16:13:53Z"
|
"date": "2026-03-05T05:38:02Z"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"slug": "kimai",
|
"slug": "kimai",
|
||||||
@@ -690,9 +690,9 @@
|
|||||||
{
|
{
|
||||||
"slug": "koel",
|
"slug": "koel",
|
||||||
"repo": "koel/koel",
|
"repo": "koel/koel",
|
||||||
"version": "v8.3.0",
|
"version": "v8.3.1",
|
||||||
"pinned": false,
|
"pinned": false,
|
||||||
"date": "2026-01-08T21:32:58Z"
|
"date": "2026-03-04T08:22:06Z"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"slug": "koillection",
|
"slug": "koillection",
|
||||||
@@ -1061,9 +1061,9 @@
|
|||||||
{
|
{
|
||||||
"slug": "paperless-ngx",
|
"slug": "paperless-ngx",
|
||||||
"repo": "paperless-ngx/paperless-ngx",
|
"repo": "paperless-ngx/paperless-ngx",
|
||||||
"version": "v2.20.9",
|
"version": "v2.20.10",
|
||||||
"pinned": false,
|
"pinned": false,
|
||||||
"date": "2026-02-28T10:17:35Z"
|
"date": "2026-03-04T19:20:57Z"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"slug": "patchmon",
|
"slug": "patchmon",
|
||||||
@@ -1229,9 +1229,9 @@
|
|||||||
{
|
{
|
||||||
"slug": "pulse",
|
"slug": "pulse",
|
||||||
"repo": "rcourtman/Pulse",
|
"repo": "rcourtman/Pulse",
|
||||||
"version": "v5.1.18",
|
"version": "v5.1.19",
|
||||||
"pinned": false,
|
"pinned": false,
|
||||||
"date": "2026-03-03T22:09:15Z"
|
"date": "2026-03-05T11:14:54Z"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"slug": "pve-scripts-local",
|
"slug": "pve-scripts-local",
|
||||||
@@ -1355,9 +1355,9 @@
|
|||||||
{
|
{
|
||||||
"slug": "scanopy",
|
"slug": "scanopy",
|
||||||
"repo": "scanopy/scanopy",
|
"repo": "scanopy/scanopy",
|
||||||
"version": "v0.14.11",
|
"version": "v0.14.12",
|
||||||
"pinned": false,
|
"pinned": false,
|
||||||
"date": "2026-03-02T08:48:42Z"
|
"date": "2026-03-05T07:24:59Z"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"slug": "scraparr",
|
"slug": "scraparr",
|
||||||
@@ -1369,9 +1369,9 @@
|
|||||||
{
|
{
|
||||||
"slug": "seaweedfs",
|
"slug": "seaweedfs",
|
||||||
"repo": "seaweedfs/seaweedfs",
|
"repo": "seaweedfs/seaweedfs",
|
||||||
"version": "4.13",
|
"version": "4.15",
|
||||||
"pinned": false,
|
"pinned": false,
|
||||||
"date": "2026-02-17T01:09:45Z"
|
"date": "2026-03-05T06:30:30Z"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"slug": "seelf",
|
"slug": "seelf",
|
||||||
@@ -1474,9 +1474,9 @@
|
|||||||
{
|
{
|
||||||
"slug": "stirling-pdf",
|
"slug": "stirling-pdf",
|
||||||
"repo": "Stirling-Tools/Stirling-PDF",
|
"repo": "Stirling-Tools/Stirling-PDF",
|
||||||
"version": "v2.5.3",
|
"version": "v2.6.0",
|
||||||
"pinned": false,
|
"pinned": false,
|
||||||
"date": "2026-02-23T23:23:39Z"
|
"date": "2026-03-03T20:46:42Z"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"slug": "streamlink-webui",
|
"slug": "streamlink-webui",
|
||||||
@@ -1565,9 +1565,9 @@
|
|||||||
{
|
{
|
||||||
"slug": "tinyauth",
|
"slug": "tinyauth",
|
||||||
"repo": "steveiliop56/tinyauth",
|
"repo": "steveiliop56/tinyauth",
|
||||||
"version": "v5.0.0",
|
"version": "v5.0.1",
|
||||||
"pinned": false,
|
"pinned": false,
|
||||||
"date": "2026-03-02T18:43:57Z"
|
"date": "2026-03-04T21:05:05Z"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"slug": "traccar",
|
"slug": "traccar",
|
||||||
@@ -1607,9 +1607,9 @@
|
|||||||
{
|
{
|
||||||
"slug": "trip",
|
"slug": "trip",
|
||||||
"repo": "itskovacs/TRIP",
|
"repo": "itskovacs/TRIP",
|
||||||
"version": "1.41.0",
|
"version": "1.41.1",
|
||||||
"pinned": false,
|
"pinned": false,
|
||||||
"date": "2026-02-23T17:57:31Z"
|
"date": "2026-03-04T07:25:35Z"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"slug": "tududi",
|
"slug": "tududi",
|
||||||
@@ -1663,9 +1663,9 @@
|
|||||||
{
|
{
|
||||||
"slug": "uptimekuma",
|
"slug": "uptimekuma",
|
||||||
"repo": "louislam/uptime-kuma",
|
"repo": "louislam/uptime-kuma",
|
||||||
"version": "2.1.3",
|
"version": "2.2.0",
|
||||||
"pinned": false,
|
"pinned": false,
|
||||||
"date": "2026-02-19T05:37:30Z"
|
"date": "2026-03-05T02:08:14Z"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"slug": "vaultwarden",
|
"slug": "vaultwarden",
|
||||||
@@ -1719,9 +1719,9 @@
|
|||||||
{
|
{
|
||||||
"slug": "watcharr",
|
"slug": "watcharr",
|
||||||
"repo": "sbondCo/Watcharr",
|
"repo": "sbondCo/Watcharr",
|
||||||
"version": "v2.1.1",
|
"version": "v3.0.0",
|
||||||
"pinned": false,
|
"pinned": false,
|
||||||
"date": "2025-07-15T22:38:01Z"
|
"date": "2026-03-04T09:29:14Z"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"slug": "watchyourlan",
|
"slug": "watchyourlan",
|
||||||
@@ -1824,9 +1824,9 @@
|
|||||||
{
|
{
|
||||||
"slug": "zitadel",
|
"slug": "zitadel",
|
||||||
"repo": "zitadel/zitadel",
|
"repo": "zitadel/zitadel",
|
||||||
"version": "v4.12.0",
|
"version": "v4.12.1",
|
||||||
"pinned": false,
|
"pinned": false,
|
||||||
"date": "2026-03-02T08:16:10Z"
|
"date": "2026-03-04T12:40:17Z"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"slug": "zoraxy",
|
"slug": "zoraxy",
|
||||||
@@ -1838,9 +1838,9 @@
|
|||||||
{
|
{
|
||||||
"slug": "zwave-js-ui",
|
"slug": "zwave-js-ui",
|
||||||
"repo": "zwave-js/zwave-js-ui",
|
"repo": "zwave-js/zwave-js-ui",
|
||||||
"version": "v11.12.0",
|
"version": "v11.13.0",
|
||||||
"pinned": false,
|
"pinned": false,
|
||||||
"date": "2026-02-19T10:14:19Z"
|
"date": "2026-03-04T15:09:54Z"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|||||||
56
frontend/public/json/papra.json
Normal file
56
frontend/public/json/papra.json
Normal file
@@ -0,0 +1,56 @@
|
|||||||
|
{
|
||||||
|
"name": "Papra",
|
||||||
|
"slug": "papra",
|
||||||
|
"categories": [
|
||||||
|
12
|
||||||
|
],
|
||||||
|
"date_created": "2026-03-05",
|
||||||
|
"type": "ct",
|
||||||
|
"updateable": true,
|
||||||
|
"privileged": false,
|
||||||
|
"interface_port": 1221,
|
||||||
|
"documentation": "https://github.com/CorentinTh/papra",
|
||||||
|
"website": "https://github.com/CorentinTh/papra",
|
||||||
|
"logo": "https://cdn.jsdelivr.net/gh/selfhst/icons@main/webp/papra.webp",
|
||||||
|
"config_path": "/opt/papra/.env",
|
||||||
|
"description": "Papra is a modern, self-hosted document management system with full-text search, OCR support, and automatic document processing. Built with Node.js and featuring a clean web interface for organizing and managing your documents.",
|
||||||
|
"install_methods": [
|
||||||
|
{
|
||||||
|
"type": "default",
|
||||||
|
"script": "ct/papra.sh",
|
||||||
|
"resources": {
|
||||||
|
"cpu": 2,
|
||||||
|
"ram": 2048,
|
||||||
|
"hdd": 10,
|
||||||
|
"os": "debian",
|
||||||
|
"version": "13"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"default_credentials": {
|
||||||
|
"username": null,
|
||||||
|
"password": null
|
||||||
|
},
|
||||||
|
"notes": [
|
||||||
|
{
|
||||||
|
"text": "First visit will prompt you to create an account",
|
||||||
|
"type": "info"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"text": "Tesseract OCR is pre-installed for all languages",
|
||||||
|
"type": "info"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"text": "Documents are stored in /opt/papra/app-data/documents",
|
||||||
|
"type": "info"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"text": "Ingestion folder available at /opt/papra/ingestion for automatic document import",
|
||||||
|
"type": "info"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"text": "Email functionality runs in dry-run mode by default",
|
||||||
|
"type": "warning"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
37
install/ddclient-install.sh
Normal file
37
install/ddclient-install.sh
Normal file
@@ -0,0 +1,37 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
# Copyright (c) 2021-2026 mitchscobell
|
||||||
|
# Author: mitchscobell
|
||||||
|
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
|
||||||
|
# Source: https://ddclient.net/
|
||||||
|
|
||||||
|
source /dev/stdin <<<"$FUNCTIONS_FILE_PATH"
|
||||||
|
color
|
||||||
|
verb_ip6
|
||||||
|
catch_errors
|
||||||
|
setting_up_container
|
||||||
|
network_check
|
||||||
|
update_os
|
||||||
|
|
||||||
|
msg_info "Installing ddclient"
|
||||||
|
DEBIAN_FRONTEND=noninteractive $STD apt -o Dpkg::Options::="--force-confdef" -o Dpkg::Options::="--force-confold" install -y ddclient
|
||||||
|
msg_ok "Installed ddclient"
|
||||||
|
|
||||||
|
msg_info "Creating ddclient service"
|
||||||
|
cat << EOF >/etc/ddclient.conf
|
||||||
|
protocol=namecheap
|
||||||
|
use=web, web=dynamicdns.park-your-domain.com/getip
|
||||||
|
protocol=namecheap
|
||||||
|
use=web, web=dynamicdns.park-your-domain.com/getip
|
||||||
|
server=dynamicdns.park-your-domain.com
|
||||||
|
login=yourdomain.com
|
||||||
|
password='your-ddns-password'
|
||||||
|
@,www
|
||||||
|
EOF
|
||||||
|
chmod 600 /etc/ddclient.conf
|
||||||
|
systemctl enable -q --now ddclient
|
||||||
|
msg_ok "Created ddclient service"
|
||||||
|
|
||||||
|
motd_ssh
|
||||||
|
customize
|
||||||
|
cleanup_lxc
|
||||||
@@ -26,6 +26,17 @@ fetch_and_deploy_gh_release "docmost" "docmost/docmost" "tarball"
|
|||||||
|
|
||||||
msg_info "Configuring Docmost (Patience)"
|
msg_info "Configuring Docmost (Patience)"
|
||||||
cd /opt/docmost
|
cd /opt/docmost
|
||||||
|
|
||||||
|
# Fix: Docmost EE (audit logs etc.) lives in a git submodule that is NOT
|
||||||
|
# included in GitHub tarballs. The community NoopAuditService exists but
|
||||||
|
# is only exported by CoreModule – child modules such as UserModule cannot
|
||||||
|
# resolve it. Making CoreModule @Global() exposes the token app-wide.
|
||||||
|
if [[ ! -f /opt/docmost/apps/server/src/ee/ee.module.ts ]] \
|
||||||
|
&& ! grep -q '@Global()' /opt/docmost/apps/server/src/core/core.module.ts 2>/dev/null; then
|
||||||
|
sed -i '/^ Module,$/a\ Global,' /opt/docmost/apps/server/src/core/core.module.ts
|
||||||
|
sed -i '/^@Module({$/i @Global()' /opt/docmost/apps/server/src/core/core.module.ts
|
||||||
|
fi
|
||||||
|
|
||||||
mv .env.example .env
|
mv .env.example .env
|
||||||
mkdir data
|
mkdir data
|
||||||
sed -i -e "s|APP_SECRET=.*|APP_SECRET=$(openssl rand -base64 32 | tr -dc 'a-zA-Z0-9' | cut -c1-32)|" \
|
sed -i -e "s|APP_SECRET=.*|APP_SECRET=$(openssl rand -base64 32 | tr -dc 'a-zA-Z0-9' | cut -c1-32)|" \
|
||||||
|
|||||||
@@ -19,7 +19,7 @@ msg_ok "Installed Dependencies"
|
|||||||
|
|
||||||
PG_VERSION="17" setup_postgresql
|
PG_VERSION="17" setup_postgresql
|
||||||
PG_DB_NAME="fluiddb" PG_DB_USER="fluiduser" setup_postgresql_db
|
PG_DB_NAME="fluiddb" PG_DB_USER="fluiduser" setup_postgresql_db
|
||||||
NODE_VERSION="20" setup_nodejs
|
NODE_VERSION="24" setup_nodejs
|
||||||
fetch_and_deploy_gh_release "fluid-calendar" "dotnetfactory/fluid-calendar" "tarball"
|
fetch_and_deploy_gh_release "fluid-calendar" "dotnetfactory/fluid-calendar" "tarball"
|
||||||
|
|
||||||
msg_info "Configuring fluid-calendar"
|
msg_info "Configuring fluid-calendar"
|
||||||
|
|||||||
@@ -18,7 +18,8 @@ $STD apt install -y \
|
|||||||
build-essential \
|
build-essential \
|
||||||
openssl \
|
openssl \
|
||||||
sqlite3 \
|
sqlite3 \
|
||||||
unzip
|
unzip \
|
||||||
|
git
|
||||||
msg_ok "Installed Dependencies"
|
msg_ok "Installed Dependencies"
|
||||||
|
|
||||||
msg_info "Installing Bun"
|
msg_info "Installing Bun"
|
||||||
|
|||||||
@@ -20,24 +20,8 @@ $STD apt install -y \
|
|||||||
msg_ok "Installed Dependencies"
|
msg_ok "Installed Dependencies"
|
||||||
|
|
||||||
PG_VERSION="17" setup_postgresql
|
PG_VERSION="17" setup_postgresql
|
||||||
PYTHON_VERSION="3.13" setup_uv
|
PG_DB_NAME="litellm_db" PG_DB_USER="litellm" setup_postgresql_db
|
||||||
|
PYTHON_VERSION="3.13" USE_UVX="YES" setup_uv
|
||||||
msg_info "Setting up PostgreSQL"
|
|
||||||
DB_NAME="litellm_db"
|
|
||||||
DB_USER="litellm"
|
|
||||||
DB_PASS="$(openssl rand -base64 18 | tr -dc 'a-zA-Z0-9' | cut -c1-13)"
|
|
||||||
$STD sudo -u postgres psql -c "CREATE ROLE $DB_USER WITH LOGIN PASSWORD '$DB_PASS';"
|
|
||||||
$STD sudo -u postgres psql -c "CREATE DATABASE $DB_NAME WITH OWNER $DB_USER ENCODING 'UTF8' TEMPLATE template0;"
|
|
||||||
$STD sudo -u postgres psql -c "ALTER ROLE $DB_USER SET client_encoding TO 'utf8';"
|
|
||||||
$STD sudo -u postgres psql -c "ALTER ROLE $DB_USER SET default_transaction_isolation TO 'read committed';"
|
|
||||||
$STD sudo -u postgres psql -c "ALTER ROLE $DB_USER SET timezone TO 'UTC';"
|
|
||||||
{
|
|
||||||
echo "${APPLICATION} Credentials"
|
|
||||||
echo "Database Name: $DB_NAME"
|
|
||||||
echo "Database User: $DB_USER"
|
|
||||||
echo "Database Password: $DB_PASS"
|
|
||||||
} >>~/litellm.creds
|
|
||||||
msg_ok "Set up PostgreSQL"
|
|
||||||
|
|
||||||
msg_info "Setting up Virtual Environment"
|
msg_info "Setting up Virtual Environment"
|
||||||
mkdir -p /opt/litellm
|
mkdir -p /opt/litellm
|
||||||
@@ -53,10 +37,9 @@ mkdir -p /opt
|
|||||||
cat <<EOF >/opt/litellm/litellm.yaml
|
cat <<EOF >/opt/litellm/litellm.yaml
|
||||||
general_settings:
|
general_settings:
|
||||||
master_key: sk-1234
|
master_key: sk-1234
|
||||||
database_url: postgresql://$DB_USER:$DB_PASS@127.0.0.1:5432/$DB_NAME
|
database_url: postgresql://$PG_DB_USER:$PG_DB_PASS@127.0.0.1:5432/$PG_DB_NAME
|
||||||
store_model_in_db: true
|
store_model_in_db: true
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
uv --directory=/opt/litellm run litellm --config /opt/litellm/litellm.yaml --use_prisma_db_push --skip_server_startup
|
uv --directory=/opt/litellm run litellm --config /opt/litellm/litellm.yaml --use_prisma_db_push --skip_server_startup
|
||||||
msg_ok "Configured LiteLLM"
|
msg_ok "Configured LiteLLM"
|
||||||
|
|
||||||
@@ -73,7 +56,6 @@ Restart=always
|
|||||||
[Install]
|
[Install]
|
||||||
WantedBy=multi-user.target
|
WantedBy=multi-user.target
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
systemctl enable -q --now litellm
|
systemctl enable -q --now litellm
|
||||||
msg_ok "Created Service"
|
msg_ok "Created Service"
|
||||||
|
|
||||||
|
|||||||
79
install/papra-install.sh
Normal file
79
install/papra-install.sh
Normal file
@@ -0,0 +1,79 @@
|
|||||||
|
#!/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/papra-hq/papra
|
||||||
|
|
||||||
|
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 \
|
||||||
|
build-essential \
|
||||||
|
tesseract-ocr \
|
||||||
|
tesseract-ocr-all
|
||||||
|
msg_ok "Installed Dependencies"
|
||||||
|
|
||||||
|
RELEASE=$(curl -fsSL https://api.github.com/repos/papra-hq/papra/releases | grep -oP '"tag_name":\s*"\K@papra/app@[^"]+' | head -n1)
|
||||||
|
fetch_and_deploy_gh_release "papra" "papra-hq/papra" "tarball" "${RELEASE}" "/opt/papra"
|
||||||
|
|
||||||
|
pnpm_version=$(grep -oP '"packageManager":\s*"pnpm@\K[^"]+' /opt/papra/package.json)
|
||||||
|
NODE_VERSION="24" NODE_MODULE="pnpm@$pnpm_version" setup_nodejs
|
||||||
|
|
||||||
|
msg_info "Installing Papra (Patience)"
|
||||||
|
cd /opt/papra
|
||||||
|
$STD pnpm install --frozen-lockfile
|
||||||
|
$STD pnpm --filter "@papra/app-client..." run build
|
||||||
|
$STD pnpm --filter "@papra/app-server..." run build
|
||||||
|
ln -sf /opt/papra/apps/papra-client/dist /opt/papra/apps/papra-server/public
|
||||||
|
msg_ok "Installed Papra"
|
||||||
|
|
||||||
|
msg_info "Configuring Papra"
|
||||||
|
mkdir -p /opt/papra_data/{db,documents,ingestion}
|
||||||
|
[[ ! -f /opt/papra_data/.secret ]] && openssl rand -hex 32 >/opt/papra_data/.secret
|
||||||
|
cat <<EOF >/opt/papra/apps/papra-server/.env
|
||||||
|
NODE_ENV=production
|
||||||
|
SERVER_SERVE_PUBLIC_DIR=true
|
||||||
|
PORT=1221
|
||||||
|
DATABASE_URL=file:/opt/papra_data/db/db.sqlite
|
||||||
|
DOCUMENT_STORAGE_FILESYSTEM_ROOT=/opt/papra_data/documents
|
||||||
|
PAPRA_CONFIG_DIR=/opt/papra_data
|
||||||
|
AUTH_SECRET=$(cat /opt/papra_data/.secret)
|
||||||
|
BETTER_AUTH_SECRET=$(cat /opt/papra_data/.secret)
|
||||||
|
BETTER_AUTH_TELEMETRY=0
|
||||||
|
CLIENT_BASE_URL=http://${LOCAL_IP}:1221
|
||||||
|
SERVER_BASE_URL=http://${LOCAL_IP}:1221
|
||||||
|
EMAILS_DRY_RUN=true
|
||||||
|
INGESTION_FOLDER_IS_ENABLED=true
|
||||||
|
INGESTION_FOLDER_ROOT_PATH=/opt/papra_data/ingestion
|
||||||
|
EOF
|
||||||
|
msg_ok "Configured Papra"
|
||||||
|
|
||||||
|
msg_info "Creating Service"
|
||||||
|
cat <<EOF >/etc/systemd/system/papra.service
|
||||||
|
[Unit]
|
||||||
|
Description=Papra Document Management
|
||||||
|
After=network.target
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
Type=simple
|
||||||
|
WorkingDirectory=/opt/papra/apps/papra-server
|
||||||
|
EnvironmentFile=/opt/papra/apps/papra-server/.env
|
||||||
|
ExecStartPre=/usr/bin/pnpm run migrate:up
|
||||||
|
ExecStart=/usr/bin/node dist/index.js
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
||||||
|
EOF
|
||||||
|
systemctl enable -q --now papra
|
||||||
|
msg_ok "Created Service"
|
||||||
|
|
||||||
|
motd_ssh
|
||||||
|
customize
|
||||||
|
cleanup_lxc
|
||||||
@@ -38,6 +38,12 @@ msg_info "Setting up PowerDNS"
|
|||||||
$STD apt install -y \
|
$STD apt install -y \
|
||||||
pdns-server \
|
pdns-server \
|
||||||
pdns-backend-sqlite3
|
pdns-backend-sqlite3
|
||||||
|
sed -i 's/^launch=$/# launch=/' /etc/powerdns/pdns.conf
|
||||||
|
rm -f /etc/powerdns/pdns.d/bind.conf
|
||||||
|
cat <<EOF >/etc/powerdns/pdns.d/gsqlite3.conf
|
||||||
|
launch+=gsqlite3
|
||||||
|
gsqlite3-database=/opt/poweradmin/powerdns.db
|
||||||
|
EOF
|
||||||
msg_ok "Setup PowerDNS"
|
msg_ok "Setup PowerDNS"
|
||||||
|
|
||||||
fetch_and_deploy_gh_release "poweradmin" "poweradmin/poweradmin" "tarball"
|
fetch_and_deploy_gh_release "poweradmin" "poweradmin/poweradmin" "tarball"
|
||||||
@@ -125,9 +131,13 @@ cat <<EOF >/etc/apache2/sites-enabled/poweradmin.conf
|
|||||||
</VirtualHost>
|
</VirtualHost>
|
||||||
EOF
|
EOF
|
||||||
$STD a2enmod rewrite headers
|
$STD a2enmod rewrite headers
|
||||||
chown -R www-data:www-data /opt/poweradmin
|
chown -R www-data:pdns /opt/poweradmin
|
||||||
$STD systemctl restart apache2
|
chmod 775 /opt/poweradmin
|
||||||
msg_info "Created Service"
|
chown pdns:pdns /opt/poweradmin/powerdns.db
|
||||||
|
chmod 664 /opt/poweradmin/powerdns.db
|
||||||
|
usermod -aG pdns www-data
|
||||||
|
$STD systemctl restart pdns apache2
|
||||||
|
msg_ok "Created Service"
|
||||||
|
|
||||||
motd_ssh
|
motd_ssh
|
||||||
customize
|
customize
|
||||||
|
|||||||
@@ -31,7 +31,7 @@ $STD apt install -y \
|
|||||||
msg_ok "Installed Dependencies"
|
msg_ok "Installed Dependencies"
|
||||||
|
|
||||||
PYTHON_VERSION="3.12" setup_uv
|
PYTHON_VERSION="3.12" setup_uv
|
||||||
JAVA_VERSION="21" setup_java
|
JAVA_VERSION="25" setup_java
|
||||||
|
|
||||||
read -r -p "${TAB3}Do you want to use Stirling-PDF with Login? (no/n = without Login) [Y/n] " response
|
read -r -p "${TAB3}Do you want to use Stirling-PDF with Login? (no/n = without Login) [Y/n] " response
|
||||||
response=${response,,} # Convert to lowercase
|
response=${response,,} # Convert to lowercase
|
||||||
|
|||||||
@@ -3617,16 +3617,16 @@ build_container() {
|
|||||||
$PCT_OPTIONS_STRING"
|
$PCT_OPTIONS_STRING"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Add storage if specified
|
# Add searchdomain if specified
|
||||||
if [ -n "$SD" ]; then
|
if [ -n "$SD" ]; then
|
||||||
PCT_OPTIONS_STRING="$PCT_OPTIONS_STRING
|
PCT_OPTIONS_STRING="$PCT_OPTIONS_STRING
|
||||||
-searchdomain $SD"
|
$SD"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Add nameserver if specified
|
# Add nameserver if specified
|
||||||
if [ -n "$NS" ]; then
|
if [ -n "$NS" ]; then
|
||||||
PCT_OPTIONS_STRING="$PCT_OPTIONS_STRING
|
PCT_OPTIONS_STRING="$PCT_OPTIONS_STRING
|
||||||
-nameserver $NS"
|
$NS"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Network configuration
|
# Network configuration
|
||||||
|
|||||||
@@ -6500,14 +6500,13 @@ function setup_postgresql() {
|
|||||||
local SUITE
|
local SUITE
|
||||||
case "$DISTRO_CODENAME" in
|
case "$DISTRO_CODENAME" in
|
||||||
trixie | forky | sid)
|
trixie | forky | sid)
|
||||||
|
|
||||||
if verify_repo_available "https://apt.postgresql.org/pub/repos/apt" "trixie-pgdg"; then
|
if verify_repo_available "https://apt.postgresql.org/pub/repos/apt" "trixie-pgdg"; then
|
||||||
SUITE="trixie-pgdg"
|
SUITE="trixie-pgdg"
|
||||||
|
|
||||||
else
|
else
|
||||||
SUITE="bookworm-pgdg"
|
msg_warn "PGDG repo not available for ${DISTRO_CODENAME}, falling back to distro packages"
|
||||||
|
USE_PGDG_REPO=false setup_postgresql
|
||||||
|
return $?
|
||||||
fi
|
fi
|
||||||
|
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
SUITE=$(get_fallback_suite "$DISTRO_ID" "$DISTRO_CODENAME" "https://apt.postgresql.org/pub/repos/apt")
|
SUITE=$(get_fallback_suite "$DISTRO_ID" "$DISTRO_CODENAME" "https://apt.postgresql.org/pub/repos/apt")
|
||||||
|
|||||||
Reference in New Issue
Block a user