From 0cd7eed2763464fb84fa4852ecd3858c8b22ff72 Mon Sep 17 00:00:00 2001 From: juronja <101410098+juronja@users.noreply.github.com> Date: Thu, 15 Jan 2026 15:46:35 +0000 Subject: [PATCH 01/33] initial commit --- frontend/public/json/truenas-vm.json | 56 +++ vm/truenas-vm.sh | 592 +++++++++++++++++++++++++++ 2 files changed, 648 insertions(+) create mode 100644 frontend/public/json/truenas-vm.json create mode 100644 vm/truenas-vm.sh diff --git a/frontend/public/json/truenas-vm.json b/frontend/public/json/truenas-vm.json new file mode 100644 index 000000000..d4675b55f --- /dev/null +++ b/frontend/public/json/truenas-vm.json @@ -0,0 +1,56 @@ +{ + "name": "TrueNAS Community Edition", + "slug": "truenas-community-edition", + "categories": [ + 2 + ], + "date_created": "2026-01-16", + "type": "vm", + "updateable": true, + "privileged": false, + "interface_port": null, + "documentation": "https://www.truenas.com/docs/", + "website": "https://www.truenas.com/truenas-community-edition/", + "logo": "https://cdn.jsdelivr.net/gh/selfhst/icons@main/webp/truenas-core.webp", + "config_path": "", + "description": "TrueNAS Community Edition is the world's most deployed storage software. Free, flexible and build on OpenZFS with Docker.", + "install_methods": [ + { + "type": "default", + "script": "vm/truenas-vm.sh", + "resources": { + "cpu": 2, + "ram": 8192, + "hdd": 16, + "os": null, + "version": null + } + } + ], + "default_credentials": { + "username": null, + "password": null + }, + "notes": [ + { + "text": "The default install uses the latest stable release. Please use advanced install for more options.", + "type": "info" + }, + { + "text": "8 GB of RAM is the minimum requirement, but 16 GB+ is recommended for optimal performance.", + "type": "info" + }, + { + "text": "After installation, you will be prompted to unmount the media. To do this: Go to the VM's Hardware tab > select the CD/DVD Drive > Edit > select 'Do not use any media'", + "type": "info" + }, + { + "text": "While you can import onboard disks during install, it is highly recommended to use an HBA to pass through disks for production environments.", + "type": "warning" + }, + { + "text": "ECC RAM is strongly recommended to ensure data integrity, as ZFS checksumming can be compromised by bad data in RAM before the data is written to the pool.", + "type": "warning" + } + ] +} diff --git a/vm/truenas-vm.sh b/vm/truenas-vm.sh new file mode 100644 index 000000000..ab796ee77 --- /dev/null +++ b/vm/truenas-vm.sh @@ -0,0 +1,592 @@ +#!/usr/bin/env bash + +# Copyright (c) 2021-2026 community-scripts ORG +# Author: juronja +# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE + +source /dev/stdin <<<$(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/api.func) + +function header_info() { + clear + cat <<"EOF" + ______ _ _____ _____ + /_ __/______ _____ / | / / | / ___/ + / / / ___/ / / / _ \/ |/ / /| | \__ \ + / / / / / /_/ / __/ /| / ___ |___/ / +/_/ /_/ \__,_/\___/_/ |_/_/ |_/____/ + (Community Edition) +EOF +} +header_info +echo -e "\n Loading..." +GEN_MAC=02:$(openssl rand -hex 5 | awk '{print toupper($0)}' | sed 's/\(..\)/\1:/g; s/.$//') +RANDOM_UUID="$(cat /proc/sys/kernel/random/uuid)" +METHOD="" + +YW=$(echo "\033[33m") +BL=$(echo "\033[36m") +RD=$(echo "\033[01;31m") +BGN=$(echo "\033[4;92m") +GN=$(echo "\033[1;92m") +DGN=$(echo "\033[32m") +CL=$(echo "\033[m") + +CL=$(echo "\033[m") +BOLD=$(echo "\033[1m") +BFR="\\r\\033[K" +HOLD=" " +TAB=" " + +CM="${TAB}✔️${TAB}${CL}" +CROSS="${TAB}✖️${TAB}${CL}" +INFO="${TAB}💡${TAB}${CL}" +OS="${TAB}🖥️${TAB}${CL}" +CONTAINERTYPE="${TAB}📦${TAB}${CL}" +ISO="${TAB}📀${TAB}${CL}" +DISKSIZE="${TAB}💾${TAB}${CL}" +CPUCORE="${TAB}🧠${TAB}${CL}" +RAMSIZE="${TAB}🛠️${TAB}${CL}" +CONTAINERID="${TAB}🆔${TAB}${CL}" +HOSTNAME="${TAB}🏠${TAB}${CL}" +BRIDGE="${TAB}🌉${TAB}${CL}" +GATEWAY="${TAB}🌐${TAB}${CL}" +DISK="${TAB}💽${TAB}${CL}" +DEFAULT="${TAB}⚙️${TAB}${CL}" +MACADDRESS="${TAB}🔗${TAB}${CL}" +VLANTAG="${TAB}🏷️${TAB}${CL}" +CREATING="${TAB}🚀${TAB}${CL}" +ADVANCED="${TAB}🧩${TAB}${CL}" +CLOUD="${TAB}☁️${TAB}${CL}" + +set -e +trap 'error_handler $LINENO "$BASH_COMMAND"' ERR +trap cleanup EXIT +trap 'post_update_to_api "failed" "INTERRUPTED"' SIGINT +trap 'post_update_to_api "failed" "TERMINATED"' SIGTERM +function error_handler() { + local exit_code="$?" + local line_number="$1" + local command="$2" + local error_message="${RD}[ERROR]${CL} in line ${RD}$line_number${CL}: exit code ${RD}$exit_code${CL}: while executing command ${YW}$command${CL}" + post_update_to_api "failed" "${command}" + echo -e "\n$error_message\n" + cleanup_vmid +} + +function truenas_iso_lookup() { + local BASE_URL="https://download.truenas.com" + local current_year=$(date +%y) + local last_year=$(date -d "1 year ago" +%y) + local year_pattern="${current_year}\.|${last_year}\." + + declare -A latest_stables + local pre_releases=() + + local all_paths=$( + curl -sL "$BASE_URL" | + grep -oE 'href="[^"]+\.iso"' | + sed 's/href="//; s/"$//' | + grep -vE '(nightly|ALPHA)' | + grep -E "$year_pattern" + ) + + while read -r path; do + local filename=$(basename "$path") + local version=$(echo "$filename" | sed -E 's/.*TrueNAS-SCALE-([0-9]{2}\.[0-9]{2}(\.[0-9]+)*(-RC[0-9]|-BETA[0-9])?)\.iso.*/\1/') + if [[ "$version" =~ (RC|BETA) ]]; then + pre_releases+=("$path") + else + local major_version=$(echo "$version" | cut -d'.' -f1,2) + local current_stored_path=${latest_stables["$major_version"]} + if [[ -z "$current_stored_path" ]]; then + latest_stables["$major_version"]="$path" + else + local stored_version=$(basename "$current_stored_path" | sed -E 's/.*TrueNAS-SCALE-([0-9]{2}\.[0-9]{2}(\.[0-9]+)*)\.iso.*/\1/') + if printf '%s\n' "$version" "$stored_version" | sort -V | tail -n 1 | grep -q "$version"; then + latest_stables["$major_version"]="$path" + fi + fi + fi + done <<<"$all_paths" + + for key in "${!latest_stables[@]}"; do + echo "${latest_stables[$key]#/}" + done + + for pre in "${pre_releases[@]}"; do + echo "${pre#/}" + done | sort -V +} + +function get_valid_nextid() { + local try_id + try_id=$(pvesh get /cluster/nextid) + while true; do + if [ -f "/etc/pve/qemu-server/${try_id}.conf" ] || [ -f "/etc/pve/lxc/${try_id}.conf" ]; then + try_id=$((try_id + 1)) + continue + fi + if lvs --noheadings -o lv_name | grep -qE "(^|[-_])${try_id}($|[-_])"; then + try_id=$((try_id + 1)) + continue + fi + break + done + echo "$try_id" +} + +function cleanup_vmid() { + if qm status $VMID &>/dev/null; then + qm stop $VMID &>/dev/null + qm destroy $VMID &>/dev/null + fi +} + +function cleanup() { + popd >/dev/null + post_update_to_api "done" "none" + rm -rf $TEMP_DIR +} + +TEMP_DIR=$(mktemp -d) +pushd $TEMP_DIR >/dev/null +if whiptail --backtitle "Proxmox VE Helper Scripts" --title "TrueNAS VM" --yesno "This will create a New TrueNAS VM. Proceed?" 10 58; then + : +else + header_info && echo -e "${CROSS}${RD}User exited script${CL}\n" && exit +fi + +function msg_info() { + local msg="$1" + echo -ne "${TAB}${YW}${HOLD}${msg}${HOLD}" +} + +function msg_ok() { + local msg="$1" + echo -e "${BFR}${CM}${GN}${msg}${CL}" +} + +function msg_error() { + local msg="$1" + echo -e "${BFR}${CROSS}${RD}${msg}${CL}" +} + +function check_root() { + if [[ "$(id -u)" -ne 0 || $(ps -o comm= -p $PPID) == "sudo" ]]; then + clear + msg_error "Please run this script as root." + echo -e "\nExiting..." + sleep 2 + exit + fi +} + +# This function checks the version of Proxmox Virtual Environment (PVE) and exits if the version is not supported. +# Supported: Proxmox VE 8.0.x – 8.9.x and 9.0 – 9.1 +pve_check() { + local PVE_VER + PVE_VER="$(pveversion | awk -F'/' '{print $2}' | awk -F'-' '{print $1}')" + + # Check for Proxmox VE 8.x: allow 8.0–8.9 + if [[ "$PVE_VER" =~ ^8\.([0-9]+) ]]; then + local MINOR="${BASH_REMATCH[1]}" + if ((MINOR < 0 || MINOR > 9)); then + msg_error "This version of Proxmox VE is not supported." + msg_error "Supported: Proxmox VE version 8.0 – 8.9" + exit 1 + fi + return 0 + fi + + # Check for Proxmox VE 9.x: allow 9.0–9.1 + if [[ "$PVE_VER" =~ ^9\.([0-9]+) ]]; then + local MINOR="${BASH_REMATCH[1]}" + if ((MINOR < 0 || MINOR > 1)); then + msg_error "This version of Proxmox VE is not yet supported." + msg_error "Supported: Proxmox VE version 9.0 – 9.1" + exit 1 + fi + return 0 + fi + + # All other unsupported versions + msg_error "This version of Proxmox VE is not supported." + msg_error "Supported versions: Proxmox VE 8.0 – 8.x or 9.0 – 9.1" + exit 1 +} + +function arch_check() { + if [ "$(dpkg --print-architecture)" != "amd64" ]; then + echo -e "\n ${INFO}${YWB}This script will not work with PiMox! \n" + echo -e "\n ${YWB}Visit https://github.com/asylumexp/Proxmox for ARM64 support. \n" + echo -e "Exiting..." + sleep 2 + exit + fi +} + +function ssh_check() { + if command -v pveversion >/dev/null 2>&1; then + if [ -n "${SSH_CLIENT:+x}" ]; then + if whiptail --backtitle "Proxmox VE Helper Scripts" --defaultno --title "SSH DETECTED" --yesno "It's suggested to use the Proxmox shell instead of SSH, since SSH can create issues while gathering variables. Would you like to proceed with using SSH?" 10 62; then + echo "you've been warned" + else + clear + exit + fi + fi + fi +} + +function exit-script() { + clear + echo -e "\n${CROSS}${RD}User exited script${CL}\n" + exit +} + +function default_settings() { + VMID=$(get_valid_nextid) + ISO_DEFAULT="latest stable" + FORMAT="" + MACHINE="q35" + DISK_SIZE="16" + HN="truenas" + CPU_TYPE="host" + CORE_COUNT="2" + RAM_SIZE="8192" + BRG="vmbr0" + MAC="$GEN_MAC" + VLAN="" + MTU="" + START_VM="yes" + METHOD="default" + echo -e "${CONTAINERID}${BOLD}${DGN}Virtual Machine ID: ${BGN}${VMID}${CL}" + echo -e "${ISO}${BOLD}${DGN}ISO Chosen: ${BGN}${ISO_DEFAULT}${CL}" + echo -e "${CONTAINERTYPE}${BOLD}${DGN}Machine Type: ${BGN}q35${CL}" + echo -e "${DISKSIZE}${BOLD}${DGN}Disk Size: ${BGN}${DISK_SIZE}${CL}" + echo -e "${HOSTNAME}${BOLD}${DGN}Hostname: ${BGN}${HN}${CL}" + echo -e "${OS}${BOLD}${DGN}CPU Model: ${BGN}${CPU_TYPE}${CL}" + echo -e "${CPUCORE}${BOLD}${DGN}CPU Cores: ${BGN}${CORE_COUNT}${CL}" + echo -e "${RAMSIZE}${BOLD}${DGN}RAM Size: ${BGN}${RAM_SIZE}${CL}" + echo -e "${BRIDGE}${BOLD}${DGN}Bridge: ${BGN}${BRG}${CL}" + echo -e "${MACADDRESS}${BOLD}${DGN}MAC Address: ${BGN}${MAC}${CL}" + echo -e "${VLANTAG}${BOLD}${DGN}VLAN: ${BGN}Default${CL}" + echo -e "${DEFAULT}${BOLD}${DGN}Interface MTU Size: ${BGN}Default${CL}" + echo -e "${GATEWAY}${BOLD}${DGN}Start VM when completed: ${BGN}yes${CL}" + echo -e "${CREATING}${BOLD}${DGN}Creating a TrueNAS VM using the above default settings${CL}" +} + +function advanced_settings() { + METHOD="advanced" + [ -z "${VMID:-}" ] && VMID=$(get_valid_nextid) + while true; do + if VMID=$(whiptail --backtitle "Proxmox VE Helper Scripts" --inputbox "Set Virtual Machine ID" 8 58 $VMID --title "VIRTUAL MACHINE ID" --cancel-button Exit-Script 3>&1 1>&2 2>&3); then + if [ -z "$VMID" ]; then + VMID=$(get_valid_nextid) + fi + if pct status "$VMID" &>/dev/null || qm status "$VMID" &>/dev/null; then + echo -e "${CROSS}${RD} ID $VMID is already in use${CL}" + sleep 2 + continue + fi + echo -e "${CONTAINERID}${BOLD}${DGN}Virtual Machine ID: ${BGN}$VMID${CL}" + break + else + exit-script + fi + done + + # ISO lookup + ISOARRAY=() + while read -r ISOPATH; do + FILENAME=$(basename "$ISOPATH") + ISOARRAY+=("$ISOPATH" "$FILENAME" "OFF") + done < <(truenas_iso_lookup | sort -V) + if [ ${#ISOARRAY[@]} -eq 0 ]; then + echo "No ISOs found." + exit 1 + fi + + if SELECTED_ISO=$(whiptail --backtitle "Proxmox VE Helper Scripts" --title "SELECT ISO TO INSTALL" --notags --radiolist "\nSelect version (BETA/RC + Latest stables):" 20 58 12 "${ISOARRAY[@]}" --cancel-button Exit-Script 3>&1 1>&2 2>&3); then + echo -e "${ISO}${BOLD}${DGN}ISO Chosen: ${BGN}$(basename "$SELECTED_ISO")${CL}" + else + exit-script + fi + + if DISK_SIZE=$(whiptail --backtitle "Proxmox VE Helper Scripts" --inputbox "Set Disk Size in GiB (e.g., 10, 20)" 8 58 "$DISK_SIZE" --title "DISK SIZE" --cancel-button Exit-Script 3>&1 1>&2 2>&3); then + DISK_SIZE=$(echo "$DISK_SIZE" | tr -d ' ') + if [[ "$DISK_SIZE" =~ ^[0-9]+$ ]]; then + echo -e "${DISKSIZE}${BOLD}${DGN}Disk Size: ${BGN}$DISK_SIZE${CL}" + else + echo -e "${DISKSIZE}${BOLD}${RD}Invalid Disk Size. Please use a number (e.g., 10).${CL}" + exit-script + fi + else + exit-script + fi + + if VM_NAME=$(whiptail --backtitle "Proxmox VE Helper Scripts" --inputbox "Set Hostname" 8 58 truenas --title "HOSTNAME" --cancel-button Exit-Script 3>&1 1>&2 2>&3); then + if [ -z $VM_NAME ]; then + HN="truenas" + echo -e "${HOSTNAME}${BOLD}${DGN}Hostname: ${BGN}$HN${CL}" + else + HN=$(echo ${VM_NAME,,} | tr -d ' ') + echo -e "${HOSTNAME}${BOLD}${DGN}Hostname: ${BGN}$HN${CL}" + fi + else + exit-script + fi + + if CPU_TYPE1=$(whiptail --backtitle "Proxmox VE Helper Scripts" --title "CPU MODEL" --radiolist "Choose CPU Model" --cancel-button Exit-Script 10 58 2 \ + "KVM64" "Default – safe for migration/compatibility" OFF \ + "Host" "Use host CPU features (faster, no migration)" ON \ + 3>&1 1>&2 2>&3); then + case "$CPU_TYPE1" in + Host) + echo -e "${OS}${BOLD}${DGN}CPU Model: ${BGN}Host${CL}" + CPU_TYPE="host" + ;; + *) + echo -e "${OS}${BOLD}${DGN}CPU Model: ${BGN}KVM64${CL}" + CPU_TYPE="" + ;; + esac + else + exit-script + fi + + if CORE_COUNT=$(whiptail --backtitle "Proxmox VE Helper Scripts" --inputbox "Allocate CPU Cores" 8 58 2 --title "CORE COUNT" --cancel-button Exit-Script 3>&1 1>&2 2>&3); then + if [ -z $CORE_COUNT ]; then + CORE_COUNT="2" + echo -e "${CPUCORE}${BOLD}${DGN}CPU Cores: ${BGN}$CORE_COUNT${CL}" + else + echo -e "${CPUCORE}${BOLD}${DGN}CPU Cores: ${BGN}$CORE_COUNT${CL}" + fi + else + exit-script + fi + + if RAM_SIZE=$(whiptail --backtitle "Proxmox VE Helper Scripts" --inputbox "Allocate RAM in MiB" 8 58 8192 --title "RAM" --cancel-button Exit-Script 3>&1 1>&2 2>&3); then + if [ -z $RAM_SIZE ]; then + RAM_SIZE="8192" + echo -e "${RAMSIZE}${BOLD}${DGN}RAM Size: ${BGN}$RAM_SIZE${CL}" + else + echo -e "${RAMSIZE}${BOLD}${DGN}RAM Size: ${BGN}$RAM_SIZE${CL}" + fi + else + exit-script + fi + + if BRG=$(whiptail --backtitle "Proxmox VE Helper Scripts" --inputbox "Set a Bridge" 8 58 vmbr0 --title "BRIDGE" --cancel-button Exit-Script 3>&1 1>&2 2>&3); then + if [ -z $BRG ]; then + BRG="vmbr0" + echo -e "${BRIDGE}${BOLD}${DGN}Bridge: ${BGN}$BRG${CL}" + else + echo -e "${BRIDGE}${BOLD}${DGN}Bridge: ${BGN}$BRG${CL}" + fi + else + exit-script + fi + + if MAC1=$(whiptail --backtitle "Proxmox VE Helper Scripts" --inputbox "Set a MAC Address" 8 58 $GEN_MAC --title "MAC ADDRESS" --cancel-button Exit-Script 3>&1 1>&2 2>&3); then + if [ -z $MAC1 ]; then + MAC="$GEN_MAC" + echo -e "${MACADDRESS}${BOLD}${DGN}MAC Address: ${BGN}$MAC${CL}" + else + MAC="$MAC1" + echo -e "${MACADDRESS}${BOLD}${DGN}MAC Address: ${BGN}$MAC1${CL}" + fi + else + exit-script + fi + + if VLAN1=$(whiptail --backtitle "Proxmox VE Helper Scripts" --inputbox "Set a Vlan(leave blank for default)" 8 58 --title "VLAN" --cancel-button Exit-Script 3>&1 1>&2 2>&3); then + if [ -z $VLAN1 ]; then + VLAN1="Default" + VLAN="" + echo -e "${VLANTAG}${BOLD}${DGN}VLAN: ${BGN}$VLAN1${CL}" + else + VLAN=",tag=$VLAN1" + echo -e "${VLANTAG}${BOLD}${DGN}VLAN: ${BGN}$VLAN1${CL}" + fi + else + exit-script + fi + + if MTU1=$(whiptail --backtitle "Proxmox VE Helper Scripts" --inputbox "Set Interface MTU Size (leave blank for default)" 8 58 --title "MTU SIZE" --cancel-button Exit-Script 3>&1 1>&2 2>&3); then + if [ -z $MTU1 ]; then + MTU1="Default" + MTU="" + echo -e "${DEFAULT}${BOLD}${DGN}Interface MTU Size: ${BGN}$MTU1${CL}" + else + MTU=",mtu=$MTU1" + echo -e "${DEFAULT}${BOLD}${DGN}Interface MTU Size: ${BGN}$MTU1${CL}" + fi + else + exit-script + fi + + if (whiptail --backtitle "Proxmox VE Helper Scripts" --defaultno --title "IMPORT ONBOARD DISKS" --yesno "Would you like to import onboard disks?" 10 58); then + echo -e "${DISK}${BOLD}${DGN}Import onboard disks: ${BGN}yes${CL}" + IMPORT_DISKS="yes" + else + echo -e "${DISK}${BOLD}${DGN}Import onboard disks: ${BGN}no${CL}" + IMPORT_DISKS="no" + fi + + if (whiptail --backtitle "Proxmox VE Helper Scripts" --title "START VIRTUAL MACHINE" --yesno "Start VM when completed?" 10 58); then + echo -e "${GATEWAY}${BOLD}${DGN}Start VM when completed: ${BGN}yes${CL}" + START_VM="yes" + else + echo -e "${GATEWAY}${BOLD}${DGN}Start VM when completed: ${BGN}no${CL}" + START_VM="no" + fi + + if (whiptail --backtitle "Proxmox VE Helper Scripts" --title "ADVANCED SETTINGS COMPLETE" --yesno "Ready to create a TrueNAS VM?" --no-button Do-Over 10 58); then + echo -e "${CREATING}${BOLD}${DGN}Creating a TrueNAS VM using the above advanced settings${CL}" + else + header_info + echo -e "${ADVANCED}${BOLD}${RD}Using Advanced Settings${CL}" + advanced_settings + fi +} + +function start_script() { + if (whiptail --backtitle "Proxmox VE Helper Scripts" --title "SETTINGS" --yesno "Use Default Settings?" --no-button Advanced 10 58); then + header_info + echo -e "${DEFAULT}${BOLD}${BL}Using Default Settings${CL}" + default_settings + else + header_info + echo -e "${ADVANCED}${BOLD}${RD}Using Advanced Settings${CL}" + advanced_settings + fi +} +check_root +arch_check +pve_check +ssh_check +start_script +post_to_api_vm + +msg_info "Validating Storage" +while read -r line; do + TAG=$(echo $line | awk '{print $1}') + TYPE=$(echo $line | awk '{printf "%-10s", $2}') + FREE=$(echo $line | numfmt --field 4-6 --from-unit=K --to=iec --format %.2f | awk '{printf( "%9sB", $6)}') + ITEM=" Type: $TYPE Free: $FREE " + OFFSET=2 + if [[ $((${#ITEM} + $OFFSET)) -gt ${MSG_MAX_LENGTH:-} ]]; then + MSG_MAX_LENGTH=$((${#ITEM} + $OFFSET)) + fi + STORAGE_MENU+=("$TAG" "$ITEM" "OFF") +done < <(pvesm status -content images | awk 'NR>1') +VALID=$(pvesm status -content images | awk 'NR>1') +if [ -z "$VALID" ]; then + msg_error "Unable to detect a valid storage location." + exit +elif [ $((${#STORAGE_MENU[@]} / 3)) -eq 1 ]; then + STORAGE=${STORAGE_MENU[0]} +else + while [ -z "${STORAGE:+x}" ]; do + if [ -n "$SPINNER_PID" ] && ps -p $SPINNER_PID >/dev/null; then kill $SPINNER_PID >/dev/null; fi + printf "\e[?25h" + STORAGE=$(whiptail --backtitle "Proxmox VE Helper Scripts" --title "Storage Pools" --radiolist \ + "Which storage pool would you like to use for ${HN}?\nTo make a selection, use the Spacebar.\n" \ + 16 $(($MSG_MAX_LENGTH + 23)) 6 \ + "${STORAGE_MENU[@]}" 3>&1 1>&2 2>&3) + done +fi +msg_ok "Using ${CL}${BL}$STORAGE${CL} ${GN}for Storage Location." +msg_ok "Virtual Machine ID is ${CL}${BL}$VMID${CL}." + +if [ -z "${SELECTED_ISO:-}" ]; then + # Fallback: Find the latest stable release only (excluding RC/BETA for safety) + SELECTED_ISO=$(truenas_iso_lookup | grep -vE 'RC|BETA' | sort -V | tail -n 1) + + if [ -z "$SELECTED_ISO" ]; then + msg_error "Could not find a stable ISO for fallback." + exit 1 + fi +fi + +FULL_URL="https://download.truenas.com/${SELECTED_ISO#/}" +ISO_NAME=$(basename "$FULL_URL") +CACHE_DIR="/var/lib/vz/template/iso" +CACHE_FILE="$CACHE_DIR/$ISO_NAME" + +if [[ ! -s "$CACHE_FILE" ]]; then + msg_info "Retrieving the ISO for the TrueNAS Disk Image" + curl -f#SL -o "$CACHE_FILE" "$FULL_URL" + msg_ok "Downloaded ${CL}${BL}$(basename "$CACHE_FILE")${CL}" +else + msg_ok "Using cached image ${CL}${BL}$(basename "$CACHE_FILE")${CL}" +fi + +set -o pipefail +msg_info "Creating TrueNAS VM shell" +qm create "$VMID" -machine q35 -bios ovmf -agent enabled=1 -tablet 0 -localtime 1 -cpu "$CPU_TYPE" \ + -cores "$CORE_COUNT" -memory "$RAM_SIZE" -balloon 0 -name "$HN" -tags community-script \ + -net0 "virtio,bridge=$BRG,macaddr=$MAC$VLAN$MTU" -onboot 1 -ostype l26 \ + -efidisk0 $STORAGE:1,efitype=4m,pre-enrolled-keys=0 -scsi0 $STORAGE:$DISK_SIZE,ssd=1,iothread=on \ + -scsihw virtio-scsi-single -cdrom local:iso/$ISO_NAME -vga virtio >/dev/null +msg_ok "Created VM shell" + +if [ "$IMPORT_DISKS" == "yes" ]; then + msg_info "Importing onboard disks" + DISKARRAY=() + SCSI_NR=0 + + while read -r LSOUTPUT; do + DISKARRAY+=("$LSOUTPUT" "" "OFF") + done < <(ls /dev/disk/by-id | grep -E '^ata-|^nvme-' | grep -v 'part') + + SELECTIONS=$(whiptail --backtitle "Proxmox VE Helper Scripts" --title "SELECT DISKS TO IMPORT" --checklist "\nSelect disk IDs to import. (Use Spacebar to select)\n" --cancel-button "Exit Script" 20 58 10 "${DISKARRAY[@]}" 3>&1 1>&2 2>&3 | tr -d '"') || exit + + for SELECTION in $SELECTIONS; do + ((++SCSI_NR)) + qm set $VMID --scsi$SCSI_NR /dev/disk/by-id/$SELECTION + done + msg_ok "Disks imported successfully" +fi + +DESCRIPTION=$( + cat < + + Logo + + +

