Proper State Monitoring

This commit is contained in:
Rosiak
2016-02-26 23:40:34 +01:00
parent d0f844e776
commit 928fd70ced
4 changed files with 118 additions and 6 deletions

View File

@@ -2,6 +2,10 @@
$sensors = dbFetchRows('SELECT * FROM `sensors` WHERE `sensor_class` = ? AND device_id = ? ORDER BY `poller_type`, `sensor_oid`, `sensor_index`', array($sensor_class, $device['device_id']));
if ($sensor_class == 'state') {
$sensors = dbFetchRows('SELECT * FROM `sensors` LEFT JOIN `sensors_to_state_indexes` ON sensors_to_state_indexes.sensor_id = sensors.sensor_id LEFT JOIN state_indexes ON state_indexes.state_index_id = sensors_to_state_indexes.state_index_id WHERE `sensor_class` = ? AND device_id = ? ORDER BY `poller_type`, `sensor_index` ', array($sensor_class, $device['device_id']));
}
if (count($sensors)) {
echo '<div class="container-fluid ">
<div class="row">
@@ -12,6 +16,11 @@ if (count($sensors)) {
echo ' </div>
<table class="table table-hover table-condensed table-striped">';
foreach ($sensors as $sensor) {
$state_translation = array();
if (!empty($sensor['state_index_id'])) {
$state_translation = dbFetchRows('SELECT * FROM `state_translations` WHERE `state_index_id` = ? AND `state_value` = ? ', array($sensor['state_index_id'], $sensor['sensor_current']));
}
if (!isset($sensor['sensor_current'])) {
$sensor['sensor_current'] = 'NaN';
}
@@ -51,12 +60,36 @@ if (count($sensors)) {
$sensor_minigraph = generate_lazy_graph_tag($graph_array);
$sensor['sensor_descr'] = truncate($sensor['sensor_descr'], 48, '');
echo '<tr>
<td>'.overlib_link($link, shorten_interface_type($sensor['sensor_descr']), $overlib_content).'</td>
<td>'.overlib_link($link, $sensor_minigraph, $overlib_content).'</td>
<td>'.overlib_link($link, '<span '.($sensor['sensor_current'] < $sensor['sensor_limit_low'] || $sensor['sensor_current'] > $sensor['sensor_limit'] ? "style='color: red'" : '').'>'.$sensor['sensor_current'].$sensor_unit.'</span>', $overlib_content).'</td>
</tr>';
if (!empty($state_translation['0']['state_descr'])) {
$state_style="";
switch ($state_translation['state_generic_value']) {
case 0: // OK
$state_style="class='label label-success'";
break;
case 1: // Warning
$state_style="class='label label-warning'";
break;
case 2: // Critical
$state_style="class='label label-danger'";
break;
case 3: // Unknown
default:
$state_style="class='label label-default'";
break;
}
echo '<tr>
<td>'.overlib_link($link, shorten_interface_type($sensor['sensor_descr']), $overlib_content).'</td>
<td>'.overlib_link($link, $sensor_minigraph, $overlib_content).'</td>
<td>'.overlib_link($link, '<span '.$state_style.'>'.$state_translation['0']['state_descr'].'</span>', $overlib_content).'</td>
</tr>';
}
else {
echo '<tr>
<td>'.overlib_link($link, shorten_interface_type($sensor['sensor_descr']), $overlib_content).'</td>
<td>'.overlib_link($link, $sensor_minigraph, $overlib_content).'</td>
<td>'.overlib_link($link, '<span '.($sensor['sensor_current'] < $sensor['sensor_limit_low'] || $sensor['sensor_current'] > $sensor['sensor_limit'] ? "style='color: red'" : '').'>'.$sensor['sensor_current'].$sensor_unit.'</span>', $overlib_content).'</td>
</tr>';
}
}//end foreach
echo '</table>';