2 # -*- encoding: utf-8; py-indent-offset: 4 -*-
3 # +------------------------------------------------------------------+
4 # | ____ _ _ __ __ _ __ |
5 # | / ___| |__ ___ ___| | __ | \/ | |/ / |
6 # | | | | '_ \ / _ \/ __| |/ / | |\/| | ' / |
7 # | | |___| | | | __/ (__| < | | | | . \ |
8 # | \____|_| |_|\___|\___|_|\_\___|_| |_|_|\_\ |
10 # | Copyright Mathias Kettner 2015 mk@mathias-kettner.de |
11 # +------------------------------------------------------------------+
13 # This file is part of Check_MK.
14 # The official homepage is at http://mathias-kettner.de/check_mk.
16 # check_mk is free software; you can redistribute it and/or modify it
17 # under the terms of the GNU General Public License as published by
18 # the Free Software Foundation in version 2. check_mk is distributed
19 # in the hope that it will be useful, but WITHOUT ANY WARRANTY; with-
20 # out even the implied warranty of MERCHANTABILITY or FITNESS FOR A
21 # PARTICULAR PURPOSE. See the GNU General Public License for more de-
22 # tails. You should have received a copy of the GNU General Public
23 # License along with GNU Make; see the file COPYING. If not, write
24 # to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
25 # Boston, MA 02110-1301 USA.
28 def extract_cmciii_lcp_temps(liste
):
32 miste
.append(float(l
.split(" ")[0]))
34 # Dirty hack fix for a dirty check. Ignore all values that can not be
36 # sh: introduced by lm. But why?
41 def translate_cmciii_lcp_status(status
):
42 statusl
= status
.lower()
45 elif statusl
== "warning":
50 def inventory_cmciii_lcp_fanunit(zone
, direction
, info
):
51 # these checks are considered obsolete as temp_in_out covers the same
55 # return [ ("%s LCP Fanunit %s Average" % (zone, direction), {}) ]
58 def check_cmciii_lcp_fanunit(item
, params
, info
):
61 _unit_desc
, unit_status
, _desc
, status
= info
[0][1:4]
62 temps
= extract_cmciii_lcp_temps(info
[0][4:])
64 status
, message
, perfdata
= check_temperature(
67 "cmciii_lcp_fanunit_%s" % item
,
68 dev_status
=translate_cmciii_lcp_status(unit_status
),
69 dev_status_name
="Unit: %s" % unit_status
,
70 dev_levels
=(temps
[2], temps
[3]),
71 dev_levels_lower
=(temps
[1], temps
[0]))
73 output_unit
= params
.get("output_unit", "c")
75 message
+= " ; Top/Mid/Bottom: %s/%s/%s" %\
76 (render_temp(temps
[5], output_unit
),
77 render_temp(temps
[6], output_unit
),
78 render_temp(temps
[7], output_unit
))
80 return status
, message
, perfdata
83 def snmp_scan_cmciii_lcp_fanunit(oid
):
84 return oid(".1.3.6.1.2.1.1.1.0").startswith("Rittal LCP") and \
85 oid(".1.3.6.1.4.1.2606.7.4.2.2.1.3.2.6").startswith("Air.Temperature.DescName")