mirror of
https://github.com/community-scripts/ProxmoxVE.git
synced 2026-06-29 18:55:01 +02:00
Compare commits
6 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| dcac3e0870 | |||
| 82e3fc0d2e | |||
| 151d021f15 | |||
| 2ab62bea16 | |||
| 68b76e7b0b | |||
| 03963b5193 |
@@ -491,6 +491,12 @@ Exercise vigilance regarding copycat or coat-tailing sites that seek to exploit
|
|||||||
|
|
||||||
## 2026-06-28
|
## 2026-06-28
|
||||||
|
|
||||||
|
### 🚀 Updated Scripts
|
||||||
|
|
||||||
|
- #### 💥 Breaking Changes
|
||||||
|
|
||||||
|
- remove: promtail as EOL and other fixes [@asylumexp](https://github.com/asylumexp) ([#15455](https://github.com/community-scripts/ProxmoxVE/pull/15455))
|
||||||
|
|
||||||
## 2026-06-27
|
## 2026-06-27
|
||||||
|
|
||||||
### 🆕 New Scripts
|
### 🆕 New Scripts
|
||||||
|
|||||||
@@ -58,5 +58,3 @@ msg_ok "Completed successfully!\n"
|
|||||||
echo -e "${CREATING}${GN}${APP} setup has been successfully initialized!${CL}"
|
echo -e "${CREATING}${GN}${APP} setup has been successfully initialized!${CL}"
|
||||||
echo -e "${INFO}${YW}Access it using the following URL:${CL}"
|
echo -e "${INFO}${YW}Access it using the following URL:${CL}"
|
||||||
echo -e "${GATEWAY}${BGN}http://${IP}:3100${CL}"
|
echo -e "${GATEWAY}${BGN}http://${IP}:3100${CL}"
|
||||||
echo -e "${INFO}${YW}Access Promtail using the following URL:${CL}"
|
|
||||||
echo -e "${GATEWAY}${BGN}http://${IP}:9080${CL}"
|
|
||||||
|
|||||||
@@ -0,0 +1,6 @@
|
|||||||
|
____ __ __
|
||||||
|
/ __ \____ ______/ /____ __/ /___ _
|
||||||
|
/ /_/ / __ `/ ___/ //_/ / / / / __ `/
|
||||||
|
/ _, _/ /_/ / /__/ ,< / /_/ / / /_/ /
|
||||||
|
/_/ |_|\__,_/\___/_/|_|\__,_/_/\__,_/
|
||||||
|
|
||||||
+1
-14
@@ -31,7 +31,7 @@ function update_script() {
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
CHOICE=$(msg_menu "Loki Update Options" \
|
CHOICE=$(msg_menu "Loki Update Options" \
|
||||||
"1" "Update Loki & Promtail" \
|
"1" "Update Loki" \
|
||||||
"2" "Allow 0.0.0.0 for listening" \
|
"2" "Allow 0.0.0.0 for listening" \
|
||||||
"3" "Allow only ${LOCAL_IP} for listening")
|
"3" "Allow only ${LOCAL_IP} for listening")
|
||||||
|
|
||||||
@@ -39,24 +39,15 @@ function update_script() {
|
|||||||
1)
|
1)
|
||||||
msg_info "Stopping Loki"
|
msg_info "Stopping Loki"
|
||||||
systemctl stop loki
|
systemctl stop loki
|
||||||
if systemctl is-active --quiet promtail 2>/dev/null || dpkg -s promtail >/dev/null 2>&1; then
|
|
||||||
systemctl stop promtail
|
|
||||||
fi
|
|
||||||
msg_ok "Stopped Loki"
|
msg_ok "Stopped Loki"
|
||||||
|
|
||||||
msg_info "Updating Loki"
|
msg_info "Updating Loki"
|
||||||
$STD apt update
|
$STD apt update
|
||||||
$STD apt install -y --only-upgrade loki
|
$STD apt install -y --only-upgrade loki
|
||||||
if dpkg -s promtail >/dev/null 2>&1; then
|
|
||||||
$STD apt install -y --only-upgrade promtail
|
|
||||||
fi
|
|
||||||
msg_ok "Updated Loki"
|
msg_ok "Updated Loki"
|
||||||
|
|
||||||
msg_info "Starting Loki"
|
msg_info "Starting Loki"
|
||||||
systemctl start loki
|
systemctl start loki
|
||||||
if dpkg -s promtail >/dev/null 2>&1; then
|
|
||||||
systemctl start promtail
|
|
||||||
fi
|
|
||||||
msg_ok "Started Loki"
|
msg_ok "Started Loki"
|
||||||
msg_ok "Updated successfully!"
|
msg_ok "Updated successfully!"
|
||||||
exit
|
exit
|
||||||
@@ -89,7 +80,3 @@ msg_ok "Completed successfully!\n"
|
|||||||
echo -e "${CREATING}${GN}${APP} setup has been successfully initialized!${CL}"
|
echo -e "${CREATING}${GN}${APP} setup has been successfully initialized!${CL}"
|
||||||
echo -e "${INFO}${YW} Access loki using the following URL:${CL}"
|
echo -e "${INFO}${YW} Access loki using the following URL:${CL}"
|
||||||
echo -e "${GATEWAY}${BGN}http://${IP}:3100${CL}\n"
|
echo -e "${GATEWAY}${BGN}http://${IP}:3100${CL}\n"
|
||||||
if dpkg -s promtail >/dev/null 2>&1; then
|
|
||||||
echo -e "${INFO}${YW} Access promtail using the following URL:${CL}"
|
|
||||||
echo -e "${GATEWAY}${BGN}http://${IP}:9080${CL}"
|
|
||||||
fi
|
|
||||||
|
|||||||
@@ -235,6 +235,9 @@ EOF
|
|||||||
fi
|
fi
|
||||||
sed -i 's/user npm/user root/g; s/^pid/#pid/g' /usr/local/openresty/nginx/conf/nginx.conf
|
sed -i 's/user npm/user root/g; s/^pid/#pid/g' /usr/local/openresty/nginx/conf/nginx.conf
|
||||||
sed -r -i 's/^([[:space:]]*)su npm npm/\1#su npm npm/g;' /etc/logrotate.d/nginx-proxy-manager
|
sed -r -i 's/^([[:space:]]*)su npm npm/\1#su npm npm/g;' /etc/logrotate.d/nginx-proxy-manager
|
||||||
|
if [ -n "$(command -v node)" ]; then
|
||||||
|
sed -i -E "s|^ExecStart=.*/node index\.js|ExecStart=$(command -v node) index.js|" /lib/systemd/system/npm.service
|
||||||
|
fi
|
||||||
systemctl daemon-reload
|
systemctl daemon-reload
|
||||||
systemctl enable -q --now openresty
|
systemctl enable -q --now openresty
|
||||||
systemctl enable -q --now npm
|
systemctl enable -q --now npm
|
||||||
|
|||||||
+1
-1
@@ -39,7 +39,7 @@ function update_script() {
|
|||||||
|
|
||||||
JAVA_VERSION="21" setup_java
|
JAVA_VERSION="21" setup_java
|
||||||
|
|
||||||
OMADA_URL=$(curl -fsSL "https://support.omadanetworks.com/en/download/software/omada-controller/" |
|
OMADA_URL=$(curl -fsSL -A "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.5 Safari/605.1.15" "https://support.omadanetworks.com/en/download/software/omada-controller/" |
|
||||||
grep -o 'https://static\.tp-link\.com/upload/software/[^"]*linux_x64[^"]*\.deb' |
|
grep -o 'https://static\.tp-link\.com/upload/software/[^"]*linux_x64[^"]*\.deb' |
|
||||||
head -n1)
|
head -n1)
|
||||||
OMADA_PKG=$(basename "${OMADA_URL}")
|
OMADA_PKG=$(basename "${OMADA_URL}")
|
||||||
|
|||||||
Executable
+81
@@ -0,0 +1,81 @@
|
|||||||
|
#!/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: gVNS (ggfevans)
|
||||||
|
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
|
||||||
|
# Source: https://github.com/RackulaLives/Rackula
|
||||||
|
|
||||||
|
APP="Rackula"
|
||||||
|
var_tags="${var_tags:-homelab}"
|
||||||
|
var_cpu="${var_cpu:-1}"
|
||||||
|
var_ram="${var_ram:-512}"
|
||||||
|
var_disk="${var_disk:-8}"
|
||||||
|
var_os="${var_os:-debian}"
|
||||||
|
var_version="${var_version:-13}"
|
||||||
|
var_arm64="${var_arm64:-yes}"
|
||||||
|
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/rackula ]]; then
|
||||||
|
msg_error "No ${APP} Installation Found!"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if check_for_gh_release "rackula" "RackulaLives/Rackula"; then
|
||||||
|
msg_info "Stopping Services"
|
||||||
|
systemctl stop rackula-api nginx
|
||||||
|
msg_ok "Stopped Services"
|
||||||
|
|
||||||
|
create_backup /opt/rackula/data
|
||||||
|
CLEAN_INSTALL=1 fetch_and_deploy_gh_release "rackula" "RackulaLives/Rackula" "prebuild" "latest" "/opt/rackula" "rackula-lxc-*.tar.gz"
|
||||||
|
restore_backup
|
||||||
|
|
||||||
|
msg_info "Updating Configuration"
|
||||||
|
cp /opt/rackula/config/nginx.conf /etc/nginx/sites-available/rackula
|
||||||
|
cp /opt/rackula/config/security-headers.conf /etc/nginx/snippets/security-headers.conf
|
||||||
|
cp /opt/rackula/config/rackula-api.service /etc/systemd/system/rackula-api.service
|
||||||
|
if grep -q '^User=' /etc/systemd/system/rackula-api.service; then
|
||||||
|
sed -i 's/^User=.*/User=root/' /etc/systemd/system/rackula-api.service
|
||||||
|
else
|
||||||
|
sed -i '/^\[Service\]/a User=root' /etc/systemd/system/rackula-api.service
|
||||||
|
fi
|
||||||
|
if grep -q '^Group=' /etc/systemd/system/rackula-api.service; then
|
||||||
|
sed -i 's/^Group=.*/Group=root/' /etc/systemd/system/rackula-api.service
|
||||||
|
else
|
||||||
|
sed -i '/^\[Service\]/a Group=root' /etc/systemd/system/rackula-api.service
|
||||||
|
fi
|
||||||
|
mkdir -p /etc/systemd/system/nginx.service.d
|
||||||
|
cp /opt/rackula/config/nginx.service.d-override.conf /etc/systemd/system/nginx.service.d/override.conf
|
||||||
|
chown -R root:root /opt/rackula/frontend
|
||||||
|
find /opt/rackula/frontend -type d -exec chmod 755 {} \;
|
||||||
|
find /opt/rackula/frontend -type f -exec chmod 644 {} \;
|
||||||
|
chmod 750 /opt/rackula/data
|
||||||
|
msg_ok "Updated Configuration"
|
||||||
|
|
||||||
|
msg_info "Starting Services"
|
||||||
|
$STD nginx -t
|
||||||
|
systemctl daemon-reload
|
||||||
|
systemctl start nginx rackula-api
|
||||||
|
msg_ok "Started Services"
|
||||||
|
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}"
|
||||||
+1
-1
@@ -29,7 +29,7 @@ function update_script() {
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
if check_for_gh_release "wishlist" "cmintey/wishlist"; then
|
if check_for_gh_release "wishlist" "cmintey/wishlist"; then
|
||||||
NODE_VERSION="24" NODE_MODULE="pnpm" setup_nodejs
|
NODE_VERSION="24" NODE_MODULE="pnpm@11" setup_nodejs
|
||||||
|
|
||||||
msg_info "Stopping Service"
|
msg_info "Stopping Service"
|
||||||
systemctl stop wishlist
|
systemctl stop wishlist
|
||||||
|
|||||||
@@ -71,16 +71,6 @@ $STD rc-update add loki default
|
|||||||
$STD rc-service loki start
|
$STD rc-service loki start
|
||||||
msg_ok "Installed Loki"
|
msg_ok "Installed Loki"
|
||||||
|
|
||||||
read -rp "Would you like to install Promtail? (y/N): " INSTALL_PROMTAIL
|
|
||||||
if [[ "${INSTALL_PROMTAIL,,}" =~ ^(y|yes)$ ]]; then
|
|
||||||
msg_info "Installing Promtail"
|
|
||||||
$STD apk add loki-promtail
|
|
||||||
$STD sed -i '/http_addr/s/127.0.0.1/0.0.0.0/g' /etc/conf.d/loki-promtail
|
|
||||||
$STD rc-update add loki-promtail default
|
|
||||||
$STD rc-service loki-promtail start
|
|
||||||
msg_ok "Installed Promtail"
|
|
||||||
fi
|
|
||||||
|
|
||||||
motd_ssh
|
motd_ssh
|
||||||
customize
|
customize
|
||||||
cleanup_lxc
|
cleanup_lxc
|
||||||
|
|||||||
@@ -70,14 +70,6 @@ chown loki /etc/loki/config.yml
|
|||||||
systemctl enable -q --now loki
|
systemctl enable -q --now loki
|
||||||
msg_ok "Installed Loki"
|
msg_ok "Installed Loki"
|
||||||
|
|
||||||
read -rp "Would you like to install Promtail? (y/N): " INSTALL_PROMTAIL
|
|
||||||
if [[ "${INSTALL_PROMTAIL,,}" =~ ^(y|yes)$ ]]; then
|
|
||||||
msg_info "Installing Promtail"
|
|
||||||
$STD apt install -y promtail
|
|
||||||
systemctl enable -q --now promtail
|
|
||||||
msg_ok "Installed Promtail"
|
|
||||||
fi
|
|
||||||
|
|
||||||
motd_ssh
|
motd_ssh
|
||||||
customize
|
customize
|
||||||
cleanup_lxc
|
cleanup_lxc
|
||||||
|
|||||||
@@ -35,7 +35,7 @@ if ! dpkg -l | grep -q 'libssl1.1'; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
msg_info "Installing Omada Controller"
|
msg_info "Installing Omada Controller"
|
||||||
OMADA_URL=$(curl -fsSL "https://support.omadanetworks.com/en/download/software/omada-controller/" |
|
OMADA_URL=$(curl -fsSL -A "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/26.5 Safari/605.1.15" "https://support.omadanetworks.com/en/download/software/omada-controller/" |
|
||||||
grep -o 'https://static\.tp-link\.com/upload/software/[^"]*linux_x64[^"]*\.deb' |
|
grep -o 'https://static\.tp-link\.com/upload/software/[^"]*linux_x64[^"]*\.deb' |
|
||||||
head -n1)
|
head -n1)
|
||||||
OMADA_PKG=$(basename "${OMADA_URL}")
|
OMADA_PKG=$(basename "${OMADA_URL}")
|
||||||
|
|||||||
Executable
+96
@@ -0,0 +1,96 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
# Copyright (c) 2021-2026 community-scripts ORG
|
||||||
|
# Author: gVNS (ggfevans)
|
||||||
|
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
|
||||||
|
# Source: https://github.com/RackulaLives/Rackula
|
||||||
|
|
||||||
|
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"
|
||||||
|
|
||||||
|
msg_info "Installing Bun"
|
||||||
|
ensure_dependencies unzip ca-certificates
|
||||||
|
BUN_VERSION="${BUN_VERSION:-1.3.14}"
|
||||||
|
case "$(uname -m)" in
|
||||||
|
x86_64) grep -q avx2 /proc/cpuinfo && BUN_VARIANT="x64" || BUN_VARIANT="x64-baseline" ;;
|
||||||
|
aarch64) BUN_VARIANT="aarch64" ;;
|
||||||
|
*)
|
||||||
|
msg_error "Unsupported architecture: $(uname -m)"
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
export BUN_INSTALL="/root/.bun"
|
||||||
|
curl -fsSL https://bun.sh/install | $STD bash
|
||||||
|
ln -sf /root/.bun/bin/bun /usr/local/bin/bun
|
||||||
|
fetch_and_deploy_gh_release "rackula" "RackulaLives/Rackula" "prebuild" "latest" "/opt/rackula" "rackula-lxc-*.tar.gz"
|
||||||
|
mkdir -p /opt/rackula/data /etc/nginx/snippets
|
||||||
|
|
||||||
|
SECURITY_HEADERS_SRC="/opt/rackula/config/security-headers.conf"
|
||||||
|
if [ ! -f "$SECURITY_HEADERS_SRC" ]; then
|
||||||
|
msg_error "Required config file missing: $SECURITY_HEADERS_SRC (release may be incomplete)"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
cp "$SECURITY_HEADERS_SRC" /etc/nginx/snippets/security-headers.conf
|
||||||
|
|
||||||
|
chown -R root:root /opt/rackula/frontend
|
||||||
|
find /opt/rackula/frontend -type d -exec chmod 755 {} \;
|
||||||
|
find /opt/rackula/frontend -type f -exec chmod 644 {} \;
|
||||||
|
chmod 750 /opt/rackula/data
|
||||||
|
|
||||||
|
API_WRITE_TOKEN=$(openssl rand -hex 32)
|
||||||
|
cat <<EOF >/opt/rackula/data/.env
|
||||||
|
RACKULA_API_WRITE_TOKEN=${API_WRITE_TOKEN}
|
||||||
|
CORS_ORIGIN=http://localhost
|
||||||
|
ALLOW_INSECURE_CORS=false
|
||||||
|
EOF
|
||||||
|
chmod 600 /opt/rackula/data/.env
|
||||||
|
|
||||||
|
cat <<EOF >/etc/nginx/snippets/rackula-api-token.conf
|
||||||
|
map \$host \$rackula_api_write_token {
|
||||||
|
default "${API_WRITE_TOKEN}";
|
||||||
|
}
|
||||||
|
map \$host \$rackula_has_api_write_token {
|
||||||
|
default 1;
|
||||||
|
}
|
||||||
|
EOF
|
||||||
|
chmod 640 /etc/nginx/snippets/rackula-api-token.conf
|
||||||
|
msg_ok "Set up Rackula"
|
||||||
|
|
||||||
|
msg_info "Configuring nginx"
|
||||||
|
cp /opt/rackula/config/nginx.conf /etc/nginx/sites-available/rackula
|
||||||
|
rm -f /etc/nginx/sites-enabled/default
|
||||||
|
ln -sf /etc/nginx/sites-available/rackula /etc/nginx/sites-enabled/rackula
|
||||||
|
$STD nginx -t
|
||||||
|
msg_ok "Configured nginx"
|
||||||
|
|
||||||
|
msg_info "Creating Services"
|
||||||
|
cp /opt/rackula/config/rackula-api.service /etc/systemd/system/rackula-api.service
|
||||||
|
if grep -q '^User=' /etc/systemd/system/rackula-api.service; then
|
||||||
|
sed -i 's/^User=.*/User=root/' /etc/systemd/system/rackula-api.service
|
||||||
|
else
|
||||||
|
sed -i '/^\[Service\]/a User=root' /etc/systemd/system/rackula-api.service
|
||||||
|
fi
|
||||||
|
if grep -q '^Group=' /etc/systemd/system/rackula-api.service; then
|
||||||
|
sed -i 's/^Group=.*/Group=root/' /etc/systemd/system/rackula-api.service
|
||||||
|
else
|
||||||
|
sed -i '/^\[Service\]/a Group=root' /etc/systemd/system/rackula-api.service
|
||||||
|
fi
|
||||||
|
mkdir -p /etc/systemd/system/nginx.service.d
|
||||||
|
cp /opt/rackula/config/nginx.service.d-override.conf /etc/systemd/system/nginx.service.d/override.conf
|
||||||
|
systemctl daemon-reload
|
||||||
|
systemctl enable -q nginx rackula-api
|
||||||
|
systemctl restart nginx rackula-api
|
||||||
|
msg_ok "Created Services"
|
||||||
|
|
||||||
|
motd_ssh
|
||||||
|
customize
|
||||||
|
cleanup_lxc
|
||||||
Reference in New Issue
Block a user