/usr/share/check_mk/checks/fjdarye.include is in check-mk-server 1.2.2p3-1.
This file is owned by root:root, with mode 0o755.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 | #!/usr/bin/python
# -*- encoding: utf-8; py-indent-offset: 4 -*-
# +------------------------------------------------------------------+
# | ____ _ _ __ __ _ __ |
# | / ___| |__ ___ ___| | __ | \/ | |/ / |
# | | | | '_ \ / _ \/ __| |/ / | |\/| | ' / |
# | | |___| | | | __/ (__| < | | | | . \ |
# | \____|_| |_|\___|\___|_|\_\___|_| |_|_|\_\ |
# | |
# | Copyright Mathias Kettner 2013 mk@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.
# check_mk plugin to monitor Fujitsu storage systems supporting FJDARY-E60.MIB or FJDARY-E100.MIB
# Copyright (c) 2012 FuH Entwicklungsgesellschaft mbH, Umkirch, Germany. All rights reserved.
# Author: Philipp Hoefflin, 2012, hoefflin+cmk@fuh-e.de
# generic data structure widely used in the FJDARY-Mibs:
# <oid>
# <oid>.1: Index
# <oid>.3: Status
# the latter can be one of the following:
fjdarye_item_status = { 1: 'normal', 2: 'alarm', 3: 'warning',
4: 'invalid', 5: 'maintenance', 6: 'undefined' }
# generic inventory item - status other than 'invalid' is ok for inventory
def inventory_fjdarye_item(info):
return [ (int(index), '', None) for index, status in info if int(status) != 4 ]
# generic check_function returning the nagios-code and the status text
def check_fjdarye_item(index, _no_param, info):
for line in info:
if int(line[0]) == index:
status = int(line[1])
if status == 1:
code = 0
elif status == 3:
code = 1
else:
code = 2
return(code, "%s - Status is %s" % (nagios_state_names[code], fjdarye_item_status[status]))
return(3, 'UNKNOWN - No status for item %d present' % index )
# --------------------------------------------------------------------------------
# disk checks:
# available(1), broken(2), notavailable(3), notsupported(4), present(5),
# readying(6), recovering(7), partbroken(64), spare(65), formatting(66),
# unformatted(67), notexist(68), copying(69)
fjdarye_disks_status = { 1: 'available', 2: 'broken', 3: 'notavailable',
4: 'notsupported', 5: 'present', 6: 'readying', 7: 'recovering',
64: 'partbroken', 65: 'spare', 66: 'formatting', 67: 'unformated',
68: 'notexist', 69: 'copying' }
# 1. Summary version of check -> all disks into one service
def fjdarye_disks_summary(info):
# compute the number of disks in each state.
states = {}
for index, state in info:
state = int(state)
statename = fjdarye_disks_status[state]
if state != 3:
states[statename] = states.get(statename, 0) + 1
return states
def inventory_fjdarye_disks_summary(info):
current_state = fjdarye_disks_summary(info)
if len(current_state) > 0:
return [ (None, current_state) ]
def fjdarye_disks_printstates(state):
return ", ".join(["%s: %s" % (s,c) for (s,c) in state.items()])
def check_fjdarye_disks_summary(index, expected_status, info):
current_state = fjdarye_disks_summary(info)
infotext = " - " + fjdarye_disks_printstates(current_state)
if current_state == expected_status:
return (0, "OK" + infotext)
result = 1
for ename, ecount in expected_status.items():
if current_state.get(ename, 0) < ecount:
result = 2
break
return (result, nagios_state_names[result] + infotext + \
" (expected was: %s)" % fjdarye_disks_printstates(expected_status))
# --------------------------------------------------------------------------------
# 2. Single disk version of check -> one check for each disk
def inventory_fjdarye_disks(info):
return [ (int(index), repr(fjdarye_disks_status[int(status)])) for index, status in info if int(status) != 3 ]
def check_fjdarye_disks(index, expected_status, info):
for line in info:
if int(line[0]) == index:
status = fjdarye_disks_status[int(line[1])]
if status == expected_status:
return (0, "OK - Status is %s" % status)
else:
return (2, "CRIT - Status is %s (expected status is %s)" % (status, expected_status))
return (3, "UNKNOWN - No status for disk number %d present" % index)
|