47 Commits
v1.0 ... v1.3

Author SHA1 Message Date
57b5cd5397 install.sh aktualisiert 2024-10-28 14:11:42 +01:00
26058e12f7 usr/bin/custom/hostname aktualisiert 2024-10-28 14:06:16 +01:00
134a398fb9 usr/bin/custom/hostname aktualisiert 2024-10-28 14:05:07 +01:00
4b607c3ad8 etc/systemd/system/hostname.service hinzugefügt 2024-10-28 14:03:39 +01:00
1d22c6dc07 usr/bin/hostname hinzugefügt 2024-10-28 14:02:25 +01:00
0b8a9d2ba6 install.sh aktualisiert 2024-10-28 13:51:09 +01:00
b921505906 etc/systemd/system/watchdog.service aktualisiert 2024-10-28 13:45:55 +01:00
b39edf6343 etc/systemd/system/chromium-monitor.service aktualisiert 2024-10-28 13:45:43 +01:00
0d081f2380 install.sh aktualisiert 2024-10-28 13:45:03 +01:00
8038479898 usr/bin/custom/watchdog aktualisiert 2024-10-28 13:43:46 +01:00
8fe03e7cad usr/bin/custom/chromium-monitor aktualisiert 2024-10-28 13:43:36 +01:00
83c6f7de70 install.sh aktualisiert 2024-10-28 13:41:40 +01:00
dece859ca8 install.sh aktualisiert 2024-10-28 13:04:35 +01:00
0d1a2b7c21 usr/bin/watchdog aktualisiert 2024-10-28 13:02:32 +01:00
d96260222c usr/bin/chromium-monitor aktualisiert 2024-10-28 13:01:36 +01:00
54d218451a etc/systemd/system/watchdog.service aktualisiert 2024-10-28 09:54:46 +01:00
ef29887a40 root/.ssh/id_rsa.pub hinzugefügt 2024-10-27 18:36:19 +01:00
67e55e37bb roo/.ssh/id_rsa.pub gelöscht 2024-10-27 18:36:02 +01:00
b01e957dfa roo/.ssh/id_rsa.pub hinzugefügt 2024-10-27 18:35:44 +01:00
5940c1e4e8 .gitignore gelöscht 2024-10-27 18:33:04 +01:00
4a2afa57e0 install.sh aktualisiert 2024-10-27 18:32:45 +01:00
eb785117d7 etc/systemd/system/watchdog.service aktualisiert 2024-10-27 18:27:11 +01:00
eb74659abf etc/systemd/system/chromium-monitor.service aktualisiert 2024-10-27 18:26:12 +01:00
3cd8e0bea6 usr/bin/watchdog aktualisiert 2024-10-27 18:23:34 +01:00
651f9280c9 usr/bin/chromium-monitor aktualisiert 2024-10-27 18:21:21 +01:00
10ca7032ef README.md aktualisiert 2024-10-21 19:32:37 +02:00
00ef7ab4b7 install.sh aktualisiert 2024-10-21 17:07:47 +02:00
95d3a9ccd9 install.sh aktualisiert 2024-10-21 17:02:43 +02:00
ee9d49cba5 README.md aktualisiert 2024-10-21 16:57:50 +02:00
d1e9a179fc etc/systemd/system/chromium-monitor.service aktualisiert 2024-10-21 16:57:20 +02:00
3bdee6bd3e install.sh aktualisiert 2024-10-21 16:56:52 +02:00
c76a1c3613 etc/systemd/system/chromium-monitor.service aktualisiert 2024-10-21 16:39:18 +02:00
d92f9cebb8 install.sh aktualisiert 2024-10-20 11:48:23 +02:00
14fc513e70 install.sh aktualisiert 2024-10-16 16:21:14 +02:00
f9ad27df20 install.sh aktualisiert 2024-10-16 16:15:27 +02:00
e4fa735c71 install.sh aktualisiert 2024-10-16 16:11:42 +02:00
40b802a418 README.md aktualisiert 2024-10-16 16:02:14 +02:00
643bc897f3 install.sh aktualisiert 2024-10-16 15:56:03 +02:00
aefd8d032a install.sh aktualisiert 2024-10-16 15:42:09 +02:00
531f4bdaa4 home/wis/.ssh/id_rsa.pub hinzugefügt 2024-10-16 14:47:18 +02:00
1858524a0f install.sh aktualisiert 2024-10-16 14:32:47 +02:00
95ae6ffa2f install.sh aktualisiert 2024-10-16 14:20:55 +02:00
74b3a695cb install.sh aktualisiert 2024-10-16 14:15:28 +02:00
bed96e3b77 README.md aktualisiert 2024-10-16 14:03:31 +02:00
78dd888b98 install.sh aktualisiert 2024-10-16 13:55:14 +02:00
1f99185b38 install.sh aktualisiert 2024-10-16 13:13:54 +02:00
8cb69931a6 README.md aktualisiert 2024-10-16 13:04:14 +02:00
12 changed files with 196 additions and 100 deletions