TrueNAS VM

+ +

+ + spend Coffee + +

+ + + + GitHub + + + + Discussions + + + + Issues + + +EOF +) +qm set "$VMID" -description "$DESCRIPTION" >/dev/null + +msg_ok "Created a TrueNAS VM ${CL}${BL}(${HN})" +if [ "$START_VM" == "yes" ]; then + msg_info "Starting TrueNAS VM" + qm start $VMID + msg_ok "Started TrueNAS VM" +fi + +msg_ok "Completed Successfully! Go to VM console and start installation process.\n" From 9872ea39f3824f0f996ab9882c33f23ec6d2b3a8 Mon Sep 17 00:00:00 2001 From: juronja <101410098+juronja@users.noreply.github.com> Date: Thu, 15 Jan 2026 15:52:19 +0000 Subject: [PATCH 02/33] api func source changed to VED --- vm/truenas-vm.sh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/vm/truenas-vm.sh b/vm/truenas-vm.sh index ab796ee77..5808b070e 100644 --- a/vm/truenas-vm.sh +++ b/vm/truenas-vm.sh @@ -4,7 +4,7 @@ # Author: juronja # License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE -source /dev/stdin <<<$(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/api.func) +source /dev/stdin <<<$(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVED/main/misc/api.func) function header_info() { clear @@ -262,7 +262,7 @@ function default_settings() { METHOD="default" echo -e "${CONTAINERID}${BOLD}${DGN}Virtual Machine ID: ${BGN}${VMID}${CL}" echo -e "${ISO}${BOLD}${DGN}ISO Chosen: ${BGN}${ISO_DEFAULT}${CL}" - echo -e "${CONTAINERTYPE}${BOLD}${DGN}Machine Type: ${BGN}q35${CL}" + echo -e "${CONTAINERTYPE}${BOLD}${DGN}Machine Type: ${BGN}${MACHINE}${CL}" echo -e "${DISKSIZE}${BOLD}${DGN}Disk Size: ${BGN}${DISK_SIZE}${CL}" echo -e "${HOSTNAME}${BOLD}${DGN}Hostname: ${BGN}${HN}${CL}" echo -e "${OS}${BOLD}${DGN}CPU Model: ${BGN}${CPU_TYPE}${CL}" From e748ad5a6d7d1d9da5d65bf48cf1f79b1737a8b2 Mon Sep 17 00:00:00 2001 From: juronja <101410098+juronja@users.noreply.github.com> Date: Thu, 15 Jan 2026 16:02:20 +0000 Subject: [PATCH 03/33] added sleep for disk pickup --- vm/truenas-vm.sh | 2 ++ 1 file changed, 2 insertions(+) diff --git a/vm/truenas-vm.sh b/vm/truenas-vm.sh index 5808b070e..453979eac 100644 --- a/vm/truenas-vm.sh +++ b/vm/truenas-vm.sh @@ -582,6 +582,8 @@ EOF ) qm set "$VMID" -description "$DESCRIPTION" >/dev/null +sleep 5 + msg_ok "Created a TrueNAS VM ${CL}${BL}(${HN})" if [ "$START_VM" == "yes" ]; then msg_info "Starting TrueNAS VM" From 42b192272db5fe2686db0b894f6c8a75a0004a17 Mon Sep 17 00:00:00 2001 From: juronja <101410098+juronja@users.noreply.github.com> Date: Thu, 15 Jan 2026 16:19:00 +0000 Subject: [PATCH 04/33] testing with 3 sec sleep --- vm/truenas-vm.sh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/vm/truenas-vm.sh b/vm/truenas-vm.sh index 453979eac..cdbc789b4 100644 --- a/vm/truenas-vm.sh +++ b/vm/truenas-vm.sh @@ -557,7 +557,7 @@ DESCRIPTION=$( Logo -

