Newer
Older
#!/usr/bin/env php
<?php
/**
* Nagios compatible script to export data from the monitor page.
*
* Outputs a single line like: `WARNING: (ok: 12, info: system_update, warning: sys_log)`
*
* Usage:
*
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
* `command[check_ispconfig]=/usr/bin/sudo /usr/local/ispconfig/server/check_ispconfig.php`
*
* /etc/sudoers.d/ispconfig:
* ```
* Cmnd_Alias CHECK_ISPCONFIG = /usr/local/ispconfig/server/check_ispconfig.php
*
* nagios ALL = NOPASSWD : CHECK_ISPCONFIG
* ```
*/
define('SCRIPT_PATH', dirname($_SERVER["SCRIPT_FILENAME"]));
require SCRIPT_PATH."/lib/config.inc.php";
require SCRIPT_PATH."/lib/app.inc.php";
ini_set('error_reporting', E_ALL & ~E_NOTICE);
$server_state = 'ok';
$retval = 0;
$server_states = array();
$state_list = array();
$records = $app->dbmaster->queryAllRecords("SELECT DISTINCT type, state FROM monitor_data
WHERE server_id = ? AND state != 'no_state'", $conf['server_id']);
foreach($records as $record) {
$server_states[$record['state']][] = $record['type'];
}
foreach ($server_states as $state => $data) {
if ($state == 'ok') {
$state_list[] = "$state: " . count($data);
}
else {
$state_list[] = "$state: " . join(', ', $data);
}
}
if (empty($server_states)) {
$server_state = 'unknown';
$retval = 3;
}
elseif (is_array($server_states['critical']) && count($server_states['critical']) > 0 || is_array($server_states['error']) && count($server_states['error']) > 0) {
$server_state = 'critical';
$retval = 2;
}
elseif ($server_states['warning'] > 0) {
$server_state = 'warning';
$retval = 1;
}
$status_line = strtoupper($server_state) . ': (' . join(', ', $state_list) . ')';
echo $status_line . PHP_EOL;
exit($retval);