15
.gitignore vendored
View File

@@ -1,15 +0,0 @@
# ---> Linux
*~
# temporary files which can be created if a process still has a handle open of a deleted file
.fuse_hidden*
# KDE directory preferences
.directory
# Linux trash folder which might appear on any partition or disk
.Trash-*
# .nfs files are created when an open file is removed but is still being accessed
.nfs*

View File

@@ -1,10 +1,10 @@
# RPS-Light-PXE # RPS-Client
```bash ```bash
wget -qO- --header 'Authorization:token 9031f8d227dd83ba601680bf3a9f6c2d26c1a970' https://gitea.int.eertmoed.net/WiS/RPS-Light-PXE/archive/latest.tar.gz| tar xvz ; bash ./rps-light-pxe/install.sh ; wget -qO- --header 'Authorization:token 9031f8d227dd83ba601680bf3a9f6c2d26c1a970' https://gitea.int.eertmoed.net/WiS/RPS-Client/archive/latest.tar.gz | tar xvz ; bash ./rps-client/install.sh ;
``` ```
```ruby ```ruby
# Version 1.0: # Version 1.1:
# Created 2024 by Tim Eertmoed, Christian Hampp @ WiS IT-Solutions GmbH, Germany to work on Raspian as custom pxe init script. # Created 2024 by Tim Eertmoed, Christian Hampp @ WiS IT-Solutions GmbH, Germany to work on Raspian as custom pxe init script.
``` ```

View File

@@ -3,15 +3,17 @@ Description=A Service to monitor the Kiosk's current site
After=network.target getty@tty1.service After=network.target getty@tty1.service
[Service] [Service]
# Wait until Chromium is running ExecStartPre=-/bin/sleep 10
ExecStartPre=-/bin/bash -c 'while ! pgrep -f chromium-browser > /dev/null; do sleep 5; done'
ExecStartPre=-/usr/bin/sleep 20
Type=simple Type=simple
User=loginuser User=loginuser
ExecStart=/usr/bin/chromium-monitor ExecStart=/usr/bin/custom/chromium-monitor
Restart=on-failure
RestartSec=5s
StandardOutput=append:/var/log/chromium-monitor.log
StandardError=append:/var/log/chromium-monitor.log
[Install] [Install]
WantedBy=multi-user.target WantedBy=multi-user.target
# Version 1.0: # Version 1.1:
# Created 2024 by Tim Eertmoed, Christian Hampp @ WiS IT-Solutions GmbH, Germany to work on Raspian as custom pxe init script. # Created 2024 by Tim Eertmoed, Christian Hampp @ WiS IT-Solutions GmbH, Germany to work on Raspian as custom pxe init script.

View File

@@ -0,0 +1,11 @@
[Unit]
Description=Set Hostname from DHCP
After=network.target
[Service]
Type=oneshot
ExecStart=/usr/bin/custom/hostname
RemainAfterExit=yes
[Install]
WantedBy=multi-user.target

