2012-09-19 Sergio Martin <sergio.martin@artica.es>
* include/functions_graph.php include/graphs/functions_flot.php include/graphs/flot/pandora.flot.js include/graphs/fgraph.php operation/agentes/stat_win.php: Fix several bugs of the event graph and event special features on flot graphs when compare periods git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6989 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
This commit is contained in:
parent
31b78d9121
commit
f848544e6f
|
@ -1,3 +1,13 @@
|
||||||
|
2012-09-19 Sergio Martin <sergio.martin@artica.es>
|
||||||
|
|
||||||
|
* include/functions_graph.php
|
||||||
|
include/graphs/functions_flot.php
|
||||||
|
include/graphs/flot/pandora.flot.js
|
||||||
|
include/graphs/fgraph.php
|
||||||
|
operation/agentes/stat_win.php: Fix several bugs of the
|
||||||
|
event graph and event special features on flot graphs when
|
||||||
|
compare periods
|
||||||
|
|
||||||
2012-09-19 Miguel de Dios <miguel.dedios@artica.es>
|
2012-09-19 Miguel de Dios <miguel.dedios@artica.es>
|
||||||
|
|
||||||
* extensions/resource_registration.php, extensions/system_info.php,
|
* extensions/resource_registration.php, extensions/system_info.php,
|
||||||
|
|
|
@ -29,7 +29,7 @@ function grafico_modulo_sparse_data_chart (&$chart, &$chart_data_extra, &$long_i
|
||||||
$data, $data_i, $previous_data, $resolution, $interval, $period, $datelimit,
|
$data, $data_i, $previous_data, $resolution, $interval, $period, $datelimit,
|
||||||
$projection, $avg_only = false, $uncompressed_module = false,
|
$projection, $avg_only = false, $uncompressed_module = false,
|
||||||
$show_events = false, $show_alerts = false, $show_unknown = false, $baseline = false,
|
$show_events = false, $show_alerts = false, $show_unknown = false, $baseline = false,
|
||||||
$baseline_data = array(), $events = array(), $series_suffix = '') {
|
$baseline_data = array(), $events = array(), $series_suffix = '', $start_unknown = false) {
|
||||||
|
|
||||||
global $config;
|
global $config;
|
||||||
global $chart_extra_data;
|
global $chart_extra_data;
|
||||||
|
@ -41,7 +41,7 @@ function grafico_modulo_sparse_data_chart (&$chart, &$chart_data_extra, &$long_i
|
||||||
$event_i = 0;
|
$event_i = 0;
|
||||||
|
|
||||||
// Is unknown flag
|
// Is unknown flag
|
||||||
$is_unknown = false;
|
$is_unknown = $start_unknown;
|
||||||
|
|
||||||
// Calculate chart data
|
// Calculate chart data
|
||||||
for ($i = 0; $i < $resolution; $i++) {
|
for ($i = 0; $i < $resolution; $i++) {
|
||||||
|
@ -103,6 +103,7 @@ function grafico_modulo_sparse_data_chart (&$chart, &$chart_data_extra, &$long_i
|
||||||
}
|
}
|
||||||
$event_i++;
|
$event_i++;
|
||||||
}
|
}
|
||||||
|
|
||||||
if($is_unknown) {
|
if($is_unknown) {
|
||||||
$unknown_value++;
|
$unknown_value++;
|
||||||
}
|
}
|
||||||
|
@ -150,16 +151,29 @@ function grafico_modulo_sparse_data_chart (&$chart, &$chart_data_extra, &$long_i
|
||||||
if (!$projection){
|
if (!$projection){
|
||||||
$timestamp = $timestamp_short;
|
$timestamp = $timestamp_short;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Data
|
// Data
|
||||||
if($show_events) {
|
if($show_events) {
|
||||||
$chart[$timestamp]['event'.$series_suffix] = $event_value;
|
if(!isset($chart[$timestamp]['event'.$series_suffix])) {
|
||||||
|
$chart[$timestamp]['event'.$series_suffix] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
$chart[$timestamp]['event'.$series_suffix] += $event_value;
|
||||||
$series_type['event'.$series_suffix] = 'points';
|
$series_type['event'.$series_suffix] = 'points';
|
||||||
}
|
}
|
||||||
if($show_alerts) {
|
if($show_alerts) {
|
||||||
$chart[$timestamp]['alert'.$series_suffix] = $alert_value;
|
if(!isset($chart[$timestamp]['alert'.$series_suffix])) {
|
||||||
|
$chart[$timestamp]['alert'.$series_suffix] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
$chart[$timestamp]['alert'.$series_suffix] += $alert_value;
|
||||||
$series_type['alert'.$series_suffix] = 'points';
|
$series_type['alert'.$series_suffix] = 'points';
|
||||||
}
|
}
|
||||||
if($show_unknown) {
|
if($show_unknown) {
|
||||||
|
if(!isset($chart[$timestamp]['unknown'.$series_suffix])) {
|
||||||
|
$chart[$timestamp]['unknown'.$series_suffix] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
$chart[$timestamp]['unknown'.$series_suffix] = $unknown_value;
|
$chart[$timestamp]['unknown'.$series_suffix] = $unknown_value;
|
||||||
$series_type['unknown'.$series_suffix] = 'area';
|
$series_type['unknown'.$series_suffix] = 'area';
|
||||||
}
|
}
|
||||||
|
@ -217,10 +231,10 @@ function grafico_modulo_sparse_data_chart (&$chart, &$chart_data_extra, &$long_i
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!empty($event_ids)) {
|
if(!empty($event_ids)) {
|
||||||
$chart_extra_data[count($chart)-1]['events'.$series_suffix] = implode(',',$event_ids);
|
$chart_extra_data[count($chart)-1]['events'] = implode(',',$event_ids);
|
||||||
}
|
}
|
||||||
if(!empty($alert_ids)) {
|
if(!empty($alert_ids)) {
|
||||||
$chart_extra_data[count($chart)-1]['alerts'.$series_suffix] = implode(',',$alert_ids);
|
$chart_extra_data[count($chart)-1]['alerts'] = implode(',',$alert_ids);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -248,10 +262,9 @@ function grafico_modulo_sparse_data ($agent_module_id, $period, $show_events,
|
||||||
$color = array();
|
$color = array();
|
||||||
$legend = array();
|
$legend = array();
|
||||||
$long_index = array();
|
$long_index = array();
|
||||||
$series_type = array();
|
|
||||||
$chart_extra_data = array();
|
|
||||||
$warning_min = 0;
|
$warning_min = 0;
|
||||||
$critical_min = 0;
|
$critical_min = 0;
|
||||||
|
$start_unknown = false;
|
||||||
|
|
||||||
// Set variables
|
// Set variables
|
||||||
if ($date == 0) $date = get_system_time();
|
if ($date == 0) $date = get_system_time();
|
||||||
|
@ -279,6 +292,16 @@ function grafico_modulo_sparse_data ($agent_module_id, $period, $show_events,
|
||||||
"utimestamp < $date",
|
"utimestamp < $date",
|
||||||
'order' => 'utimestamp ASC'),
|
'order' => 'utimestamp ASC'),
|
||||||
array ('id_evento', 'evento', 'utimestamp', 'event_type'));
|
array ('id_evento', 'evento', 'utimestamp', 'event_type'));
|
||||||
|
|
||||||
|
// Get the last event after inverval to know if graph start on unknown
|
||||||
|
$prev_event = db_get_row_filter ('tevento',
|
||||||
|
array ('id_agentmodule' => $agent_module_id,
|
||||||
|
"utimestamp <= $datelimit",
|
||||||
|
'order' => 'utimestamp DESC'));
|
||||||
|
if(isset($prev_event['event_type']) && $prev_event['event_type'] == 'going_unknown') {
|
||||||
|
$start_unknown = true;
|
||||||
|
}
|
||||||
|
|
||||||
if ($events === false) {
|
if ($events === false) {
|
||||||
$events = array ();
|
$events = array ();
|
||||||
}
|
}
|
||||||
|
@ -376,7 +399,7 @@ function grafico_modulo_sparse_data ($agent_module_id, $period, $show_events,
|
||||||
$data, $data_i, $previous_data, $resolution, $interval, $period, $datelimit,
|
$data, $data_i, $previous_data, $resolution, $interval, $period, $datelimit,
|
||||||
$projection, $avg_only, $uncompressed_module,
|
$projection, $avg_only, $uncompressed_module,
|
||||||
$show_events, $show_alerts, $show_unknown, $baseline,
|
$show_events, $show_alerts, $show_unknown, $baseline,
|
||||||
$baseline_data, $events, $series_suffix);
|
$baseline_data, $events, $series_suffix, $start_unknown);
|
||||||
|
|
||||||
// Return chart data and don't draw
|
// Return chart data and don't draw
|
||||||
if ($return_data == 1) {
|
if ($return_data == 1) {
|
||||||
|
@ -387,17 +410,16 @@ function grafico_modulo_sparse_data ($agent_module_id, $period, $show_events,
|
||||||
$min_value = round(reporting_get_agentmodule_data_min ($agent_module_id, $period, $date), 2);
|
$min_value = round(reporting_get_agentmodule_data_min ($agent_module_id, $period, $date), 2);
|
||||||
$max_value = round(reporting_get_agentmodule_data_max ($agent_module_id, $period, $date), 2);
|
$max_value = round(reporting_get_agentmodule_data_max ($agent_module_id, $period, $date), 2);
|
||||||
$avg_value = round(reporting_get_agentmodule_data_average ($agent_module_id, $period, $date), 2);
|
$avg_value = round(reporting_get_agentmodule_data_average ($agent_module_id, $period, $date), 2);
|
||||||
|
|
||||||
// Fix event and alert scale
|
// Fix event and alert scale
|
||||||
$event_max = $max_value * 1.05;
|
$event_max = $max_value * 1.05;
|
||||||
foreach ($chart as $timestamp => $chart_data) {
|
foreach ($chart as $timestamp => $chart_data) {
|
||||||
if ($show_events && $chart_data['event'.$series_suffix] > 0) {
|
if ($show_events && $chart_data['event'.$series_suffix] > 0) {
|
||||||
$chart[$timestamp]['event'.$series_suffix] = $event_max * 1.2;
|
$chart[$timestamp]['event'.$series_suffix] = $event_max * 1.2;
|
||||||
}
|
}
|
||||||
if ($show_alerts && $chart_data['alert'] > 0) {
|
if ($show_alerts && $chart_data['alert'.$series_suffix] > 0) {
|
||||||
$chart[$timestamp]['alert'.$series_suffix] = $event_max * 1.10;
|
$chart[$timestamp]['alert'.$series_suffix] = $event_max * 1.10;
|
||||||
}
|
}
|
||||||
if ($show_unknown && $chart_data['unknown'] > 0) {
|
if ($show_unknown && $chart_data['unknown'.$series_suffix] > 0) {
|
||||||
$chart[$timestamp]['unknown'.$series_suffix] = $event_max * 1.05;
|
$chart[$timestamp]['unknown'.$series_suffix] = $event_max * 1.05;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -427,16 +449,16 @@ function grafico_modulo_sparse_data ($agent_module_id, $period, $show_events,
|
||||||
$color['unit'.$series_suffix] = array('border' => null, 'color' => '#0097BC', 'alpha' => 10);
|
$color['unit'.$series_suffix] = array('border' => null, 'color' => '#0097BC', 'alpha' => 10);
|
||||||
|
|
||||||
if($show_events) {
|
if($show_events) {
|
||||||
$legend['event'.$series_suffix] = __('Events');
|
$legend['event'.$series_suffix_str] = __('Events').$series_suffix_str;
|
||||||
$chart_extra_data['legend_events'] = $legend['event'];
|
$chart_extra_data['legend_events'] = $legend['event'].$series_suffix_str;
|
||||||
}
|
}
|
||||||
if($show_alerts) {
|
if($show_alerts) {
|
||||||
$legend['alert'.$series_suffix] = __('Alerts');
|
$legend['alert'.$series_suffix] = __('Alerts').$series_suffix_str;
|
||||||
$chart_extra_data['legend_alerts'] = $legend['alert'];
|
$chart_extra_data['legend_alerts'] = $legend['alert'.$series_suffix_str];
|
||||||
}
|
}
|
||||||
if($show_unknown) {
|
if($show_unknown) {
|
||||||
$legend['unknown'.$series_suffix] = __('Unknown').$series_suffix_str;
|
$legend['unknown'.$series_suffix] = __('Unknown').$series_suffix_str;
|
||||||
$chart_extra_data['legend_unknown'] = $legend['unknown'];
|
$chart_extra_data['legend_unknown'] = $legend['unknown'.$series_suffix_str];
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!$avg_only){
|
if (!$avg_only){
|
||||||
|
@ -475,6 +497,7 @@ function grafico_modulo_sparse ($agent_module_id, $period, $show_events,
|
||||||
global $warning_min;
|
global $warning_min;
|
||||||
global $critical_min;
|
global $critical_min;
|
||||||
|
|
||||||
|
$series_suffix_str = '';
|
||||||
if($compare !== false) {
|
if($compare !== false) {
|
||||||
$series_suffix = '2';
|
$series_suffix = '2';
|
||||||
$series_suffix_str = ' ('.__('Previous').')';
|
$series_suffix_str = ' ('.__('Previous').')';
|
||||||
|
@ -492,11 +515,14 @@ function grafico_modulo_sparse ($agent_module_id, $period, $show_events,
|
||||||
$chart_prev = $chart;
|
$chart_prev = $chart;
|
||||||
$legend_prev = $legend;
|
$legend_prev = $legend;
|
||||||
$long_index_prev = $long_index;
|
$long_index_prev = $long_index;
|
||||||
|
$series_type_prev = $series_type;
|
||||||
|
$color_prev = $color;
|
||||||
break;
|
break;
|
||||||
case 'overlapped':
|
case 'overlapped':
|
||||||
// Store the chart calculated deleting index, because will be over the current period
|
// Store the chart calculated deleting index, because will be over the current period
|
||||||
$chart_prev = array_values($chart);
|
$chart_prev = array_values($chart);
|
||||||
$legend_prev = $legend;
|
$legend_prev = $legend;
|
||||||
|
$series_type_prev = $series_type;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -535,19 +561,19 @@ function grafico_modulo_sparse ($agent_module_id, $period, $show_events,
|
||||||
return area_graph($flash_chart, $chart, $width, $height/2, $color, $legend,
|
return area_graph($flash_chart, $chart, $width, $height/2, $color, $legend,
|
||||||
$long_index, ui_get_full_url("images/image_problem.opaque.png"), "", $unit, $homeurl,
|
$long_index, ui_get_full_url("images/image_problem.opaque.png"), "", $unit, $homeurl,
|
||||||
$water_mark, $config['fontpath'], $config['font_size'], $unit, $ttl,
|
$water_mark, $config['fontpath'], $config['font_size'], $unit, $ttl,
|
||||||
$series_type, $chart_extra_data, $warning_min, $critical_min, $adapt_key).
|
$series_type, $chart_extra_data, $warning_min, $critical_min, $adapt_key, false, $series_suffix_str).
|
||||||
'<br>'.
|
'<br>'.
|
||||||
area_graph($flash_chart, $chart_prev, $width, $height/2, $color, $legend_prev,
|
area_graph($flash_chart, $chart_prev, $width, $height/2, $color_prev, $legend_prev,
|
||||||
$long_index_prev, ui_get_full_url("images/image_problem.opaque.png"), "", $unit, $homeurl,
|
$long_index_prev, ui_get_full_url("images/image_problem.opaque.png"), "", $unit, $homeurl,
|
||||||
$water_mark, $config['fontpath'], $config['font_size'], $unit, $ttl,
|
$water_mark, $config['fontpath'], $config['font_size'], $unit, $ttl,
|
||||||
$series_type, $chart_extra_data, $warning_min, $critical_min, $adapt_key);
|
$series_type_prev, $chart_extra_data, $warning_min, $critical_min, $adapt_key, false, $series_suffix_str);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
// Color commented not to restrict serie colors
|
// Color commented not to restrict serie colors
|
||||||
return area_graph($flash_chart, $chart, $width, $height, $color, $legend,
|
return area_graph($flash_chart, $chart, $width, $height, $color, $legend,
|
||||||
$long_index, ui_get_full_url("images/image_problem.opaque.png"), "", $unit, $homeurl,
|
$long_index, ui_get_full_url("images/image_problem.opaque.png"), "", $unit, $homeurl,
|
||||||
$water_mark, $config['fontpath'], $config['font_size'], $unit, $ttl,
|
$water_mark, $config['fontpath'], $config['font_size'], $unit, $ttl,
|
||||||
$series_type, $chart_extra_data, $warning_min, $critical_min, $adapt_key);
|
$series_type, $chart_extra_data, $warning_min, $critical_min, $adapt_key, false, $series_suffix_str);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1968,18 +1994,21 @@ function fs_error_image () {
|
||||||
|
|
||||||
function grafico_modulo_boolean_data ($agent_module_id, $period, $show_events,
|
function grafico_modulo_boolean_data ($agent_module_id, $period, $show_events,
|
||||||
$unit_name, $show_alerts, $avg_only = 0, $date = 0, $series_suffix = '',
|
$unit_name, $show_alerts, $avg_only = 0, $date = 0, $series_suffix = '',
|
||||||
$series_suffix_str = '') {
|
$series_suffix_str = '', $show_unknown = false) {
|
||||||
|
|
||||||
global $config;
|
global $config;
|
||||||
global $chart;
|
global $chart;
|
||||||
global $color;
|
global $color;
|
||||||
global $legend;
|
global $legend;
|
||||||
global $long_index;
|
global $long_index;
|
||||||
|
global $series_type;
|
||||||
|
global $chart_extra_data;
|
||||||
|
|
||||||
$chart = array();
|
$chart = array();
|
||||||
$color = array();
|
$color = array();
|
||||||
$legend = array();
|
$legend = array();
|
||||||
$long_index = array();
|
$long_index = array();
|
||||||
|
$start_unknown = false;
|
||||||
|
|
||||||
// Set variables
|
// Set variables
|
||||||
if ($date == 0) $date = get_system_time();
|
if ($date == 0) $date = get_system_time();
|
||||||
|
@ -1997,13 +2026,23 @@ function grafico_modulo_boolean_data ($agent_module_id, $period, $show_events,
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get event data (contains alert data too)
|
// Get event data (contains alert data too)
|
||||||
if ($show_events == 1 || $show_alerts == 1) {
|
if ($show_unknown == 1 || $show_events == 1 || $show_alerts == 1) {
|
||||||
$events = db_get_all_rows_filter('tevento',
|
$events = db_get_all_rows_filter('tevento',
|
||||||
array ('id_agentmodule' => $agent_module_id,
|
array ('id_agentmodule' => $agent_module_id,
|
||||||
"utimestamp > $datelimit",
|
"utimestamp > $datelimit",
|
||||||
"utimestamp < $date",
|
"utimestamp < $date",
|
||||||
'order' => 'utimestamp ASC'),
|
'order' => 'utimestamp ASC'),
|
||||||
array ('evento', 'utimestamp', 'event_type'));
|
array ('evento', 'utimestamp', 'event_type', 'id_evento'));
|
||||||
|
|
||||||
|
// Get the last event after inverval to know if graph start on unknown
|
||||||
|
$prev_event = db_get_row_filter ('tevento',
|
||||||
|
array ('id_agentmodule' => $agent_module_id,
|
||||||
|
"utimestamp <= $datelimit",
|
||||||
|
'order' => 'utimestamp DESC'));
|
||||||
|
if(isset($prev_event['event_type']) && $prev_event['event_type'] == 'going_unknown') {
|
||||||
|
$start_unknown = true;
|
||||||
|
}
|
||||||
|
|
||||||
if ($events === false) {
|
if ($events === false) {
|
||||||
$events = array ();
|
$events = array ();
|
||||||
}
|
}
|
||||||
|
@ -2110,18 +2149,36 @@ function grafico_modulo_boolean_data ($agent_module_id, $period, $show_events,
|
||||||
// Read events and alerts that fall in the current interval
|
// Read events and alerts that fall in the current interval
|
||||||
$event_value = 0;
|
$event_value = 0;
|
||||||
$alert_value = 0;
|
$alert_value = 0;
|
||||||
|
$unknown_value = 0;
|
||||||
|
|
||||||
|
$event_ids = array();
|
||||||
|
$alert_ids = array();
|
||||||
while (isset ($events[$k]) &&
|
while (isset ($events[$k]) &&
|
||||||
$events[$k]['utimestamp'] >= $timestamp &&
|
$events[$k]['utimestamp'] >= $timestamp &&
|
||||||
$events[$k]['utimestamp'] < ($timestamp + $interval)) {
|
$events[$k]['utimestamp'] < ($timestamp + $interval)) {
|
||||||
if ($show_events == 1) {
|
if ($show_events == 1) {
|
||||||
$event_value++;
|
$event_value++;
|
||||||
|
$event_ids[] = $events[$k]['id_evento'];
|
||||||
}
|
}
|
||||||
if ($show_alerts == 1 && substr ($events[$k]['event_type'], 0, 5) == 'alert') {
|
if ($show_alerts == 1 && substr ($events[$k]['event_type'], 0, 5) == 'alert') {
|
||||||
$alert_value++;
|
$alert_value++;
|
||||||
|
$alert_ids[] = $events[$k]['id_evento'];
|
||||||
|
}
|
||||||
|
if ($show_unknown) {
|
||||||
|
if($events[$k]['event_type'] == 'going_unknown') {
|
||||||
|
$is_unknown = true;
|
||||||
|
}
|
||||||
|
else if(substr ($events[$k]['event_type'], 0, 5) == 'going') {
|
||||||
|
$is_unknown = false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
$k++;
|
$k++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if($is_unknown) {
|
||||||
|
$unknown_value++;
|
||||||
|
}
|
||||||
|
|
||||||
// Set the title and time format
|
// Set the title and time format
|
||||||
if ($period <= SECONDS_6HOURS) {
|
if ($period <= SECONDS_6HOURS) {
|
||||||
$time_format = 'H:i:s';
|
$time_format = 'H:i:s';
|
||||||
|
@ -2145,6 +2202,10 @@ function grafico_modulo_boolean_data ($agent_module_id, $period, $show_events,
|
||||||
$timestamp = $timestamp_short;
|
$timestamp = $timestamp_short;
|
||||||
/////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
if($is_unknown) {
|
||||||
|
$total = 0;
|
||||||
|
}
|
||||||
|
|
||||||
// Data and zeroes (draw a step)
|
// Data and zeroes (draw a step)
|
||||||
if ($zero == 1 && $count > 0) {
|
if ($zero == 1 && $count > 0) {
|
||||||
if ($avg_only) {
|
if ($avg_only) {
|
||||||
|
@ -2172,7 +2233,7 @@ function grafico_modulo_boolean_data ($agent_module_id, $period, $show_events,
|
||||||
$previous_data = $total;
|
$previous_data = $total;
|
||||||
}
|
}
|
||||||
else { // Compressed data
|
else { // Compressed data
|
||||||
if ($uncompressed_module || ($timestamp > time ())) {
|
if ($uncompressed_module || ($timestamp > time ()) || $is_unknown) {
|
||||||
$chart[$timestamp]['sum'.$series_suffix] = 0;
|
$chart[$timestamp]['sum'.$series_suffix] = 0;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
@ -2185,17 +2246,37 @@ function grafico_modulo_boolean_data ($agent_module_id, $period, $show_events,
|
||||||
$chart[$timestamp]['max'.$series_suffix] = 0;
|
$chart[$timestamp]['max'.$series_suffix] = 0;
|
||||||
}
|
}
|
||||||
if($show_events) {
|
if($show_events) {
|
||||||
$chart[$timestamp]['event'.$series_suffix] = $event_value;
|
if(!isset($chart[$timestamp]['event'.$series_suffix])) {
|
||||||
|
$chart[$timestamp]['event'.$series_suffix] = 0;
|
||||||
}
|
}
|
||||||
else {
|
|
||||||
unset($chart[$timestamp]['event'.$series_suffix]);
|
$chart[$timestamp]['event'.$series_suffix] += $event_value;
|
||||||
|
$series_type['event'.$series_suffix] = 'points';
|
||||||
}
|
}
|
||||||
if($show_alerts) {
|
if($show_alerts) {
|
||||||
$chart[$timestamp]['alert'.$series_suffix] = $alert_value;
|
if(!isset($chart[$timestamp]['alert'.$series_suffix])) {
|
||||||
|
$chart[$timestamp]['alert'.$series_suffix] = 0;
|
||||||
}
|
}
|
||||||
else {
|
|
||||||
unset($chart[$timestamp]['alert'.$series_suffix]);
|
$chart[$timestamp]['alert'.$series_suffix] += $alert_value;
|
||||||
|
$series_type['alert'.$series_suffix] = 'points';
|
||||||
}
|
}
|
||||||
|
if($show_unknown) {
|
||||||
|
if(!isset($chart[$timestamp]['unknown'.$series_suffix])) {
|
||||||
|
$chart[$timestamp]['unknown'.$series_suffix] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
$chart[$timestamp]['unknown'.$series_suffix] = $unknown_value;
|
||||||
|
$series_type['unknown'.$series_suffix] = 'area';
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!empty($event_ids)) {
|
||||||
|
$chart_extra_data[count($chart)-1]['events'] = implode(',',$event_ids);
|
||||||
|
}
|
||||||
|
if(!empty($alert_ids)) {
|
||||||
|
$chart_extra_data[count($chart)-1]['alerts'] = implode(',',$alert_ids);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get min, max and avg (less efficient but centralized for all modules and reports)
|
// Get min, max and avg (less efficient but centralized for all modules and reports)
|
||||||
|
@ -2204,19 +2285,24 @@ function grafico_modulo_boolean_data ($agent_module_id, $period, $show_events,
|
||||||
$avg_value = round(reporting_get_agentmodule_data_average ($agent_module_id, $period, $date), 2);
|
$avg_value = round(reporting_get_agentmodule_data_average ($agent_module_id, $period, $date), 2);
|
||||||
|
|
||||||
// Fix event and alert scale
|
// Fix event and alert scale
|
||||||
$event_max = $max_value * 1.05;
|
|
||||||
foreach ($chart as $timestamp => $chart_data) {
|
foreach ($chart as $timestamp => $chart_data) {
|
||||||
if ($show_events) {
|
if ($show_events) {
|
||||||
if ($chart_data['event'] > 0) {
|
if ($chart_data['event'.$series_suffix] > 0) {
|
||||||
$chart[$timestamp]['event'.$series_suffix] = $event_max;
|
$chart[$timestamp]['event'.$series_suffix] = $max_value * 1.2;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if ($show_alerts) {
|
if ($show_alerts) {
|
||||||
if ($chart_data['alert'] > 0) {
|
if ($chart_data['alert'.$series_suffix] > 0) {
|
||||||
$chart[$timestamp]['alert'.$series_suffix] = $event_max;
|
$chart[$timestamp]['alert'.$series_suffix] = $max_value * 1.10;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if ($show_unknown) {
|
||||||
|
if ($chart_data['unknown'.$series_suffix] > 0) {
|
||||||
|
$chart[$timestamp]['unknown'.$series_suffix] = $max_value * 1.05;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
///////////////////////////////////////////////////
|
///////////////////////////////////////////////////
|
||||||
// Set the title and time format
|
// Set the title and time format
|
||||||
if ($period <= SECONDS_6HOURS) {
|
if ($period <= SECONDS_6HOURS) {
|
||||||
|
@ -2241,12 +2327,20 @@ function grafico_modulo_boolean_data ($agent_module_id, $period, $show_events,
|
||||||
|
|
||||||
/////////////////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////////////////
|
||||||
$legend['sum'.$series_suffix] = __('Avg').$series_suffix_str . ' (' . $avg_value . ') ' . $unit;
|
$legend['sum'.$series_suffix] = __('Avg').$series_suffix_str . ' (' . $avg_value . ') ' . $unit;
|
||||||
|
|
||||||
if($show_events) {
|
if($show_events) {
|
||||||
$legend['event'.$series_suffix] = __('Events').$series_suffix_str;
|
$legend['event'.$series_suffix] = __('Events').$series_suffix_str;
|
||||||
|
$chart_extra_data['legend_events'] = $legend['event'.$series_suffix];
|
||||||
}
|
}
|
||||||
if($show_alerts) {
|
if($show_alerts) {
|
||||||
$legend['alert'.$series_suffix] = __('Alerts').$series_suffix_str;
|
$legend['alert'.$series_suffix] = __('Alerts').$series_suffix_str;
|
||||||
|
$chart_extra_data['legend_alerts'] = $legend['alert'.$series_suffix];
|
||||||
}
|
}
|
||||||
|
if($show_unknown) {
|
||||||
|
$legend['unknown'.$series_suffix] = __('Unknown').$series_suffix_str;
|
||||||
|
$chart_extra_data['legend_unknown'] = $legend['unknown'.$series_suffix];
|
||||||
|
}
|
||||||
|
|
||||||
if (!$avg_only) {
|
if (!$avg_only) {
|
||||||
$legend['max'.$series_suffix] = __('Max').$series_suffix_str . ' (' .format_for_graph($max_value) . ') ' . $unit;
|
$legend['max'.$series_suffix] = __('Max').$series_suffix_str . ' (' .format_for_graph($max_value) . ') ' . $unit;
|
||||||
$legend['min'.$series_suffix] = __('Min').$series_suffix_str . ' (' . format_for_graph($min_value) . ') ' . $unit;
|
$legend['min'.$series_suffix] = __('Min').$series_suffix_str . ' (' . format_for_graph($min_value) . ') ' . $unit;
|
||||||
|
@ -2260,6 +2354,9 @@ function grafico_modulo_boolean_data ($agent_module_id, $period, $show_events,
|
||||||
if($show_alerts) {
|
if($show_alerts) {
|
||||||
$color['alert'.$series_suffix] = array('border' => '#ff0000', 'color' => '#ff0000', 'alpha' => 50);
|
$color['alert'.$series_suffix] = array('border' => '#ff0000', 'color' => '#ff0000', 'alpha' => 50);
|
||||||
}
|
}
|
||||||
|
if($show_unknown) {
|
||||||
|
$color['unknown'.$series_suffix] = array('border' => '#999999', 'color' => '#999999', 'alpha' => 50);
|
||||||
|
}
|
||||||
$color['max'.$series_suffix] = array('border' => '#000000', 'color' => $config['graph_color3'], 'alpha' => 50);
|
$color['max'.$series_suffix] = array('border' => '#000000', 'color' => $config['graph_color3'], 'alpha' => 50);
|
||||||
$color['min'.$series_suffix] = array('border' => '#000000', 'color' => $config['graph_color1'], 'alpha' => 50);
|
$color['min'.$series_suffix] = array('border' => '#000000', 'color' => $config['graph_color1'], 'alpha' => 50);
|
||||||
//$color['baseline'.$series_suffix] = array('border' => null, 'color' => '#0097BD', 'alpha' => 10);
|
//$color['baseline'.$series_suffix] = array('border' => null, 'color' => '#0097BD', 'alpha' => 10);
|
||||||
|
@ -2268,7 +2365,7 @@ function grafico_modulo_boolean_data ($agent_module_id, $period, $show_events,
|
||||||
|
|
||||||
function grafico_modulo_boolean ($agent_module_id, $period, $show_events,
|
function grafico_modulo_boolean ($agent_module_id, $period, $show_events,
|
||||||
$width, $height , $title, $unit_name, $show_alerts, $avg_only = 0, $pure=0,
|
$width, $height , $title, $unit_name, $show_alerts, $avg_only = 0, $pure=0,
|
||||||
$date = 0, $only_image = false, $homeurl = '', $adapt_key = '', $compare = false) {
|
$date = 0, $only_image = false, $homeurl = '', $adapt_key = '', $compare = false, $show_unknown = false) {
|
||||||
|
|
||||||
global $config;
|
global $config;
|
||||||
global $graphic_type;
|
global $graphic_type;
|
||||||
|
@ -2279,31 +2376,38 @@ function grafico_modulo_boolean ($agent_module_id, $period, $show_events,
|
||||||
global $color;
|
global $color;
|
||||||
global $legend;
|
global $legend;
|
||||||
global $long_index;
|
global $long_index;
|
||||||
|
global $series_type;
|
||||||
|
global $chart_extra_data;
|
||||||
|
|
||||||
|
$series_suffix_str = '';
|
||||||
if ($compare !== false) {
|
if ($compare !== false) {
|
||||||
$series_suffix = '2';
|
$series_suffix = '2';
|
||||||
$series_suffix_str = ' ('.__('Previous').')';
|
$series_suffix_str = ' ('.__('Previous').')';
|
||||||
// Build the data of the previous period
|
// Build the data of the previous period
|
||||||
grafico_modulo_boolean_data ($agent_module_id, $period, $show_events,
|
grafico_modulo_boolean_data ($agent_module_id, $period, $show_events,
|
||||||
$unit_name, $show_alerts, $avg_only, $date-$period, $series_suffix, $series_suffix_str);
|
$unit_name, $show_alerts, $avg_only, $date-$period, $series_suffix,
|
||||||
|
$series_suffix_str, $show_unknown);
|
||||||
switch($compare) {
|
switch($compare) {
|
||||||
case 'separated':
|
case 'separated':
|
||||||
// Store the chart calculated
|
// Store the chart calculated
|
||||||
$chart_prev = $chart;
|
$chart_prev = $chart;
|
||||||
$legend_prev = $legend;
|
$legend_prev = $legend;
|
||||||
$long_index_prev = $long_index;
|
$long_index_prev = $long_index;
|
||||||
|
$series_type_prev = $series_type;
|
||||||
|
$chart_extra_data_prev = $chart_extra_data;
|
||||||
|
$chart_extra_data = array();
|
||||||
|
$color_prev = $color;
|
||||||
break;
|
break;
|
||||||
case 'overlapped':
|
case 'overlapped':
|
||||||
// Store the chart calculated deleting index, because will be over the current period
|
// Store the chart calculated deleting index, because will be over the current period
|
||||||
$chart_prev = array_values($chart);
|
$chart_prev = array_values($chart);
|
||||||
$legend_prev = $legend;
|
$legend_prev = $legend;
|
||||||
|
$series_type_prev = $series_type;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
grafico_modulo_boolean_data ($agent_module_id, $period, $show_events,
|
grafico_modulo_boolean_data ($agent_module_id, $period, $show_events,
|
||||||
$unit_name, $show_alerts, $avg_only, $date);
|
$unit_name, $show_alerts, $avg_only, $date, '', '', $show_unknown);
|
||||||
|
|
||||||
if ($compare === 'overlapped') {
|
if ($compare === 'overlapped') {
|
||||||
$i = 0;
|
$i = 0;
|
||||||
|
@ -2326,21 +2430,21 @@ function grafico_modulo_boolean ($agent_module_id, $period, $show_events,
|
||||||
return area_graph($flash_chart, $chart, $width, $height/2, $color, $legend,
|
return area_graph($flash_chart, $chart, $width, $height/2, $color, $legend,
|
||||||
$long_index, ui_get_full_url("images/image_problem.opaque.png"), "", $unit, $homeurl,
|
$long_index, ui_get_full_url("images/image_problem.opaque.png"), "", $unit, $homeurl,
|
||||||
$water_mark,
|
$water_mark,
|
||||||
$config['fontpath'], $config['font_size'], $unit, 1, array(),
|
$config['fontpath'], $config['font_size'], $unit, 1, $series_type,
|
||||||
array(), 0, 0, $adapt_key).
|
$chart_extra_data, 0, 0, $adapt_key, false, $series_suffix_str).
|
||||||
'<br>'.
|
'<br>'.
|
||||||
area_graph($flash_chart, $chart_prev, $width, $height/2, $color, $legend_prev,
|
area_graph($flash_chart, $chart_prev, $width, $height/2, $color_prev, $legend_prev,
|
||||||
$long_index_prev, ui_get_full_url("images/image_problem.opaque.png"), "", $unit, $homeurl,
|
$long_index_prev, ui_get_full_url("images/image_problem.opaque.png"), "", $unit, $homeurl,
|
||||||
$water_mark,
|
$water_mark,
|
||||||
$config['fontpath'], $config['font_size'], $unit, 1, array(),
|
$config['fontpath'], $config['font_size'], $unit, 1, $series_type_prev,
|
||||||
array(), 0, 0, $adapt_key);
|
$chart_extra_data_prev, 0, 0, $adapt_key, false, $series_suffix_str);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return area_graph($flash_chart, $chart, $width, $height, $color, $legend,
|
return area_graph($flash_chart, $chart, $width, $height, $color, $legend,
|
||||||
$long_index, ui_get_full_url("images/image_problem.opaque.png"), "", $unit, $homeurl,
|
$long_index, ui_get_full_url("images/image_problem.opaque.png"), "", $unit, $homeurl,
|
||||||
$water_mark,
|
$water_mark,
|
||||||
$config['fontpath'], $config['font_size'], $unit, 1, array(),
|
$config['fontpath'], $config['font_size'], $unit, 1, $series_type,
|
||||||
array(), 0, 0, $adapt_key);
|
$chart_extra_data, 0, 0, $adapt_key, false, $series_suffix_str);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2411,10 +2515,10 @@ function graph_netflow_aggregate_area ($data, $period, $width, $height, $only_im
|
||||||
$water_mark = array('file' => $config['homedir'] . "/images/logo_vertical_water.png",
|
$water_mark = array('file' => $config['homedir'] . "/images/logo_vertical_water.png",
|
||||||
'url' => ui_get_full_url("/images/logo_vertical_water.png"));
|
'url' => ui_get_full_url("/images/logo_vertical_water.png"));
|
||||||
|
|
||||||
return stacked_area_graph($flash_chart, $chart, $width, $height, null, $sources,
|
return area_graph($flash_chart, $chart, $width, $height, $color, $legend,
|
||||||
null, ui_get_full_url("images/image_problem.opaque.png"), "", "",
|
$long_index, "images/image_problem.opaque.png", "", $unit, $homeurl,
|
||||||
$water_mark,
|
$config['homedir'] . "/images/logo_vertical_water.png",
|
||||||
$config['fontpath'], $config['font_size'], "");
|
$config['fontpath'], $config['font_size'], $unit);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -2744,8 +2848,9 @@ function grafico_modulo_string ($agent_module_id, $period, $show_events,
|
||||||
* @param string homeurl Home url if the complete path is needed
|
* @param string homeurl Home url if the complete path is needed
|
||||||
* @param int Zoom factor over the graph
|
* @param int Zoom factor over the graph
|
||||||
* @param string adaptation width and margin left key (could be adapter_[something] or adapted_[something])
|
* @param string adaptation width and margin left key (could be adapter_[something] or adapted_[something])
|
||||||
|
* @param int date limit of the period
|
||||||
*/
|
*/
|
||||||
function graphic_module_events ($id_module, $width, $height, $period = 0, $homeurl = '', $zoom = 0, $adapt_key = '') {
|
function graphic_module_events ($id_module, $width, $height, $period = 0, $homeurl = '', $zoom = 0, $adapt_key = '', $date = false) {
|
||||||
global $config;
|
global $config;
|
||||||
global $graphic_type;
|
global $graphic_type;
|
||||||
|
|
||||||
|
@ -2754,7 +2859,9 @@ function graphic_module_events ($id_module, $width, $height, $period = 0, $homeu
|
||||||
$resolution = $config['graph_res'] * ($period * 2 / $width); // Number of "slices" we want in graph
|
$resolution = $config['graph_res'] * ($period * 2 / $width); // Number of "slices" we want in graph
|
||||||
|
|
||||||
$interval = (int) ($period / $resolution);
|
$interval = (int) ($period / $resolution);
|
||||||
|
if($date === false) {
|
||||||
$date = get_system_time ();
|
$date = get_system_time ();
|
||||||
|
}
|
||||||
$datelimit = $date - $period;
|
$datelimit = $date - $period;
|
||||||
$periodtime = floor ($period / $interval);
|
$periodtime = floor ($period / $interval);
|
||||||
$time = array ();
|
$time = array ();
|
||||||
|
@ -2790,32 +2897,63 @@ function graphic_module_events ($id_module, $width, $height, $period = 0, $homeu
|
||||||
|
|
||||||
$top = $datelimit + ($periodtime * ($i + 1));
|
$top = $datelimit + ($periodtime * ($i + 1));
|
||||||
|
|
||||||
|
$events = db_get_all_rows_filter ('tevento',
|
||||||
$event = db_get_row_filter ('tevento',
|
|
||||||
array ('id_agentmodule' => $id_module,
|
array ('id_agentmodule' => $id_module,
|
||||||
'utimestamp > '.$bottom,
|
'utimestamp > '.$bottom,
|
||||||
'utimestamp < '.$top), 'criticity, utimestamp');
|
'utimestamp < '.$top), 'event_type, utimestamp');
|
||||||
|
|
||||||
|
$status = 'normal';
|
||||||
|
foreach($events as $event) {
|
||||||
|
if(empty($event['utimestamp'])) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch($event['event_type']) {
|
||||||
|
case 'going_down_normal':
|
||||||
|
case 'going_up_normal':
|
||||||
|
// The default status is normal. Do nothing
|
||||||
|
break;
|
||||||
|
case 'going_unknown':
|
||||||
|
if($status == 'normal') {
|
||||||
|
$status = 'unknown';
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'going_up_warning':
|
||||||
|
case 'going_down_warning':
|
||||||
|
if($status == 'normal' || $status == 'unknown') {
|
||||||
|
$status = 'warning';
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'going_up_critical':
|
||||||
|
case 'going_down_critical':
|
||||||
|
$status = 'critical';
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (!empty($event['utimestamp'])){
|
|
||||||
$data[$cont]['utimestamp'] = $periodtime;
|
$data[$cont]['utimestamp'] = $periodtime;
|
||||||
switch ($event['criticity']) {
|
|
||||||
case 3:
|
if (!empty($events)){
|
||||||
|
switch ($status) {
|
||||||
|
case 'warning':
|
||||||
$data[$cont]['data'] = 2;
|
$data[$cont]['data'] = 2;
|
||||||
break;
|
break;
|
||||||
case 4:
|
case 'critical':
|
||||||
$data[$cont]['data'] = 3;
|
$data[$cont]['data'] = 3;
|
||||||
break;
|
break;
|
||||||
|
case 'unknown':
|
||||||
|
$data[$cont]['data'] = 4;
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
$data[$cont]['data'] = 1;
|
$data[$cont]['data'] = 1;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
$current_timestamp = $event['utimestamp'];
|
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
$data[$cont]['utimestamp'] = $periodtime;
|
|
||||||
$data[$cont]['data'] = 1;
|
$data[$cont]['data'] = 1;
|
||||||
$current_timestamp = $bottom;
|
$current_timestamp = $bottom;
|
||||||
}
|
}
|
||||||
|
|
||||||
$legend[] = date($time_format, $current_timestamp);
|
$legend[] = date($time_format, $current_timestamp);
|
||||||
$cont++;
|
$cont++;
|
||||||
}
|
}
|
||||||
|
|
|
@ -233,7 +233,8 @@ function threshold_graph($flash_chart, $chart_data, $width, $height, $ttl = 1) {
|
||||||
function area_graph($flash_chart, $chart_data, $width, $height, $color, $legend,
|
function area_graph($flash_chart, $chart_data, $width, $height, $color, $legend,
|
||||||
$long_index, $no_data_image, $xaxisname = "", $yaxisname = "", $homeurl="",
|
$long_index, $no_data_image, $xaxisname = "", $yaxisname = "", $homeurl="",
|
||||||
$water_mark = "", $font = '', $font_size = '', $unit = '', $ttl = 1, $series_type = array(),
|
$water_mark = "", $font = '', $font_size = '', $unit = '', $ttl = 1, $series_type = array(),
|
||||||
$chart_extra_data = array(), $yellow_threshold = 0, $red_threshold = 0, $adapt_key = '', $force_integer = false) {
|
$chart_extra_data = array(), $yellow_threshold = 0, $red_threshold = 0, $adapt_key = '', $force_integer = false,
|
||||||
|
$series_suffix_str = '') {
|
||||||
|
|
||||||
setup_watermark($water_mark, $water_mark_file, $water_mark_url);
|
setup_watermark($water_mark, $water_mark_file, $water_mark_url);
|
||||||
|
|
||||||
|
@ -251,7 +252,7 @@ function area_graph($flash_chart, $chart_data, $width, $height, $color, $legend,
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($flash_chart) {
|
if ($flash_chart) {
|
||||||
return flot_area_simple_graph($chart_data, $width, $height, $color, $legend, $long_index, $homeurl, $unit, $water_mark_url, $series_type, $chart_extra_data, $yellow_threshold, $red_threshold, $adapt_key, $force_integer);
|
return flot_area_simple_graph($chart_data, $width, $height, $color, $legend, $long_index, $homeurl, $unit, $water_mark_url, $series_type, $chart_extra_data, $yellow_threshold, $red_threshold, $adapt_key, $force_integer, $series_suffix_str);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
$graph = array();
|
$graph = array();
|
||||||
|
|
|
@ -442,7 +442,7 @@ function pandoraFlotSlicebar(graph_id, values, datacolor, labels, legend, acumul
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function pandoraFlotArea(graph_id, values, labels, labels_long, legend, colors, type, serie_types, water_mark, width, max_x, homeurl, unit, font_size, menu, events, event_ids, legend_events, alerts, alert_ids, legend_alerts, yellow_threshold, red_threshold, force_integer, separator, separator2) {
|
function pandoraFlotArea(graph_id, values, labels, labels_long, legend, colors, type, serie_types, water_mark, width, max_x, homeurl, unit, font_size, menu, events, event_ids, legend_events, alerts, alert_ids, legend_alerts, yellow_threshold, red_threshold, force_integer, separator, separator2, series_suffix_str) {
|
||||||
|
|
||||||
var threshold = true;
|
var threshold = true;
|
||||||
var thresholded = false;
|
var thresholded = false;
|
||||||
|
@ -793,7 +793,7 @@ function pandoraFlotArea(graph_id, values, labels, labels_long, legend, colors,
|
||||||
|
|
||||||
$('#'+graph_id).bind("plotclick", function (event, pos, item) {
|
$('#'+graph_id).bind("plotclick", function (event, pos, item) {
|
||||||
plot.unhighlight();
|
plot.unhighlight();
|
||||||
if (item && item.series.label != '' && (item.series.label == legend_events || item.series.label == legend_alerts)) {
|
if (item && item.series.label != '' && (item.series.label == legend_events || item.series.label == legend_events+series_suffix_str || item.series.label == legend_alerts || item.series.label == legend_alerts+series_suffix_str)) {
|
||||||
plot.unhighlight();
|
plot.unhighlight();
|
||||||
var canvaslimit = parseInt(plot.offset().left + plot.width());
|
var canvaslimit = parseInt(plot.offset().left + plot.width());
|
||||||
var dataset = plot.getData();
|
var dataset = plot.getData();
|
||||||
|
@ -815,10 +815,12 @@ function pandoraFlotArea(graph_id, values, labels, labels_long, legend, colors,
|
||||||
$('#extra_'+graph_id).css('top',plot.offset().top + 25);
|
$('#extra_'+graph_id).css('top',plot.offset().top + 25);
|
||||||
|
|
||||||
switch(item.series.label) {
|
switch(item.series.label) {
|
||||||
|
case legend_alerts+series_suffix_str:
|
||||||
case legend_alerts:
|
case legend_alerts:
|
||||||
extra_info = '<b>'+legend_alerts+' - '+labels_long[item.dataIndex]+'</b>'+get_event_details(alertsz[item.dataIndex]);
|
extra_info = '<b>'+legend_alerts+' - '+labels_long[item.dataIndex]+'</b>'+get_event_details(alertsz[item.dataIndex]);
|
||||||
extra_show = true;
|
extra_show = true;
|
||||||
break;
|
break;
|
||||||
|
case legend_events+series_suffix_str:
|
||||||
case legend_events:
|
case legend_events:
|
||||||
extra_info = '<b>'+legend_events+' - '+labels_long[item.dataIndex]+'</b>'+get_event_details(eventsz[item.dataIndex]);
|
extra_info = '<b>'+legend_events+' - '+labels_long[item.dataIndex]+'</b>'+get_event_details(eventsz[item.dataIndex]);
|
||||||
extra_show = true;
|
extra_show = true;
|
||||||
|
|
|
@ -77,31 +77,31 @@ function include_javascript_dependencies_flot_graph($return = false) {
|
||||||
///////////////////////////////
|
///////////////////////////////
|
||||||
////////// AREA GRAPHS ////////
|
////////// AREA GRAPHS ////////
|
||||||
///////////////////////////////
|
///////////////////////////////
|
||||||
function flot_area_stacked_graph($chart_data, $width, $height, $color, $legend, $long_index, $homeurl = '', $unit = '', $water_mark = '', $serie_types = array(), $chart_extra_data = array(), $yellow_threshold = 0, $red_threshold = 0, $adapt_key= '', $force_integer = false) {
|
function flot_area_stacked_graph($chart_data, $width, $height, $color, $legend, $long_index, $homeurl = '', $unit = '', $water_mark = '', $serie_types = array(), $chart_extra_data = array(), $yellow_threshold = 0, $red_threshold = 0, $adapt_key= '', $force_integer = false, $series_suffix_str = '') {
|
||||||
global $config;
|
global $config;
|
||||||
|
|
||||||
return flot_area_graph($chart_data, $width, $height, $color, $legend, $long_index, $homeurl, $unit, 'area_stacked', $water_mark, $serie_types, $chart_extra_data, $yellow_threshold, $red_threshold, $adapt_key, $force_integer);
|
return flot_area_graph($chart_data, $width, $height, $color, $legend, $long_index, $homeurl, $unit, 'area_stacked', $water_mark, $serie_types, $chart_extra_data, $yellow_threshold, $red_threshold, $adapt_key, $force_integer, $series_suffix_str);
|
||||||
}
|
}
|
||||||
|
|
||||||
function flot_area_simple_graph($chart_data, $width, $height, $color, $legend, $long_index, $homeurl = '', $unit = '', $water_mark = '', $serie_types = array(), $chart_extra_data = array(), $yellow_threshold = 0, $red_threshold = 0, $adapt_key= '', $force_integer = false) {
|
function flot_area_simple_graph($chart_data, $width, $height, $color, $legend, $long_index, $homeurl = '', $unit = '', $water_mark = '', $serie_types = array(), $chart_extra_data = array(), $yellow_threshold = 0, $red_threshold = 0, $adapt_key= '', $force_integer = false, $series_suffix_str = '') {
|
||||||
global $config;
|
global $config;
|
||||||
|
|
||||||
return flot_area_graph($chart_data, $width, $height, $color, $legend, $long_index, $homeurl, $unit, 'area_simple', $water_mark, $serie_types, $chart_extra_data, $yellow_threshold, $red_threshold, $adapt_key, $force_integer);
|
return flot_area_graph($chart_data, $width, $height, $color, $legend, $long_index, $homeurl, $unit, 'area_simple', $water_mark, $serie_types, $chart_extra_data, $yellow_threshold, $red_threshold, $adapt_key, $force_integer, $series_suffix_str);
|
||||||
}
|
}
|
||||||
|
|
||||||
function flot_line_stacked_graph($chart_data, $width, $height, $color, $legend, $long_index, $homeurl = '', $unit = '', $water_mark = '', $serie_types = array(), $chart_extra_data = array(), $yellow_threshold = 0, $red_threshold = 0, $adapt_key= '', $force_integer = false) {
|
function flot_line_stacked_graph($chart_data, $width, $height, $color, $legend, $long_index, $homeurl = '', $unit = '', $water_mark = '', $serie_types = array(), $chart_extra_data = array(), $yellow_threshold = 0, $red_threshold = 0, $adapt_key= '', $force_integer = false, $series_suffix_str = '') {
|
||||||
global $config;
|
global $config;
|
||||||
|
|
||||||
return flot_area_graph($chart_data, $width, $height, $color, $legend, $long_index, $homeurl, $unit, 'line_stacked', $water_mark, $serie_types, $chart_extra_data, $yellow_threshold, $red_threshold, $adapt_key, $force_integer);
|
return flot_area_graph($chart_data, $width, $height, $color, $legend, $long_index, $homeurl, $unit, 'line_stacked', $water_mark, $serie_types, $chart_extra_data, $yellow_threshold, $red_threshold, $adapt_key, $force_integer, $series_suffix_str);
|
||||||
}
|
}
|
||||||
|
|
||||||
function flot_line_simple_graph($chart_data, $width, $height, $color, $legend, $long_index, $homeurl = '', $unit = '', $water_mark = '', $serie_types = array(), $chart_extra_data = array(), $yellow_threshold = 0, $red_threshold = 0, $adapt_key= '', $force_integer = false) {
|
function flot_line_simple_graph($chart_data, $width, $height, $color, $legend, $long_index, $homeurl = '', $unit = '', $water_mark = '', $serie_types = array(), $chart_extra_data = array(), $yellow_threshold = 0, $red_threshold = 0, $adapt_key= '', $force_integer = false, $series_suffix_str = '') {
|
||||||
global $config;
|
global $config;
|
||||||
|
|
||||||
return flot_area_graph($chart_data, $width, $height, $color, $legend, $long_index, $homeurl, $unit, 'line_simple', $water_mark, $serie_types, $chart_extra_data, $yellow_threshold, $red_threshold, $adapt_key, $force_integer);
|
return flot_area_graph($chart_data, $width, $height, $color, $legend, $long_index, $homeurl, $unit, 'line_simple', $water_mark, $serie_types, $chart_extra_data, $yellow_threshold, $red_threshold, $adapt_key, $force_integer, $series_suffix_str);
|
||||||
}
|
}
|
||||||
|
|
||||||
function flot_area_graph($chart_data, $width, $height, $color, $legend, $long_index, $homeurl, $unit, $type, $water_mark, $serie_types, $chart_extra_data, $yellow_threshold, $red_threshold, $adapt_key, $force_integer) {
|
function flot_area_graph($chart_data, $width, $height, $color, $legend, $long_index, $homeurl, $unit, $type, $water_mark, $serie_types, $chart_extra_data, $yellow_threshold, $red_threshold, $adapt_key, $force_integer, $series_suffix_str = '') {
|
||||||
global $config;
|
global $config;
|
||||||
|
|
||||||
include_javascript_dependencies_flot_graph();
|
include_javascript_dependencies_flot_graph();
|
||||||
|
@ -285,7 +285,7 @@ function flot_area_graph($chart_data, $width, $height, $color, $legend, $long_in
|
||||||
// Javascript code
|
// Javascript code
|
||||||
$return .= "<script type='text/javascript'>";
|
$return .= "<script type='text/javascript'>";
|
||||||
$return .= "//<![CDATA[\n";
|
$return .= "//<![CDATA[\n";
|
||||||
$return .= "pandoraFlotArea('$graph_id', '$values', '$labels', '$labels_long', '$legend', '$colors', '$type', '$serie_types', $watermark, $width, $max_x, '".$config['homeurl']."', '$unit', $font_size, $menu, '$events', '$event_ids', '$legend_events', '$alerts', '$alert_ids', '$legend_alerts', '$yellow_threshold', '$red_threshold', $force_integer, '$separator', '$separator2');";
|
$return .= "pandoraFlotArea('$graph_id', '$values', '$labels', '$labels_long', '$legend', '$colors', '$type', '$serie_types', $watermark, $width, $max_x, '".$config['homeurl']."', '$unit', $font_size, $menu, '$events', '$event_ids', '$legend_events', '$alerts', '$alert_ids', '$legend_alerts', '$yellow_threshold', '$red_threshold', $force_integer, '$separator', '$separator2', '$series_suffix_str');";
|
||||||
$return .= "\n//]]>";
|
$return .= "\n//]]>";
|
||||||
$return .= "</script>";
|
$return .= "</script>";
|
||||||
|
|
||||||
|
|
|
@ -238,31 +238,31 @@ $label = base64_decode(get_parameter('label', ''));
|
||||||
case 'boolean':
|
case 'boolean':
|
||||||
echo grafico_modulo_boolean ($id, $period, $draw_events, $width, $height,
|
echo grafico_modulo_boolean ($id, $period, $draw_events, $width, $height,
|
||||||
$label, null, $draw_alerts, $avg_only, false, $date, false, $urlImage, 'adapter_'.$graph_type, $time_compare, $unknown_graph);
|
$label, null, $draw_alerts, $avg_only, false, $date, false, $urlImage, 'adapter_'.$graph_type, $time_compare, $unknown_graph);
|
||||||
echo '<br><br><br>';
|
echo '<br>';
|
||||||
if ($show_events_graph)
|
if ($show_events_graph)
|
||||||
echo graphic_module_events($id, $width, $height, $period, $config['homeurl'] . '/', $zoom, 'adapted_'.$graph_type);
|
echo graphic_module_events($id, $width, $height, $period, $config['homeurl'] . '/', $zoom, 'adapted_'.$graph_type, $date);
|
||||||
break;
|
break;
|
||||||
case 'sparse':
|
case 'sparse':
|
||||||
echo grafico_modulo_sparse ($id, $period, $draw_events, $width, $height,
|
echo grafico_modulo_sparse ($id, $period, $draw_events, $width, $height,
|
||||||
$label, null, $draw_alerts, $avg_only, false, $date, '', $baseline,
|
$label, null, $draw_alerts, $avg_only, false, $date, '', $baseline,
|
||||||
0, true, false, $urlImage, 1, false, 'adapter_'.$graph_type, $time_compare, $unknown_graph);
|
0, true, false, $urlImage, 1, false, 'adapter_'.$graph_type, $time_compare, $unknown_graph);
|
||||||
echo '<br><br><br>';
|
echo '<br>';
|
||||||
if ($show_events_graph)
|
if ($show_events_graph)
|
||||||
echo graphic_module_events($id, $width, $height, $period, $config['homeurl'] . '/', $zoom, 'adapted_'.$graph_type);
|
echo graphic_module_events($id, $width, $height, $period, $config['homeurl'] . '/', $zoom, 'adapted_'.$graph_type, $date);
|
||||||
break;
|
break;
|
||||||
case 'string':
|
case 'string':
|
||||||
echo grafico_modulo_string ($id, $period, $draw_events, $width, $height,
|
echo grafico_modulo_string ($id, $period, $draw_events, $width, $height,
|
||||||
$label, null, $draw_alerts, 1, false, $date, false, $urlImage, 'adapter_'.$graph_type);
|
$label, null, $draw_alerts, 1, false, $date, false, $urlImage, 'adapter_'.$graph_type);
|
||||||
echo '<br><br><br>';
|
echo '<br>';
|
||||||
if ($show_events_graph)
|
if ($show_events_graph)
|
||||||
echo graphic_module_events($id, $width, $height, $period, $config['homeurl'] . '/', $zoom, 'adapted_'.$graph_type);
|
echo graphic_module_events($id, $width, $height, $period, $config['homeurl'] . '/', $zoom, 'adapted_'.$graph_type, $date);
|
||||||
break;
|
break;
|
||||||
case 'log4x':
|
case 'log4x':
|
||||||
echo grafico_modulo_log4x ($id, $period, $draw_events, $width, $height,
|
echo grafico_modulo_log4x ($id, $period, $draw_events, $width, $height,
|
||||||
$label, $unit_name, $draw_alerts, 1, $pure, $date);
|
$label, $unit_name, $draw_alerts, 1, $pure, $date);
|
||||||
echo '<br><br><br>';
|
echo '<br>';
|
||||||
if ($show_events_graph)
|
if ($show_events_graph)
|
||||||
echo graphic_module_events($id, $width, $height, $period, $config['homeurl'] . '/', $zoom);
|
echo graphic_module_events($id, $width, $height, $period, $config['homeurl'] . '/', $zoom, '', $date);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
echo fs_error_image ('../images');
|
echo fs_error_image ('../images');
|
||||||
|
|
Loading…
Reference in New Issue