mirror of
https://github.com/community-scripts/ProxmoxVE.git
synced 2026-04-18 08:22:16 +00:00
Compare commits
17 Commits
fix/checkm
...
copilot/fi
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
8dacebf747 | ||
|
|
a15f57e0e3 | ||
|
|
ba876c7495 | ||
|
|
0d2d1f46f5 | ||
|
|
5e865278e9 | ||
|
|
a18642a8f8 | ||
|
|
9a82ec48b2 | ||
|
|
f2d46dd8c8 | ||
|
|
2707295eba | ||
|
|
82cc074b05 | ||
|
|
6b224ac649 | ||
|
|
a69f9955f4 | ||
|
|
7d19269122 | ||
|
|
498d37ae3a | ||
|
|
703ad0ecb7 | ||
|
|
ae6cf7666e | ||
|
|
2c2beab3ce |
35
CHANGELOG.md
35
CHANGELOG.md
@@ -439,6 +439,41 @@ Exercise vigilance regarding copycat or coat-tailing sites that seek to exploit
|
|||||||
|
|
||||||
</details>
|
</details>
|
||||||
|
|
||||||
|
## 2026-04-10
|
||||||
|
|
||||||
|
### 🚀 Updated Scripts
|
||||||
|
|
||||||
|
- Immich: Pin version to 2.7.3 [@vhsdream](https://github.com/vhsdream) ([#13631](https://github.com/community-scripts/ProxmoxVE/pull/13631))
|
||||||
|
|
||||||
|
- #### ✨ New Features
|
||||||
|
|
||||||
|
- Homarr: bind Redis to localhost only [@MickLesk](https://github.com/MickLesk) ([#13552](https://github.com/community-scripts/ProxmoxVE/pull/13552))
|
||||||
|
|
||||||
|
### 💾 Core
|
||||||
|
|
||||||
|
- #### 🐞 Bug Fixes
|
||||||
|
|
||||||
|
- tools.func: prevent script crash when entering GitHub token after rate limit [@MickLesk](https://github.com/MickLesk) ([#13638](https://github.com/community-scripts/ProxmoxVE/pull/13638))
|
||||||
|
|
||||||
|
### 🧰 Tools
|
||||||
|
|
||||||
|
- #### 🔧 Refactor
|
||||||
|
|
||||||
|
- addons: Filebrowser & Filebrowser-Quantum get warning if host install [@MickLesk](https://github.com/MickLesk) ([#13639](https://github.com/community-scripts/ProxmoxVE/pull/13639))
|
||||||
|
|
||||||
|
## 2026-04-09
|
||||||
|
|
||||||
|
### 🚀 Updated Scripts
|
||||||
|
|
||||||
|
- #### 🐞 Bug Fixes
|
||||||
|
|
||||||
|
- boostack: add: git [@CrazyWolf13](https://github.com/CrazyWolf13) ([#13620](https://github.com/community-scripts/ProxmoxVE/pull/13620))
|
||||||
|
|
||||||
|
- #### ✨ New Features
|
||||||
|
|
||||||
|
- Update OPNsense version from 25.7 to 26.1 [@tdn131](https://github.com/tdn131) ([#13626](https://github.com/community-scripts/ProxmoxVE/pull/13626))
|
||||||
|
- CheckMK: Bump Default OS to 13 (trixie) + dynamic codename + fix RELEASE-Tag Fetching [@MickLesk](https://github.com/MickLesk) ([#13610](https://github.com/community-scripts/ProxmoxVE/pull/13610))
|
||||||
|
|
||||||
## 2026-04-08
|
## 2026-04-08
|
||||||
|
|
||||||
### 🆕 New Scripts
|
### 🆕 New Scripts
|
||||||
|
|||||||
@@ -29,6 +29,7 @@ function update_script() {
|
|||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
setup_mariadb
|
setup_mariadb
|
||||||
|
ensure_dependencies git
|
||||||
if check_for_gh_release "bookstack" "BookStackApp/BookStack"; then
|
if check_for_gh_release "bookstack" "BookStackApp/BookStack"; then
|
||||||
msg_info "Stopping Apache2"
|
msg_info "Stopping Apache2"
|
||||||
systemctl stop apache2
|
systemctl stop apache2
|
||||||
|
|||||||
@@ -65,6 +65,8 @@ EOF
|
|||||||
|
|
||||||
msg_info "Updating Homarr"
|
msg_info "Updating Homarr"
|
||||||
cp /opt/homarr/redis.conf /etc/redis/redis.conf
|
cp /opt/homarr/redis.conf /etc/redis/redis.conf
|
||||||
|
sed -i -e '$a\' /etc/redis/redis.conf
|
||||||
|
grep -q '^bind 127.0.0.1 -::1$' /etc/redis/redis.conf || echo "bind 127.0.0.1 -::1" >> /etc/redis/redis.conf
|
||||||
rm /etc/nginx/nginx.conf
|
rm /etc/nginx/nginx.conf
|
||||||
cp /opt/homarr/nginx.conf /etc/nginx/templates/nginx.conf
|
cp /opt/homarr/nginx.conf /etc/nginx/templates/nginx.conf
|
||||||
msg_ok "Updated Homarr"
|
msg_ok "Updated Homarr"
|
||||||
|
|||||||
@@ -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.7.2"
|
RELEASE="v2.7.3"
|
||||||
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"
|
||||||
|
|||||||
@@ -14,7 +14,9 @@ network_check
|
|||||||
update_os
|
update_os
|
||||||
|
|
||||||
msg_info "Installing Dependencies"
|
msg_info "Installing Dependencies"
|
||||||
$STD apt install -y make
|
$STD apt install -y \
|
||||||
|
make \
|
||||||
|
git
|
||||||
msg_ok "Installed Dependencies"
|
msg_ok "Installed Dependencies"
|
||||||
|
|
||||||
PHP_VERSION="8.3" PHP_APACHE="YES" PHP_FPM="YES" PHP_MODULE="ldap,tidy,mysqli" setup_php
|
PHP_VERSION="8.3" PHP_APACHE="YES" PHP_FPM="YES" PHP_MODULE="ldap,tidy,mysqli" setup_php
|
||||||
|
|||||||
@@ -47,6 +47,8 @@ mkdir -p /appdata/redis
|
|||||||
chown -R redis:redis /appdata/redis
|
chown -R redis:redis /appdata/redis
|
||||||
chmod 744 /appdata/redis
|
chmod 744 /appdata/redis
|
||||||
cp /opt/homarr/redis.conf /etc/redis/redis.conf
|
cp /opt/homarr/redis.conf /etc/redis/redis.conf
|
||||||
|
sed -i -e '$a\' /etc/redis/redis.conf
|
||||||
|
grep -q '^bind 127.0.0.1 -::1$' /etc/redis/redis.conf || echo "bind 127.0.0.1 -::1" >>/etc/redis/redis.conf
|
||||||
rm /etc/nginx/nginx.conf
|
rm /etc/nginx/nginx.conf
|
||||||
mkdir -p /etc/nginx/templates
|
mkdir -p /etc/nginx/templates
|
||||||
cp /opt/homarr/nginx.conf /etc/nginx/templates/nginx.conf
|
cp /opt/homarr/nginx.conf /etc/nginx/templates/nginx.conf
|
||||||
@@ -80,7 +82,7 @@ chmod +x /opt/homarr/run.sh
|
|||||||
systemctl daemon-reload
|
systemctl daemon-reload
|
||||||
systemctl enable -q --now redis-server
|
systemctl enable -q --now redis-server
|
||||||
systemctl enable -q --now homarr
|
systemctl enable -q --now homarr
|
||||||
systemctl disable -q --now nginx
|
systemctl disable -q --now nginx
|
||||||
msg_ok "Created Services"
|
msg_ok "Created Services"
|
||||||
|
|
||||||
motd_ssh
|
motd_ssh
|
||||||
|
|||||||
@@ -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.7.2" "$SRC_DIR"
|
fetch_and_deploy_gh_release "Immich" "immich-app/immich" "tarball" "v2.7.3" "$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
|
||||||
|
|
||||||
|
|||||||
@@ -1054,7 +1054,7 @@ load_vars_file() {
|
|||||||
|
|
||||||
# Allowed var_* keys
|
# Allowed var_* keys
|
||||||
local VAR_WHITELIST=(
|
local VAR_WHITELIST=(
|
||||||
var_apt_cacher var_apt_cacher_ip var_brg var_cpu var_disk var_fuse var_gpu var_keyctl
|
var_apt_cacher var_apt_cacher_ip var_brg var_cpu var_disk var_fuse var_github_token var_gpu var_keyctl
|
||||||
var_gateway var_hostname var_ipv6_method var_mac var_mknod var_mount_fs var_mtu
|
var_gateway var_hostname var_ipv6_method var_mac var_mknod var_mount_fs var_mtu
|
||||||
var_net var_nesting var_ns var_os var_protection var_pw var_ram var_tags var_timezone var_tun var_unprivileged
|
var_net var_nesting var_ns var_os var_protection var_pw var_ram var_tags var_timezone var_tun var_unprivileged
|
||||||
var_verbose var_version var_vlan var_ssh var_ssh_authorized_key var_container_storage var_template_storage var_searchdomain
|
var_verbose var_version var_vlan var_ssh var_ssh_authorized_key var_container_storage var_template_storage var_searchdomain
|
||||||
@@ -1255,7 +1255,7 @@ default_var_settings() {
|
|||||||
# Allowed var_* keys (alphabetically sorted)
|
# Allowed var_* keys (alphabetically sorted)
|
||||||
# Note: Removed var_ctid (can only exist once), var_ipv6_static (static IPs are unique)
|
# Note: Removed var_ctid (can only exist once), var_ipv6_static (static IPs are unique)
|
||||||
local VAR_WHITELIST=(
|
local VAR_WHITELIST=(
|
||||||
var_apt_cacher var_apt_cacher_ip var_brg var_cpu var_disk var_fuse var_gpu var_keyctl
|
var_apt_cacher var_apt_cacher_ip var_brg var_cpu var_disk var_fuse var_github_token var_gpu var_keyctl
|
||||||
var_gateway var_hostname var_ipv6_method var_mac var_mknod var_mount_fs var_mtu
|
var_gateway var_hostname var_ipv6_method var_mac var_mknod var_mount_fs var_mtu
|
||||||
var_net var_nesting var_ns var_os var_protection var_pw var_ram var_tags var_timezone var_tun var_unprivileged
|
var_net var_nesting var_ns var_os var_protection var_pw var_ram var_tags var_timezone var_tun var_unprivileged
|
||||||
var_verbose var_version var_vlan var_ssh var_ssh_authorized_key var_container_storage var_template_storage
|
var_verbose var_version var_vlan var_ssh var_ssh_authorized_key var_container_storage var_template_storage
|
||||||
@@ -1350,6 +1350,10 @@ var_verbose=no
|
|||||||
|
|
||||||
# Security (root PW) – empty => autologin
|
# Security (root PW) – empty => autologin
|
||||||
# var_pw=
|
# var_pw=
|
||||||
|
|
||||||
|
# GitHub Personal Access Token (optional – avoids API rate limits during installs)
|
||||||
|
# Create at https://github.com/settings/tokens – read-only public access is sufficient
|
||||||
|
# var_github_token=ghp_your_token_here
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
# Now choose storages (always prompt unless just one exists)
|
# Now choose storages (always prompt unless just one exists)
|
||||||
@@ -1387,6 +1391,11 @@ EOF
|
|||||||
VERBOSE="no"
|
VERBOSE="no"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# 4) Map var_github_token → GITHUB_TOKEN (only if not already set in environment)
|
||||||
|
if [[ -z "${GITHUB_TOKEN:-}" && -n "${var_github_token:-}" ]]; then
|
||||||
|
export GITHUB_TOKEN="${var_github_token}"
|
||||||
|
fi
|
||||||
|
|
||||||
# 4) Apply base settings and show summary
|
# 4) Apply base settings and show summary
|
||||||
METHOD="mydefaults-global"
|
METHOD="mydefaults-global"
|
||||||
base_settings "$VERBOSE"
|
base_settings "$VERBOSE"
|
||||||
@@ -1419,7 +1428,7 @@ get_app_defaults_path() {
|
|||||||
if ! declare -p VAR_WHITELIST >/dev/null 2>&1; then
|
if ! declare -p VAR_WHITELIST >/dev/null 2>&1; then
|
||||||
# Note: Removed var_ctid (can only exist once), var_ipv6_static (static IPs are unique)
|
# Note: Removed var_ctid (can only exist once), var_ipv6_static (static IPs are unique)
|
||||||
declare -ag VAR_WHITELIST=(
|
declare -ag VAR_WHITELIST=(
|
||||||
var_apt_cacher var_apt_cacher_ip var_brg var_cpu var_disk var_fuse var_gpu
|
var_apt_cacher var_apt_cacher_ip var_brg var_cpu var_disk var_fuse var_github_token var_gpu
|
||||||
var_gateway var_hostname var_ipv6_method var_mac var_mtu
|
var_gateway var_hostname var_ipv6_method var_mac var_mtu
|
||||||
var_net var_ns var_os var_pw var_ram var_tags var_tun var_unprivileged
|
var_net var_ns var_os var_pw var_ram var_tags var_tun var_unprivileged
|
||||||
var_verbose var_version var_vlan var_ssh var_ssh_authorized_key var_container_storage var_template_storage
|
var_verbose var_version var_vlan var_ssh var_ssh_authorized_key var_container_storage var_template_storage
|
||||||
|
|||||||
@@ -1117,15 +1117,87 @@ is_package_installed() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
|
# validate_github_token()
|
||||||
|
# Checks a GitHub token via the /user endpoint.
|
||||||
|
# Prints a status message and returns:
|
||||||
|
# 0 - token is valid
|
||||||
|
# 1 - token is invalid / expired (HTTP 401)
|
||||||
|
# 2 - token has no public repo scope (HTTP 200 but missing scope)
|
||||||
|
# 3 - network/API error
|
||||||
|
# Also reports expiry date if the token carries an x-oauth-expiry header.
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
|
validate_github_token() {
|
||||||
|
local token="${1:-${GITHUB_TOKEN:-}}"
|
||||||
|
[[ -z "$token" ]] && return 3
|
||||||
|
|
||||||
|
local response headers http_code expiry_date scopes
|
||||||
|
headers=$(mktemp)
|
||||||
|
response=$(curl -sSL -w "%{http_code}" \
|
||||||
|
-D "$headers" \
|
||||||
|
-o /dev/null \
|
||||||
|
-H "Authorization: Bearer $token" \
|
||||||
|
-H "Accept: application/vnd.github+json" \
|
||||||
|
-H "X-GitHub-Api-Version: 2022-11-28" \
|
||||||
|
"https://api.github.com/user" 2>/dev/null) || { rm -f "$headers"; return 3; }
|
||||||
|
http_code="$response"
|
||||||
|
|
||||||
|
# Read expiry header (fine-grained PATs carry this)
|
||||||
|
expiry_date=$(grep -i '^github-authentication-token-expiration:' "$headers" \
|
||||||
|
| sed 's/.*: *//' | tr -d '\r\n' || true)
|
||||||
|
# Read token scopes (classic PATs)
|
||||||
|
scopes=$(grep -i '^x-oauth-scopes:' "$headers" \
|
||||||
|
| sed 's/.*: *//' | tr -d '\r\n' || true)
|
||||||
|
rm -f "$headers"
|
||||||
|
|
||||||
|
case "$http_code" in
|
||||||
|
200)
|
||||||
|
if [[ -n "$expiry_date" ]]; then
|
||||||
|
msg_ok "GitHub token is valid (expires: $expiry_date)."
|
||||||
|
else
|
||||||
|
msg_ok "GitHub token is valid (no expiry / fine-grained PAT)."
|
||||||
|
fi
|
||||||
|
# Warn if classic PAT has no public_repo scope
|
||||||
|
if [[ -n "$scopes" && "$scopes" != *"public_repo"* && "$scopes" != *"repo"* ]]; then
|
||||||
|
msg_warn "Token has no 'public_repo' scope - private repos and some release APIs may fail."
|
||||||
|
return 2
|
||||||
|
fi
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
401)
|
||||||
|
msg_error "GitHub token is invalid or expired (HTTP 401)."
|
||||||
|
return 1
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
msg_warn "GitHub token validation returned HTTP $http_code - treating as valid."
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
# ------------------------------------------------------------------------------
|
# ------------------------------------------------------------------------------
|
||||||
# Prompt user to enter a GitHub Personal Access Token (PAT) interactively
|
# Prompt user to enter a GitHub Personal Access Token (PAT) interactively
|
||||||
# Returns 0 if a valid token was provided, 1 otherwise
|
# Returns 0 if a valid token was provided, 1 otherwise
|
||||||
# ------------------------------------------------------------------------------
|
# ------------------------------------------------------------------------------
|
||||||
prompt_for_github_token() {
|
prompt_for_github_token() {
|
||||||
if [[ ! -t 0 ]]; then
|
if [[ ! -t 0 ]]; then
|
||||||
|
# Non-interactive: pick up var_github_token if set (from default.vars / app.vars / env)
|
||||||
|
if [[ -z "${GITHUB_TOKEN:-}" && -n "${var_github_token:-}" ]]; then
|
||||||
|
export GITHUB_TOKEN="${var_github_token}"
|
||||||
|
msg_ok "GitHub token loaded from var_github_token."
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# Prefer var_github_token when already set and no interactive override needed
|
||||||
|
if [[ -z "${GITHUB_TOKEN:-}" && -n "${var_github_token:-}" ]]; then
|
||||||
|
export GITHUB_TOKEN="${var_github_token}"
|
||||||
|
msg_ok "GitHub token loaded from var_github_token."
|
||||||
|
validate_github_token || true
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
local reply
|
local reply
|
||||||
read -rp "${TAB}Would you like to enter a GitHub Personal Access Token (PAT)? [y/N]: " reply
|
read -rp "${TAB}Would you like to enter a GitHub Personal Access Token (PAT)? [y/N]: " reply
|
||||||
reply="${reply:-n}"
|
reply="${reply:-n}"
|
||||||
@@ -1147,10 +1219,16 @@ prompt_for_github_token() {
|
|||||||
msg_warn "Token must not contain spaces. Please try again."
|
msg_warn "Token must not contain spaces. Please try again."
|
||||||
continue
|
continue
|
||||||
fi
|
fi
|
||||||
break
|
# Validate before accepting
|
||||||
|
export GITHUB_TOKEN="$token"
|
||||||
|
if validate_github_token "$token"; then
|
||||||
|
break
|
||||||
|
else
|
||||||
|
msg_warn "Please enter a valid token, or press Ctrl+C to abort."
|
||||||
|
unset GITHUB_TOKEN
|
||||||
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
export GITHUB_TOKEN="$token"
|
|
||||||
msg_ok "GitHub token has been set."
|
msg_ok "GitHub token has been set."
|
||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
@@ -2860,7 +2938,7 @@ function fetch_and_deploy_codeberg_release() {
|
|||||||
|
|
||||||
while ((attempt < ${#api_timeouts[@]})); do
|
while ((attempt < ${#api_timeouts[@]})); do
|
||||||
resp=$(curl --connect-timeout 10 --max-time "${api_timeouts[$attempt]}" -fsSL -w "%{http_code}" -o /tmp/codeberg_rel.json "$api_url") && success=true && break
|
resp=$(curl --connect-timeout 10 --max-time "${api_timeouts[$attempt]}" -fsSL -w "%{http_code}" -o /tmp/codeberg_rel.json "$api_url") && success=true && break
|
||||||
((attempt++))
|
attempt=$((attempt + 1))
|
||||||
if ((attempt < ${#api_timeouts[@]})); then
|
if ((attempt < ${#api_timeouts[@]})); then
|
||||||
msg_warn "API request timed out after ${api_timeouts[$((attempt - 1))]}s, retrying... (attempt $((attempt + 1))/${#api_timeouts[@]})"
|
msg_warn "API request timed out after ${api_timeouts[$((attempt - 1))]}s, retrying... (attempt $((attempt + 1))/${#api_timeouts[@]})"
|
||||||
fi
|
fi
|
||||||
@@ -3370,7 +3448,8 @@ function fetch_and_deploy_gh_release() {
|
|||||||
if prompt_for_github_token; then
|
if prompt_for_github_token; then
|
||||||
header=(-H "Authorization: token $GITHUB_TOKEN")
|
header=(-H "Authorization: token $GITHUB_TOKEN")
|
||||||
retry_delay=2
|
retry_delay=2
|
||||||
attempt=0
|
attempt=1
|
||||||
|
continue
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
|
|||||||
@@ -43,6 +43,21 @@ IP=$(ip -4 addr show "$IFACE" | awk '/inet / {print $2}' | cut -d/ -f1 | head -n
|
|||||||
[[ -z "$IP" ]] && IP=$(hostname -I | awk '{print $1}')
|
[[ -z "$IP" ]] && IP=$(hostname -I | awk '{print $1}')
|
||||||
[[ -z "$IP" ]] && IP="127.0.0.1"
|
[[ -z "$IP" ]] && IP="127.0.0.1"
|
||||||
|
|
||||||
|
# Proxmox Host Warning
|
||||||
|
if [[ -d "/etc/pve" ]]; then
|
||||||
|
echo -e "${RD}⚠️ Warning: Running this addon directly on the Proxmox host is not recommended!${CL}"
|
||||||
|
echo -e "${YW} Only the boot disk will be visible — passthrough drives will not be indexed.${CL}"
|
||||||
|
echo -e "${YW} This causes incorrect disk usage stats and incomplete file browsing.${CL}"
|
||||||
|
echo -e "${YW} Run this addon inside an LXC or VM instead and mount your drives there.${CL}"
|
||||||
|
echo ""
|
||||||
|
echo -n "Continue anyway on the Proxmox host? (y/N): "
|
||||||
|
read -r host_confirm
|
||||||
|
if [[ ! "${host_confirm,,}" =~ ^(y|yes)$ ]]; then
|
||||||
|
echo -e "${YW}Aborted.${CL}"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
# OS Detection
|
# OS Detection
|
||||||
if [[ -f "/etc/alpine-release" ]]; then
|
if [[ -f "/etc/alpine-release" ]]; then
|
||||||
OS="Alpine"
|
OS="Alpine"
|
||||||
|
|||||||
@@ -41,6 +41,21 @@ IP=$(ip -4 addr show "$IFACE" | awk '/inet / {print $2}' | cut -d/ -f1 | head -n
|
|||||||
[[ -z "$IP" ]] && IP=$(hostname -I | awk '{print $1}')
|
[[ -z "$IP" ]] && IP=$(hostname -I | awk '{print $1}')
|
||||||
[[ -z "$IP" ]] && IP="127.0.0.1"
|
[[ -z "$IP" ]] && IP="127.0.0.1"
|
||||||
|
|
||||||
|
# Proxmox Host Warning
|
||||||
|
if [[ -d "/etc/pve" ]]; then
|
||||||
|
echo -e "${RD}⚠️ Warning: Running this addon directly on the Proxmox host is not recommended!${CL}"
|
||||||
|
echo -e "${YW} Only the boot disk will be visible — passthrough drives will not be indexed.${CL}"
|
||||||
|
echo -e "${YW} This causes incorrect disk usage stats and incomplete file browsing.${CL}"
|
||||||
|
echo -e "${YW} Run this addon inside an LXC or VM instead and mount your drives there.${CL}"
|
||||||
|
echo ""
|
||||||
|
echo -n "Continue anyway on the Proxmox host? (y/N): "
|
||||||
|
read -r host_confirm
|
||||||
|
if [[ ! "${host_confirm,,}" =~ ^(y|yes)$ ]]; then
|
||||||
|
echo -e "${YW}Aborted.${CL}"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
# Detect OS
|
# Detect OS
|
||||||
if [[ -f "/etc/alpine-release" ]]; then
|
if [[ -f "/etc/alpine-release" ]]; then
|
||||||
OS="Alpine"
|
OS="Alpine"
|
||||||
|
|||||||
@@ -24,7 +24,7 @@ RANDOM_UUID="$(cat /proc/sys/kernel/random/uuid)"
|
|||||||
METHOD=""
|
METHOD=""
|
||||||
NSAPP="opnsense-vm"
|
NSAPP="opnsense-vm"
|
||||||
var_os="opnsense"
|
var_os="opnsense"
|
||||||
var_version="25.7"
|
var_version="26.1"
|
||||||
#
|
#
|
||||||
GEN_MAC=02:$(openssl rand -hex 5 | awk '{print toupper($0)}' | sed 's/\(..\)/\1:/g; s/.$//')
|
GEN_MAC=02:$(openssl rand -hex 5 | awk '{print toupper($0)}' | sed 's/\(..\)/\1:/g; s/.$//')
|
||||||
GEN_MAC_LAN=02:$(openssl rand -hex 5 | awk '{print toupper($0)}' | sed 's/\(..\)/\1:/g; s/.$//')
|
GEN_MAC_LAN=02:$(openssl rand -hex 5 | awk '{print toupper($0)}' | sed 's/\(..\)/\1:/g; s/.$//')
|
||||||
@@ -797,7 +797,7 @@ if [ -n "$WAN_BRG" ]; then
|
|||||||
msg_ok "WAN interface added"
|
msg_ok "WAN interface added"
|
||||||
sleep 5 # Brief pause after adding network interface
|
sleep 5 # Brief pause after adding network interface
|
||||||
fi
|
fi
|
||||||
send_line_to_vm "sh ./opnsense-bootstrap.sh.in -y -f -r 25.7"
|
send_line_to_vm "sh ./opnsense-bootstrap.sh.in -y -f -r 26.1"
|
||||||
msg_ok "OPNsense VM is being installed, do not close the terminal, or the installation will fail."
|
msg_ok "OPNsense VM is being installed, do not close the terminal, or the installation will fail."
|
||||||
#We need to wait for the OPNsense build proccess to finish, this takes a few minutes
|
#We need to wait for the OPNsense build proccess to finish, this takes a few minutes
|
||||||
sleep 1000
|
sleep 1000
|
||||||
|
|||||||
Reference in New Issue
Block a user