View File

@@ -3,13 +3,17 @@ Description=Watchdog Monitor Service
After=network.target getty@tty1.service After=network.target getty@tty1.service
[Service] [Service]
ExecStartPre=-/bin/sleep 120 ExecStartPre=-/bin/sleep 10
Type=simple Type=simple
ExecStart=/usr/bin/watchdog User=loginuser
ExecStart=/usr/bin/watchdog/watchdog
Restart=on-failure Restart=on-failure
RestartSec=5s
StandardOutput=append:/var/log/watchdog
StandardError=append:/var/log/watchdog
[Install] [Install]
WantedBy=multi-user.target WantedBy=multi-user.target
# Version 1.0: # Version 1.1:
# Created 2024 by Tim Eertmoed, Christian Hampp @ WiS IT-Solutions GmbH, Germany to work on Raspian as custom pxe init script. # Created 2024 by Tim Eertmoed, Christian Hampp @ WiS IT-Solutions GmbH, Germany to work on Raspian as custom pxe init script.

1
home/wis/.ssh/id_rsa.pub Normal file
View File

@@ -0,0 +1 @@
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAACAQCYDmONGe644a3bWKAyX1W704B8fCwlj4x/QjwyJX6gKpX2hmtrxZtusK729wTxP0lr1Gzll9A8LAEGqW5/sxxJqwtYDMOEfINsgE8fmvg9XSmJ9t5zOxJAuQfJB/dmE2a2mX3VSH740czvJ6NKlf9BUeu+41ZZUilyHngfgpVxEIED/6ZHRrkMUfaY09IfvwmNiYPTtK4cufLBdeEoNJPQvYdY1i+N+cJstUzlDRs179w8CqLPuPhIb0iQ3WO1S1XXQH4vUm4MaMmK+hDR4J/pfhuI3DXulwE04rZFU2izXQwl5VdYLv8w31gcegyRz68p+LprusY4QiDP62yaUCTE6JdrjjQSxbEag+OqCzozfvoO+SxMdWsxg2eViM4sKTODc0cQBSA4HJcDWeag5LU9k4WGeuVVj8BCCBqh+93IqylqyK7AKMztVZNiftSBEbfK8ZoHawg5PM26LtCTz6YcmGhn/dHpcpyC8606+SHSTl5YinDaRjarCBM4nppD3o5pizVFKutI28Ys3wkVAe96njnJqIi/J5tNQgrbJmteCE3/9SWhpsXjnuZX1RaZYLE3bBg8Gisz/sm7rN3acVXe6QD03PIxwn9Xp8r3avzDkQKo4vqxoYK6JF6j3vs+U4WLElq+NtvuMewfAWF2cgL2quognLWUM5s0p1/zLzxa8w==

View File

