Ostatnio aktywny 1 week ago

Rewizja 248704255efdd1d64120463311b8e8366a9b5162

install.sh Surowy
1#!/bin/bash
2
3set -e
4
5# Цвета для вывода
6ANSI_RED=$(tput -Txterm setaf 1)
7ANSI_GREEN=$(tput -Txterm setaf 2)
8ANSI_YELLOW=$(tput -Txterm setaf 3)
9ANSI_RESET=$(tput -Txterm sgr0)
10
11# ==================== ФУНКЦИИ ====================
12
13# Проверка прав root
14check_root() {
15 if [ "$EUID" -ne 0 ]; then
16 echo -e "${ANSI_RED}Ошибка: скрипт должен запускаться от root${ANSI_RESET}"
17 exit 1
18 fi
19}
20
21# Запрос имени хоста
22ask_hostname() {
23 local current_hostname=$(hostname)
24 read -e -p "${ANSI_YELLOW}Введите имя хоста: (текущее: $current_hostname) ${ANSI_RESET}" -i "${current_hostname}" NEW_HOSTNAME
25 echo "$NEW_HOSTNAME"
26}
27
28# Запрос - создавать ли пользователя
29ask_create_user() {
30 local choice
31 echo -e "${ANSI_YELLOW}Создать нового пользователя? (y/n):${ANSI_RESET}"
32 read -p "Create user [Y/N]? " choice
33 if [[ "$choice" =~ ^[Yy]$ ]]; then
34 CREATE_USER="yes"
35 else
36 CREATE_USER="no"
37 fi
38}
39
40# Запрос имени пользователя
41ask_username() {
42 local username
43 echo -e "${ANSI_YELLOW}Введите имя нового пользователя:${ANSI_RESET}" >&2
44 read -p "Username: " username
45 if [ -z "$username" ]; then
46 echo -e "${ANSI_RED}Имя пользователя не может быть пустым.${ANSI_RESET}" >&2
47 exit 1
48 fi
49 echo "$username"
50}
51
52# Запрос пароля
53ask_password() {
54 local username=$1
55 local user_pass
56 echo -e "${ANSI_YELLOW}Введите пароль для пользователя $username:${ANSI_RESET}" >&2
57 read -s -p "Password: " user_pass
58 echo >&2
59 if [ -z "$user_pass" ]; then
60 echo -e "${ANSI_RED}Пароль не может быть пустым.${ANSI_RESET}" >&2
61 exit 1
62 fi
63 echo "$user_pass"
64}
65
66# Запрос настройки прокси
67ask_proxy() {
68 echo -e "\n${ANSI_YELLOW}Использовать прокси-сервер apt-cacher-ng? (y/n):${ANSI_RESET}"
69 read -p "Use proxy? " USE_PROXY
70 if [[ "$USE_PROXY" =~ ^[Yy]$ ]]; then
71 echo -e "${ANSI_YELLOW}Введите URL прокси-сервера (например: http://192.168.111.87:3142):${ANSI_RESET}"
72 read -e -p "Proxy URL: " -i "http://192.168.111.87:3142" PROXY_URL
73 if [ -n "$PROXY_URL" ]; then
74 configure_proxy "$PROXY_URL"
75 fi
76 fi
77}
78
79# Настройка прокси для apt
80configure_proxy() {
81 local proxy_url=$1
82 echo -e "${ANSI_GREEN}Настройка прокси для apt...${ANSI_RESET}"
83 cat > /etc/apt/apt.conf.d/02aptproxy << EOF
84Acquire::http::proxy "$proxy_url";
85Acquire::ftp::proxy "$proxy_url";
86EOF
87 echo -e "${ANSI_GREEN}Прокси настроен в /etc/apt/apt.conf.d/02aptproxy${ANSI_RESET}"
88}
89
90# Установка имени хоста
91set_hostname() {
92 local hostname=$1
93 echo -e "\n${ANSI_GREEN}=== Установка имени хоста: $hostname ===${ANSI_RESET}"
94 hostnamectl set-hostname "$hostname"
95 if grep -q "^127.0.1.1" /etc/hosts; then
96 sed -i "s/^127.0.1.1.*/127.0.1.1\t$hostname/" /etc/hosts
97 else
98 echo "127.0.1.1\t$hostname" >> /etc/hosts
99 fi
100 echo -e "${ANSI_GREEN}Имя хоста установлено.${ANSI_RESET}"
101}
102
103# Добавление репозитория MEPHI
104add_mephi_repository() {
105 . /etc/os-release 2>/dev/null || { echo "Failed to determine release"; exit 1; }
106 [ -z "$VERSION_CODENAME" ] && echo "VERSION_CODENAME not found" && exit 1
107
108 local conf_file="/etc/apt/sources.list.d/debian_mephi.list"
109
110 if grep -qs "mirror.mephi.ru.*$VERSION_CODENAME" "$conf_file" 2>/dev/null; then
111 echo -e "Repository for $VERSION_CODENAME already exists in $conf_file"
112 else
113 echo -e "Adding repository for Debian $VERSION_CODENAME"
114 cat >> "$conf_file" << EOF
115
116# Added $(date '+%Y-%m-%d')
117deb http://mirror.mephi.ru/debian/ $VERSION_CODENAME main non-free-firmware
118deb-src http://mirror.mephi.ru/debian/ $VERSION_CODENAME main non-free-firmware
119
120deb http://mirror.mephi.ru/debian/ $VERSION_CODENAME-updates main non-free-firmware
121deb-src http://mirror.mephi.ru/debian/ $VERSION_CODENAME-updates main non-free-firmware
122
123EOF
124 echo "Repository added, updating package list..."
125 apt update
126 fi
127}
128
129# Обновление системы
130update_system() {
131 echo -e "${ANSI_GREEN}=== Обновление системы ===${ANSI_RESET}"
132 apt update
133 apt -y upgrade
134}
135
136# Установка пакетов
137install_packages() {
138 local packages=(
139 pv nano curl wget sudo lsb-release iptables
140 unzip pigz zstd
141 ncdu gdu
142 screen tmux lynx
143 htop btop iftop mtr ioping
144 git jq yq pwgen
145 bind9-dnsutils net-tools ssh-audit
146 cloud-guest-utils qemu-guest-agent
147 console-setup
148 )
149
150 echo -e "${ANSI_GREEN}Installing packages...${ANSI_RESET}"
151 apt-get update
152 apt-get install -y "${packages[@]}"
153}
154
155install_qemu_geest_agent() {
156 apt-get install -y qemu-guest-agent
157 sudo systemctl start qemu-guest-agent
158 sudo systemctl status qemu-guest-agent
159}
160
161# Настройка SSH
162configure_ssh() {
163 echo -e "${ANSI_GREEN}Allowing SSH root login${ANSI_RESET}"
164 sed -i 's/^.*PermitRootLogin.*$/PermitRootLogin yes/' /etc/ssh/sshd_config
165 systemctl restart sshd
166 echo -e "${ANSI_GREEN}Ok.${ANSI_RESET}"
167}
168
169# Настройка таймзоны и локали
170configure_locale() {
171 echo "tzdata tzdata/Areas select Europe" | debconf-set-selections
172 echo "tzdata tzdata/Zones/Europe select Moscow" | debconf-set-selections
173 DEBIAN_FRONTEND=noninteractive dpkg-reconfigure tzdata
174
175 cat > /etc/locale.gen << EOF
176ru_RU.UTF-8 UTF-8
177en_US.UTF-8 UTF-8
178EOF
179
180 locale-gen
181 update-locale LANG=en_US.UTF-8
182 locale -a | grep -E "en_US|ru_RU"
183 source /etc/default/locale
184
185 dpkg-reconfigure console-setup
186 dpkg-reconfigure keyboard-configuration
187}
188
189# Настройка journald
190configure_journald() {
191 mkdir -p /etc/systemd/journald.conf.d
192 cat > /etc/systemd/journald.conf.d/size.conf << EOF
193[Journal]
194SystemMaxUse=1G
195SystemMaxFileSize=50M
196MaxLevelStore=warning
197EOF
198
199 systemctl restart systemd-journald
200}
201
202# Создание пользователя
203create_user() {
204 local username=$1
205 local password=$2
206
207 useradd -m "$username" && echo "$username:$password" | chpasswd && passwd -e "$username"
208 usermod -aG sudo "$username"
209
210 touch "/home/$username/.Xauthority"
211 chown "$username:$username" "/home/$username/.Xauthority"
212
213 echo -e "${ANSI_GREEN}Пользователь $username с паролем '${ANSI_YELLOW}$password${ANSI_GREEN}' создан${ANSI_RESET}"
214}
215
216# Настройка истории для пользователя
217configure_user_history() {
218 local username=$1
219 cat >> "/home/$username/.bashrc" << 'EOF'
220export HISTSIZE=10000
221export HISTFILESIZE=50000
222export HISTTIMEFORMAT="%F %T "
223export HISTCONTROL=ignoredups:ignorespace
224shopt -s histappend
225export PROMPT_COMMAND="history -a; history -c; history -r; $PROMPT_COMMAND"
226export TERM=xterm-256color
227EOF
228 chown "$username:$username" "/home/$username/.bashrc"
229}
230
231# Настройка истории для root
232configure_root_history() {
233 cat >> /root/.bashrc << 'EOF'
234export HISTSIZE=10000
235export HISTFILESIZE=50000
236export HISTTIMEFORMAT="%F %T "
237export HISTCONTROL=ignoredups:ignorespace
238shopt -s histappend
239export PROMPT_COMMAND="history -a; history -c; history -r; $PROMPT_COMMAND"
240export TERM=xterm-256color
241EOF
242 source /root/.bashrc
243}
244
245# Очистка документации git
246clean_git_docs() {
247 rm -rf /usr/share/doc/git/RelNotes
248}
249
250# Финальное сообщение
251finish_setup() {
252 echo -e "${ANSI_GREEN}=== Настройка завершена ===${ANSI_RESET}"
253}
254
255# Запись конфигурационного файла
256write_config_file() {
257 local file_path=$1
258 local create_backup=${2:-true} # создать резервную копию? (по умолчанию true)
259
260 echo -e "${ANSI_GREEN}=== Запись конфигурации в $file_path ===${ANSI_RESET}"
261
262 # Создание резервной копии
263 if [ "$create_backup" = true ] && [ -f "$file_path" ]; then
264 local backup_path="${file_path}.backup.$(date +%Y%m%d_%H%M%S)"
265 cp "$file_path" "$backup_path"
266 echo -e "${ANSI_YELLOW}Создана резервная копия: $backup_path${ANSI_RESET}"
267 fi
268
269 # Создание директории, если её нет
270 local dir_path=$(dirname "$file_path")
271 if [ ! -d "$dir_path" ]; then
272 mkdir -p "$dir_path"
273 echo -e "${ANSI_YELLOW}Создана директория: $dir_path${ANSI_RESET}"
274 fi
275
276 # Чтение содержимого из heredoc
277 cat > "$file_path"
278
279 # Установка правильных прав (опционально)
280 chmod 644 "$file_path"
281
282 echo -e "${ANSI_GREEN}Файл успешно записан: $file_path${ANSI_RESET}"
283}
284
285make_motd_generator() {
286 write_config_file "/etc/update-motd.d/99-mymotd-generator" false << 'EOF'
287 #!/bin/bash
288
289 # Text Color Variables http://misc.flogisoft.com/bash/tip_colors_and_formatting
290 tcLtG="\033[00;37m" # LIGHT GRAY
291 tcDkG="\033[01;30m" # DARK GRAY
292 tcLtR="\033[01;31m" # LIGHT RED
293 tcLtGRN="\033[01;32m" # LIGHT GREEN
294 tcLtBL="\033[01;34m" # LIGHT BLUE
295 tcLtP="\033[01;35m" # LIGHT PURPLE
296 tcLtC="\033[01;36m" # LIGHT CYAN
297 tcW="\033[01;37m" # WHITE
298 tcRESET="\033[0m"
299 tcORANGE="\033[38;5;209m"
300
301 # Time of day
302 HOUR=$(date +"%H")
303 if [ $HOUR -lt 12 -a $HOUR -ge 0 ]; then TIME="morning"
304 elif [ $HOUR -lt 17 -a $HOUR -ge 12 ]; then TIME="afternoon"
305 else TIME="evening"
306 fi
307
308 # System uptime
309 uptime=`cat /proc/uptime | cut -f1 -d.`
310 upDays=$((uptime/60/60/24))
311 upHours=$((uptime/60/60%24))
312 upMins=$((uptime/60%60))
313
314 # System + Memory
315 MEMORY_USED=`free -b | grep Mem | awk '{print $3/$2 * 100.0}'`
316 SWAP_USED=`free -b | grep Swap | awk '{print $3/$2 * 100.0}'`
317 NUM_PROCS=`ps aux | wc -l`
318
319 # IP первого сетевого интерфейса
320 LOCAL_IP=$(ip -4 addr show | grep -oP '(?<=inet\s)\d+\.\d+\.\d+\.\d+' | grep -v '^127\.' | head -n 1)
321
322 # Имя сервера
323 HOSTNAME=$(hostname)
324
325 # ОS
326 OS=$(grep PRETTY_NAME /etc/os-release | cut -d= -f2 | tr -d '"')
327
328 # Пользователь
329 USER_NAME=$(whoami)
330 [ "$USER_NAME" = "root" ] && USER_NAME="${tcLtR}${USER_NAME}${tcRESET}"
331
332 # Load average
333 LOADAVG=$(awk '{print $1" "$2" "$3}' /proc/loadavg)
334 SYS_LOADS=`cat /proc/loadavg | awk '{print $1}'`
335
336 # RAM: всего и свободно (в мегабайтах)
337 RAM_TOTAL=$(free -m | awk '/Mem:/ {print $2}')
338 RAM_FREE=$(free -m | awk '/Mem:/ {print $7}')
339 RAM_FREE_PCT=$(( RAM_FREE * 100 / RAM_TOTAL ))
340
341 # Количество CPU
342 CPU_COUNT=$(nproc)
343
344 # Uptime
345 UPTIME=$(uptime -p)
346
347 # HDD: для корневого раздела /
348 DISK_TOTAL_HUMAN=$(df -h / | awk 'NR==2 {print $2}')
349 DISK_FREE_HUMAN=$(df -h / | awk 'NR==2 {print $4}')
350
351 # Используем df без форматирования для процентов
352 DISK_TOTAL=$(df -k / | awk 'NR==2 {print $2}')
353 DISK_FREE=$(df -k / | awk 'NR==2 {print $4}')
354 DISK_FREE_PCT=$(( DISK_FREE * 100 / DISK_TOTAL ))
355
356 echo -e "$tcDkG ==============================================================="
357 echo -e $tcLtG " Good $TIME! $tcORANGE $LOCAL_IP"
358 echo -e $tcDkG "==============================================================="
359 echo -e $tcLtG " - Hostname :$tcW ${HOSTNAME}"
360 echo -e $tcLtG " - IP Address :$tcW ${LOCAL_IP:-N/A}"
361 echo -e $tcLtG " - User :$tcW ${USER_NAME}"
362 echo -e $tcLtG "==============================================================="
363 echo -e $tcLtG " - OS Release :$tcW ${OS}"
364 echo -e $tcLtG " - Kernel : `uname -a | awk '{print $1" "$3" "$12}'`"
365 echo -e $tcLtG " - Users : Currently `users | wc -w` user(s) logged on"
366 echo -e $tcLtG "==============================================================="
367 echo -e $tcLtG " - Server Time : `date`"
368 echo -e $tcLtG " - System load : ${SYS_LOADS} / ${NUM_PROCS} processes running"
369 echo -e $tcLtG " - Load average : ${LOADAVG}"
370 echo -e $tcLtG " - System uptime : ${upDays} days ${upHours} hours ${upMins} minutes"
371 echo -e $tcLtG "==============================================================="
372 echo -e $tcLtG " - CPU : ${CPU_COUNT} CPU"
373 echo -e $tcLtG " - RAM : ${RAM_TOTAL} MB, ${RAM_FREE} MB (${RAM_FREE_PCT}%) free"
374 echo -e $tcLtG " - HDD : ${DISK_TOTAL_HUMAN}, ${DISK_FREE_HUMAN} (${DISK_FREE_PCT}%) free"
375 echo -e $tcLtG " - Swap used % : ${SWAP_USED}"
376 echo -e $tcDkG "==============================================================="
377 echo -e $tcRESET ""
378EOF
379
380 write_config_file "/etc/issue" false << 'EOF'
381 Debian GNU/Linux 12 \n \l
382
383 Local IP: не доступен
384EOF
385}
386
387install_midnight_commanger() {
388 apt-get -y install mc
389
390 write_config_file "/root/.config/mc/ini" false << 'EOF'
391[Midnight-Commander]
392verbose=true
393shell_patterns=true
394auto_save_setup=true
395preallocate_space=false
396auto_menu=false
397use_internal_view=true
398use_internal_edit=false
399clear_before_exec=true
400confirm_delete=true
401confirm_overwrite=true
402confirm_execute=false
403confirm_history_cleanup=true
404confirm_exit=false
405confirm_directory_hotlist_delete=false
406confirm_view_dir=false
407safe_delete=false
408safe_overwrite=false
409use_8th_bit_as_meta=false
410mouse_move_pages_viewer=true
411mouse_close_dialog=false
412fast_refresh=false
413drop_menus=false
414wrap_mode=true
415old_esc_mode=true
416cd_symlinks=true
417show_all_if_ambiguous=false
418use_file_to_guess_type=true
419alternate_plus_minus=false
420only_leading_plus_minus=true
421show_output_starts_shell=false
422xtree_mode=false
423file_op_compute_totals=true
424classic_progressbar=true
425use_netrc=true
426ftpfs_always_use_proxy=false
427ftpfs_use_passive_connections=true
428ftpfs_use_passive_connections_over_proxy=false
429ftpfs_use_unix_list_options=true
430ftpfs_first_cd_then_ls=true
431ignore_ftp_chattr_errors=true
432editor_fill_tabs_with_spaces=false
433editor_return_does_auto_indent=false
434editor_backspace_through_tabs=false
435editor_fake_half_tabs=true
436editor_option_save_position=true
437editor_option_auto_para_formatting=false
438editor_option_typewriter_wrap=false
439editor_edit_confirm_save=true
440editor_syntax_highlighting=true
441editor_persistent_selections=true
442editor_drop_selection_on_copy=true
443editor_cursor_beyond_eol=false
444editor_cursor_after_inserted_block=false
445editor_visible_tabs=true
446editor_visible_spaces=true
447editor_line_state=false
448editor_simple_statusbar=false
449editor_check_new_line=false
450editor_show_right_margin=false
451editor_group_undo=true
452editor_state_full_filename=true
453editor_ask_filename_before_edit=false
454nice_rotating_dash=true
455shadows=true
456mcview_remember_file_position=false
457auto_fill_mkdir_name=true
458copymove_persistent_attr=true
459pause_after_run=1
460mouse_repeat_rate=100
461double_click_speed=250
462old_esc_mode_timeout=1000000
463max_dirt_limit=10
464num_history_items_recorded=60
465vfs_timeout=60
466ftpfs_directory_timeout=900
467ftpfs_retry_seconds=30
468fish_directory_timeout=900
469editor_tab_spacing=8
470editor_word_wrap_line_length=72
471editor_option_save_mode=0
472editor_backup_extension=~
473editor_filesize_threshold=64M
474editor_stop_format_chars=-+*\\,.;:&>
475mcview_eof=
476skin=modarcon16
477
478filepos_max_saved_entries=1024
479
480[Layout]
481output_lines=0
482left_panel_size=86
483top_panel_size=0
484message_visible=false
485keybar_visible=true
486xterm_title=true
487command_prompt=true
488menubar_visible=true
489free_space=true
490horizontal_split=false
491vertical_equal=true
492horizontal_equal=true
493
494[Misc]
495timeformat_recent=%b %e %H:%M
496timeformat_old=%b %e %Y
497ftp_proxy_host=gate
498ftpfs_password=anonymous@
499display_codepage=UTF-8
500source_codepage=Other_8_bit
501autodetect_codeset=
502spell_language=en
503clipboard_store=
504clipboard_paste=
505
506[Colors]
507base_color=
508linux=
509color_terminals=
510
511xterm-256color=
512
513[Panels]
514show_mini_info=true
515kilobyte_si=false
516mix_all_files=false
517show_backups=true
518show_dot_files=true
519fast_reload=false
520fast_reload_msg_shown=false
521mark_moves_down=true
522reverse_files_only=true
523auto_save_setup_panels=false
524navigate_with_arrows=false
525panel_scroll_pages=true
526panel_scroll_center=false
527mouse_move_pages=true
528filetype_mode=true
529permission_mode=false
530torben_fj_mode=false
531quick_search_mode=2
532select_flags=6
533
534[Panelize]
535Find *.orig after patching=find . -name \\*.orig -print
536Find SUID and SGID programs=find . \\( \\( -perm -04000 -a -perm /011 \\) -o \\( -perm -02000 -a -perm /01 \\) \\) -print
537Find rejects after patching=find . -name \\*.rej -print
538Modified git files=git ls-files --modified
539
540EOF
541
542 write_config_file "/root/.config/mc/panels.ini" false << 'EOF'
543[New Left Panel]
544display=listing
545reverse=false
546case_sensitive=true
547exec_first=false
548sort_order=name
549list_mode=full
550brief_cols=2
551user_format=half type name | size | owner
552user_status0=half type name | size | perm
553user_status1=half type name | size | perm
554user_status2=half type name | size | perm
555user_status3=half type name | size | perm
556user_mini_status=false
557filter_flags=7
558list_format=user
559
560[New Right Panel]
561display=listing
562reverse=false
563case_sensitive=true
564exec_first=false
565sort_order=name
566list_mode=full
567brief_cols=2
568user_format=half type name | size | owner
569user_status0=half type name | size | perm
570user_status1=half type name | size | perm
571user_status2=half type name | size | perm
572user_status3=half type name | size | perm
573user_mini_status=false
574filter_flags=7
575list_format=user
576
577[Dirs]
578current_is_left=false
579other_dir=/root
580EOF
581}
582
583# Обновление GPG ключей Debian
584fix_debian_keys() {
585 echo -e "${ANSI_GREEN}=== Исправление GPG-ключей Debian ===${ANSI_RESET}"
586
587 # 1. Полностью удаляем кэш списков пакетов
588 rm -rf /var/lib/apt/lists/*
589
590 # 2. Удаляем старые проблемные ключи из trusted.gpg.d и связки apt-key
591 rm -f /etc/apt/trusted.gpg.d/*54404762BBB6E853* \
592 /etc/apt/trusted.gpg.d/*6ED0E7B82643E131* 2>/dev/null || true
593 apt-key del 54404762BBB6E853 2>/dev/null || true
594 apt-key del 6ED0E7B82643E131 2>/dev/null || true
595
596 # 3. Очищаем кэш apt
597 apt-get clean
598
599 # 4. Принудительно переустанавливаем пакет с ключами (без проверки подписи)
600 apt-get install --reinstall -y --allow-unauthenticated debian-archive-keyring
601
602 # 5. Если прокси-сервер используется, настраиваем переменные окружения для gpg
603 if [ -n "$PROXY_URL" ]; then
604 export http_proxy="$PROXY_URL"
605 export https_proxy="$PROXY_URL"
606 fi
607
608 # 6. Пытаемся получить ключи напрямую с keyserver (альтернативный источник)
609 echo "Получение свежих ключей с keyserver..."
610 gpg --keyserver keyserver.ubuntu.com --recv-keys 54404762BBB6E853 6ED0E7B82643E131 2>/dev/null || \
611 gpg --keyserver pgp.mit.edu --recv-keys 54404762BBB6E853 6ED0E7B82643E131 2>/dev/null || \
612 gpg --keyserver keys.openpgp.org --recv-keys 54404762BBB6E853 6ED0E7B82643E131 2>/dev/null || true
613
614 # 7. Экспортируем ключи в директорию apt (если были получены)
615 gpg --export 54404762BBB6E853 > /etc/apt/trusted.gpg.d/debian-security-automatic.gpg 2>/dev/null || true
616 gpg --export 6ED0E7B82643E131 > /etc/apt/trusted.gpg.d/debian-archive-automatic.gpg 2>/dev/null || true
617
618 # 8. Снова очищаем списки и обновляем
619 rm -rf /var/lib/apt/lists/*
620 apt-get update --allow-insecure-repositories || true
621
622 echo -e "${ANSI_GREEN}Ключи обновлены.${ANSI_RESET}"
623}
624
625# ==================== ОСНОВНАЯ ЛОГИКА ====================
626
627main() {
628 # check_root
629
630 echo -e "${ANSI_GREEN}=== Настройка системы ===${ANSI_RESET}"
631
632 NEW_HOSTNAME=$(ask_hostname)
633
634 ask_create_user
635
636 echo $CREATE_USER
637
638 if [ "$CREATE_USER" = "yes" ]; then
639 NEW_USER=$(ask_username)
640 USER_PASS=$(ask_password "$NEW_USER")
641 create_user "$NEW_USER" "$USER_PASS"
642 configure_user_history "$NEW_USER"
643 fi
644
645 ask_proxy
646 fix_debian_keys
647
648 # Выполнение настроек
649 configure_root_history
650
651 set_hostname "$NEW_HOSTNAME"
652 add_mephi_repository
653 update_system
654 install_packages
655 install_qemu_geest_agent
656 configure_ssh
657 configure_locale
658 configure_journald
659 clean_git_docs
660
661 make_motd_generator
662
663 install_midnight_commanger
664
665 finish_setup
666}
667
668# Запуск главной функции
669main "$@"