OSCam Client-Verbindung überwachen (Satreceiver): Unterschied zwischen den Versionen

Aus Tutorials
Zur Navigation springen Zur Suche springen
Zeile 35: Zeile 35:


if [ "$#" -lt "5" ]; then
if [ "$#" -lt "5" ]; then
    echo -e "$howto" && exit "3"
  echo -e "$howto" && exit "3"
fi
fi


Zeile 53: Zeile 53:
then
then
{
{
    lines=$(wc -l ""$temp"/status.html" | awk '{print $1}')
  lines=$(wc -l ""$temp"/status.html" | awk '{print $1}')
    if [ $lines -lt 2 ]  ;  then
  if [ $lines -lt 2 ]  ;  then
{
  {
        t=$(tail -n 1 ""$temp"/status.html")
    t=$(tail -n 1 ""$temp"/status.html")
        echo "CRITICAL: " $t
    echo "CRITICAL: " $t
        # Logging
    # Logging
        if [ "$logsyslog"  == "1" ] ; then logger  "$filename $version - CRITICAL: $t"; fi
    if [ "$logsyslog"  == "1" ] ; then logger  "$filename $version - CRITICAL: $t"; fi
        if [ $debug -eq 1 ] ;then echo -e "Fehler -  Status.html hat >2 Zeilen und sieht somit nicht korrekt aus." ; fi
    if [ $debug -eq 1 ] ;then echo -e "Fehler -  Status.html hat >2 Zeilen und sieht somit nicht korrekt aus." ; fi
 
    exit 2;
  }
  else
  {
    s='<P id="chead">Clients <span id="ucs">'${strClientcount}'</span>/<span id="uca">1</span></P><DIV>';
    #echo "s="$s"";
 
    g=$(grep "$s" "$temp"/status.html)
    if [ $debug -eq 1 ] ; then echo -e "Suchstring="$g""; fi
 
    if [ $? -eq 0 ]
    then
      #Grep erfolgreich - aber noch nicht klar ob string gefunden
      if [ ! "$g" == "" ]
      then
        if [ $debug -eq 1 ] ;then echo -e "Sieht gut aus - String $s wurde gefunden." ; fi
        echo -e "OSCAM client of $client is working at `date +"'%d.%m.%Y %H:%M'"`" | /usr/bin/mailx -A kirner.or.at -s "OSCAM client of $client are currently working" admin@kirner.or.at
      else
        if [ $debug -eq 1 ] ;then echo -e  "Sieht schlecht aus - String $s nicht gefunden." ;  fi
 
        // TODO add restart logic


         exit 2;
         echo -e "OSCAM client of $client restarted at `date +"'%d.%m.%Y %H:%M'"`" | /usr/bin/mailx -A kirner.or.at -s "OSCAM client of $client restarted" admin@kirner.or.at
}
      fi
     else
     else
    {
      if [ $debug -eq 1 ] ;then echo -e "Sieht  schlecht aus - String $s nicht gefunden." ; fi
s='<P id="chead">Clients <span id="ucs">'${strClientcount}'</span>/<span id="uca">1</span></P><DIV>';
    fi
#echo "s="$s"";
  }
  fi
        g=$(grep "$s" "$temp"/status.html)
        if [ $debug -eq 1 ] ; then echo -e "Suchstring="$g""; fi
if [ $? -eq 0 ]
        then
            #Grep erfolgreich - aber noch nicht klar ob string gefunden
            if [ ! "$g" == "" ]
            then
                if [ $debug -eq 1 ] ;then echo -e "Sieht gut aus - String $s wurde gefunden." ; fi
echo -e "OSCAM client of $client is working at `date +"'%d.%m.%Y %H:%M'"`" | /usr/bin/mailx -A kirner.or.at -s "OSCAM client of $client are currently working" admin@kirner.or.at
            else
                if [ $debug -eq 1 ] ;then echo -e  "Sieht schlecht aus - String $s nicht gefunden." ;  fi
echo -e "OSCAM client of $client restarted at `date +"'%d.%m.%Y %H:%M'"`" | /usr/bin/mailx -A kirner.or.at -s "OSCAM client of $client restarted" admin@kirner.or.at
            fi
        else
            if [ $debug -eq 1 ] ;then echo -e "Sieht  schlecht aus - String $s nicht gefunden." ; fi
        fi
    }
fi
}
}
else
else
{
{
    echo "CRITICAL: Could not download status.html (StatusCheck)"
  echo "CRITICAL: Could not download status.html (StatusCheck)"
    # Logging
  # Logging
    if [ "$logsyslog"  == "1" ] ; then logger "$filename $version - CRITICAL: Could not download status.html (StatusCheck)"; fi
  if [ "$logsyslog"  == "1" ] ; then logger "$filename $version - CRITICAL: Could not download status.html (StatusCheck)"; fi
    exit 2;
  exit 2;
}
}
fi
fi