TrueNAS VM

+

TrueNAS Community Edition

@@ -582,7 +582,7 @@ EOF ) qm set "$VMID" -description "$DESCRIPTION" >/dev/null -sleep 5 +sleep 3 msg_ok "Created a TrueNAS VM ${CL}${BL}(${HN})" if [ "$START_VM" == "yes" ]; then From d979edecf1d7f5bcfc16cbe9ca7111cefc378d68 Mon Sep 17 00:00:00 2001 From: juronja <101410098+juronja@users.noreply.github.com> Date: Fri, 16 Jan 2026 11:16:21 +0000 Subject: [PATCH 05/33] Fetching iso list msg --- vm/truenas-vm.sh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/vm/truenas-vm.sh b/vm/truenas-vm.sh index cdbc789b4..7f46ce73d 100644 --- a/vm/truenas-vm.sh +++ b/vm/truenas-vm.sh @@ -296,7 +296,7 @@ function advanced_settings() { fi done - # ISO lookup + msg_info "Fetching iso list from https://download.truenas.com/" ISOARRAY=() while read -r ISOPATH; do FILENAME=$(basename "$ISOPATH") @@ -591,4 +591,4 @@ if [ "$START_VM" == "yes" ]; then msg_ok "Started TrueNAS VM" fi -msg_ok "Completed Successfully! Go to VM console and start installation process.\n" +msg_ok "Completed Successfully!\n" From 773d588232229d01c256171b3d10e88b788de2d7 Mon Sep 17 00:00:00 2001 From: juronja <101410098+juronja@users.noreply.github.com> Date: Fri, 16 Jan 2026 11:26:25 +0000 Subject: [PATCH 06/33] removed info message --- vm/truenas-vm.sh | 1 - 1 file changed, 1 deletion(-) diff --git a/vm/truenas-vm.sh b/vm/truenas-vm.sh index 7f46ce73d..675a4de7a 100644 --- a/vm/truenas-vm.sh +++ b/vm/truenas-vm.sh @@ -296,7 +296,6 @@ function advanced_settings() { fi done - msg_info "Fetching iso list from https://download.truenas.com/" ISOARRAY=() while read -r ISOPATH; do FILENAME=$(basename "$ISOPATH") From fabeb9f0d6897c35a5fd55ba86f2e98ff1987a67 Mon Sep 17 00:00:00 2001 From: juronja <101410098+juronja@users.noreply.github.com> Date: Fri, 16 Jan 2026 11:34:48 +0000 Subject: [PATCH 07/33] added comments for custom code specific to truenas --- vm/truenas-vm.sh | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/vm/truenas-vm.sh b/vm/truenas-vm.sh index 675a4de7a..b81525ee2 100644 --- a/vm/truenas-vm.sh +++ b/vm/truenas-vm.sh @@ -73,6 +73,9 @@ function error_handler() { cleanup_vmid } +# Scrapes the TrueNAS download portal for ISO paths from the current and previous year, +# filtering out nightlies/alphas and returning the latest stable releases for each major +# version along with any beta or RC pre-releases. function truenas_iso_lookup() { local BASE_URL="https://download.truenas.com" local current_year=$(date +%y) @@ -296,6 +299,7 @@ function advanced_settings() { fi done + # Fetching iso list from TrueNAS downloads for whiptail radiolist ISOARRAY=() while read -r ISOPATH; do FILENAME=$(basename "$ISOPATH") @@ -531,6 +535,7 @@ qm create "$VMID" -machine q35 -bios ovmf -agent enabled=1 -tablet 0 -localtime -scsihw virtio-scsi-single -cdrom local:iso/$ISO_NAME -vga virtio >/dev/null msg_ok "Created VM shell" +# Optional step to import onboard disks if [ "$IMPORT_DISKS" == "yes" ]; then msg_info "Importing onboard disks" DISKARRAY=() From f04946cae8e63238db8d195de3cf9a6295c0bd60 Mon Sep 17 00:00:00 2001 From: juronja <101410098+juronja@users.noreply.github.com> Date: Fri, 16 Jan 2026 13:20:18 +0100 Subject: [PATCH 08/33] Adding source in file header Co-authored-by: greptile-apps[bot] <165735046+greptile-apps[bot]@users.noreply.github.com> --- vm/truenas-vm.sh | 1 + 1 file changed, 1 insertion(+) diff --git a/vm/truenas-vm.sh b/vm/truenas-vm.sh index b81525ee2..54b5652f9 100644 --- a/vm/truenas-vm.sh +++ b/vm/truenas-vm.sh @@ -3,6 +3,7 @@ # Copyright (c) 2021-2026 community-scripts ORG # Author: juronja # License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE +# Source: https://www.truenas.com/truenas-community-edition/ source /dev/stdin <<<$(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVED/main/misc/api.func) From f91ba71b8a3d0e456fed2e1b851a1fa4fc4a8a35 Mon Sep 17 00:00:00 2001 From: Joerg Heinemann Date: Mon, 26 Jan 2026 15:31:48 +0100 Subject: [PATCH 09/33] Initial commit for ebusd New script for ebusd --- ct/ebusd.sh | 43 +++++++++++++++++++++++++++ ct/headers/ebusd | 6 ++++ frontend/public/json/ebusd.json | 52 +++++++++++++++++++++++++++++++++ install/ebusd-install.sh | 39 +++++++++++++++++++++++++ 4 files changed, 140 insertions(+) create mode 100644 ct/ebusd.sh create mode 100644 ct/headers/ebusd create mode 100644 frontend/public/json/ebusd.json create mode 100644 install/ebusd-install.sh diff --git a/ct/ebusd.sh b/ct/ebusd.sh new file mode 100644 index 000000000..5ce7fd284 --- /dev/null +++ b/ct/ebusd.sh @@ -0,0 +1,43 @@ +#!/usr/bin/env bash +source <(curl -fsSL https://raw.githubusercontent.com/heinemannj/ProxmoxVE/main/misc/build.func) +# Copyright (c) 2021-2026 community-scripts ORG +# Author: Joerg Heinemann (heinemannj) +# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE +# Source: https://github.com/john30/ebusd + +APP="ebusd" +var_tags="${var_tags:-automation}" +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/apt/sources.list.d/ebusd.sources ]]; then + msg_error "No ${APP} Installation Found!" + exit + fi + msg_info "Updating $APP LXC" + $STD apt update + $STD apt -y upgrade + msg_ok "Updated $APP LXC" + 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}" diff --git a/ct/headers/ebusd b/ct/headers/ebusd new file mode 100644 index 000000000..fec79a3e3 --- /dev/null +++ b/ct/headers/ebusd @@ -0,0 +1,6 @@ + __ __ + ___ / /_ _ ___________/ / + / _ \/ __ \/ / / / ___/ __ / +/ __/ /_/ / /_/ (__ ) /_/ / +\___/_.___/\__,_/____/\__,_/ + diff --git a/frontend/public/json/ebusd.json b/frontend/public/json/ebusd.json new file mode 100644 index 000000000..3db2f8542 --- /dev/null +++ b/frontend/public/json/ebusd.json @@ -0,0 +1,52 @@ +{ + "name": "ebusd", + "slug": "ebusd", + "categories": [ + 16 + ], + "date_created": "2026-01-26", + "type": "ct", + "updateable": true, + "privileged": false, + "interface_port": null, + "documentation": "https://github.com/john30/ebusd/wiki", + "website": "https://github.com/john30/ebusd", + "logo": "", + "config_path": "/etc/default/ebusd", + "description": "ebusd is a daemon for handling communication with eBUS devices connected to a 2-wire bus system ("energy bus" used by numerous heating systems).", + "install_methods": [ + { + "type": "default", + "script": "ct/ebusd.sh", + "resources": { + "cpu": 1, + "ram": 512, + "hdd": 2, + "os": "debian", + "version": "13" + } + } + ], + "default_credentials": { + "username": null, + "password": null + }, + "notes": [ + { + "text": "Instructions: \ + 1. Edit `/etc/default/ebusd` if necessary (especially if your device is not `/dev/ttyUSB0`) \ + 2. Start the daemon with `systemctl start ebusd` \ + 3. Check the log file `/var/log/ebusd.log` \ + 4. Make the daemon autostart with `systemctl enable ebusd`", + "type": "info" + }, + { + "text": "Working `/etc/default/ebusd` options for `ebus adapter shield v5`: EBUSD_OPTS='--pidfile=/run/ebusd.pid --latency=100 --scanconfig --configpath=https://ebus.github.io/ --accesslevel=* --pollinterval=30 --device=ens:x.x.x.x:9999 --mqtthost=x.x.x.x --mqttport=1883 --mqttuser=ha-mqtt --mqttpass=xxxxxxxx! --mqttint=/etc/ebusd/mqtt-hassio.cfg --mqttjson --mqttlog --mqttretain --mqtttopic=ebusd --log=all:notice --log=main:notice --log=bus:notice --log=update:notice --log=network:notice --log=other:notice'", + "type": "info" + }, + { + "text": "Only tested with `ebusd-25.1_amd64-bookworm.deb`!", + "type": "warning" + } + ] +} diff --git a/install/ebusd-install.sh b/install/ebusd-install.sh new file mode 100644 index 000000000..32c2eb9a2 --- /dev/null +++ b/install/ebusd-install.sh @@ -0,0 +1,39 @@ +#!/usr/bin/env bash + +# Copyright (c) 2021-2026 community-scripts ORG +# Author: Joerg Heinemann (heinemannj) +# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE +# Source: https://github.com/john30/ebusd + +source /dev/stdin <<<"$FUNCTIONS_FILE_PATH" +color +verb_ip6 +catch_errors +setting_up_container +network_check +update_os + +msg_info "Setting up ebusd Repository" +setup_deb822_repo \ + "ebusd" \ + "https://raw.githubusercontent.com/john30/ebusd-debian/master/ebusd.gpg" \ + "https://repo.ebusd.eu/apt/default/bookworm/" \ + "bookworm" \ + "main" +$STD apt update +msg_ok "ebusd Repository setup sucessfully" + +msg_info "Installing ebusd" +$STD apt install -y ebusd +msg_ok "Installed ebusd" + +msg_info "Follow below instructions to make the daemon autostart:" +msg_info "1. Edit '/etc/default/ebusd' if necessary (especially if your device is not '/dev/ttyUSB0')" +msg_info "2. Start the daemon with 'systemctl start ebusd'" +msg_info "3. Check the daemon status with 'systemctl status ebusd'" +msg_info "4. Check the log file '/var/log/ebusd.log'" +msg_info "5. Make the daemon autostart with 'systemctl enable ebusd'" + +motd_ssh +customize +cleanup_lxc From d62da49b8afa502ae0f754dbf9fe5770137a7659 Mon Sep 17 00:00:00 2001 From: Joerg Heinemann Date: Mon, 26 Jan 2026 15:54:25 +0100 Subject: [PATCH 10/33] Update ct/ebusd.sh Co-authored-by: greptile-apps[bot] <165735046+greptile-apps[bot]@users.noreply.github.com> --- ct/ebusd.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ct/ebusd.sh b/ct/ebusd.sh index 5ce7fd284..732bc8179 100644 --- a/ct/ebusd.sh +++ b/ct/ebusd.sh @@ -1,5 +1,5 @@ #!/usr/bin/env bash -source <(curl -fsSL https://raw.githubusercontent.com/heinemannj/ProxmoxVE/main/misc/build.func) +source <(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVED/main/misc/build.func) # Copyright (c) 2021-2026 community-scripts ORG # Author: Joerg Heinemann (heinemannj) # License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE From 4888dbca6c47b25d13ddcdc6c3bd9b8c0d9d850a Mon Sep 17 00:00:00 2001 From: Joerg Heinemann Date: Mon, 26 Jan 2026 15:55:17 +0100 Subject: [PATCH 11/33] Update ct/ebusd.sh Co-authored-by: greptile-apps[bot] <165735046+greptile-apps[bot]@users.noreply.github.com> --- ct/ebusd.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ct/ebusd.sh b/ct/ebusd.sh index 732bc8179..2791cb696 100644 --- a/ct/ebusd.sh +++ b/ct/ebusd.sh @@ -2,7 +2,7 @@ source <(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVED/main/misc/build.func) # Copyright (c) 2021-2026 community-scripts ORG # Author: Joerg Heinemann (heinemannj) -# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE +# License: MIT | https://github.com/community-scripts/ProxmoxVED/raw/main/LICENSE # Source: https://github.com/john30/ebusd APP="ebusd" From b945cf7543467733676c6a40c21cfd1f7415b9f1 Mon Sep 17 00:00:00 2001 From: Joerg Heinemann Date: Mon, 26 Jan 2026 15:57:30 +0100 Subject: [PATCH 12/33] Update install/ebusd-install.sh Co-authored-by: greptile-apps[bot] <165735046+greptile-apps[bot]@users.noreply.github.com> --- install/ebusd-install.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/install/ebusd-install.sh b/install/ebusd-install.sh index 32c2eb9a2..1abc0b12b 100644 --- a/install/ebusd-install.sh +++ b/install/ebusd-install.sh @@ -2,7 +2,7 @@ # Copyright (c) 2021-2026 community-scripts ORG # Author: Joerg Heinemann (heinemannj) -# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE +# License: MIT | https://github.com/community-scripts/ProxmoxVED/raw/main/LICENSE # Source: https://github.com/john30/ebusd source /dev/stdin <<<"$FUNCTIONS_FILE_PATH" From 482681222aceb4541d464444492ae6f9bdbe2ad1 Mon Sep 17 00:00:00 2001 From: Joerg Heinemann Date: Mon, 26 Jan 2026 15:58:22 +0100 Subject: [PATCH 13/33] Update install/ebusd-install.sh Co-authored-by: greptile-apps[bot] <165735046+greptile-apps[bot]@users.noreply.github.com> --- install/ebusd-install.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/install/ebusd-install.sh b/install/ebusd-install.sh index 1abc0b12b..17c21b96a 100644 --- a/install/ebusd-install.sh +++ b/install/ebusd-install.sh @@ -21,7 +21,7 @@ setup_deb822_repo \ "bookworm" \ "main" $STD apt update -msg_ok "ebusd Repository setup sucessfully" +msg_ok "ebusd Repository setup successfully" msg_info "Installing ebusd" $STD apt install -y ebusd From 8a06452794e3d0bafe37566c2a4fc217f2c50fc9 Mon Sep 17 00:00:00 2001 From: Joerg Heinemann Date: Mon, 26 Jan 2026 15:58:59 +0100 Subject: [PATCH 14/33] Update frontend/public/json/ebusd.json Co-authored-by: greptile-apps[bot] <165735046+greptile-apps[bot]@users.noreply.github.com> --- frontend/public/json/ebusd.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/frontend/public/json/ebusd.json b/frontend/public/json/ebusd.json index 3db2f8542..0be1da11b 100644 --- a/frontend/public/json/ebusd.json +++ b/frontend/public/json/ebusd.json @@ -28,7 +28,7 @@ } ], "default_credentials": { - "username": null, + "username": "root", "password": null }, "notes": [ From 9c03a5dcd636e579f771c9ebc39468694380df34 Mon Sep 17 00:00:00 2001 From: "CanbiZ (MickLesk)" <47820557+MickLesk@users.noreply.github.com> Date: Mon, 26 Jan 2026 21:24:54 +0100 Subject: [PATCH 15/33] Update install/ebusd-install.sh Co-authored-by: Tobias <96661824+CrazyWolf13@users.noreply.github.com> --- install/ebusd-install.sh | 3 --- 1 file changed, 3 deletions(-) diff --git a/install/ebusd-install.sh b/install/ebusd-install.sh index 17c21b96a..c43be4708 100644 --- a/install/ebusd-install.sh +++ b/install/ebusd-install.sh @@ -13,15 +13,12 @@ setting_up_container network_check update_os -msg_info "Setting up ebusd Repository" setup_deb822_repo \ "ebusd" \ "https://raw.githubusercontent.com/john30/ebusd-debian/master/ebusd.gpg" \ "https://repo.ebusd.eu/apt/default/bookworm/" \ "bookworm" \ "main" -$STD apt update -msg_ok "ebusd Repository setup successfully" msg_info "Installing ebusd" $STD apt install -y ebusd From 2371ae3849efa2f9a2d0974424fa3c2de76d9718 Mon Sep 17 00:00:00 2001 From: Joerg Heinemann Date: Tue, 27 Jan 2026 06:42:40 +0100 Subject: [PATCH 16/33] Update frontend/public/json/ebusd.json Co-authored-by: Tobias <96661824+CrazyWolf13@users.noreply.github.com> --- frontend/public/json/ebusd.json | 4 ---- 1 file changed, 4 deletions(-) diff --git a/frontend/public/json/ebusd.json b/frontend/public/json/ebusd.json index 0be1da11b..96d94b7a8 100644 --- a/frontend/public/json/ebusd.json +++ b/frontend/public/json/ebusd.json @@ -44,9 +44,5 @@ "text": "Working `/etc/default/ebusd` options for `ebus adapter shield v5`: EBUSD_OPTS='--pidfile=/run/ebusd.pid --latency=100 --scanconfig --configpath=https://ebus.github.io/ --accesslevel=* --pollinterval=30 --device=ens:x.x.x.x:9999 --mqtthost=x.x.x.x --mqttport=1883 --mqttuser=ha-mqtt --mqttpass=xxxxxxxx! --mqttint=/etc/ebusd/mqtt-hassio.cfg --mqttjson --mqttlog --mqttretain --mqtttopic=ebusd --log=all:notice --log=main:notice --log=bus:notice --log=update:notice --log=network:notice --log=other:notice'", "type": "info" }, - { - "text": "Only tested with `ebusd-25.1_amd64-bookworm.deb`!", - "type": "warning" - } ] } From dfeb8a8e1fe84f3cfc3bc6b711c38d3cae4136f6 Mon Sep 17 00:00:00 2001 From: Joerg Heinemann Date: Tue, 27 Jan 2026 06:47:34 +0100 Subject: [PATCH 17/33] Update ct/ebusd.sh Co-authored-by: Tobias <96661824+CrazyWolf13@users.noreply.github.com> --- ct/ebusd.sh | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/ct/ebusd.sh b/ct/ebusd.sh index 2791cb696..63f16f512 100644 --- a/ct/ebusd.sh +++ b/ct/ebusd.sh @@ -27,10 +27,10 @@ function update_script() { msg_error "No ${APP} Installation Found!" exit fi - msg_info "Updating $APP LXC" + msg_info "Updating ebusd" $STD apt update - $STD apt -y upgrade - msg_ok "Updated $APP LXC" + $STD apt -y --upgrade ebusd + msg_ok "Updated ebusd" msg_ok "Updated successfully!" exit } From 0e87e5f76955a31d795d1857d5ae3e1feee41fe9 Mon Sep 17 00:00:00 2001 From: Joerg Heinemann Date: Tue, 27 Jan 2026 06:54:24 +0100 Subject: [PATCH 18/33] Update description format in ebusd.json --- frontend/public/json/ebusd.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/frontend/public/json/ebusd.json b/frontend/public/json/ebusd.json index 96d94b7a8..b902ea7a2 100644 --- a/frontend/public/json/ebusd.json +++ b/frontend/public/json/ebusd.json @@ -13,7 +13,7 @@ "website": "https://github.com/john30/ebusd", "logo": "", "config_path": "/etc/default/ebusd", - "description": "ebusd is a daemon for handling communication with eBUS devices connected to a 2-wire bus system ("energy bus" used by numerous heating systems).", + "description": "ebusd is a daemon for handling communication with eBUS devices connected to a 2-wire `energy bus` used by numerous heating systems.", "install_methods": [ { "type": "default", From 90718b440acac48b5b016ee64f8d22abcf4a834a Mon Sep 17 00:00:00 2001 From: Joerg Heinemann Date: Tue, 27 Jan 2026 16:19:14 +0100 Subject: [PATCH 19/33] Clean up installation script by removing autostart instructions Removed instructions for making the ebusd daemon autostart. --- install/ebusd-install.sh | 8 +------- 1 file changed, 1 insertion(+), 7 deletions(-) diff --git a/install/ebusd-install.sh b/install/ebusd-install.sh index c43be4708..0ede2e9b8 100644 --- a/install/ebusd-install.sh +++ b/install/ebusd-install.sh @@ -22,15 +22,9 @@ setup_deb822_repo \ msg_info "Installing ebusd" $STD apt install -y ebusd +$STD systemctl enable ebusd msg_ok "Installed ebusd" -msg_info "Follow below instructions to make the daemon autostart:" -msg_info "1. Edit '/etc/default/ebusd' if necessary (especially if your device is not '/dev/ttyUSB0')" -msg_info "2. Start the daemon with 'systemctl start ebusd'" -msg_info "3. Check the daemon status with 'systemctl status ebusd'" -msg_info "4. Check the log file '/var/log/ebusd.log'" -msg_info "5. Make the daemon autostart with 'systemctl enable ebusd'" - motd_ssh customize cleanup_lxc From 1658c13309a54c87b7fb5a976fcba5751ffdb13d Mon Sep 17 00:00:00 2001 From: Joerg Heinemann Date: Wed, 28 Jan 2026 11:09:09 +0100 Subject: [PATCH 20/33] Update logo and configuration instructions in ebusd.json --- frontend/public/json/ebusd.json | 14 +++----------- 1 file changed, 3 insertions(+), 11 deletions(-) diff --git a/frontend/public/json/ebusd.json b/frontend/public/json/ebusd.json index b902ea7a2..e946af464 100644 --- a/frontend/public/json/ebusd.json +++ b/frontend/public/json/ebusd.json @@ -11,7 +11,7 @@ "interface_port": null, "documentation": "https://github.com/john30/ebusd/wiki", "website": "https://github.com/john30/ebusd", - "logo": "", + "logo": "https://cdn.jsdelivr.net/gh/selfhst/icons@main/webp/proxmox-helper-scripts.webp", "config_path": "/etc/default/ebusd", "description": "ebusd is a daemon for handling communication with eBUS devices connected to a 2-wire `energy bus` used by numerous heating systems.", "install_methods": [ @@ -33,16 +33,8 @@ }, "notes": [ { - "text": "Instructions: \ - 1. Edit `/etc/default/ebusd` if necessary (especially if your device is not `/dev/ttyUSB0`) \ - 2. Start the daemon with `systemctl start ebusd` \ - 3. Check the log file `/var/log/ebusd.log` \ - 4. Make the daemon autostart with `systemctl enable ebusd`", + "text": "Show configuration instructions: `cat ~/ebusd-configuation-instructions.txt`", "type": "info" - }, - { - "text": "Working `/etc/default/ebusd` options for `ebus adapter shield v5`: EBUSD_OPTS='--pidfile=/run/ebusd.pid --latency=100 --scanconfig --configpath=https://ebus.github.io/ --accesslevel=* --pollinterval=30 --device=ens:x.x.x.x:9999 --mqtthost=x.x.x.x --mqttport=1883 --mqttuser=ha-mqtt --mqttpass=xxxxxxxx! --mqttint=/etc/ebusd/mqtt-hassio.cfg --mqttjson --mqttlog --mqttretain --mqtttopic=ebusd --log=all:notice --log=main:notice --log=bus:notice --log=update:notice --log=network:notice --log=other:notice'", - "type": "info" - }, + } ] } From e1be251201474ad35cef44fbf15a5dce47327d88 Mon Sep 17 00:00:00 2001 From: Joerg Heinemann Date: Wed, 28 Jan 2026 13:16:35 +0100 Subject: [PATCH 21/33] Add ebusd configuration instructions to a text file Added configuration instructions for ebusd in a new text file. --- install/ebusd-install.sh | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) diff --git a/install/ebusd-install.sh b/install/ebusd-install.sh index 0ede2e9b8..560bf362a 100644 --- a/install/ebusd-install.sh +++ b/install/ebusd-install.sh @@ -25,6 +25,41 @@ $STD apt install -y ebusd $STD systemctl enable ebusd msg_ok "Installed ebusd" +cat <~/ebusd-configuation-instructions.txt +Configuration instructions: + + 1. Edit "/etc/default/ebusd" if necessary (especially if your device is not "/dev/ttyUSB0") + 2. Start the daemon with "systemctl start ebusd" + 3. Check the log file "/var/log/ebusd.log" + 4. Make the daemon autostart with "systemctl enable ebusd" + +Working "/etc/default/ebusd" options for "ebus adapter shield v5": + +EBUSD_OPTS=" + --pidfile=/run/ebusd.pid + --latency=100 + --scanconfig + --configpath=https://cfg.ebusd.eu/ + --accesslevel=* + --pollinterval=30 + --device=ens:XXX.XXX.XXX.XXX:9999 + --mqtthost=XXX.XXX.XXX.XXX + --mqttport=1883 + --mqttuser=XXXXXX + --mqttpass=XXXXXX + --mqttint=/etc/ebusd/mqtt-hassio.cfg + --mqttjson + --mqttlog + --mqttretain + --mqtttopic=ebusd + --log=all:notice + --log=main:notice + --log=bus:notice + --log=update:notice + --log=network:notice + --log=other:notice" +EOF + motd_ssh customize cleanup_lxc From b858cafad7e3047c1fd729ebe5c1b711dca7d0ec Mon Sep 17 00:00:00 2001 From: Joerg Heinemann Date: Wed, 28 Jan 2026 13:42:39 +0100 Subject: [PATCH 22/33] Update install/ebusd-install.sh Co-authored-by: Tobias <96661824+CrazyWolf13@users.noreply.github.com> --- install/ebusd-install.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/install/ebusd-install.sh b/install/ebusd-install.sh index 560bf362a..187cc2265 100644 --- a/install/ebusd-install.sh +++ b/install/ebusd-install.sh @@ -22,7 +22,7 @@ setup_deb822_repo \ msg_info "Installing ebusd" $STD apt install -y ebusd -$STD systemctl enable ebusd +systemctl enable -q --now ebusd msg_ok "Installed ebusd" cat <~/ebusd-configuation-instructions.txt From aac028efda5436f2fce5ba75f11ff1e050e40ce1 Mon Sep 17 00:00:00 2001 From: Tobias <96661824+CrazyWolf13@users.noreply.github.com> Date: Thu, 29 Jan 2026 15:00:25 +0100 Subject: [PATCH 23/33] Update ebusd.sh --- ct/ebusd.sh | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/ct/ebusd.sh b/ct/ebusd.sh index 63f16f512..710c81c06 100644 --- a/ct/ebusd.sh +++ b/ct/ebusd.sh @@ -27,9 +27,10 @@ function update_script() { msg_error "No ${APP} Installation Found!" exit fi + msg_info "Updating ebusd" $STD apt update - $STD apt -y --upgrade ebusd + $STD apt --upgrade -y ebusd msg_ok "Updated ebusd" msg_ok "Updated successfully!" exit From eae154328f315fed9de4755f31e0730ee8a4d885 Mon Sep 17 00:00:00 2001 From: tremor021 Date: Thu, 29 Jan 2026 19:03:41 +0100 Subject: [PATCH 24/33] Add PowerDNS script --- ct/alpine-powerdns.sh | 50 ++++++++++++++++++++++++++++++++++++++ install/alpine-powerdns.sh | 34 ++++++++++++++++++++++++++ 2 files changed, 84 insertions(+) create mode 100644 ct/alpine-powerdns.sh create mode 100644 install/alpine-powerdns.sh diff --git a/ct/alpine-powerdns.sh b/ct/alpine-powerdns.sh new file mode 100644 index 000000000..470079396 --- /dev/null +++ b/ct/alpine-powerdns.sh @@ -0,0 +1,50 @@ +#!/usr/bin/env bash +source <(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVED/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/orhun/rustypaste + +APP="Alpine-PowerDNS" +var_tags="${var_tags:-os;alpine;dns}" +var_cpu="${var_cpu:-1}" +var_ram="${var_ram:-256}" +var_disk="${var_disk:-4}" +var_os="${var_os:-alpine}" +var_version="${var_version:-3.23}" +var_unprivileged="${var_unprivileged:-1}" + +header_info "$APP" +variables +color +catch_errors + +function update_script() { + header_info + check_container_storage + check_container_resources + + if ! apk info -e pdns >/dev/null 2>&1; then + msg_error "No ${APP} Installation Found!" + exit + fi + + msg_info "Updating PowerDNS" + $STD apk -U upgrade + msg_ok "Updated PowerDNS" + + msg_info "Restarting Services" + $STD rc-service pdns restart + msg_ok "Restarted Services" + 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}" +echo -e "${INFO}${YW} Access it using the following URL:${CL}" +echo -e "${TAB}${GATEWAY}${BGN}http://${IP}:53${CL}" diff --git a/install/alpine-powerdns.sh b/install/alpine-powerdns.sh new file mode 100644 index 000000000..de78cf8a5 --- /dev/null +++ b/install/alpine-powerdns.sh @@ -0,0 +1,34 @@ +#!/usr/bin/env bash + +# Copyright (c) 2021-2026 community-scripts ORG +# Author: Slaviša Arežina (tremor021) +# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE +# Source: https://www.powerdns.com/ + +source /dev/stdin <<<"$FUNCTIONS_FILE_PATH" +color +verb_ip6 +catch_errors +setting_up_container +network_check +update_os + +msg_info "Installing PowerDNS" +$STD apk add --no-cache pdns pdns-backend-sqlite3 pdns-doc +msg_ok "Installed PowerDNS" + +msg_info "Configuring PowerDNS" +sed -i '/^# launch=$/c\launch=gsqlite3\ngsqlite3-database=/var/lib/powerdns/pdns.sqlite3' /etc/pdns/pdns.conf +mkdir /var/lib/powerdns +sqlite3 /var/lib/powerdns/pdns.sqlite3 < /usr/share/doc/pdns/schema.sqlite3.sql +chown -R pdns:pdns /var/lib/powerdns +msg_ok "Configured PowerDNS" + +msg_info "Creating Service" +$STD rc-update add pdns default +$STD rc-service pdns start +msg_ok "Created Service" + +motd_ssh +customize +cleanup_lxc From e3452d7d9ef2952fed80a9043c4b4c3b7649f9b3 Mon Sep 17 00:00:00 2001 From: tremor021 Date: Thu, 29 Jan 2026 19:26:14 +0100 Subject: [PATCH 25/33] Add PowerDNS script --- install/{alpine-powerdns.sh => alpine-powerdns-install.sh} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename install/{alpine-powerdns.sh => alpine-powerdns-install.sh} (100%) diff --git a/install/alpine-powerdns.sh b/install/alpine-powerdns-install.sh similarity index 100% rename from install/alpine-powerdns.sh rename to install/alpine-powerdns-install.sh From 302ef66520546d79c791f7305217ad484694c6a5 Mon Sep 17 00:00:00 2001 From: tremor021 Date: Thu, 29 Jan 2026 19:52:49 +0100 Subject: [PATCH 26/33] Add PowerDNS script --- ct/alpine-powerdns.sh | 6 +++--- install/alpine-powerdns-install.sh | 2 +- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/ct/alpine-powerdns.sh b/ct/alpine-powerdns.sh index 470079396..21ce7f0b5 100644 --- a/ct/alpine-powerdns.sh +++ b/ct/alpine-powerdns.sh @@ -1,9 +1,9 @@ #!/usr/bin/env bash source <(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVED/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/orhun/rustypaste +# Author: Slaviša Arežina (tremor021) +# License: MIT | https://github.com/community-scripts/ProxmoxVED/raw/main/LICENSE +# Source: https://www.powerdns.com/ APP="Alpine-PowerDNS" var_tags="${var_tags:-os;alpine;dns}" diff --git a/install/alpine-powerdns-install.sh b/install/alpine-powerdns-install.sh index de78cf8a5..b3cbc6d65 100644 --- a/install/alpine-powerdns-install.sh +++ b/install/alpine-powerdns-install.sh @@ -2,7 +2,7 @@ # Copyright (c) 2021-2026 community-scripts ORG # Author: Slaviša Arežina (tremor021) -# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE +# License: MIT | https://github.com/community-scripts/ProxmoxVED/raw/main/LICENSE # Source: https://www.powerdns.com/ source /dev/stdin <<<"$FUNCTIONS_FILE_PATH" From d00e1176becfa380c968503faea4fc15c0b9defe Mon Sep 17 00:00:00 2001 From: "GitHub Actions[bot]" Date: Thu, 29 Jan 2026 18:58:55 +0000 Subject: [PATCH 27/33] chore: update github-versions.json Total versions: 20 Pinned versions: 1 Generated: 2026-01-29T18:58:55Z --- frontend/public/json/github-versions.json | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/frontend/public/json/github-versions.json b/frontend/public/json/github-versions.json index 7364cdacf..73deb25d9 100644 --- a/frontend/public/json/github-versions.json +++ b/frontend/public/json/github-versions.json @@ -1,5 +1,5 @@ { - "generated": "2026-01-29T02:41:18Z", + "generated": "2026-01-29T18:58:55Z", "versions": [ { "slug": "affine", @@ -15,6 +15,13 @@ "pinned": false, "date": "2025-12-22T04:23:45Z" }, + { + "slug": "anytype", + "repo": "grishy/any-sync-bundle", + "version": "v1.2.1-2025-12-10", + "pinned": false, + "date": "2025-12-24T20:40:15Z" + }, { "slug": "databasus", "repo": "databasus/databasus", @@ -25,9 +32,9 @@ { "slug": "ente", "repo": "ente-io/ente", - "version": "photos-v1.3.0", + "version": "photos-v1.3.7", "pinned": false, - "date": "2026-01-12T06:33:12Z" + "date": "2026-01-29T17:20:41Z" }, { "slug": "frigate", @@ -81,9 +88,9 @@ { "slug": "opencloud", "repo": "opencloud-eu/opencloud", - "version": "v5.0.0", + "version": "v5.0.1", "pinned": true, - "date": "2026-01-26T15:58:00Z" + "date": "2026-01-28T15:08:23Z" }, { "slug": "piler", From 2c9fb7b6f926212b6c14ef32ca5ea615b31b2fc7 Mon Sep 17 00:00:00 2001 From: juronja <101410098+juronja@users.noreply.github.com> Date: Thu, 29 Jan 2026 19:01:49 +0000 Subject: [PATCH 28/33] removed comments --- vm/truenas-vm.sh | 11 ----------- 1 file changed, 11 deletions(-) diff --git a/vm/truenas-vm.sh b/vm/truenas-vm.sh index b81525ee2..bc9ab24b1 100644 --- a/vm/truenas-vm.sh +++ b/vm/truenas-vm.sh @@ -73,9 +73,6 @@ function error_handler() { cleanup_vmid } -# Scrapes the TrueNAS download portal for ISO paths from the current and previous year, -# filtering out nightlies/alphas and returning the latest stable releases for each major -# version along with any beta or RC pre-releases. function truenas_iso_lookup() { local BASE_URL="https://download.truenas.com" local current_year=$(date +%y) @@ -184,13 +181,10 @@ function check_root() { fi } -# This function checks the version of Proxmox Virtual Environment (PVE) and exits if the version is not supported. -# Supported: Proxmox VE 8.0.x – 8.9.x and 9.0 – 9.1 pve_check() { local PVE_VER PVE_VER="$(pveversion | awk -F'/' '{print $2}' | awk -F'-' '{print $1}')" - # Check for Proxmox VE 8.x: allow 8.0–8.9 if [[ "$PVE_VER" =~ ^8\.([0-9]+) ]]; then local MINOR="${BASH_REMATCH[1]}" if ((MINOR < 0 || MINOR > 9)); then @@ -201,7 +195,6 @@ pve_check() { return 0 fi - # Check for Proxmox VE 9.x: allow 9.0–9.1 if [[ "$PVE_VER" =~ ^9\.([0-9]+) ]]; then local MINOR="${BASH_REMATCH[1]}" if ((MINOR < 0 || MINOR > 1)); then @@ -212,7 +205,6 @@ pve_check() { return 0 fi - # All other unsupported versions msg_error "This version of Proxmox VE is not supported." msg_error "Supported versions: Proxmox VE 8.0 – 8.x or 9.0 – 9.1" exit 1 @@ -299,7 +291,6 @@ function advanced_settings() { fi done - # Fetching iso list from TrueNAS downloads for whiptail radiolist ISOARRAY=() while read -r ISOPATH; do FILENAME=$(basename "$ISOPATH") @@ -504,7 +495,6 @@ msg_ok "Using ${CL}${BL}$STORAGE${CL} ${GN}for Storage Location." msg_ok "Virtual Machine ID is ${CL}${BL}$VMID${CL}." if [ -z "${SELECTED_ISO:-}" ]; then - # Fallback: Find the latest stable release only (excluding RC/BETA for safety) SELECTED_ISO=$(truenas_iso_lookup | grep -vE 'RC|BETA' | sort -V | tail -n 1) if [ -z "$SELECTED_ISO" ]; then @@ -535,7 +525,6 @@ qm create "$VMID" -machine q35 -bios ovmf -agent enabled=1 -tablet 0 -localtime -scsihw virtio-scsi-single -cdrom local:iso/$ISO_NAME -vga virtio >/dev/null msg_ok "Created VM shell" -# Optional step to import onboard disks if [ "$IMPORT_DISKS" == "yes" ]; then msg_info "Importing onboard disks" DISKARRAY=() From bf57d6693995c8b279ab2b99f736833d03388746 Mon Sep 17 00:00:00 2001 From: juronja <101410098+juronja@users.noreply.github.com> Date: Thu, 29 Jan 2026 20:01:47 +0000 Subject: [PATCH 29/33] Left only one notice with a link to the discussion --- frontend/public/json/truenas-vm.json | 18 +----------------- 1 file changed, 1 insertion(+), 17 deletions(-) diff --git a/frontend/public/json/truenas-vm.json b/frontend/public/json/truenas-vm.json index d4675b55f..7f11e7564 100644 --- a/frontend/public/json/truenas-vm.json +++ b/frontend/public/json/truenas-vm.json @@ -33,24 +33,8 @@ }, "notes": [ { - "text": "The default install uses the latest stable release. Please use advanced install for more options.", + "text": "Once the script finishes, proceed with the OS installation via the console. For more details, please refer to this discussion: `https://github.com/community-scripts/ProxmoxVE/discussions/11344`", "type": "info" - }, - { - "text": "8 GB of RAM is the minimum requirement, but 16 GB+ is recommended for optimal performance.", - "type": "info" - }, - { - "text": "After installation, you will be prompted to unmount the media. To do this: Go to the VM's Hardware tab > select the CD/DVD Drive > Edit > select 'Do not use any media'", - "type": "info" - }, - { - "text": "While you can import onboard disks during install, it is highly recommended to use an HBA to pass through disks for production environments.", - "type": "warning" - }, - { - "text": "ECC RAM is strongly recommended to ensure data integrity, as ZFS checksumming can be compromised by bad data in RAM before the data is written to the pool.", - "type": "warning" } ] } From ed1dc2f3635c41de46d6167b66f4fedee5e52f41 Mon Sep 17 00:00:00 2001 From: "GitHub Actions[bot]" Date: Fri, 30 Jan 2026 07:00:55 +0000 Subject: [PATCH 30/33] chore: update github-versions.json Total versions: 20 Pinned versions: 1 Generated: 2026-01-30T07:00:55Z --- frontend/public/json/github-versions.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/frontend/public/json/github-versions.json b/frontend/public/json/github-versions.json index 73deb25d9..3be9decfb 100644 --- a/frontend/public/json/github-versions.json +++ b/frontend/public/json/github-versions.json @@ -1,5 +1,5 @@ { - "generated": "2026-01-29T18:58:55Z", + "generated": "2026-01-30T07:00:55Z", "versions": [ { "slug": "affine", From 1ff16293dee578a8bfa6f3b7cc6fd8ce3ca9938e Mon Sep 17 00:00:00 2001 From: Joerg Heinemann Date: Fri, 30 Jan 2026 08:07:54 +0100 Subject: [PATCH 31/33] Remove ebusd configuration instructions Removed configuration instructions for ebusd from the installation script. --- install/ebusd-install.sh | 35 ----------------------------------- 1 file changed, 35 deletions(-) diff --git a/install/ebusd-install.sh b/install/ebusd-install.sh index 187cc2265..f7e58010c 100644 --- a/install/ebusd-install.sh +++ b/install/ebusd-install.sh @@ -25,41 +25,6 @@ $STD apt install -y ebusd systemctl enable -q --now ebusd msg_ok "Installed ebusd" -cat <~/ebusd-configuation-instructions.txt -Configuration instructions: - - 1. Edit "/etc/default/ebusd" if necessary (especially if your device is not "/dev/ttyUSB0") - 2. Start the daemon with "systemctl start ebusd" - 3. Check the log file "/var/log/ebusd.log" - 4. Make the daemon autostart with "systemctl enable ebusd" - -Working "/etc/default/ebusd" options for "ebus adapter shield v5": - -EBUSD_OPTS=" - --pidfile=/run/ebusd.pid - --latency=100 - --scanconfig - --configpath=https://cfg.ebusd.eu/ - --accesslevel=* - --pollinterval=30 - --device=ens:XXX.XXX.XXX.XXX:9999 - --mqtthost=XXX.XXX.XXX.XXX - --mqttport=1883 - --mqttuser=XXXXXX - --mqttpass=XXXXXX - --mqttint=/etc/ebusd/mqtt-hassio.cfg - --mqttjson - --mqttlog - --mqttretain - --mqtttopic=ebusd - --log=all:notice - --log=main:notice - --log=bus:notice - --log=update:notice - --log=network:notice - --log=other:notice" -EOF - motd_ssh customize cleanup_lxc From c9da138a6980eaf7bc7738f23b9e5ad94583ec03 Mon Sep 17 00:00:00 2001 From: Joerg Heinemann Date: Fri, 30 Jan 2026 08:13:08 +0100 Subject: [PATCH 32/33] Update notes with new post installation link --- frontend/public/json/ebusd.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/frontend/public/json/ebusd.json b/frontend/public/json/ebusd.json index e946af464..862d24153 100644 --- a/frontend/public/json/ebusd.json +++ b/frontend/public/json/ebusd.json @@ -33,7 +33,7 @@ }, "notes": [ { - "text": "Show configuration instructions: `cat ~/ebusd-configuation-instructions.txt`", + "text": "For required post installation actions, checkout: `https://github.com/community-scripts/ProxmoxVE/discussions/11352`", "type": "info" } ] From 0dd93a4df029dfb23fbcc826480fd95728341f88 Mon Sep 17 00:00:00 2001 From: Michel Roegl-Brunner Date: Fri, 30 Jan 2026 09:12:11 +0100 Subject: [PATCH 33/33] Fix CI/CD --- frontend/src/__tests__/public/validate-json.test.ts | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/frontend/src/__tests__/public/validate-json.test.ts b/frontend/src/__tests__/public/validate-json.test.ts index 1ab52db68..f0ab7dde1 100644 --- a/frontend/src/__tests__/public/validate-json.test.ts +++ b/frontend/src/__tests__/public/validate-json.test.ts @@ -7,16 +7,17 @@ console.log('Current directory: ' + process.cwd()); const jsonDir = "public/json"; const metadataFileName = "metadata.json"; const versionsFileName = "versions.json"; +const githubVersionsFileName = "github-versions.json"; const encoding = "utf-8"; const fileNames = (await fs.readdir(jsonDir)) - .filter((fileName) => fileName !== metadataFileName && fileName !== versionsFileName); + .filter((fileName) => fileName !== metadataFileName && fileName !== versionsFileName && fileName !== githubVersionsFileName); describe.each(fileNames)("%s", async (fileName) => { let script: Script; beforeAll(async () => { - const filePath = path.resolve(jsonDir, fileName); + const filePath = path.resolve(jsonDir, fileName); const fileContent = await fs.readFile(filePath, encoding) script = JSON.parse(fileContent); }) @@ -40,7 +41,7 @@ describe(`${metadataFileName}`, async () => { let metadata: Metadata; beforeAll(async () => { - const filePath = path.resolve(jsonDir, metadataFileName); + const filePath = path.resolve(jsonDir, metadataFileName); const fileContent = await fs.readFile(filePath, encoding) metadata = JSON.parse(fileContent); }) @@ -48,9 +49,9 @@ describe(`${metadataFileName}`, async () => { // TODO: create zod schema for metadata. Move zod schemas to /lib/types.ts assert(metadata.categories.length > 0); metadata.categories.forEach((category) => { - assert.isString(category.name) - assert.isNumber(category.id) - assert.isNumber(category.sort_order) + assert.isString(category.name) + assert.isNumber(category.id) + assert.isNumber(category.sort_order) }); }); })