2011-03-30 14:34:25 +02:00
< ? php
2019-05-09 16:26:38 +02:00
/**
* Extension to manage a list of gateways and the node address where they should
* point to .
*
* @ category Graphs
* @ package Pandora FMS
* @ subpackage Community
* @ version 1.0 . 0
* @ license See below
*
* ______ ___ _______ _______ ________
2023-06-08 12:42:10 +02:00
* | __ \ .-----.--.--.--| |.-----.----.-----. | ___ | | | __ |
* | __ /| _ | | _ || _ | _ | _ | | ___ | | __ |
2019-05-09 16:26:38 +02:00
* | ___ | | ___ . _ | __ | __ | _____ || _____ | __ | | ___ . _ | | ___ | | __ | _ | __ | _______ |
*
* ============================================================================
2023-06-08 11:53:13 +02:00
* Copyright ( c ) 2005 - 2023 Pandora FMS
2023-06-08 13:19:01 +02:00
* Please see https :// pandorafms . com / community / for full contribution list
2019-05-09 16:26:38 +02:00
* 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 for 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 .
* ============================================================================
*/
2011-03-30 14:34:25 +02:00
2023-11-07 13:18:44 +01:00
use Models\VisualConsole\Items\Percentile ;
2019-01-30 16:18:44 +01:00
require_once $config [ 'homedir' ] . '/include/graphs/fgraph.php' ;
require_once $config [ 'homedir' ] . '/include/functions_reporting.php' ;
require_once $config [ 'homedir' ] . '/include/functions_agents.php' ;
require_once $config [ 'homedir' ] . '/include/functions_modules.php' ;
require_once $config [ 'homedir' ] . '/include/functions_users.php' ;
2019-05-09 16:26:38 +02:00
/**
* Function for retun data extract aand uncompressed bbdd .
*
* @ param integer $agent_module_id ID .
* @ param array $date_array Date stasrt finish and period .
* @ param array $data_module_graph Data module .
* @ param array $params Params graphs .
* @ param integer $series_suffix Int .
*
* @ return array Return data module .
*/
2019-01-30 16:18:44 +01:00
function grafico_modulo_sparse_data_chart (
$agent_module_id ,
$date_array ,
$data_module_graph ,
$params ,
$series_suffix
) {
global $config ;
2019-05-09 16:26:38 +02:00
// To avoid showing all the data at the same time which can be reloaded,
// a system of boxes is made starting from a constant = 250
// and the selected period of time in addition to being able to reduce
// the level of boxes, that is, increasing the level of detail of the graph
// until the full option that would show all the points (data)
// that that period contains.
2019-01-30 16:18:44 +01:00
$data_slice = ( $date_array [ 'period' ] / ( 250 * $params [ 'zoom' ]));
if ( $data_module_graph [ 'id_module_type' ] == 23
|| $data_module_graph [ 'id_module_type' ] == 3
|| $data_module_graph [ 'id_module_type' ] == 17
|| $data_module_graph [ 'id_module_type' ] == 10
|| $data_module_graph [ 'id_module_type' ] == 33
) {
$data = db_get_all_rows_filter (
'tagente_datos_string' ,
[ 'id_agente_modulo' => ( int ) $agent_module_id ,
" utimestamp > ' " . $date_array [ 'start_date' ] . " ' " ,
" utimestamp < ' " . $date_array [ 'final_date' ] . " ' " ,
'group' => " ROUND(utimestamp / $data_slice ) " ,
'order' => 'utimestamp ASC'
],
[
'count(*) as datos' ,
'min(utimestamp) as utimestamp' ,
],
'AND' ,
$data_module_graph [ 'history_db' ]
);
} else {
// all points(data) and boolean
if ( $data_module_graph [ 'id_module_type' ] == 2
|| $data_module_graph [ 'id_module_type' ] == 6
|| $data_module_graph [ 'id_module_type' ] == 21
|| $data_module_graph [ 'id_module_type' ] == 18
|| $data_module_graph [ 'id_module_type' ] == 9
|| $data_module_graph [ 'id_module_type' ] == 31
|| $data_module_graph [ 'id_module_type' ] == 100
) {
$data = db_get_all_rows_filter (
'tagente_datos' ,
[ 'id_agente_modulo' => ( int ) $agent_module_id ,
" utimestamp > ' " . $date_array [ 'start_date' ] . " ' " ,
" utimestamp < ' " . $date_array [ 'final_date' ] . " ' " ,
'order' => 'utimestamp ASC'
],
[
'datos' ,
'utimestamp' ,
],
'AND' ,
$data_module_graph [ 'history_db' ]
);
}
}
if ( $data === false ) {
$data = [];
}
2019-05-09 16:26:38 +02:00
// Get previous data.
2019-01-30 16:18:44 +01:00
$previous_data = modules_get_previous_data (
$agent_module_id ,
$date_array [ 'start_date' ]
);
if ( $previous_data !== false ) {
$previous_data [ 'utimestamp' ] = $date_array [ 'start_date' ];
unset ( $previous_data [ 'id_agente_modulo' ]);
array_unshift ( $data , $previous_data );
}
2019-05-09 16:26:38 +02:00
// Get next data.
2019-01-30 16:18:44 +01:00
$nextData = modules_get_next_data (
$agent_module_id ,
$date_array [ 'final_date' ]
);
if ( $nextData !== false ) {
unset ( $nextData [ 'id_agente_modulo' ]);
array_push ( $data , $nextData );
} else if ( count ( $data ) > 0 ) {
2019-05-09 16:26:38 +02:00
// Propagate the last known data to the end of the interval.
2019-01-30 16:18:44 +01:00
$nextData = [
'datos' => $data [( count ( $data ) - 1 )][ 'datos' ],
'utimestamp' => $date_array [ 'final_date' ],
];
array_push ( $data , $nextData );
}
2019-05-09 16:26:38 +02:00
// Check available data.
2019-01-30 16:18:44 +01:00
if ( count ( $data ) < 1 ) {
return false ;
}
$array_data = [];
$min_value = ( PHP_INT_MAX - 1 );
$max_value = ( PHP_INT_MIN + 1 );
$array_percentil = [];
foreach ( $data as $k => $v ) {
2019-05-09 16:26:38 +02:00
// Convert array.
2019-01-30 16:18:44 +01:00
if ( $params [ 'flag_overlapped' ]) {
$array_data [ 'sum' . $series_suffix ][ 'data' ][ $k ] = [
(( $v [ 'utimestamp' ] + $date_array [ 'period' ] ) * 1000 ),
$v [ 'datos' ],
];
} else {
$array_data [ 'sum' . $series_suffix ][ 'data' ][ $k ] = [
( $v [ 'utimestamp' ] * 1000 ),
$v [ 'datos' ],
];
}
2019-05-09 16:26:38 +02:00
// Min.
2019-01-30 16:18:44 +01:00
if ( $min_value > $v [ 'datos' ]) {
$min_value = $v [ 'datos' ];
}
2019-05-09 16:26:38 +02:00
// Max.
2019-01-30 16:18:44 +01:00
if ( $max_value < $v [ 'datos' ]) {
$max_value = $v [ 'datos' ];
}
2019-05-09 16:26:38 +02:00
// Avg.
2019-01-30 16:18:44 +01:00
$sum_data += $v [ 'datos' ];
$count_data ++ ;
2019-05-09 16:26:38 +02:00
// Percentil.
if ( ! isset ( $params [ 'percentil' ]) && $params [ 'percentil' ]) {
2019-01-30 16:18:44 +01:00
$array_percentil [] = $v [ 'datos' ];
}
}
2019-05-09 16:26:38 +02:00
$array_data [ 'sum' . $series_suffix ][ 'min' ] = $min_value ;
$array_data [ 'sum' . $series_suffix ][ 'max' ] = $max_value ;
$array_data [ 'sum' . $series_suffix ][ 'avg' ] = ( $sum_data / $count_data );
2019-01-30 16:18:44 +01:00
$array_data [ 'sum' . $series_suffix ][ 'agent_module_id' ] = $agent_module_id ;
$array_data [ 'sum' . $series_suffix ][ 'id_module_type' ] = $data_module_graph [ 'id_module_type' ];
2019-05-09 16:26:38 +02:00
$array_data [ 'sum' . $series_suffix ][ 'agent_name' ] = $data_module_graph [ 'agent_name' ];
$array_data [ 'sum' . $series_suffix ][ 'module_name' ] = $data_module_graph [ 'module_name' ];
$array_data [ 'sum' . $series_suffix ][ 'agent_alias' ] = $data_module_graph [ 'agent_alias' ];
2019-01-30 16:18:44 +01:00
2019-05-09 16:26:38 +02:00
if ( ! isset ( $params [ 'percentil' ])
2019-01-30 16:18:44 +01:00
&& $params [ 'percentil' ]
&& ! $params [ 'flag_overlapped' ]
) {
2019-05-09 16:26:38 +02:00
$percentil_result = get_percentile (
$params [ 'percentil' ],
$array_percentil
);
2019-01-30 16:18:44 +01:00
$array_data [ 'percentil' . $series_suffix ][ 'data' ][ 0 ] = [
( $date_array [ 'start_date' ] * 1000 ),
$percentil_result ,
];
$array_data [ 'percentil' . $series_suffix ][ 'data' ][ 1 ] = [
( $date_array [ 'final_date' ] * 1000 ),
$percentil_result ,
];
$array_data [ 'percentil' . $series_suffix ][ 'agent_module_id' ] = $agent_module_id ;
}
return $array_data ;
2018-02-21 11:54:24 +01:00
}
2019-01-30 16:18:44 +01:00
2019-05-09 16:26:38 +02:00
/**
* Prepare data for send to function js paint charts .
*
* @ param integer $agent_module_id ID .
* @ param array $date_array Date stasrt finish and period .
* @ param array $data_module_graph Data module .
* @ param array $params Params graphs .
* @ param integer $series_suffix Int .
*
* @ return array Prepare data to paint js .
*/
2018-02-27 16:28:00 +01:00
function grafico_modulo_sparse_data (
2019-01-30 16:18:44 +01:00
$agent_module_id ,
$date_array ,
$data_module_graph ,
$params ,
$series_suffix
) {
global $config ;
global $array_events_alerts ;
if ( $params [ 'fullscale' ]) {
$array_data = fullscale_data (
$agent_module_id ,
$date_array ,
$params [ 'show_unknown' ],
$params [ 'percentil' ],
$series_suffix ,
$params [ 'flag_overlapped' ],
false ,
$params [ 'type_mode_graph' ]
);
} else {
2019-05-09 16:26:38 +02:00
// Uncompress data except boolean and string.
2019-01-30 16:18:44 +01:00
if ( $data_module_graph [ 'id_module_type' ] == 23
|| $data_module_graph [ 'id_module_type' ] == 3
|| $data_module_graph [ 'id_module_type' ] == 17
|| $data_module_graph [ 'id_module_type' ] == 10
|| $data_module_graph [ 'id_module_type' ] == 33
|| $data_module_graph [ 'id_module_type' ] == 2
|| $data_module_graph [ 'id_module_type' ] == 6
|| $data_module_graph [ 'id_module_type' ] == 21
|| $data_module_graph [ 'id_module_type' ] == 18
|| $data_module_graph [ 'id_module_type' ] == 9
|| $data_module_graph [ 'id_module_type' ] == 31
|| $data_module_graph [ 'id_module_type' ] == 100
) {
2020-10-01 15:29:54 +02:00
$array_data = grafico_modulo_sparse_data_chart (
$agent_module_id ,
$date_array ,
$data_module_graph ,
$params ,
$series_suffix
);
2019-01-30 16:18:44 +01:00
} else {
2019-05-09 16:26:38 +02:00
$data_slice = ( $date_array [ 'period' ] / ( 250 * $params [ 'zoom' ]) + 100 );
2019-01-30 16:18:44 +01:00
$array_data = fullscale_data (
$agent_module_id ,
$date_array ,
$params [ 'show_unknown' ],
$params [ 'percentil' ],
$series_suffix ,
$params [ 'flag_overlapped' ],
2019-05-09 16:26:38 +02:00
$data_slice ,
2019-01-30 16:18:44 +01:00
$params [ 'type_mode_graph' ]
);
}
}
2020-10-01 15:29:54 +02:00
if ( empty ( $array_data ) === true ) {
return [];
}
2019-06-03 15:37:05 +02:00
if ( $array_data === false && ( ! $params [ 'graph_combined' ]
2019-02-18 16:34:48 +01:00
&& ! isset ( $array_data [ 'sum1' ][ 'data' ][ 0 ][ 1 ]) && ! $params [ 'baseline' ])
) {
2019-01-30 16:18:44 +01:00
return false ;
}
2020-10-02 14:16:55 +02:00
if (( int ) $params [ 'type_mode_graph' ] !== 2
&& ( int ) $params [ 'type_mode_graph' ] !== 3
) {
2019-09-27 12:07:40 +02:00
$array_data = series_suffix_leyend (
2020-10-02 14:16:55 +02:00
'sum' ,
2019-09-27 12:07:40 +02:00
$series_suffix ,
$agent_module_id ,
$data_module_graph ,
$array_data
);
2019-09-26 17:51:26 +02:00
}
2020-10-02 14:16:55 +02:00
if ( $params [ 'percentil' ]) {
2019-09-27 12:07:40 +02:00
$array_data = series_suffix_leyend (
2020-10-02 14:16:55 +02:00
'percentil' ,
2019-09-27 12:07:40 +02:00
$series_suffix ,
$agent_module_id ,
$data_module_graph ,
$array_data
);
2020-10-02 14:16:55 +02:00
}
2019-09-26 17:51:26 +02:00
2020-10-02 14:16:55 +02:00
if ( $params [ 'type_mode_graph' ] > 0 ) {
if (( int ) $params [ 'type_mode_graph' ] === 1
|| ( int ) $params [ 'type_mode_graph' ] === 3
) {
$array_data = series_suffix_leyend (
'min' ,
$series_suffix ,
$agent_module_id ,
$data_module_graph ,
$array_data
);
}
if (( int ) $params [ 'type_mode_graph' ] === 1
|| ( int ) $params [ 'type_mode_graph' ] === 2
) {
$array_data = series_suffix_leyend (
'max' ,
$series_suffix ,
$agent_module_id ,
$data_module_graph ,
$array_data
);
}
2019-09-18 11:15:55 +02:00
}
2019-05-09 16:26:38 +02:00
// This is for a specific type of report that consists in passing
// an interval and doing the average sum and avg.
2019-01-30 16:18:44 +01:00
if ( $params [ 'force_interval' ] != '' ) {
$period_time_interval = ( $date_array [ 'period' ] * 1000 );
$start_period = ( $date_array [ 'start_date' ] * 1000 );
$i = 0 ;
$sum_data = 0 ;
$count_data = 0 ;
$data_last_acum = $array_data [ 'sum1' ][ 'data' ][ 0 ][ 1 ];
2022-02-07 13:38:45 +01:00
$array_data_only = [];
2019-01-30 16:18:44 +01:00
while ( $period_time_interval > 0 ) {
foreach ( $array_data [ 'sum1' ][ 'data' ] as $key => $value ) {
2019-05-09 16:26:38 +02:00
if ( $value [ 0 ] >= $start_period
&& $value [ 0 ] < ( $start_period + $params [ 'time_interval' ] * 1000 )
) {
2019-01-30 16:18:44 +01:00
$sum_data = $value [ 1 ];
$array_data_only [] = $value [ 1 ];
$count_data ++ ;
unset ( $array_data [ 'sum1' ][ 'data' ][ $key ]);
} else {
if ( $params [ 'force_interval' ] == 'max_only' ) {
$acum_array_data [ $i ][ 0 ] = $start_period ;
2019-05-09 16:26:38 +02:00
if ( is_array ( $array_data_only )
&& count ( $array_data_only ) > 0
) {
2019-01-30 16:18:44 +01:00
$acum_array_data [ $i ][ 1 ] = max ( $array_data_only );
$data_last_acum = $array_data_only [( count ( $array_data_only ) - 1 )];
} else {
$acum_array_data [ $i ][ 1 ] = $data_last_acum ;
}
}
if ( $params [ 'force_interval' ] == 'min_only' ) {
$acum_array_data [ $i ][ 0 ] = $start_period ;
2019-05-09 16:26:38 +02:00
if ( is_array ( $array_data_only )
&& count ( $array_data_only ) > 0
) {
2019-01-30 16:18:44 +01:00
$acum_array_data [ $i ][ 1 ] = min ( $array_data_only );
$data_last_acum = $array_data_only [( count ( $array_data_only ) - 1 )];
} else {
$acum_array_data [ $i ][ 1 ] = $data_last_acum ;
}
}
if ( $params [ 'force_interval' ] == 'avg_only' ) {
$acum_array_data [ $i ][ 0 ] = $start_period ;
2019-05-09 16:26:38 +02:00
if ( is_array ( $array_data_only )
&& count ( $array_data_only ) > 0
) {
2019-01-30 16:18:44 +01:00
$acum_array_data [ $i ][ 1 ] = ( $sum_data / $count_data );
} else {
$acum_array_data [ $i ][ 1 ] = $data_last_acum ;
}
}
$start_period = ( $start_period + $params [ 'time_interval' ] * 1000 );
$array_data_only = [];
$sum_data = 0 ;
$count_data = 0 ;
$i ++ ;
break ;
}
}
$period_time_interval = ( $period_time_interval - $params [ 'time_interval' ]);
}
2019-05-09 16:26:38 +02:00
// Drag the last value to paint the graph correctly.
2019-01-30 16:18:44 +01:00
$acum_array_data [] = [
0 => $start_period ,
1 => $acum_array_data [( $i - 1 )][ 1 ],
];
$array_data [ 'sum1' ][ 'data' ] = $acum_array_data ;
}
$events = [];
if ( isset ( $array_data [ 'sum' . $series_suffix ][ 'max' ])) {
$max = $array_data [ 'sum' . $series_suffix ][ 'max' ];
$min = $array_data [ 'sum' . $series_suffix ][ 'min' ];
$avg = $array_data [ 'sum' . $series_suffix ][ 'avg' ];
}
if ( ! $params [ 'flag_overlapped' ]) {
if ( $params [ 'fullscale' ]) {
if ( $params [ 'show_unknown' ]
&& isset ( $array_data [ 'unknown' . $series_suffix ])
&& is_array ( $array_data [ 'unknown' . $series_suffix ][ 'data' ])
) {
foreach ( $array_data [ 'unknown' . $series_suffix ][ 'data' ] as $key => $s_date ) {
if ( $s_date [ 1 ] == 1 ) {
$array_data [ 'unknown' . $series_suffix ][ 'data' ][ $key ] = [
$s_date [ 0 ],
( $max * 1.05 ),
];
}
}
}
} else {
if ( $params [ 'show_unknown' ]) {
$unknown_events = db_get_module_ranges_unknown (
$agent_module_id ,
$date_array [ 'start_date' ],
$date_array [ 'final_date' ],
$data_module_graph [ 'history_db' ],
1
);
if ( $unknown_events !== false ) {
foreach ( $unknown_events as $key => $s_date ) {
if ( isset ( $s_date [ 'time_from' ])) {
$array_data [ 'unknown' . $series_suffix ][ 'data' ][] = [
(( $s_date [ 'time_from' ] - 1 ) * 1000 ),
0 ,
];
$array_data [ 'unknown' . $series_suffix ][ 'data' ][] = [
( $s_date [ 'time_from' ] * 1000 ),
( $max * 1.05 ),
];
} else {
$array_data [ 'unknown' . $series_suffix ][ 'data' ][] = [
( $date_array [ 'start_date' ] * 1000 ),
( $max * 1.05 ),
];
}
if ( isset ( $s_date [ 'time_to' ])) {
$array_data [ 'unknown' . $series_suffix ][ 'data' ][] = [
( $s_date [ 'time_to' ] * 1000 ),
( $max * 1.05 ),
];
$array_data [ 'unknown' . $series_suffix ][ 'data' ][] = [
(( $s_date [ 'time_to' ] + 1 ) * 1000 ),
0 ,
];
} else {
$array_data [ 'unknown' . $series_suffix ][ 'data' ][] = [
( $date_array [ 'final_date' ] * 1000 ),
( $max * 1.05 ),
];
}
}
}
}
}
if ( $params [ 'show_events' ]
|| $params [ 'show_alerts' ]
) {
$events = db_get_all_rows_filter (
'tevento' ,
[ 'id_agentmodule' => $agent_module_id ,
'utimestamp > ' . $date_array [ 'start_date' ],
'utimestamp < ' . $date_array [ 'final_date' ],
'order' => 'utimestamp ASC'
],
false ,
'AND' ,
$data_module_graph [ 'history_db' ]
);
$alerts_array = [];
$events_array = [];
if ( $events && is_array ( $events )) {
$count_events = 0 ;
$count_alerts = 0 ;
foreach ( $events as $k => $v ) {
if ( strpos ( $v [ 'event_type' ], 'alert' ) !== false ) {
if ( $params [ 'flag_overlapped' ]) {
$alerts_array [ 'data' ][ $count_alerts ] = [
( $v [ 'utimestamp' ] + $date_array [ 'period' ] * 1000 ),
( $max * 1.10 ),
];
} else {
$alerts_array [ 'data' ][ $count_alerts ] = [
( $v [ 'utimestamp' ] * 1000 ),
( $max * 1.10 ),
];
}
$count_alerts ++ ;
} else {
if ( $params [ 'flag_overlapped' ]) {
if (( strstr ( $v [ 'event_type' ], 'going_up' ) )
|| ( strstr ( $v [ 'event_type' ], 'going_down' ) )
) {
$events_array [ 'data' ][ $count_events ] = [
(( $v [ 'utimestamp' ] + 1 + $date_array [ 'period' ]) * 1000 ),
( $max * 1.15 ),
];
} else {
$events_array [ 'data' ][ $count_events ] = [
( $v [ 'utimestamp' ] + $date_array [ 'period' ] * 1000 ),
( $max * 1.15 ),
];
}
} else {
if (( strstr ( $v [ 'event_type' ], 'going_up' ) )
|| ( strstr ( $v [ 'event_type' ], 'going_down' ) )
) {
$events_array [ 'data' ][ $count_events ] = [
(( $v [ 'utimestamp' ] + 1 ) * 1000 ),
( $max * 1.15 ),
];
} else {
$events_array [ 'data' ][ $count_events ] = [
( $v [ 'utimestamp' ] * 1000 ),
( $max * 1.15 ),
];
}
}
$count_events ++ ;
}
}
}
}
if ( $params [ 'show_events' ]) {
$array_data [ 'event' . $series_suffix ] = $events_array ;
}
if ( $params [ 'show_alerts' ]) {
$array_data [ 'alert' . $series_suffix ] = $alerts_array ;
}
}
if ( $params [ 'return_data' ] == 1 ) {
return $array_data ;
}
$array_events_alerts [ $series_suffix ] = $events ;
return $array_data ;
2018-02-12 13:29:25 +01:00
}
2018-05-28 17:47:40 +02:00
2019-05-09 16:26:38 +02:00
/**
2019-12-05 17:41:44 +01:00
* Functions to create graphs .
2019-05-09 16:26:38 +02:00
*
* @ param array $params Details builds graphs . For example :
* 'agent_module_id' => $agent_module_id ,
* 'period' => $period ,
* 'show_events' => false ,
* 'width' => $width ,
* 'height' => $height ,
* 'title' => '' ,
* 'unit_name' => null ,
* 'show_alerts' => false ,
* 'date' => 0 ,
* 'unit' => '' ,
* 'baseline' => 0 ,
* 'return_data' => 0 ,
* 'show_title' => true ,
* 'only_image' => false ,
* 'homeurl' => $config [ 'homeurl' ],
* 'ttl' => 1 ,
* 'adapt_key' => '' ,
* 'compare' => false ,
* 'show_unknown' => false ,
* 'menu' => true ,
* 'backgroundColor' => 'white' ,
* 'percentil' => null ,
* 'dashboard' => false ,
* 'vconsole' => false ,
* 'type_graph' => 'area' ,
* 'fullscale' => false ,
* 'id_widget_dashboard' => false ,
* 'force_interval' => '' ,
* 'time_interval' => 300 ,
* 'array_data_create' => 0 ,
* 'show_legend' => true ,
* 'show_overview' => true ,
* 'return_img_base_64' => false ,
2022-05-18 17:17:31 +02:00
* 'image_threshold' => false ,
2019-05-09 16:26:38 +02:00
* 'graph_combined' => false ,
2020-10-02 14:16:55 +02:00
* 'graph_render' => 0 ,
2019-05-09 16:26:38 +02:00
* 'zoom' => 1 ,
* 'server_id' => null ,
2020-10-05 17:03:30 +02:00
* 'stacked' => 0
* 'maximum_y_axis' => 0.
2019-05-09 16:26:38 +02:00
*
* @ return string html Content graphs .
*/
2020-10-05 17:03:30 +02:00
function grafico_modulo_sparse ( $params )
2019-01-30 16:18:44 +01:00
{
global $config ;
2020-10-05 17:03:30 +02:00
if ( isset ( $params ) === false || is_array ( $params ) === false ) {
2019-01-30 16:18:44 +01:00
return false ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'period' ]) === false ) {
2019-01-30 16:18:44 +01:00
return false ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'show_events' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'show_events' ] = false ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'width' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'width' ] = '90%' ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'height' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'height' ] = 450 ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'title' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'title' ] = '' ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'unit_name' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'unit_name' ] = null ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'show_alerts' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'show_alerts' ] = false ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'date' ]) === false || ! $params [ 'date' ]) {
2019-01-30 16:18:44 +01:00
$params [ 'date' ] = get_system_time ();
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'unit' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'unit' ] = '' ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'baseline' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'baseline' ] = 0 ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'return_data' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'return_data' ] = 0 ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'show_title' ]) === false ) {
2019-01-30 16:18:44 +01:00
$show_title = true ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'only_image' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'only_image' ] = false ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'homeurl' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'homeurl' ] = $config [ 'homeurl' ];
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'ttl' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'ttl' ] = 1 ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'adapt_key' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'adapt_key' ] = '' ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'compare' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'compare' ] = false ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'show_unknown' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'show_unknown' ] = false ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'menu' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'menu' ] = true ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'show_legend' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'show_legend' ] = true ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'show_overview' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'show_overview' ] = true ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'show_export_csv' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'show_export_csv' ] = true ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'backgroundColor' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'backgroundColor' ] = 'white' ;
}
2021-07-08 10:03:57 +02:00
if ( isset ( $params [ 'only_image' ]) === true && $params [ 'vconsole' ] !== true ) {
2021-06-10 10:19:11 +02:00
$params [ 'backgroundColor' ] = 'transparent' ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'percentil' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'percentil' ] = null ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'dashboard' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'dashboard' ] = false ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'vconsole' ]) === false || $params [ 'vconsole' ] == false ) {
2019-01-30 16:18:44 +01:00
$params [ 'vconsole' ] = false ;
} else {
$params [ 'menu' ] = false ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'type_graph' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'type_graph' ] = $config [ 'type_module_charts' ];
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'fullscale' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'fullscale' ] = false ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'id_widget_dashboard' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'id_widget_dashboard' ] = false ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'force_interval' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'force_interval' ] = '' ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'time_interval' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'time_interval' ] = 300 ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'array_data_create' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'array_data_create' ] = 0 ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'return_img_base_64' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'return_img_base_64' ] = false ;
}
2022-05-18 17:17:31 +02:00
if ( isset ( $params [ 'image_threshold' ]) === false ) {
$params [ 'image_threshold' ] = false ;
2019-01-30 16:18:44 +01:00
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'graph_combined' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'graph_combined' ] = false ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'zoom' ]) === false ) {
2019-05-09 16:26:38 +02:00
$params [ 'zoom' ] = ( $config [ 'zoom_graph' ]) ? $config [ 'zoom_graph' ] : 1 ;
2019-01-30 16:18:44 +01:00
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'type_mode_graph' ]) === false ) {
2022-01-12 19:43:33 +01:00
$params [ 'type_mode_graph' ] = ( $config [ 'type_mode_graph' ] ? ? null );
2020-10-02 14:16:55 +02:00
if ( isset ( $params [ 'graph_render' ]) === true ) {
$params [ 'type_mode_graph' ] = $params [ 'graph_render' ];
}
2019-01-30 16:18:44 +01:00
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'maximum_y_axis' ]) === false ) {
$params [ 'maximum_y_axis' ] = $config [ 'maximum_y_axis' ];
}
if ( isset ( $params [ 'projection' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'projection' ] = false ;
}
2020-10-02 14:16:55 +02:00
if ( isset ( $params [ 'pdf' ]) === false ) {
$params [ 'pdf' ] = false ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'agent_module_id' ]) === false ) {
2022-12-13 09:10:13 +01:00
return graph_nodata_image ( $params );
2019-02-25 16:50:27 +01:00
} else {
$agent_module_id = $params [ 'agent_module_id' ];
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'stacked' ]) === false ) {
2019-03-11 16:25:10 +01:00
$params [ 'stacked' ] = 0 ;
}
2021-07-05 11:34:32 +02:00
if ( isset ( $params [ 'graph_font_size' ]) === true ) {
$font_size = $params [ 'graph_font_size' ];
} else {
$font_size = $config [ 'font_size' ];
}
2021-06-10 10:19:11 +02:00
2021-08-03 15:46:01 +02:00
if ( isset ( $params [ 'basic_chart' ]) === false ) {
$params [ 'basic_chart' ] = false ;
}
2023-04-20 10:16:18 +02:00
if ( isset ( $params [ 'array_colors' ]) === false ) {
$params [ 'array_colors' ] = false ;
}
2021-06-10 10:19:11 +02:00
// If is metaconsole set 10pt size value.
if ( is_metaconsole ()) {
$font_size = '10' ;
}
2019-05-09 16:26:38 +02:00
$params [ 'grid_color' ] = '#C1C1C1' ;
2019-01-30 16:18:44 +01:00
$params [ 'legend_color' ] = '#636363' ;
2021-06-10 10:19:11 +02:00
$params [ 'font' ] = 'lato' ;
$params [ 'font_size' ] = $font_size ;
2019-01-30 16:18:44 +01:00
$params [ 'short_data' ] = $config [ 'short_module_graph_data' ];
if ( $params [ 'only_image' ]) {
return generator_chart_to_pdf ( 'sparse' , $params );
}
global $graphic_type ;
global $array_events_alerts ;
2019-05-09 16:26:38 +02:00
$array_data = [];
$legend = [];
2019-01-30 16:18:44 +01:00
$array_events_alerts = [];
$date_array = [];
$date_array [ 'period' ] = $params [ 'period' ];
$date_array [ 'final_date' ] = $params [ 'date' ];
$date_array [ 'start_date' ] = ( $params [ 'date' ] - $params [ 'period' ]);
if ( $agent_module_id ) {
$module_data = db_get_row_sql (
' SELECT * FROM tagente_modulo
WHERE id_agente_modulo = ' . $agent_module_id
);
$data_module_graph = [];
2019-05-09 16:26:38 +02:00
$data_module_graph [ 'history_db' ] = db_search_in_history_db (
$date_array [ 'start_date' ]
);
$data_module_graph [ 'agent_name' ] = modules_get_agentmodule_agent_name (
$agent_module_id
);
$data_module_graph [ 'agent_alias' ] = modules_get_agentmodule_agent_alias (
$agent_module_id
);
$data_module_graph [ 'agent_id' ] = $module_data [ 'id_agente' ];
$data_module_graph [ 'module_name' ] = $module_data [ 'nombre' ];
2019-01-30 16:18:44 +01:00
$data_module_graph [ 'id_module_type' ] = $module_data [ 'id_tipo_modulo' ];
2019-05-09 16:26:38 +02:00
$data_module_graph [ 'module_type' ] = modules_get_moduletype_name (
$data_module_graph [ 'id_module_type' ]
);
$data_module_graph [ 'uncompressed' ] = is_module_uncompressed (
$data_module_graph [ 'module_type' ]
);
$data_module_graph [ 'w_min' ] = $module_data [ 'min_warning' ];
$data_module_graph [ 'w_max' ] = $module_data [ 'max_warning' ];
$data_module_graph [ 'w_inv' ] = $module_data [ 'warning_inverse' ];
$data_module_graph [ 'c_min' ] = $module_data [ 'min_critical' ];
$data_module_graph [ 'c_max' ] = $module_data [ 'max_critical' ];
$data_module_graph [ 'c_inv' ] = $module_data [ 'critical_inverse' ];
$data_module_graph [ 'unit' ] = $module_data [ 'unit' ];
2019-01-30 16:18:44 +01:00
} else {
$data_module_graph = false ;
}
2019-05-09 16:26:38 +02:00
// Format of the graph.
2020-10-05 17:03:30 +02:00
if ( empty ( $params [ 'unit' ]) === true ) {
2019-01-30 16:18:44 +01:00
$params [ 'unit' ] = $module_data [ 'unit' ];
if ( modules_is_unit_macro ( $params [ 'unit' ])) {
$params [ 'unit' ] = '' ;
}
}
2020-10-05 17:03:30 +02:00
if ( empty ( $params [ 'divisor' ]) === true ) {
2019-12-05 17:41:44 +01:00
$params [ 'divisor' ] = get_data_multiplier ( $params [ 'unit' ]);
}
2019-01-30 16:18:44 +01:00
if ( ! $params [ 'array_data_create' ]) {
if ( $params [ 'baseline' ]) {
2019-05-09 16:26:38 +02:00
$array_data = get_baseline_data (
$agent_module_id ,
$date_array ,
$data_module_graph ,
$params
);
2019-01-30 16:18:44 +01:00
} else {
if ( $params [ 'compare' ] !== false ) {
$series_suffix = 2 ;
$date_array_prev [ 'final_date' ] = $date_array [ 'start_date' ];
$date_array_prev [ 'start_date' ] = ( $date_array [ 'start_date' ] - $date_array [ 'period' ]);
$date_array_prev [ 'period' ] = $date_array [ 'period' ];
if ( $params [ 'compare' ] === 'overlapped' ) {
$params [ 'flag_overlapped' ] = 1 ;
} else {
$params [ 'flag_overlapped' ] = 0 ;
}
$array_data = grafico_modulo_sparse_data (
$agent_module_id ,
$date_array_prev ,
$data_module_graph ,
$params ,
$series_suffix
);
switch ( $params [ 'compare' ]) {
case 'separated' :
case 'overlapped' :
2019-05-09 16:26:38 +02:00
// Store the chart calculated.
2019-01-30 16:18:44 +01:00
$array_data_prev = $array_data ;
$legend_prev = $legend ;
break ;
2019-05-09 16:26:38 +02:00
default :
// Not defined.
break ;
2019-01-30 16:18:44 +01:00
}
}
$series_suffix = 1 ;
$params [ 'flag_overlapped' ] = 0 ;
$array_data = grafico_modulo_sparse_data (
$agent_module_id ,
$date_array ,
$data_module_graph ,
$params ,
$series_suffix
);
if ( $params [ 'compare' ]) {
if ( $params [ 'compare' ] === 'overlapped' ) {
$array_data = array_merge ( $array_data , $array_data_prev );
$legend = array_merge ( $legend , $legend_prev );
}
}
}
} else {
$array_data = $params [ 'array_data_create' ];
}
if ( $params [ 'return_data' ]) {
return $array_data ;
}
$series_type_array = series_type_graph_array (
$array_data ,
$params
);
$series_type = $series_type_array [ 'series_type' ];
$legend = $series_type_array [ 'legend' ];
$color = $series_type_array [ 'color' ];
if ( $config [ 'fixed_graph' ] == false ) {
$water_mark = [
'file' => $config [ 'homedir' ] . '/images/logo_vertical_water.png' ,
'url' => ui_get_full_url (
'/images/logo_vertical_water.png' ,
false ,
false ,
false
),
];
}
2023-08-01 11:19:04 +02:00
if ( $data_module_graph === false ) {
$data_module_graph = [];
}
2019-01-30 16:18:44 +01:00
$data_module_graph [ 'series_suffix' ] = $series_suffix ;
2019-05-09 16:26:38 +02:00
// Check available data.
2019-01-30 16:18:44 +01:00
if ( $params [ 'compare' ] === 'separated' ) {
2020-10-05 17:03:30 +02:00
if ( empty ( $array_data ) === false ) {
2019-01-30 16:18:44 +01:00
$return = area_graph (
$agent_module_id ,
$array_data ,
$legend ,
$series_type ,
$color ,
$date_array ,
$data_module_graph ,
$params ,
$water_mark ,
$array_events_alerts
);
} else {
2022-12-13 09:10:13 +01:00
$return = graph_nodata_image ( $params );
2019-01-30 16:18:44 +01:00
}
$return .= '<br>' ;
2020-10-05 17:03:30 +02:00
if ( empty ( $array_data_prev ) === false ) {
2019-01-30 16:18:44 +01:00
$series_type_array = series_type_graph_array (
$array_data_prev ,
$params
);
$series_type = $series_type_array [ 'series_type' ];
$legend = $series_type_array [ 'legend' ];
$color = $series_type_array [ 'color' ];
$return .= area_graph (
$agent_module_id ,
$array_data_prev ,
$legend ,
$series_type ,
$color ,
$date_array_prev ,
$data_module_graph ,
$params ,
$water_mark ,
$array_events_alerts
);
} else {
2022-12-13 09:10:13 +01:00
$return = graph_nodata_image ( $params );
2019-01-30 16:18:44 +01:00
}
} else {
2020-10-01 15:29:54 +02:00
if ( empty ( $array_data ) === false ) {
2019-01-30 16:18:44 +01:00
$return = area_graph (
$agent_module_id ,
$array_data ,
$legend ,
$series_type ,
$color ,
$date_array ,
$data_module_graph ,
$params ,
$water_mark ,
$array_events_alerts
);
} else {
2022-12-13 09:10:13 +01:00
$return = graph_nodata_image ( $params );
2019-01-30 16:18:44 +01:00
}
}
return $return ;
2011-04-05 18:11:53 +02:00
}
2019-01-30 16:18:44 +01:00
2011-04-05 18:11:53 +02:00
/**
2019-05-09 16:26:38 +02:00
* Functions tu create graphs .
2011-04-05 18:11:53 +02:00
*
2019-05-09 16:26:38 +02:00
* @ param array $module_list Array modules .
* @ param array $params Details builds graphs . For example :
* 'period' => $period ,
* 'show_events' => false ,
* 'width' => $width ,
* 'height' => $height ,
* 'title' => '' ,
* 'unit_name' => null ,
* 'show_alerts' => false ,
* 'date' => 0 ,
* 'unit' => '' ,
* 'only_image' => false ,
* 'homeurl' => '' ,
* 'ttl' => 1 ,
* 'percentil' => null ,
* 'dashboard' => false ,
* 'vconsole' => false ,
* 'fullscale' => false ,
* 'id_widget_dashboard' => false .
* @ param array $params_combined Details builds graphs . For example :
* 'weight_list' => array (),
* 'stacked' => 0 ,
* 'projection' => false ,
* 'labels' => array (),
* 'from_interface' => false ,
* 'summatory' => 0 ,
* 'average' => 0 ,
* 'modules_series' => 0 ,
* 'id_graph' => 0 ,
* 'return' => 1.
2018-04-27 10:03:05 +02:00
*
2019-05-09 16:26:38 +02:00
* @ return string html Content graphs .
2011-04-05 18:11:53 +02:00
*/
2019-01-30 16:18:44 +01:00
function graphic_combined_module (
$module_list ,
$params ,
$params_combined
2018-04-18 16:01:38 +02:00
) {
2019-01-30 16:18:44 +01:00
global $config ;
2020-10-05 17:03:30 +02:00
if ( isset ( $params_combined [ 'from_interface' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params_combined [ 'from_interface' ] = false ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params_combined [ 'stacked' ]) === false ) {
2019-01-30 16:18:44 +01:00
if ( $params_combined [ 'from_interface' ]) {
if ( $config [ 'type_interface_charts' ] == 'line' ) {
$params_combined [ 'stacked' ] = CUSTOM_GRAPH_LINE ;
} else {
$params_combined [ 'stacked' ] = CUSTOM_GRAPH_AREA ;
}
} else {
if ( $params_combined [ 'id_graph' ] == 0 ) {
$params_combined [ 'stacked' ] = CUSTOM_GRAPH_AREA ;
} else {
2020-10-05 17:03:30 +02:00
$params_combined [ 'stacked' ] = db_get_row (
'tgraph' ,
'id_graph' ,
$params_combined [ 'id_graph' ]
);
2019-01-30 16:18:44 +01:00
}
}
}
$params [ 'stacked' ] = $params_combined [ 'stacked' ];
2020-10-05 17:03:30 +02:00
if ( isset ( $params_combined [ 'projection' ]) === false
|| $params_combined [ 'projection' ] == false
) {
2019-01-30 16:18:44 +01:00
$params_combined [ 'projection' ] = false ;
} else {
$params [ 'stacked' ] = 'area' ;
$params [ 'projection' ] = true ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params_combined [ 'labels' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params_combined [ 'labels' ] = [];
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params_combined [ 'summatory' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params_combined [ 'summatory' ] = 0 ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params_combined [ 'average' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params_combined [ 'average' ] = 0 ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params_combined [ 'modules_series' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params_combined [ 'modules_series' ] = 0 ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params_combined [ 'return' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params_combined [ 'return' ] = 1 ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params_combined [ 'id_graph' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params_combined [ 'id_graph' ] = 0 ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params_combined [ 'type_report' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params_combined [ 'type_report' ] = '' ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'percentil' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params_combined [ 'percentil' ] = null ;
} else {
$params_combined [ 'percentil' ] = $params [ 'percentil' ];
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'period' ]) === false ) {
2019-01-30 16:18:44 +01:00
return false ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'width' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'width' ] = '90%' ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'height' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'height' ] = 450 ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'title' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'title' ] = '' ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'unit_name' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'unit_name' ] = null ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'show_alerts' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'show_alerts' ] = false ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'date' ]) === false || ! $params [ 'date' ]) {
2019-01-30 16:18:44 +01:00
$params [ 'date' ] = get_system_time ();
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'only_image' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'only_image' ] = false ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'ttl' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'ttl' ] = 1 ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'backgroundColor' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'backgroundColor' ] = 'white' ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'dashboard' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'dashboard' ] = false ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'menu' ]) === false
|| $params [ 'only_image' ]
) {
2019-01-30 16:18:44 +01:00
$params [ 'menu' ] = true ;
} else {
$params [ 'menu' ] = false ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'vconsole' ]) === false
|| $params [ 'vconsole' ] == false
) {
2019-01-30 16:18:44 +01:00
$params [ 'vconsole' ] = false ;
} else {
$params [ 'menu' ] = false ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'type_graph' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'type_graph' ] = $config [ 'type_module_charts' ];
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'percentil' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'percentil' ] = null ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'fullscale' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'fullscale' ] = false ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'id_widget_dashboard' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'id_widget_dashboard' ] = false ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'homeurl' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'homeurl' ] = ui_get_full_url ( false , false , false , false );
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'show_legend' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'show_legend' ] = true ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'show_overview' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'show_overview' ] = true ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'show_export_csv' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'show_export_csv' ] = true ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'return_img_base_64' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'return_img_base_64' ] = false ;
}
2022-05-18 17:17:31 +02:00
if ( isset ( $params [ 'image_threshold' ]) === false ) {
$params [ 'image_threshold' ] = false ;
2019-01-30 16:18:44 +01:00
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'show_unknown' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'show_unknown' ] = false ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'type_mode_graph' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'type_mode_graph' ] = 0 ;
2020-10-02 14:16:55 +02:00
if ( isset ( $params [ 'graph_render' ]) === true ) {
$params [ 'type_mode_graph' ] = $params [ 'graph_render' ];
$params_combined [ 'type_mode_graph' ] = $params [ 'graph_render' ];
}
}
if ( isset ( $params [ 'fullscale' ]) === false ) {
$params_combined [ 'fullscale' ] = false ;
} else {
$params_combined [ 'fullscale' ] = $params [ 'fullscale' ];
2019-01-30 16:18:44 +01:00
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'maximum_y_axis' ]) === false ) {
$params [ 'maximum_y_axis' ] = $config [ 'maximum_y_axis' ];
}
2019-01-30 16:18:44 +01:00
$params [ 'graph_combined' ] = true ;
$params_combined [ 'graph_combined' ] = true ;
if ( $params [ 'only_image' ]) {
2019-05-09 16:26:38 +02:00
return generator_chart_to_pdf (
'combined' ,
$params ,
$params_combined ,
$module_list
);
2019-01-30 16:18:44 +01:00
}
2020-10-05 17:03:30 +02:00
if ( isset ( $params [ 'zoom' ]) === false ) {
2019-01-30 16:18:44 +01:00
$params [ 'zoom' ] = 1 ;
}
$params [ 'grid_color' ] = '#C1C1C1' ;
$params [ 'legend_color' ] = '#636363' ;
2019-05-09 16:26:38 +02:00
2021-06-10 10:19:11 +02:00
$params [ 'font' ] = 'lato' ;
2019-05-09 16:26:38 +02:00
$params [ 'font_size' ] = $config [ 'font_size' ];
2019-01-30 16:18:44 +01:00
$params [ 'short_data' ] = $config [ 'short_module_graph_data' ];
global $config ;
global $graphic_type ;
$sources = false ;
2020-10-02 14:16:55 +02:00
if (( int ) $params_combined [ 'id_graph' ] === 0 ) {
2019-01-30 16:18:44 +01:00
$count_modules = count ( $module_list );
if ( ! $params_combined [ 'weight_list' ]) {
$weights = array_fill ( 0 , $count_modules , 1 );
}
if ( $count_modules > 0 ) {
2020-07-07 16:07:13 +02:00
foreach ( $module_list as $key => $value ) {
2020-10-02 14:16:55 +02:00
$sources [ $key ][ 'id_server' ] = ( isset ( $value [ 'id_server' ]) === true ) ? $value [ 'id_server' ] : $params [ 'server_id' ];
2020-10-13 18:24:10 +02:00
$sources [ $key ][ 'id_agent_module' ] = ( isset ( $value [ 'module' ]) === true ) ? $value [ 'module' ] : $value ;
2020-07-07 16:07:13 +02:00
$sources [ $key ][ 'weight' ] = $weights [ $key ];
$sources [ $key ][ 'label' ] = $params_combined [ 'labels' ];
}
2019-01-30 16:18:44 +01:00
}
} else {
2020-07-07 16:07:13 +02:00
if ( is_metaconsole ()) {
metaconsole_restore_db ();
$server = metaconsole_get_connection_by_id ( $params [ 'server_id' ]);
if ( metaconsole_connect ( $server ) != NOERR ) {
return false ;
}
}
2019-01-30 16:18:44 +01:00
$sources = db_get_all_rows_field_filter (
'tgraph_source' ,
'id_graph' ,
$params_combined [ 'id_graph' ],
'field_order'
);
2020-07-07 16:07:13 +02:00
if ( is_metaconsole ()) {
if ( isset ( $sources ) && is_array ( $sources )) {
foreach ( $sources as $key => $value ) {
$sources [ $key ][ 'id_server' ] = $params [ 'server_id' ];
}
}
}
2019-01-30 16:18:44 +01:00
$series = db_get_all_rows_sql (
2020-07-07 16:07:13 +02:00
' SELECT summatory_series ,
average_series ,
modules_series
2019-01-30 16:18:44 +01:00
FROM tgraph
WHERE id_graph = '.$params_combined[' id_graph ' ]
);
$summatory = $series [ 0 ][ 'summatory_series' ];
$average = $series [ 0 ][ 'average_series' ];
$modules_series = $series [ 0 ][ 'modules_series' ];
2020-07-07 16:07:13 +02:00
if ( is_metaconsole ()) {
metaconsole_restore_db ();
}
}
2022-10-27 16:12:17 +02:00
if ( isset ( $sources ) === true && is_array ( $sources ) === true ) {
2019-01-30 16:18:44 +01:00
$weights = [];
$labels = [];
$modules = [];
2020-07-07 16:07:13 +02:00
foreach ( $sources as $source ) {
if ( is_metaconsole () === true ) {
2020-09-08 11:48:27 +02:00
metaconsole_restore_db ();
2020-07-07 16:07:13 +02:00
$server = metaconsole_get_connection_by_id ( $source [ 'id_server' ]);
if ( metaconsole_connect ( $server ) != NOERR ) {
continue ;
}
}
2019-01-30 16:18:44 +01:00
2021-09-29 16:20:18 +02:00
$id_agent = agents_get_module_id (
$source [ 'id_agent_module' ]
);
if ( ! $id_agent ) {
continue ;
}
2020-07-07 16:07:13 +02:00
$modulepush = [
'server' => ( isset ( $source [ 'id_server' ]) === true ) ? $source [ 'id_server' ] : 0 ,
'module' => $source [ 'id_agent_module' ],
];
2019-07-10 18:20:43 +02:00
2020-07-07 16:07:13 +02:00
array_push ( $modules , $modulepush );
array_push ( $weights , $source [ 'weight' ]);
2022-06-27 17:09:27 +02:00
if ( empty ( $source [ 'label' ]) === false || $params_combined [ 'labels' ]) {
2020-07-07 16:07:13 +02:00
$agent_description = agents_get_description ( $id_agent );
$agent_group = agents_get_agent_group ( $id_agent );
$agent_address = agents_get_address ( $id_agent );
$agent_alias = agents_get_alias ( $id_agent );
$module_name = modules_get_agentmodule_name (
$source [ 'id_agent_module' ]
);
2019-07-10 18:20:43 +02:00
2020-07-07 16:07:13 +02:00
$module_description = modules_get_agentmodule_descripcion (
$source [ 'id_agent_module' ]
);
2019-07-10 18:20:43 +02:00
2020-07-07 16:07:13 +02:00
$items_label = [
'type' => 'custom_graph' ,
'id_agent' => $id_agent ,
'id_agent_module' => $source [ 'id_agent_module' ],
'agent_description' => $agent_description ,
'agent_group' => $agent_group ,
'agent_address' => $agent_address ,
'agent_alias' => $agent_alias ,
'module_name' => $module_name ,
'module_description' => $module_description ,
];
2022-02-07 13:35:00 +01:00
if ( is_array ( $source [ 'label' ]) === true ) {
$lab = '' ;
foreach ( $source [ 'label' ] as $label ) {
$lab .= reporting_label_macro (
$items_label ,
2022-02-16 14:01:23 +01:00
( $label ? ? '' )
2022-02-07 13:35:00 +01:00
);
}
} else if ( $source [ 'label' ] != '' ) {
2020-07-07 16:07:13 +02:00
$lab = reporting_label_macro (
$items_label ,
2022-02-16 14:01:23 +01:00
( $source [ 'label' ] ? ? '' )
2020-07-07 16:07:13 +02:00
);
} else {
$lab = reporting_label_macro (
$items_label ,
2022-02-16 14:01:23 +01:00
( $params_combined [ 'labels' ] ? ? '' )
2020-07-07 16:07:13 +02:00
);
2019-01-30 16:18:44 +01:00
}
2020-07-07 16:07:13 +02:00
$labels [ $source [ 'id_agent_module' ]] = $lab ;
}
if ( is_metaconsole () === true ) {
metaconsole_restore_db ();
2019-01-30 16:18:44 +01:00
}
}
}
2022-10-27 16:12:17 +02:00
if (( bool ) $params_combined [ 'from_interface' ] === true ) {
$labels = [];
}
2019-01-30 16:18:44 +01:00
if ( $module_list ) {
$params_combined [ 'modules_id' ] = $module_list ;
} else {
$params_combined [ 'modules_id' ] = $modules ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $summatory ) === true ) {
2019-01-30 16:18:44 +01:00
$params_combined [ 'summatory' ] = $summatory ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $average ) === true ) {
2019-01-30 16:18:44 +01:00
$params_combined [ 'average' ] = $average ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $modules_series ) === true ) {
2019-01-30 16:18:44 +01:00
$params_combined [ 'modules_series' ] = $modules_series ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $labels ) === true ) {
2019-01-30 16:18:44 +01:00
$params_combined [ 'labels' ] = $labels ;
}
2020-10-05 17:03:30 +02:00
if ( isset ( $weights ) === true ) {
2019-01-30 16:18:44 +01:00
$params_combined [ 'weight_list' ] = $weights ;
}
if ( ! $module_list ) {
$module_list = $modules ;
}
if ( $sources === false ) {
if ( $params_combined [ 'return' ]) {
return false ;
} else {
ui_print_info_message (
[
'no_close' => true ,
'message' => __ ( 'No items.' ),
]
);
return ;
}
}
2019-05-09 16:26:38 +02:00
$width = $params [ 'width' ];
$height = $params [ 'height' ];
$homeurl = $params [ 'homeurl' ];
$ttl = $params [ 'ttl' ];
2022-12-13 09:10:13 +01:00
$date_array = [];
$date_array [ 'period' ] = $params [ 'period' ];
$date_array [ 'final_date' ] = $params [ 'date' ];
$date_array [ 'start_date' ] = ( $params [ 'date' ] - $params [ 'period' ]);
2019-01-30 16:18:44 +01:00
$background_color = $params [ 'backgroundColor' ];
2019-05-09 16:26:38 +02:00
$datelimit = $date_array [ 'start_date' ];
$fixed_font_size = $config [ 'font_size' ];
2019-01-30 16:18:44 +01:00
if ( $config [ 'fixed_graph' ] == false ) {
$water_mark = [
'file' => $config [ 'homedir' ] . '/images/logo_vertical_water.png' ,
'url' => ui_get_full_url (
'/images/logo_vertical_water.png' ,
false ,
false ,
false
),
];
}
$long_index = '' ;
2021-06-10 10:19:11 +02:00
2022-01-17 10:22:30 +01:00
if (( $config [ 'style' ] === 'pandora_black' && ! is_metaconsole ()) && ( $params [ 'pdf' ] === false || $params [ 'pdf' ] === null )
2021-06-10 10:19:11 +02:00
) {
2021-04-09 11:52:28 +02:00
$background_color = '#222' ;
$params [ 'legend_color' ] = '#fff' ;
2021-06-10 10:19:11 +02:00
} else if ( $params [ 'pdf' ]) {
$params [ 'legend_color' ] = '#000' ;
2021-04-09 11:52:28 +02:00
}
2019-01-30 16:18:44 +01:00
switch ( $params_combined [ 'stacked' ]) {
default :
case CUSTOM_GRAPH_STACKED_LINE :
case CUSTOM_GRAPH_STACKED_AREA :
case CUSTOM_GRAPH_AREA :
case CUSTOM_GRAPH_LINE :
$date_array = [];
$date_array [ 'period' ] = $params [ 'period' ];
$date_array [ 'final_date' ] = $params [ 'date' ];
$date_array [ 'start_date' ] = ( $params [ 'date' ] - $params [ 'period' ]);
2021-11-22 12:12:32 +01:00
if ( is_metaconsole ()) {
$server_name = metaconsole_get_server_by_id ( $modules [ 0 ][ 'server' ]);
}
2021-10-05 10:47:50 +02:00
2023-09-07 10:44:46 +02:00
if ( isset ( $params_combined [ 'custom_period' ]) !== false && $params_combined [ 'custom_period' ] !== false ) {
$period = $params_combined [ 'custom_period' ];
} else {
$period = $params [ 'period' ];
}
2019-01-30 16:18:44 +01:00
if ( $params_combined [ 'projection' ]) {
$output_projection = forecast_projection_graph (
$module_list [ 0 ],
2023-09-07 10:44:46 +02:00
$period ,
2021-10-05 10:47:50 +02:00
$params_combined [ 'projection' ],
false ,
false ,
false ,
$server_name
2019-01-30 16:18:44 +01:00
);
}
$i = 0 ;
$array_data = [];
foreach ( $module_list as $key => $agent_module_id ) {
2019-02-25 16:50:27 +01:00
if (( bool ) $agent_module_id === false ) {
continue ;
}
2020-07-13 10:02:56 +02:00
// Only 10 item for chart.
2020-12-17 16:58:20 +01:00
if ( $i >= $config [ 'items_combined_charts' ]) {
2020-07-13 10:02:56 +02:00
break ;
}
2020-07-07 16:07:13 +02:00
if ( is_metaconsole ()) {
2020-09-08 11:48:27 +02:00
metaconsole_restore_db ();
2023-05-25 09:36:58 +02:00
if ( isset ( $agent_module_id [ 'server' ])) {
$id_server = $agent_module_id [ 'server' ];
} else if ( isset ( $agent_module_id [ 'id_server' ])) {
$id_server = $agent_module_id [ 'id_server' ];
} else {
$id_server = $source [ 'id_server' ];
}
$server = metaconsole_get_connection_by_id ( $id_server );
2019-01-30 16:18:44 +01:00
if ( metaconsole_connect ( $server ) != NOERR ) {
continue ;
}
}
2020-08-26 11:47:54 +02:00
if ( is_array ( $agent_module_id )) {
$agent_module_id = $agent_module_id [ 'module' ];
}
2020-07-07 16:07:13 +02:00
2019-01-30 16:18:44 +01:00
$module_data = db_get_row_sql (
' SELECT * FROM tagente_modulo
WHERE id_agente_modulo = ' . $agent_module_id
);
$data_module_graph = [];
2019-05-09 16:26:38 +02:00
$data_module_graph [ 'history_db' ] = db_search_in_history_db (
$date_array [ 'start_date' ]
);
$data_module_graph [ 'agent_name' ] = modules_get_agentmodule_agent_name (
$agent_module_id
);
2020-01-08 11:37:44 +01:00
if ( is_metaconsole ()) {
$data_module_graph [ 'agent_alias' ] = db_get_value (
'alias' ,
'tagente' ,
'id_agente' ,
( int ) $module_data [ 'id_agente' ]
);
} else {
$data_module_graph [ 'agent_alias' ] = modules_get_agentmodule_agent_alias (
$agent_module_id
);
}
2019-05-09 16:26:38 +02:00
$data_module_graph [ 'agent_id' ] = $module_data [ 'id_agente' ];
$data_module_graph [ 'module_name' ] = $module_data [ 'nombre' ];
2019-01-30 16:18:44 +01:00
$data_module_graph [ 'id_module_type' ] = $module_data [ 'id_tipo_modulo' ];
2019-05-09 16:26:38 +02:00
$data_module_graph [ 'module_type' ] = modules_get_moduletype_name (
$data_module_graph [ 'id_module_type' ]
);
$data_module_graph [ 'uncompressed' ] = is_module_uncompressed (
$data_module_graph [ 'module_type' ]
);
$data_module_graph [ 'w_min' ] = $module_data [ 'min_warning' ];
$data_module_graph [ 'w_max' ] = $module_data [ 'max_warning' ];
$data_module_graph [ 'w_inv' ] = $module_data [ 'warning_inverse' ];
$data_module_graph [ 'c_min' ] = $module_data [ 'min_critical' ];
$data_module_graph [ 'c_max' ] = $module_data [ 'max_critical' ];
$data_module_graph [ 'c_inv' ] = $module_data [ 'critical_inverse' ];
$data_module_graph [ 'module_id' ] = $agent_module_id ;
$data_module_graph [ 'unit' ] = $module_data [ 'unit' ];
2019-12-05 17:41:44 +01:00
$params [ 'unit' ] = $module_data [ 'unit' ];
$params [ 'divisor' ] = get_data_multiplier ( $params [ 'unit' ]);
2019-05-09 16:26:38 +02:00
// Stract data.
2019-01-30 16:18:44 +01:00
$array_data_module = grafico_modulo_sparse_data (
$agent_module_id ,
$date_array ,
$data_module_graph ,
$params ,
$i
);
$series_suffix = $i ;
2019-05-09 16:26:38 +02:00
// Convert to array graph and weight.
2019-01-30 16:18:44 +01:00
foreach ( $array_data_module as $key => $value ) {
$array_data [ $key ] = $value ;
2019-05-06 16:43:59 +02:00
if ( $params_combined [ 'weight_list' ][ $i ] != 1 ) {
2019-01-30 16:18:44 +01:00
foreach ( $value [ 'data' ] as $k => $v ) {
2019-05-06 16:43:59 +02:00
if ( $v [ 1 ] != false ) {
$array_data [ $key ][ 'data' ][ $k ][ 1 ] = ( $v [ 1 ] * $params_combined [ 'weight_list' ][ $i ]);
2020-06-29 15:37:37 +02:00
$array_data [ $key ][ 'slice_data' ][ $v [ 0 ]][ 'avg' ] *= $params_combined [ 'weight_list' ][ $i ];
$array_data [ $key ][ 'slice_data' ][ $v [ 0 ]][ 'min' ] *= $params_combined [ 'weight_list' ][ $i ];
$array_data [ $key ][ 'slice_data' ][ $v [ 0 ]][ 'max' ] *= $params_combined [ 'weight_list' ][ $i ];
2019-05-06 16:43:59 +02:00
}
2019-01-30 16:18:44 +01:00
}
2020-06-29 15:37:37 +02:00
$array_data [ $key ][ 'max' ] *= $params_combined [ 'weight_list' ][ $i ];
$array_data [ $key ][ 'min' ] *= $params_combined [ 'weight_list' ][ $i ];
$array_data [ $key ][ 'avg' ] *= $params_combined [ 'weight_list' ][ $i ];
$array_data [ $key ][ 'weight' ] = $params_combined [ 'weight_list' ][ $i ];
2019-01-30 16:18:44 +01:00
}
}
if ( $config [ 'fixed_graph' ] == false ) {
$water_mark = [
'file' => $config [ 'homedir' ] . '/images/logo_vertical_water.png' ,
2020-07-07 16:07:13 +02:00
'url' => ui_get_full_url (
'images/logo_vertical_water.png' ,
false ,
false ,
false
),
2019-01-30 16:18:44 +01:00
];
}
// Work around for fixed the agents name with huge size chars.
$fixed_font_size = $config [ 'font_size' ];
$i ++ ;
2020-07-07 16:07:13 +02:00
if ( is_metaconsole ()) {
2019-01-30 16:18:44 +01:00
metaconsole_restore_db ();
}
}
2020-10-05 17:03:30 +02:00
if ( empty ( $array_data ) === true ) {
2019-02-25 16:50:27 +01:00
if ( $params_combined [ 'return' ]) {
2022-12-13 09:10:13 +01:00
return graph_nodata_image ( $params );
2019-02-25 16:50:27 +01:00
}
2022-12-13 09:10:13 +01:00
echo graph_nodata_image ( $params );
2019-02-25 16:50:27 +01:00
return false ;
}
2019-01-30 16:18:44 +01:00
if ( $params_combined [ 'projection' ]) {
2019-05-09 16:26:38 +02:00
// If projection doesn't have data then don't draw graph.
2019-01-30 16:18:44 +01:00
if ( $output_projection != null ) {
$date_array_projection = max ( $output_projection );
$date_array [ 'final_date' ] = ( $date_array_projection [ 0 ] / 1000 );
$array_data [ 'projection' ][ 'data' ] = $output_projection ;
}
}
2019-05-09 16:26:38 +02:00
// Summatory and average series.
if ( $params_combined [ 'stacked' ] == CUSTOM_GRAPH_AREA
|| $params_combined [ 'stacked' ] == CUSTOM_GRAPH_LINE
) {
if ( $params_combined [ 'summatory' ]
|| $params_combined [ 'average' ]
) {
2019-01-30 16:18:44 +01:00
$array_data = combined_graph_summatory_average (
$array_data ,
$params_combined [ 'average' ],
$params_combined [ 'summatory' ],
2019-09-24 17:39:11 +02:00
$params_combined [ 'modules_series' ],
$date_array
2019-01-30 16:18:44 +01:00
);
}
}
$series_type_array = series_type_graph_array (
$array_data ,
$params_combined
);
$series_type = $series_type_array [ 'series_type' ];
$legend = $series_type_array [ 'legend' ];
$color = $series_type_array [ 'color' ];
$threshold_data = [];
if ( $params_combined [ 'from_interface' ]) {
$yellow_threshold = 0 ;
$red_threshold = 0 ;
$yellow_up = 0 ;
$red_up = 0 ;
$yellow_inverse = 0 ;
$red_inverse = 0 ;
$compare_warning = false ;
$compare_critical = false ;
$do_it_warning_min = true ;
$do_it_critical_min = true ;
$do_it_warning_max = true ;
$do_it_critical_max = true ;
$do_it_warning_inverse = true ;
$do_it_critical_inverse = true ;
foreach ( $module_list as $index => $id_module ) {
2019-05-09 16:26:38 +02:00
// Get module warning_min and critical_min.
$warning_min = db_get_value (
'min_warning' ,
'tagente_modulo' ,
'id_agente_modulo' ,
$id_module
);
$critical_min = db_get_value (
'min_critical' ,
'tagente_modulo' ,
'id_agente_modulo' ,
$id_module
);
2019-01-30 16:18:44 +01:00
if ( $index == 0 ) {
$compare_warning = $warning_min ;
} else {
if ( $compare_warning != $warning_min ) {
$do_it_warning_min = false ;
}
}
if ( $index == 0 ) {
$compare_critical = $critical_min ;
} else {
if ( $compare_critical != $critical_min ) {
$do_it_critical_min = false ;
}
}
}
if ( $do_it_warning_min || $do_it_critical_min ) {
foreach ( $module_list as $index => $id_module ) {
2019-05-09 16:26:38 +02:00
$warning_max = db_get_value (
'max_warning' ,
'tagente_modulo' ,
'id_agente_modulo' ,
$id_module
);
$critical_max = db_get_value (
'max_critical' ,
'tagente_modulo' ,
'id_agente_modulo' ,
$id_module
);
2019-01-30 16:18:44 +01:00
if ( $index == 0 ) {
$yellow_up = $warning_max ;
} else {
if ( $yellow_up != $warning_max ) {
$do_it_warning_max = false ;
}
}
if ( $index == 0 ) {
$red_up = $critical_max ;
} else {
if ( $red_up != $critical_max ) {
$do_it_critical_max = false ;
}
}
}
}
if ( $do_it_warning_min || $do_it_critical_min ) {
foreach ( $module_list as $index => $id_module ) {
2019-05-09 16:26:38 +02:00
$warning_inverse = db_get_value (
'warning_inverse' ,
'tagente_modulo' ,
'id_agente_modulo' ,
$id_module
);
$critical_inverse = db_get_value (
'critical_inverse' ,
'tagente_modulo' ,
'id_agente_modulo' ,
$id_module
);
2019-01-30 16:18:44 +01:00
if ( $index == 0 ) {
$yellow_inverse = $warning_inverse ;
} else {
if ( $yellow_inverse != $warning_inverse ) {
$do_it_warning_inverse = false ;
}
}
if ( $index == 0 ) {
$red_inverse = $critical_inverse ;
} else {
if ( $red_inverse != $critical_inverse ) {
$do_it_critical_inverse = false ;
}
}
}
}
2019-05-09 16:26:38 +02:00
if ( $do_it_warning_min
&& $do_it_warning_max
&& $do_it_warning_inverse
) {
2019-01-30 16:18:44 +01:00
$yellow_threshold = $compare_warning ;
$threshold_data [ 'yellow_threshold' ] = $compare_warning ;
2019-05-09 16:26:38 +02:00
$threshold_data [ 'yellow_up' ] = $yellow_up ;
$threshold_data [ 'yellow_inverse' ] = ( bool ) $yellow_inverse ;
2019-01-30 16:18:44 +01:00
}
2019-05-09 16:26:38 +02:00
if ( $do_it_critical_min
&& $do_it_critical_max
&& $do_it_critical_inverse
) {
2019-01-30 16:18:44 +01:00
$red_threshold = $compare_critical ;
$threshold_data [ 'red_threshold' ] = $compare_critical ;
2019-05-09 16:26:38 +02:00
$threshold_data [ 'red_up' ] = $red_up ;
$threshold_data [ 'red_inverse' ] = ( bool ) $red_inverse ;
2019-01-30 16:18:44 +01:00
}
$params [ 'threshold_data' ] = $threshold_data ;
}
2020-03-26 12:29:38 +01:00
if ( $params [ 'vconsole' ] === true ) {
$water_mark = false ;
}
2019-01-30 16:18:44 +01:00
$output = area_graph (
$agent_module_id ,
$array_data ,
$legend ,
$series_type ,
$color ,
$date_array ,
$data_module_graph ,
$params ,
$water_mark ,
$array_events_alerts
);
break ;
case CUSTOM_GRAPH_BULLET_CHART_THRESHOLD :
case CUSTOM_GRAPH_BULLET_CHART :
$number_elements = count ( $module_list );
if ( $params_combined [ 'stacked' ] == CUSTOM_GRAPH_BULLET_CHART_THRESHOLD ) {
$acumulador = 0 ;
foreach ( $module_list as $module_item ) {
$module = $module_item ;
$query_last_value = sprintf (
'
SELECT datos
FROM tagente_datos
WHERE id_agente_modulo = % d
AND utimestamp < % d
ORDER BY utimestamp DESC ' ,
$module ,
$params [ 'date' ]
);
$temp_data = db_get_value_sql ( $query_last_value );
if ( $acumulador < $temp_data ) {
$acumulador = $temp_data ;
}
}
}
foreach ( $module_list as $module_item ) {
2020-07-13 11:48:11 +02:00
if ( is_metaconsole () === true ) {
2019-05-09 16:26:38 +02:00
// Automatic custom graph from the report
// template in metaconsole.
2020-07-13 11:48:11 +02:00
$server = metaconsole_get_connection_by_id (
$module_item [ 'server' ]
);
metaconsole_connect ( $server );
2019-01-30 16:18:44 +01:00
}
2020-07-13 10:02:56 +02:00
$module = $module_item [ 'module' ];
2019-01-30 16:18:44 +01:00
$search_in_history_db = db_search_in_history_db ( $datelimit );
2020-07-13 10:02:56 +02:00
$temp [ $module ] = io_safe_output (
modules_get_agentmodule ( $module )
);
2020-07-13 11:48:11 +02:00
2019-01-30 16:18:44 +01:00
$query_last_value = sprintf (
'
SELECT datos
FROM tagente_datos
WHERE id_agente_modulo = % d
AND utimestamp < % d
ORDER BY utimestamp DESC ' ,
$module ,
$params [ 'date' ]
);
$temp_data = db_get_value_sql ( $query_last_value );
if ( $temp_data ) {
if ( is_numeric ( $temp_data )) {
$value = $temp_data ;
} else {
$value = count ( $value );
}
} else {
$value = false ;
}
2019-05-09 16:26:38 +02:00
if ( ! empty ( $params_combined [ 'labels' ])
&& isset ( $params_combined [ 'labels' ][ $module ])
) {
2019-12-04 17:45:58 +01:00
$label = io_safe_output ( $params_combined [ 'labels' ][ $module ]);
2019-01-30 16:18:44 +01:00
} else {
2019-05-09 16:26:38 +02:00
$alias = db_get_value (
'alias' ,
'tagente' ,
'id_agente' ,
$temp [ $module ][ 'id_agente' ]
);
2019-01-30 16:18:44 +01:00
$label = $alias . ': ' . $temp [ $module ][ 'nombre' ];
}
$temp [ $module ][ 'label' ] = $label ;
$temp [ $module ][ 'value' ] = $value ;
2019-05-09 16:26:38 +02:00
$temp_max = reporting_get_agentmodule_data_max (
$module ,
$params [ 'period' ],
$params [ 'date' ]
);
2019-01-30 16:18:44 +01:00
if ( $temp_max < 0 ) {
$temp_max = 0 ;
}
if ( isset ( $acumulador )) {
$temp [ $module ][ 'max' ] = $acumulador ;
} else {
$temp [ $module ][ 'max' ] = ( $temp_max === false ) ? 0 : $temp_max ;
}
2019-05-09 16:26:38 +02:00
$temp_min = reporting_get_agentmodule_data_min (
$module ,
$params [ 'period' ],
$params [ 'date' ]
);
2019-01-30 16:18:44 +01:00
if ( $temp_min < 0 ) {
$temp_min = 0 ;
}
$temp [ $module ][ 'min' ] = ( $temp_min === false ) ? 0 : $temp_min ;
2020-07-13 11:48:11 +02:00
if ( is_metaconsole () === true ) {
metaconsole_restore_db ();
2019-01-30 16:18:44 +01:00
}
}
$graph_values = $temp ;
if ( ! $params [ 'vconsole' ]) {
$width = 1024 ;
$height = 50 ;
} else {
$height = ( $height / $number_elements );
2020-03-26 12:29:38 +01:00
$water_mark = false ;
2019-01-30 16:18:44 +01:00
}
$color = color_graph_array ();
$output = stacked_bullet_chart (
$graph_values ,
$width ,
$height ,
$color ,
2021-11-05 11:22:25 +01:00
[],
2019-01-30 16:18:44 +01:00
$long_index ,
2019-05-09 16:26:38 +02:00
ui_get_full_url (
'images/image_problem_area_small.png' ,
false ,
false ,
false
),
2019-01-30 16:18:44 +01:00
'' ,
'' ,
$water_mark ,
$config [ 'fontpath' ],
( $config [ 'font_size' ] + 1 ),
'' ,
$ttl ,
$homeurl ,
$background_color
);
break ;
case CUSTOM_GRAPH_GAUGE :
$i = 0 ;
$number_elements = count ( $module_list );
foreach ( $module_list as $module_item ) {
2020-07-13 11:48:11 +02:00
if ( is_metaconsole () === true ) {
$server = metaconsole_get_connection_by_id (
$module_item [ 'server' ]
);
metaconsole_connect ( $server );
2019-01-30 16:18:44 +01:00
}
2020-07-13 10:02:56 +02:00
$module = $module_item [ 'module' ];
2019-01-30 16:18:44 +01:00
$temp [ $module ] = modules_get_agentmodule ( $module );
$query_last_value = sprintf (
'
SELECT datos
FROM tagente_datos
WHERE id_agente_modulo = % d
AND utimestamp < % d
ORDER BY utimestamp DESC ' ,
$module ,
$params [ 'date' ]
);
$temp_data = db_get_value_sql ( $query_last_value );
if ( $temp_data ) {
if ( is_numeric ( $temp_data )) {
$value = $temp_data ;
} else {
$value = count ( $value );
}
} else {
$value = false ;
}
$temp [ $module ][ 'label' ] = ( $params_combined [ 'labels' ][ $module ] != '' ) ? $params_combined [ 'labels' ][ $module ] : $temp [ $module ][ 'nombre' ];
$temp [ $module ][ 'value' ] = $value ;
2019-05-09 16:26:38 +02:00
$temp [ $module ][ 'label' ] = ui_print_truncate_text (
$temp [ $module ][ 'label' ],
'module_small' ,
false ,
true ,
false ,
'..'
);
2019-01-30 16:18:44 +01:00
if ( $temp [ $module ][ 'unit' ] == '%' ) {
$temp [ $module ][ 'min' ] = 0 ;
$temp [ $module ][ 'max' ] = 100 ;
} else {
$min = $temp [ $module ][ 'min' ];
if ( $temp [ $module ][ 'max' ] == 0 ) {
2019-05-09 16:26:38 +02:00
$max = reporting_get_agentmodule_data_max (
$module ,
$params [ 'period' ],
$params [ 'date' ]
);
2019-01-30 16:18:44 +01:00
} else {
$max = $temp [ $module ][ 'max' ];
}
$temp [ $module ][ 'min' ] = ( $min == 0 ) ? 0 : $min ;
$temp [ $module ][ 'max' ] = ( $max == 0 ) ? 100 : $max ;
}
$temp [ $module ][ 'gauge' ] = uniqid ( 'gauge_' );
2020-07-13 11:48:11 +02:00
if ( is_metaconsole () === true ) {
metaconsole_restore_db ();
2019-01-30 16:18:44 +01:00
}
$i ++ ;
}
$graph_values = $temp ;
$color = color_graph_array ();
2020-03-26 12:29:38 +01:00
if ( $params [ 'vconsole' ] === false ) {
2020-05-20 10:00:38 +02:00
$new_width = 200 ;
$new_height = 200 ;
2019-01-30 16:18:44 +01:00
} else {
2020-03-26 12:29:38 +01:00
$ratio = (( 200 * ( $height / ( 200 * $number_elements ) )) / ( 200 * ( $width / ( 200 * $number_elements ))));
$new_width = ( 200 * ( $width / ( 200 * $number_elements ) ) );
$new_height = ( 200 * ( $height / ( 200 * $number_elements ) / $ratio ) );
if ( $height > $width ) {
$new_height = ( 200 * ( $height / ( 200 * $number_elements )));
$new_width = ( 200 * ( $width / ( 200 * $number_elements )) / $ratio );
}
2019-01-30 16:18:44 +01:00
}
2020-06-01 14:48:53 +02:00
if ( isset ( $params [ 'pdf' ]) === true && $params [ 'pdf' ] === true ) {
$transitionDuration = 0 ;
} else {
$transitionDuration = 500 ;
}
2019-01-30 16:18:44 +01:00
$output = stacked_gauge (
$graph_values ,
2020-03-26 12:29:38 +01:00
$new_width ,
$new_height ,
2019-01-30 16:18:44 +01:00
$color ,
$module_name_list ,
2019-05-09 16:26:38 +02:00
ui_get_full_url (
'images/image_problem_area_small.png' ,
false ,
false ,
false
),
2019-01-30 16:18:44 +01:00
$config [ 'fontpath' ],
$fixed_font_size ,
'' ,
2020-06-01 14:48:53 +02:00
$homeurl ,
$transitionDuration
2019-01-30 16:18:44 +01:00
);
break ;
case CUSTOM_GRAPH_HBARS :
case CUSTOM_GRAPH_VBARS :
$label = '' ;
2020-12-17 16:58:20 +01:00
$i = 0 ;
2019-01-30 16:18:44 +01:00
foreach ( $module_list as $module_item ) {
2020-12-17 16:58:20 +01:00
if ( $i >= $config [ 'items_combined_charts' ]) {
break ;
}
2020-03-26 12:29:38 +01:00
if ( is_metaconsole () === true ) {
2020-07-13 11:48:11 +02:00
$server = metaconsole_get_connection_by_id (
$module_item [ 'server' ]
);
metaconsole_connect ( $server );
2019-01-30 16:18:44 +01:00
}
2020-07-13 10:02:56 +02:00
$module = $module_item [ 'module' ];
2019-01-30 16:18:44 +01:00
$module_data = modules_get_agentmodule ( $module );
$query_last_value = sprintf (
2020-03-26 12:29:38 +01:00
' SELECT datos
2019-01-30 16:18:44 +01:00
FROM tagente_datos
WHERE id_agente_modulo = % d
AND utimestamp < % d
ORDER BY utimestamp DESC ' ,
$module ,
$params [ 'date' ]
);
$temp_data = db_get_value_sql ( $query_last_value );
2020-03-26 12:29:38 +01:00
if ( empty ( $params_combined [ 'labels' ]) === false
&& isset ( $params_combined [ 'labels' ][ $module ]) === true
2019-05-09 16:26:38 +02:00
) {
2019-01-30 16:18:44 +01:00
$label = $params_combined [ 'labels' ][ $module ];
} else {
2019-05-09 16:26:38 +02:00
$alias = db_get_value (
'alias' ,
'tagente' ,
'id_agente' ,
$module_data [ 'id_agente' ]
);
2022-12-22 23:03:52 +01:00
$label = $alias . ' - ' . $module_data [ 'nombre' ];
2019-01-30 16:18:44 +01:00
}
2022-12-22 23:03:52 +01:00
$graph_labels [] = io_safe_output ( $label );
if ( $params_combined [ 'stacked' ] == CUSTOM_GRAPH_HBARS ) {
$graph_values [] = [
'y' => io_safe_output ( $label ),
'x' => round ( $temp_data , 4 ),
];
} else {
$graph_values [] = [
'x' => io_safe_output ( $label ),
'y' => round ( $temp_data , 4 ),
];
}
2019-01-30 16:18:44 +01:00
2020-03-26 12:29:38 +01:00
if ( is_metaconsole () === true ) {
2020-07-13 11:48:11 +02:00
metaconsole_restore_db ();
2019-01-30 16:18:44 +01:00
}
2020-12-17 16:58:20 +01:00
$i ++ ;
2019-01-30 16:18:44 +01:00
}
2022-12-16 10:38:37 +01:00
$color = color_graph_array ();
2020-03-26 12:29:38 +01:00
2022-12-16 10:38:37 +01:00
if ( $params [ 'vconsole' ] === true ) {
$water_mark = '' ;
2019-01-30 16:18:44 +01:00
}
2022-12-16 10:38:37 +01:00
$options = [
2022-12-21 10:07:18 +01:00
'height' => $height ,
'waterMark' => $water_mark ,
'ttl' => $ttl ,
'pdf' => $params [ 'pdf' ],
'legend' => [ 'display' => false ],
'scales' => [
2022-12-16 10:38:37 +01:00
'x' => [
'bounds' => 'data' ,
'grid' => [ 'display' => false ],
],
'y' => [
'grid' => [ 'display' => false ],
],
],
2022-12-22 23:03:52 +01:00
'labels' => $graph_labels ,
2022-12-16 10:38:37 +01:00
];
2020-03-26 12:29:38 +01:00
2022-12-16 10:38:37 +01:00
if ( $params_combined [ 'stacked' ] == CUSTOM_GRAPH_HBARS ) {
$options [ 'axis' ] = 'y' ;
2019-01-30 16:18:44 +01:00
}
2022-12-16 10:38:37 +01:00
2022-12-20 12:23:18 +01:00
if (( bool ) $params [ 'pdf' ] === true ) {
$options [ 'dataLabel' ] = [ 'display' => 'auto' ];
if ( $params_combined [ 'stacked' ] == CUSTOM_GRAPH_HBARS ) {
$options [ 'layout' ] = [
'padding' => [ 'right' => 35 ],
];
} else {
$options [ 'layout' ] = [
'padding' => [ 'top' => 35 ],
];
}
}
2022-12-16 10:38:37 +01:00
$output = '<div style="display: flex; flex-direction:row; justify-content: center; align-items: center; align-content: center; width:100%; height:100%;">' ;
2022-12-21 10:07:18 +01:00
$output .= '<div style="flex: 0 0 auto; width:99%; height:100%; background-color:' . $background_color . '">' ;
2022-12-16 10:38:37 +01:00
$output .= vbar_graph ( $graph_values , $options );
$output .= '</div>' ;
$output .= '</div>' ;
2019-01-30 16:18:44 +01:00
break ;
case CUSTOM_GRAPH_PIE :
$total_modules = 0 ;
foreach ( $module_list as $module_item ) {
2020-07-13 11:48:11 +02:00
if ( is_metaconsole () === true ) {
$server = metaconsole_get_connection_by_id (
$module_item [ 'server' ]
);
metaconsole_connect ( $server );
2019-01-30 16:18:44 +01:00
}
2020-07-13 10:02:56 +02:00
$module = $module_item [ 'module' ];
2019-01-30 16:18:44 +01:00
$data_module = modules_get_agentmodule ( $module );
$query_last_value = sprintf (
2020-07-13 10:02:56 +02:00
' SELECT datos
2019-01-30 16:18:44 +01:00
FROM tagente_datos
WHERE id_agente_modulo = % d
AND utimestamp < % d
ORDER BY utimestamp DESC ' ,
$module ,
$params [ 'date' ]
);
2020-03-26 12:29:38 +01:00
2019-01-30 16:18:44 +01:00
$temp_data = db_get_value_sql ( $query_last_value );
2022-12-22 23:03:52 +01:00
if ( $temp_data !== false ) {
if ( is_numeric ( $temp_data ) === true ) {
2019-01-30 16:18:44 +01:00
$value = $temp_data ;
} else {
$value = count ( $value );
}
} else {
$value = false ;
}
$total_modules += $value ;
2022-12-22 23:03:52 +01:00
if ( empty ( $params_combined [ 'labels' ]) === false
&& isset ( $params_combined [ 'labels' ][ $module ]) === true
2019-05-09 16:26:38 +02:00
) {
$label = io_safe_output (
$params_combined [ 'labels' ][ $module ]
);
2019-01-30 16:18:44 +01:00
} else {
2019-05-09 16:26:38 +02:00
$alias = db_get_value (
'alias' ,
'tagente' ,
'id_agente' ,
$data_module [ 'id_agente' ]
);
2019-01-30 16:18:44 +01:00
$label = io_safe_output ( $alias . ': ' . $data_module [ 'nombre' ]);
}
2022-12-20 12:23:18 +01:00
if (( bool ) $params [ 'pdf' ] === true ) {
$value = ( empty ( $value ) === false ) ? $value : 0 ;
$label .= ' (' . $value . ')' ;
}
2022-12-22 23:03:52 +01:00
$graph_labels [] = io_safe_output ( $label );
$graph_values [] = round ( $temp_data , 4 );
2020-07-13 11:48:11 +02:00
if ( is_metaconsole () === true ) {
metaconsole_restore_db ();
2019-01-30 16:18:44 +01:00
}
}
2022-12-22 23:03:52 +01:00
if ( $params [ 'vconsole' ] === true ) {
2020-03-26 12:29:38 +01:00
$water_mark = false ;
2019-01-30 16:18:44 +01:00
}
2022-12-13 09:10:13 +01:00
$options = [
2022-12-21 10:07:18 +01:00
'waterMark' => $water_mark ,
'ttl' => $ttl ,
'pdf' => $params [ 'pdf' ],
'legend' => [
2022-12-20 12:23:18 +01:00
'display' => ( bool ) $params [ 'show_legend' ],
'position' => 'right' ,
'align' => 'center' ,
],
2022-12-22 23:03:52 +01:00
'labels' => $graph_labels ,
2022-12-13 09:10:13 +01:00
];
2019-01-30 16:18:44 +01:00
2022-12-20 12:23:18 +01:00
if (( bool ) $params [ 'pdf' ] === true ) {
$options [ 'dataLabel' ] = [ 'display' => 'auto' ];
$options [ 'layout' ] = [
'padding' => [
'top' => 20 ,
'bottom' => 20 ,
],
];
}
2022-12-13 09:10:13 +01:00
$output = '<div style="display: flex; flex-direction:row; justify-content: center; align-items: center; align-content: center; width:100%; height:100%;">' ;
2022-12-21 10:07:18 +01:00
$output .= '<div style="flex: 0 0 auto; width:99%; height:100%; background-color:' . $background_color . '">' ;
2022-12-13 09:10:13 +01:00
$output .= ring_graph ( $graph_values , $options );
$output .= '</div>' ;
$output .= '</div>' ;
2019-01-30 16:18:44 +01:00
break ;
}
if ( $params_combined [ 'return' ]) {
return $output ;
}
echo $output ;
2011-04-12 18:30:24 +02:00
}
2019-01-30 16:18:44 +01:00
2023-10-18 12:49:47 +02:00
/**
* Draw periodicity graph
*
* @ param array $params Params for draw chart .
*
* @ return string Html output .
*/
function graphic_periodicity_module ( array $params ) : string
{
2023-10-23 17:02:08 +02:00
if ( isset ( $params [ 'date' ]) === false || ! $params [ 'date' ]) {
$params [ 'date' ] = get_system_time ();
}
2023-10-18 12:49:47 +02:00
$date_array = [];
$date_array [ 'period' ] = $params [ 'period' ];
$date_array [ 'final_date' ] = $params [ 'date' ];
$date_array [ 'start_date' ] = ( $params [ 'date' ] - $params [ 'period' ]);
$array_data = fullscale_data (
$params [ 'agent_module_id' ],
$date_array ,
false ,
false ,
1 ,
false ,
$params [ 'period_slice_chart' ],
0
);
if ( empty ( $array_data ) === false ) {
$graph_labels = [];
$multiple_labels = [];
foreach ( $array_data [ 'sum1' ][ 'slice_data' ] as $time => $array_data ) {
$graph_labels [] = date ( 'H:i' , ( $time / 1000 ));
$avg = [
'y' => $array_data [ 'avg' ],
'x' => $time ,
];
$max = [
'y' => $array_data [ 'max' ],
'x' => $time ,
];
$min = [
'y' => $array_data [ 'min' ],
'x' => $time ,
];
$sum = [
'y' => $array_data [ 'sum' ],
'x' => $time ,
];
if (( int ) $params [ 'period_mode' ] === CUSTOM_GRAPH_HBARS ) {
$avg = [
'x' => $array_data [ 'avg' ],
'y' => $time ,
];
$max = [
'x' => $array_data [ 'max' ],
'y' => $time ,
];
$min = [
'x' => $array_data [ 'min' ],
'y' => $time ,
];
$sum = [
'x' => $array_data [ 'sum' ],
'y' => $time ,
];
}
$graph_values_avg [] = $avg ;
$graph_values_max [] = $max ;
$graph_values_min [] = $min ;
$graph_values_sum [] = $sum ;
}
if (( bool ) $params [ 'period_average' ] === true ) {
$graph_values [ 'avg' ] = $graph_values_avg ;
$multiple_labels [ 'avg' ] = [
'label' => __ ( 'Average' ),
'fill' => (( int ) $params [ 'period_mode' ] === CUSTOM_GRAPH_AREA ) ? true : false ,
];
}
if (( bool ) $params [ 'period_maximum' ] === true ) {
$graph_values [ 'max' ] = $graph_values_max ;
$multiple_labels [ 'max' ] = [
'label' => __ ( 'Maximun' ),
'fill' => (( int ) $params [ 'period_mode' ] === CUSTOM_GRAPH_AREA ) ? true : false ,
];
}
if (( bool ) $params [ 'period_minimum' ] === true ) {
$graph_values [ 'min' ] = $graph_values_min ;
$multiple_labels [ 'min' ] = [
'label' => __ ( 'Minimum' ),
'fill' => (( int ) $params [ 'period_mode' ] === CUSTOM_GRAPH_AREA ) ? true : false ,
];
}
if (( bool ) $params [ 'period_summatory' ] === true ) {
$graph_values [ 'sum' ] = $graph_values_sum ;
$multiple_labels [ 'sum' ] = [
'label' => __ ( 'Summatory' ),
'fill' => (( int ) $params [ 'period_mode' ] === CUSTOM_GRAPH_AREA ) ? true : false ,
];
}
}
$options = [
2023-10-23 17:02:08 +02:00
'height' => ( isset ( $params [ 'height' ]) === true ) ? $params [ 'height' ] : 200 ,
2023-10-18 12:49:47 +02:00
'waterMark' => true ,
'legend' => [ 'display' => true ],
'labels' => $graph_labels ,
'multiple' => $multiple_labels ,
2023-10-23 17:02:08 +02:00
'legend' => [
'display' => ( isset ( $params [ 'show_legend' ])) ? $params [ 'show_legend' ] : true ,
],
2023-10-25 15:55:54 +02:00
'ttl' => ( isset ( $params [ 'ttl' ]) === true ) ? $params [ 'ttl' ] : 1 ,
2023-10-18 12:49:47 +02:00
];
if (( int ) $params [ 'period_mode' ] === CUSTOM_GRAPH_HBARS
|| ( int ) $params [ 'period_mode' ] === CUSTOM_GRAPH_VBARS
) {
if (( int ) $params [ 'period_mode' ] === CUSTOM_GRAPH_HBARS ) {
$options [ 'axis' ] = 'y' ;
}
2023-10-23 17:02:08 +02:00
$output = vbar_graph ( $graph_values , $options );
2023-10-18 12:49:47 +02:00
} else {
2023-10-23 17:02:08 +02:00
$output = line_graph ( $graph_values , $options );
2023-10-18 12:49:47 +02:00
}
return $output ;
}
2019-05-09 16:26:38 +02:00
/**
* Function for convert data summatory .
*
* @ param array $array_data Data array .
* @ param boolean $average Average .
* @ param boolean $summatory Summatory .
* @ param boolean $modules_series Series module .
2019-09-24 17:39:11 +02:00
* @ param array $date_array Date data .
2019-05-09 16:26:38 +02:00
*
* @ return array Data .
*/
function combined_graph_summatory_average (
$array_data ,
$average = false ,
$summatory = false ,
$modules_series = false ,
2019-09-24 17:39:11 +02:00
$date_array = []
2019-05-09 16:26:38 +02:00
) {
2019-01-30 16:18:44 +01:00
if ( isset ( $array_data ) && is_array ( $array_data )) {
2019-09-24 17:39:11 +02:00
$reduce_array = [];
2019-01-30 16:18:44 +01:00
foreach ( $array_data as $key => $value ) {
if ( strpos ( $key , 'sum' ) !== false ) {
2019-09-24 17:39:11 +02:00
$last = $date_array [ 'start_date' ];
$reduce_array = array_reduce (
$value [ 'data' ],
function ( $carry , $item ) use ( $date_array , $last , $reduce_array ) {
$slice_start = $date_array [ 'start_date' ];
$iterator = $last ;
// JS to PHP timestamp format.
$item [ 0 ] /= 1000 ;
while ( $iterator <= $date_array [ 'final_date' ]) {
if ( $item [ 0 ] >= $slice_start && $item [ 0 ] < $iterator ) {
$array = [];
$val = 0 ;
$n = 0 ;
if ( is_array ( $reduce_array [ $slice_start ])) {
$val = $reduce_array [ $slice_start ][ 'value' ];
$n = ( $reduce_array [ $slice_start ][ 'n' ] + 1 );
}
2019-01-30 16:18:44 +01:00
2019-09-24 17:39:11 +02:00
$array [ 'value' ] = ( $item [ 1 ] + $val );
$array [ 'n' ] = $n ;
$array [ 't' ] = ( $slice_start * 1000 );
2019-01-30 16:18:44 +01:00
2019-09-24 17:39:11 +02:00
$carry [ $slice_start ] = $array ;
$last = $iterator ;
break ;
2019-01-30 16:18:44 +01:00
} else {
2019-09-24 17:39:11 +02:00
$slice_start = $iterator ;
$iterator += 300 ;
2019-01-30 16:18:44 +01:00
}
}
2019-09-24 17:39:11 +02:00
$i ++ ;
return $carry ;
},
$reduce_array
);
}
2019-01-30 16:18:44 +01:00
2019-09-24 17:39:11 +02:00
if ( ! $modules_series ) {
unset ( $array_data [ $key ]);
}
}
2019-01-30 16:18:44 +01:00
2019-09-24 17:39:11 +02:00
$reduce_array_summatory = [];
$reduce_array_average = [];
$i = 0 ;
foreach ( $reduce_array as $item ) {
$reduce_array_summatory [ $i ][ 0 ] = $item [ 't' ];
$reduce_array_summatory [ $i ][ 1 ] = $item [ 'value' ];
2019-01-30 16:18:44 +01:00
2019-09-24 17:39:11 +02:00
$reduce_array_average [ $i ][ 0 ] = $item [ 't' ];
$reduce_array_average [ $i ][ 1 ] = ( $item [ 'value' ] / ( $item [ 'n' ] + 1 ));
2019-01-30 16:18:44 +01:00
2019-09-24 17:39:11 +02:00
$i ++ ;
}
2019-01-30 16:18:44 +01:00
2019-09-24 17:39:11 +02:00
if ( $summatory && isset ( $reduce_array_summatory )
&& is_array ( $reduce_array_summatory )
&& count ( $reduce_array_summatory ) > 0
) {
$array_data [ 'summatory' ][ 'data' ] = $reduce_array_summatory ;
}
if ( $average && isset ( $reduce_array_average )
&& is_array ( $reduce_array_average )
&& count ( $reduce_array_average ) > 0
) {
$array_data [ 'average' ][ 'data' ] = $reduce_array_average ;
2019-01-30 16:18:44 +01:00
}
return $array_data ;
} else {
return false ;
}
2018-05-18 14:22:39 +02:00
}
2019-01-30 16:18:44 +01:00
2013-02-27 18:11:42 +01:00
/**
* Print a pie graph with alerts defined / fired data
2019-01-30 16:18:44 +01:00
*
2013-02-27 18:11:42 +01:00
* @ param integer Number of defined alerts
* @ param integer Number of fired alerts
* @ param integer width pie graph width
* @ param integer height pie graph height
* @ param bool return or echo flag
*/
2019-01-30 16:18:44 +01:00
function graph_alert_status ( $defined_alerts , $fired_alerts , $width = 300 , $height = 200 , $return = false )
{
global $config ;
2022-12-22 23:03:52 +01:00
$labels = [
__ ( 'Not fired alerts' ),
__ ( 'Fired alerts' ),
];
2019-01-30 16:18:44 +01:00
$data = [
2022-12-22 23:03:52 +01:00
( $defined_alerts - $fired_alerts ),
$fired_alerts ,
2019-01-30 16:18:44 +01:00
];
$colors = [
COL_NORMAL ,
COL_ALERTFIRED ,
];
2022-12-13 09:10:13 +01:00
$options = [
'width' => $width ,
'height' => $height ,
'colors' => $colors ,
'legend' => [ 'display' => false ],
2022-12-22 23:03:52 +01:00
'labels' => $labels ,
2022-12-13 09:10:13 +01:00
];
2019-01-30 16:18:44 +01:00
$out = pie_graph (
$data ,
2022-12-13 09:10:13 +01:00
$options
2019-01-30 16:18:44 +01:00
);
2022-12-22 23:03:52 +01:00
if ( $return === true ) {
2019-01-30 16:18:44 +01:00
return $out ;
} else {
echo $out ;
}
2013-02-27 18:11:42 +01:00
}
2019-01-30 16:18:44 +01:00
2013-04-15 18:04:39 +02:00
// If any value is negative, truncate it to 0
2019-01-30 16:18:44 +01:00
function truncate_negatives ( & $element )
{
if ( $element < 0 ) {
$element = 0 ;
}
2013-04-15 18:04:39 +02:00
}
2019-01-30 16:18:44 +01:00
2013-02-20 18:15:38 +01:00
/**
2020-09-21 15:13:07 +02:00
* Print a pie graph with events
* data of agent or all agents ( if id_agent = false ) .
2019-01-30 16:18:44 +01:00
*
2020-09-21 15:13:07 +02:00
* @ param integer $id_agent Agent ID .
* @ param integer $width Pie graph width .
* @ param integer $height Pie graph height .
* @ param boolean $return Flag .
* @ param boolean $show_not_init Flag .
* @ param array $data_agents Data .
* @ param boolean $donut_narrow_graph Flag type graph .
*
* @ return string Html chart .
2013-02-20 18:15:38 +01:00
*/
2020-09-21 15:13:07 +02:00
function graph_agent_status (
$id_agent = false ,
$width = 300 ,
$height = 200 ,
$return = false ,
$show_not_init = false ,
$data_agents = false ,
2023-11-07 13:18:44 +01:00
$donut_narrow_graph = false ,
$onClick = '' ,
$data_in_percentage = false ,
2020-09-21 15:13:07 +02:00
) {
2019-01-30 16:18:44 +01:00
global $config ;
if ( $data_agents == false ) {
2020-09-21 15:13:07 +02:00
$groups = implode (
',' ,
array_keys ( users_get_groups ( false , 'AR' , false ))
);
2019-01-30 16:18:44 +01:00
$p_table = 'tagente' ;
$s_table = 'tagent_secondary_group' ;
if ( is_metaconsole ()) {
$p_table = 'tmetaconsole_agent' ;
$s_table = 'tmetaconsole_agent_secondary_group' ;
}
2020-09-21 15:13:07 +02:00
$sql = sprintf (
' SELECT SUM ( critical_count ) AS Critical ,
2019-01-30 16:18:44 +01:00
SUM ( warning_count ) AS Warning ,
SUM ( normal_count ) AS Normal ,
SUM ( unknown_count ) AS Unknown
% s
FROM % s ta LEFT JOIN % s tasg
ON ta . id_agente = tasg . id_agent
WHERE
ta . disabled = 0 AND
% s
( ta . id_grupo IN ( % s ) OR tasg . id_group IN ( % s )) ' ,
2020-09-21 15:13:07 +02:00
$show_not_init ? ', SUM(notinit_count) "Not init"' : '' ,
$p_table ,
$s_table ,
( empty ( $id_agent ) === true ) ? '' : 'ta.id_agente = ' . $id_agent . ' AND' ,
$groups ,
$groups
2019-01-30 16:18:44 +01:00
);
2020-09-21 15:13:07 +02:00
$data = db_get_row_sql ( $sql );
2019-01-30 16:18:44 +01:00
} else {
$data = $data_agents ;
}
2020-09-21 15:13:07 +02:00
if ( empty ( $data ) === true ) {
2019-01-30 16:18:44 +01:00
$data = [];
}
array_walk ( $data , 'truncate_negatives' );
if ( $config [ 'fixed_graph' ] == false ) {
$water_mark = [
'file' => $config [ 'homedir' ] . '/images/logo_vertical_water.png' ,
2020-09-21 15:13:07 +02:00
'url' => ui_get_full_url (
'images/logo_vertical_water.png' ,
false ,
false ,
false
),
2019-01-30 16:18:44 +01:00
];
}
2019-06-06 17:50:47 +02:00
$colors [ 'Critical' ] = COL_CRITICAL ;
$colors [ 'Warning' ] = COL_WARNING ;
$colors [ 'Normal' ] = COL_NORMAL ;
$colors [ 'Unknown' ] = COL_UNKNOWN ;
2019-01-30 16:18:44 +01:00
if ( $show_not_init ) {
2019-06-06 17:50:47 +02:00
$colors [ 'Not init' ] = COL_NOTINIT ;
2019-01-30 16:18:44 +01:00
}
if ( array_sum ( $data ) == 0 ) {
$data = [];
}
2022-12-13 09:10:13 +01:00
$options = [
'width' => $width ,
'height' => $height ,
'colors' => array_values ( $colors ),
'legend' => [ 'display' => false ],
2023-09-27 13:30:56 +02:00
'labels' => array_keys ( $data ),
2022-12-13 09:10:13 +01:00
];
2023-11-07 13:18:44 +01:00
if ( empty ( $onClick ) === false ) {
$options [ 'onClick' ] = $onClick ;
}
if ( $data_in_percentage === true ) {
$percentages = [];
$total = array_sum ( $data );
foreach ( $data as $key => $value ) {
$percentage = (( $value / $total ) * 100 );
if ( $percentage < 1 && $percentage > 0 ) {
$percentage = 1 ;
}
$percentages [ $key ] = format_numeric ( $percentage , 0 );
}
$data = $percentages ;
}
2019-05-27 19:00:48 +02:00
if ( $donut_narrow_graph == true ) {
2022-12-13 09:10:13 +01:00
$out = ring_graph (
2019-05-27 19:00:48 +02:00
$data ,
2022-12-13 09:10:13 +01:00
$options
2019-05-27 19:00:48 +02:00
);
2019-01-30 16:18:44 +01:00
return $out ;
} else {
2019-05-27 19:00:48 +02:00
$out = pie_graph (
$data ,
2022-12-13 09:10:13 +01:00
$options
2019-05-27 19:00:48 +02:00
);
if ( $return ) {
return $out ;
} else {
echo $out ;
}
2019-01-30 16:18:44 +01:00
}
2011-04-12 18:30:24 +02:00
}
2013-02-20 18:15:38 +01:00
2019-01-30 16:18:44 +01:00
function progress_bar ( $progress , $width , $height , $title = '' , $mode = 1 , $value_text = false , $color = false , $options = false )
{
global $config ;
$out_of_lim_str = io_safe_output ( __ ( 'Out of limits' ));
$title = '' ;
if ( $value_text === false ) {
$value_text = $progress . '%' ;
}
$colorRGB = '' ;
if ( $color !== false ) {
$colorRGB = html_html2rgb ( $color );
$colorRGB = implode ( '|' , $colorRGB );
}
$class_tag = '' ;
$id_tag = '' ;
if ( $options !== false ) {
foreach ( $options as $option_type => $option_value ) {
if ( $option_type == 'class' ) {
$class_tag = ' class="' . $option_value . '" ' ;
} else if ( $option_type == 'id' ) {
$id_tag = ' id="' . $option_value . '" ' ;
}
}
}
include_once 'include_graph_dependencies.php' ;
include_graphs_dependencies ( $config [ 'homedir' ] . '/' );
$src = ui_get_full_url (
'/include/graphs/fgraph.php?graph_type=progressbar' . '&width=' . $width . '&height=' . $height . '&progress=' . $progress . '&mode=' . $mode . '&out_of_lim_str=' . $out_of_lim_str . '&title=' . $title . '&value_text=' . $value_text . '&colorRGB=' . $colorRGB ,
false ,
false ,
false
);
return " <img title=' " . $title . " ' alt=' " . $title . " ' " . $class_tag . $id_tag . " src=' " . $src . " ' /> " ;
2012-03-05 Miguel de Dios <miguel.dedios@artica.es>
* extensions/update_manager/main.php, general/shortcut_bar.php,
godmode/reporting/reporting_builder.item_editor.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.preview.php, include/functions_api.php,
include/functions_html.php, include/htmlawed.php, include/pchart_graph.php,
operation/events/events_list.php, operation/netflow/nf_live_view.php:
cleaned source code style.
* godmode/menu.php, godmode/agentes/manage_config_remote.php: removed the
enterprise feature that have been wrong for years.
* general/header.php: changed to load the jquery-ui and jquery javascript
library to last version.
* extensions/insert_data.php, extensions/snmp_explorer.php,
godmode/agentes/agent_manager.php, include/ajax/agent.php,
include/javascript/pandora.js, operation/agentes/exportdata.php,
operation/events/events.php: changed the unknow plugin autocomplete for
the autocomple from jquery-ui.
* include/functions_ui.php: cleaned source code style and into the function
"ui_process_page_head" added the blacklist hardwrote for to use old jquery.
* include/styles/jquery-ui-1.8.17.custom.css,
include/javascript/jquery-1.7.1.min.js,
include/javascript/jquery.jquery-ui-1.8.17.custom.min.js: added the last
version of Jquery and Jquery-ui.
Merge from the branch "pandora_4.0"
* godmode/reporting/visual_console_builder.constans.php,
godmode/reporting/visual_console_builder.editor.js,
godmode/reporting/visual_console_builder.editor.php,
include/functions_visual_map.php,
include/ajax/visual_console_builder.ajax.php,
include/javascript/pandora_visual_console.js: changed the unknow
plugin autocomplete for the autocomple from jquery-ui and added function to
paint a Bubble Chart (http://en.wikipedia.org/wiki/Bubble_chart) with the
name "progress_bubble".
* images/percentile_item.disabled.png, images/percentile_item.png: added
images for button of percentile item (new item in visual map).
* include/styles/pandora.css: added the style for the new button percentile
item.
* include/functions_graph.php, include/graphs/fgraph.php,
include/graphs/functions_gd.php: cleaned source code style, and added the
params to set text and color in the function "progress_bar" and added
function to paint a Bubble Chart (http://en.wikipedia.org/wiki/Bubble_chart)
with the name "progress_bubble".
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@5693 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-03-05 18:56:56 +01:00
}
2011-06-13 13:12:32 +02:00
2019-01-30 16:18:44 +01:00
function progress_bubble ( $progress , $width , $height , $title = '' , $mode = 1 , $value_text = false , $color = false )
{
global $config ;
$hack_metaconsole = '' ;
if ( defined ( 'METACONSOLE' )) {
$hack_metaconsole = '../../' ;
}
$out_of_lim_str = io_safe_output ( __ ( 'Out of limits' ));
$title = '' ;
if ( $value_text === false ) {
$value_text = $progress . '%' ;
}
$colorRGB = '' ;
if ( $color !== false ) {
$colorRGB = html_html2rgb ( $color );
$colorRGB = implode ( '|' , $colorRGB );
}
include_once 'include_graph_dependencies.php' ;
include_graphs_dependencies ( $config [ 'homedir' ] . '/' );
return " <img title=' " . $title . " ' alt=' " . $title . " ' " . " src=' " . $config [ 'homeurl' ] . $hack_metaconsole . '/include/graphs/fgraph.php?graph_type=progressbubble' . '&width=' . $width . '&height=' . $height . '&progress=' . $progress . '&mode=' . $mode . '&out_of_lim_str=' . $out_of_lim_str . '&title=' . $title . '&value_text=' . $value_text . '&colorRGB=' . $colorRGB . " ' /> " ;
2011-04-13 Miguel de Dios <miguel.dedios@artica.es>
* include/functions_graph.php, include/graphs/functions_gd.php,
include/graphs/fgraph.php, include/functions_visual_map.php,
include/fgraph.php, operation/agentes/estado_generalagente.php,
operation/agentes/tactical.php. operation/agentes/stat_win.php,
operation/servers/view_server.php, operation/servers/view_server_detail.php,
mobile/operation/agents/tactical.php, general/logon_ok.php,
godmode/reporting/graph_builder.preview.php: added function "progress_bar2"
and changed in source code of Pandora.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4199 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-04-13 11:29:10 +02:00
}
2011-04-13 15:01:37 +02:00
2019-01-30 16:18:44 +01:00
function graph_sla_slicebar (
$id ,
$period ,
$sla_min ,
$sla_max ,
$date ,
2022-01-21 17:39:11 +01:00
$daysWeek ,
$time_from ,
$time_to ,
2019-01-30 16:18:44 +01:00
$width ,
$height ,
$home_url ,
$ttl = 1 ,
$data = false ,
$round_corner = null
) {
global $config ;
if ( $round_corner === null ) {
$round_corner = $config [ 'round_corner' ];
}
$col_planned_downtime = '#20973F' ;
$colors = [
1 => COL_NORMAL ,
2 => COL_WARNING ,
3 => COL_CRITICAL ,
4 => COL_UNKNOWN ,
5 => COL_DOWNTIME ,
6 => COL_NOTINIT ,
7 => COL_IGNORED ,
];
return $return [ 'chart' ] = flot_slicesbar_graph (
$data ,
$period ,
$width ,
$height ,
'' ,
$colors ,
$config [ 'fontpath' ],
$round_corner ,
$home_url ,
'' ,
'' ,
false ,
0 ,
[],
true ,
$ttl ,
false ,
2022-05-25 09:06:22 +02:00
true ,
2020-01-27 11:52:13 +01:00
$date
2019-01-30 16:18:44 +01:00
);
2011-04-13 15:01:37 +02:00
}
2011-04-13 17:58:59 +02:00
2019-01-30 16:18:44 +01:00
2019-09-27 12:07:40 +02:00
function series_suffix_leyend ( $series_name , $series_suffix , $id_agent , $data_module_graph , $array_data )
{
global $config ;
$array_data [ $series_name . $series_suffix ][ 'agent_module_id' ] = $id_agent ;
$array_data [ $series_name . $series_suffix ][ 'id_module_type' ] = $data_module_graph [ 'id_module_type' ];
$array_data [ $series_name . $series_suffix ][ 'agent_name' ] = $data_module_graph [ 'agent_name' ];
$array_data [ $series_name . $series_suffix ][ 'module_name' ] = $data_module_graph [ 'module_name' ];
$array_data [ $series_name . $series_suffix ][ 'agent_alias' ] = $data_module_graph [ 'agent_alias' ];
$array_data [ $series_name . $series_suffix ][ 'unit' ] = $data_module_graph [ 'unit' ];
return $array_data ;
}
2011-04-13 Miguel de Dios <miguel.dedios@artica.es>
* include/functions_graph.php, include/functions_reporting.php,
operation/incidents/incident_statistics.php,
operation/agentes/custom_fields.php, operation/agentes/agent_fields.php,
operation/servers/view_server_detail.php,
operation/integria_incidents/incident_statistics.php,
operation/events/event_statistics.php, operation/events/events_list.php,
operation/events/events.php, operation/reporting/reporting_xml.php,
godmode/admin_access_logs.php, godmode/db/db_main.php,
godmode/db/db_info.php, godmode/db/db_purge.php,
godmode/reporting/graph_builder.main.php,
godmode/reporting/visual_console_builder.editor.js,
godmode/reporting/graph_builder.php,
godmode/reporting/graph_builder.graph_editor.php,
godmode/reporting/graph_builder.preview.php: changed for to use new engine.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4216 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-04-13 19:31:06 +02:00
/**
* Print a pie graph with events data of group
2019-01-30 16:18:44 +01:00
*
2011-04-13 Miguel de Dios <miguel.dedios@artica.es>
* include/functions_graph.php, include/functions_reporting.php,
operation/incidents/incident_statistics.php,
operation/agentes/custom_fields.php, operation/agentes/agent_fields.php,
operation/servers/view_server_detail.php,
operation/integria_incidents/incident_statistics.php,
operation/events/event_statistics.php, operation/events/events_list.php,
operation/events/events.php, operation/reporting/reporting_xml.php,
godmode/admin_access_logs.php, godmode/db/db_main.php,
godmode/db/db_info.php, godmode/db/db_purge.php,
godmode/reporting/graph_builder.main.php,
godmode/reporting/visual_console_builder.editor.js,
godmode/reporting/graph_builder.php,
godmode/reporting/graph_builder.graph_editor.php,
godmode/reporting/graph_builder.preview.php: changed for to use new engine.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4216 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-04-13 19:31:06 +02:00
* @ param integer width pie graph width
* @ param integer height pie graph height
* @ param string url
*/
2019-01-30 16:18:44 +01:00
function grafico_eventos_grupo ( $width = 300 , $height = 200 , $url = '' , $noWaterMark = true , $time_limit = false )
{
global $config ;
global $graphic_type ;
2022-06-08 17:01:15 +02:00
// It was urlencoded, so we urldecode it.
2019-01-30 16:18:44 +01:00
$url = html_entity_decode ( rawurldecode ( $url ), ENT_QUOTES );
$data = [];
2022-12-22 23:03:52 +01:00
$labels = [];
2019-01-30 16:18:44 +01:00
$loop = 0 ;
define ( 'NUM_PIECES_PIE' , 6 );
2022-06-08 17:01:15 +02:00
// Hotfix for the id_agente_modulo.
2019-01-30 16:18:44 +01:00
$url = str_replace (
'SELECT id_agente_modulo' ,
'SELECT_id_agente_modulo' ,
$url
);
$badstrings = [
';' ,
'SELECT ' ,
'DELETE ' ,
'UPDATE ' ,
'INSERT ' ,
'EXEC' ,
];
2022-06-08 17:01:15 +02:00
// remove bad strings from the query so queries like ; DELETE FROM don't pass.
2019-01-30 16:18:44 +01:00
$url = str_ireplace ( $badstrings , '' , $url );
2022-06-08 17:01:15 +02:00
// Hotfix for the id_agente_modulo.
2019-01-30 16:18:44 +01:00
$url = str_replace (
'SELECT_id_agente_modulo' ,
'SELECT id_agente_modulo' ,
$url
);
2022-06-08 17:01:15 +02:00
// Add tags condition to filter.
$tags_condition = tags_get_acl_tags (
$config [ 'id_user' ],
0 ,
'ER' ,
'event_condition' ,
'AND'
);
2019-01-30 16:18:44 +01:00
if ( $time_limit && $config [ 'event_view_hr' ]) {
$tags_condition .= ' AND utimestamp > (UNIX_TIMESTAMP(NOW()) - ' . ( $config [ 'event_view_hr' ] * SECONDS_1HOUR ) . ')' ;
}
// This will give the distinct id_agente, give the id_grupo that goes
// with it and then the number of times it occured. GROUP BY statement
2022-06-08 17:01:15 +02:00
// is required if both DISTINCT() and COUNT() are in the statement.
2019-01-30 16:18:44 +01:00
$sql = sprintf (
' SELECT DISTINCT ( id_agente ) AS id_agente ,
2022-06-08 17:01:15 +02:00
COUNT ( id_agente ) AS count
FROM tevento te LEFT JOIN tagent_secondary_group tasg
2019-01-30 16:18:44 +01:00
ON te . id_grupo = tasg . id_group
WHERE 1 = 1 % s % s
2022-06-08 17:01:15 +02:00
GROUP BY id_agente
2019-01-30 16:18:44 +01:00
ORDER BY count DESC LIMIT 8 ' ,
$url ,
$tags_condition
);
$result = db_get_all_rows_sql ( $sql , false , false );
if ( $result === false ) {
$result = [];
}
$system_events = 0 ;
$other_events = 0 ;
foreach ( $result as $row ) {
$row [ 'id_grupo' ] = agents_get_agent_group ( $row [ 'id_agente' ]);
if ( ! check_acl ( $config [ 'id_user' ], $row [ 'id_grupo' ], 'ER' ) == 1 ) {
continue ;
}
if ( $loop >= NUM_PIECES_PIE ) {
$other_events += $row [ 'count' ];
} else {
if ( $row [ 'id_agente' ] == 0 ) {
$system_events += $row [ 'count' ];
} else {
$alias = agents_get_alias ( $row [ 'id_agente' ]);
$name = mb_substr ( $alias , 0 , 25 ) . ' #' . $row [ 'id_agente' ] . ' (' . $row [ 'count' ] . ')' ;
2022-12-22 23:03:52 +01:00
$labels [] = io_safe_output ( $name );
$data [] = $row [ 'count' ];
2019-01-30 16:18:44 +01:00
}
}
$loop ++ ;
}
if ( $system_events > 0 ) {
$name = __ ( 'SYSTEM' ) . ' (' . $system_events . ')' ;
2022-12-22 23:03:52 +01:00
$labels [] = io_safe_output ( $name );
$data [] = $system_events ;
2019-01-30 16:18:44 +01:00
}
2022-06-08 17:01:15 +02:00
// Sort the data.
2019-01-30 16:18:44 +01:00
arsort ( $data );
if ( $noWaterMark ) {
$water_mark = [
'file' => $config [ 'homedir' ] . '/images/logo_vertical_water.png' ,
'url' => ui_get_full_url ( 'images/logo_vertical_water.png' , false , false , false ),
];
} else {
$water_mark = [];
}
2022-12-13 09:10:13 +01:00
$options = [
2022-12-16 10:38:37 +01:00
'width' => $width ,
'height' => $height ,
'waterMark' => $water_mark ,
'legend' => [
2022-12-13 09:10:13 +01:00
'display' => true ,
'position' => 'right' ,
'align' => 'center' ,
],
2022-12-22 23:03:52 +01:00
'labels' => $labels ,
2022-12-13 09:10:13 +01:00
];
2019-01-30 16:18:44 +01:00
return pie_graph (
$data ,
2022-12-13 09:10:13 +01:00
$options
2019-01-30 16:18:44 +01:00
);
2011-04-13 Miguel de Dios <miguel.dedios@artica.es>
* include/functions_graph.php, include/functions_reporting.php,
operation/incidents/incident_statistics.php,
operation/agentes/custom_fields.php, operation/agentes/agent_fields.php,
operation/servers/view_server_detail.php,
operation/integria_incidents/incident_statistics.php,
operation/events/event_statistics.php, operation/events/events_list.php,
operation/events/events.php, operation/reporting/reporting_xml.php,
godmode/admin_access_logs.php, godmode/db/db_main.php,
godmode/db/db_info.php, godmode/db/db_purge.php,
godmode/reporting/graph_builder.main.php,
godmode/reporting/visual_console_builder.editor.js,
godmode/reporting/graph_builder.php,
godmode/reporting/graph_builder.graph_editor.php,
godmode/reporting/graph_builder.preview.php: changed for to use new engine.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4216 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-04-13 19:31:06 +02:00
}
2019-01-30 16:18:44 +01:00
2011-04-13 Miguel de Dios <miguel.dedios@artica.es>
* include/functions_graph.php, include/functions_reporting.php,
operation/incidents/incident_statistics.php,
operation/agentes/custom_fields.php, operation/agentes/agent_fields.php,
operation/servers/view_server_detail.php,
operation/integria_incidents/incident_statistics.php,
operation/events/event_statistics.php, operation/events/events_list.php,
operation/events/events.php, operation/reporting/reporting_xml.php,
godmode/admin_access_logs.php, godmode/db/db_main.php,
godmode/db/db_info.php, godmode/db/db_purge.php,
godmode/reporting/graph_builder.main.php,
godmode/reporting/visual_console_builder.editor.js,
godmode/reporting/graph_builder.php,
godmode/reporting/graph_builder.graph_editor.php,
godmode/reporting/graph_builder.preview.php: changed for to use new engine.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4216 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-04-13 19:31:06 +02:00
/**
* Print a pie graph with events data in 320 x200 size
2019-01-30 16:18:44 +01:00
*
2011-04-13 Miguel de Dios <miguel.dedios@artica.es>
* include/functions_graph.php, include/functions_reporting.php,
operation/incidents/incident_statistics.php,
operation/agentes/custom_fields.php, operation/agentes/agent_fields.php,
operation/servers/view_server_detail.php,
operation/integria_incidents/incident_statistics.php,
operation/events/event_statistics.php, operation/events/events_list.php,
operation/events/events.php, operation/reporting/reporting_xml.php,
godmode/admin_access_logs.php, godmode/db/db_main.php,
godmode/db/db_info.php, godmode/db/db_purge.php,
godmode/reporting/graph_builder.main.php,
godmode/reporting/visual_console_builder.editor.js,
godmode/reporting/graph_builder.php,
godmode/reporting/graph_builder.graph_editor.php,
godmode/reporting/graph_builder.preview.php: changed for to use new engine.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4216 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-04-13 19:31:06 +02:00
* @ param string filter Filter for query in DB
*/
2019-01-30 16:18:44 +01:00
function grafico_eventos_total ( $filter = '' , $width = 320 , $height = 200 , $noWaterMark = true , $time_limit = false )
{
global $config ;
global $graphic_type ;
$filter = str_replace ( '\\' , '' , $filter );
2022-12-13 09:10:13 +01:00
// Add tags condition to filter.
2019-01-30 16:18:44 +01:00
$tags_condition = tags_get_acl_tags ( $config [ 'id_user' ], 0 , 'ER' , 'event_condition' , 'AND' );
$filter .= $tags_condition ;
if ( $time_limit && $config [ 'event_view_hr' ]) {
$filter .= ' AND utimestamp > (UNIX_TIMESTAMP(NOW()) - ' . ( $config [ 'event_view_hr' ] * SECONDS_1HOUR ) . ')' ;
}
$data = [];
2022-12-22 23:03:52 +01:00
$labels = [];
2019-01-30 16:18:44 +01:00
$where = 'WHERE 1=1' ;
if ( ! users_is_admin ()) {
$where = 'WHERE event_type NOT IN (\'recon_host_detected\', \'system\',\'error\', \'new_agent\', \'configuration_change\')' ;
}
$sql = sprintf (
' SELECT criticity , COUNT ( id_evento ) events
FROM tevento
LEFT JOIN tagent_secondary_group tasg
ON tevento . id_agente = tasg . id_agent
% s % s
GROUP BY criticity ORDER BY events DESC ' ,
$where ,
$filter
);
$criticities = db_get_all_rows_sql ( $sql , false , false );
2022-12-16 10:38:37 +01:00
if ( empty ( $criticities ) === true ) {
2019-01-30 16:18:44 +01:00
$criticities = [];
$colors = [];
}
foreach ( $criticities as $cr ) {
switch ( $cr [ 'criticity' ]) {
case EVENT_CRIT_MAINTENANCE :
2022-12-22 23:03:52 +01:00
$labels [] = __ ( 'Maintenance' ) . ' (' . $cr [ 'events' ] . ')' ;
$data [] = $cr [ 'events' ];
2019-01-30 16:18:44 +01:00
$colors [ __ ( 'Maintenance' )] = COL_MAINTENANCE ;
break ;
case EVENT_CRIT_INFORMATIONAL :
2022-12-22 23:03:52 +01:00
$labels [] = __ ( 'Informational' ) . ' (' . $cr [ 'events' ] . ')' ;
$data [] = $cr [ 'events' ];
2019-01-30 16:18:44 +01:00
$colors [ __ ( 'Informational' )] = COL_INFORMATIONAL ;
break ;
case EVENT_CRIT_NORMAL :
2022-12-22 23:03:52 +01:00
$labels [] = __ ( 'Normal' ) . ' (' . $cr [ 'events' ] . ')' ;
$data [] = $cr [ 'events' ];
2019-01-30 16:18:44 +01:00
$colors [ __ ( 'Normal' )] = COL_NORMAL ;
break ;
case EVENT_CRIT_MINOR :
2022-12-22 23:03:52 +01:00
$labels [] = __ ( 'Minor' ) . ' (' . $cr [ 'events' ] . ')' ;
$data [] = $cr [ 'events' ];
2019-01-30 16:18:44 +01:00
$colors [ __ ( 'Minor' )] = COL_MINOR ;
break ;
case EVENT_CRIT_WARNING :
2022-12-22 23:03:52 +01:00
$labels [] = __ ( 'Warning' ) . ' (' . $cr [ 'events' ] . ')' ;
$data [] = $cr [ 'events' ];
2019-01-30 16:18:44 +01:00
$colors [ __ ( 'Warning' )] = COL_WARNING ;
break ;
case EVENT_CRIT_MAJOR :
2022-12-22 23:03:52 +01:00
$labels [] = __ ( 'Major' ) . ' (' . $cr [ 'events' ] . ')' ;
$data [] = $cr [ 'events' ];
2019-01-30 16:18:44 +01:00
$colors [ __ ( 'Major' )] = COL_MAJOR ;
break ;
case EVENT_CRIT_CRITICAL :
2022-12-22 23:03:52 +01:00
$labels [] = __ ( 'Critical' ) . ' (' . $cr [ 'events' ] . ')' ;
$data [] = $cr [ 'events' ];
2019-01-30 16:18:44 +01:00
$colors [ __ ( 'Critical' )] = COL_CRITICAL ;
break ;
2022-12-16 10:38:37 +01:00
default :
// Not possible.
break ;
2019-01-30 16:18:44 +01:00
}
}
2022-12-16 10:38:37 +01:00
$water_mark = [];
if ( $noWaterMark === true ) {
2019-01-30 16:18:44 +01:00
$water_mark = [
'file' => $config [ 'homedir' ] . '/images/logo_vertical_water.png' ,
'url' => ui_get_full_url ( '/images/logo_vertical_water.png' , false , false , false ),
];
}
2022-12-13 09:10:13 +01:00
$options = [
2022-12-16 10:38:37 +01:00
'width' => $width ,
'height' => $height ,
'waterMark' => $water_mark ,
'colors' => array_values ( $colors ),
'legend' => [
2022-12-13 09:10:13 +01:00
'display' => true ,
'position' => 'right' ,
'align' => 'center' ,
],
2022-12-22 23:03:52 +01:00
'labels' => $labels ,
2019-01-30 16:18:44 +01:00
];
return pie_graph (
$data ,
2022-12-13 09:10:13 +01:00
$options
2019-01-30 16:18:44 +01:00
);
2011-04-13 Miguel de Dios <miguel.dedios@artica.es>
* include/functions_graph.php, include/functions_reporting.php,
operation/incidents/incident_statistics.php,
operation/agentes/custom_fields.php, operation/agentes/agent_fields.php,
operation/servers/view_server_detail.php,
operation/integria_incidents/incident_statistics.php,
operation/events/event_statistics.php, operation/events/events_list.php,
operation/events/events.php, operation/reporting/reporting_xml.php,
godmode/admin_access_logs.php, godmode/db/db_main.php,
godmode/db/db_info.php, godmode/db/db_purge.php,
godmode/reporting/graph_builder.main.php,
godmode/reporting/visual_console_builder.editor.js,
godmode/reporting/graph_builder.php,
godmode/reporting/graph_builder.graph_editor.php,
godmode/reporting/graph_builder.preview.php: changed for to use new engine.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4216 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-04-13 19:31:06 +02:00
}
2011-04-14 18:52:50 +02:00
2019-01-30 16:18:44 +01:00
2011-04-14 18:52:50 +02:00
/**
2020-10-09 12:05:57 +02:00
* Undocumented function
2019-01-30 16:18:44 +01:00
*
2020-10-09 12:05:57 +02:00
* @ param array $content ID of report content
* used to get SQL code to get information for graph .
* @ param integer $width Graph width .
* @ param integer $height Graph height .
* @ param string $type Graph type 1 vbar , 2 hbar , 3 pie .
* @ param boolean $only_image Only image .
* @ param string $homeurl Url .
* @ param integer $ttl Ttl .
* @ param integer $max_num_elements Max elements .
*
* @ return string Graph .
2011-04-14 18:52:50 +02:00
*/
2019-01-30 16:18:44 +01:00
function graph_custom_sql_graph (
2020-10-08 11:54:10 +02:00
$content ,
2019-01-30 16:18:44 +01:00
$width ,
$height ,
$type = 'sql_graph_vbar' ,
$only_image = false ,
$homeurl = '' ,
$ttl = 1 ,
$max_num_elements = 8
) {
global $config ;
$SQL_GRAPH_MAX_LABEL_SIZE = 20 ;
2020-10-13 09:32:28 +02:00
if ( is_metaconsole () === true
&& empty ( $content [ 'server_name' ]) === false
) {
$connection = metaconsole_get_connection ( $content [ 'server_name' ]);
2019-10-22 15:41:13 +02:00
metaconsole_connect ( $connection );
2019-10-09 13:15:07 +02:00
}
2020-10-13 09:32:28 +02:00
$report_content = db_get_row (
'treport_content' ,
'id_rc' ,
$content [ 'id_rc' ]
);
2019-10-22 15:41:13 +02:00
if ( $report_content == false || $report_content == '' ) {
2020-10-09 12:05:57 +02:00
$report_content = db_get_row (
'treport_content_template' ,
'id_rc' ,
$content [ 'id_rc' ]
);
2019-10-22 15:41:13 +02:00
}
if ( $report_content == false || $report_content == '' ) {
2020-10-13 09:32:28 +02:00
if ( is_metaconsole () === true
&& empty ( $content [ 'server_name' ]) === false
) {
2020-10-08 11:54:10 +02:00
enterprise_hook ( 'metaconsole_restore_db' );
}
2020-10-09 12:05:57 +02:00
$report_content = db_get_row (
'treport_content' ,
'id_rc' ,
$content [ 'id_rc' ]
);
2019-10-22 15:41:13 +02:00
if ( $report_content == false || $report_content == '' ) {
2020-10-09 12:05:57 +02:00
$report_content = db_get_row (
'treport_content_template' ,
'id_rc' ,
$content [ 'id_rc' ]
);
2019-10-22 15:41:13 +02:00
}
2020-10-13 09:32:28 +02:00
if ( is_metaconsole () === true
&& empty ( $content [ 'server_name' ]) === false
) {
$connection = metaconsole_get_connection ( $content [ 'server_name' ]);
2019-10-22 15:41:13 +02:00
metaconsole_connect ( $connection );
}
}
2021-04-22 09:50:22 +02:00
$historical_db = $content [ 'historical_db' ];
if ( $content [ 'external_source' ] != '' ) {
$sql = io_safe_output ( $content [ 'external_source' ]);
2019-01-30 16:18:44 +01:00
} else {
2020-10-09 12:05:57 +02:00
$sql = db_get_row (
'treport_custom_sql' ,
'id' ,
$report_content [ 'treport_custom_sql_id' ]
);
2019-01-30 16:18:44 +01:00
$sql = io_safe_output ( $sql [ 'sql' ]);
}
$data_result = db_get_all_rows_sql ( $sql , $historical_db );
2020-10-13 09:32:28 +02:00
if ( is_metaconsole () === true && empty ( $content [ 'server_name' ]) === false ) {
2019-01-30 16:18:44 +01:00
enterprise_hook ( 'metaconsole_restore_db' );
}
if ( $data_result === false ) {
$data_result = [];
}
2023-01-19 17:50:27 +01:00
$data_bar = [];
$labels_pie = [];
$data_pie = [];
2019-01-30 16:18:44 +01:00
$count = 0 ;
2022-12-22 23:03:52 +01:00
$other = 0 ;
2019-01-30 16:18:44 +01:00
foreach ( $data_result as $data_item ) {
$count ++ ;
$value = 0 ;
2020-10-09 12:05:57 +02:00
if ( empty ( $data_item [ 'value' ]) === false ) {
2019-01-30 16:18:44 +01:00
$value = $data_item [ 'value' ];
}
if ( $count <= $max_num_elements ) {
$label = __ ( 'Data' );
2020-10-09 12:05:57 +02:00
if ( empty ( $data_item [ 'label' ]) === false ) {
2019-01-30 16:18:44 +01:00
$label = io_safe_output ( $data_item [ 'label' ]);
if ( strlen ( $label ) > $SQL_GRAPH_MAX_LABEL_SIZE ) {
$first_label = $label ;
2020-10-09 12:05:57 +02:00
$label = substr (
$first_label ,
0 ,
floor ( $SQL_GRAPH_MAX_LABEL_SIZE / 2 )
);
2019-01-30 16:18:44 +01:00
}
}
2022-12-22 23:03:52 +01:00
$labels_bar [] = $label ;
if ( $type === 'sql_graph_hbar' ) {
$data_bar [] = [
'y' => $label ,
'x' => $value ,
];
} else {
$data_bar [] = [
'x' => $label ,
'y' => $value ,
];
}
2022-12-16 14:28:04 +01:00
if (( int ) $ttl === 2 && $type === 'sql_graph_pie' ) {
2022-12-22 23:03:52 +01:00
$labels_pie [] = $label . '_' . $count . ' (' . $value . ')' ;
2022-12-16 14:28:04 +01:00
} else {
2022-12-22 23:03:52 +01:00
$labels_pie [] = $label . '_' . $count ;
2022-12-16 14:28:04 +01:00
}
2022-12-22 23:03:52 +01:00
$data_pie [] = $value ;
2019-01-30 16:18:44 +01:00
} else {
2022-12-22 23:03:52 +01:00
$other += $value ;
}
}
2022-12-16 10:38:37 +01:00
2022-12-22 23:03:52 +01:00
if ( empty ( $other ) === false ) {
$label = __ ( 'Other' );
$labels_bar [] = $label ;
if ( $type === 'sql_graph_hbar' ) {
$data_bar [] = [
'y' => $label ,
'x' => $other ,
];
} else {
$data_bar [] = [
'x' => $label ,
'y' => $other ,
];
2019-01-30 16:18:44 +01:00
}
2022-12-22 23:03:52 +01:00
if (( int ) $ttl === 2 && $type === 'sql_graph_pie' ) {
$label .= ' (' . $other . ')' ;
}
$labels_pie [] = $label ;
$data_pie [] = $other ;
2019-01-30 16:18:44 +01:00
}
if ( $config [ 'fixed_graph' ] == false ) {
$water_mark = [
'file' => $config [ 'homedir' ] . '/images/logo_vertical_water.png' ,
2020-10-09 12:05:57 +02:00
'url' => ui_get_full_url (
'images/logo_vertical_water.png' ,
false ,
false ,
false
),
2019-01-30 16:18:44 +01:00
];
}
2020-10-13 09:32:28 +02:00
$output = '' ;
2022-12-20 12:23:18 +01:00
$output .= '<div style="height:' . ( $height ) . 'px; width: 99%; margin: 0 auto;">' ;
2022-12-16 10:38:37 +01:00
if (( int ) $ttl === 2 ) {
$output .= '<img src="data:image/png;base64,' ;
}
2019-01-30 16:18:44 +01:00
switch ( $type ) {
case 'sql_graph_vbar' :
2022-12-16 10:38:37 +01:00
case 'sql_graph_hbar' :
2020-10-09 12:05:57 +02:00
default :
2022-12-16 10:38:37 +01:00
$options = [
'height' => $height ,
'waterMark' => $water_mark ,
'ttl' => $ttl ,
'legend' => [ 'display' => false ],
'scales' => [
'x' => [
'grid' => [ 'display' => false ],
],
'y' => [
'grid' => [ 'display' => false ],
],
],
2022-12-22 23:03:52 +01:00
'labels' => $labels_bar ,
2022-12-16 10:38:37 +01:00
];
2020-03-26 12:29:38 +01:00
2022-12-16 10:38:37 +01:00
if ( $type === 'sql_graph_hbar' ) {
$options [ 'axis' ] = 'y' ;
2020-03-26 12:29:38 +01:00
}
2019-01-30 16:18:44 +01:00
2022-12-16 14:28:04 +01:00
if (( int ) $ttl === 2 ) {
$options [ 'dataLabel' ] = [ 'display' => 'auto' ];
}
2022-12-16 10:38:37 +01:00
$output .= vbar_graph (
2022-12-22 23:03:52 +01:00
$data_bar ,
2022-12-16 10:38:37 +01:00
$options
2020-10-13 09:32:28 +02:00
);
break ;
2019-01-30 16:18:44 +01:00
case 'sql_graph_pie' :
2022-12-13 09:10:13 +01:00
$options = [
'height' => $height ,
'waterMark' => $water_mark ,
'ttl' => $ttl ,
2022-12-16 10:38:37 +01:00
'legend' => [
'display' => true ,
'position' => 'right' ,
'align' => 'center' ,
],
2022-12-22 23:03:52 +01:00
'labels' => $labels_pie ,
2022-12-13 09:10:13 +01:00
];
2022-12-16 14:28:04 +01:00
if (( int ) $ttl === 2 ) {
$options [ 'dataLabel' ] = [ 'display' => 'auto' ];
$options [ 'layout' ] = [
'padding' => [
2022-12-20 12:23:18 +01:00
'top' => 20 ,
'bottom' => 20 ,
2022-12-16 14:28:04 +01:00
],
];
}
2020-10-09 12:05:57 +02:00
// Pie.
2020-10-13 09:32:28 +02:00
$output .= pie_graph (
2022-12-22 23:03:52 +01:00
$data_pie ,
2022-12-13 09:10:13 +01:00
$options
2020-10-13 09:32:28 +02:00
);
break ;
2019-01-30 16:18:44 +01:00
}
2020-10-13 09:32:28 +02:00
2022-12-16 10:38:37 +01:00
if (( int ) $ttl === 2 ) {
$output .= '" />' ;
}
2022-12-20 12:23:18 +01:00
$output .= '</div>' ;
2020-10-13 09:32:28 +02:00
return $output ;
2011-04-14 18:52:50 +02:00
}
2011-04-18 16:05:54 +02:00
2019-01-30 16:18:44 +01:00
2012-01-26 13:51:43 +01:00
/**
* Print a static graph with event data of agents
2019-01-30 16:18:44 +01:00
*
2012-01-26 13:51:43 +01:00
* @ param integer id_agent Agent ID
* @ param integer width pie graph width
* @ param integer height pie graph height
* @ param integer period time period
2013-02-20 18:15:38 +01:00
* @ param string homeurl
* @ param bool return or echo the result
2012-01-26 13:51:43 +01:00
*/
2020-03-26 12:29:38 +01:00
function graph_graphic_agentevents (
$id_agent ,
$width ,
$height ,
$period = 0 ,
2021-03-09 17:36:37 +01:00
$homeurl = '' ,
2020-03-26 12:29:38 +01:00
$return = false ,
$from_agent_view = false ,
$widgets = false ,
$not_interactive = 0 ,
$server_id = ''
) {
2019-01-30 16:18:44 +01:00
global $config ;
global $graphic_type ;
$data = [];
// TODO interval
$interval = 24 ;
$date = get_system_time ();
$datelimit = ( $date - $period );
$periodtime = floor ( $period / $interval );
$time = [];
$data = [];
$legend = [];
$full_legend = [];
$full_legend_date = [];
$cont = 0 ;
for ( $i = 0 ; $i < $interval ; $i ++ ) {
$bottom = ( $datelimit + ( $periodtime * $i ));
if ( ! $graphic_type ) {
$name = date ( 'H:i' , $bottom );
} else {
$name = $bottom ;
}
// Show less values in legend
if ( $cont == 0 or ( $cont % 2 )) {
$legend [ $cont ] = $name ;
}
if ( $from_agent_view ) {
$full_date = date ( 'Y/m/d' , $bottom );
$full_legend_date [ $cont ] = $full_date ;
}
$full_legend [ $cont ] = $name ;
$top = ( $datelimit + ( $periodtime * ( $i + 1 )));
2019-12-10 11:28:56 +01:00
$events = db_get_all_rows_filter (
2019-01-30 16:18:44 +01:00
'tevento' ,
[ 'id_agente' => $id_agent ,
'utimestamp > ' . $bottom ,
2019-12-10 11:28:56 +01:00
'utimestamp < ' . $top ,
2019-01-30 16:18:44 +01:00
],
'criticity, utimestamp'
);
2019-12-10 11:28:56 +01:00
if ( ! empty ( $events )) {
2019-01-30 16:18:44 +01:00
$data [ $cont ][ 'utimestamp' ] = $periodtime ;
2019-12-10 11:28:56 +01:00
$event_criticity = array_column ( $events , 'criticity' );
if ( array_search ( EVENT_CRIT_CRITICAL , $event_criticity ) !== false ) {
$data [ $cont ][ 'data' ] = EVENT_CRIT_CRITICAL ;
} else if ( array_search ( EVENT_CRIT_WARNING , $event_criticity ) !== false ) {
$data [ $cont ][ 'data' ] = EVENT_CRIT_WARNING ;
} else {
$data [ $cont ][ 'data' ] = EVENT_CRIT_NORMAL ;
2019-01-30 16:18:44 +01:00
}
} else {
$data [ $cont ][ 'utimestamp' ] = $periodtime ;
2019-12-10 11:28:56 +01:00
$data [ $cont ][ 'data' ] = EVENT_CRIT_NORMAL ;
2019-01-30 16:18:44 +01:00
}
$cont ++ ;
}
$colors = [
2019-12-10 11:28:56 +01:00
1 => COL_UNKNOWN ,
EVENT_CRIT_NORMAL => COL_NORMAL ,
EVENT_CRIT_WARNING => COL_WARNING ,
EVENT_CRIT_CRITICAL => COL_CRITICAL ,
2019-01-30 16:18:44 +01:00
];
2022-05-25 09:06:22 +02:00
// Draw slicebar graph.
2020-03-26 12:29:38 +01:00
$out = flot_slicesbar_graph (
$data ,
$period ,
$width ,
$height ,
$full_legend ,
$colors ,
$config [ 'fontpath' ],
$config [ 'round_corner' ],
$homeurl ,
'' ,
'' ,
false ,
$id_agent ,
$full_legend_date ,
$not_interactive ,
1 ,
$widgets ,
2022-05-25 09:06:22 +02:00
true ,
2020-03-26 12:29:38 +01:00
$server_id
);
2019-01-30 16:18:44 +01:00
if ( $return ) {
return $out ;
} else {
echo $out ;
}
2017-07-13 16:57:53 +02:00
}
2019-01-30 16:18:44 +01:00
2017-07-13 16:57:53 +02:00
/**
* Print a static graph with event data of agents
2019-01-30 16:18:44 +01:00
*
2017-07-13 16:57:53 +02:00
* @ param integer id_agent Agent ID
* @ param integer width pie graph width
* @ param integer height pie graph height
* @ param integer period time period
* @ param string homeurl
* @ param bool return or echo the result
*/
2020-03-26 12:29:38 +01:00
function graph_graphic_moduleevents (
$id_agent ,
$id_module ,
$width ,
$height ,
$period = 0 ,
$homeurl = '' ,
$return = false ,
$ttl = 1 ,
$widthForTicks = false
) {
2019-01-30 16:18:44 +01:00
global $config ;
global $graphic_type ;
$data = [];
$interval = 24 ;
$date = get_system_time ();
$datelimit = ( $date - $period );
$periodtime = floor ( $period / $interval );
$data = [];
$legend = [];
$full_legend = [];
$cont = 0 ;
for ( $i = 0 ; $i < $interval ; $i ++ ) {
$bottom = ( $datelimit + ( $periodtime * $i ));
if ( ! $graphic_type ) {
$name = date ( 'H\h' , $bottom );
} else {
$name = $bottom ;
}
// Show less values in legend
if ( $cont == 0 or ( $cont % 2 )) {
$legend [ $cont ] = $name ;
}
$full_legend [ $cont ] = $name ;
$top = ( $datelimit + ( $periodtime * ( $i + 1 )));
$event_filter = [ 'id_agente' => $id_agent ,
'utimestamp > ' . $bottom ,
'utimestamp < ' . $top
];
if (( int ) $id_module !== 0 ) {
$event_filter [ 'id_agentmodule' ] = $id_module ;
}
$event = db_get_row_filter ( 'tevento' , $event_filter , 'criticity, utimestamp' );
if ( ! empty ( $event [ 'utimestamp' ])) {
$data [ $cont ][ 'utimestamp' ] = $periodtime ;
switch ( $event [ 'criticity' ]) {
case EVENT_CRIT_WARNING :
$data [ $cont ][ 'data' ] = 2 ;
break ;
case EVENT_CRIT_CRITICAL :
$data [ $cont ][ 'data' ] = 3 ;
break ;
default :
$data [ $cont ][ 'data' ] = 1 ;
break ;
}
} else {
$data [ $cont ][ 'utimestamp' ] = $periodtime ;
$data [ $cont ][ 'data' ] = 1 ;
}
$cont ++ ;
}
$colors = [
1 => COL_NORMAL ,
2 => COL_WARNING ,
3 => COL_CRITICAL ,
4 => COL_UNKNOWN ,
];
$out = flot_slicesbar_graph (
$data ,
$period ,
2020-01-15 14:28:43 +01:00
$width ,
2019-01-30 16:18:44 +01:00
$height ,
$full_legend ,
$colors ,
$config [ 'fontpath' ],
$config [ 'round_corner' ],
$homeurl ,
'' ,
'' ,
false ,
$id_agent ,
[],
true ,
2020-01-15 14:28:43 +01:00
$ttl ,
2020-03-26 12:29:38 +01:00
$widthForTicks
2019-01-30 16:18:44 +01:00
);
if ( $return ) {
return $out ;
} else {
echo $out ;
}
2012-01-26 13:51:43 +01:00
}
2019-01-30 16:18:44 +01:00
2019-05-09 16:26:38 +02:00
/**
* Function for retun image no data .
*
* @ param integer $width Width .
* @ param integer $height Height .
*
* @ return string Image .
*/
2019-01-30 16:18:44 +01:00
function fs_error_image ( $width = 300 , $height = 110 )
{
2022-12-13 09:10:13 +01:00
return graph_nodata_image ([ 'height' => $height ]);
2011-04-18 16:05:54 +02:00
}
2011-04-19 14:11:00 +02:00
2019-01-30 16:18:44 +01:00
2019-05-09 16:26:38 +02:00
/**
* Function for uncompressed data module for cherts .
*
* @ param integer $agent_module_id Id modulo .
* @ param array $date_array Date start , finish , period .
* @ param integer $show_unknown Show Unknown .
* @ param integer $show_percentil Show Percentil .
* @ param integer $series_suffix Series .
* @ param boolean $compare Type compare .
* @ param boolean $data_slice Size slice .
* @ param string $type_mode_graph Type .
*
* @ return array Return array data uncompresess .
*/
2019-01-30 16:18:44 +01:00
function fullscale_data (
$agent_module_id ,
$date_array ,
$show_unknown = 0 ,
$show_percentil = 0 ,
2019-05-09 16:26:38 +02:00
$series_suffix = 0 ,
2019-01-30 16:18:44 +01:00
$compare = false ,
$data_slice = false ,
2019-05-09 16:26:38 +02:00
$type_mode_graph = ''
2019-01-30 16:18:44 +01:00
) {
global $config ;
$data_uncompress = db_uncompress_module_data (
$agent_module_id ,
$date_array [ 'start_date' ],
$date_array [ 'final_date' ],
$data_slice
);
2020-10-01 15:29:54 +02:00
if ( $data_uncompress === false ) {
return [];
}
2019-01-30 16:18:44 +01:00
$data = [];
$previous_data = 0 ;
2019-05-09 16:26:38 +02:00
// Normal.
2019-01-30 16:18:44 +01:00
$min_value_total = PHP_INT_MAX ;
2019-05-09 16:26:38 +02:00
$max_value_total = ( - PHP_INT_MAX );
// Max.
2019-01-30 16:18:44 +01:00
$max_value_min = PHP_INT_MAX ;
2019-05-09 16:26:38 +02:00
$max_value_max = ( - PHP_INT_MAX );
// Min.
2019-01-30 16:18:44 +01:00
$min_value_min = PHP_INT_MAX ;
2019-05-09 16:26:38 +02:00
$min_value_max = ( - PHP_INT_MAX );
// Avg.
2019-01-30 16:18:44 +01:00
$avg_value_min = PHP_INT_MAX ;
2019-05-09 16:26:38 +02:00
$avg_value_max = ( - PHP_INT_MAX );
2019-01-30 16:18:44 +01:00
$flag_unknown = 0 ;
$array_percentil = [];
2022-01-12 19:43:33 +01:00
// Missing initializations.
$params = [ 'baseline' => false ];
$sum_data_total = 0 ;
$count_data_total = 0 ;
$sum_data_min = 0 ;
$sum_data_max = 0 ;
$sum_data_avg = 0 ;
2019-01-30 16:18:44 +01:00
if ( $data_slice ) {
2019-05-09 16:26:38 +02:00
if ( isset ( $data_uncompress ) === true
&& is_array ( $data_uncompress ) === true
) {
foreach ( $data_uncompress as $k ) {
$sum_data = 0 ;
$count_data = 0 ;
$min_value = PHP_INT_MAX ;
$max_value = ( - PHP_INT_MAX );
$flag_virtual_data = 0 ;
foreach ( $k [ 'data' ] as $v ) {
if ( isset ( $v [ 'type' ]) && $v [ 'type' ] == 1 ) {
// Skip unnecesary virtual data.
continue ;
$flag_virtual_data = 1 ;
}
2019-01-30 16:18:44 +01:00
2019-05-09 16:26:38 +02:00
if ( $compare ) {
// Data * 1000 need js utimestam mlsecond.
$real_date = (( $v [ 'utimestamp' ] + $date_array [ 'period' ]) * 1000 );
} else {
$real_date = ( $v [ 'utimestamp' ] * 1000 );
}
2019-01-30 16:18:44 +01:00
2019-05-09 16:26:38 +02:00
if ( $v [ 'datos' ] === null ) {
// Unknown.
if ( $show_unknown ) {
if ( ! $compare ) {
if ( $flag_unknown ) {
$data [ 'unknown' . $series_suffix ][ 'data' ][] = [
$real_date ,
1 ,
];
} else {
$data [ 'unknown' . $series_suffix ][ 'data' ][] = [
( $real_date - 1 ),
0 ,
];
$data [ 'unknown' . $series_suffix ][ 'data' ][] = [
$real_date ,
1 ,
];
$flag_unknown = 1 ;
}
2019-01-30 16:18:44 +01:00
}
}
2019-05-09 16:26:38 +02:00
$v [ 'datos' ] = $previous_data ;
} else {
// Normal.
$previous_data = $v [ 'datos' ];
if ( $show_unknown ) {
if ( ! $compare ) {
if ( $flag_unknown ) {
$data [ 'unknown' . $series_suffix ][ 'data' ][] = [
$real_date ,
0 ,
];
$flag_unknown = 0 ;
}
2019-01-30 16:18:44 +01:00
}
}
}
2020-10-02 14:16:55 +02:00
// Max.
if ( $v [ 'datos' ] === false || $v [ 'datos' ] >= $max_value ) {
if ( $v [ 'datos' ] === false ) {
$max_value = 0 ;
} else {
2019-05-09 16:26:38 +02:00
$max_value = $v [ 'datos' ];
}
2020-10-02 14:16:55 +02:00
}
2019-05-09 16:26:38 +02:00
2020-10-02 14:16:55 +02:00
// Min.
if ( $v [ 'datos' ] <= $min_value ) {
$min_value = $v [ 'datos' ];
2019-01-30 16:18:44 +01:00
}
2020-10-02 14:16:55 +02:00
// Avg sum.
$sum_data += $v [ 'datos' ];
2019-05-09 16:26:38 +02:00
// Avg count.
$count_data ++ ;
if ( $show_percentil && ! $compare ) {
$array_percentil [] = $v [ 'datos' ];
2019-01-30 16:18:44 +01:00
}
2019-05-09 16:26:38 +02:00
$last_data = $v [ 'datos' ];
2019-01-30 16:18:44 +01:00
}
2019-05-09 16:26:38 +02:00
if ( ! $flag_virtual_data ) {
if ( $compare ) {
// Data * 1000 need js utimestam mlsecond.
$real_date = (( $k [ 'data' ][ 0 ][ 'utimestamp' ] + $date_array [ 'period' ]) * 1000 );
} else {
$real_date = ( $k [ 'data' ][ 0 ][ 'utimestamp' ] * 1000 );
}
2019-01-30 16:18:44 +01:00
2020-10-02 14:16:55 +02:00
if ( $type_mode_graph <= 1 ) {
$data [ 'sum' . $series_suffix ][ 'data' ][] = [
$real_date ,
( $sum_data / $count_data ),
];
}
2019-05-09 16:26:38 +02:00
if ( $type_mode_graph && ! $params [ 'baseline' ]) {
2020-10-02 14:16:55 +02:00
if (( int ) $type_mode_graph === 1 || ( int ) $type_mode_graph === 3 ) {
if ( $min_value != PHP_INT_MAX ) {
$data [ 'min' . $series_suffix ][ 'data' ][] = [
$real_date ,
$min_value ,
];
}
2019-05-09 16:26:38 +02:00
}
2019-01-30 16:18:44 +01:00
2020-10-02 14:16:55 +02:00
if (( int ) $type_mode_graph === 1 || ( int ) $type_mode_graph === 2 ) {
if ( $max_value != ( - PHP_INT_MAX )) {
$data [ 'max' . $series_suffix ][ 'data' ][] = [
$real_date ,
$max_value ,
];
}
2019-05-09 16:26:38 +02:00
}
} else {
if ( $min_value != PHP_INT_MAX ) {
$data [ 'sum' . $series_suffix ][ 'slice_data' ][ $real_date ][ 'min' ] = $min_value ;
}
2019-01-30 16:18:44 +01:00
2019-05-09 16:26:38 +02:00
$data [ 'sum' . $series_suffix ][ 'slice_data' ][ $real_date ][ 'avg' ] = ( $sum_data / $count_data );
2023-10-18 12:49:47 +02:00
$data [ 'sum' . $series_suffix ][ 'slice_data' ][ $real_date ][ 'sum' ] = $sum_data ;
2019-01-30 16:18:44 +01:00
2019-05-09 16:26:38 +02:00
if ( $max_value != ( - PHP_INT_MAX )) {
$data [ 'sum' . $series_suffix ][ 'slice_data' ][ $real_date ][ 'max' ] = $max_value ;
}
2019-01-30 16:18:44 +01:00
}
2019-05-09 16:26:38 +02:00
// Max total.
if ( $max_value >= $max_value_total
&& $max_value != ( - PHP_INT_MAX )
) {
$max_value_total = $max_value ;
2019-01-30 16:18:44 +01:00
}
2019-05-09 16:26:38 +02:00
// Min total.
if ( $min_value <= $min_value_total
&& $min_value != PHP_INT_MAX
) {
$min_value_total = $min_value ;
2019-01-30 16:18:44 +01:00
}
2019-05-09 16:26:38 +02:00
// Avg sum total.
$sum_data_total += ( $sum_data / $count_data );
2019-01-30 16:18:44 +01:00
2019-05-09 16:26:38 +02:00
// Avg count total.
$count_data_total ++ ;
2019-01-30 16:18:44 +01:00
2020-10-05 17:03:30 +02:00
if ( ! $params [ 'baseline' ]) {
2019-05-09 16:26:38 +02:00
// MIN.
// max min.
if ( $min_value >= $min_value_max
&& $min_value != PHP_INT_MAX
) {
$min_value_max = $min_value ;
}
2019-01-30 16:18:44 +01:00
2019-05-09 16:26:38 +02:00
// Min min.
if ( $min_value <= $min_value_min
&& $min_value != PHP_INT_MAX
) {
$min_value_min = $min_value ;
}
2019-01-30 16:18:44 +01:00
2019-05-09 16:26:38 +02:00
// Avg sum min.
if ( $min_value != PHP_INT_MAX ) {
$sum_data_min += $min_value ;
}
2019-01-30 16:18:44 +01:00
2019-05-09 16:26:38 +02:00
// MAX.
// Max max.
if ( $max_value >= $max_value_max
&& $max_value != ( - PHP_INT_MAX )
) {
$max_value_max = $max_value ;
}
2019-01-30 16:18:44 +01:00
2019-05-09 16:26:38 +02:00
// Min max.
if ( $max_value <= $max_value_min
&& $max_value != ( - PHP_INT_MAX )
) {
$max_value_min = $max_value ;
}
2019-01-30 16:18:44 +01:00
2019-05-09 16:26:38 +02:00
// Avg Sum max.
if ( $max_value != ( - PHP_INT_MAX )) {
$sum_data_max += $max_value ;
}
2019-01-30 16:18:44 +01:00
2019-05-09 16:26:38 +02:00
// AVG.
// Max max.
if (( $sum_data / $count_data ) >= $avg_value_max ) {
$avg_value_max = ( $sum_data / $count_data );
}
2019-01-30 16:18:44 +01:00
2019-05-09 16:26:38 +02:00
// Min max.
if (( $sum_data / $count_data ) <= $avg_value_min ) {
$avg_value_min = ( $sum_data / $count_data );
}
2019-01-30 16:18:44 +01:00
2019-05-09 16:26:38 +02:00
// Avg sum max.
$sum_data_avg += ( $sum_data / $count_data );
2019-01-30 16:18:44 +01:00
}
}
}
}
2020-10-02 14:16:55 +02:00
if ( $type_mode_graph <= 1 ) {
$data [ 'sum' . $series_suffix ][ 'min' ] = $min_value_total ;
$data [ 'sum' . $series_suffix ][ 'max' ] = $max_value_total ;
$data [ 'sum' . $series_suffix ][ 'avg' ] = 0 ;
if ( isset ( $count_data_total ) === true ) {
$data [ 'sum' . $series_suffix ][ 'avg' ] = ( $sum_data_total / $count_data_total );
}
2019-05-09 16:26:38 +02:00
}
2019-01-30 16:18:44 +01:00
2020-10-05 17:03:30 +02:00
if ( ! $params [ 'baseline' ]) {
2020-10-02 14:16:55 +02:00
if (( int ) $type_mode_graph === 1 || ( int ) $type_mode_graph === 3 ) {
$data [ 'min' . $series_suffix ][ 'min' ] = $min_value_min ;
$data [ 'min' . $series_suffix ][ 'max' ] = $min_value_max ;
$data [ 'min' . $series_suffix ][ 'avg' ] = ( $sum_data_min / $count_data_total );
}
2019-01-30 16:18:44 +01:00
2020-10-02 14:16:55 +02:00
if (( int ) $type_mode_graph === 1 || ( int ) $type_mode_graph === 2 ) {
$data [ 'max' . $series_suffix ][ 'min' ] = $max_value_min ;
$data [ 'max' . $series_suffix ][ 'max' ] = $max_value_max ;
$data [ 'max' . $series_suffix ][ 'avg' ] = ( $sum_data_max / $count_data_total );
}
2019-01-30 16:18:44 +01:00
2020-10-02 14:16:55 +02:00
if ( $type_mode_graph <= 1 ) {
$data [ 'sum' . $series_suffix ][ 'min' ] = $avg_value_min ;
$data [ 'sum' . $series_suffix ][ 'max' ] = $avg_value_max ;
$data [ 'sum' . $series_suffix ][ 'avg' ] = ( $sum_data_avg / $count_data_total );
}
2019-01-30 16:18:44 +01:00
}
} else {
2022-01-12 19:43:33 +01:00
$sum_data = 0 ;
$count_data = 0 ;
2019-01-30 16:18:44 +01:00
foreach ( $data_uncompress as $k ) {
foreach ( $k [ 'data' ] as $v ) {
if ( isset ( $v [ 'type' ]) && $v [ 'type' ] == 1 ) {
2019-05-09 16:26:38 +02:00
// Skip unnecesary virtual data.
2019-01-30 16:18:44 +01:00
continue ;
}
if ( $compare ) {
2019-05-09 16:26:38 +02:00
// Data * 1000 need js utimestam mlsecond.
2019-01-30 16:18:44 +01:00
$real_date = (( $v [ 'utimestamp' ] + $date_array [ 'period' ]) * 1000 );
} else {
$real_date = ( $v [ 'utimestamp' ] * 1000 );
}
if ( $v [ 'datos' ] === null ) {
2019-05-09 16:26:38 +02:00
// Unknown.
2019-01-30 16:18:44 +01:00
if ( $show_unknown ) {
if ( ! $compare ) {
if ( $flag_unknown ) {
$data [ 'unknown' . $series_suffix ][ 'data' ][] = [
$real_date ,
1 ,
];
} else {
$data [ 'unknown' . $series_suffix ][ 'data' ][] = [
( $real_date - 1 ),
0 ,
];
$data [ 'unknown' . $series_suffix ][ 'data' ][] = [
$real_date ,
1 ,
];
$flag_unknown = 1 ;
}
}
}
$data [ 'sum' . $series_suffix ][ 'data' ][] = [
$real_date ,
$previous_data ,
];
} else {
2019-05-09 16:26:38 +02:00
// Normal.
2019-01-30 16:18:44 +01:00
$previous_data = $v [ 'datos' ];
$data [ 'sum' . $series_suffix ][ 'data' ][] = [
$real_date ,
$v [ 'datos' ],
];
if ( $show_unknown ) {
if ( ! $compare ) {
if ( $flag_unknown ) {
$data [ 'unknown' . $series_suffix ][ 'data' ][] = [
$real_date ,
0 ,
];
$flag_unknown = 0 ;
}
}
}
}
if ( isset ( $v [ 'datos' ]) && $v [ 'datos' ]) {
2019-05-09 16:26:38 +02:00
// Max.
2019-01-30 16:18:44 +01:00
if (( float ) $v [ 'datos' ] >= $max_value_max ) {
$max_value_max = $v [ 'datos' ];
}
2019-05-09 16:26:38 +02:00
// Min.
2019-01-30 16:18:44 +01:00
if (( float ) $v [ 'datos' ] <= $min_value_min ) {
$min_value_min = $v [ 'datos' ];
}
2019-05-09 16:26:38 +02:00
// Avg sum.
2019-01-30 16:18:44 +01:00
$sum_data += $v [ 'datos' ];
}
2019-05-09 16:26:38 +02:00
// Avg count.
2019-01-30 16:18:44 +01:00
$count_data ++ ;
if ( $show_percentil && ! $compare ) {
$array_percentil [] = $v [ 'datos' ];
}
$last_data = $v [ 'datos' ];
}
}
$data [ 'sum' . $series_suffix ][ 'min' ] = $min_value_min ;
$data [ 'sum' . $series_suffix ][ 'max' ] = $max_value_max ;
2019-05-09 16:26:38 +02:00
$data [ 'sum' . $series_suffix ][ 'avg' ] = ( $count_data == 0 ) ? 0 : ( $sum_data / $count_data );
2019-01-30 16:18:44 +01:00
}
if ( $show_percentil && ! $compare ) {
$percentil_result = get_percentile ( $show_percentil , $array_percentil );
if ( $compare ) {
$data [ 'percentil' . $series_suffix ][ 'data' ][] = [
(( $date_array [ 'start_date' ] + $date_array [ 'period' ]) * 1000 ),
$percentil_result ,
];
$data [ 'percentil' . $series_suffix ][ 'data' ][] = [
(( $date_array [ 'final_date' ] + $date_array [ 'period' ]) * 1000 ),
$percentil_result ,
];
} else {
$data [ 'percentil' . $series_suffix ][ 'data' ][] = [
( $date_array [ 'start_date' ] * 1000 ),
$percentil_result ,
];
$data [ 'percentil' . $series_suffix ][ 'data' ][] = [
( $date_array [ 'final_date' ] * 1000 ),
$percentil_result ,
];
}
}
2019-05-09 16:26:38 +02:00
// Add missed last data.
2019-01-30 16:18:44 +01:00
if ( $compare ) {
$data [ 'sum' . $series_suffix ][ 'data' ][] = [
(( $date_array [ 'final_date' ] + $date_array [ 'period' ]) * 1000 ),
$last_data ,
];
} else {
2020-10-02 14:16:55 +02:00
if ( $type_mode_graph <= 1 ) {
$data [ 'sum' . $series_suffix ][ 'data' ][] = [
( $date_array [ 'final_date' ] * 1000 ),
$last_data ,
];
}
2019-01-30 16:18:44 +01:00
if ( $data_slice ) {
if ( $type_mode_graph && ! $params [ 'baseline' ]) {
2020-10-02 14:16:55 +02:00
if (( int ) $type_mode_graph === 1 || ( int ) $type_mode_graph === 3 ) {
$data [ 'min' . $series_suffix ][ 'data' ][] = [
( $date_array [ 'final_date' ] * 1000 ),
$min_value ,
];
}
if (( int ) $type_mode_graph === 1 || ( int ) $type_mode_graph === 2 ) {
$data [ 'max' . $series_suffix ][ 'data' ][] = [
( $date_array [ 'final_date' ] * 1000 ),
$max_value ,
];
}
2019-01-30 16:18:44 +01:00
} else {
$data [ 'sum' . $series_suffix ][ 'slice_data' ][( $date_array [ 'final_date' ] * 1000 )][ 'min' ] = $min_value ;
2019-05-09 16:26:38 +02:00
$data [ 'sum' . $series_suffix ][ 'slice_data' ][( $date_array [ 'final_date' ] * 1000 )][ 'avg' ] = 0 ;
if ( isset ( $count_data ) === true ) {
$data [ 'sum' . $series_suffix ][ 'slice_data' ][( $date_array [ 'final_date' ] * 1000 )][ 'avg' ] = ( $sum_data / $count_data );
2023-10-18 12:49:47 +02:00
$data [ 'sum' . $series_suffix ][ 'slice_data' ][( $date_array [ 'final_date' ] * 1000 )][ 'sum' ] = $sum_data ;
2019-05-09 16:26:38 +02:00
}
2019-01-30 16:18:44 +01:00
$data [ 'sum' . $series_suffix ][ 'slice_data' ][( $date_array [ 'final_date' ] * 1000 )][ 'max' ] = $max_value ;
}
}
}
return $data ;
2018-02-16 13:41:31 +01:00
}
2019-01-30 16:18:44 +01:00
2018-02-27 16:28:00 +01:00
/**
* Print an area graph with netflow aggregated
*/
2019-03-14 10:36:15 +01:00
function graph_netflow_aggregate_area ( $data , $period , $width , $height , $ttl = 1 , $only_image = false , $date = null )
2019-01-30 16:18:44 +01:00
{
global $config ;
global $graphic_type ;
if ( empty ( $data )) {
echo fs_error_image ();
return ;
}
2019-05-09 16:26:38 +02:00
// Calculate source indexes.
2019-01-30 16:18:44 +01:00
foreach ( $data [ 'sources' ] as $key => $value ) {
$i = 0 ;
foreach ( $data [ 'data' ] as $k => $v ) {
2023-06-15 14:46:31 +02:00
$chart [ $key ][ 'data' ][ $i ][ 0 ] = ( $k * 1000 );
$chart [ $key ][ 'data' ][ $i ][ 1 ] = $v [ $key ];
2019-01-30 16:18:44 +01:00
$i ++ ;
}
}
if ( $config [ 'homeurl' ] != '' ) {
$homeurl = $config [ 'homeurl' ];
} else {
$homeurl = '' ;
}
if ( $config [ 'fixed_graph' ] == false ) {
$water_mark = [
'file' => $config [ 'homedir' ] . '/images/logo_vertical_water.png' ,
2019-05-09 16:26:38 +02:00
'url' => ui_get_full_url (
'images/logo_vertical_water.png' ,
false ,
false ,
false
),
2019-01-30 16:18:44 +01:00
];
$water_mark = $config [ 'homedir' ] . '/images/logo_vertical_water.png' ;
}
if ( $ttl >= 2 ) {
$only_image = true ;
} else {
$only_image = false ;
}
$params = [
'agent_module_id' => false ,
'period' => $period ,
'width' => '90%' ,
'height' => 450 ,
2019-03-14 10:36:15 +01:00
'unit' => 'bytes' ,
2019-01-30 16:18:44 +01:00
'only_image' => $only_image ,
'homeurl' => $homeurl ,
'menu' => true ,
'backgroundColor' => 'white' ,
'type_graph' => 'area' ,
'font' => $config [ 'fontpath' ],
'font_size' => $config [ 'font_size' ],
'array_data_create' => $chart ,
2019-03-11 16:25:10 +01:00
'stacked' => 1 ,
2019-03-13 18:55:16 +01:00
'date' => $date ,
2019-03-14 17:49:44 +01:00
'show_export_csv' => false ,
'show_overview' => false ,
2019-01-30 16:18:44 +01:00
];
return grafico_modulo_sparse ( $params );
2011-12-21 14:09:26 +01:00
}
2019-01-30 16:18:44 +01:00
2011-12-21 14:09:26 +01:00
/**
* Print an area graph with netflow total
*/
2019-01-30 16:18:44 +01:00
function graph_netflow_total_area ( $data , $period , $width , $height , $unit = '' , $ttl = 1 , $only_image = false )
{
global $config ;
global $graphic_type ;
if ( empty ( $data )) {
echo fs_error_image ();
return ;
}
// Calculate source indexes
$i = 0 ;
foreach ( $data as $key => $value ) {
$chart [ 'netflow' ][ 'data' ][ $i ][ 0 ] = ( $key * 1000 );
$chart [ 'netflow' ][ 'data' ][ $i ][ 1 ] = $value [ 'data' ];
$i ++ ;
}
if ( $config [ 'homeurl' ] != '' ) {
$homeurl = $config [ 'homeurl' ];
} else {
$homeurl = '' ;
}
if ( $config [ 'fixed_graph' ] == false ) {
$water_mark = [
'file' => $config [ 'homedir' ] . '/images/logo_vertical_water.png' ,
'url' => ui_get_full_url ( 'images/logo_vertical_water.png' , false , false , false ),
];
$water_mark = $config [ 'homedir' ] . '/images/logo_vertical_water.png' ;
}
if ( $ttl >= 2 ) {
$only_image = true ;
} else {
$only_image = false ;
}
$params = [
'agent_module_id' => false ,
'period' => $period ,
'width' => '90%' ,
'height' => 450 ,
'unit' => $unit ,
'only_image' => $only_image ,
'homeurl' => $homeurl ,
'menu' => true ,
'backgroundColor' => 'white' ,
'type_graph' => 'area' ,
'font' => $config [ 'fontpath' ],
'font_size' => $config [ 'font_size' ],
'array_data_create' => $chart ,
];
return grafico_modulo_sparse ( $params );
2011-12-21 14:09:26 +01:00
}
2019-01-30 16:18:44 +01:00
2011-12-21 14:09:26 +01:00
/**
* Print a pie graph with netflow aggregated
*/
2019-01-30 16:18:44 +01:00
function graph_netflow_aggregate_pie ( $data , $aggregate , $ttl = 1 , $only_image = false )
{
global $config ;
global $graphic_type ;
if ( empty ( $data )) {
return fs_error_image ();
}
$date_array = [];
$date_array [ 'period' ] = 300 ;
$date_array [ 'final_date' ] = time ();
$date_array [ 'start_date' ] = ( time () - 300 );
$i = 0 ;
$values = [];
$agg = '' ;
while ( isset ( $data [ $i ])) {
$agg = $data [ $i ][ 'agg' ];
if ( ! isset ( $values [ $agg ])) {
$values [ $agg ] = $data [ $i ][ 'data' ];
} else {
$values [ $agg ] += $data [ $i ][ 'data' ];
}
$i ++ ;
}
2022-12-22 23:03:52 +01:00
$labels = array_keys ( $values );
2023-07-25 10:33:29 +02:00
foreach ( $labels as $key => $label ) {
$labels [ $key ] = ( string ) $label ;
}
2022-12-22 23:03:52 +01:00
$values = array_values ( $values );
2019-01-30 16:18:44 +01:00
if ( $config [ 'fixed_graph' ] == false ) {
$water_mark = [
'file' => $config [ 'homedir' ] . '/images/logo_vertical_water.png' ,
'url' => ui_get_full_url ( 'images/logo_vertical_water.png' , false , false , false ),
];
}
2022-12-16 10:38:37 +01:00
$options = [
'height' => 230 ,
'waterMark' => $water_mark ,
'ttl' => $ttl ,
'legend' => [
'display' => true ,
'position' => 'right' ,
'align' => 'center' ,
],
2022-12-22 23:03:52 +01:00
'labels' => $labels ,
2022-12-16 10:38:37 +01:00
];
$output = '' ;
if (( int ) $ttl === 2 ) {
$output .= '<img src="data:image/png;base64,' ;
} else {
$output .= '<div style="margin: 0 auto; width:500px;">' ;
}
// Pie.
$output .= pie_graph (
2019-01-30 16:18:44 +01:00
$values ,
2022-12-16 10:38:37 +01:00
$options
2019-01-30 16:18:44 +01:00
);
2022-12-16 10:38:37 +01:00
if (( int ) $ttl === 2 ) {
$output .= '" />' ;
} else {
$output .= '</div>' ;
}
return $output ;
2011-12-21 14:09:26 +01:00
}
2019-01-30 16:18:44 +01:00
2014-04-23 11:34:00 +02:00
/**
2019-03-21 12:37:03 +01:00
* Print a circular mesh array .
*
* @ param array $data Array with properly data structure . Array with two
* elements required :
* 'elements' : Non - associative array with all the relationships .
* 'matrix' : Array of arrays with value of the relationship .
*
* @ return string HTML data .
2014-04-23 11:34:00 +02:00
*/
2019-03-21 12:37:03 +01:00
function graph_netflow_circular_mesh ( $data )
2019-01-30 16:18:44 +01:00
{
global $config ;
2014-04-23 11:34:00 +02:00
2019-01-30 16:18:44 +01:00
if ( empty ( $data ) || empty ( $data [ 'elements' ]) || empty ( $data [ 'matrix' ])) {
return fs_error_image ();
}
2014-04-23 11:34:00 +02:00
2019-01-30 16:18:44 +01:00
include_once $config [ 'homedir' ] . '/include/graphs/functions_d3.php' ;
2014-04-23 11:34:00 +02:00
2023-07-19 10:36:30 +02:00
$width = ( empty ( $data [ 'width' ]) === false ) ? $data [ 'width' ] : 900 ;
$height = ( empty ( $data [ 'height' ]) === false ) ? $data [ 'height' ] : 900 ;
return d3_relationship_graph ( $data [ 'elements' ], $data [ 'matrix' ], $width , true , $height );
2014-04-23 11:34:00 +02:00
}
2019-01-30 16:18:44 +01:00
2014-04-23 11:34:00 +02:00
/**
2014-06-10 17:21:58 +02:00
* Print a rectangular graph with the traffic of the ports for each IP
2014-04-23 11:34:00 +02:00
*/
2019-03-14 10:36:15 +01:00
function graph_netflow_host_traffic ( $data , $width = 700 , $height = 700 )
2019-01-30 16:18:44 +01:00
{
global $config ;
2014-04-23 11:34:00 +02:00
2019-01-30 16:18:44 +01:00
if ( empty ( $data )) {
return fs_error_image ();
}
2014-04-23 11:34:00 +02:00
2019-01-30 16:18:44 +01:00
include_once $config [ 'homedir' ] . '/include/graphs/functions_d3.php' ;
2014-04-23 11:34:00 +02:00
2019-01-30 16:18:44 +01:00
return d3_tree_map_graph ( $data , $width , $height , true );
2014-04-23 11:34:00 +02:00
}
2011-12-21 14:09:26 +01:00
2019-01-30 16:18:44 +01:00
2011-04-19 14:11:00 +02:00
/**
2018-02-27 16:28:00 +01:00
* Print a graph with event data of module
2019-01-30 16:18:44 +01:00
*
2018-02-27 16:28:00 +01:00
* @ param integer id_module Module ID
2011-04-19 14:11:00 +02:00
* @ param integer width graph width
2018-02-27 16:28:00 +01:00
* @ param integer height graph height
* @ param integer period time period
* @ param string homeurl Home url if the complete path is needed
* @ param int Zoom factor over the graph
* @ param string adaptation width and margin left key ( could be adapter_ [ something ] or adapted_ [ something ])
* @ param int date limit of the period
2011-04-19 14:11:00 +02:00
*/
2019-01-30 16:18:44 +01:00
function graphic_module_events ( $id_module , $width , $height , $period = 0 , $homeurl = '' , $zoom = 0 , $adapt_key = '' , $date = false , $stat_win = false )
{
global $config ;
global $graphic_type ;
$data = [];
// $resolution = $config['graph_res'] * ($period * 2 / $width); // Number of "slices" we want in graph
$resolution = ( 5 * ( $period * 2 / $width ));
// Number of "slices" we want in graph
$interval = ( int ) ( $period / $resolution );
if ( $date === false ) {
$date = get_system_time ();
}
$datelimit = ( $date - $period );
$periodtime = floor ( $period / $interval );
$time = [];
$data = [];
// Set the title and time format
if ( $period <= SECONDS_6HOURS ) {
$time_format = 'H:i:s' ;
} else if ( $period < SECONDS_1DAY ) {
$time_format = 'H:i' ;
} else if ( $period < SECONDS_15DAYS ) {
$time_format = 'M d H:i' ;
} else if ( $period < SECONDS_1MONTH ) {
$time_format = 'M d H\h' ;
} else if ( $period < SECONDS_6MONTHS ) {
$time_format = 'M d H\h' ;
} else {
$time_format = 'Y M d H\h' ;
}
$legend = [];
$cont = 0 ;
for ( $i = 0 ; $i < $interval ; $i ++ ) {
$bottom = ( $datelimit + ( $periodtime * $i ));
if ( ! $graphic_type ) {
$name = date ( $time_format , $bottom );
// $name = date('H\h', $bottom);
} else {
$name = $bottom ;
}
$top = ( $datelimit + ( $periodtime * ( $i + 1 )));
$events = db_get_all_rows_filter (
'tevento' ,
[ 'id_agentmodule' => $id_module ,
'utimestamp > ' . $bottom ,
'utimestamp < ' . $top
],
'event_type, utimestamp'
);
if ( ! empty ( $events )) {
$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 ;
}
}
}
$data [ $cont ][ 'utimestamp' ] = $periodtime ;
if ( ! empty ( $events )) {
switch ( $status ) {
case 'warning' :
$data [ $cont ][ 'data' ] = 2 ;
break ;
case 'critical' :
$data [ $cont ][ 'data' ] = 3 ;
break ;
case 'unknown' :
$data [ $cont ][ 'data' ] = 4 ;
break ;
default :
$data [ $cont ][ 'data' ] = 1 ;
break ;
}
} else {
$data [ $cont ][ 'data' ] = 1 ;
}
$current_timestamp = $bottom ;
$legend [] = date ( $time_format , $current_timestamp );
$cont ++ ;
}
$pixels_between_xdata = 25 ;
$max_xdata_display = round ( $width / $pixels_between_xdata );
$ndata = count ( $data );
if ( $max_xdata_display > $ndata ) {
$xdata_display = $ndata ;
} else {
$xdata_display = $max_xdata_display ;
}
$step = round ( $ndata / $xdata_display );
$colors = [
1 => '#38B800' ,
2 => '#FFFF00' ,
3 => '#FF0000' ,
4 => '#C3C3C3' ,
];
// Draw slicebar graph
echo flot_slicesbar_graph (
$data ,
$period ,
$width ,
50 ,
$legend ,
$colors ,
$config [ 'fontpath' ],
$config [ 'round_corner' ],
$homeurl ,
'' ,
$adapt_key ,
$stat_win
);
2018-02-27 16:28:00 +01:00
}
2019-01-30 16:18:44 +01:00
2022-12-13 09:10:13 +01:00
function graph_nodata_image ( $options )
{
2020-10-14 11:17:05 +02:00
global $config ;
2022-12-13 09:10:13 +01:00
2022-12-20 12:23:18 +01:00
if ( $options [ 'base64' ] === true ) {
$dataImg = file_get_contents (
$config [ 'homedir' ] . '/images/image_problem_area_150.png'
);
return base64_encode ( $dataImg );
}
2023-11-07 13:18:44 +01:00
$style = '' ;
2023-09-25 13:52:28 +02:00
if ( isset ( $options [ 'nodata_image' ][ 'width' ]) === true ) {
2023-11-07 13:18:44 +01:00
$style .= 'width: ' . $options [ 'nodata_image' ][ 'width' ] . '; ' ;
} else {
$style .= 'width: 200px; ' ;
}
if ( isset ( $options [ 'nodata_image' ][ 'height' ]) === true ) {
$style .= 'height: ' . $options [ 'nodata_image' ][ 'height' ] . '; ' ;
2023-09-25 13:52:28 +02:00
}
2022-12-13 09:10:13 +01:00
return html_print_image (
'images/image_problem_area.png' ,
true ,
[
'title' => __ ( 'No data' ),
2023-11-07 13:18:44 +01:00
'style' => $style ,
2022-12-13 09:10:13 +01:00
]
);
2018-02-27 16:28:00 +01:00
}
2019-01-30 16:18:44 +01:00
function get_criticity_pie_colors ( $data_graph )
{
$colors = [];
foreach ( array_keys ( $data_graph ) as $crit ) {
switch ( $crit ) {
case __ ( 'Maintenance' ) :
$colors [ $crit ] = COL_MAINTENANCE ;
break ;
case __ ( 'Informational' ) :
$colors [ $crit ] = COL_INFORMATIONAL ;
break ;
case __ ( 'Normal' ) :
$colors [ $crit ] = COL_NORMAL ;
break ;
case __ ( 'Warning' ) :
$colors [ $crit ] = COL_WARNING ;
break ;
case __ ( 'Critical' ) :
$colors [ $crit ] = COL_CRITICAL ;
break ;
case __ ( 'Minor' ) :
$colors [ $crit ] = COL_MINOR ;
break ;
case __ ( 'Major' ) :
$colors [ $crit ] = COL_MAJOR ;
break ;
}
}
return $colors ;
2011-04-19 14:11:00 +02:00
}
2018-02-27 16:28:00 +01:00
2012-07-18 15:25:51 +02:00
/**
2018-02-27 16:28:00 +01:00
* Print a rectangular graph with the snmptraps received
2012-07-18 15:25:51 +02:00
*/
2019-01-30 16:18:44 +01:00
function graph_snmp_traps_treemap ( $data , $width = 700 , $height = 700 )
{
global $config ;
if ( empty ( $data )) {
return fs_error_image ();
}
include_once $config [ 'homedir' ] . '/include/graphs/functions_d3.php' ;
return d3_tree_map_graph ( $data , $width , $height , true );
}
function extract_agents_with_group_id ( & $agents , $group_id )
{
$valid_agents = [];
foreach ( $agents as $id => $agent ) {
if ( isset ( $agent [ 'group' ]) && $agent [ 'group' ] == $group_id ) {
$valid_agents [ $id ] = $agent ;
unset ( $agents [ $id ]);
}
}
if ( ! empty ( $valid_agents )) {
return $valid_agents ;
} else {
return false ;
}
}
function iterate_group_array ( $groups , & $data_agents )
{
$data = [];
2018-02-27 16:28:00 +01:00
2019-01-30 16:18:44 +01:00
foreach ( $groups as $id => $group ) {
$group_aux = [];
$group_aux [ 'id' ] = ( int ) $id ;
$group_aux [ 'name' ] = io_safe_output ( $group [ 'nombre' ]);
$group_aux [ 'show_name' ] = true ;
$group_aux [ 'parent' ] = ( int ) $group [ 'parent' ];
$group_aux [ 'type' ] = 'group' ;
$group_aux [ 'size' ] = 100 ;
$group_aux [ 'status' ] = groups_get_status ( $id );
2018-02-27 16:28:00 +01:00
2019-01-30 16:18:44 +01:00
switch ( $group_aux [ 'status' ]) {
case AGENT_STATUS_CRITICAL :
$group_aux [ 'color' ] = COL_CRITICAL ;
break ;
2018-02-27 16:28:00 +01:00
2019-01-30 16:18:44 +01:00
case AGENT_STATUS_WARNING :
case AGENT_STATUS_ALERT_FIRED :
$group_aux [ 'color' ] = COL_WARNING ;
break ;
case AGENT_STATUS_NORMAL :
$group_aux [ 'color' ] = COL_NORMAL ;
break ;
case AGENT_STATUS_UNKNOWN :
default :
$group_aux [ 'color' ] = COL_UNKNOWN ;
break ;
}
2023-03-28 10:45:41 +02:00
$tooltip_content = html_print_image ( 'images/' . $group [ 'icon' ], true ) . ' ' . __ ( 'Group' ) . ': <b>' . $group_aux [ 'name' ] . '</b>' ;
2019-01-30 16:18:44 +01:00
$group_aux [ 'tooltip_content' ] = $tooltip_content ;
$group_aux [ 'children' ] = [];
if ( ! empty ( $group [ 'children' ])) {
$group_aux [ 'children' ] = iterate_group_array ( $group [ 'children' ], $data_agents );
}
$agents = extract_agents_with_group_id ( $data_agents , ( int ) $id );
if ( ! empty ( $agents )) {
$group_aux [ 'children' ] = array_merge ( $group_aux [ 'children' ], $agents );
}
$data [] = $group_aux ;
}
return $data ;
2018-02-27 16:28:00 +01:00
}
2019-01-30 16:18:44 +01:00
2018-02-27 16:28:00 +01:00
/**
* Print a solarburst graph with a representation of all the groups , agents , module groups and modules grouped
*/
2019-01-30 16:18:44 +01:00
function graph_monitor_wheel ( $width = 550 , $height = 600 , $filter = false )
{
global $config ;
include_once $config [ 'homedir' ] . '/include/functions_users.php' ;
include_once $config [ 'homedir' ] . '/include/functions_groups.php' ;
include_once $config [ 'homedir' ] . '/include/functions_agents.php' ;
include_once $config [ 'homedir' ] . '/include/functions_modules.php' ;
$graph_data = [];
$filter_module_group = ( ! empty ( $filter ) && ! empty ( $filter [ 'module_group' ])) ? $filter [ 'module_group' ] : false ;
if ( $filter [ 'group' ] != 0 ) {
2023-07-18 10:18:30 +02:00
if ( $filter [ 'dont_show_subgroups' ] === false ) {
$groups = groups_get_children ( $filter [ 'group' ]);
$groups_ax = [];
foreach ( $groups as $g ) {
$groups_ax [ $g [ 'id_grupo' ]] = $g ;
}
2019-01-30 16:18:44 +01:00
2023-07-18 10:18:30 +02:00
$groups = $groups_ax ;
} else {
$groups = groups_get_group_by_id ( $filter [ 'group' ]);
$groups [ $group [ 'id_grupo' ]] = $group ;
2019-01-30 16:18:44 +01:00
}
} else {
$groups = users_get_groups ( false , 'AR' , false , true , ( ! empty ( $filter ) && isset ( $filter [ 'group' ]) ? $filter [ 'group' ] : null ));
}
$data_groups = [];
if ( ! empty ( $groups )) {
$groups_aux = $groups ;
$childrens = [];
$data_groups = groups_get_tree_good ( $groups , false , $childrens );
// When i want only one group
if ( count ( $data_groups ) > 1 ) {
foreach ( $childrens as $id_c ) {
unset ( $data_groups [ $id_c ]);
}
}
$data_groups_keys = [];
groups_get_tree_keys ( $data_groups , $data_groups_keys );
$groups_aux = null ;
}
if ( ! empty ( $data_groups )) {
$filter = [ 'id_grupo' => array_keys ( $data_groups_keys )];
$fields = [
'id_agente' ,
'id_parent' ,
'id_grupo' ,
'alias' ,
];
$agents = agents_get_agents ( $filter , $fields );
if ( ! empty ( $agents )) {
$agents_id = [];
$agents_aux = [];
foreach ( $agents as $key => $agent ) {
$agents_aux [ $agent [ 'id_agente' ]] = $agent ;
}
$agents = $agents_aux ;
$agents_aux = null ;
$module_groups = modules_get_modulegroups ();
$module_groups [ 0 ] = __ ( 'Not assigned' );
$modules = agents_get_modules ( array_keys ( $agents ), '*' );
$data_agents = [];
if ( ! empty ( $modules )) {
foreach ( $modules as $key => $module ) {
$module_id = ( int ) $module [ 'id_agente_modulo' ];
$agent_id = ( int ) $module [ 'id_agente' ];
$module_group_id = ( int ) $module [ 'id_module_group' ];
$module_name = io_safe_output ( $module [ 'nombre' ]);
$module_status = modules_get_agentmodule_status ( $module_id );
$module_value = modules_get_last_value ( $module_id );
if ( $filter_module_group && $filter_module_group != $module_group_id ) {
continue ;
}
if ( ! isset ( $data_agents [ $agent_id ])) {
$data_agents [ $agent_id ] = [];
$data_agents [ $agent_id ][ 'id' ] = $agent_id ;
$data_agents [ $agent_id ][ 'name' ] = io_safe_output ( $agents [ $agent_id ][ 'alias' ]);
$data_agents [ $agent_id ][ 'group' ] = ( int ) $agents [ $agent_id ][ 'id_grupo' ];
$data_agents [ $agent_id ][ 'type' ] = 'agent' ;
$data_agents [ $agent_id ][ 'size' ] = 30 ;
$data_agents [ $agent_id ][ 'show_name' ] = true ;
$data_agents [ $agent_id ][ 'children' ] = [];
$tooltip_content = __ ( 'Agent' ) . ': <b>' . $data_agents [ $agent_id ][ 'name' ] . '</b>' ;
$data_agents [ $agent_id ][ 'tooltip_content' ] = io_safe_output ( $tooltip_content );
$data_agents [ $agent_id ][ 'modules_critical' ] = 0 ;
$data_agents [ $agent_id ][ 'modules_warning' ] = 0 ;
$data_agents [ $agent_id ][ 'modules_normal' ] = 0 ;
$data_agents [ $agent_id ][ 'modules_not_init' ] = 0 ;
$data_agents [ $agent_id ][ 'modules_not_normal' ] = 0 ;
$data_agents [ $agent_id ][ 'modules_unknown' ] = 0 ;
$data_agents [ $agent_id ][ 'color' ] = COL_UNKNOWN ;
unset ( $agents [ $agent_id ]);
}
if ( ! isset ( $data_agents [ $agent_id ][ 'children' ][ $module_group_id ])) {
$data_agents [ $agent_id ][ 'children' ][ $module_group_id ] = [];
$data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'id' ] = $module_group_id ;
$data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'name' ] = io_safe_output ( $module_groups [ $module_group_id ]);
$data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'type' ] = 'module_group' ;
$data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'size' ] = 10 ;
$data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'children' ] = [];
$tooltip_content = __ ( 'Module group' ) . ': <b>' . $data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'name' ] . '</b>' ;
$data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'tooltip_content' ] = $tooltip_content ;
$data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'modules_critical' ] = 0 ;
$data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'modules_warning' ] = 0 ;
$data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'modules_normal' ] = 0 ;
$data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'modules_not_init' ] = 0 ;
$data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'modules_not_normal' ] = 0 ;
$data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'modules_unknown' ] = 0 ;
$data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'color' ] = COL_UNKNOWN ;
}
switch ( $module_status ) {
case AGENT_MODULE_STATUS_CRITICAL_BAD :
case AGENT_MODULE_STATUS_CRITICAL_ALERT :
$data_agents [ $agent_id ][ 'modules_critical' ] ++ ;
$data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'modules_critical' ] ++ ;
break ;
case AGENT_MODULE_STATUS_WARNING :
case AGENT_MODULE_STATUS_WARNING_ALERT :
$data_agents [ $agent_id ][ 'modules_warning' ] ++ ;
$data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'modules_warning' ] ++ ;
break ;
case AGENT_MODULE_STATUS_NORMAL :
case AGENT_MODULE_STATUS_NORMAL_ALERT :
$data_agents [ $agent_id ][ 'modules_normal' ] ++ ;
$data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'modules_normal' ] ++ ;
break ;
case AGENT_MODULE_STATUS_NOT_INIT :
$data_agents [ $agent_id ][ 'modules_not_init' ] ++ ;
$data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'modules_not_init' ] ++ ;
break ;
case AGENT_MODULE_STATUS_NOT_NORMAL :
$data_agents [ $agent_id ][ 'modules_not_normal' ] ++ ;
$data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'modules_not_normal' ] ++ ;
break ;
case AGENT_MODULE_STATUS_NO_DATA :
case AGENT_MODULE_STATUS_UNKNOWN :
$data_agents [ $agent_id ][ 'modules_unknown' ] ++ ;
$data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'modules_unknown' ] ++ ;
break ;
}
if ( $data_agents [ $agent_id ][ 'modules_critical' ] > 0 ) {
$data_agents [ $agent_id ][ 'color' ] = COL_CRITICAL ;
} else if ( $data_agents [ $agent_id ][ 'modules_warning' ] > 0 ) {
$data_agents [ $agent_id ][ 'color' ] = COL_WARNING ;
} else if ( $data_agents [ $agent_id ][ 'modules_not_normal' ] > 0 ) {
$data_agents [ $agent_id ][ 'color' ] = COL_WARNING ;
} else if ( $data_agents [ $agent_id ][ 'modules_unknown' ] > 0 ) {
$data_agents [ $agent_id ][ 'color' ] = COL_UNKNOWN ;
} else if ( $data_agents [ $agent_id ][ 'modules_normal' ] > 0 ) {
$data_agents [ $agent_id ][ 'color' ] = COL_NORMAL ;
} else {
$data_agents [ $agent_id ][ 'color' ] = COL_NOTINIT ;
}
if ( $data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'modules_critical' ] > 0 ) {
$data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'color' ] = COL_CRITICAL ;
} else if ( $data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'modules_warning' ] > 0 ) {
$data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'color' ] = COL_WARNING ;
} else if ( $data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'modules_not_normal' ] > 0 ) {
$data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'color' ] = COL_WARNING ;
} else if ( $data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'modules_unknown' ] > 0 ) {
$data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'color' ] = COL_UNKNOWN ;
} else if ( $data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'modules_normal' ] > 0 ) {
$data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'color' ] = COL_NORMAL ;
} else {
$data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'color' ] = COL_NOTINIT ;
}
$data_module = [];
$data_module [ 'id' ] = $module_id ;
$data_module [ 'name' ] = $module_name ;
$data_module [ 'type' ] = 'module' ;
$data_module [ 'size' ] = 10 ;
$data_module [ 'link' ] = ui_get_full_url ( " index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente= $agent_id " );
$tooltip_content = __ ( 'Module' ) . ': <b>' . $module_name . '</b>' ;
if ( isset ( $module_value ) && $module_value !== false ) {
$tooltip_content .= '<br>' ;
$tooltip_content .= __ ( 'Value' ) . ': <b>' . io_safe_output ( $module_value ) . '</b>' ;
}
$data_module [ 'tooltip_content' ] = $tooltip_content ;
switch ( $module_status ) {
case AGENT_MODULE_STATUS_CRITICAL_BAD :
case AGENT_MODULE_STATUS_CRITICAL_ALERT :
$data_module [ 'color' ] = COL_CRITICAL ;
break ;
case AGENT_MODULE_STATUS_WARNING :
case AGENT_MODULE_STATUS_WARNING_ALERT :
$data_module [ 'color' ] = COL_WARNING ;
break ;
case AGENT_MODULE_STATUS_NORMAL :
case AGENT_MODULE_STATUS_NORMAL_ALERT :
$data_module [ 'color' ] = COL_NORMAL ;
break ;
case AGENT_MODULE_STATUS_NOT_INIT :
$data_module [ 'color' ] = COL_NOTINIT ;
break ;
case AGENT_MODULE_STATUS_NOT_NORMAL :
$data_module [ 'color' ] = COL_WARNING ;
break ;
case AGENT_MODULE_STATUS_NO_DATA :
case AGENT_MODULE_STATUS_UNKNOWN :
default :
$data_module [ 'color' ] = COL_UNKNOWN ;
break ;
}
$data_agents [ $agent_id ][ 'children' ][ $module_group_id ][ 'children' ][] = $data_module ;
unset ( $modules [ $module_id ]);
}
$data_agents = array_map (
function ( $value ) {
$value [ 'children' ] = array_merge ( $value [ 'children' ]);
return $value ;
},
$data_agents
);
}
foreach ( $agents as $id => $agent ) {
if ( ! isset ( $data_agents [ $id ])) {
$data_agents [ $id ] = [];
$data_agents [ $id ][ 'id' ] = ( int ) $id ;
$data_agents [ $id ][ 'name' ] = io_safe_output ( $agent [ 'alias' ]);
$data_agents [ $id ][ 'type' ] = 'agent' ;
$data_agents [ $id ][ 'color' ] = COL_NOTINIT ;
$data_agents [ $id ][ 'show_name' ] = true ;
}
}
$agents = null ;
}
}
$graph_data = [
'name' => __ ( 'Main node' ),
'type' => 'center_node' ,
'children' => iterate_group_array ( $data_groups , $data_agents ),
2023-04-27 10:05:20 +02:00
'color' => ( $config [ 'style' ] === 'pandora_black' ) ? '#111' : '#FFF' ,
2019-01-30 16:18:44 +01:00
];
if ( empty ( $graph_data [ 'children' ])) {
return fs_error_image ();
}
include_once $config [ 'homedir' ] . '/include/graphs/functions_d3.php' ;
return d3_sunburst_graph ( $graph_data , $width , $height , true );
2014-06-26 13:32:14 +02:00
}
2018-09-11 17:06:35 +02:00
2019-05-09 16:26:38 +02:00
/**
* Function that on a date requests 3 times that period and takes an average .
*
* @ param integer $agent_module_id ID module .
* @ param array $date_array Date array start finish period .
* @ param array $data_module_graph Data module .
* @ param array $params Params .
*
* @ return array Data baseline graph .
*/
function get_baseline_data (
$agent_module_id ,
$date_array ,
$data_module_graph ,
$params
) {
2019-01-30 16:18:44 +01:00
$period = $date_array [ 'period' ];
$date = $date_array [ 'final_date' ];
$array_data = [];
2019-02-18 16:34:48 +01:00
2019-01-30 16:18:44 +01:00
for ( $i = 0 ; $i < 4 ; $i ++ ) {
$date_array = [];
$date_array [ 'period' ] = $period ;
2019-02-18 16:34:48 +01:00
$date_array [ 'final_date' ] = ( $date - ( $period * $i ));
$date_array [ 'start_date' ] = ( $date - ( $period * ( $i + 1 )));
$array_data [] = grafico_modulo_sparse_data (
2019-01-30 16:18:44 +01:00
$agent_module_id ,
$date_array ,
$data_module_graph ,
$params ,
$i
);
}
$result = [];
$array_data [ 1 ] = array_reverse ( $array_data [ 1 ][ 'sum1' ][ 'slice_data' ]);
$array_data [ 2 ] = array_reverse ( $array_data [ 2 ][ 'sum2' ][ 'slice_data' ]);
$array_data [ 3 ] = array_reverse ( $array_data [ 3 ][ 'sum3' ][ 'slice_data' ]);
foreach ( $array_data [ 0 ][ 'sum0' ][ 'slice_data' ] as $key => $value ) {
$data1 = array_pop ( $array_data [ 1 ]);
$data2 = array_pop ( $array_data [ 2 ]);
$data3 = array_pop ( $array_data [ 3 ]);
$result [ 'slice_data' ][ $key ][ 'min' ] = (( $data1 [ 'min' ] + $data2 [ 'min' ] + $data3 [ 'min' ] + $value [ 'min' ]) / 4 );
$result [ 'slice_data' ][ $key ][ 'avg' ] = (( $data1 [ 'avg' ] + $data2 [ 'avg' ] + $data3 [ 'avg' ] + $value [ 'avg' ]) / 4 );
$result [ 'slice_data' ][ $key ][ 'max' ] = (( $data1 [ 'max' ] + $data2 [ 'max' ] + $data3 [ 'max' ] + $value [ 'max' ]) / 4 );
$result [ 'data' ][] = [
$key ,
$result [ 'slice_data' ][ $key ][ 'avg' ],
];
}
$result [ 'avg' ] = (( $array_data [ 0 ][ 'sum0' ][ 'avg' ] + $array_data [ 1 ][ 'sum1' ][ 'avg' ] + $array_data [ 2 ][ 'sum2' ][ 'avg' ] + $array_data [ 3 ][ 'sum3' ][ 'avg' ]) / 4 );
2019-05-09 16:26:38 +02:00
$result [ 'max' ] = max (
$array_data [ 0 ][ 'sum0' ][ 'max' ],
$array_data [ 1 ][ 'sum1' ][ 'max' ],
$array_data [ 2 ][ 'sum2' ][ 'max' ],
$array_data [ 3 ][ 'sum3' ][ 'max' ]
);
$result [ 'min' ] = min (
$array_data [ 0 ][ 'sum0' ][ 'min' ],
$array_data [ 1 ][ 'sum1' ][ 'min' ],
$array_data [ 2 ][ 'sum2' ][ 'min' ],
$array_data [ 3 ][ 'sum3' ][ 'min' ]
);
2019-01-30 16:18:44 +01:00
$result [ 'agent_module_id' ] = $array_data [ 0 ][ 'sum0' ][ 'agent_module_id' ];
$result [ 'id_module_type' ] = $array_data [ 0 ][ 'sum0' ][ 'id_module_type' ];
$result [ 'agent_name' ] = $array_data [ 0 ][ 'sum0' ][ 'agent_name' ];
$result [ 'module_name' ] = $array_data [ 0 ][ 'sum0' ][ 'module_name' ];
$result [ 'agent_alias' ] = $array_data [ 0 ][ 'sum0' ][ 'agent_alias' ];
return [ 'sum0' => $result ];
}
2023-03-01 17:27:32 +01:00
2023-03-03 13:13:49 +01:00
/**
* Draw graph SO agents by group .
*
* @ param [ type ] $id_group
* @ param integer $width
* @ param integer $height
* @ param boolean $recursive
* @ param boolean $noWaterMark
* @ return string Graph
*/
2023-03-02 13:48:14 +01:00
function graph_so_by_group ( $id_group , $width = 300 , $height = 200 , $recursive = true , $noWaterMark = true )
2023-03-01 17:27:32 +01:00
{
global $config ;
$id_groups = [ $id_group ];
if ( $recursive == true ) {
$groups = groups_get_children ( $id_group );
if ( count ( $groups ) > 0 ) {
$id_groups = [];
foreach ( $groups as $key => $value ) {
$id_groups [] = $value [ 'id_grupo' ];
}
}
}
$sql = sprintf (
' SELECT COUNT ( id_agente ) AS count ,
os . name
FROM tagente a
2023-09-12 16:35:45 +02:00
LEFT JOIN tagent_secondary_group g ON g . id_agent = a . id_agente
2023-03-01 17:27:32 +01:00
LEFT JOIN tconfig_os os ON a . id_os = os . id_os
2023-09-12 16:35:45 +02:00
WHERE a . id_grupo IN ( % s ) OR g . id_group IN ( % s )
2023-03-01 17:27:32 +01:00
GROUP BY os . id_os ' ,
2023-09-12 16:35:45 +02:00
implode ( ',' , $id_groups ),
2023-03-01 17:27:32 +01:00
implode ( ',' , $id_groups )
);
$result = db_get_all_rows_sql ( $sql , false , false );
if ( $result === false ) {
$result = [];
}
$labels = [];
$data = [];
foreach ( $result as $key => $row ) {
$labels [] = $row [ 'name' ];
$data [] = $row [ 'count' ];
}
2023-03-02 16:22:25 +01:00
if ( $noWaterMark === true ) {
2023-03-02 13:48:14 +01:00
$water_mark = [
'file' => $config [ 'homedir' ] . '/images/logo_vertical_water.png' ,
'url' => ui_get_full_url ( 'images/logo_vertical_water.png' , false , false , false ),
];
2023-03-02 16:22:25 +01:00
} else {
$water_mark = [];
2023-03-02 13:48:14 +01:00
}
2023-03-01 17:27:32 +01:00
$options = [
'width' => $width ,
'height' => $height ,
'waterMark' => $water_mark ,
'legend' => [
'display' => true ,
'position' => 'right' ,
'align' => 'center' ,
],
'labels' => $labels ,
];
return pie_graph (
$data ,
$options
);
}
2023-03-03 13:13:49 +01:00
/**
* Draw graph events by group
*
* @ param [ type ] $id_group
* @ param integer $width
* @ param integer $height
* @ param boolean $noWaterMark
* @ param boolean $time_limit
* @ param boolean $recursive
* @ return string Graph
*/
2023-03-01 17:27:32 +01:00
function graph_events_agent_by_group ( $id_group , $width = 300 , $height = 200 , $noWaterMark = true , $time_limit = false , $recursive = true )
{
global $config ;
$data = [];
$labels = [];
$loop = 0 ;
define ( 'NUM_PIECES_PIE_2' , 6 );
// Add tags condition to filter.
2023-03-02 17:06:16 +01:00
$tags_condition = '' ;
2023-03-01 17:27:32 +01:00
if ( $time_limit && $config [ 'event_view_hr' ]) {
$tags_condition .= ' AND utimestamp > (UNIX_TIMESTAMP(NOW()) - ' . ( $config [ 'event_view_hr' ] * SECONDS_1HOUR ) . ')' ;
}
$id_groups = [ $id_group ];
if ( $recursive === true ) {
$groups = groups_get_children ( $id_group );
if ( count ( $groups ) > 0 ) {
$id_groups = [];
foreach ( $groups as $key => $value ) {
$id_groups [] = $value [ 'id_grupo' ];
}
}
}
2023-09-12 16:35:45 +02:00
$filter_groups = ' AND (te.id_grupo IN (' . implode ( ',' , $id_groups ) . ') OR g.id_group IN (' . implode ( ',' , $id_groups ) . '))' ;
2023-03-01 17:27:32 +01:00
// This will give the distinct id_agente, give the id_grupo that goes
// with it and then the number of times it occured. GROUP BY statement
// is required if both DISTINCT() and COUNT() are in the statement.
$sql = sprintf (
' SELECT DISTINCT ( id_agente ) AS id_agente ,
COUNT ( id_agente ) AS count
FROM tevento te
2023-09-12 16:35:45 +02:00
LEFT JOIN tagent_secondary_group g ON g . id_agent = te . id_agente
WHERE 1 = 1 AND estado = 0
2023-03-03 13:13:49 +01:00
% s % s
2023-03-01 17:27:32 +01:00
GROUP BY id_agente
ORDER BY count DESC LIMIT 8 ' ,
$tags_condition ,
$filter_groups
);
$result = db_get_all_rows_sql ( $sql , false , false );
if ( $result === false ) {
$result = [];
}
$system_events = 0 ;
$other_events = 0 ;
foreach ( $result as $row ) {
$row [ 'id_grupo' ] = agents_get_agent_group ( $row [ 'id_agente' ]);
if ( ! check_acl ( $config [ 'id_user' ], $row [ 'id_grupo' ], 'ER' ) == 1 ) {
continue ;
}
if ( $loop >= NUM_PIECES_PIE_2 ) {
$other_events += $row [ 'count' ];
} else {
if ( $row [ 'id_agente' ] == 0 ) {
$system_events += $row [ 'count' ];
} else {
$alias = agents_get_alias ( $row [ 'id_agente' ]);
$name = mb_substr ( $alias , 0 , 25 ) . ' #' . $row [ 'id_agente' ] . ' (' . $row [ 'count' ] . ')' ;
$labels [] = io_safe_output ( $name );
$data [] = $row [ 'count' ];
}
}
$loop ++ ;
}
if ( $system_events > 0 ) {
$name = __ ( 'SYSTEM' ) . ' (' . $system_events . ')' ;
$labels [] = io_safe_output ( $name );
$data [] = $system_events ;
}
// Sort the data.
arsort ( $data );
2023-03-02 16:22:25 +01:00
if ( $noWaterMark === true ) {
2023-03-01 17:27:32 +01:00
$water_mark = [
'file' => $config [ 'homedir' ] . '/images/logo_vertical_water.png' ,
'url' => ui_get_full_url ( 'images/logo_vertical_water.png' , false , false , false ),
];
} else {
$water_mark = [];
}
$options = [
'width' => $width ,
'height' => $height ,
'waterMark' => $water_mark ,
'legend' => [
'display' => true ,
'position' => 'right' ,
'align' => 'center' ,
],
'labels' => $labels ,
];
return pie_graph (
$data ,
$options
);
}
2023-08-22 10:04:33 +02:00
function graph_analytics_filter_select ()
{
global $config ;
$result = [];
if ( check_acl ( $config [ 'id_user' ], 0 , 'RW' ) === 1 || check_acl ( $config [ 'id_user' ], 0 , 'RM' ) === 1 ) {
$filters = db_get_all_rows_sql ( 'SELECT id, filter_name FROM tgraph_analytics_filter WHERE user_id = "' . $config [ 'id_user' ] . '"' );
if ( $filters !== false ) {
foreach ( $filters as $filter ) {
$result [ $filter [ 'id' ]] = $filter [ 'filter_name' ];
}
}
}
return $result ;
}
2023-10-18 12:49:47 +02:00
function draw_form_stat_win ( array $form_data , string $tab_active )
{
$table = html_get_predefined_table ( 'transparent' , 2 );
$table -> width = '100%' ;
$table -> id = 'stat_win_form_div' ;
$table -> style [ 0 ] = 'text-align:left;font-weight: bold;font-size:8.5pt;line-height:30pt;' ;
$table -> style [ 1 ] = 'text-align:left;font-weight: bold;line-height:30pt;' ;
$table -> style [ 2 ] = 'text-align:left;font-weight: bold;line-height:30pt;' ;
$table -> style [ 3 ] = 'text-align:left;font-weight: bold;line-height:30pt;' ;
$table -> class = 'table_modal_alternate' ;
$table -> data = [];
if (( bool ) $form_data [ 'histogram' ] === true || $tab_active === 'tabs-chart-period-graph' ) {
$table -> data [ 0 ][ 0 ] = __ ( 'Refresh time' );
$table -> data [ 0 ][ 1 ] = '<div class="small-input-select2">' . html_print_extended_select_for_time (
'refresh' ,
$form_data [ 'refresh' ],
'' ,
'' ,
0 ,
7 ,
true
) . '</div>' ;
$table -> data [ 0 ][ 2 ] = '' ;
$table -> data [ 0 ][ 3 ] = '' ;
$table -> data [ 1 ][ 0 ] = __ ( 'Begin date' );
$table -> data [ 1 ][ 1 ] = html_print_input_text (
'start_date' ,
$form_data [ 'start_date' ],
'' ,
10 ,
20 ,
true ,
false ,
false ,
'' ,
'small-input'
);
$table -> data [ 1 ][ 2 ] = __ ( 'Begin time' );
$table -> data [ 1 ][ 3 ] = html_print_input_text (
'start_time' ,
$form_data [ 'start_time' ],
'' ,
10 ,
10 ,
true ,
false ,
false ,
'' ,
'small-input'
);
$table -> data [ 2 ][ 0 ] = __ ( 'Time range' );
$table -> data [ 2 ][ 1 ] = '<div class="small-input-select2">' . html_print_extended_select_for_time (
'period' ,
$form_data [ 'period' ],
'' ,
'' ,
0 ,
7 ,
true
) . '</div>' ;
$table -> data [ 3 ][ 0 ] = __ ( 'Time compare (Separated)' );
$table -> data [ 3 ][ 1 ] = html_print_checkbox_switch (
'time_compare_separated' ,
1 ,
( bool ) $form_data [ 'time_compare_separated' ],
true
);
$table -> data [ 3 ][ 2 ] = '' ;
$table -> data [ 3 ][ 3 ] = '' ;
if ( $tab_active === 'tabs-chart-period-graph' ) {
$table -> data [ 4 ][ 0 ] = __ ( 'Maximum' );
$table -> data [ 4 ][ 1 ] = html_print_checkbox_switch (
'period_maximum' ,
1 ,
( bool ) $form_data [ 'period_maximum' ],
true
);
$table -> data [ 4 ][ 2 ] = __ ( 'Minimum' );
$table -> data [ 4 ][ 3 ] = html_print_checkbox_switch (
'period_minimum' ,
1 ,
( bool ) $form_data [ 'period_minimum' ],
true
);
$table -> data [ 5 ][ 0 ] = __ ( 'Average' );
$table -> data [ 5 ][ 1 ] = html_print_checkbox_switch (
'period_average' ,
1 ,
( bool ) $form_data [ 'period_average' ],
true
);
$table -> data [ 5 ][ 2 ] = __ ( 'Summatory' );
$table -> data [ 5 ][ 3 ] = html_print_checkbox_switch (
'period_summatory' ,
1 ,
( bool ) $form_data [ 'period_summatory' ],
true
);
$table -> data [ 6 ][ 0 ] = __ ( 'Slice' );
$table -> data [ 6 ][ 1 ] = '<div class="small-input-select2">' . html_print_extended_select_for_time (
'period_slice_chart' ,
( string ) $form_data [ 'period_slice_chart' ],
'' ,
'' ,
0 ,
7 ,
true ,
false ,
true ,
'' ,
false ,
[
SECONDS_1HOUR => __ ( '1 hour' ),
SECONDS_1DAY => __ ( '1 day' ),
SECONDS_1WEEK => __ ( '1 week' ),
SECONDS_1MONTH => __ ( '1 month' ),
]
) . '</div>' ;
$table -> data [ 6 ][ 2 ] = __ ( 'Mode' );
$options_period_mode = [
CUSTOM_GRAPH_AREA => __ ( 'Area' ),
CUSTOM_GRAPH_LINE => __ ( 'Line' ),
// CUSTOM_GRAPH_HBARS => __('Horizontal bars'),
CUSTOM_GRAPH_VBARS => __ ( 'Vertical bars' ),
];
$table -> data [ 6 ][ 3 ] = '<div class="small-input-select2">' . html_print_select (
$options_period_mode ,
'period_mode' ,
$form_data [ 'period_mode' ],
'' ,
'' ,
0 ,
true ,
false ,
false
) . '</div>' ;
}
} else {
$table -> data [ 0 ][ 0 ] = __ ( 'Refresh time' );
$table -> data [ 0 ][ 1 ] = '<div class="small-input-select2">' . html_print_extended_select_for_time (
'refresh' ,
$form_data [ 'refresh' ],
'' ,
'' ,
0 ,
7 ,
true
) . '</div>' ;
$table -> data [ 0 ][ 2 ] = __ ( 'Show events' );
$disabled = false ;
$table -> data [ 0 ][ 3 ] = html_print_checkbox_switch (
'draw_events' ,
1 ,
( bool ) $form_data [ 'draw_events' ],
true ,
$disabled
);
$table -> data [ 1 ][ 0 ] = __ ( 'Begin date' );
$table -> data [ 1 ][ 1 ] = html_print_input_text (
'start_date' ,
$form_data [ 'start_date' ],
'' ,
10 ,
20 ,
true ,
false ,
false ,
'' ,
'small-input'
);
$table -> data [ 1 ][ 2 ] = __ ( 'Show alerts' );
$table -> data [ 1 ][ 3 ] = html_print_checkbox_switch (
'draw_alerts' ,
1 ,
( bool ) $form_data [ 'draw_alerts' ],
true
);
$table -> data [ 2 ][ 0 ] = __ ( 'Begin time' );
$table -> data [ 2 ][ 1 ] = html_print_input_text (
'start_time' ,
$form_data [ 'start_time' ],
'' ,
10 ,
10 ,
true ,
false ,
false ,
'' ,
'small-input'
);
$table -> data [ 2 ][ 2 ] = __ ( 'Show unknown graph' );
$table -> data [ 2 ][ 3 ] = html_print_checkbox_switch (
'unknown_graph' ,
1 ,
( bool ) $form_data [ 'unknown_graph' ],
true
);
$table -> data [ 3 ][ 0 ] = __ ( 'Time range' );
$table -> data [ 3 ][ 1 ] = '<div class="small-input-select2">' . html_print_extended_select_for_time (
'period' ,
$form_data [ 'period' ],
'' ,
'' ,
0 ,
7 ,
true
) . '</div>' ;
$table -> data [ 3 ][ 2 ] = '' ;
$table -> data [ 3 ][ 3 ] = '' ;
if ( ! modules_is_boolean ( $form_data [ 'id' ])) {
$table -> data [ 4 ][ 0 ] = __ ( 'Zoom' );
$options = [];
$options [ $form_data [ 'zoom' ]] = 'x' . $form_data [ 'zoom' ];
$options [ 1 ] = 'x1' ;
$options [ 2 ] = 'x2' ;
$options [ 3 ] = 'x3' ;
$options [ 4 ] = 'x4' ;
$options [ 5 ] = 'x5' ;
$table -> data [ 4 ][ 1 ] = '<div class="small-input-select2">' . html_print_select (
$options ,
'zoom' ,
$form_data [ 'zoom' ],
'' ,
'' ,
0 ,
true ,
false ,
false
) . '</div>' ;
$table -> data [ 4 ][ 2 ] = __ ( 'Show percentil' );
$table -> data [ 4 ][ 3 ] = html_print_checkbox_switch (
'show_percentil' ,
1 ,
( bool ) $form_data [ 'show_percentil' ],
true
);
}
$table -> data [ 5 ][ 0 ] = __ ( 'Time compare (Overlapped)' );
$table -> data [ 5 ][ 1 ] = html_print_checkbox_switch (
'time_compare_overlapped' ,
1 ,
( bool ) $form_data [ 'time_compare_overlapped' ],
true
);
$table -> data [ 5 ][ 2 ] = __ ( 'Time compare (Separated)' );
$table -> data [ 5 ][ 3 ] = html_print_checkbox_switch (
'time_compare_separated' ,
1 ,
( bool ) $form_data [ 'time_compare_separated' ],
true
);
$table -> data [ 6 ][ 0 ] = __ ( 'Show AVG/MAX/MIN data series in graph' );
$table -> data [ 6 ][ 1 ] = html_print_checkbox_switch (
'type_mode_graph' ,
1 ,
( bool ) $form_data [ 'type_mode_graph' ],
true ,
false
);
$table -> data [ 6 ][ 2 ] = __ ( 'Show full scale graph (TIP)' );
$table -> data [ 6 ][ 2 ] .= ui_print_help_tip (
__ ( 'TIP mode charts do not support average - maximum - minimum series, you can only enable TIP or average, maximum or minimum series' ),
true
);
$table -> data [ 6 ][ 3 ] = html_print_checkbox_switch (
'fullscale' ,
1 ,
( bool ) $form_data [ 'fullscale' ],
true ,
false
);
$table -> data [ 7 ][ 0 ] = __ ( 'Projection graph' );
$table -> data [ 7 ][ 0 ] .= ui_print_help_tip (
__ ( 'Projection graph take as begin date the current time' ),
true
);
$table -> data [ 7 ][ 1 ] = html_print_checkbox_switch (
'enable_projected_period' ,
1 ,
( bool ) $form_data [ 'enable_projected_period' ],
true
);
$table -> data [ 7 ][ 2 ] = __ ( 'Projection period' );
$table -> data [ 7 ][ 3 ] = '<div class="small-input-select2">' . html_print_extended_select_for_time (
'period_projected' ,
$form_data [ 'period_projected' ],
'' ,
'' ,
0 ,
7 ,
true
) . '</div>' ;
}
$form_table = html_print_table ( $table , true );
$form_table .= html_print_div (
[
'class' => 'action-buttons-right-forced margin-top-10' ,
'content' => html_print_submit_button (
__ ( 'Reload' ),
'submit' ,
false ,
[
'icon' => 'search' ,
'mode' => 'secondary mini' ,
'class' => 'float-right' ,
],
true
),
],
true
);
$output = '<form method="GET" action="stat_win.php" style="margin-bottom: 0">' ;
$output .= html_print_input_hidden ( 'id' , $form_data [ 'id' ], true );
$output .= html_print_input_hidden ( 'label' , $form_data [ 'label' ], true );
if ( empty ( $server_id ) === false ) {
$output .= html_print_input_hidden ( 'server' , $form_data [ 'server_id' ], true );
}
$output .= html_print_input_hidden ( 'histogram' , $form_data [ 'histogram' ], true );
$output .= html_print_input_hidden ( 'period_graph' , $form_data [ 'period_graph' ], true );
$output .= html_print_input_hidden ( 'type' , $form_data [ 'type' ], true );
$output .= ui_toggle (
$form_table ,
'<span class="subsection_header_title">' . __ ( 'Graph configuration menu' ) . '</span>' . ui_print_help_tip (
__ ( 'In Pandora FMS, data is stored compressed. The data visualization in database, charts or CSV exported data won\'t match, because is interpreted at runtime. Please check \'Pandora FMS Engineering\' chapter from documentation.' ),
true
),
'' ,
'' ,
true ,
true ,
'' ,
'white-box-content' ,
'box-flat pdd_10px' ,
'images/arrow@svg.svg' ,
'images/arrow@svg.svg' ,
true
);
$output .= '</form>' ;
return $output ;
}
function draw_container_chart_stat_win ( ? string $name = 'stat-win-module-graph' )
{
$output = '<div class="margin-lr-10" id="' . $name . '">' ;
$output .= '<div id="' . $name . '-spinner" class="stat-win-spinner">' ;
$output .= html_print_image ( 'images/spinner_charts.gif' , true );
$output .= '</div>' ;
$output .= '<div id="' . $name . '-content">' ;
$output .= '</div>' ;
$output .= '</div>' ;
return $output ;
}