Version vom 5. Dezember 2023, 19:34 Uhr

Noch in Bearbeitung


Script

touch /usr/script/check_oscam_client.sh
chmod +x /usr/script/check_oscam_client.sh
vi /usr/script/check_oscam_client.sh
#!/bin/bash
#
# -------------------------------
# Requires: curl (opkg install curl)
# -------------------------------
# Changelog:
#
# -------------------------------
filename="check_oscam_client"

client="GigaBlue UHD QUAD 4K (receiver-seestadt)"

# Debug
# "1" Aktiviert
# "0" Deaktiviert
debug="0"

# Temporärer Pfad OHNE abschließendem Slash (/) am Ende
temp="/tmp"

# -------------------------------
howto='\nUsage: ./check_oscam_client <hostname> <port> <username> <password> <clientcount>'

if [ "$#" -lt "5" ]; then
  echo -e "$howto" && exit "3"
fi

# General
strHostname=${1}
strPort=${2}
strUser=${3}
strPass=${4}
strClientcount=${5}

#echo "$strHostname:$strPort:$strUser:$strPass:$strClientcount"
rm -f "$temp"/status.html

# File Download
a=$(curl --connect-timeout 2 -vu ""$strUser":"$strPass"" --anyauth  -o ""$temp"/status.html" "http://$strHostname:$strPort/status.html"  >/dev/null 2>/dev/null)
if [ $? -eq 0 ]
then
{
  lines=$(wc -l ""$temp"/status.html" | awk '{print $1}')
	
  if [ $lines -lt 2 ]  ;  then
  {
    t=$(tail -n 1 ""$temp"/status.html")
    echo "CRITICAL: " $t
    # Logging
    if [ "$logsyslog"  == "1" ] ; then logger  "$filename $version - CRITICAL: $t"; fi
    if [ $debug -eq 1 ] ;then echo -e "Fehler -  Status.html hat >2 Zeilen und sieht somit nicht korrekt aus." ; fi

    exit 2;
  }
  else
  {
    s='<P id="chead">Clients <span id="ucs">'${strClientcount}'</span>/<span id="uca">1</span></P><DIV>';
    #echo "s="$s"";

    g=$(grep "$s" "$temp"/status.html)
    if [ $debug -eq 1 ] ; then echo -e "Suchstring="$g""; fi

    if [ $? -eq 0 ]
    then
      #Grep erfolgreich - aber noch nicht klar ob string gefunden
      if [ ! "$g" == "" ]
      then
        if [ $debug -eq 1 ] ;then echo -e "Sieht gut aus - String $s wurde gefunden." ; fi
        echo -e "OSCAM client of $client is working at `date +"'%d.%m.%Y %H:%M'"`" | /usr/bin/mailx -A kirner.or.at -s "OSCAM client of $client are currently working" admin@kirner.or.at
      else
        if [ $debug -eq 1 ] ;then echo -e  "Sieht schlecht aus - String $s nicht gefunden." ;  fi

        // TODO add restart logic

        echo -e "OSCAM client of $client restarted at `date +"'%d.%m.%Y %H:%M'"`" | /usr/bin/mailx -A kirner.or.at -s "OSCAM client of $client restarted" admin@kirner.or.at
      fi
    else
      if [ $debug -eq 1 ] ;then echo -e "Sieht  schlecht aus - String $s nicht gefunden." ; fi
    fi
  }
  fi
}
else
{
  echo "CRITICAL: Could not download status.html (StatusCheck)"
  # Logging
  if [ "$logsyslog"  == "1" ] ; then logger "$filename $version - CRITICAL: Could not download status.html (StatusCheck)"; fi
  exit 2;
}
fi

Init-Script erstellen

touch /etc/init.d/run_check_oscam_client.sh
chmod a+x /etc/init.d/run_check_oscam_client.sh
vi /etc/init.d/run_check_oscam_client.sh
sleep 20 && /usr/script/check_oscam_client.sh <hostname> 83 <username> <password> 1
cd /etc/rc3.d/
ln -sf ../init.d/run_check_oscam_client.sh /etc/rc3.d/S99run_check_oscam_client.sh


Zurück zu Watchdog (Oscam)