/****************************************************************************** * Icinga 2 * * Copyright (C) 2012-2018 Icinga Development Team (https://icinga.com/) * * * * This program 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; either version 2 * * of the License, or (at your option) any later version. * * * * This program is distributed in the hope that it will be useful, * * but WITHOUT ANY WARRANTY; without even the implied warranty of * * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * * GNU General Public License for more details. * * * * You should have received a copy of the GNU General Public License * * along with this program; if not, write to the Free Software Foundation * * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA. * ******************************************************************************/ if (!globals.contains("NscpPath")) { NscpPath = dirname(msi_get_component_path("{5C45463A-4AE9-4325-96DB-6E239C034F93}")) } object CheckCommand "nscp-local" { command = [ NscpPath + "\\nscp.exe", "client" ] arguments = { "--log" = { value = "$nscp_log_level$" description = "The log level to use" } "--load-all" = { set_if ="$nscp_load_all$" description = "Load all plugins (currently only used with generate)" } "--module" = { value = "$nscp_modules$" description = "Specify which NSClient++ modules are required. 'nscp client' just needs 'CheckSystem' by default." repeat_key = true } "-q" = { value = "$nscp_query$" description = "Run a query with a given name" required = true } "-b" = { set_if = "$nscp_boot$" description = "Boot the client before executing command (similar as running the command from test mode)" } "-a" = { value = "$nscp_arguments$" repeat_key = true description = "List of arguments (arguments gets -- prefixed automatically (--argument foo=bar is the same as setting '--foo bar')" } "--show-all" = { set_if = "$nscp_showall$" description = "" } } vars.nscp_log_level = "critical" vars.nscp_load_all = false vars.nscp_boot = true vars.nscp_showall = false vars.nscp_modules = [ "CheckSystem" ] } object CheckCommand "nscp-local-cpu" { import "nscp-local" arguments += { "--time" = { value = "$nscp_cpu_time$" repeat_key = true description = "The time to check" } "--warning" = { value = "load>$nscp_cpu_warning$" } "--critical" = { value = "load>$nscp_cpu_critical$" } "-a" = { value = "$nscp_cpu_arguments$" repeat_key = true } } vars.nscp_query = "check_cpu" vars.nscp_showall = "$nscp_cpu_showall$" vars.nscp_cpu_time = [ "1m", "5m", "15m" ] vars.nscp_cpu_showall = true vars.nscp_cpu_warning = 80 vars.nscp_cpu_critical = 90 } object CheckCommand "nscp-local-memory" { import "nscp-local" arguments += { "--type=committed" = { set_if = "$nscp_memory_committed$" description = "Total memory (RAM+PAGE)" } "--type=physical" = { set_if = "$nscp_memory_physical$" description = "Physical memory (RAM)" } "--warning" = { value = "$nscp_memory_op$ $nscp_memory_warning$" } "--critical" = { value = "$nscp_memory_op$ $nscp_memory_critical$" } "-a" = { value = "$nscp_memory_arguments$" repeat_key = true } } vars.nscp_query = "check_memory" vars.nscp_showall = "$nscp_memory_showall$" vars.nscp_memory_op = {{ if (!macro("$nscp_memory_free$")) { return "used >" } else { return "free <" } }} vars.nscp_memory_committed = false vars.nscp_memory_physical = true vars.nscp_memory_free = true vars.nscp_memory_warning = {{ if (!macro("$nscp_memory_free$")) { return 80 } else { return 20 } }} vars.nscp_memory_critical = {{ if (!macro("$nscp_memory_free$")) { return 90 } else { return 10 } }} vars.nscp_memory_showall = false } object CheckCommand "nscp-local-os-version" { import "nscp-local" vars.nscp_query = "check_os_version" } object CheckCommand "nscp-local-pagefile" { import "nscp-local" vars.nscp_query = "check_pagefile" } object CheckCommand "nscp-local-process" { import "nscp-local" vars.nscp_query = "check_process" } object CheckCommand "nscp-local-service" { import "nscp-local" arguments += { "--service" = { value = "$nscp_service_name$" repeat_key = true } "--ok" = { value = "$nscp_service_otype$='$nscp_service_ok$'" } "--warning" = { value = "$nscp_service_wtype$='$nscp_service_warning$'" } "--critical" = { value = "$nscp_service_ctype$='$nscp_service_critical$'" } "-a" = { value = "$nscp_service_arguments$" repeat_key = true } } vars.nscp_query = "check_service" vars.nscp_showall = "$nscp_service_showall$" vars.nscp_service_showall = true vars.nscp_service_type = "state" vars.nscp_service_otype = vars.nscp_service_type vars.nscp_service_wtype = vars.nscp_service_type vars.nscp_service_ctype = vars.nscp_service_type } object CheckCommand "nscp-local-uptime" { import "nscp-local" vars.nscp_query = "check_uptime" } object CheckCommand "nscp-local-version" { import "nscp-local" vars.nscp_query = "check_version" vars.nscp_modules = [ "CheckHelpers" ] } object CheckCommand "nscp-local-disk" { import "nscp-local" arguments += { "--drive" = { value = "$nscp_disk_drive$" repeat_key = true } "--exclude" = { value = "$nscp_disk_exclude$" repeat_key = true } "--warning" = { value = "$nscp_disk_op$ $nscp_disk_warning$" } "--critical" = { value = "$nscp_disk_op$ $nscp_disk_critical$" } "-a" = { value = "$nscp_disk_arguments$" repeat_key = true } } vars.nscp_query = "check_drivesize" vars.nscp_showall = "$nscp_disk_showall$" vars.nscp_disk_op = {{ if (!macro("$nscp_disk_free$")) { return "used >" } else { return "free <" } }} vars.nscp_disk_showall = true vars.nscp_disk_free = false vars.nscp_disk_warning = {{ if (!macro("$nscp_disk_free$")) { return 80 } else { return 20 } }} vars.nscp_disk_critical = {{ if (!macro("$nscp_disk_free$")) { return 90 } else { return 10 } }} vars.nscp_modules = [ "CheckDisk" ] } object CheckCommand "nscp-local-counter" { import "nscp-local" arguments += { "--counter" = { value = "$nscp_counter_name$" repeat_key = true } "--warning" = { value = "value $nscp_counter_op$ $nscp_counter_warning$" } "--critical" = { value = "value $nscp_counter_op$ $nscp_counter_critical$" } "--perf-syntax" = { value = "$nscp_counter_perfsyntax$" } "-a" = { value = "$nscp_counter_arguments$" repeat_key = true } } vars.nscp_counter_op = {{ if (!macro("$nscp_counter_less$")) { return ">" } else { return "<" } }} vars.nscp_query = "check_pdh" vars.nscp_showall = "$nscp_counter_showall$" vars.nscp_counter_less = false vars.nscp_counter_perfsyntax = "$nscp_counter_name$" } object CheckCommand "nscp-local-tasksched" { import "nscp-local" arguments += { "--filter" = { set_if = {{ var scheduler_name = macro("$nscp_tasksched_name$") if (len(scheduler_name) > 0 ) { return true } else { return false } }} value = "title='$nscp_tasksched_name$'" description = "Name of the task to check." } "--folder" = { value = "$nscp_tasksched_folder$" description = "The folder in which the tasks to check reside." } "--hidden" = { set_if = "$nscp_tasksched_hidden$" description = "Look for hidden tasks." } "--recursive" = { value = "$nscp_tasksched_recursive$" description = "Recurse sub folder (defaults to true)." } "--warning" = { value = "$nscp_tasksched_warning$" description = "Filter which marks items which generates a warning state." } "--critical" = { value = "$nscp_tasksched_critical$" description = "Filter which marks items which generates a critical state." } "--empty-state" = { value = "$nscp_tasksched_emptystate$" description = "Return status to use when nothing matched filter." } "--perf-syntax" = { value = "$nscp_tasksched_perfsyntax$" description = "Performance alias syntax." } "--detail-syntax" = { value = "$nscp_tasksched_detailsyntax$" description = "Detail level syntax." } "-a" = { value = "$nscp_tasksched_arguments$" repeat_key = true } } vars.nscp_modules = "CheckTaskSched" vars.nscp_query = "check_tasksched" vars.nscp_showall = "$nscp_tasksched_showall$" vars.nscp_tasksched_recursive = true vars.nscp_tasksched_perfsyntax = "%(title)" vars.nscp_tasksched_detailsyntax = "%(folder)/%(title): %(exit_code) != 0" vars.nscp_tasksched_warning = "exit_code != 0" vars.nscp_tasksched_critical = "exit_code < 0" }