mirror of
https://github.com/community-scripts/ProxmoxVE.git
synced 2026-06-30 03:05:00 +02:00
Compare commits
3 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 2ec1eda7f5 | |||
| b52eab2114 | |||
| 43216917e3 |
+1
-17
@@ -493,23 +493,7 @@ Exercise vigilance regarding copycat or coat-tailing sites that seek to exploit
|
|||||||
|
|
||||||
### 🆕 New Scripts
|
### 🆕 New Scripts
|
||||||
|
|
||||||
- Koffan ([#15467](https://github.com/community-scripts/ProxmoxVE/pull/15467))
|
- Flame ([#15464](https://github.com/community-scripts/ProxmoxVE/pull/15464))
|
||||||
- Etherpad ([#15468](https://github.com/community-scripts/ProxmoxVE/pull/15468))
|
|
||||||
- Flame ([#15464](https://github.com/community-scripts/ProxmoxVE/pull/15464))
|
|
||||||
|
|
||||||
### 🚀 Updated Scripts
|
|
||||||
|
|
||||||
- chore(ct): sync snapotter defaults with PocketBase [@github-actions[bot]](https://github.com/github-actions[bot]) ([#15472](https://github.com/community-scripts/ProxmoxVE/pull/15472))
|
|
||||||
|
|
||||||
- #### 🐞 Bug Fixes
|
|
||||||
|
|
||||||
- feat: update nginx proxy manager to trixie [@asylumexp](https://github.com/asylumexp) ([#15457](https://github.com/community-scripts/ProxmoxVE/pull/15457))
|
|
||||||
|
|
||||||
### 💾 Core
|
|
||||||
|
|
||||||
- #### ✨ New Features
|
|
||||||
|
|
||||||
- [tools.func]: add edit_yaml_config function [@tremor021](https://github.com/tremor021) ([#15484](https://github.com/community-scripts/ProxmoxVE/pull/15484))
|
|
||||||
|
|
||||||
## 2026-06-28
|
## 2026-06-28
|
||||||
|
|
||||||
|
|||||||
@@ -1,6 +0,0 @@
|
|||||||
__ __ ________
|
|
||||||
/ //_/___ / __/ __/___ _____
|
|
||||||
/ ,< / __ \/ /_/ /_/ __ `/ __ \
|
|
||||||
/ /| / /_/ / __/ __/ /_/ / / / /
|
|
||||||
/_/ |_\____/_/ /_/ \__,_/_/ /_/
|
|
||||||
|
|
||||||
@@ -1,63 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
source <(curl -s https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/build.func)
|
|
||||||
# Copyright (c) 2021-2026 community-scripts ORG
|
|
||||||
# Author: (AminGholizad)
|
|
||||||
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
|
|
||||||
# Source: https://github.com/PanSalut/Koffan
|
|
||||||
|
|
||||||
APP="Koffan"
|
|
||||||
var_tags="${var_tags:-productivity}"
|
|
||||||
var_cpu="${var_cpu:-1}"
|
|
||||||
var_ram="${var_ram:-1024}"
|
|
||||||
var_disk="${var_disk:-4}"
|
|
||||||
var_os="${var_os:-debian}"
|
|
||||||
var_version="${var_version:-13}"
|
|
||||||
var_arm64="${var_arm64:-yes}"
|
|
||||||
var_arm64="${var_arm64:-no}"
|
|
||||||
var_unprivileged="${var_unprivileged:-1}"
|
|
||||||
|
|
||||||
header_info "$APP"
|
|
||||||
variables
|
|
||||||
color
|
|
||||||
catch_errors
|
|
||||||
|
|
||||||
function update_script() {
|
|
||||||
header_info
|
|
||||||
check_container_storage
|
|
||||||
check_container_resources
|
|
||||||
|
|
||||||
if [[ ! -f /opt/koffan/koffan ]]; then
|
|
||||||
msg_error "No ${APP} Installation Found!"
|
|
||||||
exit
|
|
||||||
fi
|
|
||||||
|
|
||||||
if check_for_gh_release "koffan" "PanSalut/Koffan"; then
|
|
||||||
msg_info "Stopping Service"
|
|
||||||
systemctl stop koffan
|
|
||||||
msg_ok "Stopped Service"
|
|
||||||
|
|
||||||
create_backup /opt/koffan/data
|
|
||||||
CLEAN_INSTALL=1 fetch_and_deploy_gh_release "koffan" "PanSalut/Koffan" "tarball"
|
|
||||||
restore_backup
|
|
||||||
|
|
||||||
msg_info "Rebuilding Koffan"
|
|
||||||
cd /opt/koffan
|
|
||||||
$STD go build -o koffan main.go
|
|
||||||
msg_ok "Rebuild Koffan"
|
|
||||||
|
|
||||||
msg_info "Starting Service"
|
|
||||||
systemctl start koffan
|
|
||||||
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}:3000${CL}"
|
|
||||||
@@ -11,7 +11,7 @@ var_cpu="${var_cpu:-2}"
|
|||||||
var_ram="${var_ram:-2048}"
|
var_ram="${var_ram:-2048}"
|
||||||
var_disk="${var_disk:-8}"
|
var_disk="${var_disk:-8}"
|
||||||
var_os="${var_os:-debian}"
|
var_os="${var_os:-debian}"
|
||||||
var_version="${var_version:-13}"
|
var_version="${var_version:-12}"
|
||||||
var_arm64="${var_arm64:-yes}"
|
var_arm64="${var_arm64:-yes}"
|
||||||
var_unprivileged="${var_unprivileged:-1}"
|
var_unprivileged="${var_unprivileged:-1}"
|
||||||
|
|
||||||
@@ -60,9 +60,8 @@ function update_script() {
|
|||||||
fi
|
fi
|
||||||
$STD apt install -y build-essential "$pcre_pkg" libssl-dev zlib1g-dev
|
$STD apt install -y build-essential "$pcre_pkg" libssl-dev zlib1g-dev
|
||||||
|
|
||||||
OPENRESTY_VERSION="1.29.2.5"
|
if check_for_gh_release "openresty" "openresty/openresty"; then
|
||||||
if [[ "$(cat ~/.openresty 2>/dev/null)" != "$OPENRESTY_VERSION" ]]; then
|
CLEAN_INSTALL=1 fetch_and_deploy_gh_release "openresty" "openresty/openresty" "prebuild" "${CHECK_UPDATE_RELEASE}" "/opt/openresty" "openresty-*.tar.gz"
|
||||||
CLEAN_INSTALL=1 fetch_and_deploy_from_url "https://openresty.org/download/openresty-${OPENRESTY_VERSION}.tar.gz" "/opt/openresty"
|
|
||||||
|
|
||||||
msg_info "Building OpenResty"
|
msg_info "Building OpenResty"
|
||||||
cd /opt/openresty
|
cd /opt/openresty
|
||||||
@@ -78,7 +77,6 @@ function update_script() {
|
|||||||
--with-stream_ssl_module
|
--with-stream_ssl_module
|
||||||
$STD make -j"$(nproc)"
|
$STD make -j"$(nproc)"
|
||||||
$STD make install
|
$STD make install
|
||||||
echo "${OPENRESTY_VERSION}" >~/.openresty
|
|
||||||
rm -rf /opt/openresty
|
rm -rf /opt/openresty
|
||||||
cat <<'EOF' >/lib/systemd/system/openresty.service
|
cat <<'EOF' >/lib/systemd/system/openresty.service
|
||||||
[Unit]
|
[Unit]
|
||||||
|
|||||||
+1
-1
@@ -8,7 +8,7 @@ source <(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxV
|
|||||||
APP="SnapOtter"
|
APP="SnapOtter"
|
||||||
var_tags="${var_tags:-media;image}"
|
var_tags="${var_tags:-media;image}"
|
||||||
var_cpu="${var_cpu:-2}"
|
var_cpu="${var_cpu:-2}"
|
||||||
var_ram="${var_ram:-4096}"
|
var_ram="${var_ram:-2048}"
|
||||||
var_disk="${var_disk:-20}"
|
var_disk="${var_disk:-20}"
|
||||||
var_os="${var_os:-debian}"
|
var_os="${var_os:-debian}"
|
||||||
var_version="${var_version:-13}"
|
var_version="${var_version:-13}"
|
||||||
|
|||||||
@@ -1,62 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
|
|
||||||
# Copyright (c) 2021-2026 community-scripts ORG
|
|
||||||
# Author: (AminGholizad)
|
|
||||||
# License: MIT | https://github.com/AminGholizad/ProxmoxVED/raw/main/LICENSE
|
|
||||||
# Source: https://github.com/PanSalut/Koffan
|
|
||||||
|
|
||||||
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
|
|
||||||
msg_ok "Installed Dependencies"
|
|
||||||
|
|
||||||
setup_go
|
|
||||||
fetch_and_deploy_gh_release "koffan" "PanSalut/Koffan" "tarball"
|
|
||||||
|
|
||||||
msg_info "Building Koffan"
|
|
||||||
cd /opt/koffan
|
|
||||||
$STD go build -o koffan main.go
|
|
||||||
msg_ok "Built Koffan"
|
|
||||||
|
|
||||||
msg_info "Configuring Koffan"
|
|
||||||
APP_PASSWD=$(openssl rand -base64 12)
|
|
||||||
mkdir /opt/koffan/data
|
|
||||||
cat <<EOF >/opt/koffan/data/.env
|
|
||||||
APP_ENV=production
|
|
||||||
APP_PASSWORD=${APP_PASSWD}
|
|
||||||
PORT=3000
|
|
||||||
DB_PATH=/opt/koffan/data/shopping.db
|
|
||||||
EOF
|
|
||||||
cat <<EOF >~/koffan.creds
|
|
||||||
Password: ${APP_PASSWD}
|
|
||||||
EOF
|
|
||||||
msg_ok "Configured Koffan"
|
|
||||||
|
|
||||||
msg_info "Creating systemd service"
|
|
||||||
cat <<EOF >/etc/systemd/system/koffan.service
|
|
||||||
[Unit]
|
|
||||||
Description=Koffan Service
|
|
||||||
After=network.target
|
|
||||||
|
|
||||||
[Service]
|
|
||||||
EnvironmentFile=/opt/koffan/data/.env
|
|
||||||
WorkingDirectory=/opt/koffan
|
|
||||||
ExecStart=/opt/koffan/koffan
|
|
||||||
Restart=always
|
|
||||||
|
|
||||||
[Install]
|
|
||||||
WantedBy=multi-user.target
|
|
||||||
EOF
|
|
||||||
systemctl enable -q --now koffan
|
|
||||||
msg_ok "Created systemd service"
|
|
||||||
|
|
||||||
motd_ssh
|
|
||||||
customize
|
|
||||||
cleanup_lxc
|
|
||||||
@@ -18,7 +18,7 @@ $STD apt install -y \
|
|||||||
apache2-utils \
|
apache2-utils \
|
||||||
logrotate \
|
logrotate \
|
||||||
build-essential \
|
build-essential \
|
||||||
libpcre2-dev \
|
libpcre3-dev \
|
||||||
libssl-dev \
|
libssl-dev \
|
||||||
zlib1g-dev \
|
zlib1g-dev \
|
||||||
git \
|
git \
|
||||||
@@ -36,8 +36,7 @@ $STD /opt/certbot/bin/pip install certbot certbot-dns-cloudflare
|
|||||||
ln -sf /opt/certbot/bin/certbot /usr/local/bin/certbot
|
ln -sf /opt/certbot/bin/certbot /usr/local/bin/certbot
|
||||||
msg_ok "Set up Certbot"
|
msg_ok "Set up Certbot"
|
||||||
|
|
||||||
OPENRESTY_VERSION="1.29.2.5"
|
fetch_and_deploy_gh_release "openresty" "openresty/openresty" "prebuild" "latest" "/opt/openresty" "openresty-*.tar.gz"
|
||||||
fetch_and_deploy_from_url "https://openresty.org/download/openresty-${OPENRESTY_VERSION}.tar.gz" "/opt/openresty"
|
|
||||||
|
|
||||||
msg_info "Building OpenResty"
|
msg_info "Building OpenResty"
|
||||||
cd /opt/openresty
|
cd /opt/openresty
|
||||||
@@ -53,7 +52,6 @@ $STD ./configure \
|
|||||||
--with-stream_ssl_module
|
--with-stream_ssl_module
|
||||||
$STD make -j"$(nproc)"
|
$STD make -j"$(nproc)"
|
||||||
$STD make install
|
$STD make install
|
||||||
echo "${OPENRESTY_VERSION}" >~/.openresty
|
|
||||||
rm -rf /opt/openresty
|
rm -rf /opt/openresty
|
||||||
|
|
||||||
cat <<'EOF' >/lib/systemd/system/openresty.service
|
cat <<'EOF' >/lib/systemd/system/openresty.service
|
||||||
|
|||||||
@@ -20,11 +20,6 @@ $STD apt install -y \
|
|||||||
potrace \
|
potrace \
|
||||||
libopenjp2-tools \
|
libopenjp2-tools \
|
||||||
libegl1 \
|
libegl1 \
|
||||||
libgl1 \
|
|
||||||
libglib2.0-0 \
|
|
||||||
libsm6 \
|
|
||||||
libxext6 \
|
|
||||||
libxrender1 \
|
|
||||||
libwayland-client0 \
|
libwayland-client0 \
|
||||||
libwayland-cursor0 \
|
libwayland-cursor0 \
|
||||||
libwayland-egl1 \
|
libwayland-egl1 \
|
||||||
|
|||||||
@@ -266,47 +266,6 @@ download_gpg_key() {
|
|||||||
return 7
|
return 7
|
||||||
}
|
}
|
||||||
|
|
||||||
# ------------------------------------------------------------------------------
|
|
||||||
# Edit a key-value pair in a YAML configuration file.
|
|
||||||
#
|
|
||||||
# Description:
|
|
||||||
# - Finds the first occurrence of the given key in the YAML file and replaces
|
|
||||||
# its value in-place using sed.
|
|
||||||
# - Handles both quoted and unquoted values on the same line.
|
|
||||||
# - The key is matched at the start of a line (optionally preceded by spaces),
|
|
||||||
# followed by a colon and optional whitespace.
|
|
||||||
# - If the key is not found, the function exits with a non-zero status and
|
|
||||||
# prints an error message.
|
|
||||||
#
|
|
||||||
# Usage:
|
|
||||||
# edit_yaml_config "/opt/myapp/config.yml" "database_host" "localhost"
|
|
||||||
# edit_yaml_config "/opt/myapp/config.yml" "port" "5432"
|
|
||||||
#
|
|
||||||
# Parameters:
|
|
||||||
# $1 - Path to the YAML file
|
|
||||||
# $2 - Key to find (e.g. "database_host")
|
|
||||||
# $3 - New value to set (e.g. "localhost")
|
|
||||||
#
|
|
||||||
# Returns: 0 on success, 1 if the file does not exist or the key is not found
|
|
||||||
# ------------------------------------------------------------------------------
|
|
||||||
edit_yaml_config() {
|
|
||||||
local file="$1"
|
|
||||||
local key="$2"
|
|
||||||
local value="$3"
|
|
||||||
|
|
||||||
if [[ ! -f "$file" ]]; then
|
|
||||||
msg_error "edit_yaml_config: file not found: $file"
|
|
||||||
return 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! grep -qE "^[[:space:]]*${key}[[:space:]]*:" "$file"; then
|
|
||||||
msg_error "edit_yaml_config: key '${key}' not found in $file"
|
|
||||||
return 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
sed -i "s|^\([[:space:]]*${key}[[:space:]]*:\).*|\1 ${value}|" "$file"
|
|
||||||
}
|
|
||||||
|
|
||||||
# ------------------------------------------------------------------------------
|
# ------------------------------------------------------------------------------
|
||||||
# Cache installed version to avoid repeated checks
|
# Cache installed version to avoid repeated checks
|
||||||
# ------------------------------------------------------------------------------
|
# ------------------------------------------------------------------------------
|
||||||
|
|||||||
Reference in New Issue
Block a user