@@ -6,80 +6,91 @@ NC='\033[0m' # No Color
clear clear
# Function to print status with a checkmark
print_status() {
echo -e "${GREEN}${NC} ${1} completed."
}
echo -e "${RED}${NC} Starting System Update..." echo -e "${RED}${NC} Starting System Update..."
sudo apt update >/dev/null 2>&1 && sudo apt upgrade -y >/dev/null 2>&1 && sudo apt dist-upgrade -y >/dev/null 2>&1 && sudo apt autoremove -y >/dev/null 2>&1 && sudo apt clean -y >/dev/null 2>&1 sudo apt update >>/var/log/install 2>&1 && print_status "System Update"
echo -e "${GREEN}${NC} System Update Completed..." sudo apt upgrade -y >>/var/log/install 2>&1 && print_status "System Upgrade"
sudo apt dist-upgrade -y >>/var/log/install 2>&1 && print_status "System Dist-Upgrade"
sudo apt autoremove -y >>/var/log/install 2>&1 && print_status "Autoremove"
sudo apt clean >>/var/log/install 2>&1 && print_status "Clean"
echo -e "${RED}${NC} Installing required packages..." echo -e "${RED}${NC} Installing required packages..."
sudo apt install --no-install-recommends xserver-xorg x11-xserver-utils xinit chromium-browser fonts-noto-color-emoji nfs-common watchdog xdotool rsync -y >/dev/null 2>&1 sudo apt install --no-install-recommends xserver-xorg x11-xserver-utils xinit chromium-browser fonts-noto-color-emoji nfs-common watchdog xdotool rsync -y >>/var/log/install 2>&1 && print_status "Required packages installed"
echo -e "${GREEN}${NC} Required packages installed..." sudo apt install realvnc-vnc-server overlayroot -y >>/var/log/install 2>&1 && print_status "VNC and Overlayroot installed"
echo -e "${RED}${NC} Creating user 'loginuser'..." echo -e "${RED}${NC} Creating user 'loginuser'..."
sudo adduser --disabled-password --gecos "" loginuser >/dev/null 2>&1 sudo adduser --disabled-password --gecos "" loginuser >>/var/log/install 2>&1 && print_status "User 'loginuser' created"
echo -e "${GREEN}${NC} User 'loginuser' created..."
echo -e "${RED}${NC} Setting permissions for 'loginuser'..." echo -e "${RED}${NC} Setting permissions for 'loginuser'..."
sudo tee /etc/sudoers.d/loginuser >/dev/null << 'EOF' sudo tee /etc/sudoers.d/loginuser >/dev/null << 'EOF'
loginuser ALL=(ALL) NOPASSWD: /usr/bin/systemctl restart watchdog loginuser ALL=(ALL) NOPASSWD: /usr/bin/systemctl restart watchdog, /usr/bin/systemctl restart chromium-monitor
loginuser ALL=(ALL) NOPASSWD: /usr/bin/echo loginuser ALL=(ALL) NOPASSWD: /usr/bin/echo, /usr/bin/cp, /usr/bin/sed
loginuser ALL=(ALL) NOPASSWD: /usr/bin/cp loginuser ALL=(ALL) NOPASSWD: /usr/sbin/reboot, /usr/sbin/dhclient eth0, /usr/bin/fbset
loginuser ALL=(ALL) NOPASSWD: /usr/bin/sed
loginuser ALL=(ALL) NOPASSWD: /usr/sbin/reboot
loginuser ALL=(ALL) NOPASSWD: /usr/sbin/dhclient eth0
loginuser ALL=(ALL) NOPASSWD: /usr/bin/fbset
loginuser ALL=(ALL) NOPASSWD: /usr/bin/cat /var/lib/dhcp/* loginuser ALL=(ALL) NOPASSWD: /usr/bin/cat /var/lib/dhcp/*
EOF EOF
sudo usermod -aG video loginuser >/dev/null 2>&1 sudo usermod -aG video loginuser >>/var/log/install 2>&1 && print_status "Permissions for 'loginuser' set"
echo -e "${GREEN}${NC} Permissions for 'loginuser' set..."
echo -e "${RED}${NC} Disabling root login..." echo -e "${RED}${NC} Disabling root login..."
sudo tee /etc/ssh/sshd_config >/dev/null << 'EOF' sudo tee /etc/ssh/sshd_config >/dev/null << 'EOF'
PermitRootLogin no PermitRootLogin no
EOF EOF
sudo passwd -l root >/dev/null 2>&1 sudo passwd -l root >>/var/log/install 2>&1 && print_status "Root login disabled"
echo -e "${GREEN}${NC} Root login disabled..."
echo -e "${RED}${NC} Copying required files..." echo -e "${RED}${NC} Copying required files..."
sudo rm ./rps-light-pxe/.gitignore ./rps-light-pxe/LICENSE ./rps-light-pxe/README.md >/dev/null 2>&1 sudo rsync -a --numeric-ids --info=progress2 --no-owner --no-group \
sudo cp -r ./rps-light-pxe/ / >/dev/null 2>&1 ./rps-client/boot/ro-root.sh /boot/ro-root.sh \
echo -e "${GREEN}${NC} Required files copied..." ./rps-client/boot/firmware/ro-root.sh /boot/firmware/ro-root.sh \
./rps-client/etc/dhcp/dhclient.conf /etc/dhcp/dhclient.conf \
./rps-client/etc/systemd/system/hostname.service /etc/systemd/system/hostname.service \
./rps-client/etc/systemd/system/watchdog.service /etc/systemd/system/watchdog.service \
./rps-client/etc/systemd/system/chromium-monitor.service /etc/systemd/system/chromium-monitor.service \
./rps-client/etc/systemd/system/getty@tty1.service.d/override.conf /etc/systemd/system/getty@tty1.service.d/override.conf \
./rps-client/etc/chromium/policies/managed/disable_password_saving.json /etc/chromium/policies/managed/disable_password_saving.json \
./rps-client/home/loginuser/.bash_profile /home/loginuser/.bash_profile \
./rps-client/home/loginuser/.xinitrc /home/loginuser/.xinitrc \
./rps-client/home/wis/.ssh/id_rsa.pub /home/wis/.ssh/id_rsa.pub \
./rps-client/root/remove_unused_kernel.sh /root/remove_unused_kernel.sh \
./rps-client/root/.vnc/config.d/vncserver-x11 /root/.vnc/config.d/vncserver-x11 \
./rps-client/usr/bin/custom/hostname /usr/bin/custom/hostname \
./rps-client/usr/bin/custom/chromium-monitor /usr/bin/custom/chromium-monitor \
./rps-client/usr/bin/custom/watchdog /usr/bin/custom/watchdog >>/var/log/install 2>&1 && print_status "Required files copied"
echo -e "${RED}${NC} Setting file permissions..." echo -e "${RED}${NC} Setting file permissions..."
sudo chown loginuser:loginuser /home/loginuser/.xinitrc >/dev/null 2>&1 sudo chown loginuser:loginuser -R /home/loginuser >>/var/log/install 2>&1 && print_status "File permissions set"
sudo chown loginuser:loginuser /home/loginuser/.bash_profile >/dev/null 2>&1
sudo chmod +x /root/remove_unused_kernel.sh >/dev/null 2>&1 echo -e "${RED}${NC} Creating log files..."
sudo chmod +x /usr/bin/watchdog >/dev/null 2>&1 sudo touch /var/log/watchdog.log /var/log/chromium-monitor.log >>/var/log/install 2>&1 && print_status "Log files created"
sudo chmod +x /usr/bin/chromium-monitor >/dev/null 2>&1
echo -e "${GREEN}${NC} File permissions set..." echo -e "${RED}${NC} Setting ownership for log files..."
sudo chown loginuser:loginuser /var/log/watchdog.log /var/log/chromium-monitor.log >>/var/log/install 2>&1 && print_status "Ownership set for log files"
echo -e "${RED}${NC} Setting permissions for log files..."
sudo chmod 664 /var/log/watchdog.log /var/log/chromium-monitor.log >>/var/log/install 2>&1 && print_status "Permissions set for log files"
echo -e "${RED}${NC} Enabling services..." echo -e "${RED}${NC} Enabling services..."
sudo systemctl daemon-reload >/dev/null 2>&1 sudo systemctl daemon-reload >>/var/log/install 2>&1 && print_status "Daemon reloaded"
sudo systemctl enable watchdog >/dev/null 2>&1 sudo systemctl enable hostname watchdog chromium-monitor vncserver-x11-serviced.service >>/var/log/install 2>&1 && print_status "Services enabled"
sudo systemctl enable chromium-monitor >/dev/null 2>&1 sudo systemctl restart getty@tty1 >>/var/log/install 2>&1 && print_status "getty service restarted"
sudo systemctl enable getty@tty1 >/dev/null 2>&1
echo -e "${GREEN}${NC} Services enabled..."
echo -e "${RED}${NC} Cleaning up old kernels..." echo -e "${RED}${NC} Do you want to clean up unused kernels? (yes/y/ye to proceed):"
sudo bash /root/remove_unused_kernel.sh -u -e >/dev/null 2>&1 read -r clean_kernels
sudo rm /root/remove_unused_kernel.sh >/dev/null 2>&1 if [[ "$clean_kernels" =~ ^[Yy](e[Ss]?)?$ ]]; then
echo -e "${GREEN}${NC} Old kernels cleaned up..." echo -e "${RED}${NC} Cleaning up unused kernels..."
sudo bash /root/remove_unused_kernel.sh -u -e >>/var/log/install 2>&1 && print_status "Unused kernels cleaned up"
else
echo -e "${RED}${NC} Skipping unused kernel cleanup."
fi
echo -e "${RED}${NC} Cleaning up installer..." echo -e "${RED}${NC} Cleaning up installer..."
sudo rm -rf ./rps-light-pxe >/dev/null 2>&1 sudo rm -rf ./rps-client >>/var/log/install 2>&1 && print_status "Installer cleaned up"
echo -e "${GREEN}${NC} Installer cleaned up..."
echo -e "${GREEN}${NC} Installation complete. Press any key to reboot." echo -e "${GREEN}${NC} Installation complete. Press any key to reboot..."
read -n 1 -s read -n 1 -s
sudo mkdir -p /etc/systemd/system/getty@tty1.service.d
sudo tee /etc/systemd/system/getty@tty1.service.d/override.conf > /dev/null << 'EOF'
[Service]
ExecStart=
ExecStart=-/sbin/agetty --autologin loginuser --noclear %I $TERM
EOF
sudo systemctl daemon-reload
sudo systemctl restart getty@tty1
sudo systemctl enable getty@tty1
sudo reboot sudo reboot
# Version 1.0: # Version 1.2:
# Created 2024 by Tim Eertmoed, Christian Hampp @ WiS IT-Solutions GmbH, Germany to work on Raspian as custom pxe init script. # Created 2024 by Tim Eertmoed, Christian Hampp @ WiS IT-Solutions GmbH, Germany to work on Raspian as custom pxe init script.

1
root/.ssh/id_rsa.pub Normal file
View File

@@ -0,0 +1 @@
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAACAQCYDmONGe644a3bWKAyX1W704B8fCwlj4x/QjwyJX6gKpX2hmtrxZtusK729wTxP0lr1Gzll9A8LAEGqW5/sxxJqwtYDMOEfINsgE8fmvg9XSmJ9t5zOxJAuQfJB/dmE2a2mX3VSH740czvJ6NKlf9BUeu+41ZZUilyHngfgpVxEIED/6ZHRrkMUfaY09IfvwmNiYPTtK4cufLBdeEoNJPQvYdY1i+N+cJstUzlDRs179w8CqLPuPhIb0iQ3WO1S1XXQH4vUm4MaMmK+hDR4J/pfhuI3DXulwE04rZFU2izXQwl5VdYLv8w31gcegyRz68p+LprusY4QiDP62yaUCTE6JdrjjQSxbEag+OqCzozfvoO+SxMdWsxg2eViM4sKTODc0cQBSA4HJcDWeag5LU9k4WGeuVVj8BCCBqh+93IqylqyK7AKMztVZNiftSBEbfK8ZoHawg5PM26LtCTz6YcmGhn/dHpcpyC8606+SHSTl5YinDaRjarCBM4nppD3o5pizVFKutI28Ys3wkVAe96njnJqIi/J5tNQgrbJmteCE3/9SWhpsXjnuZX1RaZYLE3bBg8Gisz/sm7rN3acVXe6QD03PIxwn9Xp8r3avzDkQKo4vqxoYK6JF6j3vs+U4WLElq+NtvuMewfAWF2cgL2quognLWUM5s0p1/zLzxa8w==

View File

@@ -1,34 +1,56 @@
#!/bin/bash #!/bin/bash
LOGFILE="/var/log/chromium-monitor.log"
get_monitor() { get_monitor() {
sudo cat /var/lib/dhcp/* | grep -a "option monitor" | tail -1 | \ sudo cat /var/lib/dhcp/* | grep -a "option monitor" | tail -1 | \
awk '{ s = ""; for (i = 3; i <= NF; i++) s = s $i " "; print s}' | \ awk '{ s = ""; for (i = 3; i <= NF; i++) s = s $i " "; print s}' | \
awk -F '"' '{print $2}' awk -F '"' '{print $2}'
} }
get_current_window() { get_current_window() {
DISPLAY=:0 xdotool getwindowfocus getwindowname | awk -F '- Chromium' '{print $1}' DISPLAY=:0 xdotool getwindowfocus getwindowname | awk -F '- Chromium' '{print $1}'
} }
monitor="" monitor=""
while [ -z "$monitor" ]; do while [ -z "$monitor" ]; do
monitor=$(get_monitor) monitor=$(get_monitor)
echo "Current monitor: $monitor" >> $LOGFILE # Debug output
if [ -z "$monitor" ]; then if [ -z "$monitor" ]; then
sleep 5 sleep 5
fi fi
done done
monitor_md5=$(echo -n ${monitor^^} | sed -e 's/^[[:space:]]*//' | md5sum | awk '{print $1}') monitor_md5=$(echo -n ${monitor^^} | sed -e 's/^[[:space:]]*//' | md5sum | awk '{print $1}')
echo "Monitor MD5: $monitor_md5" >> $LOGFILE # Debug output
while true; do while true; do
new_monitor=$(get_monitor) new_monitor=$(get_monitor)
new_current=$(get_current_window) new_current=$(get_current_window)
# Log the current state
echo "New monitor: $new_monitor" >> $LOGFILE # Debug output
echo "New current window: $new_current" >> $LOGFILE # Debug output
if [ -n "$new_monitor" ] && [ -n "$new_current" ]; then if [ -n "$new_monitor" ] && [ -n "$new_current" ]; then
new_monitor_md5=$(echo -n ${new_monitor^^} | sed -e 's/^[[:space:]]*//' | md5sum | awk '{print $1}') new_monitor_md5=$(echo -n ${new_monitor^^} | sed -e 's/^[[:space:]]*//' | md5sum | awk '{print $1}')
current_md5=$(echo -n ${new_current^^} | sed -e 's/^[[:space:]]*//' | md5sum | awk '{print $1}') current_md5=$(echo -n ${new_current^^} | sed -e 's/^[[:space:]]*//' | md5sum | awk '{print $1}')
# Log the computed MD5 hashes
echo "New monitor MD5: $new_monitor_md5" >> $LOGFILE # Debug output
echo "Current window MD5: $current_md5" >> $LOGFILE # Debug output
if [ "$new_monitor_md5" != "$monitor_md5" ] && [ "$current_md5" != "$monitor_md5" ]; then if [ "$new_monitor_md5" != "$monitor_md5" ] && [ "$current_md5" != "$monitor_md5" ]; then
echo "Mismatch detected. Rebooting now." echo "Mismatch detected. Rebooting now." >> $LOGFILE
sudo reboot sudo reboot
exit 1 exit 1
fi fi
else else
echo "Either monitor or current is not available, skipping check." echo "Either monitor or current is not available, skipping check." >> $LOGFILE
fi fi
# Log the status before sleeping
echo "Sleeping for 5 seconds before the next check..." >> $LOGFILE
sleep 5s sleep 5s
done done

