Son aktivite 1760778126

Надградих скрипта с множество нови функции и подобрения

Revizyon d83e671218e052d84e38fffaeb437704148a2191

proxmox-setup2.sh Ham
1#!/bin/bash
2
3# Proxmox VE Post-Install Configuration Script
4# Автор: Федя Серафиев и Proxmox Helper Scripts
5# Версия: 2.0 - Разширена версия
6
7# Цветови променливи
8RD=$(echo "\033[01;31m")
9YW=$(echo "\033[33m")
10GN=$(echo "\033[1;92m")
11BL=$(echo "\033[36m")
12MG=$(echo "\033[35m")
13CL=$(echo "\033[m")
14BFR="\\r\\033[K"
15HOLD="-"
16CM="${GN}${CL}"
17CROSS="${RD}${CL}"
18WARN="${YW}${CL}"
19
20# Лог файл
21LOG_FILE="/var/log/proxmox-postinstall.log"
22
23# Функции за съобщения
24msg_info() {
25 local msg="$1"
26 echo -ne " ${HOLD} ${YW}${msg}..."
27 echo "[INFO] $(date '+%Y-%m-%d %H:%M:%S') - ${msg}" >> "$LOG_FILE"
28}
29
30msg_ok() {
31 local msg="$1"
32 echo -e "${BFR} ${CM} ${GN}${msg}${CL}"
33 echo "[OK] $(date '+%Y-%m-%d %H:%M:%S') - ${msg}" >> "$LOG_FILE"
34}
35
36msg_error() {
37 local msg="$1"
38 echo -e "${BFR} ${CROSS} ${RD}${msg}${CL}"
39 echo "[ERROR] $(date '+%Y-%m-%d %H:%M:%S') - ${msg}" >> "$LOG_FILE"
40}
41
42msg_warn() {
43 local msg="$1"
44 echo -e "${BFR} ${WARN} ${YW}${msg}${CL}"
45 echo "[WARN] $(date '+%Y-%m-%d %H:%M:%S') - ${msg}" >> "$LOG_FILE"
46}
47
48# Хедър информация
49header_info() {
50 clear
51 cat <<"EOF"
52 ____ _ ____________
53 / __ \_________ _ ______ ___ ____ | | / / ____/
54 / /_/ / ___/ __ \| |/_/ __ `__ \/ __ \ | | / / __/
55 / ____/ / / /_/ /> </ / / / / / /_/ / | |/ / /___
56/_/ /_/ \____/_/|_/_/ /_/ /_/\____/ |___/_____/
57
58 ____ __ ____ __ ____
59 / __ \____ _____/ /_ / _/___ _____/ /_____ _/ / /
60 / /_/ / __ \/ ___/ __/ / // __ \/ ___/ __/ __ `/ / /
61 / ____/ /_/ (__ ) /_ _/ // / / (__ ) /_/ /_/ / / /
62/_/ \____/____/\__/ /___/_/ /_/____/\__/\__,_/_/_/
63
64 Конфигурационен скрипт за Proxmox VE
65 Версия 2.0 - Enhanced
66EOF
67 echo -e "${BL}════════════════════════════════════════════════════════════${CL}"
68 echo -e "${GN}Добре дошли в разширения помощник за Proxmox VE!${CL}"
69 echo -e "${BL}════════════════════════════════════════════════════════════${CL}"
70 echo
71}
72
73# Проверка за root права
74check_root() {
75 if [[ $EUID -ne 0 ]]; then
76 msg_error "Този скрипт трябва да бъде стартиран като root потребител"
77 exit 1
78 fi
79}
80
81# Проверка за Proxmox VE
82check_proxmox() {
83 if [[ ! -f /etc/pve/local/pve-ssl.pem ]]; then
84 msg_error "Proxmox VE не е открит в тази система"
85 exit 1
86 fi
87}
88
89# Създаване на backup преди промени
90create_backup() {
91 local file="$1"
92 if [[ -f "$file" ]]; then
93 cp "$file" "${file}.backup-$(date +%Y%m%d-%H%M%S)"
94 msg_ok "Създаден backup на $file"
95 fi
96}
97
98# Функция за изключване на напомнянето за абонамент
99disable_subscription_nag() {
100 if [[ ! -f /etc/apt/apt.conf.d/no-nag-script ]]; then
101 CHOICE=$(whiptail --backtitle "Proxmox VE Helper Scripts" --title "НАПОМНЯНЕ ЗА АБОНАМЕНТ" --menu "Това ще изключи съобщението, което ви напомня да закупите абонамент всеки път, когато влезете в уеб интерфейса.\n \nИзключване на напомнянето за абонамент?" 14 58 2 \
102 "yes" " " \
103 "no" " " 3>&2 2>&1 1>&3)
104 case $CHOICE in
105 yes)
106 whiptail --backtitle "Proxmox VE Helper Scripts" --msgbox --title "Поддръжка на абонаменти" "Подкрепата на екипа за разработка на софтуера е от съществено значение. Проверете официалния уебсайт за Поддръжка на абонаменти за цени. Без тяхната посветена работа нямаше да имаме този изключителен софтуер." 10 58
107 msg_info "Изключване на напомнянето за абонамент"
108 echo "DPkg::Post-Invoke { \"dpkg -V proxmox-widget-toolkit | grep -q '/proxmoxlib\.js$'; if [ \$? -eq 1 ]; then { echo 'Премахване на напомнянето от интерфейса...'; sed -i '/.*data\.status.*{/{s/\!//;s/active/NoMoreNagging/}' /usr/share/javascript/proxmox-widget-toolkit/proxmoxlib.js; }; fi\"; };" >/etc/apt/apt.conf.d/no-nag-script
109 apt --reinstall install proxmox-widget-toolkit &>/dev/null
110 msg_ok "Напомнянето за абонамент е изключено (Изтрийте кеша на браузъра)"
111 ;;
112 no)
113 msg_error "Избрахте 'не' за изключване на напомнянето"
114 ;;
115 esac
116 else
117 msg_ok "Напомнянето за абонамент вече е изключено"
118 fi
119}
120
121# Функция за корекция на източниците
122fix_sources() {
123 CHOICE=$(whiptail --backtitle "Proxmox VE Helper Scripts" --title "КОРЕКЦИЯ НА ИЗТОЧНИЦИТЕ" --menu "Това ще коригира източниците на Proxmox VE за правилна работа.\n \nКорекция на източниците на Proxmox VE?" 14 58 2 \
124 "yes" " " \
125 "no" " " 3>&2 2>&1 1>&3)
126 case $CHOICE in
127 yes)
128 msg_info "Коригиране на източниците на Proxmox VE"
129 create_backup "/etc/apt/sources.list"
130 cat <<EOF >/etc/apt/sources.list
131deb http://deb.debian.org/debian bookworm main contrib
132deb http://deb.debian.org/debian bookworm-updates main contrib
133deb http://security.debian.org/debian-security bookworm-security main contrib
134EOF
135 echo 'APT::Get::Update::SourceListWarnings::NonFreeFirmware "false";' >/etc/apt/apt.conf.d/no-bookworm-firmware.conf
136 msg_ok "Източниците на Proxmox VE са коригирани"
137 ;;
138 no)
139 msg_error "Избрахте 'не' за корекция на източниците"
140 ;;
141 esac
142}
143
144# Функция за изключване на enterprise хранилище
145disable_enterprise_repo() {
146 CHOICE=$(whiptail --backtitle "Proxmox VE Helper Scripts" --title "PVE-ENTERPRISE" --menu "Хранилището 'pve-enterprise' е достъпно само за потребители, закупили абонамент за Proxmox VE.\n \nИзключване на 'pve-enterprise' хранилище?" 14 58 2 \
147 "yes" " " \
148 "no" " " 3>&2 2>&1 1>&3)
149 case $CHOICE in
150 yes)
151 msg_info "Изключване на 'pve-enterprise' хранилище"
152 create_backup "/etc/apt/sources.list.d/pve-enterprise.list"
153 cat <<EOF >/etc/apt/sources.list.d/pve-enterprise.list
154# deb https://enterprise.proxmox.com/debian/pve bookworm pve-enterprise
155EOF
156 msg_ok "'pve-enterprise' хранилището е изключено"
157 ;;
158 no)
159 msg_error "Избрахте 'не' за изключване на хранилището"
160 ;;
161 esac
162}
163
164# Функция за активиране на no-subscription хранилище
165enable_no_subscription_repo() {
166 CHOICE=$(whiptail --backtitle "Proxmox VE Helper Scripts" --title "PVE-NO-SUBSCRIPTION" --menu "Хранилището 'pve-no-subscription' предоставя достъп до всички компоненти с отворен код на Proxmox VE.\n \nАктивиране на 'pve-no-subscription' хранилище?" 14 58 2 \
167 "yes" " " \
168 "no" " " 3>&2 2>&1 1>&3)
169 case $CHOICE in
170 yes)
171 msg_info "Активиране на 'pve-no-subscription' хранилище"
172 cat <<EOF >/etc/apt/sources.list.d/pve-install-repo.list
173deb http://download.proxmox.com/debian/pve bookworm pve-no-subscription
174EOF
175 msg_ok "'pve-no-subscription' хранилището е активирано"
176 ;;
177 no)
178 msg_error "Избрахте 'не' за активиране на хранилището"
179 ;;
180 esac
181}
182
183# Функция за обновяване на системата
184update_system() {
185 CHOICE=$(whiptail --backtitle "Proxmox VE Helper Scripts" --title "ОБНОВЯВАНЕ НА СИСТЕМАТА" --menu "Това ще обнови всички пакети в системата.\n \nОбновяване на системата?" 14 58 2 \
186 "yes" " " \
187 "no" " " 3>&2 2>&1 1>&3)
188 case $CHOICE in
189 yes)
190 msg_info "Обновяване на списъка с пакети"
191 apt update &>/dev/null
192 msg_ok "Списъкът с пакети е обновен"
193
194 msg_info "Обновяване на системата"
195 apt full-upgrade -y &>/dev/null
196 msg_ok "Системата е обновена"
197
198 msg_info "Почистване на ненужни пакети"
199 apt autoremove -y &>/dev/null
200 apt autoclean &>/dev/null
201 msg_ok "Ненужните пакети са премахнати"
202 ;;
203 no)
204 msg_error "Избрахте 'не' за обновяване на системата"
205 ;;
206 esac
207}
208
209# Функция за конфигуриране на firewall
210configure_firewall() {
211 CHOICE=$(whiptail --backtitle "Proxmox VE Helper Scripts" --title "FIREWALL КОНФИГУРАЦИЯ" --menu "Активиране на основна firewall конфигурация?\n \nТова ще активира основни firewall правила за защита." 14 58 2 \
212 "yes" " " \
213 "no" " " 3>&2 2>&1 1>&3)
214 case $CHOICE in
215 yes)
216 msg_info "Конфигуриране на firewall"
217 pvesh set /cluster/firewall/options --enable 1 &>/dev/null
218 msg_ok "Firewall е активиран"
219 ;;
220 no)
221 msg_error "Избрахте 'не' за активиране на firewall"
222 ;;
223 esac
224}
225
226# НОВА ФУНКЦИЯ: Инсталиране на полезни пакети
227install_useful_packages() {
228 CHOICE=$(whiptail --backtitle "Proxmox VE Helper Scripts" --title "ИНСТАЛАЦИЯ НА ПАКЕТИ" --checklist "Изберете пакети за инсталиране:" 20 70 10 \
229 "htop" "Интерактивен мониторинг на процеси" OFF \
230 "iotop" "Мониторинг на I/O операции" OFF \
231 "ncdu" "Анализатор на дисково пространство" OFF \
232 "vim" "Разширен текстов редактор" OFF \
233 "net-tools" "Мрежови инструменти" OFF \
234 "curl" "Инструмент за трансфер на данни" OFF \
235 "wget" "Инструмент за изтегляне" OFF \
236 "git" "Система за контрол на версии" OFF \
237 "tmux" "Терминален мултиплексор" OFF \
238 "screen" "Терминален мултиплексор" OFF 3>&2 2>&1 1>&3)
239
240 if [[ -n "$CHOICE" ]]; then
241 msg_info "Инсталиране на избраните пакети"
242 PACKAGES=$(echo "$CHOICE" | tr -d '"')
243 apt update &>/dev/null
244 apt install -y $PACKAGES &>/dev/null
245 msg_ok "Пакетите са инсталирани успешно"
246 else
247 msg_error "Не са избрани пакети за инсталиране"
248 fi
249}
250
251# НОВА ФУНКЦИЯ: Оптимизация на swap
252optimize_swap() {
253 CHOICE=$(whiptail --backtitle "Proxmox VE Helper Scripts" --title "SWAP ОПТИМИЗАЦИЯ" --menu "Оптимизиране на swap настройките?\n \nТова ще подобри производителността на системата." 14 58 2 \
254 "yes" " " \
255 "no" " " 3>&2 2>&1 1>&3)
256 case $CHOICE in
257 yes)
258 msg_info "Оптимизиране на swap настройките"
259
260 # Проверка текущи настройки
261 current_swappiness=$(cat /proc/sys/vm/swappiness)
262 current_cache_pressure=$(cat /proc/sys/vm/vfs_cache_pressure)
263
264 # Задаване на нови стойности
265 echo "vm.swappiness=10" >> /etc/sysctl.conf
266 echo "vm.vfs_cache_pressure=50" >> /etc/sysctl.conf
267 sysctl -p &>/dev/null
268
269 msg_ok "Swap е оптимизиран (swappiness: $current_swappiness -> 10, cache_pressure: $current_cache_pressure -> 50)"
270 ;;
271 no)
272 msg_error "Избрахте 'не' за оптимизация на swap"
273 ;;
274 esac
275}
276
277# НОВА ФУНКЦИЯ: Конфигуриране на автоматични backups
278configure_auto_backup() {
279 CHOICE=$(whiptail --backtitle "Proxmox VE Helper Scripts" --title "АВТОМАТИЧНИ BACKUPS" --menu "Конфигуриране на автоматични backups?\n \nТова ще настрои планиран backup на VMs/CTs." 14 58 2 \
280 "yes" " " \
281 "no" " " 3>&2 2>&1 1>&3)
282 case $CHOICE in
283 yes)
284 BACKUP_TIME=$(whiptail --backtitle "Proxmox VE Helper Scripts" --inputbox "Въведете час за backup (0-23):" 10 60 "2" 3>&1 1>&2 2>&3)
285 BACKUP_STORAGE=$(whiptail --backtitle "Proxmox VE Helper Scripts" --inputbox "Въведете име на storage за backups:" 10 60 "local" 3>&1 1>&2 2>&3)
286 BACKUP_RETENTION=$(whiptail --backtitle "Proxmox VE Helper Scripts" --inputbox "Брой backups за запазване:" 10 60 "3" 3>&1 1>&2 2>&3)
287
288 msg_info "Конфигуриране на автоматични backups"
289
290 # Създаване на backup задача
291 pvesh create /cluster/backup --schedule "0 $BACKUP_TIME * * *" \
292 --storage "$BACKUP_STORAGE" \
293 --mode snapshot \
294 --compress zstd \
295 --prune-backups "keep-last=$BACKUP_RETENTION" \
296 --all 1 \
297 --enabled 1 &>/dev/null
298
299 msg_ok "Автоматичните backups са конфигурирани (час: $BACKUP_TIME, storage: $BACKUP_STORAGE, запазване: $BACKUP_RETENTION)"
300 ;;
301 no)
302 msg_error "Избрахте 'не' за конфигуриране на backups"
303 ;;
304 esac
305}
306
307# НОВА ФУНКЦИЯ: Настройване на email известия
308configure_email_notifications() {
309 CHOICE=$(whiptail --backtitle "Proxmox VE Helper Scripts" --title "EMAIL ИЗВЕСТИЯ" --menu "Конфигуриране на email известия?\n \nТова ще настрои изпращане на email при проблеми." 14 58 2 \
310 "yes" " " \
311 "no" " " 3>&2 2>&1 1>&3)
312 case $CHOICE in
313 yes)
314 EMAIL=$(whiptail --backtitle "Proxmox VE Helper Scripts" --inputbox "Въведете вашия email адрес:" 10 60 3>&1 1>&2 2>&3)
315
316 if [[ -n "$EMAIL" ]]; then
317 msg_info "Конфигуриране на email известия"
318
319 # Инсталиране на postfix ако не е инсталиран
320 if ! command -v postfix &> /dev/null; then
321 DEBIAN_FRONTEND=noninteractive apt install -y postfix mailutils &>/dev/null
322 fi
323
324 # Настройка на root email
325 echo "root: $EMAIL" >> /etc/aliases
326 newaliases &>/dev/null
327
328 msg_ok "Email известията са конфигурирани за $EMAIL"
329 else
330 msg_error "Невалиден email адрес"
331 fi
332 ;;
333 no)
334 msg_error "Избрахте 'не' за конфигуриране на email"
335 ;;
336 esac
337}
338
339# НОВА ФУНКЦИЯ: Оптимизация на ZFS (ако е налично)
340optimize_zfs() {
341 if ! command -v zfs &> /dev/null; then
342 msg_warn "ZFS не е открит в системата"
343 return
344 fi
345
346 CHOICE=$(whiptail --backtitle "Proxmox VE Helper Scripts" --title "ZFS ОПТИМИЗАЦИЯ" --menu "Оптимизиране на ZFS настройките?\n \nТова ще подобри производителността на ZFS." 14 58 2 \
347 "yes" " " \
348 "no" " " 3>&2 2>&1 1>&3)
349 case $CHOICE in
350 yes)
351 msg_info "Оптимизиране на ZFS настройките"
352
353 # Ограничаване на ARC памет (50% от RAM)
354 TOTAL_MEM=$(free -b | grep '^Mem:' | awk '{print $2}')
355 ARC_MAX=$((TOTAL_MEM / 2))
356
357 echo "options zfs zfs_arc_max=$ARC_MAX" > /etc/modprobe.d/zfs.conf
358
359 msg_ok "ZFS е оптимизиран (ARC max: $(($ARC_MAX / 1024 / 1024 / 1024))GB)"
360 msg_warn "Необходим е рестарт за прилагане на промените"
361 ;;
362 no)
363 msg_error "Избрахте 'не' за оптимизация на ZFS"
364 ;;
365 esac
366}
367
368# НОВА ФУНКЦИЯ: Почистване на логове
369cleanup_logs() {
370 CHOICE=$(whiptail --backtitle "Proxmox VE Helper Scripts" --title "ПОЧИСТВАНЕ НА ЛОГОВЕ" --menu "Почистване на стари лог файлове?\n \nТова ще освободи дисково пространство." 14 58 2 \
371 "yes" " " \
372 "no" " " 3>&2 2>&1 1>&3)
373 case $CHOICE in
374 yes)
375 msg_info "Почистване на стари логове"
376
377 # Почистване на журнални логове (запазване на последните 7 дни)
378 journalctl --vacuum-time=7d &>/dev/null
379
380 # Почистване на стари apt кешове
381 apt clean &>/dev/null
382
383 # Почистване на стари ротирани логове
384 find /var/log -type f -name "*.gz" -mtime +30 -delete 2>/dev/null
385 find /var/log -type f -name "*.1" -mtime +7 -delete 2>/dev/null
386
387 msg_ok "Старите логове са почистени"
388 ;;
389 no)
390 msg_error "Избрахте 'не' за почистване на логове"
391 ;;
392 esac
393}
394
395# НОВА ФУНКЦИЯ: Преглед на лог файла
396view_log() {
397 if [[ -f "$LOG_FILE" ]]; then
398 whiptail --backtitle "Proxmox VE Helper Scripts" --title "ЛОГ ФАЙЛ" --scrolltext --textbox "$LOG_FILE" 20 70
399 else
400 whiptail --backtitle "Proxmox VE Helper Scripts" --msgbox "Лог файлът не съществува" 8 40
401 fi
402}
403
404# ПОДОБРЕНА ФУНКЦИЯ: Показване на системна информация
405show_system_info() {
406 clear
407 header_info
408 echo -e "${BL}════════════════════════════════════════════════════════════${CL}"
409 echo -e "${GN} СИСТЕМНА ИНФОРМАЦИЯ ${CL}"
410 echo -e "${BL}════════════════════════════════════════════════════════════${CL}"
411 echo
412 echo -e "${YW}Proxmox VE версия:${CL} $(pveversion | head -1)"
413 echo -e "${YW}Операционна система:${CL} $(lsb_release -d | cut -f2)"
414 echo -e "${YW}Kernel версия:${CL} $(uname -r)"
415 echo -e "${YW}Архитектура:${CL} $(uname -m)"
416 echo -e "${YW}Хостнейм:${CL} $(hostname)"
417 echo -e "${YW}Възходящо време:${CL} $(uptime -p)"
418 echo -e "${YW}Натоварване:${CL} $(uptime | awk -F'load average:' '{print $2}')"
419 echo
420 echo -e "${MG}=== РЕСУРСИ ===${CL}"
421 echo -e "${YW}CPU модел:${CL} $(lscpu | grep 'Model name' | cut -d: -f2 | xargs)"
422 echo -e "${YW}CPU ядра:${CL} $(nproc)"
423 echo -e "${YW}Памет:${CL} $(free -h | grep '^Mem:' | awk '{print $3"/"$2" ("$3/$2*100"%)"}')"
424 echo -e "${YW}Swap:${CL} $(free -h | grep '^Swap:' | awk '{print $3"/"$2}')"
425 echo
426 echo -e "${MG}=== ДИСКОВЕ ===${CL}"
427 df -h | grep -E '^/dev/' | awk '{printf "%-20s %10s %10s %10s %s\n", $1, $2, $3, $4, $5}'
428 echo
429 echo -e "${MG}=== МРЕЖА ===${CL}"
430 ip -4 addr show | grep -oP '(?<=inet\s)\d+(\.\d+){3}' | grep -v '127.0.0.1' | head -5
431 echo
432 echo -e "${BL}════════════════════════════════════════════════════════════${CL}"
433 echo
434 read -p "Натиснете Enter за връщане в главното меню..."
435}
436
437# ПОДОБРЕНО: Главно меню с повече опции
438main_menu() {
439 while true; do
440 header_info
441 CHOICE=$(whiptail --backtitle "Proxmox VE Helper Scripts v2.0" --title "ГЛАВНО МЕНЮ" --menu "Изберете опция:" 24 78 16 \
442 "1" "Изключване на напомнянето за абонамент" \
443 "2" "Корекция на източниците" \
444 "3" "Изключване на enterprise хранилище" \
445 "4" "Активиране на no-subscription хранилище" \
446 "5" "Обновяване на системата" \
447 "6" "Конфигуриране на firewall" \
448 "7" "Инсталиране на полезни пакети" \
449 "8" "Оптимизация на swap" \
450 "9" "Конфигуриране на автоматични backups" \
451 "10" "Настройване на email известия" \
452 "11" "Оптимизация на ZFS" \
453 "12" "Почистване на логове" \
454 "13" "Преглед на лог файла" \
455 "14" "Показване на системна информация" \
456 "15" "Изпълнение на всички конфигурации" \
457 "16" "Изход" 3>&2 2>&1 1>&3)
458
459 case $CHOICE in
460 1) disable_subscription_nag ;;
461 2) fix_sources ;;
462 3) disable_enterprise_repo ;;
463 4) enable_no_subscription_repo ;;
464 5) update_system ;;
465 6) configure_firewall ;;
466 7) install_useful_packages ;;
467 8) optimize_swap ;;
468 9) configure_auto_backup ;;
469 10) configure_email_notifications ;;
470 11) optimize_zfs ;;
471 12) cleanup_logs ;;
472 13) view_log ;;
473 14) show_system_info ;;
474 15)
475 echo -e "${GN}Изпълнение на всички основни конфигурации...${CL}"
476 echo
477 disable_subscription_nag
478 fix_sources
479 disable_enterprise_repo
480 enable_no_subscription_repo
481 update_system
482 configure_firewall
483 optimize_swap
484 cleanup_logs
485 echo
486 echo -e "${GN}Всички конфигурации са завършени!${CL}"
487 echo -e "${YW}Препоръчва се рестартиране на системата.${CL}"
488 echo
489 REBOOT=$(whiptail --backtitle "Proxmox VE Helper Scripts" --title "РЕСТАРТИРАНЕ" --yesno "Искате ли да рестартирате системата сега?" 10 60 3>&1 1>&2 2>&3)
490 if [[ $? -eq 0 ]]; then
491 msg_info "Рестартиране на системата след 5 секунди..."
492 sleep 5
493 reboot
494 fi
495 ;;
496 16)
497 echo -e "${GN}Благодарим ви за използването на Proxmox VE Helper Scripts!${CL}"
498 exit 0
499 ;;
500 *)
501 msg_error "Невалидна опция"
502 ;;
503 esac
504
505 echo
506 read -p "Натиснете Enter за връщане в главното меню..."
507 done
508}
509
510# Основна функция
511main() {
512 check_root
513 check_proxmox
514
515 # Създаване на лог файл ако не съществува
516 touch "$LOG_FILE"
517 echo "=== Proxmox Post-Install Script Log ===" >> "$LOG_FILE"
518 echo "Стартиран на: $(date)" >> "$LOG_FILE"
519
520 # Проверка за whiptail
521 if ! command -v whiptail &> /dev/null; then
522 msg_info "Инсталиране на whiptail"
523 apt update &>/dev/null
524 apt install -y whiptail &>/dev/null
525 msg_ok "whiptail е инсталиран"
526 fi
527
528 main_menu
529}
530
531# Стартиране на скрипта
532main "$@"