#!/usr/bin/python
# -*- encoding: utf-8; py-indent-offset: 4 -*-
# +------------------------------------------------------------------+
# |             ____ _               _        __  __ _  __           |
# |            / ___| |__   ___  ___| | __   |  \/  | |/ /           |
# |           | |   | '_ \ / _ \/ __| |/ /   | |\/| | ' /            |
# |           | |___| | | |  __/ (__|   <    | |  | | . \            |
# |            \____|_| |_|\___|\___|_|\_\___|_|  |_|_|\_\           |
# |                                                                  |
# | Copyright Mathias Kettner 2014             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.

def inventory_cmciii_lcp_waterin(info):
    if info:
        return [( None, None )]

def extract_temps(liste):
    miste = []
    for l in liste:
        miste.append(float(l.split(" ")[0]))
    return miste

def check_cmciii_lcp_waterin(item, params, info):
    limits = ()
    unit_desc, unit_status, desc = info[0][0:3]
    limits  = extract_temps(info[0][3:8])
    temp = limits.pop(0)
    status = info[0][9]

    state = 0
    sym = ""
    if status.lower() != "ok" or unit_status.lower() != "ok":
        if status.lower() in ( "ok", "warning" ) and \
                unit_status.lower() in  ( "ok", "warning" ):
            state = 1
        else:
            state = 2
    if temp < limits[3] or temp > limits[0] :
        state = 2
        sym = "(!!)"
    elif temp < limits[2] or temp > limits[1]:
        state = max(state, 1)
        sym = "(!)"
    else:
        state = max(state, 0)

    info_text = "%s %s, %s %s, Temperature: %.1f°C%s" \
            % (unit_desc, unit_status, desc, status, temp, sym)

    levels_text = ", lowcrit/lowwarn/highwarn/highcrit: %.1f/%.1f/%.1f/%.1f" \
            % ( limits[3], limits[2], limits[1], limits[0] )

    perfdata = [ ("temp", temp, str(limits[2])+":"+str(limits[1]), str(limits[3])+":"+str(limits[0]), 0 ) ]

    return (state, info_text + levels_text, perfdata)

check_info['cmciii_lcp_waterin'] = {
    "check_function"      : check_cmciii_lcp_waterin,
    "inventory_function"  : inventory_cmciii_lcp_waterin,
    "has_perfdata"        : True,
    "service_description" : "LCP Fanunit Water IN",
    "snmp_scan_function"  : lambda oid: oid(".1.3.6.1.2.1.1.1.0").startswith("Rittal LCP") and \
                                oid(".1.3.6.1.4.1.2606.7.4.2.2.1.3.2.6").startswith("Air.Temperature.DescName"),
    "snmp_info"           : ( '.1.3.6.1.4.1.2606.7.4.2.2.1.10.2', [59, 62] + range(64,72) ),
}
