#!/bin/bash # --- Konfiguration --- URL="https://node-red.mgnt.vmd55888.de/vpn-status" MY_HOSTNAME=$(hostname) # Pfade NETCLIENT=$(which netclient) CURL=$(which curl) # --- Start --- # Wir rufen netclient peers auf und filtern direkt die Zeilen mit vpn/mdvpn $NETCLIENT peers | grep -E "vpn|mdvpn" | while read -r line; do # Extraktion der Spalten (basierend auf deiner Tabelle): # Spalte 3: Hostname # Spalte 6: Last Handshake CLIENT_RAW=$(echo "$line" | awk -F'|' '{print $3}' | xargs) # Wir lassen das Icon im CLIENT_RAW für das Dashboard, # säubern aber den Namen für den Key CLIENT_CLEAN=$(echo "$CLIENT_RAW" | sed 's/[^a-zA-Z0-9._-]//g') [[ -z "$CLIENT_CLEAN" ]] && continue HANDSHAKE=$(echo "$line" | awk -F'|' '{print $6}' | xargs) STATUS="false" # Logik: Online wenn "seconds" vorkommt oder 1-5 Minuten if [[ "$HANDSHAKE" == *"seconds"* ]] || [[ "$HANDSHAKE" =~ ^[1-5]\ minute ]]; then STATUS="true" fi # JSON senden (Wir senden CLIENT_RAW, damit das Icon im Dashboard bleibt!) $CURL -s -X POST -H "Content-Type: application/json" \ -d "{\"server\": \"$MY_HOSTNAME\", \"client\": \"$CLIENT_RAW\", \"status\": \"$STATUS\", \"handshake\": \"$HANDSHAKE\"}" \ "$URL" > /dev/null done