Files
RPS-Client/new.md
2024-12-06 10:52:49 +01:00

75 lines
3.8 KiB
Markdown

apt-get update
apt-get full-upgrade -y
raspi-config
reboot
raspi-config -> alle einstellungen setzen - ohne vnc
apt-get install --no-install-recommends -y xserver-xorg x11-xserver-utils xinit chromium-browser fonts-noto-color-emoji nfs-common xdotool rsync
apt-get install --no-install-recommends -y realvnc-vnc-server
systemctl enable vncserver-virtuald.service
apt-get autoremove
apt-get clean >>/var/log/install
rm -rf /var/lib/apt/lists/*
touch /root/.vnc/config.d/vncserver-x11
echo "Authentication=none" >> /root/.vnc/config.d/vncserver-x11
adduser --disabled-password --gecos "" loginuser
usermod -aG video loginuser
mkdir -p /etc/chromium/policies/managed /home/wis/.ssh /usr/bin/custom
tee /etc/sudoers.d/loginuser >/dev/null << 'EOF'
loginuser ALL=(ALL) NOPASSWD: /usr/bin/systemctl stop chromium-monitor, /usr/bin/systemctl start chromium-monitor
loginuser ALL=(ALL) NOPASSWD: /usr/bin/systemctl stop watchdog-monitor, /usr/bin/systemctl start watchdog-monitor
loginuser ALL=(ALL) NOPASSWD: /usr/bin/cat /var/lib/dhcp/*
loginuser ALL=(ALL) NOPASSWD: /usr/bin/cp /etc/watchdog.conf /etc/watchdog.conf.bak
loginuser ALL=(ALL) NOPASSWD: /usr/bin/tee /etc/watchdog.conf, /usr/bin/tee -a /etc/watchdog.conf
loginuser ALL=(ALL) NOPASSWD: /usr/bin/sed -i
loginuser ALL=(ALL) NOPASSWD: /usr/bin/sed -r 's/[x]+/,/g'
loginuser ALL=(ALL) NOPASSWD: /usr/bin/fbset -s
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
mkdir -p /etc/systemd/system/getty@tty1.service.d/
declare -A files=(
["/root/rps-client/boot/ro-root.sh"]="/boot/ro-root.sh"
["/root/rps-client/boot/firmware/ro-root.sh"]="/boot/firmware/ro-root.sh"
["/root/rps-client/etc/dhcp/dhclient.conf"]="/etc/dhcp/dhclient.conf"
["/root/rps-client/etc/systemd/system/hostname.service"]="/etc/systemd/system/hostname.service"
["/root/rps-client/etc/systemd/system/watchdog-monitor.service"]="/etc/systemd/system/watchdog-monitor.service"
["/root/rps-client/etc/systemd/system/chromium-monitor.service"]="/etc/systemd/system/chromium-monitor.service"
["/root/rps-client/etc/systemd/system/getty@tty1.service.d/override.conf"]="/etc/systemd/system/getty@tty1.service.d/override.conf"
["/root/rps-client/etc/chromium/policies/managed/disable_password_saving.json"]="/etc/chromium/policies/managed/disable_password_saving.json"
["/root/rps-client/home/loginuser/.bash_profile"]="/home/loginuser/.bash_profile"
["/root/rps-client/home/loginuser/.xinitrc"]="/home/loginuser/.xinitrc"
["/root/rps-client/home/wis/.ssh/id_rsa.pub"]="/home/wis/.ssh/id_rsa.pub"
["/root/rps-client/root/remove_unused_kernel.sh"]="/root/remove_unused_kernel.sh"
["/root/rps-client/usr/bin/custom/hostname"]="/usr/bin/custom/hostname"
["/root/rps-client/usr/bin/custom/chromium-monitor"]="/usr/bin/custom/chromium-monitor"
["/root/rps-client/usr/bin/custom/watchdog-monitor"]="/usr/bin/custom/watchdog-monitor"
)
RSYNC_OPTS="-a --numeric-ids --info=progress2 --no-owner --no-group"
for src in "${!files[@]}"; do
dst="${files[$src]}"
echo "Copying $src to $dst..."
rsync $RSYNC_OPTS "$src" "$dst"
done
chown loginuser:loginuser -R /home/loginuser
chown wis:wis -R /home/wis
touch /var/log/watchdog.log /var/log/chromium-monitor.log /var/log/hostname.log
chown loginuser:loginuser /var/log/watchdog.log /var/log/chromium-monitor.log /var/log/hostname.log
chmod 777 /var/log/watchdog.log /var/log/chromium-monitor.log /var/log/hostname.log
chmod +x /usr/bin/custom/*
systemctl daemon-reload
systemctl enable hostname chromium-monitor getty@tty1
systemctl restart getty@tty1
systemctl mask sleep.target suspend.target hibernate.target hybrid-sleep.target
sudo tee /etc/ssh/sshd_config >/dev/null << 'EOF'
PermitRootLogin no
EOF
sudo passwd -l root
bash /root/remove_unused_kernel.sh -u -e
reboot