35
usr/bin/custom/hostname Normal file
View File

@@ -0,0 +1,35 @@
#!/bin/bash
LOGFILE="/var/log/hostname.log"
# Function to read the hostname from the DHCP lease file
get_hostname() {
sudo cat /var/lib/dhcp/* | grep -a "option host-name" | tail -1 | \
awk -F '"' '{print $2}'
}
# Function to update /etc/hosts with the new hostname
update_hosts() {
local hostname="$1"
# Replace the second line with the new hostname
sudo sed -i "2s/.*/127.0.1.1 ${hostname}/" /etc/hosts
echo "Updated /etc/hosts with hostname: $hostname" >> $LOGFILE
}
# Read the hostname from DHCP
hostname=$(get_hostname)
if [ -n "$hostname" ]; then
# Set the hostname using hostnamectl
sudo hostnamectl set-hostname "$hostname"
echo "Set hostname to: $hostname" >> $LOGFILE
update_hosts "$hostname"
else
echo "No hostname found." >> $LOGFILE
fi
# Log completion
echo "Hostname update script completed." >> $LOGFILE
# Version 1.0:
# Created 2024 by Tim Eertmoed, Christian Hampp @ WiS IT-Solutions GmbH, Germany to work on Raspian as custom pxe init script.

46
usr/bin/custom/watchdog Normal file
View File

