#!/usr/bin/env python3
# Copyright (C) 2019 Checkmk GmbH - License: GNU General Public License v2
# This file is part of Checkmk (https://checkmk.com). It is subject to the terms and
# conditions defined in the file COPYING, which is part of this source code package.

# Example output from agent:
# <<<arcserve_backup>>>
#
# Job:
# 3960
# Beschreibung: Tagessicherung staging. (27.01.2014)
# 255.154 Verzeichnis(se) 1.400.060 Datei(en) (388,38 GB) auf Datentr�ger gesichert.
# Vorgang Sichern erfolgreich
#
# Job:
# 3954
# Beschreibung: Wochensicherung staging. (24.01.2014)
# 340.611 Verzeichnis(se) 1.726.321 Datei(en) (446,52 GB) auf Datentr�ger gesichert.
# Vorgang Sichern erfolgreich
#
# <<<arcserve_backup>>>
# Job:
# 3972
# Beschreibung: Tagessicherung staging. (30.01.2014)
# 255.641 Verzeichnis(se) 1.405.125 Datei(en) (389,27 GB) auf Datentr�ger gesichert.
# Vorgang Sichern unvollst�ndig.Anzahl an Fehlern/Warnungen: 0/1
#
# Job:
# 3954
# Beschreibung: Wochensicherung staging. (24.01.2014)
# 340.611 Verzeichnis(se) 1.726.321 Datei(en) (446,52 GB) auf Datentr�ger gesichert.
# Vorgang Sichern erfolgreich
#
# <<<arcserve_backup>>>
# Job:
# 3976
# Beschreibung: Wochensicherung staging. (31.01.2014)
# 341.092 Verzeichnis(se) 1.731.713 Datei(en) (447,42 GB) auf Datentr�ger gesichert.
# Vorgang Sichern konnte nicht durchgef�hrt werden.Anzahl an Fehlern/Warnungen: 1/0
#
# Job:
# 3972
# Beschreibung: Tagessicherung staging. (30.01.2014)
# 255.641 Verzeichnis(se) 1.405.125 Datei(en) (389,27 GB) auf Datentr�ger gesichert.
# Vorgang Sichern unvollst�ndig.Anzahl an Fehlern/Warnungen: 0/1

# parses info in a structure like
# parsed = {
#     'Tagessicherung staging': { 'dirs'  : 255641,
#                                 'files' : 1405125,
#                                 'result': 'Sichern unvollst\xc3\xa4ndig.Anzahl an Fehlern/Warnungen: 0/1',
#                                 'size'  : 417975479828},
#     'Wochensicherung staging': {'dirs'  : 341092,
#                                 'files' : 1731713,
#                                 'result': 'Sichern konnte nicht durchgef\xc3\xbchrt werden.Anzahl an Fehlern/Warnungen: 1/0',
#                                 'size'  : 480413566894}}


# mypy: disable-error-code="var-annotated"

from cmk.base.check_api import LegacyCheckDefinition
from cmk.base.config import check_info

from cmk.agent_based.v2 import render


def parse_arcserve_backup(info):
    unit_factor = {"kb": 1024, "mb": 1024**2, "gb": 1024**3, "tb": 1024**4}
    parsed: dict[str, str | int | dict] = {}
    for line in info:
        if line[0] == "Beschreibung:":
            backup_id = " ".join(line[1:-1])
            if backup_id[-1] == ".":
                backup_id = backup_id[0:-1]
                backup: dict[str, str | int] = {}
                parsed[backup_id] = backup
        elif (
            len(line) > 5
            and line[1] == "Verzeichnis(se)"
            and line[3] == "Datei(en)"
            and line[5][-1] == ")"
        ):
            dirs = int(line[0].replace(".", ""))
            files = int(line[2].replace(".", ""))
            unit = line[5].replace(")", "").lower()
            size = int(float(line[4].replace("(", "").replace(",", ".")) * unit_factor[unit])
            backup["dirs"] = dirs
            backup["files"] = files
            backup["size"] = size
        elif len(line) > 1 and line[0] == "Vorgang":
            result = " ".join(line[1:])
            backup["result"] = result
    return parsed


def inventory_arcserve_backup(section):
    inventory = []
    for backup in section:
        inventory.append((backup, None))
    return inventory


def check_arcserve_backup(item, _no_params, section):  # pylint: disable=too-many-branches
    if item not in section:
        return 3, "Backup %s not found in agent output" % item

    message = ""
    perfdata = []

    # directories
    if "dirs" in section[item]:
        dirs = section[item]["dirs"]
        message += "%s directories" % section[item]["dirs"]
    else:
        dirs = 0
    perfdata.append(("dirs", dirs))

    # files
    if "files" in section[item]:
        if message != "":
            message += ", "
        files = section[item]["files"]
        message += "%s files" % section[item]["files"]
    else:
        files = 0
    perfdata.append(("files", files))

    # size
    if "size" in section[item]:
        if message != "":
            message += ", "
        size = section[item]["size"]
        message += "Size: %s" % render.bytes(section[item]["size"])
    else:
        size = 0
    perfdata.append(("size", size))

    # result
    if message != "":
        message += ", "

    if section[item]["result"].startswith("Sichern erfolgreich"):
        status = 0
    elif section[item]["result"].startswith("Sichern unvollst"):
        status = 1
    elif section[item]["result"].startswith("Sichern konnte nicht durchgef"):
        status = 2
    else:
        message += "unknown Result: %s" % section[item]["result"]
        return 3, message, perfdata

    message += "Result: %s" % section[item]["result"]

    return status, message, perfdata


check_info["arcserve_backup"] = LegacyCheckDefinition(
    service_name="Arcserve Backup %s",
    parse_function=parse_arcserve_backup,
    discovery_function=inventory_arcserve_backup,
    check_function=check_arcserve_backup,
)
