2009-04-13 17:05:21 +02:00
< ? php
2009-06-08 20:26:14 +02:00
// Pandora FMS - http://pandorafms.com
// ==================================================
// Copyright (c) 2005-2009 Artica Soluciones Tecnologicas
// Please see http://pandorafms.org for full contribution list
2009-04-13 17:05:21 +02:00
// This program is free software; you can redistribute it and/or
2009-06-08 20:26:14 +02:00
// modify it under the terms of the GNU Lesser General Public License
// as published by the Free Software Foundation; version 2
2009-04-13 17:05:21 +02:00
// 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.
2009-08-24 Miguel de Dios <miguel.dedios@artica.es>
* include/functions_menu.php, include/functions_html.php,
include/functions_events.php, include/functions_messages.php,
include/functions_modules.php, include/functions_exportserver.php,
include/functions_reporting.php, include/functions_filemanager.php,
include/pchart_graph.php, include/pandora_graph.php, include/auth/dev.php,
include/auth/ldap.php, include/auth/mysql.php, include/config.inc.php,
include/functions_networkmap.php, include/functions_servers.php,
include/FusionCharts/FusionCharts_Gen.php,
include/FusionCharts/FusionCharts.php,
include/functions_network_profiles.php, include/gettext.php,
include/functions_network_components.php, include/functions_visual_map.php,
include/fgraph2.php, include/Image/image_functions.php,
include/functions_config.php, include/help/en/help_plugin_parameters.php,
include/help/en/help_snmpcommunity.php, include/help/en/help_wmiquery.php,
include/help/en/help_postprocess.php,
include/help/en/help_prediction_source_module.php,
include/help/en/help_date_format.php, include/help/en/help_recontask.php,
include/help/en/help_alert-matches.php, include/help/en/help_tcp_send.php,
include/help/en/help_wmifield.php, include/help/en/help_duplicateconfig.php,
include/help/en/help_agent_status.php,
include/help/en/help_manage_alerts.php, include/help/en/help_wmikey.php,
include/help/en/help_alert_type.php,
include/help/en/help_network_component.php,
include/help/en/help_time_stamp-comparation.php,
include/help/en/help_eventview.php, include/help/en/help_timesource.php,
include/help/en/help_alert_validation.php,
include/help/en/help_map_builder.php,
include/help/en/help_alert_recovery.php,
include/help/en/help_module_type.php,
include/help/en/help_planned_downtime.php,
include/help/en/help_serverlag.php, include/help/en/help_alerts.php,
include/help/en/help_snmpwalk.php,
include/help/en/help_module_definition.php,
include/help/en/help_plugin_definition.php,
include/help/en/help_wminamespace.php, include/help/en/help_snmpoid.php
include/help/en/help_manageconfig.php,
include/help/es/help_alert_validation.php,
include/help/es/help_plugin_parameters.php,
include/help/es/help_snmpcommunity.php, include/help/es/help_wmiquery.php,
include/help/es/help_map_builder.php, include/help/es/help_postprocess.php,
include/help/es/help_date_format.php,
include/help/es/help_alert_recovery.php,
include/help/es/help_prediction_source_module.php,
include/help/es/help_module_type.php,
include/help/es/help_planned_downtime.php,
include/help/es/help_alert-matches.php, include/help/es/help_recontask.php,
include/help/es/help_alerts.php, include/help/es/help_serverlag.php,
include/help/es/help_snmpwalk.php,
include/help/es/help_module_definition.php,
include/help/es/help_tcp_send.php, include/help/es/help_duplicateconfig.php,
include/help/es/help_wmifield.php, include/help/es/help_manage_alerts.php,
include/help/es/help_wmikey.php, include/help/es/help_plugin_definition.php,
include/help/es/help_alert_type.php, include/help/es/help_snmpoid.php,
include/help/es/help_wminamespace.php,
include/help/es/help_network_component.php,
include/help/es/help_time_stamp-comparation.php,
include/help/es/help_manageconfig.php, include/help/es/help_timesource.php,
include/config_process.php, include/functions_ui.php, include/htmlawed.php,
include/functions_custom_graphs.php, include/fgraph.php,
include/functions_incidents.php, include/functions.php,
include/functions_agents.php, include/functions_db.php,
include/functions_themes.php, include/streams.php,
include/functions_fsgraph.php, include/functions_alerts.php,
include/functions_reports.php, include/functions_extensions.php,
include/functions_ui_renders.php: change comments blocks for delete the
warnings to construct phpDoc Files, give a struct and order in the
phpDoc files.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1881 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-08-25 19:39:28 +02:00
/**
* @ package Include
2009-08-24 Miguel de Dios <miguel.dedios@artica.es>
* include/functions_menu.php, include/functions_html.php,
include/functions_events.php, include/functions_messages.php,
include/functions_modules.php, include/functions_exportserver.php,
include/functions_reporting.php, include/functions_filemanager.php,
include/pchart_graph.php, include/pandora_graph.php, include/auth/ldap.php,
include/auth/mysql.php, include/config.inc.php,
include/functions_networkmap.php, include/functions_servers.php,
include/functions_network_profiles.php, include/gettext.php,
include/functions_network_components.php, include/functions_visual_map.php,
include/fgraph2.php, include/Image/image_functions.php,
include/functions_config.php, include/config_process.php,
include/functions_ui.php, include/htmlawed.php,
include/functions_custom_graphs.php, include/fgraph.php,
include/functions_incidents.php, include/functions.php,
include/functions_agents.php, include/functions_db.php,
include/functions_themes.php, include/streams.php,
include/functions_fsgraph.php, include/functions_alerts.php,
include/functions_reports.php, include/functions_extensions.php,
include/functions_ui_renders.php: change or add the subpackage in phpdoc
comment blocks for to organize more the result phpdoc files. Start to
document undocument functions.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1882 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-08-26 17:37:47 +02:00
* @ subpackage Servers
2009-08-24 Miguel de Dios <miguel.dedios@artica.es>
* include/functions_menu.php, include/functions_html.php,
include/functions_events.php, include/functions_messages.php,
include/functions_modules.php, include/functions_exportserver.php,
include/functions_reporting.php, include/functions_filemanager.php,
include/pchart_graph.php, include/pandora_graph.php, include/auth/dev.php,
include/auth/ldap.php, include/auth/mysql.php, include/config.inc.php,
include/functions_networkmap.php, include/functions_servers.php,
include/FusionCharts/FusionCharts_Gen.php,
include/FusionCharts/FusionCharts.php,
include/functions_network_profiles.php, include/gettext.php,
include/functions_network_components.php, include/functions_visual_map.php,
include/fgraph2.php, include/Image/image_functions.php,
include/functions_config.php, include/help/en/help_plugin_parameters.php,
include/help/en/help_snmpcommunity.php, include/help/en/help_wmiquery.php,
include/help/en/help_postprocess.php,
include/help/en/help_prediction_source_module.php,
include/help/en/help_date_format.php, include/help/en/help_recontask.php,
include/help/en/help_alert-matches.php, include/help/en/help_tcp_send.php,
include/help/en/help_wmifield.php, include/help/en/help_duplicateconfig.php,
include/help/en/help_agent_status.php,
include/help/en/help_manage_alerts.php, include/help/en/help_wmikey.php,
include/help/en/help_alert_type.php,
include/help/en/help_network_component.php,
include/help/en/help_time_stamp-comparation.php,
include/help/en/help_eventview.php, include/help/en/help_timesource.php,
include/help/en/help_alert_validation.php,
include/help/en/help_map_builder.php,
include/help/en/help_alert_recovery.php,
include/help/en/help_module_type.php,
include/help/en/help_planned_downtime.php,
include/help/en/help_serverlag.php, include/help/en/help_alerts.php,
include/help/en/help_snmpwalk.php,
include/help/en/help_module_definition.php,
include/help/en/help_plugin_definition.php,
include/help/en/help_wminamespace.php, include/help/en/help_snmpoid.php
include/help/en/help_manageconfig.php,
include/help/es/help_alert_validation.php,
include/help/es/help_plugin_parameters.php,
include/help/es/help_snmpcommunity.php, include/help/es/help_wmiquery.php,
include/help/es/help_map_builder.php, include/help/es/help_postprocess.php,
include/help/es/help_date_format.php,
include/help/es/help_alert_recovery.php,
include/help/es/help_prediction_source_module.php,
include/help/es/help_module_type.php,
include/help/es/help_planned_downtime.php,
include/help/es/help_alert-matches.php, include/help/es/help_recontask.php,
include/help/es/help_alerts.php, include/help/es/help_serverlag.php,
include/help/es/help_snmpwalk.php,
include/help/es/help_module_definition.php,
include/help/es/help_tcp_send.php, include/help/es/help_duplicateconfig.php,
include/help/es/help_wmifield.php, include/help/es/help_manage_alerts.php,
include/help/es/help_wmikey.php, include/help/es/help_plugin_definition.php,
include/help/es/help_alert_type.php, include/help/es/help_snmpoid.php,
include/help/es/help_wminamespace.php,
include/help/es/help_network_component.php,
include/help/es/help_time_stamp-comparation.php,
include/help/es/help_manageconfig.php, include/help/es/help_timesource.php,
include/config_process.php, include/functions_ui.php, include/htmlawed.php,
include/functions_custom_graphs.php, include/fgraph.php,
include/functions_incidents.php, include/functions.php,
include/functions_agents.php, include/functions_db.php,
include/functions_themes.php, include/streams.php,
include/functions_fsgraph.php, include/functions_alerts.php,
include/functions_reports.php, include/functions_extensions.php,
include/functions_ui_renders.php: change comments blocks for delete the
warnings to construct phpDoc Files, give a struct and order in the
phpDoc files.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1881 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-08-25 19:39:28 +02:00
*/
2009-04-13 17:05:21 +02:00
/**
* Get a server .
*
* @ param int Server id to get .
* @ param array Extra filter .
* @ param array Fields to get .
*
* @ return Server with the given id . False if not available .
*/
function get_server ( $id_server , $filter = false , $fields = false ) {
if ( empty ( $id_server ))
return false ;
if ( ! is_array ( $filter ))
$filter = array ();
$filter [ 'id_server' ] = $id_server ;
return @ get_db_row_filter ( 'tserver' , $filter , $fields );
}
/**
* Get all the server availables .
*
* @ return All the servers available .
*/
function get_server_names () {
$all_servers = @ get_db_all_rows_filter ( 'tserver' , false , array ( 'DISTINCT(`name`) as name' ));
if ( $all_servers === false )
return array ();
$servers = array ();
foreach ( $all_servers as $server ) {
$servers [ $server [ 'name' ]] = $server [ 'name' ];
}
return $servers ;
}
2009-12-02 00:10:00 +01:00
/**
* This function will get several metrics from the database to get info about server performance
* @ return array with several data
*/
function get_server_performance () {
global $config ;
$data = array ();
// For remote modules:
// Get total modules running
$data [ " total_remote_modules " ] = get_db_sql ( " SELECT COUNT(tagente_modulo.id_agente_modulo) FROM tagente_modulo, tagente_estado WHERE tagente_modulo.id_agente_modulo = tagente_estado.id_agente_modulo AND tagente_modulo.id_modulo != 1 AND disabled = 0 AND utimestamp > 0 " );
$data [ " avg_interval_remote_modules " ] = get_db_sql ( " SELECT AVG(module_interval) FROM tagente_modulo, tagente_estado where tagente_modulo.id_agente_modulo = tagente_estado.id_agente_modulo AND disabled = 0 AND id_modulo != 1 AND module_interval > 0 AND utimestamp > 0 " );
2009-12-16 12:19:09 +01:00
if ( $data [ " total_remote_modules " ] == 0 )
$data [ " remote_modules_rate " ] = 0 ;
else
$data [ " remote_modules_rate " ] = $data [ " total_remote_modules " ] / $data [ " avg_interval_remote_modules " ];
2009-12-02 00:10:00 +01:00
// For local modules (ignoring local modules with custom invervals for simplicity).
$data [ " total_local_modules " ] = get_db_sql ( " SELECT COUNT(tagente_modulo.id_agente_modulo) FROM tagente_modulo, tagente_estado WHERE tagente_modulo.id_agente_modulo = tagente_estado.id_agente_modulo AND id_modulo = 1 AND disabled = 0 AND utimestamp > 0 " );
$data [ " avg_interval_local_modules " ] = get_db_sql ( " SELECT AVG(tagente.intervalo) FROM tagente WHERE disabled = 0 AND intervalo > 0 " );
2009-12-29 17:43:35 +01:00
if ( $data [ " avg_interval_local_modules " ] > 0 ){
$data [ " local_modules_rate " ] = $data [ " total_local_modules " ] / $data [ " avg_interval_local_modules " ];
} else {
$data [ " local_modules_rate " ] = 0 ;
}
2009-12-02 00:10:00 +01:00
$data [ " total_modules " ] = $data [ " total_local_modules " ] + $data [ " total_remote_modules " ];
return ( $data );
}
/**
* This function will get all the server information in an array or a specific server
*
* @ param mixed An optional integer or array of integers to select specific servers
*
* @ return mixed False in case the server doesn ' t exist or an array with info .
*/
function get_server_info ( $id_server = - 1 ) {
if ( is_array ( $id_server )) {
$select_id = " WHERE id_server IN ( " . implode ( " , " , $id_server ) . " ) " ;
} elseif ( $id_server > 0 ) {
$select_id = " WHERE id_server IN ( " . ( int ) $id_server . " ) " ;
} else {
$select_id = " " ;
}
$modules_info = array ();
$modules_total = array ();
$result = get_db_all_rows_sql ( " SELECT DISTINCT(tagente_estado.running_by),
COUNT ( tagente_estado . id_agente_modulo ) AS modules , id_modulo
FROM tagente_estado , tagente_modulo
WHERE tagente_modulo . id_agente_modulo = tagente_estado . id_agente_modulo
AND tagente_modulo . disabled = 0 AND utimestamp > 0
GROUP BY running_by " );
if ( empty ( $result )) {
$result = array ();
}
foreach ( $result as $row ) {
$modules_info [ $row [ " running_by " ]] = $row [ " modules " ];
if ( ! isset ( $modules_total [ $row [ " id_modulo " ]])) {
$modules_total [ $row [ " id_modulo " ]] = $row [ " modules " ];
} else {
$modules_total [ $row [ " id_modulo " ]] += $row [ " modules " ];
}
}
$recon_total = get_db_sql ( " SELECT COUNT(*) FROM trecon_task " );
$sql = " SELECT * FROM tserver " . $select_id . " ORDER BY server_type " ;
$result = get_db_all_rows_sql ( $sql );
$time = get_system_time ();
if ( empty ( $result )) {
return false ;
}
$return = array ();
foreach ( $result as $server ) {
switch ( $server [ 'server_type' ]) {
case 0 :
$server [ " img " ] = print_image ( " images/data.png " , true , array ( " title " => __ ( 'Data server' )));
$server [ " type " ] = " data " ;
$id_modulo = 1 ;
break ;
case 1 :
$server [ " img " ] = print_image ( " images/network.png " , true , array ( " title " => __ ( 'Network server' )));
$server [ " type " ] = " network " ;
$id_modulo = 2 ;
break ;
case 2 :
$server [ " img " ] = print_image ( " images/snmp.png " , true , array ( " title " => __ ( 'SNMP server' )));
$server [ " type " ] = " snmp " ;
$id_modulo = 0 ;
break ;
case 3 :
$server [ " img " ] = print_image ( " images/recon.png " , true , array ( " title " => __ ( 'Recon server' )));
$server [ " type " ] = " recon " ;
$id_modulo = 0 ;
break ;
case 4 :
$server [ " img " ] = print_image ( " images/plugin.png " , true , array ( " title " => __ ( 'Plugin server' )));
$server [ " type " ] = " plugin " ;
$id_modulo = 4 ;
break ;
case 5 :
$server [ " img " ] = print_image ( " images/chart_bar.png " , true , array ( " title " => __ ( 'Prediction server' )));
$server [ " type " ] = " prediction " ;
$id_modulo = 5 ;
break ;
case 6 :
$server [ " img " ] = print_image ( " images/wmi.png " , true , array ( " title " => __ ( 'WMI server' )));
$server [ " type " ] = " wmi " ;
$id_modulo = 6 ;
break ;
case 7 :
$server [ " img " ] = print_image ( " images/server_export.png " , true , array ( " title " => __ ( 'Export server' )));
$server [ " type " ] = " export " ;
$id_modulo = 0 ;
break ;
case 8 :
$server [ " img " ] = print_image ( " images/page_white_text.png " , true , array ( " title " => __ ( 'Inventory server' )));
$server [ " type " ] = " inventory " ;
$id_modulo = 0 ;
break ;
case 9 :
$server [ " img " ] = print_image ( " images/world.png " , true , array ( " title " => __ ( 'Web server' )));
$server [ " type " ] = " web " ;
$id_modulo = 0 ;
break ;
default :
$server [ " img " ] = '' ;
$server [ " type " ] = " unknown " ;
$id_modulo = 0 ;
break ;
}
if ( empty ( $modules_info [ $server [ " id_server " ]])) {
$server [ " modules " ] = 0 ;
} else {
$server [ " modules " ] = $modules_info [ $server [ " id_server " ]];
}
$server [ " module_lag " ] = 0 ;
$server [ " lag " ] = 0 ;
$server [ " load " ] = 0 ;
if ( ! isset ( $modules_total [ $id_modulo ])) {
$server [ " modules_total " ] = 0 ;
} else {
$server [ " modules_total " ] = $modules_total [ $id_modulo ];
}
if ( $id_modulo > 0 && $server [ " modules " ] > 0 ) {
//If the server doesn't have modules, it doesn't have lag so nothing to calculate.
// If it's not a module server, don't go here either
// Remote servers LAG Calculation:
if ( $id_modulo != 1 ){
$result = get_db_row_sql ( " SELECT COUNT(tagente_modulo.id_agente_modulo) AS module_lag, AVG(UNIX_TIMESTAMP() - utimestamp - current_interval) AS lag FROM tagente_estado, tagente_modulo
WHERE utimestamp > 0
AND tagente_modulo . disabled = 0
AND tagente_modulo . id_agente_modulo = tagente_estado . id_agente_modulo
AND current_interval > 0
AND running_by = " . $server["id_server"] . "
AND ( UNIX_TIMESTAMP () - utimestamp ) < ( current_interval * 10 )
AND ( UNIX_TIMESTAMP () - utimestamp ) > current_interval " );
} else {
// Local/Dataserver server LAG calculation:
$result = get_db_row_sql ( " SELECT COUNT(tagente_modulo.id_agente_modulo) AS module_lag, AVG(UNIX_TIMESTAMP() - utimestamp - current_interval) AS lag FROM tagente_estado, tagente_modulo
WHERE utimestamp > 0
AND tagente_modulo . disabled = 0
AND tagente_modulo . id_tipo_modulo < 5
AND tagente_modulo . id_agente_modulo = tagente_estado . id_agente_modulo
AND current_interval > 0
AND ( UNIX_TIMESTAMP () - utimestamp ) < ( current_interval * 10 )
AND running_by = " . $server["id_server"] . "
AND ( UNIX_TIMESTAMP () - utimestamp ) > ( current_interval * 1.1 ) " );
}
// Lag over current_interval * 2 is not lag, it's a timed out module
// And we can't check current_interval = 0 (data modules) because they come as they want
if ( ! empty ( $result [ " lag " ])) {
$server [ " lag " ] = $result [ " lag " ];
}
if ( ! empty ( $result [ " module_lag " ])) {
$server [ " module_lag " ] = $result [ " module_lag " ];
}
} else {
switch ( $server [ " type " ]) {
case " recon " :
$server [ " name " ] = '<a href="index.php?sec=estado_server&sec2=operation/servers/view_server_detail&server_id=' . $server [ " id_server " ] . '">' . $server [ " name " ] . '</a>' ;
//Get recon taks info
$tasks = get_db_all_rows_sql ( " SELECT status, utimestamp FROM trecon_task WHERE id_recon_server = " . $server [ " id_server " ]);
if ( empty ( $tasks )) {
$tasks = array ();
}
//Total jobs running on this recon server
$server [ " modules " ] = count ( $tasks );
//Total recon jobs (all servers)
$server [ " modules_total " ] = $recon_total ;
//Lag (take average active time of all active tasks)
$server [ " module_lag " ] = 0 ;
$lags = array ();
foreach ( $tasks as $task ) {
if ( $task [ " status " ] > 0 && $task [ " status " ] <= 100 ) {
$lags [] = $time - $task [ " utimestamp " ];
//Module lag is actually the number of jobs that is currently running
$server [ " module_lag " ] ++ ;
}
}
if ( count ( $lags ) > 0 ) {
$server [ " lag " ] = ( int ) array_sum ( $lags ) / count ( $lags );
}
break ;
default :
break ;
}
}
$server [ " lag_txt " ] = ( $server [ " lag " ] == 0 ? '-' : human_time_description_raw ( $server [ " lag " ])) . " / " . $server [ " module_lag " ];
if ( $server [ " modules_total " ] > 0 ) {
$server [ " load " ] = round ( $server [ " modules " ] / $server [ " modules_total " ] * 100 );
}
//Push the raw data on the return stack
$return [ $server [ " id_server " ]] = $server ;
}
return $return ;
}
2009-04-13 17:05:21 +02:00
?>