@@ -0,0 +1,46 @@
#!/bin/bash
# Log file
log_file="/var/log/watchdog.log"
# Extract watchdog IP addresses
watchdog=$(sudo cat /var/lib/dhcp/* | grep -a "option watchdog" | tail -1 | \
awk '{for (i=3; i<=NF; i++) printf "%s ", $i}' | tr -d '";')
IFS=' ' read -r -a ip_array <<< "$watchdog"
# Configuration file
config_file="/etc/watchdog.conf"
# Backup current configuration
if sudo cp "$config_file" "$config_file.bak"; then
echo "Backup of $config_file created successfully." >> "$log_file"
else
echo "Failed to create backup of $config_file." >> "$log_file"
fi
# Clean existing configurations
sudo sed -i '/ping/d' "$config_file"
sudo sed -i '/^interval/d' "$config_file"
# Set interval
echo "interval = 60" | sudo tee -a "$config_file" > /dev/null
if [ ${#ip_array[@]} -eq 0 ]; then
echo "No IP addresses found. Watchdog configuration cleared." >> "$log_file"
sudo systemctl stop watchdog
else
for ip in "${ip_array[@]}"; do
echo "ping = $ip" | sudo tee -a "$config_file" > /dev/null
done
echo "Configured watchdog to ping: ${ip_array[*]}" >> "$log_file"
fi
# Restart watchdog service
if sudo systemctl restart watchdog; then
echo "Watchdog service restarted successfully." >> "$log_file"
else
echo "Failed to restart watchdog service." >> "$log_file"
fi
# Version 1.1:
# Created 2024 by Tim Eertmoed @ WiS IT-Solutions GmbH, Germany to work on Raspian as custom pxe init script.

View File

@@ -1,22 +0,0 @@
#!/bin/bash
watchdog=$(sudo cat /var/lib/dhcp/* | grep -a "option watchdog" | tail -1 | \
awk '{for (i=3; i<=NF; i++) printf "%s ", $i}' | tr -d '";')
IFS=' ' read -r -a ip_array <<< "$watchdog"
config_file="/etc/watchdog.conf"
sudo cp "$config_file" "$config_file.bak"
sudo sed -i '/ping/d' "$config_file"
sudo sed -i '/^interval/d' "$config_file"
echo "interval = 60" | sudo tee -a "$config_file" > /dev/null
if [ ${#ip_array[@]} -eq 0 ]; then
sudo sed -i '/interval/d' "$config_file"
echo "No IP addresses found. Watchdog configuration cleared." >&2
sudo systemctl stop watchdog
else
for ip in "${ip_array[@]}"; do
echo "ping = $ip" | sudo tee -a "$config_file" > /dev/null
done
fi
sudo systemctl restart watchdog
# Version 1.0:
# Created 2024 by Tim Eertmoed, Christian Hampp @ WiS IT-Solutions GmbH, Germany to work on Raspian as custom pxe init script.