Module: check_mk
Branch: master
Commit: 023b9488dac3181cdd90c9bd6e2ab3810f916510
URL:
http://git.mathias-kettner.de/git/?p=check_mk.git;a=commit;h=023b9488dac318…
Author: Bastian Kuhn <bk(a)mathias-kettner.de>
Date: Tue Sep 9 14:11:41 2014 +0200
#1182 bluecat_ha: New Check for HA Status on Bluecat Adonis devices
---
.werks/1182 | 9 +++++
ChangeLog | 1 +
checkman/bluecat_ha | 14 +++++++
checks/bluecat_ha | 69 ++++++++++++++++++++++++++++++++++
web/plugins/wato/check_parameters.py | 53 +++++++++++++++++++++++++-
5 files changed, 144 insertions(+), 2 deletions(-)
diff --git a/.werks/1182 b/.werks/1182
new file mode 100644
index 0000000..c6f9c5a
--- /dev/null
+++ b/.werks/1182
@@ -0,0 +1,9 @@
+Title: bluecat_ha: New Check for HA Status on Bluecat Adonis devices
+Level: 1
+Component: checks
+Compatible: compat
+Version: 1.2.5i6
+Date: 1410264668
+Class: feature
+
+
diff --git a/ChangeLog b/ChangeLog
index 5acbb4a..f1d77e1 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -50,6 +50,7 @@
* 1180 bluecat_dns, bluecat_dns_queries: New DNS Checks for Bluecat Adonis.
* 1181 bluecat_ntp: New Check for NTP on bluecat adonis or proteus devices
* 1105 wmic_if.ps1: Powershell version of the wmic_if.bat script...
+ * 1182 bluecat_ha: New Check for HA Status on Bluecat Adonis devices
* 1051 FIX: tcp_conn_stats: fix missing performance data...
* 1142 FIX: winperf_ts_sessions: fix computation, check has never really worked
* 1090 FIX: zfsget: fixed exception which happened on incomplete zfs entries
diff --git a/checkman/bluecat_ha b/checkman/bluecat_ha
new file mode 100644
index 0000000..28667c1
--- /dev/null
+++ b/checkman/bluecat_ha
@@ -0,0 +1,14 @@
+title: Bluecat Adonis HA State
+agents: snmp
+catalog: hw/network/bluecat
+license: GPL
+distribution: check_mk
+description:
+ This Check monitors the OperState of the HA Service on bluecat adonis devices.
+ Per default the check returns {CRITICAL} if the device is in the state fault or stopped.
{WARNING} will be returned if
+ the device is in the state stopping, becoming active, becoming passive.
+ The behavior can be changed using WATO.
+
+inventory:
+ One service will be created
+
diff --git a/checks/bluecat_ha b/checks/bluecat_ha
new file mode 100644
index 0000000..a5e4300
--- /dev/null
+++ b/checks/bluecat_ha
@@ -0,0 +1,69 @@
+#!/usr/bin/python
+# -*- encoding: utf-8; py-indent-offset: 4 -*-
+# +------------------------------------------------------------------+
+# | ____ _ _ __ __ _ __ |
+# | / ___| |__ ___ ___| | __ | \/ | |/ / |
+# | | | | '_ \ / _ \/ __| |/ / | |\/| | ' / |
+# | | |___| | | | __/ (__| < | | | | . \ |
+# | \____|_| |_|\___|\___|_|\_\___|_| |_|_|\_\ |
+# | |
+# | Copyright Mathias Kettner 2013 mk(a)mathias-kettner.de |
+# +------------------------------------------------------------------+
+#
+# This file is part of Check_MK.
+# The official homepage is at
http://mathias-kettner.de/check_mk.
+#
+# check_mk is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License as published by
+# the Free Software Foundation in version 2. check_mk is distributed
+# in the hope that it will be useful, but WITHOUT ANY WARRANTY; with-
+# out even the implied warranty of MERCHANTABILITY or FITNESS FOR A
+# PARTICULAR PURPOSE. See the GNU General Public License for more de-
+# ails. You should have received a copy of the GNU General Public
+# License along with GNU Make; see the file COPYING. If not, write
+# to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
+# Boston, MA 02110-1301 USA.
+
+factory_settings["bluecat_ha"] = {
+ "oper_states" : {
+ "warning" : [ 5, 6, 7 ],
+ "critical" : [ 8, 4 ],
+ },
+}
+
+def inventory_bluecat_ha(info):
+ # Only add if device is not in standalone mode
+ if info[0][0] != '1':
+ return [(None, None)]
+
+def check_bluecat_ha(item, params, info):
+ oper_state = int(info[0][0])
+ oper_states = {
+ 1 : "standalone",
+ 2 : "active",
+ 3 : "passiv",
+ 4 : "stopped",
+ 5 : "stopping",
+ 6 : "becoming active",
+ 7 : "becomming passive",
+ 8 : "fault",
+ }
+
+ state = 0
+ if oper_state in params['oper_states']['warning']:
+ state = 1
+ elif oper_state in params['oper_states']['critical']:
+ state = 2
+ yield state, "State is %s" % oper_states[oper_state]
+
+
+check_info["bluecat_ha"] = {
+ "check_function" : check_bluecat_ha,
+ "inventory_function" : inventory_bluecat_ha,
+ "service_description" : "HA State",
+ "default_levels_variable" : "bluecat_ha",
+ "group" : "bluecat_ha",
+ "snmp_scan_function" : lambda oid:
oid(".1.3.6.1.2.1.1.2.0") == ".1.3.6.1.4.1.13315.2.1",
+ "snmp_info" : (".1.3.6.1.4.1.13315.3.1.5.2.1", [
1 ] ),
+}
+
diff --git a/web/plugins/wato/check_parameters.py b/web/plugins/wato/check_parameters.py
index cea209b..97b6d99 100644
--- a/web/plugins/wato/check_parameters.py
+++ b/web/plugins/wato/check_parameters.py
@@ -6012,12 +6012,16 @@ register_check_parameters(
( "warning",
ListChoice(
title = _("States treated as warning"),
- choices = bluecat_operstates )
+ choices = bluecat_operstates,
+ default_value = [ 2, 3, 4 ],
+ )
),
( "critical",
ListChoice(
title = _("States treated as critical"),
- choices = bluecat_operstates )
+ choices = bluecat_operstates,
+ default_value = [ 5 ],
+ )
),
],
required_keys = [ 'warning', 'critical' ],
@@ -6037,6 +6041,51 @@ register_check_parameters(
"first"
),
+bluecat_ha_operstates = [
+ ( 1 , "standalone"),
+ ( 2 , "active"),
+ ( 3 , "passiv"),
+ ( 4 , "stopped"),
+ ( 5 , "stopping"),
+ ( 6 , "becoming active"),
+ ( 7 , "becomming passive"),
+ ( 8 , "fault"),
+]
+
+register_check_parameters(
+ subgroup_networking,
+ "bluecat_ha",
+ _("Bluecat HA Settings"),
+ Dictionary(
+ elements = [
+ ( "oper_states",
+ Dictionary(
+ title = _("Oper States"),
+ elements = [
+ ( "warning",
+ ListChoice(
+ title = _("States treated as warning"),
+ choices = bluecat_ha_operstates,
+ default_value = [ 5, 6, 7 ],
+ ),
+ ),
+ ( "critical",
+ ListChoice(
+ title = _("States treated as critical"),
+ choices = bluecat_ha_operstates ,
+ default_value = [ 8, 4 ],
+ ),
+ ),
+ ],
+ required_keys = [ 'warning', 'critical' ],
+ )
+ ),
+ ],
+ required_keys = [ 'oper_states' ], # There is only one value, so its
required
+ ),
+ None,
+ "first"
+),
register_check_parameters(
subgroup_storage,
"fc_port",