2006-03-27 05:37:27 +02:00
< ? php
2020-10-29 12:55:44 +01:00
// This file is an example on how things must NEVER be done.
2009-06-08 20:15:58 +02:00
// Pandora FMS - http://pandorafms.com
// ==================================================
2020-11-27 13:52:35 +01:00
// Copyright (c) 2005-2021 Artica Soluciones Tecnologicas
2009-06-08 20:15:58 +02:00
// Please see http://pandorafms.org for full contribution list
2006-07-09 16:20:10 +02:00
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License
2008-08-22 20:07:32 +02:00
// as published by the Free Software Foundation for version 2.
2006-07-09 16:20:10 +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.
2021-05-06 17:08:11 +02:00
// Load global vars.
2010-03-02 Sancho Lerena <slerena@artica.es>
* include/functions_reporting.php: Solved issue with several undefined
vars.
* include/functions_servers.php: Solved issue with several undefined
vars.
* include/functions_config.php: Added metaconsola witch to readconfig.
* include/config_process.php: Update build.. is YYMMDD !
* include/functions_ui.php: Removed deprecated call to split and replaced
by preg_split.
* index.php: Activated developer mode.
* operation/agentes/estado_monitores.php: Solved small problem with modules
without history, filling missing column in table. Added headers
* godmode/alerts/configure_alert_compound.php,
operation/agentes/status_monitor.php
godmode/alerts/configure_alert_template.php,
godmode/alerts/alert_templates.php,
godmode/alerts/configure_alert_action.php,
godmode/alerts/configure_alert_command.php,
godmode/alerts/alert_actions.php,
godmode/alerts/alert_commands.php,
godmode/modules/manage_network_templates.php,
godmode/modules/module_list.php,
godmode/modules/manage_network_components.php,
godmode/modules/manage_nc_groups.php: Removed deprecated call to include
config.php and in some cases, added new header style.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@2444 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2010-03-02 15:13:00 +01:00
global $config ;
2008-04-17 17:27:25 +02:00
2008-07-21 14:23:28 +02:00
check_login ();
2006-03-27 05:37:27 +02:00
2019-01-30 16:18:44 +01:00
if ( ! check_acl ( $config [ 'id_user' ], 0 , 'AR' )
&& ! check_acl ( $config [ 'id_user' ], 0 , 'AW' )
&& ! check_acl ( $config [ 'id_user' ], 0 , 'AM' )
) {
db_pandora_audit (
'ACL Violation' ,
'Trying to access Agent Management'
);
include 'general/noaccess.php' ;
return ;
2008-01-10 17:40:00 +01:00
}
2006-03-27 05:37:27 +02:00
2019-01-30 16:18:44 +01:00
require_once $config [ 'homedir' ] . '/include/functions_agents.php' ;
require_once $config [ 'homedir' ] . '/include/functions_modules.php' ;
require_once $config [ 'homedir' ] . '/include/functions_users.php' ;
enterprise_include_once ( 'include/functions_metaconsole.php' );
2012-11-26 19:38:09 +01:00
2019-01-30 16:18:44 +01:00
$isFunctionPolicies = enterprise_include_once ( 'include/functions_policies.php' );
* include/functions_graph.php
include/functions_html.php
include/functions_messages.php
include/db/postgresql.php
include/db/mysql.php
include/db/oracle.php
include/functions_reporting.php
include/functions_filemanager.php
include/functions_gis.php
include/auth/ldap.php
include/auth/mysql.php
include/functions_networkmap.php
include/functions_network_components.php
include/ajax/skins.ajax.php
include/ajax/reporting.ajax.php
include/ajax/visual_console_builder.ajax.php
include/ajax/alert_list.ajax.php
include/ajax/module.php
include/functions_config.php
include/functions_api.php
include/help/en/help_timesource.php
include/help/es/help_timesource.php
include/help/ja/help_timesource.php
include/config_process.php
include/functions_ui.php
include/functions_custom_graphs.php
include/fgraph.php
include/functions_incidents.php
include/api.php
include/functions_reports.php
include/functions_ui_renders.php
extensions/insert_data.php
extensions/system_info.php
extensions/extension_uploader.php
extensions/pandora_logs.php
extensions/agents_modules.php
extensions/update_manager.php
extensions/ssh_console.php
extensions/dbmanager.php
extensions/vnc_view.php
extensions/resource_registration.php
extensions/resource_exportation.php
extensions/users_connected.php
extensions/module_groups.php
extensions/update_manager/load_updatemanager.php
extensions/update_manager/lib/libupdate_manager_client.php
extensions/update_manager/lib/libupdate_manager.php
extensions/update_manager/lib/libupdate_manager_components.php
extensions/update_manager/lib/libupdate_manager_updates.php
extensions/update_manager/settings.php
extensions/update_manager/main.php
extensions/plugin_registration.php
operation/incidents/incident.php
operation/incidents/incident_detail.php
operation/incidents/incident_statistics.php
operation/search_modules.php
operation/visual_console/render_view.php
operation/visual_console/index.php
operation/extensions.php
operation/agentes/status_monitor.php
operation/agentes/export_csv.php
operation/agentes/estado_ultimopaquete.php
operation/agentes/datos_agente.php
operation/agentes/alerts_status.php
operation/agentes/estado_generalagente.php
operation/agentes/custom_fields.php
operation/agentes/estado_agente.php
operation/agentes/networkmap.topology.php
operation/agentes/networkmap.groups.php
operation/agentes/sla_view.php
operation/agentes/exportdata.php
operation/agentes/gis_view.php
operation/agentes/estado_monitores.php
operation/agentes/ver_agente.php
operation/agentes/graphs.php
operation/agentes/agent_fields.php
operation/agentes/tactical.php
operation/agentes/group_view.php
operation/agentes/networkmap.php
operation/agentes/stat_win.php
operation/servers/view_server.php
operation/servers/view_server_detail.php
operation/menu.php
operation/search_agents.php
operation/search_graphs.php
operation/snmpconsole/snmp_view.php
operation/users/user_edit.php
operation/gis_maps/render_view.php
operation/gis_maps/ajax.php
operation/integria_incidents/incident.php
operation/integria_incidents/incident_detail.php
operation/integria_incidents/incident_statistics.php
operation/events/event_statistics.php
operation/events/events_rss.php
operation/events/export_csv.php
operation/events/sound_events.php
operation/events/events_validate.php
operation/events/events_list.php
operation/events/events_marquee.php
operation/events/events.php
operation/search_alerts.php
operation/messages/message.php
operation/reporting/reporting_xml.php
operation/reporting/reporting_viewer.php
operation/reporting/graph_viewer.php
operation/search_reports.php
operation/search_maps.php
operation/search_users.php
extras/pandora_diag.php
mobile/operation/agents/monitor_status.php
mobile/operation/agents/view_agents.php
mobile/operation/agents/view_alerts.php
mobile/operation/agents/group_view.php
mobile/operation/events/events.php
mobile/index.php
general/error_authconfig.php
general/links_menu.php
general/logon_ok.php
general/error_dbconfig.php
general/ui/agents_list.php
general/header.php
godmode/groups/modu_group_list.php
godmode/groups/configure_group.php
godmode/groups/configure_modu_group.php
godmode/groups/group_list.php
godmode/admin_access_logs.php
godmode/db/db_main.php
godmode/db/db_audit.php
godmode/db/db_sanity.php
godmode/db/db_refine.php
godmode/db/db_info.php
godmode/db/db_event.php
godmode/db/db_purge.php
godmode/extensions.php
godmode/agentes/agent_template.php
godmode/agentes/module_manager_editor_common.php
godmode/agentes/fields_manager.php
godmode/agentes/agent_conf_gis.php
godmode/agentes/module_manager_editor_prediction.php
godmode/agentes/module_manager.php
godmode/agentes/modificar_agente.php
godmode/agentes/configurar_agente.php
godmode/agentes/configure_field.php
godmode/agentes/module_manager_editor.php
godmode/agentes/planned_downtime.php
godmode/agentes/manage_config_remote.php
godmode/agentes/agent_manager.php
godmode/servers/recon_script.php
godmode/servers/plugin.php
godmode/servers/manage_recontask.php
godmode/servers/modificar_server.php
godmode/servers/manage_recontask_form.php
godmode/alerts/alert_list.list.php
godmode/alerts/configure_alert_compound.php
godmode/alerts/alert_compounds.php
godmode/alerts/alert_list.php
godmode/alerts/configure_alert_template.php
godmode/alerts/alert_templates.php
godmode/alerts/configure_alert_action.php
godmode/alerts/configure_alert_command.php
godmode/alerts/alert_actions.php
godmode/alerts/alert_list.builder.php
godmode/alerts/alert_commands.php
godmode/setup/file_manager.php
godmode/setup/os.list.php
godmode/setup/news.php
godmode/setup/gis_step_2.php
godmode/setup/links.php
godmode/setup/setup.php
godmode/setup/os.php
godmode/setup/performance.php
godmode/setup/setup_auth.php
godmode/setup/gis.php
godmode/setup/os.builder.php
godmode/setup/setup_visuals.php
godmode/snmpconsole/snmp_alert.php
godmode/snmpconsole/snmp_filters.php
godmode/users/user_list.php
godmode/users/configure_profile.php
godmode/gis_maps/configure_gis_map.php
godmode/gis_maps/index.php
godmode/massive/massive_add_alerts.php
godmode/massive/massive_copy_modules.php
godmode/massive/massive_delete_agents.php
godmode/massive/massive_enable_disable_alerts.php
godmode/massive/massive_operations.php
godmode/massive/massive_delete_profiles.php
godmode/massive/massive_edit_agents.php
godmode/massive/massive_delete_action_alerts.php
godmode/massive/massive_delete_modules.php
godmode/massive/massive_add_profiles.php
godmode/massive/massive_delete_alerts.php
godmode/massive/massive_edit_modules.php
godmode/massive/massive_standby_alerts.php
godmode/massive/massive_add_action_alerts.php
godmode/modules/manage_network_components_form.php
godmode/modules/manage_nc_groups_form.php
godmode/modules/manage_network_templates.php
godmode/modules/module_list.php
godmode/modules/manage_network_components_form_common.php
godmode/modules/manage_network_components_form_network.php
godmode/modules/manage_network_templates_form.php
godmode/modules/manage_network_components_form_wmi.php
godmode/modules/manage_network_components.php
godmode/modules/manage_nc_groups.php
godmode/reporting/visual_console_builder.wizard.php
godmode/reporting/graph_builder.main.php
godmode/reporting/reporting_builder.list_items.php
godmode/reporting/visual_console_builder.php
godmode/reporting/reporting_builder.preview.php
godmode/reporting/reporting_builder.main.php
godmode/reporting/visual_console_builder.data.php
godmode/reporting/visual_console_builder.elements.php
godmode/reporting/graph_builder.php
godmode/reporting/visual_console_builder.preview.php
godmode/reporting/graph_builder.graph_editor.php
godmode/reporting/reporting_builder.php
godmode/reporting/visual_console_builder.editor.php
godmode/reporting/reporting_builder.item_editor.php
godmode/reporting/map_builder.php
godmode/reporting/graphs.php
godmode/reporting/graph_builder.preview.php
include/functions_db.php: Added some includes and functions of this code have "db_" prefix.
* include/functions.php: Moved function check_login(), check_acl(),
dame_nombre_pluginid(), get_os_name() from functions_db.php to functions.php.
* include/functions_groups.php: Moved functions get_childrens(), safe_acl_group()
and get_parents(), give_disabled_group(), isAllGroups(), get_group_icon(), get_all_groups(),
get_id_groups_recursive(), get_user_groups_tree_recursive(), get_group_status(),
get_group_name(), get_group_users() from functions_db.php to this code.
* include/functions_profile.php: New library with profile functions. Moved functions
get_profile_name(), get_profiles(), create_user_profile(), delete_user_profile(),
delete_profile() from functions_db.php to this code. Added new parameter in function
get_profile() to retrieve profiles with filter conditions applied.
* include/functions_users.php: New library with users functions. Moved functions
get_users_info(), get_all_model_groups(), get_user_groups(), get_user_groups_tree(),
get_user_first_group(), user_access_to_agent() from funtions_db.php to this code.
* godmode/users/configure_user.php: Changed get_profile_filter() function to get_profile().
* include/functions_agents.php: Moved functions get_group_agents(), get_agent_modules(),
get_agent_module_id(), get_agent_id(), get_agent_name(), get_agent_modules_data_count(),
check_alert_fired(), get_agent_interval(), get_agent_os(), give_agentmodule_flag(),
agent_add_address(), agent_delete_address(), get_agent_address(), get_agent_with_ip(),
get_agent_addresses(), get_agent_status(), delete_agent(), get_agentmodule_group(),
get_agent_group() from functions_db.php to this code.
* include/functions_modules.php: Moved functions get_agentmodule(), get_agentmodule_id(),
get_agentmodule_is_init(), get_agent_modules_count(), get_module_type_name(),
get_module_type_icon(), get_agentmodule_agent(), get_agentmodule_agent_name(),
get_agentmodule_name(), get_agentmodule_type(), get_monitor_downs_in_period(),
get_monitor_last_down_timestamp_in_period(), get_monitors_in_group(),
get_monitors_in_agent(), get_monitors_down(), get_moduletype_name(),
get_moduletype_description(), get_moduletypes(), get_module_interval(), show_icon_type(),
give_modulecategory_name(),
give_agent_id_from_module_id(), get_module_status(), get_agent_module_last_value(),
get_previous_data(), get_agentmodule_modulegroup(), get_modulegroups(),
get_modulegroup_name() from functions_db.php to this code.
* include/functions_alerts.php: Moved functions get_alert_type(), get_agent_alert_fired(),
get_module_alert_fired(), get_alert_fires_in_period(), get_group_alerts(), get_alerts_fired(),
get_alert_last_fire_timestamp_in_period(), get_agentmodule_status(),
get_agentmodule_last_status() from functions_db.php to this code.
* include/functions_exportserver.php: Moved function dame_nombre_servidorexportacion()
from functions_db.php to this code.
* include/functions_events.php: Moved functions get_group_events(), get_agent_events(),
get_module_events() from functions_db.php to this code.
* include/functions_servers.php: Moved functions get_server_name(), show_server_type(),
check_server_status(), server_status() from functions_db.php to this code.
* include/functions_network_profiles.php: Moved function get_networkprofile_name()
from functions_db.php to this code.
* include/functions_visual_map.php: Moved functions get_layoutdata_x(), get_layoutdata_y()
from fucntions_db.php to this code.
* include/functions_io.php: Moved function __() from functions_db.php to this code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4258 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-04-19 20:42:49 +02:00
2019-01-30 16:18:44 +01:00
if ( ! defined ( 'METACONSOLE' )) {
2019-02-25 14:42:48 +01:00
$section = ( string ) get_parameter ( 'section' , 'view' );
2019-02-15 14:22:55 +01:00
2019-02-25 14:42:48 +01:00
$buttons [ 'fields' ] = [
'active' => false ,
2021-03-11 15:40:23 +01:00
'text' => '<a href="index.php?sec=view&sec2=operation/agentes/status_monitor§ion=fields">' . html_print_image (
'images/custom_columns.png' ,
true ,
[
'title' => __ ( 'Custom fields' ),
'class' => 'invert_filter' ,
]
) . '</a>' ,
2019-02-25 14:42:48 +01:00
'operation' => true ,
];
2019-02-15 14:22:55 +01:00
2019-02-25 14:42:48 +01:00
$buttons [ 'view' ] = [
'active' => false ,
2021-03-11 15:40:23 +01:00
'text' => '<a href="index.php?sec=view&sec2=operation/agentes/status_monitor">' . html_print_image (
'images/list.png' ,
true ,
[
'title' => __ ( 'View' ),
'class' => 'invert_filter' ,
]
) . '</a>' ,
2019-02-25 14:42:48 +01:00
'operation' => true ,
];
2019-02-15 14:22:55 +01:00
switch ( $section ) {
case 'fields' :
$buttons [ 'fields' ][ 'active' ] = true ;
2019-02-25 14:42:48 +01:00
$subpage = ' - ' . __ ( 'Custom fields' );
break ;
2019-02-15 14:22:55 +01:00
default :
$buttons [ 'view' ][ 'active' ] = true ;
2019-02-25 14:42:48 +01:00
break ;
2019-02-15 14:22:55 +01:00
}
2019-01-18 11:13:29 +01:00
2020-05-29 11:37:06 +02:00
ui_print_page_header (
__ ( 'Monitor detail' ) . $subpage ,
'' ,
false ,
'' ,
true ,
$buttons
);
2019-01-18 11:13:29 +01:00
2019-02-25 14:42:48 +01:00
if ( $section == 'fields' ) {
include_once $config [ 'homedir' ] . '/godmode/agentes/status_monitor_custom_fields.php' ;
exit ();
}
2019-01-30 16:18:44 +01:00
} else {
2020-11-26 12:28:12 +01:00
$section = ( string ) get_parameter ( 'sec' , 'estado' );
2019-01-30 16:18:44 +01:00
ui_meta_print_header ( __ ( 'Monitor view' ));
2012-11-26 19:38:09 +01:00
}
2008-01-10 17:40:00 +01:00
2020-10-29 12:55:44 +01:00
$recursion = get_parameter_switch ( 'recursion' , false );
if ( $recursion === false ) {
$recursion = get_parameter ( 'recursion' , false );
}
$ag_freestring = ( string ) get_parameter ( 'ag_freestring' );
$moduletype = ( string ) get_parameter ( 'moduletype' );
$datatype = ( string ) get_parameter ( 'datatype' );
$ag_modulename = ( string ) get_parameter ( 'ag_modulename' );
$refr = ( int ) get_parameter ( 'refr' , 0 );
$offset = ( int ) get_parameter ( 'offset' , 0 );
$status = ( int ) get_parameter ( 'status' , 4 );
$modulegroup = ( int ) get_parameter ( 'modulegroup' , - 1 );
$tag_filter = ( int ) get_parameter ( 'tag_filter' , 0 );
$min_hours_status = ( string ) get_parameter ( 'min_hours_status' , '' );
// Sort functionality.
$sortField = get_parameter ( 'sort_field' );
$sort = get_parameter ( 'sort' , 'none' );
// When the previous page was a visualmap and show only one module.
$id_module = ( int ) get_parameter ( 'id_module' , 0 );
$ag_custom_fields = ( array ) get_parameter ( 'ag_custom_fields' , []);
2016-11-17 15:30:37 +01:00
$module_option = ( int ) get_parameter ( 'module_option' , 1 );
2021-05-06 17:08:11 +02:00
$not_condition = ( string ) get_parameter ( 'not_condition' , '' );
// If option not_condition is enabled, the conditions of the queries are reversed.
$condition_query = '=' ;
if ( $not_condition !== '' ) {
$condition_query = '!=' ;
}
2019-03-06 17:25:36 +01:00
$autosearch = false ;
2021-05-06 17:08:11 +02:00
// It is validated if it receives parameters different from those it has by default.
2019-03-06 17:25:36 +01:00
if ( $ag_freestring !== '' || $moduletype !== '' || $datatype !== ''
|| $ag_modulename !== '' || $refr !== 0 || $offset !== 0 || $status !== 4
|| $modulegroup !== - 1 || $tag_filter !== 0 || $sortField !== ''
|| $sort !== 'none' || $id_module !== 0 || $module_option !== 1
2020-03-23 12:47:58 +01:00
|| $min_hours_status !== ''
2019-03-06 17:25:36 +01:00
) {
$autosearch = true ;
}
2016-10-17 12:30:52 +02:00
if ( ! is_metaconsole ()) {
2019-01-30 16:18:44 +01:00
$ag_group = ( int ) get_parameter ( 'ag_group' , 0 );
} else {
$ag_group = get_parameter ( 'ag_group' , 0 );
$ag_group_metaconsole = $ag_group ;
2013-10-14 14:36:41 +02:00
}
2016-10-17 12:30:52 +02:00
$ag_custom_fields_params = '' ;
2014-04-14 15:18:20 +02:00
if ( ! empty ( $ag_custom_fields )) {
2019-01-30 16:18:44 +01:00
foreach ( $ag_custom_fields as $id => $value ) {
if ( ! empty ( $value )) {
$ag_custom_fields_params .= '&ag_custom_fields[' . $id . ']=' . $value ;
}
}
2014-04-14 15:18:20 +02:00
}
2019-01-30 16:18:44 +01:00
2013-06-24 15:43:49 +02:00
if ( $id_module ) {
2019-01-30 16:18:44 +01:00
$status = - 1 ;
$ag_modulename = modules_get_agentmodule_name ( $id_module );
$ag_freestring = modules_get_agentmodule_agent_alias ( $id_module );
2013-06-24 15:43:49 +02:00
}
2013-05-20 10:42:02 +02:00
enterprise_hook ( 'open_meta_frame' );
2015-03-11 11:31:46 +01:00
2021-05-06 17:08:11 +02:00
// Get Groups and profiles from user.
2019-01-30 16:18:44 +01:00
$user_groups = implode ( ',' , array_keys ( users_get_groups ( false , 'AR' , false )));
2013-01-10 17:00:30 +01:00
2021-05-06 17:08:11 +02:00
// Begin Build SQL sentences.
2019-01-30 16:18:44 +01:00
$sql_from = ' FROM tagente_modulo
2018-09-27 12:46:45 +02:00
INNER JOIN tagente
ON tagente_modulo . id_agente = tagente . id_agente
LEFT JOIN tagent_secondary_group tasg
ON tagente . id_agente = tasg . id_agent
INNER JOIN tagente_estado
ON tagente_estado . id_agente_modulo = tagente_modulo . id_agente_modulo
INNER JOIN tmodule
ON tmodule . id_module = tagente_modulo . id_modulo
INNER JOIN ttipo_modulo
ON tagente_modulo . id_tipo_modulo = ttipo_modulo . id_tipo
LEFT JOIN ttag_module
2019-01-30 16:18:44 +01:00
ON tagente_modulo . id_agente_modulo = ttag_module . id_agente_modulo ' ;
2018-09-27 12:46:45 +02:00
$sql_conditions = ' WHERE tagente.disabled = 0' ;
2013-02-18 14:46:28 +01:00
2014-07-23 18:59:05 +02:00
if ( is_numeric ( $ag_group )) {
2019-01-30 16:18:44 +01:00
$id_ag_group = 0 ;
} else {
$id_ag_group = db_get_value ( 'id_grupo' , 'tgrupo' , 'nombre' , $ag_group );
2014-07-23 18:59:05 +02:00
}
2013-11-12 13:38:13 +01:00
2021-05-06 17:08:11 +02:00
// Agent group selector.
2016-08-24 15:31:28 +02:00
if ( ! is_metaconsole ()) {
2019-01-30 16:18:44 +01:00
if ( $ag_group > 0 && check_acl ( $config [ 'id_user' ], $ag_group , 'AR' )) {
2020-10-29 12:55:44 +01:00
if ( $recursion ) {
$all_groups = groups_get_children_ids ( $ag_group , true );
// User has explicit permission on group 1 ?
$sql_conditions_group = sprintf (
' AND (tagente.id_grupo IN (%s) OR tasg.id_group IN (%s)) ' ,
implode ( ',' , $all_groups ),
implode ( ',' , $all_groups )
);
} else {
$sql_conditions_group = sprintf (
2021-05-06 17:08:11 +02:00
' AND (tagente.id_grupo ' . $condition_query . ' %d OR tasg.id_group ' . $condition_query . ' %d)' ,
2020-10-29 12:55:44 +01:00
$ag_group ,
$ag_group
);
}
2019-01-30 16:18:44 +01:00
} else if ( $user_groups != '' ) {
// User has explicit permission on group 1 ?
$sql_conditions_group = ' AND (
2018-04-09 18:56:05 +02:00
tagente . id_grupo IN ( '.$user_groups.' )
OR tasg . id_group IN ( '.$user_groups.' )
) ' ;
2019-01-30 16:18:44 +01:00
}
} else {
if ((( int ) $ag_group !== 0 ) && ( check_acl ( $config [ 'id_user' ], $id_ag_group , 'AR' ))) {
2020-10-29 12:55:44 +01:00
if ( $recursion ) {
$all_groups = groups_get_children_ids ( $ag_group , true );
// User has explicit permission on group 1 ?
$sql_conditions_group = sprintf (
' AND (tagente.id_grupo IN (%s) OR tasg.id_group IN (%s)) ' ,
implode ( ',' , $all_groups ),
implode ( ',' , $all_groups )
);
} else {
$sql_conditions_group = sprintf (
' AND (tagente.id_grupo IN (%s) OR tasg.id_group IN (%s))' ,
$ag_group ,
$ag_group
);
}
2019-01-30 16:18:44 +01:00
} else if ( $user_groups != '' ) {
// User has explicit permission on group 1 ?
$sql_conditions_group = ' AND (
2018-04-09 19:10:19 +02:00
tagente . id_grupo IN ( '.$user_groups.' )
OR tasg . id_group IN ( '.$user_groups.' )
) ' ;
2019-01-30 16:18:44 +01:00
}
2013-01-10 17:00:30 +01:00
}
2014-07-23 18:59:05 +02:00
2021-05-06 17:08:11 +02:00
// Module group.
2016-08-24 15:31:28 +02:00
if ( is_metaconsole ()) {
2019-01-30 16:18:44 +01:00
if ( $modulegroup != '-1' ) {
2021-05-06 17:08:11 +02:00
$sql_conditions .= sprintf ( ' AND tagente_modulo.id_module_group ' . $not_condition . ' IN (%s)' , $modulegroup );
2019-01-30 16:18:44 +01:00
}
} else if ( $modulegroup > - 1 ) {
2021-05-06 17:08:11 +02:00
$sql_conditions .= sprintf ( ' AND tagente_modulo.id_module_group ' . $condition_query . ' \'%d\'' , $modulegroup );
2013-01-10 17:00:30 +01:00
}
2021-05-06 17:08:11 +02:00
// Module name selector.
2016-08-24 15:31:28 +02:00
if ( $ag_modulename != '' ) {
2021-05-06 17:08:11 +02:00
$sql_conditions .= " AND tagente_modulo.nombre $not_condition LIKE '% " . $ag_modulename . " %' " ;
2013-01-10 17:00:30 +01:00
}
2016-11-16 09:59:48 +01:00
if ( $module_option !== 0 ) {
2019-01-30 16:18:44 +01:00
if ( $module_option == 1 ) {
2021-05-06 17:08:11 +02:00
// Only enabled.
$sql_conditions .= sprintf ( ' AND tagente_modulo.disabled ' . $condition_query . ' 0' );
2019-01-30 16:18:44 +01:00
} else if ( $module_option == 2 ) {
2021-05-06 17:08:11 +02:00
// Only disabled.
$sql_conditions .= sprintf ( ' AND tagente_modulo.disabled ' . $condition_query . ' 1' );
2019-01-30 16:18:44 +01:00
}
2016-11-16 09:59:48 +01:00
}
2016-10-14 18:51:17 +02:00
if ( $datatype != '' ) {
2021-05-06 17:08:11 +02:00
$sql_conditions .= sprintf ( ' AND ttipo_modulo.id_tipo ' . $condition_query . ' ' . $datatype );
2016-10-14 18:51:17 +02:00
}
if ( $moduletype != '' ) {
2021-05-06 17:08:11 +02:00
$sql_conditions .= sprintf ( ' AND tagente_modulo.id_modulo ' . $condition_query . ' ' . $moduletype . '' );
2016-10-14 18:51:17 +02:00
}
2021-05-06 17:08:11 +02:00
// Freestring selector.
2016-08-24 15:31:28 +02:00
if ( $ag_freestring != '' ) {
2021-05-06 17:08:11 +02:00
$sql_conditions .= ' AND (tagente.nombre COLLATE utf8_general_ci ' . $not_condition . ' LIKE \'%%' . $ag_freestring . ' %% \ '
OR tagente . alias COLLATE utf8_general_ci '.$not_condition.' LIKE \ '%%' . $ag_freestring . ' %% \ '
OR tagente_modulo . nombre COLLATE utf8_general_ci '.$not_condition.' LIKE \ '%%' . $ag_freestring . ' %% \ '
OR tagente_modulo . descripcion COLLATE utf8_general_ci '.$not_condition.' LIKE \ '%%' . $ag_freestring . '%%\')' ;
2013-01-10 17:00:30 +01:00
}
2021-05-06 17:08:11 +02:00
// Status selector.
2019-01-30 16:18:44 +01:00
if ( $status == AGENT_MODULE_STATUS_NORMAL ) {
2021-05-06 17:08:11 +02:00
// Normal.
$sql_conditions .= ' AND tagente_estado.estado ' . $condition_query . ' 0
2016-08-24 15:31:28 +02:00
AND ( utimestamp > 0 OR ( tagente_modulo . id_tipo_modulo IN ( 21 , 22 , 23 , 100 ))) ' ;
2019-01-30 16:18:44 +01:00
} else if ( $status == AGENT_MODULE_STATUS_CRITICAL_BAD ) {
2021-05-06 17:08:11 +02:00
// Critical.
$sql_conditions .= ' AND tagente_estado.estado ' . $condition_query . ' 1 AND utimestamp > 0' ;
2019-01-30 16:18:44 +01:00
} else if ( $status == AGENT_MODULE_STATUS_WARNING ) {
2021-05-06 17:08:11 +02:00
// Warning.
$sql_conditions .= ' AND tagente_estado.estado ' . $condition_query . ' 2 AND utimestamp > 0' ;
2019-01-30 16:18:44 +01:00
} else if ( $status == AGENT_MODULE_STATUS_NOT_NORMAL ) {
2021-05-06 17:08:11 +02:00
// Not normal.
2019-01-30 16:18:44 +01:00
$sql_conditions .= ' AND tagente_estado.estado <> 0' ;
} else if ( $status == AGENT_MODULE_STATUS_UNKNOWN ) {
2021-05-06 17:08:11 +02:00
// Unknown.
$sql_conditions .= ' AND tagente_estado.estado ' . $condition_query . ' 3 AND tagente_estado.utimestamp <> 0' ;
2019-01-30 16:18:44 +01:00
} else if ( $status == AGENT_MODULE_STATUS_NOT_INIT ) {
2021-05-06 17:08:11 +02:00
// Not init.
$sql_conditions .= ' AND tagente_estado.utimestamp ' . $condition_query . ' 0
2016-08-24 15:31:28 +02:00
AND tagente_modulo . id_tipo_modulo NOT IN ( 21 , 22 , 23 , 100 ) ' ;
2013-01-10 17:00:30 +01:00
}
2020-03-23 12:47:58 +01:00
if ( ! empty ( $min_hours_status )) {
$date = new DateTime ( null , new DateTimeZone ( $config [ 'timezone' ]));
$current_timestamp = $date -> getTimestamp ();
$max_time = ( $current_timestamp - (( int ) $min_hours_status * 3600 ));
$sql_conditions .= sprintf ( ' AND tagente_estado.last_status_change < %d' , $max_time );
}
2021-05-06 17:08:11 +02:00
// Filter by agent custom fields.
2019-01-30 16:18:44 +01:00
$sql_conditions_custom_fields = '' ;
2014-04-14 15:18:20 +02:00
if ( ! empty ( $ag_custom_fields )) {
2019-01-30 16:18:44 +01:00
$cf_filter = [];
foreach ( $ag_custom_fields as $field_id => $value ) {
if ( ! empty ( $value )) {
2021-05-06 17:08:11 +02:00
$cf_filter [] = '(tagent_custom_data.id_field ' . $condition_query . ' ' . $field_id . ' AND tagent_custom_data.description ' . $not_condition . ' LIKE \'%' . $value . '%\')' ;
2019-01-30 16:18:44 +01:00
}
}
2014-04-14 15:18:20 +02:00
2019-01-30 16:18:44 +01:00
if ( ! empty ( $cf_filter )) {
$sql_conditions_custom_fields = ' AND tagente . id_agente IN (
2014-04-14 15:18:20 +02:00
SELECT tagent_custom_data . id_agent
FROM tagent_custom_data
2019-01-30 16:18:44 +01:00
WHERE '.implode(' AND ', $cf_filter).' ) ' ;
}
2014-04-14 15:18:20 +02:00
}
2021-05-06 17:08:11 +02:00
// Filter by tag.
2013-01-10 17:00:30 +01:00
if ( $tag_filter !== 0 ) {
2019-01-30 16:18:44 +01:00
if ( is_metaconsole ()) {
2021-05-06 17:08:11 +02:00
$sql_conditions .= ' AND tagente_modulo.id_agente_modulo ' . $not_condition . ' IN (
2013-03-26 18:15:49 +01:00
SELECT ttag_module . id_agente_modulo
FROM ttag_module
2021-05-06 17:08:11 +02:00
WHERE ttag_module . id_tag '.$not_condition.' IN ( '.$tag_filter.' )) ' ;
2019-01-30 16:18:44 +01:00
} else {
2021-05-06 17:08:11 +02:00
$sql_conditions .= ' AND tagente_modulo.id_agente_modulo ' . $not_condition . ' IN (
2013-03-26 18:15:49 +01:00
SELECT ttag_module . id_agente_modulo
FROM ttag_module
2021-05-06 17:08:11 +02:00
WHERE ttag_module . id_tag '.$condition_query.' '.$tag_filter.' ) ' ;
2019-01-30 16:18:44 +01:00
}
2013-01-10 17:00:30 +01:00
}
2016-10-14 18:51:17 +02:00
2021-05-06 17:08:11 +02:00
// Apply the module ACL with tags.
2015-10-01 16:18:45 +02:00
$sql_conditions_tags = '' ;
2016-10-17 12:30:52 +02:00
2015-10-01 16:18:45 +02:00
if ( ! users_is_admin ()) {
2019-01-30 16:18:44 +01:00
$sql_conditions_tags = tags_get_acl_tags (
$config [ 'id_user' ],
$ag_group ,
'AR' ,
'module_condition' ,
'AND' ,
'tagente_modulo' ,
true ,
[],
false
);
if ( is_numeric ( $sql_conditions_tags )) {
$sql_conditions_tags = ' AND 1 = 0' ;
}
2013-06-07 14:28:20 +02:00
}
2021-05-06 17:08:11 +02:00
// Two modes of filter. All the filters and only ACLs filter.
2019-01-30 16:18:44 +01:00
$sql_conditions_all = $sql_conditions . $sql_conditions_group . $sql_conditions_tags . $sql_conditions_custom_fields ;
2013-01-10 17:00:30 +01:00
2021-05-06 17:08:11 +02:00
// Get count to paginate.
2019-01-30 16:18:44 +01:00
if ( ! defined ( 'METACONSOLE' )) {
$count = db_get_sql ( 'SELECT COUNT(DISTINCT tagente_modulo.id_agente_modulo)' . $sql_from . $sql_conditions_all );
}
2013-01-10 17:00:30 +01:00
2021-05-06 17:08:11 +02:00
// Get limit_sql depend of the metaconsole or standard mode.
2016-08-24 15:31:28 +02:00
if ( is_metaconsole ()) {
2021-05-06 17:08:11 +02:00
// Offset will be used to get the subset of modules.
2019-01-30 16:18:44 +01:00
$inferior_limit = $offset ;
$superior_limit = ( $config [ 'block_size' ] + $offset );
2021-05-06 17:08:11 +02:00
// Offset reset to get all elements.
2019-01-30 16:18:44 +01:00
$offset = 0 ;
if ( ! isset ( $config [ 'meta_num_elements' ])) {
$config [ 'meta_num_elements' ] = 100 ;
}
$limit_sql = $config [ 'meta_num_elements' ];
} else {
$limit_sql = $config [ 'block_size' ];
2013-01-10 17:00:30 +01:00
}
2021-05-06 17:08:11 +02:00
// End Build SQL sentences.
2019-01-30 16:18:44 +01:00
//
2021-05-06 17:08:11 +02:00
// Start Build Search Form.
2019-01-30 16:18:44 +01:00
//
2016-08-24 15:31:28 +02:00
$table = new StdClass ();
$table -> width = '100%' ;
$table -> cellspacing = 0 ;
$table -> cellpadding = 0 ;
$table -> class = 'databox filters' ;
2015-07-01 11:27:37 +02:00
$table -> style [ 0 ] = 'font-weight: bold;' ;
$table -> style [ 1 ] = 'font-weight: bold;' ;
$table -> style [ 2 ] = 'font-weight: bold;' ;
$table -> style [ 3 ] = 'font-weight: bold;' ;
$table -> style [ 4 ] = 'font-weight: bold;' ;
2015-03-11 11:31:46 +01:00
$table -> data [ 0 ][ 0 ] = __ ( 'Group' );
2020-10-29 12:55:44 +01:00
$table -> data [ 0 ][ 1 ] = '<div class="flex flex-row-vcenter w290px"><div class="w200px">' ;
$table -> data [ 0 ][ 1 ] .= html_print_select_groups (
2019-01-30 16:18:44 +01:00
$config [ 'id_user' ],
'AR' ,
true ,
'ag_group' ,
$ag_group ,
'' ,
'' ,
'0' ,
true ,
false ,
false ,
'' ,
false ,
'' ,
false ,
false ,
'id_grupo' ,
false
);
2020-10-29 12:55:44 +01:00
$table -> data [ 0 ][ 1 ] .= '</div><div>' ;
$table -> data [ 0 ][ 1 ] .= html_print_input (
[
'type' => 'checkbox' ,
'name' => 'recursion' ,
'return' => true ,
'checked' => $recursion ,
'value' => 1 ,
]
);
$table -> data [ 0 ][ 1 ] .= __ ( 'Recursion' );
$table -> data [ 0 ][ 1 ] .= '</div></div>' ;
2019-01-30 16:18:44 +01:00
$fields = [];
2015-06-08 13:13:09 +02:00
$fields [ AGENT_MODULE_STATUS_NORMAL ] = __ ( 'Normal' );
2013-03-26 18:15:49 +01:00
$fields [ AGENT_MODULE_STATUS_WARNING ] = __ ( 'Warning' );
$fields [ AGENT_MODULE_STATUS_CRITICAL_BAD ] = __ ( 'Critical' );
2013-07-24 13:06:24 +02:00
$fields [ AGENT_MODULE_STATUS_UNKNOWN ] = __ ( 'Unknown' );
2019-01-30 16:18:44 +01:00
$fields [ AGENT_MODULE_STATUS_NOT_NORMAL ] = __ ( 'Not normal' );
2021-05-06 17:08:11 +02:00
// Default.
2013-03-26 18:15:49 +01:00
$fields [ AGENT_MODULE_STATUS_NOT_INIT ] = __ ( 'Not init' );
2012-11-29 18:34:51 +01:00
2016-10-17 12:30:52 +02:00
$table -> data [ 0 ][ 2 ] = __ ( 'Monitor status' );
2019-01-30 16:18:44 +01:00
$table -> data [ 0 ][ 3 ] = html_print_select (
$fields ,
'status' ,
$status ,
'' ,
__ ( 'All' ),
- 1 ,
true ,
false ,
true ,
'' ,
false ,
'width: 150px;'
);
$rows_select = [];
2016-10-17 12:30:52 +02:00
$table -> data [ 0 ][ 4 ] = __ ( 'Module group' );
2016-08-24 15:31:28 +02:00
$rows_select [ 0 ] = __ ( 'Not assigned' );
if ( ! is_metaconsole ()) {
2019-01-30 16:18:44 +01:00
$rows = db_get_all_rows_sql (
' SELECT *
FROM tmodule_group ORDER BY name '
);
$rows = io_safe_output ( $rows );
if ( ! empty ( $rows )) {
foreach ( $rows as $module_group ) {
$rows_select [ $module_group [ 'id_mg' ]] = $module_group [ 'name' ];
}
}
} else {
$rows_select = modules_get_modulegroups ();
2016-09-12 11:54:54 +02:00
}
2019-01-30 16:18:44 +01:00
2016-09-12 11:54:54 +02:00
$table -> data [ 0 ][ 5 ] = html_print_select ( $rows_select , 'modulegroup' , $modulegroup , '' , __ ( 'All' ), - 1 , true , false , true , '' , false , 'width: 120px;' );
2015-03-11 11:31:46 +01:00
2019-06-04 13:57:55 +02:00
$table -> rowspan [ 0 ][ 6 ] = 3 ;
2019-01-30 16:18:44 +01:00
$table -> data [ 0 ][ 6 ] = html_print_submit_button (
__ ( 'Show' ),
'uptbutton' ,
false ,
2021-03-11 15:40:23 +01:00
'class="sub search mgn_tp_0"' ,
2019-01-30 16:18:44 +01:00
true
);
2018-10-02 11:12:10 +02:00
2015-03-11 11:31:46 +01:00
$table -> data [ 1 ][ 0 ] = __ ( 'Module name' );
2019-01-30 16:18:44 +01:00
$table -> data [ 1 ][ 1 ] = html_print_autocomplete_modules (
'ag_modulename' ,
$ag_modulename ,
false ,
true ,
'' ,
[],
true
);
2012-11-04 20:10:19 +01:00
2015-06-12 15:50:46 +02:00
$table -> data [ 1 ][ 2 ] = __ ( 'Search' );
2019-01-30 16:18:44 +01:00
$table -> data [ 1 ][ 3 ] = html_print_input_text ( 'ag_freestring' , $ag_freestring , '' , 20 , 30 , true );
2012-11-04 20:10:19 +01:00
2019-01-30 16:18:44 +01:00
$table -> data [ 1 ][ 4 ] = __ ( 'Tags' ) . ui_print_help_tip ( __ ( 'Only it is show tags in use.' ), true );
2013-01-10 17:00:30 +01:00
2019-01-30 16:18:44 +01:00
$tags = [];
2015-01-15 18:08:58 +01:00
$tags = tags_get_user_tags ();
2016-10-17 12:30:52 +02:00
if ( empty ( $tags )) {
2019-01-30 16:18:44 +01:00
$table -> data [ 1 ][ 5 ] = __ ( 'No tags' );
} else {
$table -> data [ 1 ][ 5 ] = html_print_select (
$tags ,
'tag_filter' ,
$tag_filter ,
'' ,
__ ( 'All' ),
'' ,
true ,
false ,
true ,
'' ,
false ,
'width: 150px;'
);
2016-10-17 12:30:52 +02:00
}
2015-01-15 15:11:26 +01:00
2016-10-14 18:51:17 +02:00
2019-01-30 16:18:44 +01:00
$network_available = db_get_sql (
' SELECT count ( * )
2016-10-14 18:51:17 +02:00
FROM tserver
2019-01-30 16:18:44 +01:00
WHERE server_type = 1 '
);
2021-05-06 17:08:11 +02:00
// POSTGRESQL AND ORACLE COMPATIBLE.
2019-01-30 16:18:44 +01:00
$wmi_available = db_get_sql (
' SELECT count ( * )
2016-10-14 18:51:17 +02:00
FROM tserver
2019-01-30 16:18:44 +01:00
WHERE server_type = 6 '
);
2021-05-06 17:08:11 +02:00
// POSTGRESQL AND ORACLE COMPATIBLE.
2019-01-30 16:18:44 +01:00
$plugin_available = db_get_sql (
' SELECT count ( * )
2016-10-14 18:51:17 +02:00
FROM tserver
2019-01-30 16:18:44 +01:00
WHERE server_type = 4 '
);
2021-05-06 17:08:11 +02:00
// POSTGRESQL AND ORACLE COMPATIBLE.
2019-01-30 16:18:44 +01:00
$prediction_available = db_get_sql (
' SELECT count ( * )
2016-10-14 18:51:17 +02:00
FROM tserver
2019-01-30 16:18:44 +01:00
WHERE server_type = 5 '
);
2021-05-06 17:08:11 +02:00
// POSTGRESQL AND ORACLE COMPATIBLE.
2019-01-30 16:18:44 +01:00
$wux_available = db_get_sql (
' SELECT count ( * )
2017-11-06 18:45:53 +01:00
FROM tserver
2019-01-30 16:18:44 +01:00
WHERE server_type = 17 '
);
2021-05-06 17:08:11 +02:00
// POSTGRESQL AND ORACLE COMPATIBLE.
// Development mode to use all servers.
2019-01-30 16:18:44 +01:00
if ( $develop_bypass ) {
2016-10-14 18:51:17 +02:00
$network_available = 1 ;
$wmi_available = 1 ;
$plugin_available = 1 ;
$prediction_available = 1 ;
2019-01-30 16:18:44 +01:00
}
2016-10-14 18:51:17 +02:00
2019-01-30 16:18:44 +01:00
$typemodules = [];
$typemodules [ 1 ] = __ ( 'Data server module' );
if ( $network_available ) {
2016-10-14 18:51:17 +02:00
$typemodules [ 2 ] = __ ( 'Network server module' );
2019-01-30 16:18:44 +01:00
}
if ( $plugin_available ) {
2016-10-14 18:51:17 +02:00
$typemodules [ 4 ] = __ ( 'Plugin server module' );
2019-01-30 16:18:44 +01:00
}
if ( $wmi_available ) {
2016-10-14 18:51:17 +02:00
$typemodules [ 6 ] = __ ( 'WMI server module' );
2019-01-30 16:18:44 +01:00
}
if ( $prediction_available ) {
2016-10-14 18:51:17 +02:00
$typemodules [ 5 ] = __ ( 'Prediction server module' );
2019-01-30 16:18:44 +01:00
}
if ( enterprise_installed ()) {
$typemodules [ 7 ] = __ ( 'Web server module' );
if ( $wux_available ) {
$typemodules [ 8 ] = __ ( 'Wux server module' );
2016-10-14 18:51:17 +02:00
}
2019-01-30 16:18:44 +01:00
}
$table -> data [ 2 ][ 0 ] = '<span>' . __ ( 'Server type' ) . '</span>' ;
$table -> data [ 2 ][ 1 ] = html_print_select ( $typemodules , 'moduletype' , $moduletype , '' , __ ( 'All' ), '' , true , false , true , '' , false , 'width: 150px;' );
$monitor_options = [
0 => __ ( 'All' ),
1 => __ ( 'Only enabled' ),
2 => __ ( 'Only disabled' ),
];
2016-10-14 18:51:17 +02:00
2019-01-30 16:18:44 +01:00
$table -> data [ 2 ][ 2 ] = '<span>' . __ ( 'Show monitors...' ) . '</span>' ;
2016-10-14 18:51:17 +02:00
2019-01-30 16:18:44 +01:00
$table -> data [ 2 ][ 3 ] = html_print_select ( $monitor_options , 'module_option' , $module_option , '' , '' , '' , true , false , true , '' , false , 'width: 150px;' );
2016-11-16 09:59:48 +01:00
2020-03-23 12:47:58 +01:00
$min_hours_val = empty ( $min_hours_status ) ? '' : ( int ) $min_hours_status ;
$table -> data [ 2 ][ 4 ] = '<span>' . __ ( 'Min. hours in current status' ) . '</span>' ;
$table -> data [ 2 ][ 5 ] = html_print_input_text ( 'min_hours_status' , $min_hours_val , '' , 12 , 20 , true );
2021-05-06 17:08:11 +02:00
$table -> data [ 3 ][ 0 ] = '<span id="datatypetittle"' ;
2016-11-16 09:59:48 +01:00
2020-03-23 12:47:58 +01:00
$table -> data [ 3 ][ 0 ] .= '>' . __ ( 'Data type' ) . '</span>' ;
2019-01-30 16:18:44 +01:00
2020-03-23 12:47:58 +01:00
$table -> data [ 3 ][ 1 ] .= '<div id="datatypebox">' ;
2019-01-30 16:18:44 +01:00
switch ( $moduletype ) {
case 1 :
$sql = sprintf (
' SELECT id_tipo , descripcion
2016-10-14 18:51:17 +02:00
FROM ttipo_modulo
2021-05-06 17:08:11 +02:00
WHERE categoria '.$not_condition.' IN ( 6 , 7 , 8 , 0 , 1 , 2 , - 1 ) order by descripcion '
2019-01-30 16:18:44 +01:00
);
break ;
case 2 :
$sql = sprintf (
' SELECT id_tipo , descripcion
2016-10-14 18:51:17 +02:00
FROM ttipo_modulo
2021-05-06 17:08:11 +02:00
WHERE categoria '.$not_condition.' between 3 and 5 '
2019-01-30 16:18:44 +01:00
);
break ;
case 4 :
$sql = sprintf (
' SELECT id_tipo , descripcion
2016-10-14 18:51:17 +02:00
FROM ttipo_modulo
2021-05-06 17:08:11 +02:00
WHERE categoria '.$not_condition.' between 0 and 2 '
2019-01-30 16:18:44 +01:00
);
break ;
case 6 :
$sql = sprintf (
' SELECT id_tipo , descripcion
2016-10-14 18:51:17 +02:00
FROM ttipo_modulo
2021-05-06 17:08:11 +02:00
WHERE categoria '.$not_condition.' between 0 and 2 '
2019-01-30 16:18:44 +01:00
);
break ;
case 7 :
$sql = sprintf (
' SELECT id_tipo , descripcion
2016-10-14 18:51:17 +02:00
FROM ttipo_modulo
2021-05-06 17:08:11 +02:00
WHERE categoria '.$condition_query.' 9 '
2019-01-30 16:18:44 +01:00
);
break ;
case 5 :
$sql = sprintf (
' SELECT id_tipo , descripcion
2016-10-14 18:51:17 +02:00
FROM ttipo_modulo
2021-05-06 17:08:11 +02:00
WHERE categoria '.$condition_query.' 0 '
2019-01-30 16:18:44 +01:00
);
break ;
case 8 :
$sql = sprintf (
' SELECT id_tipo , descripcion
2017-11-06 18:45:53 +01:00
FROM ttipo_modulo
2021-05-06 17:08:11 +02:00
WHERE nombre '.$condition_query.' \ 'web_analysis\''
2019-01-30 16:18:44 +01:00
);
break ;
case '' :
$sql = sprintf (
' SELECT id_tipo , descripcion
FROM ttipo_modulo '
);
break ;
2021-05-06 17:08:11 +02:00
default :
// Nothing.
break ;
2019-01-30 16:18:44 +01:00
}
$a = db_get_all_rows_sql ( $sql );
2020-03-23 12:47:58 +01:00
$table -> data [ 3 ][ 1 ] .= '<select id="datatype" name="datatype" ' ;
2019-01-30 16:18:44 +01:00
2020-03-23 12:47:58 +01:00
$table -> data [ 3 ][ 1 ] .= '>' ;
2019-01-30 16:18:44 +01:00
2020-03-23 12:47:58 +01:00
$table -> data [ 3 ][ 1 ] .= '<option name="datatype" value="">' . __ ( 'All' ) . '</option>' ;
2019-01-30 16:18:44 +01:00
foreach ( $a as $valor ) {
2020-03-23 12:47:58 +01:00
$table -> data [ 3 ][ 1 ] .= '<option name="datatype" value="' . $valor [ 'id_tipo' ] . '" ' ;
2019-01-30 16:18:44 +01:00
if ( $valor [ 'id_tipo' ] == $datatype ) {
2020-03-23 12:47:58 +01:00
$table -> data [ 3 ][ 1 ] .= 'selected' ;
2019-01-30 16:18:44 +01:00
}
2020-03-23 12:47:58 +01:00
$table -> data [ 3 ][ 1 ] .= '>' . $valor [ 'descripcion' ] . '</option>' ;
2019-01-30 16:18:44 +01:00
}
2020-03-23 12:47:58 +01:00
$table -> data [ 3 ][ 1 ] .= '</select>' ;
2019-01-30 16:18:44 +01:00
2020-03-23 12:47:58 +01:00
$table -> data [ 3 ][ 1 ] .= '</div>' ;
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
$table -> data [ 3 ][ 1 ] .= '<div class="w120px mrgn_top_20px">' ;
$table -> data [ 3 ][ 1 ] .= html_print_input (
[
'type' => 'checkbox' ,
'name' => 'not_condition' ,
'return' => true ,
'checked' => $check_not_condition ,
'value' => 'NOT' ,
]
);
$table -> data [ 3 ][ 1 ] .= __ ( 'Not condition' ) . ui_print_help_tip ( __ ( 'If this option is enabled, the events that DO NOT comply with this condition will be displayed.' ), true );
$table -> data [ 3 ][ 1 ] .= '</div>' ;
2019-01-30 16:18:44 +01:00
$table_custom_fields = new stdClass ();
$table_custom_fields -> class = 'filters' ;
$table_custom_fields -> width = '100%' ;
2015-07-01 11:27:37 +02:00
2021-05-06 17:08:11 +02:00
if ( is_metaconsole ()) {
$table_custom_fields -> styleTable = 'margin-left:0px; margin-top:15px;' ;
$table_custom_fields -> cellpadding = '0' ;
$table_custom_fields -> cellspacing = '0' ;
}
2019-01-30 16:18:44 +01:00
$table_custom_fields -> style = [];
2021-05-06 17:08:11 +02:00
if ( ! is_metaconsole ()) {
$table_custom_fields -> style [ 0 ] = 'font-weight: bold; width: 150px;' ;
} else {
$table_custom_fields -> style [ 0 ] = 'font-weight: bold;' ;
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
$table_custom_fields -> colspan = [];
$table_custom_fields -> data = [];
2014-04-14 15:18:20 +02:00
2021-05-06 17:08:11 +02:00
$custom_fields = db_get_all_fields_in_table ( 'tagent_custom_fields' );
if ( $custom_fields === false ) {
$custom_fields = [];
}
2014-04-14 15:18:20 +02:00
2021-05-06 17:08:11 +02:00
foreach ( $custom_fields as $custom_field ) {
$row = [];
$row [ 0 ] = $custom_field [ 'name' ];
2019-01-30 16:18:44 +01:00
$custom_field_value = '' ;
2021-05-06 17:08:11 +02:00
if ( ! empty ( $ag_custom_fields )) {
$custom_field_value = $ag_custom_fields [ $custom_field [ 'id_field' ]];
if ( empty ( $custom_field_value )) {
$custom_field_value = '' ;
}
}
$row [ 1 ] = html_print_input_text ( 'ag_custom_fields[' . $custom_field [ 'id_field' ] . ']' , $custom_field_value , '' , 100 , 300 , true );
$table_custom_fields -> data [] = $row ;
2019-01-30 16:18:44 +01:00
}
2021-05-06 17:08:11 +02:00
if ( $not_condition !== '' ) {
$check_not_condition = true ;
}
2019-01-30 16:18:44 +01:00
2014-04-14 15:18:20 +02:00
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
$filters = '<form method="post" action="index.php?sec=' . $section . '&sec2=operation/agentes/status_monitor&refr=' . $refr . '&ag_group=' . $ag_group . '&ag_freestring=' . $ag_freestring . '&module_option=' . $module_option . '&ag_modulename=' . $ag_modulename . '&moduletype=' . $moduletype . '&datatype=' . $datatype . '&status=' . $status . '&sort_field=' . $sortField . '&sort=' . $sort . '&pure=' . $config [ 'pure' ] . $ag_custom_fields_params . '">' ;
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
if ( is_metaconsole ()) {
$table -> colspan [ 4 ][ 0 ] = 7 ;
$table -> cellstyle [ 4 ][ 0 ] = 'padding: 10px;' ;
$table -> data [ 4 ][ 0 ] = ui_toggle (
html_print_table ( $table_custom_fields , true ),
__ ( 'Advanced Options' ),
'' ,
'' ,
true ,
true
);
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
$filters .= html_print_table ( $table , true );
$filters .= '</form>' ;
ui_toggle ( $filters , __ ( 'Show filters' ), '' , '' , false );
} else {
$table -> colspan [ 4 ][ 0 ] = 7 ;
$table -> cellstyle [ 4 ][ 0 ] = 'padding-left: 10px;' ;
$table -> data [ 4 ][ 0 ] = ui_toggle (
html_print_table (
$table_custom_fields ,
true
),
__ ( 'Agent custom fields' ),
'' ,
'' ,
true ,
true ,
'' ,
'white-box-content' ,
'white_table_graph'
);
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
$filters .= html_print_table ( $table , true );
$filters .= '</form>' ;
echo $filters ;
2019-01-30 16:18:44 +01:00
}
2021-05-06 17:08:11 +02:00
unset ( $table );
// End Build Search Form.
//
// Sort functionality.
$selected = true ;
$selectAgentNameUp = false ;
$selectAgentNameDown = false ;
$selectDataTypeUp = false ;
$selectDataTypeDown = false ;
$selectTypeUp = false ;
$selectTypeDown = false ;
$selectModuleNameUp = false ;
$selectModuleNameDown = false ;
$selectIntervalUp = false ;
$selectIntervalDown = false ;
$selectStatusUp = false ;
$selectStatusDown = false ;
$selectDataUp = false ;
$selectDataDown = false ;
$selectTimestampUp = false ;
$selectTimestampDown = false ;
$order = null ;
switch ( $sortField ) {
case 'agent_alias' :
switch ( $sort ) {
case 'up' :
$selectAgentNameUp = $selected ;
$order = [
'field' => 'tagente.alias' ,
'order' => 'ASC' ,
];
break ;
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
case 'down' :
$selectAgentNameDown = $selected ;
$order = [
'field' => 'tagente.alias' ,
'order' => 'DESC' ,
];
break ;
}
2019-01-30 16:18:44 +01:00
break ;
2021-05-06 17:08:11 +02:00
case 'type' :
switch ( $sort ) {
case 'up' :
$selectDataTypeUp = $selected ;
$order = [
'field' => 'tagente_modulo.id_tipo_modulo' ,
'order' => 'ASC' ,
];
break ;
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
case 'down' :
$selectDataTypeDown = $selected ;
$order = [
'field' => 'tagente_modulo.id_tipo_modulo' ,
'order' => 'DESC' ,
];
break ;
}
2019-01-30 16:18:44 +01:00
break ;
2021-05-06 17:08:11 +02:00
case 'moduletype' :
switch ( $sort ) {
case 'up' :
$selectTypeUp = $selected ;
$order = [
'field' => 'tagente_modulo.id_modulo' ,
'order' => 'ASC' ,
];
break ;
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
case 'down' :
$selectTypeDown = $selected ;
$order = [
'field' => 'tagente_modulo.id_modulo' ,
'order' => 'DESC' ,
];
break ;
}
2019-01-30 16:18:44 +01:00
break ;
2021-05-06 17:08:11 +02:00
case 'module_name' :
switch ( $sort ) {
case 'up' :
$selectModuleNameUp = $selected ;
$order = [
'field' => 'tagente_modulo.nombre' ,
'order' => 'ASC' ,
];
break ;
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
case 'down' :
$selectModuleNameDown = $selected ;
$order = [
'field' => 'tagente_modulo.nombre' ,
'order' => 'DESC' ,
];
break ;
}
2019-01-30 16:18:44 +01:00
break ;
2021-05-06 17:08:11 +02:00
case 'interval' :
switch ( $sort ) {
case 'up' :
$selectIntervalUp = $selected ;
$order = [
'field' => 'tagente_modulo.module_interval' ,
'order' => 'ASC' ,
];
break ;
case 'down' :
$selectIntervalDown = $selected ;
$order = [
'field' => 'tagente_modulo.module_interval' ,
'order' => 'DESC' ,
];
break ;
}
2020-03-23 13:19:08 +01:00
break ;
2021-05-06 17:08:11 +02:00
case 'status' :
switch ( $sort ) {
case 'up' :
$selectStatusUp = $selected ;
$order = [
'field' => 'tagente_estado.estado' ,
'order' => 'ASC' ,
];
break ;
case 'down' :
$selectStatusDown = $selected ;
$order = [
'field' => 'tagente_estado.estado' ,
'order' => 'DESC' ,
];
break ;
}
2020-03-23 13:19:08 +01:00
break ;
2021-05-06 17:08:11 +02:00
case 'last_status_change' :
switch ( $sort ) {
case 'up' :
$selectStatusUp = $selected ;
$order = [
'field' => 'tagente_estado.last_status_change' ,
'order' => 'ASC' ,
];
break ;
case 'down' :
$selectStatusDown = $selected ;
$order = [
'field' => 'tagente_estado.last_status_change' ,
'order' => 'DESC' ,
];
break ;
}
2019-01-30 16:18:44 +01:00
break ;
2021-05-06 17:08:11 +02:00
case 'timestamp' :
switch ( $sort ) {
case 'up' :
$selectTimestampUp = $selected ;
$order = [
'field' => 'tagente_estado.utimestamp' ,
'order' => 'ASC' ,
];
break ;
case 'down' :
$selectTimestampDown = $selected ;
$order = [
'field' => 'tagente_estado.utimestamp' ,
'order' => 'DESC' ,
];
break ;
}
2019-01-30 16:18:44 +01:00
break ;
2021-05-06 17:08:11 +02:00
case 'data' :
switch ( $sort ) {
case 'up' :
$selectDataUp = $selected ;
$order = [
'field' => 'tagente_estado.datos' ,
'order' => 'ASC' ,
];
break ;
case 'down' :
$selectDataDown = $selected ;
$order = [
'field' => 'tagente_estado.datos' ,
'order' => 'DESC' ,
];
break ;
}
2019-01-30 16:18:44 +01:00
break ;
2021-05-06 17:08:11 +02:00
default :
$selectAgentNameUp = $selected ;
$selectAgentNameDown = false ;
$selectDataTypeUp = false ;
$selectDataTypeDown = false ;
$selectTypeUp = false ;
$selectTypeDown = false ;
$selectModuleNameUp = false ;
$selectModuleNameDown = false ;
$selectIntervalUp = false ;
$selectIntervalDown = false ;
$selectStatusUp = false ;
$selectStatusDown = false ;
$selectDataUp = false ;
$selectDataDown = false ;
$selectTimestampUp = false ;
$selectTimestampDown = false ;
2019-01-30 16:18:44 +01:00
$order = [
2021-05-06 17:08:11 +02:00
'field' => 'tagente.alias' ,
'order' => 'ASC' ,
2019-01-30 16:18:44 +01:00
];
break ;
}
2021-05-06 17:08:11 +02:00
$sql = ' SELECT
2020-10-29 12:55:44 +01:00
( SELECT GROUP_CONCAT ( ttag . name SEPARATOR \ ' , \ ' )
2018-08-02 13:02:33 +02:00
FROM ttag
WHERE ttag . id_tag IN (
SELECT ttag_module . id_tag
FROM ttag_module
WHERE ttag_module . id_agente_modulo = tagente_modulo . id_agente_modulo ))
AS tags ,
tagente_modulo . id_agente_modulo ,
tagente_modulo . id_modulo ,
tagente . intervalo AS agent_interval ,
tagente . alias AS agent_alias ,
tagente . nombre AS agent_name ,
tagente_modulo . nombre AS module_name ,
tagente_modulo . history_data ,
tagente_modulo . flag AS flag ,
tagente . id_grupo AS id_group ,
tagente . id_agente AS id_agent ,
tagente_modulo . id_tipo_modulo AS module_type ,
tagente_modulo . module_interval ,
tagente_modulo . tcp_send ,
tagente_modulo . ip_target ,
tagente_modulo . snmp_community ,
tagente_modulo . snmp_oid ,
tagente_estado . datos ,
tagente_estado . estado ,
2020-03-23 12:47:58 +01:00
tagente_estado . last_status_change ,
2018-08-02 13:02:33 +02:00
tagente_modulo . min_warning ,
tagente_modulo . max_warning ,
tagente_modulo . str_warning ,
tagente_modulo . unit ,
tagente_modulo . min_critical ,
tagente_modulo . max_critical ,
tagente_modulo . str_critical ,
tagente_modulo . extended_info ,
tagente_modulo . critical_inverse ,
tagente_modulo . warning_inverse ,
tagente_modulo . critical_instructions ,
tagente_modulo . warning_instructions ,
tagente_modulo . unknown_instructions ,
2019-01-30 16:18:44 +01:00
tagente_estado . utimestamp AS utimestamp '.$sql_from.$sql_conditions_all.'
2018-08-02 13:02:33 +02:00
GROUP BY tagente_modulo . id_agente_modulo
2019-01-30 16:18:44 +01:00
ORDER BY '.$order[' field '].' '.$order[' order '].'
LIMIT '.$offset.' , ' . $limit_sql ;
2012-11-29 18:34:51 +01:00
2020-10-29 12:55:44 +01:00
2021-05-06 17:08:11 +02:00
// We do not show the modules until the user searches with the filter.
if ( $autosearch ) {
if ( ! defined ( 'METACONSOLE' )) {
$result = db_get_all_rows_sql ( $sql );
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
if ( $result === false ) {
$result = [];
} else {
ui_pagination ( $count , false , $offset , 0 , false , 'offset' , true );
}
} else {
// For each server defined and not disabled.
$servers = db_get_all_rows_sql (
' SELECT *
2013-03-26 18:15:49 +01:00
FROM tmetaconsole_setup
2019-01-30 16:18:44 +01:00
WHERE disabled = 0 '
2021-05-06 17:08:11 +02:00
);
if ( $servers === false ) {
$servers = [];
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
$result = [];
$count_modules = 0 ;
foreach ( $servers as $server ) {
// If connection was good then retrieve all data server.
if ( metaconsole_connect ( $server ) == NOERR ) {
$connection = true ;
} else {
$connection = false ;
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
$result_server = db_get_all_rows_sql ( $sql );
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
if ( ! empty ( $result_server )) {
// Create HASH login info.
$pwd = $server [ 'auth_token' ];
$auth_serialized = json_decode ( $pwd , true );
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
if ( is_array ( $auth_serialized )) {
$pwd = $auth_serialized [ 'auth_token' ];
$api_password = $auth_serialized [ 'api_password' ];
$console_user = $auth_serialized [ 'console_user' ];
$console_password = $auth_serialized [ 'console_password' ];
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
$user = $config [ 'id_user' ];
$user_rot13 = str_rot13 ( $config [ 'id_user' ]);
$hashdata = $user . $pwd ;
$hashdata = md5 ( $hashdata );
$url_hash = '&' . 'loginhash=auto&' . 'loginhash_data=' . $hashdata . '&' . 'loginhash_user=' . $user_rot13 ;
foreach ( $result_server as $result_element_key => $result_element_value ) {
$result_server [ $result_element_key ][ 'server_id' ] = $server [ 'id' ];
$result_server [ $result_element_key ][ 'server_name' ] = $server [ 'server_name' ];
$result_server [ $result_element_key ][ 'server_url' ] = $server [ 'server_url' ] . '/' ;
$result_server [ $result_element_key ][ 'hashdata' ] = $hashdata ;
$result_server [ $result_element_key ][ 'user' ] = $config [ 'id_user' ];
$result_server [ $result_element_key ][ 'groups_in_server' ] = agents_get_all_groups_agent (
$result_element_value [ 'id_agent' ],
$result_element_value [ 'id_group' ]
);
$count_modules ++ ;
}
$result = array_merge ( $result , $result_server );
}
metaconsole_restore_db ();
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
if ( $count_modules > $config [ 'block_size' ]) {
ui_pagination ( $count_modules , false , $offset );
2019-01-30 16:18:44 +01:00
}
2021-05-06 17:08:11 +02:00
// Get number of elements of the pagination.
$result = ui_meta_get_subset_array ( $result , $inferior_limit , $superior_limit );
2019-01-30 16:18:44 +01:00
}
}
2021-05-06 17:08:11 +02:00
if (( $config [ 'dbtype' ] == 'oracle' ) && ( $result !== false )) {
for ( $i = 0 ; $i < count ( $result ); $i ++ ) {
unset ( $result [ $i ][ 'rnum' ]);
}
2019-01-30 16:18:44 +01:00
}
2011-04-11 19:05:20 +02:00
2021-05-06 17:08:11 +02:00
// Urls to sort the table.
$url_agent_name = 'index.php?sec=' . $section . '&sec2=operation/agentes/status_monitor' ;
$url_type = 'index.php?sec=' . $section . '&sec2=operation/agentes/status_monitor' ;
$url_module_name = 'index.php?sec=' . $section . '&sec2=operation/agentes/status_monitor' ;
$url_server_type = 'index.php?sec=' . $section . '&sec2=operation/agentes/status_monitor' ;
$url_interval = 'index.php?sec=' . $section . '&sec2=operation/agentes/status_monitor' ;
$url_status = 'index.php?sec=' . $section . '&sec2=operation/agentes/status_monitor' ;
$url_status = 'index.php?sec=' . $section . '&sec2=operation/agentes/status_monitor' ;
$url_data = 'index.php?sec=' . $section . '&sec2=operation/agentes/status_monitor' ;
$url_timestamp_up = 'index.php?sec=' . $section . '&sec2=operation/agentes/status_monitor' ;
$url_timestamp_down = 'index.php?sec=' . $section . '&sec2=operation/agentes/status_monitor' ;
$url_agent_name .= '&refr=' . $refr . '&datatype=' . $datatype . '&moduletype=' . $moduletype . '&modulegroup=' . $modulegroup . '&offset=' . $offset . '&ag_group=' . $ag_group . '&ag_freestring=' . $ag_freestring . '&ag_modulename=' . $ag_modulename . '&status=' . $status . $ag_custom_fields_params ;
$url_type .= '&datatype=' . $datatype . '&moduletype=' . $moduletype . '&refr=' . $refr . '&modulegroup=' . $modulegroup . '&offset=' . $offset . '&ag_group=' . $ag_group . '&ag_freestring=' . $ag_freestring . '&ag_modulename=' . $ag_modulename . '&status=' . $status . $ag_custom_fields_params ;
$url_module_name .= '&datatype=' . $datatype . '&moduletype=' . $moduletype . '&refr=' . $refr . '&modulegroup=' . $modulegroup . '&offset=' . $offset . '&ag_group=' . $ag_group . '&ag_freestring=' . $ag_freestring . '&ag_modulename=' . $ag_modulename . '&status=' . $status . $ag_custom_fields_params ;
$url_server_type .= '&datatype=' . $datatype . '&moduletype=' . $moduletype . '&refr=' . $refr . '&modulegroup=' . $modulegroup . '&offset=' . $offset . '&ag_group=' . $ag_group . '&ag_freestring=' . $ag_freestring . '&ag_modulename=' . $ag_modulename . '&status=' . $status . $ag_custom_fields_params ;
$url_interval .= '&datatype=' . $datatype . '&moduletype=' . $moduletype . '&refr=' . $refr . '&modulegroup=' . $modulegroup . '&offset=' . $offset . '&ag_group=' . $ag_group . '&ag_freestring=' . $ag_freestring . '&ag_modulename=' . $ag_modulename . '&status=' . $status . $ag_custom_fields_params ;
$url_status .= '&datatype=' . $datatype . '&moduletype=' . $moduletype . '&refr=' . $refr . '&modulegroup=' . $modulegroup . '&offset=' . $offset . '&ag_group=' . $ag_group . '&ag_freestring=' . $ag_freestring . '&ag_modulename=' . $ag_modulename . '&status=' . $status . $ag_custom_fields_params ;
$url_status .= '&datatype=' . $datatype . '&moduletype=' . $moduletype . '&refr=' . $refr . '&modulegroup=' . $modulegroup . '&offset=' . $offset . '&ag_group=' . $ag_group . '&ag_freestring=' . $ag_freestring . '&ag_modulename=' . $ag_modulename . '&status=' . $status . $ag_custom_fields_params ;
$url_data .= '&datatype=' . $datatype . '&moduletype=' . $moduletype . '&refr=' . $refr . '&modulegroup=' . $modulegroup . '&offset=' . $offset . '&ag_group=' . $ag_group . '&ag_freestring=' . $ag_freestring . '&ag_modulename=' . $ag_modulename . '&status=' . $status . $ag_custom_fields_params ;
$url_timestamp_up .= '&datatype=' . $datatype . '&moduletype=' . $moduletype . '&refr=' . $refr . '&offset=' . $offset . '&ag_group=' . $ag_group . '&ag_freestring=' . $ag_freestring . '&ag_modulename=' . $ag_modulename . '&status=' . $status . $ag_custom_fields_params ;
$url_timestamp_down .= '&datatype=' . $datatype . '&moduletype=' . $moduletype . '&refr=' . $refr . '&modulegroup=' . $modulegroup . '&offset=' . $offset . '&ag_group=' . $ag_group . '&ag_freestring=' . $ag_freestring . '&ag_modulename=' . $ag_modulename . '&status=' . $status . $ag_custom_fields_params ;
// Holy god...
$url_agent_name .= '&recursion=' . $recursion ;
$url_type .= '&recursion=' . $recursion ;
$url_module_name .= '&recursion=' . $recursion ;
$url_server_type .= '&recursion=' . $recursion ;
$url_interval .= '&recursion=' . $recursion ;
$url_status .= '&recursion=' . $recursion ;
$url_status .= '&recursion=' . $recursion ;
$url_data .= '&recursion=' . $recursion ;
$url_timestamp_up .= '&recursion=' . $recursion ;
$url_timestamp_down .= '&recursion=' . $recursion ;
$url_agent_name .= '&sort_field=agent_alias&sort=' ;
$url_type .= '&sort_field=type&sort=' ;
$url_module_name .= '&sort_field=module_name&sort=' ;
$url_server_type .= '&sort_field=moduletype&sort=' ;
$url_interval .= '&sort_field=interval&sort=' ;
$url_status .= '&sort_field=status&sort=' ;
$url_status .= '&sort_field=last_status_change&sort=' ;
$url_data .= '&sort_field=data&sort=' ;
$url_timestamp_up .= '&sort_field=timestamp&sort=up' ;
$url_timestamp_down .= '&sort_field=timestamp&sort=down' ;
// Start Build List Result.
if ( ! empty ( $result )) {
$table = new StdClass ();
$table -> cellpadding = 0 ;
$table -> cellspacing = 0 ;
$table -> width = '100%' ;
$table -> class = 'info_table' ;
$table -> head = [];
$table -> data = [];
$table -> size = [];
$table -> align = [];
$show_fields = explode ( ',' , $config [ 'status_monitor_fields' ]);
if ( in_array ( 'policy' , $show_fields )) {
if ( $isFunctionPolicies !== ENTERPRISE_NOT_HOOK ) {
$table -> head [ 0 ] = '<span title=\'' . __ ( 'Policy' ) . '\'>' . __ ( 'P.' ) . '</span>' ;
}
}
2019-02-21 14:04:00 +01:00
2021-05-06 17:08:11 +02:00
if ( in_array ( 'agent' , $show_fields ) || is_metaconsole ()) {
$table -> head [ 1 ] = __ ( 'Agent' );
$table -> head [ 1 ] .= ui_get_sorting_arrows ( $url_agent_name . 'up' , $url_agent_name . 'down' , $selectAgentNameUp , $selectAgentNameDown );
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
if ( in_array ( 'data_type' , $show_fields ) || is_metaconsole ()) {
$table -> head [ 2 ] = __ ( 'Data Type' );
$table -> head [ 2 ] .= ui_get_sorting_arrows ( $url_type . 'up' , $url_type . 'down' , $selectDataTypeUp , $selectDataTypeDown );
$table -> align [ 2 ] = 'left' ;
}
2019-01-09 12:27:22 +01:00
2021-05-06 17:08:11 +02:00
if ( in_array ( 'module_name' , $show_fields ) || is_metaconsole ()) {
$table -> head [ 3 ] = __ ( 'Module name' );
$table -> head [ 3 ] .= ui_get_sorting_arrows ( $url_module_name . 'up' , $url_module_name . 'down' , $selectModuleNameUp , $selectModuleNameDown );
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
if ( in_array ( 'server_type' , $show_fields ) || is_metaconsole ()) {
$table -> head [ 4 ] = __ ( 'Server type' );
$table -> head [ 4 ] .= ui_get_sorting_arrows ( $url_server_type . 'up' , $url_server_type . 'down' , $selectTypeUp , $selectTypeDown );
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
if ( in_array ( 'interval' , $show_fields ) || is_metaconsole ()) {
$table -> head [ 5 ] = __ ( 'Interval' );
$table -> head [ 5 ] .= ui_get_sorting_arrows ( $url_interval . 'up' , $url_interval . 'down' , $selectIntervalUp , $selectIntervalDown );
$table -> align [ 5 ] = 'left' ;
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
if ( in_array ( 'status' , $show_fields ) || is_metaconsole ()) {
$table -> head [ 6 ] = __ ( 'Status' );
$table -> head [ 6 ] .= ui_get_sorting_arrows ( $url_status . 'up' , $url_status . 'down' , $selectStatusUp , $selectStatusDown );
$table -> align [ 6 ] = 'left' ;
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
if ( in_array ( 'last_status_change' , $show_fields )) {
$table -> head [ 7 ] = __ ( 'Last status change' );
$table -> head [ 7 ] .= ui_get_sorting_arrows ( $url_status . 'up' , $url_status . 'down' , $selectStatusUp , $selectStatusDown );
$table -> align [ 7 ] = 'left' ;
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
if ( in_array ( 'graph' , $show_fields ) || is_metaconsole ()) {
$table -> head [ 8 ] = __ ( 'Graph' );
$table -> align [ 8 ] = 'left' ;
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
if ( in_array ( 'warn' , $show_fields ) || is_metaconsole ()) {
$table -> head [ 9 ] = __ ( 'Warn' );
$table -> align [ 9 ] = 'left' ;
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
if ( in_array ( 'data' , $show_fields ) || is_metaconsole ()) {
$table -> head [ 10 ] = __ ( 'Data' );
$table -> align [ 10 ] = 'left' ;
if ( is_metaconsole ()) {
$table -> head [ 10 ] .= ui_get_sorting_arrows ( $url_data . 'up' , $url_data . 'down' , $selectDataUp , $selectDataDown );
}
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
if ( in_array ( 'timestamp' , $show_fields ) || is_metaconsole ()) {
$table -> head [ 11 ] = __ ( 'Timestamp' );
$table -> head [ 11 ] .= ui_get_sorting_arrows ( $url_timestamp_up , $url_timestamp_down , $selectTimestampUp , $selectTimestampDown );
$table -> align [ 11 ] = 'left' ;
}
2019-02-25 14:42:48 +01:00
2021-05-06 17:08:11 +02:00
$id_type_web_content_string = db_get_value (
'id_tipo' ,
'ttipo_modulo' ,
'nombre' ,
'web_content_string'
);
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
foreach ( $result as $row ) {
// Avoid unset, null and false value.
if ( empty ( $row [ 'server_name' ])) {
$row [ 'server_name' ] = '' ;
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
$is_web_content_string = ( bool ) db_get_value_filter (
'id_agente_modulo' ,
'tagente_modulo' ,
[
'id_agente_modulo' => $row [ 'id_agente_modulo' ],
'id_tipo_modulo' => $id_type_web_content_string ,
]
);
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
// Fixed the goliat sends the strings from web.
// Without HTML entities.
if ( $is_web_content_string ) {
$row [ 'datos' ] = io_safe_input ( $row [ 'datos' ]);
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
// Fixed the data from Selenium Plugin.
if ( $row [ 'datos' ] != strip_tags ( $row [ 'datos' ])) {
$row [ 'datos' ] = io_safe_input ( $row [ 'datos' ]);
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
$data = [];
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
if ( in_array ( 'policy' , $show_fields ) || is_metaconsole ()) {
if ( $isFunctionPolicies !== ENTERPRISE_NOT_HOOK ) {
if ( is_metaconsole ()) {
$node = metaconsole_get_connection_by_id ( $row [ 'server_id' ]);
if ( metaconsole_load_external_db ( $node ) !== NOERR ) {
// Restore the default connection.
metaconsole_restore_db ();
$errors ++ ;
break ;
}
}
2019-02-25 14:42:48 +01:00
2021-05-06 17:08:11 +02:00
$policyInfo = policies_info_module_policy ( $row [ 'id_agente_modulo' ]);
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
if ( $policyInfo === false ) {
$data [ 0 ] = '' ;
} else {
$linked = policies_is_module_linked ( $row [ 'id_agente_modulo' ]);
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
$adopt = false ;
if ( policies_is_module_adopt ( $row [ 'id_agente_modulo' ])) {
$adopt = true ;
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
if ( $linked ) {
if ( $adopt ) {
$img = 'images/policies_brick.png' ;
$title = __ ( '(Adopt) ' ) . $policyInfo [ 'name_policy' ];
} else {
$img = 'images/policies_mc.png' ;
$title = $policyInfo [ 'name_policy' ];
}
} else {
if ( $adopt ) {
$img = 'images/policies_not_brick.png' ;
$title = __ ( '(Unlinked) (Adopt) ' ) . $policyInfo [ 'name_policy' ];
} else {
$img = 'images/unlinkpolicy.png' ;
$title = __ ( '(Unlinked) ' ) . $policyInfo [ 'name_policy' ];
}
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
if ( is_metaconsole ()) {
$data [ 0 ] = '<a href="?sec=gmodules&sec2=advanced/policymanager&id=' . $policyInfo [ 'id_policy' ] . '">' . html_print_image ( $img , true , [ 'title' => $title ]) . '</a>' ;
} else {
$data [ 0 ] = '<a href="?sec=gmodules&sec2=enterprise/godmode/policies/policies&id=' . $policyInfo [ 'id_policy' ] . '">' . html_print_image ( $img , true , [ 'title' => $title ]) . '</a>' ;
}
2019-02-25 14:42:48 +01:00
}
2021-05-06 17:08:11 +02:00
if ( is_metaconsole ()) {
metaconsole_restore_db ();
2019-02-25 14:42:48 +01:00
}
2019-01-30 16:18:44 +01:00
}
2021-05-06 17:08:11 +02:00
}
2019-02-25 14:42:48 +01:00
2021-05-06 17:08:11 +02:00
if ( in_array ( 'agent' , $show_fields ) || is_metaconsole ()) {
$agent_alias = ! empty ( $row [ 'agent_alias' ]) ? $row [ 'agent_alias' ] : $row [ 'agent_name' ];
// TODO: Calculate hash access before to use it more simply like other sections. I.E. Events view
if ( defined ( 'METACONSOLE' )) {
$agent_link = '<a href="' . $row [ 'server_url' ] . 'index.php?' . 'sec=estado&' . 'sec2=operation/agentes/ver_agente&' . 'id_agente=' . $row [ 'id_agent' ] . '&' . 'loginhash=auto&' . 'loginhash_data=' . $row [ 'hashdata' ] . '&' . 'loginhash_user=' . str_rot13 ( $row [ 'user' ]) . '">' ;
$agent_alias = ui_print_truncate_text (
$agent_alias ,
'agent_small' ,
false ,
true ,
false ,
'[…]' ,
'font-size:7.5pt;'
);
if ( can_user_access_node ()) {
$data [ 1 ] = $agent_link . '<b>' . $agent_alias . '</b></a>' ;
} else {
$data [ 1 ] = $agent_alias ;
}
2019-01-30 16:18:44 +01:00
} else {
2021-05-06 17:08:11 +02:00
$data [ 1 ] = '<strong><a href="index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente=' . $row [ 'id_agent' ] . '">' ;
$data [ 1 ] .= ui_print_truncate_text ( $agent_alias , 'agent_medium' , false , true , false , '[…]' , 'font-size:7.5pt;' );
$data [ 1 ] .= '</a></strong>' ;
2019-01-30 16:18:44 +01:00
}
}
2021-05-06 17:08:11 +02:00
if ( in_array ( 'data_type' , $show_fields ) || is_metaconsole ()) {
$data [ 2 ] = html_print_image ( 'images/' . modules_show_icon_type ( $row [ 'module_type' ]), true , [ 'class' => 'invert_filter' ]);
$agent_groups = is_metaconsole () ? $row [ 'groups_in_server' ] : agents_get_all_groups_agent ( $row [ 'id_agent' ], $row [ 'id_group' ]);
if ( check_acl_one_of_groups ( $config [ 'id_user' ], $agent_groups , 'AW' )) {
$show_edit_icon = true ;
if ( defined ( 'METACONSOLE' )) {
if ( ! can_user_access_node ()) {
$show_edit_icon = false ;
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
$url_edit_module = $row [ 'server_url' ] . 'index.php?' . 'sec=gagente&' . 'sec2=godmode/agentes/configurar_agente&' . 'id_agente=' . $row [ 'id_agent' ] . '&' . 'tab=module&' . 'id_agent_module=' . $row [ 'id_agente_modulo' ] . '&' . 'edit_module=1' . '&loginhash=auto&loginhash_data=' . $row [ 'hashdata' ] . '&loginhash_user=' . str_rot13 ( $row [ 'user' ]);
} else {
$url_edit_module = 'index.php?' . 'sec=gagente&' . 'sec2=godmode/agentes/configurar_agente&' . 'id_agente=' . $row [ 'id_agent' ] . '&' . 'tab=module&' . 'id_agent_module=' . $row [ 'id_agente_modulo' ] . '&' . 'edit_module=1' ;
}
if ( $show_edit_icon ) {
$table -> cellclass [][ 2 ] = 'action_buttons' ;
$data [ 2 ] .= '<a href="' . $url_edit_module . '">' . html_print_image (
'images/config.png' ,
true ,
[
'alt' => '0' ,
'border' => '' ,
'title' => __ ( 'Edit' ),
]
) . '</a>' ;
}
}
2019-02-25 14:42:48 +01:00
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
if ( in_array ( 'module_name' , $show_fields ) || is_metaconsole ()) {
$data [ 3 ] = ui_print_truncate_text ( $row [ 'module_name' ], 'module_small' , false , true , true );
if ( $row [ 'extended_info' ] != '' ) {
$data [ 3 ] .= ui_print_help_tip ( $row [ 'extended_info' ], true , '/images/default_list.png' );
2019-02-25 14:42:48 +01:00
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
if ( $row [ 'tags' ] != '' ) {
$data [ 3 ] .= html_print_image (
'/images/tag_red.png' ,
true ,
[
'title' => $row [ 'tags' ],
'class' => 'tag_row' ,
]
);
}
2019-01-30 16:18:44 +01:00
}
2021-05-06 17:08:11 +02:00
if ( in_array ( 'server_type' , $show_fields ) || is_metaconsole ()) {
$data [ 4 ] = servers_show_type ( $row [ 'id_modulo' ]);
2019-02-25 14:42:48 +01:00
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
if ( in_array ( 'interval' , $show_fields ) || is_metaconsole ()) {
$data [ 5 ] = ( $row [ 'module_interval' ] == 0 ) ? human_time_description_raw ( $row [ 'agent_interval' ]) : human_time_description_raw ( $row [ 'module_interval' ]);
2019-06-06 14:16:09 +02:00
}
2021-05-06 17:08:11 +02:00
if ( in_array ( 'status' , $show_fields ) || is_metaconsole ()) {
if ( $row [ 'utimestamp' ] == 0 && (( $row [ 'module_type' ] < 21
|| $row [ 'module_type' ] > 23 ) && $row [ 'module_type' ] != 100 )
) {
$data [ 6 ] = ui_print_status_image (
STATUS_MODULE_NO_DATA ,
__ ( 'NOT INIT' ),
true
);
} else if ( $row [ 'estado' ] == 0 ) {
2019-02-25 14:42:48 +01:00
if ( is_numeric ( $row [ 'datos' ])) {
$data [ 6 ] = ui_print_status_image (
2021-05-06 17:08:11 +02:00
STATUS_MODULE_OK ,
__ ( 'NORMAL' ) . ': ' . remove_right_zeros ( number_format ( $row [ 'datos' ], $config [ 'graph_precision' ])),
2019-02-25 14:42:48 +01:00
true
);
} else {
2019-01-30 16:18:44 +01:00
$data [ 6 ] = ui_print_status_image (
2021-05-06 17:08:11 +02:00
STATUS_MODULE_OK ,
__ ( 'NORMAL' ) . ': ' . htmlspecialchars ( $row [ 'datos' ]),
2019-01-30 16:18:44 +01:00
true
);
2019-02-25 14:42:48 +01:00
}
2021-05-06 17:08:11 +02:00
} else if ( $row [ 'estado' ] == 1 ) {
2019-02-25 14:42:48 +01:00
if ( is_numeric ( $row [ 'datos' ])) {
$data [ 6 ] = ui_print_status_image (
2021-05-06 17:08:11 +02:00
STATUS_MODULE_CRITICAL ,
__ ( 'CRITICAL' ) . ': ' . remove_right_zeros (
number_format ( $row [ 'datos' ], $config [ 'graph_precision' ])
),
2019-02-25 14:42:48 +01:00
true
);
} else {
$data [ 6 ] = ui_print_status_image (
2021-05-06 17:08:11 +02:00
STATUS_MODULE_CRITICAL ,
__ ( 'CRITICAL' ) . ': ' . htmlspecialchars ( $row [ 'datos' ]),
2019-02-25 14:42:48 +01:00
true
);
}
2021-05-06 17:08:11 +02:00
} else if ( $row [ 'estado' ] == 2 ) {
if ( is_numeric ( $row [ 'datos' ])) {
$data [ 6 ] = ui_print_status_image (
STATUS_MODULE_WARNING ,
__ ( 'WARNING' ) . ': ' . remove_right_zeros (
number_format ( $row [ 'datos' ], $config [ 'graph_precision' ])
),
true
);
} else {
$data [ 6 ] = ui_print_status_image (
STATUS_MODULE_WARNING ,
__ ( 'WARNING' ) . ': ' . htmlspecialchars ( $row [ 'datos' ]),
true
);
}
} else if ( $row [ 'estado' ] == 3 ) {
2019-02-25 14:42:48 +01:00
if ( is_numeric ( $row [ 'datos' ])) {
$data [ 6 ] = ui_print_status_image (
STATUS_MODULE_UNKNOWN ,
2021-05-06 17:08:11 +02:00
__ ( 'UNKNOWN' ) . ': ' . remove_right_zeros (
number_format ( $row [ 'datos' ], $config [ 'graph_precision' ])
),
2019-02-25 14:42:48 +01:00
true
);
} else {
$data [ 6 ] = ui_print_status_image (
STATUS_MODULE_UNKNOWN ,
2021-05-06 17:08:11 +02:00
__ ( 'UNKNOWN' ) . ': ' . htmlspecialchars ( $row [ 'datos' ]),
2019-02-25 14:42:48 +01:00
true
);
}
2021-05-06 17:08:11 +02:00
} else if ( $row [ 'estado' ] == 4 ) {
if ( is_numeric ( $row [ 'datos' ])) {
$data [ 6 ] = ui_print_status_image (
STATUS_MODULE_NO_DATA ,
__ ( 'NO DATA' ) . ': ' . remove_right_zeros (
number_format ( $row [ 'datos' ], $config [ 'graph_precision' ])
),
true
);
} else {
$data [ 6 ] = ui_print_status_image (
STATUS_MODULE_NO_DATA ,
__ ( 'NO DATA' ) . ': ' . htmlspecialchars ( $row [ 'datos' ]),
true
);
}
} else {
$last_status = modules_get_agentmodule_last_status (
$row [ 'id_agente_modulo' ]
);
switch ( $last_status ) {
case 0 :
if ( is_numeric ( $row [ 'datos' ])) {
$data [ 6 ] = ui_print_status_image (
STATUS_MODULE_UNKNOWN ,
__ ( 'UNKNOWN' ) . ' - ' . __ ( 'Last status' ) . ' ' . __ ( 'NORMAL' ) . ': ' . remove_right_zeros ( number_format ( $row [ 'datos' ], $config [ 'graph_precision' ])),
true
);
} else {
$data [ 6 ] = ui_print_status_image (
STATUS_MODULE_UNKNOWN ,
__ ( 'UNKNOWN' ) . ' - ' . __ ( 'Last status' ) . ' ' . __ ( 'NORMAL' ) . ': ' . htmlspecialchars ( $row [ 'datos' ]),
true
);
}
break ;
case 1 :
if ( is_numeric ( $row [ 'datos' ])) {
$data [ 6 ] = ui_print_status_image (
STATUS_MODULE_UNKNOWN ,
__ ( 'UNKNOWN' ) . ' - ' . __ ( 'Last status' ) . ' ' . __ ( 'CRITICAL' ) . ': ' . remove_right_zeros ( number_format ( $row [ 'datos' ], $config [ 'graph_precision' ])),
true
);
} else {
$data [ 6 ] = ui_print_status_image (
STATUS_MODULE_UNKNOWN ,
__ ( 'UNKNOWN' ) . ' - ' . __ ( 'Last status' ) . ' ' . __ ( 'CRITICAL' ) . ': ' . htmlspecialchars ( $row [ 'datos' ]),
true
);
}
break ;
case 2 :
if ( is_numeric ( $row [ 'datos' ])) {
$data [ 6 ] = ui_print_status_image (
STATUS_MODULE_UNKNOWN ,
__ ( 'UNKNOWN' ) . ' - ' . __ ( 'Last status' ) . ' ' . __ ( 'WARNING' ) . ': ' . remove_right_zeros ( number_format ( $row [ 'datos' ], $config [ 'graph_precision' ])),
true
);
} else {
$data [ 6 ] = ui_print_status_image (
STATUS_MODULE_UNKNOWN ,
__ ( 'UNKNOWN' ) . ' - ' . __ ( 'Last status' ) . ' ' . __ ( 'WARNING' ) . ': ' . htmlspecialchars ( $row [ 'datos' ]),
true
);
}
break ;
}
}
2019-02-25 14:42:48 +01:00
}
2020-03-23 12:47:58 +01:00
2021-05-06 17:08:11 +02:00
if ( in_array ( 'last_status_change' , $show_fields ) || is_metaconsole ()) {
$data [ 7 ] = ( $row [ 'last_status_change' ] > 0 ) ? human_time_comparation ( $row [ 'last_status_change' ]) : __ ( 'N/A' );
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
if ( in_array ( 'graph' , $show_fields ) || is_metaconsole ()) {
$data [ 8 ] = '' ;
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
$acl_graphs = false ;
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
// Avoid the check on the metaconsole. Too slow to show/hide an icon depending on the permissions.
if ( ! is_metaconsole ()) {
$agent_groups = agents_get_all_groups_agent ( $row [ 'id_agent' ], $row [ 'id_group' ]);
$acl_graphs = check_acl_one_of_groups ( $config [ 'id_user' ], $agent_groups , 'RR' );
} else {
$acl_graphs = true ;
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
if ( $row [ 'history_data' ] == 1 && $acl_graphs ) {
$graph_type = return_graphtype ( $row [ 'module_type' ]);
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
$url = ui_get_full_url ( 'operation/agentes/stat_win.php' , false , false , false );
$handle = dechex ( crc32 ( $row [ 'id_agente_modulo' ] . $row [ 'module_name' ]));
$win_handle = 'day_' . $handle ;
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
$graph_params = [
'type' => $graph_type ,
'period' => SECONDS_1DAY ,
'id' => $row [ 'id_agente_modulo' ],
'refresh' => SECONDS_10MINUTES ,
];
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
if ( is_metaconsole () && isset ( $row [ 'server_id' ])) {
// Set the server id.
$graph_params [ 'server' ] = $row [ 'server_id' ];
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
$graph_params_str = http_build_query ( $graph_params );
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
$link = 'winopeng_var(\'' . $url . '?' . $graph_params_str . '\',\'' . $win_handle . '\', 800, 480)' ;
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
$data [ 8 ] = get_module_realtime_link_graph ( $row );
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
if ( ! is_snapshot_data ( $row [ 'datos' ])) {
$data [ 8 ] .= '<a href="javascript:' . $link . '">' . html_print_image ( 'images/chart.png' , true , [ 'border' => '0' , 'alt' => '' , 'class' => 'invert_filter' ]) . '</a>' ;
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
$data [ 8 ] .= '<a href="javascript: show_module_detail_dialog(' . $row [ 'id_agente_modulo' ] . ', ' . $row [ 'id_agent' ] . ', \'' . $row [ 'server_name' ] . '\', 0, ' . SECONDS_1DAY . ', \'' . $row [ 'module_name' ] . '\')">' . html_print_image (
'images/binary.png' ,
true ,
[
'border' => '0' ,
'alt' => '' ,
'class' => 'invert_filter' ,
]
) . '</a>' ;
$data [ 8 ] .= '<span id=\'hidden_name_module_' . $row [ 'id_agente_modulo' ] . ' \ '
2021-03-11 15:40:23 +01:00
class = \ 'invisible\'>' . $row [ 'module_name' ] . '</span>' ;
2021-05-06 17:08:11 +02:00
}
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
if ( in_array ( 'warn' , $show_fields ) || is_metaconsole ()) {
$data [ 9 ] = ui_print_module_warn_value (
$row [ 'max_warning' ],
$row [ 'min_warning' ],
$row [ 'str_warning' ],
$row [ 'max_critical' ],
$row [ 'min_critical' ],
$row [ 'str_critical' ],
$row [ 'warning_inverse' ],
$row [ 'critical_inverse' ]
);
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
if ( is_numeric ( $row [ 'datos' ]) && ! modules_is_string_type ( $row [ 'module_type' ])) {
if ( $config [ 'render_proc' ]) {
switch ( $row [ 'module_type' ]) {
case 2 :
case 6 :
case 9 :
case 18 :
case 21 :
case 31 :
if ( $row [ 'datos' ] >= 1 ) {
$salida = $config [ 'render_proc_ok' ];
} else {
$salida = $config [ 'render_proc_fail' ];
}
break ;
2019-02-25 14:42:48 +01:00
2021-05-06 17:08:11 +02:00
default :
switch ( $row [ 'module_type' ]) {
case 15 :
$value = db_get_value ( 'snmp_oid' , 'tagente_modulo' , 'id_agente_modulo' , $row [ 'id_agente_modulo' ]);
if ( $value == '.1.3.6.1.2.1.1.3.0' || $value == '.1.3.6.1.2.1.25.1.1.0' ) {
$salida = human_milliseconds_to_string ( $row [ 'datos' ]);
} else {
$salida = remove_right_zeros ( number_format ( $row [ 'datos' ], $config [ 'graph_precision' ]));
}
break ;
default :
$salida = remove_right_zeros ( number_format ( $row [ 'datos' ], $config [ 'graph_precision' ]));
break ;
}
break ;
}
} else {
2019-02-25 14:42:48 +01:00
switch ( $row [ 'module_type' ]) {
case 15 :
$value = db_get_value ( 'snmp_oid' , 'tagente_modulo' , 'id_agente_modulo' , $row [ 'id_agente_modulo' ]);
if ( $value == '.1.3.6.1.2.1.1.3.0' || $value == '.1.3.6.1.2.1.25.1.1.0' ) {
$salida = human_milliseconds_to_string ( $row [ 'datos' ]);
} else {
$salida = remove_right_zeros ( number_format ( $row [ 'datos' ], $config [ 'graph_precision' ]));
}
break ;
default :
2019-01-30 16:18:44 +01:00
$salida = remove_right_zeros ( number_format ( $row [ 'datos' ], $config [ 'graph_precision' ]));
2019-02-25 14:42:48 +01:00
break ;
}
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
// Show units ONLY in numeric data types.
if ( isset ( $row [ 'unit' ])) {
2019-02-25 14:42:48 +01:00
$data_macro = modules_get_unit_macro ( $row [ 'datos' ], $row [ 'unit' ]);
if ( $data_macro ) {
$salida = $data_macro ;
} else {
2021-05-06 17:08:11 +02:00
$salida .= ' ' . '<i>' . io_safe_output ( $row [ 'unit' ]) . '</i>' ;
if ( strlen ( $salida ) > $config [ 'agent_size_text_small' ]) {
$salida = ui_print_truncate_text ( $salida , 'agent_small' , true , true , false , '[…]' , 'font-size:7.5pt;' );
// Clean tag <i>.
$text_aux = explode ( '<a' , $salida );
$match = preg_replace ( '/(<i>|<\/i>|<i|<\/i|i>|\/i>|<|>)/' , '' , $text_aux [ 0 ]);
$salida = $match . '<a' . $text_aux [ 1 ];
} else {
$salida = ui_print_truncate_text ( $salida , 'agent_small' , true , true , false , '[…]' , 'font-size:7.5pt;' );
}
2019-02-25 14:42:48 +01:00
}
2019-01-30 16:18:44 +01:00
}
} else {
2021-05-06 17:08:11 +02:00
// Fixed the goliat sends the strings from web.
// Without HTML entities.
2019-02-25 14:42:48 +01:00
if ( $is_web_content_string ) {
2021-05-06 17:08:11 +02:00
$module_value = $row [ 'datos' ];
2019-01-30 16:18:44 +01:00
} else {
2021-05-06 17:08:11 +02:00
$module_value = io_safe_output ( $row [ 'datos' ]);
2019-01-30 16:18:44 +01:00
}
2021-05-06 17:08:11 +02:00
$is_snapshot = is_snapshot_data ( $module_value );
$is_large_image = is_text_to_black_string ( $module_value );
if (( $config [ 'command_snapshot' ]) && ( $is_snapshot || $is_large_image )) {
$link = ui_get_snapshot_link (
[
'id_module' => $row [ 'id_agente_modulo' ],
'interval' => $row [ 'current_interval' ],
'module_name' => $row [ 'module_name' ],
'id_node' => $row [ 'server_id' ],
]
);
$salida = ui_get_snapshot_image ( $link , $is_snapshot ) . ' ' ;
2019-02-25 14:42:48 +01:00
} else {
2021-05-06 17:08:11 +02:00
$sub_string = substr ( io_safe_output ( $row [ 'datos' ]), 0 , 12 );
if ( $module_value == $sub_string ) {
if ( $module_value == 0 && ! $sub_string ) {
$salida = 0 ;
} else {
$data_macro = modules_get_unit_macro ( $row [ 'datos' ], $row [ 'unit' ]);
if ( $data_macro ) {
$salida = $data_macro ;
} else {
$salida = $row [ 'datos' ];
}
}
} else {
// Fixed the goliat sends the strings from web.
// Without HTML entities.
if ( $is_web_content_string ) {
$sub_string = substr ( $row [ 'datos' ], 0 , 12 );
} else {
// Fixed the data from Selenium Plugin.
if ( $module_value != strip_tags ( $module_value )) {
$module_value = io_safe_input ( $module_value );
$sub_string = substr ( $row [ 'datos' ], 0 , 12 );
} else {
$sub_string = substr ( io_safe_output ( $row [ 'datos' ]), 0 , 12 );
}
}
if ( $module_value == $sub_string ) {
$salida = $module_value ;
} else {
$salida = '<span ' . " id='hidden_value_module_ " . $row [ 'id_agente_modulo' ] . " '
2021-03-11 15:40:23 +01:00
class = 'invisible' > " . $module_value .'</span>'.'<span '. " id = 'value_module_".$row[' id_agente_modulo ']."'
title = '".$module_value."' " . " class = 'nowrap' > " .'<span id= " value_module_text_ '.$row[' id_agente_modulo '].' " >'. $sub_string .'</span> '. " < a href = 'javascript: toggle_full_value(".$row[' id_agente_modulo '].")' > " .html_print_image('images/rosette.png', true).'</a></span>';
2021-05-06 17:08:11 +02:00
}
}
2019-02-25 14:42:48 +01:00
}
2019-01-30 16:18:44 +01:00
}
}
2021-05-06 17:08:11 +02:00
if ( in_array ( 'data' , $show_fields ) || is_metaconsole ()) {
$data [ 10 ] = $salida ;
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
if ( in_array ( 'timestamp' , $show_fields ) || is_metaconsole ()) {
if ( $row [ 'module_interval' ] > 0 ) {
$interval = $row [ 'module_interval' ];
} else {
$interval = $row [ 'agent_interval' ];
}
2019-02-25 14:42:48 +01:00
2021-05-06 17:08:11 +02:00
if ( $row [ 'estado' ] == 3 ) {
$option = [
'html_attr' => 'class="redb"' ,
'style' => 'font-size:7pt;' ,
];
} else {
$option = [ 'style' => 'font-size:7pt;' ];
}
2019-02-25 14:42:48 +01:00
2021-05-06 17:08:11 +02:00
$data [ 11 ] = ui_print_timestamp ( $row [ 'utimestamp' ], true , $option );
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
array_push ( $table -> data , $data );
}
2019-01-30 16:18:44 +01:00
2021-05-06 17:08:11 +02:00
html_print_table ( $table );
2019-03-27 17:03:55 +01:00
2021-05-06 17:08:11 +02:00
if ( $count_modules > $config [ 'block_size' ]) {
ui_pagination ( $count_modules , false , $offset , 0 , false , 'offset' , true , 'pagination-bottom' );
}
} else {
if ( $first_interaction ) {
ui_print_info_message ([ 'no_close' => true , 'message' => __ ( 'This group doesn\'t have any monitor' )]);
} else {
ui_print_info_message ([ 'no_close' => true , 'message' => __ ( 'Sorry no search parameters' )]);
}
}
2013-05-20 10:42:02 +02:00
2021-05-06 17:08:11 +02:00
// End Build List Result.
echo " <div id='monitor_details_window'></div> " ;
2015-01-15 18:08:58 +01:00
2021-05-06 17:08:11 +02:00
enterprise_hook ( 'close_meta_frame' );
2013-05-20 10:42:02 +02:00
2021-05-06 17:08:11 +02:00
ui_require_javascript_file ( 'pandora_modules' );
2013-03-15 13:06:49 +01:00
2021-05-06 17:08:11 +02:00
?>
2020-10-26 10:14:14 +01:00
< script type = " text/javascript " >
2016-10-14 18:51:17 +02:00
2019-01-30 16:18:44 +01:00
$ ( '#moduletype' ) . click ( function () {
jQuery . get (
" ajax.php " ,
{
" page " : " general/subselect_data_module " ,
" module " : $ ( '#moduletype' ) . val ()
},
function ( data , status ) {
$ ( " #datatypetittle " ) . show ();
$ ( " #datatypebox " ) . hide ()
. empty ()
. append ( data )
. show ();
},
" html "
2016-10-14 18:51:17 +02:00
);
return false ;
2019-10-09 17:26:06 +02:00
});
2019-01-30 16:18:44 +01:00
function toggle_full_value ( id ) {
text = $ ( '#hidden_value_module_' + id ) . html ();
old_text = $ ( " #value_module_text_ " + id ) . html ();
$ ( " #hidden_value_module_ " + id ) . html ( old_text );
$ ( " #value_module_text_ " + id ) . html ( text );
}
2021-05-06 17:08:11 +02:00
// Show the modal window of an module.
2019-01-30 16:18:44 +01:00
function show_module_detail_dialog ( module_id , id_agent , server_name , offset , period , module_name ) {
if ( period == - 1 ) {
if ( $ ( " #period " ) . length == 1 ) {
period = $ ( '#period' ) . val ();
}
else {
period = < ? php echo SECONDS_1DAY ; ?> ;
}
}
if ( $ ( 'input[name=selection_mode]:checked' ) . val ()) {
var selection_mode = $ ( 'input[name=selection_mode]:checked' ) . val ();
var date_from = $ ( '#text-date_from' ) . val ();
var time_from = $ ( '#text-time_from' ) . val ();
var date_to = $ ( '#text-date_to' ) . val ();
var time_to = $ ( '#text-time_to' ) . val ();
var extra_parameters = '&selection_mode=' + selection_mode + '&date_from=' + date_from + '&date_to=' + date_to + '&time_from=' + time_from + '&time_to=' + time_to ;
}
title = < ? php echo '"' . __ ( 'Module: ' ) . '"' ; ?> ;
$ . ajax ({
type : " POST " ,
url : " <?php echo ui_get_full_url('ajax.php', false, false, false); ?> " ,
data : " page=include/ajax/module&get_module_detail=1&server_name= " + server_name + " &id_agent= " + id_agent + " &id_module= " + module_id + " &offset= " + offset + " &period= " + period + extra_parameters ,
dataType : " html " ,
success : function ( data ) {
$ ( " #monitor_details_window " ) . hide ()
. empty ()
. append ( data )
. dialog ({
resizable : true ,
draggable : true ,
modal : true ,
title : title + module_name ,
overlay : {
opacity : 0.5 ,
background : " black "
},
width : 620 ,
height : 500
})
. show ();
refresh_pagination_callback ( module_id , id_agent , server_name , module_name );
}
});
}
function refresh_pagination_callback ( module_id , id_agent , server_name , module_name ) {
$ ( " .binary_dialog " ) . click ( function () {
var classes = $ ( this ) . attr ( 'class' );
classes = classes . split ( ' ' );
var offset_class = classes [ 2 ];
offset_class = offset_class . split ( '_' );
var offset = offset_class [ 1 ];
var period = $ ( '#period' ) . val ();
show_module_detail_dialog ( module_id , id_agent , server_name , offset , period , module_name );
return false ;
});
}
</ script >