2012-06-25 Miguel de Dios <miguel.dedios@artica.es>
* include/functions_graph.php: cleaned source code style. * include/functions_custom_graphs.php: fixed into the function "graphic_combined_module" the show html entities in the name of agents in legends, show better the legend for long size names of agents and modules. Merged from 4.0.2 * extensions/update_manager/debug.php: upload lost file from old commit. git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6688 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
This commit is contained in:
parent
4ddac5736a
commit
06831a5e55
|
@ -1,3 +1,17 @@
|
||||||
|
2012-06-25 Miguel de Dios <miguel.dedios@artica.es>
|
||||||
|
|
||||||
|
* include/functions_graph.php: cleaned source code style.
|
||||||
|
|
||||||
|
* include/functions_custom_graphs.php: fixed into the function
|
||||||
|
"graphic_combined_module" the show html entities in the name of
|
||||||
|
agents in legends, show better the legend for long size names of
|
||||||
|
agents and modules.
|
||||||
|
|
||||||
|
Merged from 4.0.2
|
||||||
|
|
||||||
|
* extensions/update_manager/debug.php: upload lost file from old
|
||||||
|
commit.
|
||||||
|
|
||||||
2012-06-22 Sergio Martin <sergio.martin@artica.es>
|
2012-06-22 Sergio Martin <sergio.martin@artica.es>
|
||||||
|
|
||||||
* include/functions_reporting.php: Improved several
|
* include/functions_reporting.php: Improved several
|
||||||
|
|
|
@ -0,0 +1,66 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
// Pandora FMS - http://pandorafms.com
|
||||||
|
// ==================================================
|
||||||
|
// Copyright (c) 2005-2011 Artica Soluciones Tecnologicas
|
||||||
|
// Please see http://pandorafms.org for full contribution list
|
||||||
|
|
||||||
|
// This program is free software; you can redistribute it and/or
|
||||||
|
// modify it under the terms of the GNU Lesser General Public License
|
||||||
|
// as published by the Free Software Foundation; version 2
|
||||||
|
|
||||||
|
// 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.
|
||||||
|
|
||||||
|
|
||||||
|
////////////////////////////////////
|
||||||
|
///////PLEASE DONT TOUCH
|
||||||
|
global $debug_update_manager;
|
||||||
|
////////////////////////////////////
|
||||||
|
////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
////////////////////////////////////
|
||||||
|
///////PLEASE ONLY CHANGE THIS VALUE
|
||||||
|
$debug_update_manager = 0;
|
||||||
|
////////////////////////////////////
|
||||||
|
////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
////////////////////////////////////
|
||||||
|
///////PLEASE DONT TOUCH
|
||||||
|
function print_debug_message_trace($message) {
|
||||||
|
global $debug_update_manager;
|
||||||
|
|
||||||
|
if ($debug_update_manager) {
|
||||||
|
trigger_error("PRINT DEBUG TRACE",
|
||||||
|
E_USER_NOTICE);
|
||||||
|
|
||||||
|
trigger_error($message, E_USER_NOTICE);
|
||||||
|
|
||||||
|
$backtrace = json_encode(debug_backtrace());
|
||||||
|
$backtrace_chunks = str_split($backtrace, 1024);
|
||||||
|
|
||||||
|
trigger_error("INIT DEBUG BACKTRACE (JSON ENCODE) CHUNKS " .
|
||||||
|
count($backtrace_chunks), E_USER_NOTICE);
|
||||||
|
foreach ($backtrace_chunks as $chunk)
|
||||||
|
trigger_error($chunk, E_USER_NOTICE);
|
||||||
|
trigger_error("END DEBUG BACKTRACE (JSON ENCODE)",
|
||||||
|
E_USER_NOTICE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
////////////////////////////////////
|
||||||
|
////////////////////////////////////
|
||||||
|
?>
|
|
@ -45,26 +45,26 @@ function custom_graphs_get_user ($id_user = 0, $only_names = false, $returnAllGr
|
||||||
if (!$id_user) {
|
if (!$id_user) {
|
||||||
$id_user = $config['id_user'];
|
$id_user = $config['id_user'];
|
||||||
}
|
}
|
||||||
|
|
||||||
$groups = users_get_groups ($id_user, $privileges, $returnAllGroup);
|
$groups = users_get_groups ($id_user, $privileges, $returnAllGroup);
|
||||||
|
|
||||||
$all_graphs = db_get_all_rows_in_table ('tgraph', 'name');
|
$all_graphs = db_get_all_rows_in_table ('tgraph', 'name');
|
||||||
if ($all_graphs === false)
|
if ($all_graphs === false)
|
||||||
return array ();
|
return array ();
|
||||||
|
|
||||||
$graphs = array ();
|
$graphs = array ();
|
||||||
foreach ($all_graphs as $graph) {
|
foreach ($all_graphs as $graph) {
|
||||||
if (!in_array($graph['id_group'], array_keys($groups)))
|
if (!in_array($graph['id_group'], array_keys($groups)))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if ($graph["id_user"] != $id_user && $graph['private'])
|
if ($graph["id_user"] != $id_user && $graph['private'])
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if ($graph["id_group"] > 0)
|
if ($graph["id_group"] > 0)
|
||||||
if (!isset($groups[$graph["id_group"]])){
|
if (!isset($groups[$graph["id_group"]])){
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($only_names) {
|
if ($only_names) {
|
||||||
$graphs[$graph['id_graph']] = $graph['name'];
|
$graphs[$graph['id_graph']] = $graph['name'];
|
||||||
}
|
}
|
||||||
|
@ -92,7 +92,7 @@ function custom_graphs_get_user ($id_user = 0, $only_names = false, $returnAllGr
|
||||||
|
|
||||||
function custom_graphs_print ($id_graph, $height, $width, $period, $stacked, $return = false, $date = 0) {
|
function custom_graphs_print ($id_graph, $height, $width, $period, $stacked, $return = false, $date = 0) {
|
||||||
global $config;
|
global $config;
|
||||||
|
|
||||||
$sources = db_get_all_rows_field_filter ('tgraph_source', 'id_graph', $id_graph);
|
$sources = db_get_all_rows_field_filter ('tgraph_source', 'id_graph', $id_graph);
|
||||||
$modules = array ();
|
$modules = array ();
|
||||||
$weights = array ();
|
$weights = array ();
|
||||||
|
|
|
@ -14,8 +14,8 @@
|
||||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
// GNU General Public License for more details.
|
// GNU General Public License for more details.
|
||||||
|
|
||||||
include_once($config["homedir"] . "/include/graphs/fgraph.php");
|
include_once($config['homedir'] . "/include/graphs/fgraph.php");
|
||||||
include_once($config["homedir"] . "/include/functions_reporting.php");
|
include_once($config['homedir'] . "/include/functions_reporting.php");
|
||||||
include_once($config['homedir'] . "/include/functions_agents.php");
|
include_once($config['homedir'] . "/include/functions_agents.php");
|
||||||
include_once($config['homedir'] . "/include/functions_modules.php");
|
include_once($config['homedir'] . "/include/functions_modules.php");
|
||||||
include_once($config['homedir'] . "/include/functions_users.php");
|
include_once($config['homedir'] . "/include/functions_users.php");
|
||||||
|
@ -30,10 +30,10 @@ function grafico_modulo_sparse ($agent_module_id, $period, $show_events,
|
||||||
$show_alerts = false, $avg_only = 0, $pure = false,
|
$show_alerts = false, $avg_only = 0, $pure = false,
|
||||||
$date = 0, $unit = '', $baseline = 0, $return_data = 0, $show_title = true,
|
$date = 0, $unit = '', $baseline = 0, $return_data = 0, $show_title = true,
|
||||||
$only_image = false, $homeurl = '', $ttl = 1, $projection = false, $adapt_key = '') {
|
$only_image = false, $homeurl = '', $ttl = 1, $projection = false, $adapt_key = '') {
|
||||||
|
|
||||||
global $config;
|
global $config;
|
||||||
global $graphic_type;
|
global $graphic_type;
|
||||||
|
|
||||||
enterprise_include_once("include/functions_reporting.php");
|
enterprise_include_once("include/functions_reporting.php");
|
||||||
|
|
||||||
// Set variables
|
// Set variables
|
||||||
|
@ -52,7 +52,7 @@ function grafico_modulo_sparse ($agent_module_id, $period, $show_events,
|
||||||
}
|
}
|
||||||
|
|
||||||
$flash_chart = $config['flash_charts'];
|
$flash_chart = $config['flash_charts'];
|
||||||
|
|
||||||
// Get event data (contains alert data too)
|
// Get event data (contains alert data too)
|
||||||
if ($show_events == 1 || $show_alerts == 1) {
|
if ($show_events == 1 || $show_alerts == 1) {
|
||||||
$events = db_get_all_rows_filter ('tevento',
|
$events = db_get_all_rows_filter ('tevento',
|
||||||
|
@ -65,7 +65,7 @@ function grafico_modulo_sparse ($agent_module_id, $period, $show_events,
|
||||||
$events = array ();
|
$events = array ();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get module data
|
// Get module data
|
||||||
$data = db_get_all_rows_filter ('tagente_datos',
|
$data = db_get_all_rows_filter ('tagente_datos',
|
||||||
array ('id_agente_modulo' => $agent_module_id,
|
array ('id_agente_modulo' => $agent_module_id,
|
||||||
|
@ -95,7 +95,7 @@ function grafico_modulo_sparse ($agent_module_id, $period, $show_events,
|
||||||
$previous_data['utimestamp'] = $datelimit;
|
$previous_data['utimestamp'] = $datelimit;
|
||||||
array_unshift ($data, $previous_data);
|
array_unshift ($data, $previous_data);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get next data
|
// Get next data
|
||||||
$nextData = modules_get_next_data ($agent_module_id, $date);
|
$nextData = modules_get_next_data ($agent_module_id, $date);
|
||||||
if ($nextData !== false) {
|
if ($nextData !== false) {
|
||||||
|
@ -111,7 +111,7 @@ function grafico_modulo_sparse ($agent_module_id, $period, $show_events,
|
||||||
|
|
||||||
$min_necessary = 2;
|
$min_necessary = 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check available data
|
// Check available data
|
||||||
if (count ($data) < $min_necessary) {
|
if (count ($data) < $min_necessary) {
|
||||||
if (!$graphic_type) {
|
if (!$graphic_type) {
|
||||||
|
@ -176,7 +176,7 @@ function grafico_modulo_sparse ($agent_module_id, $period, $show_events,
|
||||||
if ($interval_max === false) {
|
if ($interval_max === false) {
|
||||||
$interval_max = $data[$j]['datos'];
|
$interval_max = $data[$j]['datos'];
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($data[$j]['datos'] > $interval_max) {
|
if ($data[$j]['datos'] > $interval_max) {
|
||||||
$interval_max = $data[$j]['datos'];
|
$interval_max = $data[$j]['datos'];
|
||||||
} else if ($data[$j]['datos'] < $interval_min) {
|
} else if ($data[$j]['datos'] < $interval_min) {
|
||||||
|
@ -186,12 +186,12 @@ function grafico_modulo_sparse ($agent_module_id, $period, $show_events,
|
||||||
$count++;
|
$count++;
|
||||||
$j++;
|
$j++;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Data in the interval
|
// Data in the interval
|
||||||
if ($count > 0) {
|
if ($count > 0) {
|
||||||
$total /= $count;
|
$total /= $count;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 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;
|
||||||
|
@ -434,11 +434,11 @@ function graph_get_formatted_date($timestamp, $format1, $format2) {
|
||||||
* @return Mixed
|
* @return Mixed
|
||||||
*/
|
*/
|
||||||
function graphic_combined_module ($module_list, $weight_list, $period, $width, $height,
|
function graphic_combined_module ($module_list, $weight_list, $period, $width, $height,
|
||||||
$title, $unit_name, $show_events = 0, $show_alerts = 0, $pure = 0,
|
$title, $unit_name, $show_events = 0, $show_alerts = 0, $pure = 0,
|
||||||
$stacked = 0, $date = 0, $only_image = false, $homeurl = '', $ttl = 1, $projection = false, $prediction_period = false) {
|
$stacked = 0, $date = 0, $only_image = false, $homeurl = '', $ttl = 1, $projection = false, $prediction_period = false) {
|
||||||
global $config;
|
global $config;
|
||||||
global $graphic_type;
|
global $graphic_type;
|
||||||
|
|
||||||
$time_format_2 = '';
|
$time_format_2 = '';
|
||||||
$temp_range = $period;
|
$temp_range = $period;
|
||||||
|
|
||||||
|
@ -446,7 +446,7 @@ function graphic_combined_module ($module_list, $weight_list, $period, $width, $
|
||||||
if ($period < $prediction_period)
|
if ($period < $prediction_period)
|
||||||
$temp_range = $prediction_period;
|
$temp_range = $prediction_period;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Set the title and time format
|
// Set the title and time format
|
||||||
if ($temp_range <= 21600) {
|
if ($temp_range <= 21600) {
|
||||||
$time_format = 'H:i:s';
|
$time_format = 'H:i:s';
|
||||||
|
@ -470,13 +470,14 @@ function graphic_combined_module ($module_list, $weight_list, $period, $width, $
|
||||||
}
|
}
|
||||||
|
|
||||||
// Set variables
|
// Set variables
|
||||||
if ($date == 0) $date = get_system_time();
|
if ($date == 0)
|
||||||
|
$date = get_system_time();
|
||||||
$datelimit = $date - $period;
|
$datelimit = $date - $period;
|
||||||
$resolution = $config['graph_res'] * 50; //Number of points of the graph
|
$resolution = $config['graph_res'] * 50; //Number of points of the graph
|
||||||
$interval = (int) ($period / $resolution);
|
$interval = (int) ($period / $resolution);
|
||||||
|
|
||||||
// If projection graph, fill with zero previous data to projection interval
|
// If projection graph, fill with zero previous data to projection interval
|
||||||
if ($projection != false){
|
if ($projection != false) {
|
||||||
$j = $datelimit;
|
$j = $datelimit;
|
||||||
$in_range = true;
|
$in_range = true;
|
||||||
while ($in_range){
|
while ($in_range){
|
||||||
|
@ -484,23 +485,24 @@ function graphic_combined_module ($module_list, $weight_list, $period, $width, $
|
||||||
|
|
||||||
//$timestamp_f = date('d M Y H:i:s', $j);
|
//$timestamp_f = date('d M Y H:i:s', $j);
|
||||||
$before_projection[$timestamp_f] = 0;
|
$before_projection[$timestamp_f] = 0;
|
||||||
|
|
||||||
if ($j > $date){
|
if ($j > $date){
|
||||||
$in_range = false;
|
$in_range = false;
|
||||||
}
|
}
|
||||||
$j = $j + $interval;
|
$j = $j + $interval;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// Added support for projection graphs (normal_module + 1(prediction data))
|
|
||||||
if ($projection !== false){
|
|
||||||
$module_number = count ($module_list) + 1;
|
|
||||||
}else{
|
|
||||||
$module_number = count ($module_list);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Added support for projection graphs (normal_module + 1(prediction data))
|
||||||
|
if ($projection !== false) {
|
||||||
|
$module_number = count ($module_list) + 1;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$module_number = count ($module_list);
|
||||||
|
}
|
||||||
|
|
||||||
// interval - This is the number of "rows" we are divided the time to fill data.
|
// interval - This is the number of "rows" we are divided the time to fill data.
|
||||||
// more interval, more resolution, and slower.
|
// more interval, more resolution, and slower.
|
||||||
// periodo - Gap of time, in seconds. This is now to (now-periodo) secs
|
// periodo - Gap of time, in seconds. This is now to (now-periodo) secs
|
||||||
|
|
||||||
// Init weights
|
// Init weights
|
||||||
|
@ -509,27 +511,27 @@ function graphic_combined_module ($module_list, $weight_list, $period, $width, $
|
||||||
$weight_list[$i] = 1;
|
$weight_list[$i] = 1;
|
||||||
}
|
}
|
||||||
else if ($weight_list[$i] == 0) {
|
else if ($weight_list[$i] == 0) {
|
||||||
$weight_list[$i] = 1;
|
$weight_list[$i] = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Set data containers
|
// Set data containers
|
||||||
for ($i = 0; $i < $resolution; $i++) {
|
for ($i = 0; $i < $resolution; $i++) {
|
||||||
$timestamp = $datelimit + ($interval * $i);/*
|
$timestamp = $datelimit + ($interval * $i);/*
|
||||||
$timestamp_short = date($time_format, $timestamp);
|
$timestamp_short = date($time_format, $timestamp);
|
||||||
$long_index[$timestamp_short] = date(
|
$long_index[$timestamp_short] = date(
|
||||||
html_entity_decode($config['date_format'], ENT_QUOTES, "UTF-8"), $timestamp);
|
html_entity_decode($config['date_format'], ENT_QUOTES, "UTF-8"), $timestamp);
|
||||||
$timestamp = $timestamp_short;*/
|
$timestamp = $timestamp_short;*/
|
||||||
|
|
||||||
$graph[$timestamp]['count'] = 0;
|
$graph[$timestamp]['count'] = 0;
|
||||||
$graph[$timestamp]['timestamp_bottom'] = $timestamp;
|
$graph[$timestamp]['timestamp_bottom'] = $timestamp;
|
||||||
$graph[$timestamp]['timestamp_top'] = $timestamp + $interval;
|
$graph[$timestamp]['timestamp_top'] = $timestamp + $interval;
|
||||||
$graph[$timestamp]['min'] = 0;
|
$graph[$timestamp]['min'] = 0;
|
||||||
$graph[$timestamp]['max'] = 0;
|
$graph[$timestamp]['max'] = 0;
|
||||||
$graph[$timestamp]['event'] = 0;
|
$graph[$timestamp]['event'] = 0;
|
||||||
$graph[$timestamp]['alert'] = 0;
|
$graph[$timestamp]['alert'] = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
$long_index = array();
|
$long_index = array();
|
||||||
|
|
||||||
$graph_values = array();
|
$graph_values = array();
|
||||||
|
@ -538,31 +540,56 @@ function graphic_combined_module ($module_list, $weight_list, $period, $width, $
|
||||||
// Calculate data for each module
|
// Calculate data for each module
|
||||||
for ($i = 0; $i < $module_number; $i++) {
|
for ($i = 0; $i < $module_number; $i++) {
|
||||||
// If its a projection graph, first module will be data and second will be the projection
|
// If its a projection graph, first module will be data and second will be the projection
|
||||||
if ($projection != false and $i != 0) {
|
if ($projection != false && $i != 0) {
|
||||||
$agent_module_id = $module_list[0];
|
$agent_module_id = $module_list[0];
|
||||||
$agent_name = modules_get_agentmodule_agent_name ($agent_module_id);
|
|
||||||
|
//Get and process agent name
|
||||||
|
$agent_name = io_safe_output(
|
||||||
|
modules_get_agentmodule_agent_name ($agent_module_id));
|
||||||
|
$agent_name = ui_print_truncate_text($agent_name, 'agent_small', false, true, false, '...', false);
|
||||||
|
|
||||||
|
|
||||||
$agent_id = agents_get_agent_id ($agent_name);
|
$agent_id = agents_get_agent_id ($agent_name);
|
||||||
$module_name = "projection for " . io_safe_output(modules_get_agentmodule_name ($agent_module_id));
|
|
||||||
$module_name_list[$i] = substr($agent_name, 0,80) ." / ".substr ($module_name, 0, 40);
|
|
||||||
|
//Get and process module name
|
||||||
|
$module_name = io_safe_output(
|
||||||
|
modules_get_agentmodule_name ($agent_module_id));
|
||||||
|
$module_name = sprintf(__("projection for %s"), $module_name);
|
||||||
|
$module_name = ui_print_truncate_text($module_name, 'module_small', false, true, false, '...', false);
|
||||||
|
|
||||||
|
|
||||||
|
$module_name_list[$i] = $agent_name ." / ". $module_name;
|
||||||
$id_module_type = modules_get_agentmodule_type ($agent_module_id);
|
$id_module_type = modules_get_agentmodule_type ($agent_module_id);
|
||||||
$module_type = modules_get_moduletype_name ($id_module_type);
|
$module_type = modules_get_moduletype_name ($id_module_type);
|
||||||
$uncompressed_module = is_module_uncompressed ($module_type);
|
$uncompressed_module = is_module_uncompressed ($module_type);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
$agent_module_id = $module_list[$i];
|
$agent_module_id = $module_list[$i];
|
||||||
$agent_name = modules_get_agentmodule_agent_name ($agent_module_id);
|
|
||||||
|
//Get and process agent name
|
||||||
|
$agent_name = io_safe_output(
|
||||||
|
modules_get_agentmodule_agent_name ($agent_module_id));
|
||||||
|
$agent_name = ui_print_truncate_text($agent_name, 'agent_small', false, true, false, '...', false);
|
||||||
|
|
||||||
|
|
||||||
$agent_id = agents_get_agent_id ($agent_name);
|
$agent_id = agents_get_agent_id ($agent_name);
|
||||||
$module_name = io_safe_output(modules_get_agentmodule_name ($agent_module_id));
|
|
||||||
$module_name_list[$i] = substr($agent_name, 0,80) ." / ".substr ($module_name, 0, 40);
|
//Get and process module name
|
||||||
|
$module_name = io_safe_output(
|
||||||
|
modules_get_agentmodule_name ($agent_module_id));
|
||||||
|
$module_name = ui_print_truncate_text($module_name, 'module_small', false, true, false, '...', false);
|
||||||
|
|
||||||
|
$module_name_list[$i] = $agent_name . " / " . $module_name;
|
||||||
$id_module_type = modules_get_agentmodule_type ($agent_module_id);
|
$id_module_type = modules_get_agentmodule_type ($agent_module_id);
|
||||||
$module_type = modules_get_moduletype_name ($id_module_type);
|
$module_type = modules_get_moduletype_name ($id_module_type);
|
||||||
$uncompressed_module = is_module_uncompressed ($module_type);
|
$uncompressed_module = is_module_uncompressed ($module_type);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($uncompressed_module) {
|
if ($uncompressed_module) {
|
||||||
$avg_only = 1;
|
$avg_only = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get event data (contains alert data too)
|
// Get event data (contains alert data too)
|
||||||
if ($show_events == 1 || $show_alerts == 1) {
|
if ($show_events == 1 || $show_alerts == 1) {
|
||||||
$events = db_get_all_rows_filter ('tevento',
|
$events = db_get_all_rows_filter ('tevento',
|
||||||
|
@ -575,7 +602,7 @@ function graphic_combined_module ($module_list, $weight_list, $period, $width, $
|
||||||
$events = array ();
|
$events = array ();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get module data
|
// Get module data
|
||||||
$data = db_get_all_rows_filter ('tagente_datos',
|
$data = db_get_all_rows_filter ('tagente_datos',
|
||||||
array ('id_agente_modulo' => $agent_module_id,
|
array ('id_agente_modulo' => $agent_module_id,
|
||||||
|
@ -586,20 +613,21 @@ function graphic_combined_module ($module_list, $weight_list, $period, $width, $
|
||||||
if ($data === false) {
|
if ($data === false) {
|
||||||
$data = array ();
|
$data = array ();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Uncompressed module data
|
// Uncompressed module data
|
||||||
if ($uncompressed_module) {
|
if ($uncompressed_module) {
|
||||||
$min_necessary = 1;
|
$min_necessary = 1;
|
||||||
|
|
||||||
// Compressed module data
|
// Compressed module data
|
||||||
} else {
|
}
|
||||||
|
else {
|
||||||
// Get previous data
|
// Get previous data
|
||||||
$previous_data = modules_get_previous_data ($agent_module_id, $datelimit);
|
$previous_data = modules_get_previous_data ($agent_module_id, $datelimit);
|
||||||
if ($previous_data !== false) {
|
if ($previous_data !== false) {
|
||||||
$previous_data['utimestamp'] = $datelimit;
|
$previous_data['utimestamp'] = $datelimit;
|
||||||
array_unshift ($data, $previous_data);
|
array_unshift ($data, $previous_data);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get next data
|
// Get next data
|
||||||
$nextData = modules_get_next_data ($agent_module_id, $date);
|
$nextData = modules_get_next_data ($agent_module_id, $date);
|
||||||
if ($nextData !== false) {
|
if ($nextData !== false) {
|
||||||
|
@ -622,13 +650,13 @@ function graphic_combined_module ($module_list, $weight_list, $period, $width, $
|
||||||
if (count ($data) < $min_necessary) {
|
if (count ($data) < $min_necessary) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Data iterator
|
// Data iterator
|
||||||
$j = 0;
|
$j = 0;
|
||||||
|
|
||||||
// Event iterator
|
// Event iterator
|
||||||
$k = 0;
|
$k = 0;
|
||||||
|
|
||||||
// Set initial conditions
|
// Set initial conditions
|
||||||
|
|
||||||
//$graph_values[$i] = array();
|
//$graph_values[$i] = array();
|
||||||
|
@ -641,7 +669,7 @@ function graphic_combined_module ($module_list, $weight_list, $period, $width, $
|
||||||
else {
|
else {
|
||||||
$previous_data = 0;
|
$previous_data = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
$max = 0;
|
$max = 0;
|
||||||
$min = null;
|
$min = null;
|
||||||
$avg = 0;
|
$avg = 0;
|
||||||
|
@ -653,11 +681,11 @@ function graphic_combined_module ($module_list, $weight_list, $period, $width, $
|
||||||
|
|
||||||
$timestamp = $datelimit + ($interval * $l);
|
$timestamp = $datelimit + ($interval * $l);
|
||||||
$timestamp_short = graph_get_formatted_date($timestamp, $time_format, $time_format_2);
|
$timestamp_short = graph_get_formatted_date($timestamp, $time_format, $time_format_2);
|
||||||
|
|
||||||
$long_index[$timestamp_short] = date(
|
$long_index[$timestamp_short] = date(
|
||||||
html_entity_decode($config['date_format'], ENT_QUOTES, "UTF-8"), $timestamp);
|
html_entity_decode($config['date_format'], ENT_QUOTES, "UTF-8"), $timestamp);
|
||||||
//$timestamp = $timestamp_short;
|
//$timestamp = $timestamp_short;
|
||||||
|
|
||||||
$total = 0;
|
$total = 0;
|
||||||
$count = 0;
|
$count = 0;
|
||||||
|
|
||||||
|
@ -667,19 +695,20 @@ function graphic_combined_module ($module_list, $weight_list, $period, $width, $
|
||||||
while (isset ($data[$j]) && $data[$j]['utimestamp'] >= $timestamp && $data[$j]['utimestamp'] < ($timestamp + $interval)) {
|
while (isset ($data[$j]) && $data[$j]['utimestamp'] >= $timestamp && $data[$j]['utimestamp'] < ($timestamp + $interval)) {
|
||||||
if ($data[$j]['datos'] > $interval_max) {
|
if ($data[$j]['datos'] > $interval_max) {
|
||||||
$interval_max = $data[$j]['datos'];
|
$interval_max = $data[$j]['datos'];
|
||||||
} else if ($data[$j]['datos'] < $interval_max) {
|
}
|
||||||
|
else if ($data[$j]['datos'] < $interval_max) {
|
||||||
$interval_min = $data[$j]['datos'];
|
$interval_min = $data[$j]['datos'];
|
||||||
}
|
}
|
||||||
$total += $data[$j]['datos'];
|
$total += $data[$j]['datos'];
|
||||||
$count++;
|
$count++;
|
||||||
$j++;
|
$j++;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Average
|
// Average
|
||||||
if ($count > 0) {
|
if ($count > 0) {
|
||||||
$total /= $count;
|
$total /= $count;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 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;
|
||||||
|
@ -692,15 +721,16 @@ function graphic_combined_module ($module_list, $weight_list, $period, $width, $
|
||||||
}
|
}
|
||||||
$k++;
|
$k++;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Data
|
// Data
|
||||||
if ($count > 0) {
|
if ($count > 0) {
|
||||||
//$graph_values[$i][$timestamp] = $total * $weight_list[$i];
|
//$graph_values[$i][$timestamp] = $total * $weight_list[$i];
|
||||||
$temp_graph_values[$timestamp_short] = $total * $weight_list[$i];
|
$temp_graph_values[$timestamp_short] = $total * $weight_list[$i];
|
||||||
|
|
||||||
$previous_data = $total;
|
$previous_data = $total;
|
||||||
// Compressed data
|
}
|
||||||
} else {
|
else {
|
||||||
|
// Compressed data
|
||||||
if ($uncompressed_module || ($timestamp > time ())) {
|
if ($uncompressed_module || ($timestamp > time ())) {
|
||||||
//$graph_values[$i][$timestamp] = 0;
|
//$graph_values[$i][$timestamp] = 0;
|
||||||
$temp_graph_values[$timestamp_short] = 0;
|
$temp_graph_values[$timestamp_short] = 0;
|
||||||
|
@ -728,12 +758,12 @@ function graphic_combined_module ($module_list, $weight_list, $period, $width, $
|
||||||
|
|
||||||
// Added to support projection graphs
|
// Added to support projection graphs
|
||||||
if ($projection != false and $i != 0) {
|
if ($projection != false and $i != 0) {
|
||||||
$projection_data = array();
|
$projection_data = array();
|
||||||
$projection_data = array_merge($before_projection, $projection);
|
$projection_data = array_merge($before_projection, $projection);
|
||||||
$graph_values[$i] = $projection_data;
|
$graph_values[$i] = $projection_data;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
$graph_values[$i] = $temp_graph_values;
|
$graph_values[$i] = $temp_graph_values;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -758,17 +788,16 @@ function graphic_combined_module ($module_list, $weight_list, $period, $width, $
|
||||||
//unset($graph_values[$i]);
|
//unset($graph_values[$i]);
|
||||||
|
|
||||||
//$graph_values[$i] = $graph_values[$i];
|
//$graph_values[$i] = $graph_values[$i];
|
||||||
|
|
||||||
}
|
}
|
||||||
$temp = array();
|
$temp = array();
|
||||||
|
|
||||||
foreach ($graph_values as $graph_group => $point) {
|
foreach ($graph_values as $graph_group => $point) {
|
||||||
foreach ($point as $timestamp_point => $point_value) {
|
foreach ($point as $timestamp_point => $point_value) {
|
||||||
$temp[$timestamp_point][$graph_group] = $point_value;
|
$temp[$timestamp_point][$graph_group] = $point_value;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$graph_values = $temp;
|
$graph_values = $temp;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
for ($i = 0; $i < $module_number; $i++) {
|
for ($i = 0; $i < $module_number; $i++) {
|
||||||
if ($weight_list[$i] != 1) {
|
if ($weight_list[$i] != 1) {
|
||||||
|
@ -776,23 +805,27 @@ function graphic_combined_module ($module_list, $weight_list, $period, $width, $
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
*/
|
*/
|
||||||
|
|
||||||
$flash_charts = $config['flash_charts'];
|
$flash_charts = $config['flash_charts'];
|
||||||
|
|
||||||
if ($only_image) {
|
if ($only_image) {
|
||||||
$flash_charts = false;
|
$flash_charts = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
$water_mark = array('file' => $config['homedir'] . "/images/logo_vertical_water.png",
|
$water_mark = array('file' => $config['homedir'] . "/images/logo_vertical_water.png",
|
||||||
'url' => $config['homeurl'] . "/images/logo_vertical_water.png");
|
'url' => $config['homeurl'] . "/images/logo_vertical_water.png");
|
||||||
|
|
||||||
|
|
||||||
|
//Work around for fixed the agents name with huge size chars.
|
||||||
|
$fixed_font_size = $config['font_size'] - 1;
|
||||||
|
|
||||||
switch ($stacked) {
|
switch ($stacked) {
|
||||||
case GRAPH_AREA:
|
case GRAPH_AREA:
|
||||||
$color = null;
|
$color = null;
|
||||||
return area_graph($flash_charts, $graph_values, $width, $height,
|
return area_graph($flash_charts, $graph_values, $width, $height,
|
||||||
$color, $module_name_list, $long_index, $homeurl."images/image_problem.opaque.png",
|
$color, $module_name_list, $long_index, $homeurl."images/image_problem.opaque.png",
|
||||||
"", "", $homeurl, $water_mark,
|
"", "", $homeurl, $water_mark,
|
||||||
$config['fontpath'], $config['font_size'], "", $ttl);
|
$config['fontpath'], $fixed_font_size, "", $ttl);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
case GRAPH_STACKED_AREA:
|
case GRAPH_STACKED_AREA:
|
||||||
|
@ -800,21 +833,21 @@ function graphic_combined_module ($module_list, $weight_list, $period, $width, $
|
||||||
return stacked_area_graph($flash_charts, $graph_values, $width, $height,
|
return stacked_area_graph($flash_charts, $graph_values, $width, $height,
|
||||||
$color, $module_name_list, $long_index, $homeurl."images/image_problem.opaque.png",
|
$color, $module_name_list, $long_index, $homeurl."images/image_problem.opaque.png",
|
||||||
"", "", $water_mark,
|
"", "", $water_mark,
|
||||||
$config['fontpath'], $config['font_size'], "", $ttl, $homeurl);
|
$config['fontpath'], $fixed_font_size, "", $ttl, $homeurl);
|
||||||
break;
|
break;
|
||||||
case GRAPH_LINE:
|
case GRAPH_LINE:
|
||||||
$color = null;
|
$color = null;
|
||||||
return line_graph($flash_charts, $graph_values, $width, $height,
|
return line_graph($flash_charts, $graph_values, $width, $height,
|
||||||
$color, $module_name_list, $long_index, $homeurl."images/image_problem.opaque.png",
|
$color, $module_name_list, $long_index, $homeurl."images/image_problem.opaque.png",
|
||||||
"", "", $water_mark,
|
"", "", $water_mark,
|
||||||
$config['fontpath'], $config['font_size'], "", $ttl, $homeurl);
|
$config['fontpath'], $fixed_font_size, "", $ttl, $homeurl);
|
||||||
break;
|
break;
|
||||||
case GRAPH_STACKED_LINE:
|
case GRAPH_STACKED_LINE:
|
||||||
$color = null;
|
$color = null;
|
||||||
return stacked_line_graph($flash_charts, $graph_values, $width, $height,
|
return stacked_line_graph($flash_charts, $graph_values, $width, $height,
|
||||||
$color, $module_name_list, $long_index, $homeurl."images/image_problem.opaque.png",
|
$color, $module_name_list, $long_index, $homeurl."images/image_problem.opaque.png",
|
||||||
"", "", $water_mark,
|
"", "", $water_mark,
|
||||||
$config['fontpath'], $config['font_size'], "", $ttl, $homeurl);
|
$config['fontpath'], $fixed_font_size, "", $ttl, $homeurl);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue