Issue
Code backup
This commit is contained in:
@@ -0,0 +1,125 @@
|
||||
#!/bin/bash
|
||||
|
||||
# startup checks
|
||||
if [ -z "$BASH" ]; then
|
||||
echo "Please use BASH."
|
||||
exit 3
|
||||
fi
|
||||
if [ ! -e "/usr/bin/which" ]; then
|
||||
echo "/usr/bin/which is missing."
|
||||
exit 3
|
||||
fi
|
||||
snmp=$(which snmpwalk)
|
||||
if [ $? -ne 0 ]; then
|
||||
echo "Please install snmpwalk"
|
||||
exit 3
|
||||
fi
|
||||
|
||||
# Default Values
|
||||
community="pal-ro"
|
||||
version="2"
|
||||
more=""
|
||||
|
||||
# State Variables
|
||||
STATE_OK=0
|
||||
STATE_WARN=1
|
||||
STATE_CRIT=2
|
||||
STATE_UNK=3
|
||||
|
||||
# Default Outputs
|
||||
STATE=$STATE_OK
|
||||
STATE_STRING=""
|
||||
PERFDATA=""
|
||||
|
||||
# Usage Info
|
||||
usage() {
|
||||
echo '''
|
||||
Usage: check_snmp [OPTIONS]
|
||||
[OPTIONS]
|
||||
|
||||
-p PORT Port to send the snmp request to (default: 161)
|
||||
-N COMMUNITY SNMP community name (default: public)
|
||||
-H HOST Hostname to send SNMP queries to
|
||||
-o OID SNMP OID to query
|
||||
-V VERSION SNMP Version (default: 2)
|
||||
-M MORE When using -V 3, pass all required snmpwalk parameters
|
||||
with -M, i.E. "-u user -a MD5 -A 72d0815....D38 -x AES"
|
||||
|
||||
-w WARNING Defines limit for WARNING
|
||||
-c CRITICAL Defines limit for CRITICAL
|
||||
'''
|
||||
}
|
||||
|
||||
#main
|
||||
#get options
|
||||
while getopts "p:N:H:o:V:M:W:C:w:c:" opt; do
|
||||
case $opt in
|
||||
port=$OPTARG
|
||||
;;
|
||||
N)
|
||||
community=$OPTARG
|
||||
;;
|
||||
H)
|
||||
host=$OPTARG
|
||||
;;
|
||||
o)
|
||||
oid=$OPTARG
|
||||
;;
|
||||
V)
|
||||
version=$OPTARG
|
||||
;;
|
||||
M)
|
||||
more=$OPTARG
|
||||
;;
|
||||
w)
|
||||
warning=$OPTARG
|
||||
;;
|
||||
c)
|
||||
critical=$OPTARG
|
||||
;;
|
||||
*)
|
||||
usage
|
||||
exit 3
|
||||
;;
|
||||
esac
|
||||
done
|
||||
|
||||
#required paramters
|
||||
if [ -z "$host" ]; then
|
||||
echo "Error: host is required"
|
||||
usage
|
||||
exit 3
|
||||
fi
|
||||
if [ -z "$oid" ]; then
|
||||
echo "Error: oid is required"
|
||||
usage
|
||||
exit 3
|
||||
fi
|
||||
|
||||
if ! [[ "$version" =~ ^[0-9]+$ ]]; then
|
||||
echo "Error: -V must be 1 , 2 or 3"
|
||||
usage
|
||||
exit 3
|
||||
fi
|
||||
if [ $version -lt 1 ] || [ $version -gt 3 ]; then
|
||||
echo "Error: -V must be 1 , 2 or 3"
|
||||
usage
|
||||
exit 3
|
||||
fi
|
||||
oversion=$version
|
||||
if [ $version -eq 2 ];then
|
||||
version="-v2c"
|
||||
elif [ $version -eq 1 ]; then
|
||||
version="-v1"
|
||||
fi
|
||||
|
||||
if [ $oversion -eq 3 ] ; then
|
||||
rtr=$(snmpwalk $version -c $community $host $oid)
|
||||
fi
|
||||
status=$?
|
||||
|
||||
rtr=$(echo $rtr | cut -d " " -f 4)
|
||||
|
||||
echo "Value is: $rtr"
|
||||
|
||||
exit 0
|
||||
@@ -0,0 +1,98 @@
|
||||
// -*- mode: icinga -*-
|
||||
// Template -
|
||||
|
||||
template Host "WG" {
|
||||
address = "172.16.254.240"
|
||||
check_command = "hostalive"
|
||||
}
|
||||
|
||||
template Service "snmpv2c"{
|
||||
check_command = "check-snmp"
|
||||
vars.csnmp_community = "pal-ro"
|
||||
vars.csnmp_version = "2"
|
||||
}
|
||||
|
||||
// - CheckCommand -
|
||||
|
||||
object CheckCommand "check-snmp" {
|
||||
command = [ ConfigDir + "/scripts/check_snmp.sh" ]
|
||||
arguments += {
|
||||
"-H" = {
|
||||
required = true
|
||||
value = "$host.address$"
|
||||
}
|
||||
"-o" = {
|
||||
required = true
|
||||
value = "$csnmp_oid$"
|
||||
}
|
||||
"-w" = "$csnmp_warning$"
|
||||
"-c" = "$csnmp_critical$"
|
||||
"-p" = "$csnmp_port$"
|
||||
"-N" = "$csnmp_community$"
|
||||
"-V" = "$csnmp_version$"
|
||||
}
|
||||
}
|
||||
|
||||
// - Host -
|
||||
|
||||
object Host "WatchGuard" {
|
||||
import "WG"
|
||||
}
|
||||
|
||||
// - Basic Service -
|
||||
|
||||
object Service "ping4" {
|
||||
display_name = "Ping4"
|
||||
host_name = "WatchGuard"
|
||||
check_command = "ping4"
|
||||
}
|
||||
|
||||
object Service "http" {
|
||||
display_name = "Http"
|
||||
host_name = "WatchGuard"
|
||||
check_command = "http"
|
||||
}
|
||||
|
||||
// - SNMPWALK -
|
||||
|
||||
object Service "wgSystemTotalSendBytes" {
|
||||
import "snmpv2c"
|
||||
display_name = "Total Send Bytes"
|
||||
host_name = "WatchGuard"
|
||||
vars.csnmp_oid = "1.3.6.1.4.1.3097.6.3.8"
|
||||
}
|
||||
|
||||
object Service "wgSystemTotalRecvBytes" {
|
||||
import "snmpv2c"
|
||||
display_name = "Total Recive Bytes"
|
||||
host_name = "WatchGuard"
|
||||
vars.csnmp_oid = "1.3.6.1.4.1.3097.6.3.9"
|
||||
}
|
||||
|
||||
object Service "wgSystemTotalSendPackets" {
|
||||
import "snmpv2c"
|
||||
display_name = "Total Send Packets"
|
||||
host_name = "WatchGuard"
|
||||
vars.csnmp_oid = "1.3.6.1.4.1.3097.6.3.10"
|
||||
}
|
||||
|
||||
object Service "wgSystemTotalRecvPackets" {
|
||||
import "snmpv2c"
|
||||
display_name = "Total Recive Packets"
|
||||
host_name = "WatchGuard"
|
||||
vars.csnmp_oid = "1.3.6.1.4.1.3097.6.3.11"
|
||||
}
|
||||
|
||||
object Service "wgSystemCpuUtil1" {
|
||||
import "snmpv2c"
|
||||
display_name = "Cpu Util"
|
||||
host_name = "WatchGuard"
|
||||
vars.csnmp_oid = "1.3.6.1.4.1.3097.6.3.77"
|
||||
}
|
||||
|
||||
object Service "wgSystemCurrActiveConns" {
|
||||
import "snmpv2c"
|
||||
display_name = "Current Active Connections"
|
||||
host_name = "WatchGuard"
|
||||
vars.csnmp_oid = "1.3.6.1.4.1.3097.6.3.80"
|
||||
}
|
||||
@@ -0,0 +1,413 @@
|
||||
#########################################################
|
||||
## GLOBAL VARIABLES ##
|
||||
#########################################################
|
||||
APPNAME=$(basename $0)
|
||||
AUTHOR="Claudio Boggian"
|
||||
VERSION="0.1"
|
||||
|
||||
# Default settings for connection
|
||||
COMMUNITY='public'
|
||||
HOST_NAME='172.16.254.240'
|
||||
SNMPVERSION='2c'
|
||||
|
||||
# State Variables
|
||||
STATE_OK=0
|
||||
STATE_WARN=1
|
||||
STATE_CRIT=2
|
||||
STATE_UNK=3
|
||||
|
||||
# Default Outputs
|
||||
STATE=$STATE_OK
|
||||
STATE_STRING=""
|
||||
PERFDATA=""
|
||||
|
||||
WARNING=65
|
||||
CRITICAL=70
|
||||
|
||||
SEPARATOR="\n"
|
||||
ARG_TOKEN=','
|
||||
|
||||
#########################################################
|
||||
# Universal SNMP OIDS #
|
||||
#########################################################
|
||||
|
||||
#wgSystemStatisticsMIB
|
||||
OID_wgSystemTotalSendBytes="1.3.6.1.4.1.3097.6.3.8"
|
||||
OID_wgSystemTotalRecvBytes="1.3.6.1.4.1.3097.6.3.9"
|
||||
OID_wgSystemTotalSendPackets="1.3.6.1.4.1.3097.6.3.10"
|
||||
OID_wgSystemTotalRecvPackets="1.3.6.1.4.1.3097.6.3.11"
|
||||
OID_wgSystemCpuUtil1="1.3.6.1.4.1.3097.6.3.77"
|
||||
OID_wgSystemCurrActiveConns="1.3.6.1.4.1.3097.6.3.80"
|
||||
#wgIpsecStats
|
||||
OID_wgIpsecTunnelNum="1.3.6.1.4.1.3097.6.5.1.1"
|
||||
#wgInfoSystem
|
||||
OID_wgInfoGavService="1.3.6.1.4.1.3097.6.1.3.0"
|
||||
OID_wgInfoIpsService="1.3.6.1.4.1.3097.6.1.4.0"
|
||||
|
||||
#########################################################
|
||||
# print_version #
|
||||
#########################################################
|
||||
|
||||
print_version() {
|
||||
|
||||
echo "$APPNAME $VERSION"
|
||||
echo "$AUTHOR"
|
||||
echo ''
|
||||
|
||||
}
|
||||
|
||||
#########################################################
|
||||
# print_usage #
|
||||
#########################################################
|
||||
|
||||
print_usage(){
|
||||
|
||||
echo ''
|
||||
echo 'Usage for SNMP v1/2c:'
|
||||
echo " $APPNAME -H <host/IP> -t <type of check> [-C <SNMP community>] [-p <ports>] [-S <character>] [-w <warning value>] [-c <critical value>]"
|
||||
echo ''
|
||||
echo 'Usage for SNMP v3:'
|
||||
echo " $APPNAME -H <host/IP> -t <check> -u <user> -x <protocol> -X <password> -a <protocol> -A <password> -l <security mode> [-p <ports>] [-S <character>]>"
|
||||
echo ''
|
||||
|
||||
}
|
||||
|
||||
#########################################################
|
||||
## print_help Function ##
|
||||
#########################################################
|
||||
# Prints out user help and gives examples of proper #
|
||||
# plugin usage #
|
||||
#########################################################
|
||||
|
||||
function print_help () {
|
||||
|
||||
print_version
|
||||
echo 'Description:'
|
||||
echo "$APPNAME is a Nagios plugin to check the status of various components of Dell PowerConnect switches."
|
||||
echo ''
|
||||
echo 'This plugin is not developped by the Nagios Plugin group.'
|
||||
echo 'Please do not e-mail them for support on this plugin.'
|
||||
echo ''
|
||||
echo 'For contact info, please read the plugin script file.'
|
||||
print_usage
|
||||
echo "---------------------------------------------------------------------"
|
||||
echo ''
|
||||
echo 'OPTIONS:'
|
||||
echo ' -H|--host'
|
||||
echo ' Host name or IP address to check. Default is: localhost. REQUIRED OPTION'
|
||||
echo ' -v|--snmpversion { 1 | 2c | 3 }'
|
||||
echo " Specifies the SNMP version to use. Default is '2c'. REQUIRED OPTION"
|
||||
echo ' -C|--community'
|
||||
echo " SNMP v2 community string with Read access. Default is 'public'. REQUIRED OPTION"
|
||||
echo ' -u|--user'
|
||||
echo ' SNMP v3 username'
|
||||
echo ' -l|--privlevel { noAuthNoPriv | authNoPriv | authPriv }'
|
||||
echo ' SNMP v3 privilege level'
|
||||
echo ' -x|--privprotocol { DES | AES }'
|
||||
echo ' SNMP v3 privacy protocol'
|
||||
echo ' -X|--privpassword'
|
||||
echo ' SNMP v3 privacy password'
|
||||
echo ' -a|--authprotocol { MD5 | SHA }'
|
||||
echo ' SNMP v3 authentication protocol'
|
||||
echo ' -A|--authpassword'
|
||||
echo ' SNMP v3 authentication password'
|
||||
echo ' -t|--type { Transfer | Cpu | ActiveConns | IpsecTunnelNum | InfoUpdate }'
|
||||
echo ' The check you want to perform for the switch(es).'
|
||||
echo ' REQUIRED OPTION.'
|
||||
echo ' -p|--port <port(s)>'
|
||||
echo " Specify port number, or list of ports (comma-separated) to be checked (only for the '-t port' option!)"
|
||||
echo ' -S|--separator <text string>'
|
||||
echo ' Assign a particular string as the separator for consumables.'
|
||||
echo ' Default is " " to conform to Nagios plugin development guidelines'
|
||||
echo ' -w|--warning'
|
||||
echo ' Assign WARNING value, in degrees C, for temperature checks'
|
||||
echo ' -c|--critical'
|
||||
echo ' Assign CRITICAL value, in degrees C, for temperature checks'
|
||||
echo ' -h|--help'
|
||||
echo ' Show this help screen'
|
||||
echo ' -V|--version'
|
||||
echo ' Show the current version of the plugin'
|
||||
echo ''
|
||||
echo 'CHECK TYPES:'
|
||||
echo ' assets:'
|
||||
echo ' Returns serial number and service tag of unit. '
|
||||
echo ''
|
||||
echo ' description:'
|
||||
echo ' Returns make and model of unit. Equivalent to checking sysDescr.'
|
||||
echo ''
|
||||
echo ' uptime:'
|
||||
echo ' How long the unit has been powered on. Equivalent to checking sysUptime.'
|
||||
echo ''
|
||||
echo ' ports:'
|
||||
echo ' Checks admin status of all ports. Reports number of ports UP and DOWN. Equivalent to checking ifOperStatus'
|
||||
echo ''
|
||||
echo ' port:'
|
||||
echo ' Admin status of specified ports. Reports number of ports UP and DOWN. '
|
||||
echo ' Ports to check can be specified as a range (x-y), as well as a comma-separated list (3,5,19).'
|
||||
echo ''
|
||||
echo ' health:'
|
||||
echo " Global health status of the device(s). Will let you know something is wrong, but won't check what."
|
||||
echo ''
|
||||
echo ' temps:'
|
||||
echo ' Ambient temperature of the device(s).'
|
||||
echo ' WARNING and CRITICAL values are required! Default WARNING is 65 deg F and CRITICAL is 70 deg F.'
|
||||
echo ''
|
||||
echo ' fans:'
|
||||
echo ' Fan status of the device(s).'
|
||||
echo ''
|
||||
echo ' psus:'
|
||||
echo ' Power supply status of the device(s).'
|
||||
echo ''
|
||||
echo 'EXAMPLES:'
|
||||
echo " $APPNAME -H hostname -C public -t port -p 42"
|
||||
echo ' to check status of port 42'
|
||||
echo " $APPNAME -H hostname -C public -t psus"
|
||||
echo ' to check status of power supplies'
|
||||
echo " $APPNAME -H hostname -C public -t temps -w 60 -c 70"
|
||||
echo ' to check thermal temperatures'
|
||||
echo ''
|
||||
|
||||
exit $STATE_UNK
|
||||
|
||||
}
|
||||
|
||||
#########################################################
|
||||
## CheckPort function ##
|
||||
#########################################################
|
||||
|
||||
# Check System Statistics Send/Recv
|
||||
function CheckTransferData (){
|
||||
|
||||
TOTSENDB=$(snmpwalk -v $SNMPVERSION -c $COMMUNITY $HOST_NAME $OID_wgSystemTotalSendBytes)
|
||||
TOTSENDPKG=$(snmpwalk -v $SNMPVERSION -c $COMMUNITY $HOST_NAME $OID_wgSystemTotalSendPackets)
|
||||
TOTRECVB=$(snmpwalk -v $SNMPVERSION -c $COMMUNITY $HOST_NAME $OID_wgSystemTotalRecvBytes)
|
||||
TOTRECVPKG=$(snmpwalk -v $SNMPVERSION -c $COMMUNITY $HOST_NAME $OID_wgSystemTotalRecvPackets)
|
||||
TSPO=$(echo "$TOTSENDPKG" | cut -d " " -f 4)
|
||||
TSBO=$(echo "$TOTSENDB" | cut -d " " -f 4 | awk '{ byte =$1 /1024/1024/1024; print byte " GB" }')
|
||||
TRPO=$(echo "$TOTRECVPKG" | cut -d " " -f 4)
|
||||
TRBO=$(echo "$TOTRECVB" | cut -d " " -f 4 | awk '{ byte =$1 /1024/1024/1024; print byte " GB" }')
|
||||
echo "WatchGuard Send:"
|
||||
echo " $TSPO pkg"
|
||||
echo " $TSBO"
|
||||
echo ""
|
||||
echo "WatchGuard Recive:"
|
||||
echo " $TRPO pkg"
|
||||
echo " $TRBO"
|
||||
|
||||
}
|
||||
|
||||
function CheckCpuUtil (){
|
||||
|
||||
CPUUTIL=$(snmpwalk -v $SNMPVERSION -c $COMMUNITY $HOST_NAME $OID_wgSystemCpuUtil1)
|
||||
CPU_STATE=$(echo "$CPUUTIL" | cut -d " " -f 4)
|
||||
CPU_PERC=$(echo "$CPU_STATE" | awk '{ byte =$1 /10; print byte " %" }')
|
||||
|
||||
case 1 in
|
||||
$(($CPU_STATE>= 0))) echo "OK! CPU used: $CPU_PERC"
|
||||
exit 0 ;;
|
||||
$(($CPU_STATE>= 800))) echo "WARRING! CPU used: $CPU_PERC"
|
||||
exit 1 ;;
|
||||
$(($CPU_STATE>= 900))) echo "CRITICAL! CPU used: $CPU_PERC"
|
||||
exit 2 ;;
|
||||
*) echo "UNKNOWN! Cpu not found"
|
||||
exit 3 ;;
|
||||
esac
|
||||
}
|
||||
|
||||
function CheckCurrActiveConns (){ # Max 3.300.000
|
||||
|
||||
CAC=$(snmpwalk -v $SNMPVERSION -c $COMMUNITY $HOST_NAME $OID_wgSystemCurrActiveConns)
|
||||
CACO=$(echo "$CAC" | cut -d " " -f 4)
|
||||
|
||||
case 1 in
|
||||
$(($CACO>= 0))) echo "OK! Current Active Connections: $CACO"
|
||||
exit 0 ;;
|
||||
$(($CACO>= 2640000))) echo "WARRING! Current Active Connections: $CACO"
|
||||
exit 1 ;;
|
||||
$(($CACO>= 2970000))) echo "CRITICAL! Current Active Connections: $CACO"
|
||||
exit 2 ;;
|
||||
*) echo "UNKNOWN! Current Active Connections not found"
|
||||
exit 3 ;;
|
||||
esac
|
||||
|
||||
}
|
||||
|
||||
function CheckIpsecTunnelNum (){
|
||||
|
||||
IPSTN=$(snmpwalk -v $SNMPVERSION -c $COMMUNITY $HOST_NAME $OID_wgIpsecTunnelNum)
|
||||
IPSTNO=$(echo "$IPSTN" | cut -d " " -f 4)
|
||||
echo "VPN active: $IPSTNO"
|
||||
|
||||
}
|
||||
|
||||
function CheckInfoGavService (){
|
||||
|
||||
INFOGAV=$(snmpwalk -v $SNMPVERSION -c $COMMUNITY $HOST_NAME $OID_wgInfoGavService)
|
||||
IGSV=$(echo "$INFOGAV" | cut -d "<" -f 2 | cut -d ">" -f 1)
|
||||
IGSD=$(echo "$INFOGAV" | cut -d "(" -f 2 | cut -d ")" -f 1)
|
||||
echo "Gateway Antivirus Service: $IGSV | $IGSD"
|
||||
|
||||
}
|
||||
|
||||
function CheckInfoIpsService (){
|
||||
|
||||
INFOIPS=$(snmpwalk -v $SNMPVERSION -c $COMMUNITY $HOST_NAME $OID_wgInfoIpsService)
|
||||
IISV=$(echo "$INFOIPS" | cut -d "<" -f 2 | cut -d ">" -f 1)
|
||||
IISD=$(echo "$INFOIPS" | cut -d "(" -f 2 | cut -d ")" -f 1)
|
||||
echo "Intrusion Prevention Service: $IISV | $IISD"
|
||||
|
||||
}
|
||||
|
||||
#########################################################
|
||||
# Subroutine: check_snmp_error #
|
||||
#########################################################
|
||||
|
||||
check_snmp_error(){
|
||||
|
||||
if [[ $1 -ne 0 ]]; then
|
||||
echo $2
|
||||
exit $STATE_UNK
|
||||
fi
|
||||
|
||||
}
|
||||
|
||||
#########################################################
|
||||
## MAIN CODE ##
|
||||
#########################################################
|
||||
|
||||
# Check that all required binaries for the script are available
|
||||
# EXIT with an UNKNOWN status if not
|
||||
binaries="snmpwalk snmpget cut tr sed grep awk wc"
|
||||
|
||||
for required_binary in $binaries
|
||||
do
|
||||
which $required_binary > /dev/null
|
||||
if [ "$?" != '0' ];then
|
||||
echo "UNKNOWN: $APPNAME: No usable '$required_binary' binary in '$PATH'"
|
||||
exit $STATE_UNK
|
||||
fi
|
||||
done
|
||||
|
||||
# Check to see if any parameters were passed
|
||||
if [[ $# -eq 0 ]]; then
|
||||
print_usage
|
||||
exit $STATE_UNK
|
||||
fi
|
||||
|
||||
while test -n "$1"; do
|
||||
|
||||
case "$1" in
|
||||
--host|-H)
|
||||
HOST_NAME=$2
|
||||
shift
|
||||
;;
|
||||
--comunity|-C)
|
||||
COMMUNITY=$2
|
||||
shift
|
||||
;;
|
||||
--snmpversion|-v)
|
||||
SNMPVERSION=$2
|
||||
shift
|
||||
;;
|
||||
--user|-u)
|
||||
SNMPUSER=$2
|
||||
shift
|
||||
;;
|
||||
--privelegelevel|-l)
|
||||
PRIVILEGELEVEL=$2
|
||||
shift
|
||||
;;
|
||||
--authprotocol|-a)
|
||||
AUTHPROTOCOL=$2
|
||||
shift
|
||||
;;
|
||||
--authpassword|-A)
|
||||
AUTHPASSWORD=$2
|
||||
shift
|
||||
;;
|
||||
--privacyprotocol|-x)
|
||||
PRIVACYPROTOCOL=$2
|
||||
shift
|
||||
;;
|
||||
--privacypassword|-X)
|
||||
PRIVACYPASSWORD=$2
|
||||
shift
|
||||
;;
|
||||
--type|-t)
|
||||
CHECK_TYPE=$2
|
||||
shift
|
||||
;;
|
||||
--port|-p)
|
||||
PORT_LIST=$2
|
||||
shift
|
||||
;;
|
||||
--separator|-S) # Assign separator
|
||||
SEPARATOR="$2"
|
||||
shift
|
||||
;;
|
||||
--warning|-w) # Assign WARNING threshold
|
||||
WARNING=$2
|
||||
shift
|
||||
;;
|
||||
--critical|-c) # Assign CRITICAL threshold
|
||||
CRITICAL=$2
|
||||
shift
|
||||
;;
|
||||
--help|-h)
|
||||
print_help
|
||||
;;
|
||||
--version|-V)
|
||||
print_version
|
||||
exit $STATE
|
||||
;;
|
||||
*)
|
||||
echo "Unknown argument: $1"
|
||||
print_usage
|
||||
exit $STATE_UNK
|
||||
;;
|
||||
|
||||
esac
|
||||
|
||||
shift
|
||||
|
||||
done
|
||||
|
||||
# Make sure all necessary arguments were given; EXIT with an UNKNOWN status if not
|
||||
if [ ! -z $CHECK_TYPE ]; then
|
||||
# Determine the check to perform
|
||||
case "$CHECK_TYPE" in
|
||||
"Transfer")
|
||||
CheckTransferData
|
||||
;;
|
||||
"Cpu")
|
||||
CheckCpuUtil
|
||||
STATE=$?
|
||||
;;
|
||||
"ActiveConns")
|
||||
CheckCurrActiveConns
|
||||
STATE=$?
|
||||
;;
|
||||
"IpsecTunnelNum")
|
||||
CheckIpsecTunnelNum
|
||||
;;
|
||||
"InfoGav")
|
||||
CheckInfoGavService
|
||||
;;
|
||||
"InfoIps")
|
||||
CheckInfoIpsService
|
||||
;;
|
||||
esac
|
||||
|
||||
else
|
||||
echo "Command incomplete!"
|
||||
STATE=$STATE_UNK
|
||||
fi
|
||||
|
||||
# If the program hasn't exited already, then a check was run okay and we can quit.
|
||||
if [ "$PERFDATA" == "" ]; then
|
||||
echo "$STATE_STRING"
|
||||
else
|
||||
echo "$STATE_STRING|$PERFDATA"
|
||||
fi
|
||||
|
||||
exit $STATE
|
||||
@@ -0,0 +1,62 @@
|
||||
// -*- mode: icinga -*-
|
||||
|
||||
// # CheckCommand #
|
||||
|
||||
object CheckCommand "check_watchguard" {
|
||||
import "plugin-check-command"
|
||||
command = [ ConfigDir + "/scripts/check_watchguard.sh" ]
|
||||
arguments += {
|
||||
"-C" = "$wgsnmp_community$"
|
||||
"-H" = "$address$"
|
||||
"-t" = {
|
||||
required = true
|
||||
value = "$wgsnmp_types$"
|
||||
}
|
||||
}
|
||||
vars.wgsnmp_community = "pal-ro"
|
||||
}
|
||||
|
||||
// # Template #
|
||||
|
||||
template Host "WatchGuard" {
|
||||
address = "172.16.254.240"
|
||||
check_command = "hostalive"
|
||||
}
|
||||
|
||||
template Service "WatchGuard - check_watchguard" {
|
||||
check_command = "check_watchguard"
|
||||
check_interval = 5m
|
||||
retry_interval = 3m
|
||||
command_endpoint = null
|
||||
vars.wgsnmp_types = "InfoGav"
|
||||
}
|
||||
|
||||
// # Host #
|
||||
|
||||
object Host "WatchGuard - Host" {
|
||||
import "WG"
|
||||
}
|
||||
|
||||
// # Service #
|
||||
|
||||
// # basic #
|
||||
|
||||
object Service "ping4" {
|
||||
display_name = "Ping4"
|
||||
host_name = "WatchGuard"
|
||||
check_command = "ping4"
|
||||
}
|
||||
|
||||
object Service "http" {
|
||||
display_name = "Http"
|
||||
host_name = "WatchGuard"
|
||||
check_command = "http"
|
||||
}
|
||||
|
||||
// # snmp #
|
||||
|
||||
apply Service "WatchGuard - Cpu" {
|
||||
import "DELL Switch - check_switch"
|
||||
|
||||
vars.wgsnmp_types = "Cpu"
|
||||
}
|
||||
@@ -0,0 +1,94 @@
|
||||
// -*- mode: icinga -*-
|
||||
|
||||
// - Template -
|
||||
|
||||
template Host "WG" {
|
||||
address = "172.16.254.240"
|
||||
check_command = "hostalive"
|
||||
}
|
||||
|
||||
template Service "snmpv2c" {
|
||||
check_command = "check-watchguard"
|
||||
vars.wgsnmp_community = "pal-ro"
|
||||
vars.wgsnmp_version = "2c"
|
||||
}
|
||||
|
||||
// - CheckCommand -
|
||||
|
||||
object CheckCommand "check-watchguard" {
|
||||
command = [ ConfigDir + "/scripts/check_watchguard.sh" ]
|
||||
arguments += {
|
||||
"-v" = "$wgsnmp_version"
|
||||
"-C" = "$wgsnmp_community$"
|
||||
"-H" = "$host.address$"
|
||||
"-t" = {
|
||||
required = true
|
||||
value = "$wgsnmp_checktype$"
|
||||
}
|
||||
}
|
||||
|
||||
// - Host -
|
||||
|
||||
object Host "WatchGuard"{
|
||||
import "WG"
|
||||
}
|
||||
|
||||
// - Basic Service -
|
||||
|
||||
object Service "ping4"{
|
||||
display_name = "Ping4"
|
||||
host_name = "WatchGuard"
|
||||
check_command = "ping4"
|
||||
}
|
||||
|
||||
object Service "http"{
|
||||
display_name = "Http"
|
||||
host_name = "WatchGuard"
|
||||
check_command = "http"
|
||||
}
|
||||
|
||||
// - SNMPWALK -
|
||||
|
||||
object Service "CheckTransferData"{
|
||||
import "snmpv2c"
|
||||
display_name = "Transfer Data"
|
||||
host_name = "WatchGuard"
|
||||
vars.wgsnmp_checktype = "Transfer"
|
||||
}
|
||||
|
||||
object Service "CheckCpuUtil"{
|
||||
import "snmpv2c"
|
||||
display_name = "CPU used"
|
||||
host_name = "WatchGuard"
|
||||
vars.wgsnmp_checktype = "Cpu"
|
||||
}
|
||||
|
||||
object Service "CheckCurrActiveConns"{
|
||||
import "snmpv2c"
|
||||
display_name = "Current Active Connections"
|
||||
host_name = "WatchGuard"
|
||||
vars.wgsnmp_checktype = "ActiveConns"
|
||||
}
|
||||
|
||||
object Service "CheckIpsecTunnelNum"{
|
||||
import "snmpv2c"
|
||||
display_name = "IP Security Active"
|
||||
host_name = "WatchGuard"
|
||||
vars.wgsnmp_checktype = "IpsecTunnelNum"
|
||||
}
|
||||
|
||||
object Service "CheckInfoGavService"{
|
||||
import "snmpv2c"
|
||||
display_name = "Gateway Antivirus Service"
|
||||
host_name = "WatchGuard"
|
||||
vars.wgsnmp_checktype = "InfoGav"
|
||||
}
|
||||
|
||||
object Service "CheckInfoIpsService"{
|
||||
import "snmpv2c"
|
||||
display_name = "Intrusion Prevention Service"
|
||||
host_name = "WatchGuard"
|
||||
vars.wgsnmp_checktype = "InfoIps"
|
||||
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user