From 29a91daec367d4d58817d5ebd5e04e7f43d2701b Mon Sep 17 00:00:00 2001 From: Tim Eertmoed Date: Fri, 13 Dec 2024 07:53:58 +0100 Subject: [PATCH] install.sh aktualisiert --- install.sh | 19 +++++++++++++++---- 1 file changed, 15 insertions(+), 4 deletions(-) diff --git a/install.sh b/install.sh index 86cdec9..a4b852d 100644 --- a/install.sh +++ b/install.sh @@ -11,6 +11,7 @@ print_status() { echo -e "${GREEN}✔${NC} ${1} completed." } +# Update and setup system and packages echo -e "${RED}→${NC} Starting System Update..." | tee -a /var/log/install sudo apt-get update >>/var/log/install 2>&1 && print_status "System Update" sudo apt-get full-upgrade -y >>/var/log/install 2>&1 && print_status "System Upgrade" @@ -22,10 +23,13 @@ sudo apt clean >>/var/log/install 2>&1 && print_status "Clean" rm -rf /var/lib/apt/lists/* >>/var/log/install 2>&1 && print_status "Clear cache" echo -e "${RED}→${NC} Configuring Raspberry Pi settings..." | tee -a /var/log/install +print_status "" +# Set needed users echo -e "${RED}→${NC} Creating user 'loginuser'..." | tee -a /var/log/install sudo adduser --disabled-password --gecos "" loginuser >>/var/log/install 2>&1 && print_status "User 'loginuser' created" +# Copy required files echo -e "${RED}→${NC} Copy requiered files..." | tee -a /var/log/install mkdir -p /etc/chromium/policies/managed /etc/systemd/system/getty@tty1.service.d /usr/bin/custom declare -A files=( @@ -51,12 +55,12 @@ for src in "${!files[@]}"; do done print_status "All files have been successfully copied" +# Set permissions echo -e "${RED}→${NC} Setting file permissions..." | tee -a /var/log/install sudo chown loginuser:loginuser -R /home/loginuser >>/var/log/install 2>&1 && print_status "File permissions for 'loginuser' set" sudo chown wis:wis -R /home/wis >>/var/log/install 2>&1 && print_status "File permissions for 'wis' set" -sudo chmod +x /usr/bin/custom/hostname /usr/bin/custom/chromium-monitor /usr/bin/custom/watchdog-monitor /sbin/overlayRoot.sh >>/var/log/install 2>&1 && print_status "Permissions set for script files" - - +sudo chmod +x /usr/bin/custom/hostname /usr/bin/custom/chromium-monitor /usr/bin/custom/watchdog-monitor /sbin/overlayRoot.sh >>/var/log/install 2>&1 && print_status "Permissions for script files set" +sudo usermod -aG video loginuser >>/var/log/install 2>&1 && print_status "Permissions for 'loginuser' set" echo -e "${RED}→${NC} Setting permissions for 'loginuser'..." | tee -a /var/log/install sudo tee /etc/sudoers.d/loginuser >>/var/log/install 2>&1 && print_status "Sudo rights for 'loginuser' set" << 'EOF' loginuser ALL=(ALL) NOPASSWD: /usr/bin/systemctl stop chromium-monitor, /usr/bin/systemctl start chromium-monitor @@ -71,32 +75,37 @@ loginuser ALL=(ALL) NOPASSWD: /usr/bin/hostnamectl set-hostname loginuser ALL=(ALL) NOPASSWD: /usr/sbin/dhclient eth0 loginuser ALL=(ALL) NOPASSWD: /usr/sbin/reboot EOF -sudo usermod -aG video loginuser >>/var/log/install 2>&1 && print_status "Permissions for 'loginuser' set" +# Disable root echo -e "${RED}→${NC} Disabling root login..." | tee -a /var/log/install sudo tee /etc/ssh/sshd_config >/dev/null << 'EOF' PermitRootLogin no EOF sudo passwd -l root >>/var/log/install 2>&1 && print_status "Root login disabled" +# Setup logs echo -e "${RED}→${NC} Creating log files..." | tee -a /var/log/install sudo touch /var/log/watchdog.log /var/log/chromium-monitor.log /var/log/hostname.log >>/var/log/install 2>&1 && print_status "Log files created" sudo chown loginuser:loginuser /var/log/watchdog.log /var/log/chromium-monitor.log /var/log/hostname.log >>/var/log/install 2>&1 && print_status "Ownership set for log files" sudo chmod 777 /var/log/watchdog.log /var/log/chromium-monitor.log /var/log/hostname.log >>/var/log/install 2>&1 && print_status "Permissions set for log files" +# Configure services echo -e "${RED}→${NC} Configure services..." | tee -a /var/log/install sudo systemctl daemon-reload >>/var/log/install 2>&1 && print_status "Daemon reloaded" sudo systemctl enable hostname chromium-monitor getty@tty1 >>/var/log/install 2>&1 && print_status "Services enabled" sudo systemctl disable watchdog >>/var/log/install 2>&1 && print_status "Watchdog disabled" sudo systemctl restart getty@tty1 >>/var/log/install 2>&1 && print_status "getty service restarted" +# Set performance echo -e "${RED}→${NC} Configure performance teaks..." | tee -a /var/log/install echo "performance" | sudo tee /sys/devices/system/cpu/cpu0/cpufreq/scaling_governor >>/var/log/install 2>&1 && print_status "CPU set to high" sudo systemctl mask sleep.target suspend.target hibernate.target hybrid-sleep.target >>/var/log/install 2>&1 && print_status "Powercfg off" +# Clean echo -e "${RED}→${NC} Cleaning up installer..." | tee -a /var/log/install sudo rm -rf ./rps-client >>/var/log/install 2>&1 && print_status "Installer cleaned up" +# Configure VNC-Client echo -e "${RED}→${NC} Configuring VNC..." | tee -a /var/log/install sudo systemctl enable vncserver-x11-serviced.service >>/var/log/install 2>&1 && print_status "VNC service enabled" sudo systemctl start vncserver-x11-serviced.service >>/var/log/install 2>&1 && print_status "VNC service started" @@ -127,6 +136,7 @@ else print_status "VNC password is set. Authentication will be required." >> /var/log/install 2>&1 fi +# Remove old kernels echo -e "${RED}→${NC} Do you want to clean up unused kernels? (y/n):" | tee -a /var/log/install read -r clean_kernels if [[ "$clean_kernels" =~ ^[Yy](e[Ss]?)?$ ]]; then @@ -137,6 +147,7 @@ else echo -e "${GREEN}✔${NC} Cleanup has been skipped" | tee -a /var/log/install fi +# Finish echo -e "${GREEN}✔${NC} Installation complete. Press any key to exit..." | tee -a /var/log/install 2>&1 read -n 1 -s