2008-11-14 16:37:32 +01:00
< ? php
2009-06-08 20:26:14 +02:00
// Pandora FMS - http://pandorafms.com
// ==================================================
2011-03-02 22:56:48 +01:00
// Copyright (c) 2005-2011 Artica Soluciones Tecnologicas
2009-06-08 20:26:14 +02:00
// Please see http://pandorafms.org for full contribution list
2008-11-14 16:37:32 +01: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
2008-11-14 16:37:32 +01: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.
2019-01-30 16:18:44 +01:00
require_once $config [ 'homedir' ] . '/include/functions_ui.php' ;
require_once $config [ 'homedir' ] . '/include/functions_tags.php' ;
require_once $config [ 'homedir' ] . '/include/functions.php' ;
enterprise_include_once ( 'meta/include/functions_events_meta.php' );
enterprise_include_once ( 'meta/include/functions_agents_meta.php' );
enterprise_include_once ( 'meta/include/functions_modules_meta.php' );
2012-02-24 Miguel de Dios <miguel.dedios@artica.es>
* pandora_console/include/functions_ui.php: changed the source code into the
function "ui_get_full_url" for accept false for to return url with the home
url or with any string (as query) return url with the php file.
* pandora_console/include/functions_graph.php,
pandora_console/include/functions_html.php,
pandora_console/include/functions_events.php,
pandora_console/include/functions_reporting.php,
pandora_console/include/functions_api.php,
pandora_console/include/functions.php, pandora_console/index.php,
pandora_console/extensions/system_info.php,
pandora_console/operation/agentes/stat_win.php,
pandora_console/operation/menu.php,
pandora_console/operation/events/events_rss.php,
pandora_console/operation/events/events_marquee.php,
pandora_console/operation/events/events.php: change in more part of source
code to use "ui_get_full_url" instead the hard write method of $_SERVER
vars, now Pandora Console run fine (in all actions I hope) with web servers
in other ports instead the typical 80.
Merged from branch pandora_4.0
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@5646 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-02-24 14:48:46 +01:00
2013-04-29 16:09:01 +02:00
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
/**
2019-01-30 16:18:44 +01: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 Events
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
*/
2019-01-30 16:18:44 +01:00
function events_get_all_fields ()
{
$columns = [];
$columns [ 'id_evento' ] = __ ( 'Event id' );
$columns [ 'evento' ] = __ ( 'Event name' );
$columns [ 'id_agente' ] = __ ( 'Agent name' );
$columns [ 'id_usuario' ] = __ ( 'User' );
$columns [ 'id_grupo' ] = __ ( 'Group' );
$columns [ 'estado' ] = __ ( 'Status' );
$columns [ 'timestamp' ] = __ ( 'Timestamp' );
$columns [ 'event_type' ] = __ ( 'Event type' );
$columns [ 'id_agentmodule' ] = __ ( 'Agent module' );
$columns [ 'id_alert_am' ] = __ ( 'Alert' );
$columns [ 'criticity' ] = __ ( 'Severity' );
$columns [ 'user_comment' ] = __ ( 'Comment' );
$columns [ 'tags' ] = __ ( 'Tags' );
$columns [ 'source' ] = __ ( 'Source' );
$columns [ 'id_extra' ] = __ ( 'Extra id' );
$columns [ 'owner_user' ] = __ ( 'Owner' );
$columns [ 'ack_utimestamp' ] = __ ( 'ACK Timestamp' );
$columns [ 'instructions' ] = __ ( 'Instructions' );
$columns [ 'server_name' ] = __ ( 'Server name' );
$columns [ 'data' ] = __ ( 'Data' );
$columns [ 'module_status' ] = __ ( 'Module status' );
return $columns ;
2013-04-29 16:09:01 +02:00
}
2019-01-30 16:18:44 +01:00
/**
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
* Get all rows of events from the database , that
* pass the filter , and can get only some fields .
2019-01-30 16:18:44 +01:00
*
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
* @ param mixed Filters elements . It can be an indexed array
* ( keys would be the field name and value the expected value , and would be
* joined with an AND operator ) or a string , including any SQL clause ( without
* the WHERE keyword ) . Example :
* < code >
* Both are similars :
* 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
* db_get_all_rows_filter ( 'table' , array ( 'disabled' , 0 ));
* db_get_all_rows_filter ( 'table' , 'disabled = 0' );
2019-01-30 16:18:44 +01:00
*
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
* Both are similars :
* 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
* db_get_all_rows_filter ( 'table' , array ( 'disabled' => 0 , 'history_data' => 0 ), 'name' , 'OR' );
* db_get_all_rows_filter ( 'table' , 'disabled = 0 OR history_data = 0' , 'name' );
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
* </ code >
* @ param mixed Fields of the table to retrieve . Can be an array or a coma
* separated string . All fields are retrieved by default
2019-01-30 16:18:44 +01:00
*
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
* @ return mixed False in case of error or invalid values passed . Affected rows otherwise
*/
2019-01-30 16:18:44 +01:00
function events_get_events ( $filter = false , $fields = false )
{
if ( $filter [ 'criticity' ] == EVENT_CRIT_WARNING_OR_CRITICAL ) {
$filter [ 'criticity' ] = [
EVENT_CRIT_WARNING ,
EVENT_CRIT_CRITICAL ,
];
}
return db_get_all_rows_filter ( 'tevento' , $filter , $fields );
2009-02-26 16:34:14 +01:00
}
2019-01-30 16:18:44 +01:00
2013-04-29 16:09:01 +02:00
/**
* Get the event with the id pass as parameter .
2019-01-30 16:18:44 +01:00
*
* @ param integer $id Event id
* @ param mixed $fields The fields to show or by default all with false .
*
2013-04-29 16:09:01 +02:00
* @ return mixed False in case of error or invalid values passed . Event row otherwise
*/
2019-01-30 16:18:44 +01:00
function events_get_event ( $id , $fields = false , $meta = false , $history = false )
{
if ( empty ( $id )) {
return false ;
}
global $config ;
if ( is_array ( $fields )) {
if ( ! in_array ( 'id_grupo' , $fields )) {
$fields [] = 'id_grupo' ;
}
}
$table = events_get_events_table ( $meta , $history );
$event = db_get_row ( $table , 'id_evento' , $id , $fields );
if ( ! check_acl ( $config [ 'id_user' ], $event [ 'id_grupo' ], 'ER' )) {
return false ;
}
return $event ;
2009-02-27 13:48:05 +01:00
}
2017-01-11 13:26:50 +01:00
2019-01-30 16:18:44 +01:00
function events_get_events_no_grouped (
$sql_post ,
$offset = 0 ,
$pagination = 1 ,
$meta = false ,
$history = false ,
$total = false ,
$history_db = false ,
$order = 'ASC'
) {
global $config ;
$table = events_get_events_table ( $meta , $history );
2017-01-11 13:26:50 +01:00
2019-01-30 16:18:44 +01:00
$sql = " SELECT * FROM $table te WHERE 1=1 " . $sql_post ;
$events = db_get_all_rows_sql ( $sql , $history_db );
return $events ;
2017-01-11 13:26:50 +01:00
}
2009-02-27 13:48:05 +01:00
2019-01-30 16:18:44 +01:00
function events_get_events_grouped (
$sql_post ,
$offset = 0 ,
$pagination = 1 ,
$meta = false ,
$history = false ,
$total = false ,
$history_db = false ,
$order = 'down' ,
$sort_field = 'timestamp'
) {
global $config ;
$table = events_get_events_table ( $meta , $history );
if ( $meta ) {
$groupby_extra = ', server_id' ;
} else {
$groupby_extra = '' ;
}
switch ( $config [ 'dbtype' ]) {
case 'mysql' :
db_process_sql ( 'SET group_concat_max_len = 9999999' );
$event_lj = events_get_secondary_groups_left_join ( $table );
if ( $total ) {
$sql = " SELECT COUNT(*) FROM (SELECT *
2018-08-14 17:06:15 +02:00
FROM $table te $event_lj
2019-01-30 16:18:44 +01:00
WHERE 1 = 1 " . $sql_post .'
GROUP BY estado , evento , id_agente , id_agentmodule '.$groupby_extra.' ) AS t ' ;
} else {
$sql = " SELECT *, MAX(id_evento) AS id_evento,
2017-01-11 13:26:50 +01:00
GROUP_CONCAT ( DISTINCT user_comment SEPARATOR '<br>' ) AS user_comment ,
GROUP_CONCAT ( DISTINCT id_evento SEPARATOR ',' ) AS similar_ids ,
COUNT ( * ) AS event_rep , MAX ( utimestamp ) AS timestamp_rep ,
MIN ( utimestamp ) AS timestamp_rep_min ,
( SELECT owner_user FROM $table WHERE id_evento = MAX ( te . id_evento )) owner_user ,
( SELECT id_usuario FROM $table WHERE id_evento = MAX ( te . id_evento )) id_usuario ,
( SELECT id_agente FROM $table WHERE id_evento = MAX ( te . id_evento )) id_agente ,
( SELECT criticity FROM $table WHERE id_evento = MAX ( te . id_evento )) AS criticity ,
2018-08-03 10:38:53 +02:00
( SELECT ack_utimestamp FROM $table WHERE id_evento = MAX ( te . id_evento )) AS ack_utimestamp ,
( SELECT nombre FROM tagente_modulo WHERE id_agente_modulo = te . id_agentmodule ) AS module_name
2018-08-14 17:06:15 +02:00
FROM $table te $event_lj
2019-01-30 16:18:44 +01:00
WHERE 1 = 1 " . $sql_post .'
GROUP BY estado , evento , id_agente , id_agentmodule ' . $groupby_extra ;
$sql .= ' ' . events_get_sql_order ( $sort_field , $order , 2 );
$sql .= ' LIMIT ' . $offset . ',' . $pagination ;
}
break ;
case 'postgresql' :
if ( $total ) {
$sql = " SELECT COUNT(*)
2013-03-20 Miguel de Dios <miguel.dedios@artica.es>
* mobile/operation/events.php, mobile/include/ui.class.php,
mobile/index.php: added first version of events section.
* include/functions_incidents.php, include/functions_users.php,
include/functions.php, include/functions_groups.php,
include/functions_events.php, include/functions_html.php,
operation/events/events.build_table.php,
operation/events/events.build_query.php,
operation/events/events_list.php: some changes for interact with
mobile version.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7872 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-03-20 13:29:33 +01:00
FROM $table te
2019-01-30 16:18:44 +01:00
WHERE 1 = 1 " . $sql_post .'
GROUP BY estado , evento , id_agentmodule , id_evento , id_agente , id_usuario , id_grupo , estado , timestamp , utimestamp , event_type , id_alert_am , criticity , user_comment , tags , source , id_extra ' . $groupby_extra ;
} else {
$sql = " SELECT *, MAX(id_evento) AS id_evento, array_to_string(array_agg(DISTINCT user_comment), '<br>') AS user_comment,
2013-03-20 Miguel de Dios <miguel.dedios@artica.es>
* mobile/operation/events.php, mobile/include/ui.class.php,
mobile/index.php: added first version of events section.
* include/functions_incidents.php, include/functions_users.php,
include/functions.php, include/functions_groups.php,
include/functions_events.php, include/functions_html.php,
operation/events/events.build_table.php,
operation/events/events.build_query.php,
operation/events/events_list.php: some changes for interact with
mobile version.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7872 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-03-20 13:29:33 +01:00
array_to_string ( array_agg ( DISTINCT id_evento ), ',' ) AS similar_ids ,
COUNT ( * ) AS event_rep , MAX ( utimestamp ) AS timestamp_rep ,
MIN ( utimestamp ) AS timestamp_rep_min ,
2014-01-27 12:45:06 +01:00
( SELECT owner_user FROM $table WHERE id_evento = MAX ( te . id_evento )) owner_user ,
( SELECT id_usuario FROM $table WHERE id_evento = MAX ( te . id_evento )) id_usuario ,
( SELECT id_agente FROM $table WHERE id_evento = MAX ( te . id_evento )) id_agente ,
( SELECT criticity FROM $table WHERE id_evento = MAX ( te . id_evento )) AS criticity ,
( SELECT ack_utimestamp FROM $table WHERE id_evento = MAX ( te . id_evento )) AS ack_utimestamp
2013-03-20 Miguel de Dios <miguel.dedios@artica.es>
* mobile/operation/events.php, mobile/include/ui.class.php,
mobile/index.php: added first version of events section.
* include/functions_incidents.php, include/functions_users.php,
include/functions.php, include/functions_groups.php,
include/functions_events.php, include/functions_html.php,
operation/events/events.build_table.php,
operation/events/events.build_query.php,
operation/events/events_list.php: some changes for interact with
mobile version.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7872 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-03-20 13:29:33 +01:00
FROM $table te
2019-01-30 16:18:44 +01:00
WHERE 1 = 1 " . $sql_post .'
2014-07-24 Miguel de Dios <miguel.dedios@artica.es>
* operation/snmpconsole/snmp_view.php,
operation/events/events_list.php, operation/incidents/incident.php,
extensions/files_repo.php,
extensions/files_repo/sql/files_repo.postgreSQL.sql,
extensions/files_repo/functions_files_repo.php,
extensions/files_repo/files_repo_list.php,
godmode/agentes/modificar_agente.php,
godmode/snmpconsole/snmp_alert.php, godmode/db/db_info.php,
include/functions_graph.php, include/functions_db.php,
include/db/postgresql.php, include/db/oracle.php,
include/db/mysql.php, include/functions_update_manager.php,
include/functions_events.php, include/graphs/functions_flot.php,
include/graphs/fgraph.php: tiny fixes for the improve the support of
postgreSQL databases.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@10354 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2014-07-24 18:02:06 +02:00
GROUP BY estado , evento , id_agentmodule , id_evento ,
id_agente , id_usuario , id_grupo , estado ,
timestamp , utimestamp , event_type , id_alert_am ,
criticity , user_comment , tags , source , id_extra ,
te . critical_instructions ,
te . warning_instructions ,
te . unknown_instructions ,
te . owner_user ,
te . ack_utimestamp ,
2019-01-30 16:18:44 +01:00
te . custom_data '.$groupby_extra.'
ORDER BY timestamp_rep ASC LIMIT '.$pagination.' OFFSET ' . $offset ;
}
break ;
case 'oracle' :
if ( $total ) {
$sql = " SELECT COUNT(*)
2015-05-11 14:16:44 +02:00
FROM $table te
WHERE 1 = 1 $sql_post
2019-01-30 16:18:44 +01:00
GROUP BY estado , to_char ( evento ), id_agentmodule " . $groupby_extra .') b ';
} else {
$set = [];
$set [ 'limit' ] = $pagination ;
$set [ 'offset' ] = $offset ;
$sql = " SELECT ta.*, tb.event_rep, tb.timestamp_rep, tb.timestamp_rep_min, tb.user_comments, tb.similar_ids
2015-05-21 12:01:22 +02:00
FROM $table ta
INNER JOIN ( SELECT MAX ( id_evento ) AS id_evento , COUNT ( id_evento ) AS event_rep ,
MAX ( utimestamp ) AS timestamp_rep , MIN ( utimestamp ) AS timestamp_rep_min ,
2015-05-22 11:05:53 +02:00
TAB_TO_STRING ( CAST ( COLLECT ( TO_CHAR ( user_comment ) ORDER BY id_evento ASC ) AS t_varchar2_tab ), '<br>' ) AS user_comments ,
TAB_TO_STRING ( CAST ( COLLECT ( CAST ( id_evento AS VARCHAR2 ( 4000 )) ORDER BY id_evento ASC ) AS t_varchar2_tab )) AS similar_ids
2015-05-21 12:01:22 +02:00
FROM $table te
WHERE 1 = 1 $sql_post
GROUP BY estado , to_char ( evento ), id_agentmodule $groupby_extra ) tb
2015-05-21 12:18:31 +02:00
ON ta . id_evento = tb . id_evento
2017-01-02 16:08:02 +01:00
ORDER BY tb . timestamp_rep ASC " ;
2019-01-30 16:18:44 +01:00
$sql = oracle_recode_query ( $sql , $set );
}
break ;
}
// Extract the events by filter (or not) from db
$events = db_get_all_rows_sql ( $sql , $history_db );
if ( $total ) {
return reset ( $events [ 0 ]);
} else {
// Override the column 'user_comment' with the column 'user_comments' when oracle
if ( ! empty ( $events ) && $config [ 'dbtype' ] == 'oracle' ) {
array_walk (
$events ,
function ( & $value , $key ) {
set_if_defined ( $value [ 'user_comment' ], $value [ 'user_comments' ]);
}
);
}
return $events ;
}
2013-03-20 Miguel de Dios <miguel.dedios@artica.es>
* mobile/operation/events.php, mobile/include/ui.class.php,
mobile/index.php: added first version of events section.
* include/functions_incidents.php, include/functions_users.php,
include/functions.php, include/functions_groups.php,
include/functions_events.php, include/functions_html.php,
operation/events/events.build_table.php,
operation/events/events.build_query.php,
operation/events/events_list.php: some changes for interact with
mobile version.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7872 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-03-20 13:29:33 +01:00
}
2019-01-30 16:18:44 +01:00
function events_get_total_events_grouped ( $sql_post , $meta = false , $history = false )
{
return events_get_events_grouped ( $sql_post , 0 , 0 , $meta , $history , true );
2012-10-09 18:05:32 +02:00
}
2019-01-30 16:18:44 +01:00
2009-04-01 10:04:49 +02:00
/**
* Get all the events ids similar to a given event id .
*
* An event is similar then the event text ( evento ) and the id_agentmodule are
* the same .
*
* @ param int Event id to get similar events .
2013-01-16 13:57:11 +01:00
* @ param bool Metaconsole mode flag
* @ param bool History mode flag
2009-04-01 10:04:49 +02:00
*
* @ return array A list of events ids .
*/
2019-01-30 16:18:44 +01:00
function events_get_similar_ids ( $id , $meta = false , $history = false )
{
$events_table = events_get_events_table ( $meta , $history );
$ids = [];
if ( $meta ) {
$event = events_meta_get_event ( $id , [ 'evento' , 'id_agentmodule' ], $history );
} else {
$event = events_get_event ( $id , [ 'evento' , 'id_agentmodule' ]);
}
if ( $event === false ) {
return $ids ;
}
$events = db_get_all_rows_filter (
$events_table ,
[
'evento' => $event [ 'evento' ],
'id_agentmodule' => $event [ 'id_agentmodule' ],
],
[ 'id_evento' ]
);
if ( $events === false ) {
return $ids ;
}
foreach ( $events as $event ) {
$ids [] = $event [ 'id_evento' ];
}
return $ids ;
2009-04-01 10:04:49 +02:00
}
2019-01-30 16:18:44 +01:00
2009-01-08 16:52:13 +01:00
/**
2012-10-09 18:05:32 +02:00
* Delete events in a transresponse
2009-01-08 16:52:13 +01:00
*
2009-04-01 10:04:49 +02:00
* @ param mixed Event ID or array of events
* @ param bool Whether to delete similar events too .
2012-12-18 12:54:22 +01:00
* @ param bool Metaconsole mode flag
2013-01-16 13:57:11 +01:00
* @ param bool History mode flag
2009-01-08 16:52:13 +01:00
*
2019-01-30 16:18:44 +01:00
* @ return boolean Whether or not it was successful
2009-01-08 16:52:13 +01:00
*/
2019-01-30 16:18:44 +01:00
function events_delete_event ( $id_event , $similar = true , $meta = false , $history = false )
{
global $config ;
$table_event = events_get_events_table ( $meta , $history );
// Cleans up the selection for all unwanted values also casts any single values as an array
$id_event = ( array ) safe_int ( $id_event , 1 );
// We must delete all events like the selected
if ( $similar ) {
foreach ( $id_event as $id ) {
$id_event = array_merge ( $id_event , events_get_similar_ids ( $id , $meta , $history ));
}
$id_event = array_unique ( $id_event );
}
$errors = 0 ;
foreach ( $id_event as $event ) {
if ( $meta ) {
$event_group = events_meta_get_group ( $event , $history );
} else {
$event_group = events_get_group ( $event );
}
if ( check_acl ( $config [ 'id_user' ], $event_group , 'EM' ) == 0 ) {
// Check ACL
db_pandora_audit ( 'ACL Violation' , 'Attempted deleting event #' . $event );
$errors ++ ;
} else {
$ret = db_process_sql_delete ( $table_event , [ 'id_evento' => $event ]);
if ( ! $ret ) {
$errors ++ ;
} else {
db_pandora_audit ( 'Event deleted' , 'Deleted event #' . $event );
// ACL didn't fail nor did return
continue ;
}
}
break ;
}
if ( $errors > 0 ) {
return false ;
} else {
return true ;
}
2008-11-14 16:37:32 +01:00
}
2019-01-30 16:18:44 +01:00
2012-10-01 13:15:31 +02:00
/**
2012-10-11 19:49:17 +02:00
* Change the status of one or various events
2012-10-01 13:15:31 +02:00
*
* @ param mixed Event ID or array of events
2013-01-16 13:57:11 +01:00
* @ param int new status of the event
* @ param bool metaconsole mode flag
* @ param bool history mode flag
2012-10-01 13:15:31 +02:00
*
2019-01-30 16:18:44 +01:00
* @ return boolean Whether or not it was successful
2013-04-18 11:25:23 +02:00
*/
2019-01-30 16:18:44 +01:00
function events_change_status ( $id_event , $new_status , $meta = false , $history = false )
{
global $config ;
$event_table = events_get_events_table ( $meta , $history );
// Cleans up the selection for all unwanted values also casts any single values as an array
$id_event = ( array ) safe_int ( $id_event , 1 );
// Update ack info if the new status is validated
if ( $new_status == EVENT_STATUS_VALIDATED ) {
$ack_utimestamp = time ();
$ack_user = $config [ 'id_user' ];
} else {
$acl_utimestamp = 0 ;
$ack_user = '' ;
}
switch ( $new_status ) {
case EVENT_STATUS_NEW :
$status_string = 'New' ;
break ;
case EVENT_STATUS_VALIDATED :
$status_string = 'Validated' ;
break ;
case EVENT_STATUS_INPROCESS :
$status_string = 'In process' ;
break ;
default :
$status_string = '' ;
break ;
}
$alerts = [];
foreach ( $id_event as $k => $id ) {
if ( $meta ) {
$event_group = events_meta_get_group ( $id , $history );
$event = events_meta_get_event ( $id , false , $history );
$server_id = $event [ 'server_id' ];
} else {
$event_group = events_get_group ( $id );
$event = events_get_event ( $id );
}
if ( $event [ 'id_alert_am' ] > 0 && ! in_array ( $event [ 'id_alert_am' ], $alerts )) {
$alerts [] = $event [ 'id_alert_am' ];
}
if ( check_acl ( $config [ 'id_user' ], $event_group , 'EW' ) == 0 ) {
db_pandora_audit ( 'ACL Violation' , 'Attempted updating event #' . $id );
unset ( $id_event [ $k ]);
}
}
if ( empty ( $id_event )) {
return false ;
}
$values = [
'estado' => $new_status ,
'id_usuario' => $ack_user ,
'ack_utimestamp' => $ack_utimestamp ,
];
$ret = db_process_sql_update (
$event_table ,
$values ,
[ 'id_evento' => $id_event ]
);
if (( $ret === false ) || ( $ret === 0 )) {
return false ;
}
events_comment ( $id_event , '' , " Change status to $status_string " , $meta , $history );
if ( $meta && ! empty ( $alerts )) {
$server = metaconsole_get_connection_by_id ( $server_id );
metaconsole_connect ( $server );
}
// Put the alerts in standby or not depends the new status
foreach ( $alerts as $alert ) {
switch ( $new_status ) {
case EVENT_NEW :
case EVENT_VALIDATE :
alerts_agent_module_standby ( $alert , 0 );
break ;
case EVENT_PROCESS :
alerts_agent_module_standby ( $alert , 1 );
break ;
}
}
if ( $meta && ! empty ( $alerts )) {
metaconsole_restore_db ();
}
return true ;
2012-10-11 19:49:17 +02:00
}
2012-10-01 13:15:31 +02:00
2019-01-30 16:18:44 +01:00
2012-10-11 19:49:17 +02:00
/**
* Change the owner of an event if the event hasn ' t owner
*
* @ param mixed Event ID or array of events
* @ param string id_user of the new owner . If is false , the current owner will be setted
* @ param bool flag to force the change or not ( not force is change only when it hasn ' t owner )
2012-12-18 12:54:22 +01:00
* @ param bool metaconsole mode flag
2013-01-16 13:57:11 +01:00
* @ param bool history mode flag
2019-01-30 16:18:44 +01:00
*
* @ return boolean Whether or not it was successful
*/
function events_change_owner ( $id_event , $new_owner = false , $force = false , $meta = false , $history = false )
{
global $config ;
$event_table = events_get_events_table ( $meta , $history );
// Cleans up the selection for all unwanted values also casts any single values as an array
$id_event = ( array ) safe_int ( $id_event , 1 );
foreach ( $id_event as $k => $id ) {
if ( $meta ) {
$event_group = events_meta_get_group ( $id , $history );
} else {
$event_group = events_get_group ( $id );
}
if ( check_acl ( $config [ 'id_user' ], $event_group , 'EW' ) == 0 ) {
db_pandora_audit ( 'ACL Violation' , 'Attempted updating event #' . $id );
unset ( $id_event [ $k ]);
}
}
if ( empty ( $id_event )) {
return false ;
}
// If no new_owner is provided, the current user will be the owner
// ** Comment this lines because if possible selected None owner in owner event. TIQUET: #2250***
// if (empty($new_owner)) {
// $new_owner = $config['id_user'];
// }
// Only generate comment when is forced (sometimes is changed the owner when comment)
if ( $force ) {
events_comment ( $id_event , '' , " Change owner to $new_owner " , $meta , $history );
}
$values = [ 'owner_user' => $new_owner ];
$where = [ 'id_evento' => $id_event ];
// If not force, add to where if owner_user = ''
if ( ! $force ) {
$where [ 'owner_user' ] = '' ;
}
$ret = db_process_sql_update (
$event_table ,
$values ,
$where ,
'AND' ,
false
);
if (( $ret === false ) || ( $ret === 0 )) {
return false ;
}
return true ;
2012-10-01 13:15:31 +02:00
}
2019-01-30 16:18:44 +01:00
function events_get_events_table ( $meta , $history )
{
if ( $meta ) {
if ( $history ) {
$event_table = 'tmetaconsole_event_history' ;
} else {
$event_table = 'tmetaconsole_event' ;
}
} else {
$event_table = 'tevento' ;
}
return $event_table ;
2013-01-16 13:57:11 +01:00
}
2019-01-30 16:18:44 +01:00
2012-10-01 13:15:31 +02:00
/**
2012-10-09 18:05:32 +02:00
* Comment events in a transresponse
2012-10-01 13:15:31 +02:00
*
* @ param mixed Event ID or array of events
2012-10-11 19:49:17 +02:00
* @ param string comment to be registered
* @ param string action performed with the comment . Bu default just Added comment
2012-12-18 12:54:22 +01:00
* @ param bool Flag of metaconsole mode
2013-01-16 13:57:11 +01:00
* @ param bool Flag of history mode
2012-10-01 13:15:31 +02:00
*
2019-01-30 16:18:44 +01:00
* @ return boolean Whether or not it was successful
*/
function events_comment ( $id_event , $comment = '' , $action = 'Added comment' , $meta = false , $history = false , $similars = true )
{
global $config ;
$event_table = events_get_events_table ( $meta , $history );
// Cleans up the selection for all unwanted values also casts any single values as an array
$id_event = ( array ) safe_int ( $id_event , 1 );
foreach ( $id_event as $k => $id ) {
if ( $meta ) {
$event_group = events_meta_get_group ( $id , $history );
} else {
$event_group = events_get_group ( $id );
}
if ( check_acl ( $config [ 'id_user' ], $event_group , 'EW' ) == 0 ) {
db_pandora_audit ( 'ACL Violation' , 'Attempted updating event #' . $id );
unset ( $id_event [ $k ]);
}
}
if ( empty ( $id_event )) {
return false ;
}
// If the event hasn't owner, assign the user as owner
events_change_owner ( $id_event );
// Get the current event comments
$first_event = $id_event ;
if ( is_array ( $id_event )) {
$first_event = reset ( $id_event );
}
$event_comments = db_get_value ( 'user_comment' , $event_table , 'id_evento' , $first_event );
$event_comments_array = [];
if ( $event_comments == '' ) {
$comments_format = 'new' ;
} else {
// If comments are not stored in json, the format is old
$event_comments_array = json_decode ( $event_comments );
if ( is_null ( $event_comments_array )) {
$comments_format = 'old' ;
} else {
$comments_format = 'new' ;
}
}
switch ( $comments_format ) {
case 'new' :
$comment_for_json [ 'comment' ] = $comment ;
$comment_for_json [ 'action' ] = $action ;
$comment_for_json [ 'id_user' ] = $config [ 'id_user' ];
$comment_for_json [ 'utimestamp' ] = time ();
$event_comments_array [] = $comment_for_json ;
$event_comments = io_json_mb_encode ( $event_comments_array );
// Update comment
$ret = db_process_sql_update ( $event_table , [ 'user_comment' => $event_comments ], [ 'id_evento' => implode ( ',' , $id_event )]);
break ;
case 'old' :
// Give old ugly format to comment. TODO: Change this method for aux table or json
$comment = str_replace ([ " \r \n " , " \r " , " \n " ], '<br>' , $comment );
if ( $comment != '' ) {
$commentbox = '<div style="border:1px dotted #CCC; min-height: 10px;">' . $comment . '</div>' ;
} else {
$commentbox = '' ;
}
// Don't translate 'by' word because if various users with different languages
// make comments in the same console will be a mess
$comment = '<b>-- ' . $action . ' by ' . $config [ 'id_user' ] . ' ' . '[' . date ( $config [ 'date_format' ]) . '] --</b><br>' . $commentbox . '<br>' ;
// Update comment
switch ( $config [ 'dbtype' ]) {
// Oldstyle SQL to avoid innecesary PHP foreach
case 'mysql' :
$sql_validation = " UPDATE $event_table
SET user_comment = concat ( '".$comment."' , user_comment )
WHERE id_evento in ( " .implode(',', $id_event ).')';
$ret = db_process_sql ( $sql_validation );
break ;
case 'postgresql' :
case 'oracle' :
$sql_validation = " UPDATE $event_table
SET user_comment = '".$comment."' || user_comment )
WHERE id_evento in ( " .implode(',', $id_event ).')';
$ret = db_process_sql ( $sql_validation );
break ;
}
break ;
}
if (( $ret === false ) || ( $ret === 0 )) {
return false ;
}
return true ;
2008-11-14 16:37:32 +01:00
}
2019-01-30 16:18:44 +01:00
/**
2008-11-14 16:37:32 +01:00
* Get group id of an event .
2019-01-30 16:18:44 +01:00
*
* @ param integer $id_event Event id
*
* @ return integer Group id of the given event .
2008-11-14 16:37:32 +01:00
*/
2019-01-30 16:18:44 +01:00
function events_get_group ( $id_event )
{
return ( int ) db_get_value ( 'id_grupo' , 'tevento' , 'id_evento' , ( int ) $id_event );
2008-11-14 16:37:32 +01:00
}
2008-12-10 21:15:38 +01:00
2019-01-30 16:18:44 +01:00
/**
2008-12-10 21:15:38 +01:00
* Get description of an event .
2019-01-30 16:18:44 +01:00
*
* @ param integer $id_event Event id .
*
2009-01-08 16:52:13 +01:00
* @ return string Description of the given event .
2008-12-10 21:15:38 +01:00
*/
2019-01-30 16:18:44 +01:00
function events_get_description ( $id_event )
{
return ( string ) db_get_value ( 'evento' , 'tevento' , 'id_evento' , ( int ) $id_event );
2008-12-10 21:15:38 +01:00
}
2019-01-30 16:18:44 +01:00
/**
2008-12-10 21:15:38 +01:00
* Insert a event in the event log system .
*
2019-01-30 16:18:44 +01:00
* @ param integer $event
* @ param integer $id_group
* @ param integer $id_agent
* @ param integer $status
* @ param string $id_user
* @ param string $event_type
* @ param integer $priority
* @ param integer $id_agent_module
* @ param integer $id_aam
*
* @ return integer event id
2008-12-10 21:15:38 +01:00
*/
2019-01-30 16:18:44 +01:00
function events_create_event (
$event ,
$id_group ,
$id_agent ,
$status = 0 ,
$id_user = '' ,
$event_type = 'unknown' ,
$priority = 0 ,
$id_agent_module = 0 ,
$id_aam = 0 ,
$critical_instructions = '' ,
$warning_instructions = '' ,
$unknown_instructions = '' ,
$source = false ,
$tags = '' ,
$custom_data = '' ,
$server_id = 0 ,
$id_extra = ''
) {
global $config ;
if ( $source === false ) {
$source = get_product_name ();
}
$table_events = 'tevento' ;
if ( defined ( 'METACONSOLE' )) {
$table_events = 'tmetaconsole_event' ;
switch ( $config [ 'dbtype' ]) {
case 'mysql' :
$sql = sprintf (
'
INSERT INTO '.$table_events.' ( id_agente , id_grupo , evento ,
2014-12-15 19:38:05 +01:00
timestamp , estado , utimestamp , id_usuario ,
event_type , criticity , id_agentmodule , id_alert_am ,
critical_instructions , warning_instructions ,
unknown_instructions , source , tags , custom_data ,
2018-07-26 15:41:52 +02:00
server_id , id_extra , data , module_status )
2014-12-15 19:38:05 +01:00
VALUES ( % d , % d , " %s " , NOW (), % d , UNIX_TIMESTAMP ( NOW ()),
" %s " , " %s " , % d , % d , % d , " %s " , " %s " , " %s " , " %s " ,
2018-07-26 15:41:52 +02:00
" %s " , " %s " , % d , " %s " , % d , % d ) ' ,
2019-01-30 16:18:44 +01:00
$id_agent ,
$id_group ,
$event ,
$status ,
$id_user ,
$event_type ,
$priority ,
$id_agent_module ,
$id_aam ,
$critical_instructions ,
$warning_instructions ,
$unknown_instructions ,
$source ,
$tags ,
$custom_data ,
$server_id ,
$id_extra ,
$data ,
$module_status
);
break ;
case 'postgresql' :
$sql = sprintf (
'
INSERT INTO '.$table_events.' ( id_agente , id_grupo , evento ,
2014-12-15 19:38:05 +01:00
timestamp , estado , utimestamp , id_usuario ,
event_type , criticity , id_agentmodule , id_alert_am ,
critical_instructions , warning_instructions ,
unknown_instructions , source , tags , custom_data ,
2018-07-26 15:41:52 +02:00
server_id , id_extra , data , module_status )
2014-12-15 19:38:05 +01:00
VALUES ( % d , % d , " %s " , NOW (), % d ,
ceil ( date_part ( \ ' epoch\ ' , CURRENT_TIMESTAMP )), " %s " ,
" %s " , % d , % d , % d , " %s " , " %s " , " %s " , " %s " , " %s " ,
2018-07-26 15:41:52 +02:00
" %s " , % d , " %s " , % d , % d ) ' ,
2019-01-30 16:18:44 +01:00
$id_agent ,
$id_group ,
$event ,
$status ,
$id_user ,
$event_type ,
$priority ,
$id_agent_module ,
$id_aam ,
$critical_instructions ,
$warning_instructions ,
$unknown_instructions ,
$source ,
$tags ,
$custom_data ,
$server_id ,
$id_extra ,
$data ,
$module_status
);
break ;
case 'oracle' :
$sql = sprintf (
'
INSERT INTO '.$table_events.' ( id_agente , id_grupo , evento ,
2014-12-15 19:38:05 +01:00
timestamp , estado , utimestamp , id_usuario ,
event_type , criticity , id_agentmodule , id_alert_am ,
critical_instructions , warning_instructions ,
unknown_instructions , source , tags , custom_data ,
2018-07-26 15:41:52 +02:00
server_id , id_extra , data , module_status )
2015-05-25 19:53:20 +02:00
VALUES ( % d , % d , " %s " , CURRENT_TIMESTAMP , % d , UNIX_TIMESTAMP ,
2014-12-15 19:38:05 +01:00
" %s " , " %s " , % d , % d , % d , " %s " , " %s " , " %s " , " %s " ,
2018-07-26 15:41:52 +02:00
" %s " , " %s " , % d , " %s " , % d , % d ) ' ,
2019-01-30 16:18:44 +01:00
$id_agent ,
$id_group ,
$event ,
$status ,
$id_user ,
$event_type ,
$priority ,
$id_agent_module ,
$id_aam ,
$critical_instructions ,
$warning_instructions ,
$unknown_instructions ,
$source ,
$tags ,
$custom_data ,
$server_id ,
$id_extra ,
$data ,
$module_status
);
break ;
}
} else {
switch ( $config [ 'dbtype' ]) {
case 'mysql' :
$sql = sprintf (
'
INSERT INTO '.$table_events.' ( id_agente , id_grupo , evento ,
2014-12-15 19:38:05 +01:00
timestamp , estado , utimestamp , id_usuario ,
event_type , criticity , id_agentmodule , id_alert_am ,
critical_instructions , warning_instructions ,
2018-07-26 15:41:52 +02:00
unknown_instructions , source , tags , custom_data , id_extra , data , module_status )
2014-12-15 19:38:05 +01:00
VALUES ( % d , % d , " %s " , NOW (), % d , UNIX_TIMESTAMP ( NOW ()),
2018-07-26 15:41:52 +02:00
" %s " , " %s " , % d , % d , % d , " %s " , " %s " , " %s " , " %s " , " %s " , " %s " , " %s " , % d , % d ) ' ,
2019-01-30 16:18:44 +01:00
$id_agent ,
$id_group ,
$event ,
$status ,
$id_user ,
$event_type ,
$priority ,
$id_agent_module ,
$id_aam ,
$critical_instructions ,
$warning_instructions ,
$unknown_instructions ,
$source ,
$tags ,
$custom_data ,
$id_extra ,
$data ,
$module_status
);
break ;
case 'postgresql' :
$sql = sprintf (
'
INSERT INTO '.$table_events.' ( id_agente , id_grupo , evento ,
2014-12-15 19:38:05 +01:00
timestamp , estado , utimestamp , id_usuario ,
event_type , criticity , id_agentmodule , id_alert_am ,
critical_instructions , warning_instructions ,
2018-07-26 15:41:52 +02:00
unknown_instructions , source , tags , custom_data , id_extra , data , module_status )
2014-12-15 19:38:05 +01:00
VALUES ( % d , % d , " %s " , NOW (), % d ,
ceil ( date_part ( \ ' epoch\ ' , CURRENT_TIMESTAMP )), " %s " ,
2018-07-26 15:41:52 +02:00
" %s " , % d , % d , % d , " %s " , " %s " , " %s " , " %s " , " %s " , " %s " , " %s " , % d , % d ) ' ,
2019-01-30 16:18:44 +01:00
$id_agent ,
$id_group ,
$event ,
$status ,
$id_user ,
$event_type ,
$priority ,
$id_agent_module ,
$id_aam ,
$critical_instructions ,
$warning_instructions ,
$unknown_instructions ,
$source ,
$tags ,
$custom_data ,
$id_extra ,
$data ,
$module_status
);
break ;
case 'oracle' :
$sql = sprintf (
'
INSERT INTO ' . $table_events . " (id_agente, id_grupo, evento,
2014-12-15 19:38:05 +01:00
timestamp , estado , utimestamp , id_usuario ,
event_type , criticity , id_agentmodule , id_alert_am ,
critical_instructions , warning_instructions ,
2018-07-26 15:41:52 +02:00
unknown_instructions , source , tags , custom_data , id_extra , data , module_status )
2015-05-25 19:53:20 +02:00
VALUES ( % d , % d , '%s' , CURRENT_TIMESTAMP , % d , UNIX_TIMESTAMP ,
2018-07-26 15:41:52 +02:00
'%s' , '%s' , % d , % d , % d , '%s' , '%s' , '%s' , '%s' , '%s' , '%s' , '%s' , % d , % d ) " ,
2019-01-30 16:18:44 +01:00
$id_agent ,
$id_group ,
$event ,
$status ,
$id_user ,
$event_type ,
$priority ,
$id_agent_module ,
$id_aam ,
$critical_instructions ,
$warning_instructions ,
$unknown_instructions ,
$source ,
$tags ,
$custom_data ,
$id_extra ,
$data ,
$module_status
);
break ;
}
}
return ( int ) db_process_sql ( $sql , 'insert_id' );
2008-12-10 21:15:38 +01:00
}
2008-12-16 Evi Vanoost <vanooste@rcbi.rochester.edu>
* general/logon_ok.php, godmode/agentes/modificar_agente.php,
godmode/agentes/planned_downtime.php,
godmode/agentes/manage_recontask.php, godmode/setup/news.php,
operation/agentes/datos_agente.php, operation/agentes/estado_agente.php,
operation/agentes/status_events.php, operation/agentes/tactical.php,
operation/events/events.php, operation/incidents/incidents.php,
operation/incidents/incident_detail.php, operation/messages/message.php:
Function updates and new function definitions
* include/functions.php: safe_input used utf_decode which gives problems
with foreign chars since everything else is (or should be UTF-8) fixed.
format_datetime is no longer necessary - use print_timestamp for output.
Extended multibyte wrapper functions.
* include/functions_db.php: give_server_name is now get_server_name;
dame_so_name is now get_os_name; dame_so_icon is now print_os_icon;
show_icon_group is now print_group_icon; give_network_profile_name is now
get_networkprofile_name; smal_event_table is now print_events_table
* include/functions_events.php: print_events_table was moved here and
fixed. Now calculates the cutoff of event and agent text.
* include/functions_html.php: Added title to print_table function and
updated documentation. print_timestamp now uses the new function
definitions (array) and handles 0-dates better. print_group_icon and
print_os_icon added and extended. Added print_agent_name. This function
fixes issues that show up when cutting off agent names with multibyte char
* operation/servers/view_server.php: Rewrite with new functions
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1295 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2008-12-17 15:26:42 +01:00
2013-02-22 14:48:10 +01:00
2019-01-30 16:18:44 +01:00
/**
2008-12-16 Evi Vanoost <vanooste@rcbi.rochester.edu>
* general/logon_ok.php, godmode/agentes/modificar_agente.php,
godmode/agentes/planned_downtime.php,
godmode/agentes/manage_recontask.php, godmode/setup/news.php,
operation/agentes/datos_agente.php, operation/agentes/estado_agente.php,
operation/agentes/status_events.php, operation/agentes/tactical.php,
operation/events/events.php, operation/incidents/incidents.php,
operation/incidents/incident_detail.php, operation/messages/message.php:
Function updates and new function definitions
* include/functions.php: safe_input used utf_decode which gives problems
with foreign chars since everything else is (or should be UTF-8) fixed.
format_datetime is no longer necessary - use print_timestamp for output.
Extended multibyte wrapper functions.
* include/functions_db.php: give_server_name is now get_server_name;
dame_so_name is now get_os_name; dame_so_icon is now print_os_icon;
show_icon_group is now print_group_icon; give_network_profile_name is now
get_networkprofile_name; smal_event_table is now print_events_table
* include/functions_events.php: print_events_table was moved here and
fixed. Now calculates the cutoff of event and agent text.
* include/functions_html.php: Added title to print_table function and
updated documentation. print_timestamp now uses the new function
definitions (array) and handles 0-dates better. print_group_icon and
print_os_icon added and extended. Added print_agent_name. This function
fixes issues that show up when cutting off agent names with multibyte char
* operation/servers/view_server.php: Rewrite with new functions
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1295 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2008-12-17 15:26:42 +01:00
* Prints a small event table
2019-01-30 16:18:44 +01:00
*
* @ param string $filter SQL WHERE clause
* @ param integer $limit How many events to show
* @ param integer $width How wide the table should be
* @ param boolean $return Prints out HTML if false
2013-03-01 14:22:29 +01:00
* @ param int agent id if is the table of one agent . 0 otherwise
2019-01-30 16:18:44 +01:00
*
* @ return string HTML with table element
2008-12-16 Evi Vanoost <vanooste@rcbi.rochester.edu>
* general/logon_ok.php, godmode/agentes/modificar_agente.php,
godmode/agentes/planned_downtime.php,
godmode/agentes/manage_recontask.php, godmode/setup/news.php,
operation/agentes/datos_agente.php, operation/agentes/estado_agente.php,
operation/agentes/status_events.php, operation/agentes/tactical.php,
operation/events/events.php, operation/incidents/incidents.php,
operation/incidents/incident_detail.php, operation/messages/message.php:
Function updates and new function definitions
* include/functions.php: safe_input used utf_decode which gives problems
with foreign chars since everything else is (or should be UTF-8) fixed.
format_datetime is no longer necessary - use print_timestamp for output.
Extended multibyte wrapper functions.
* include/functions_db.php: give_server_name is now get_server_name;
dame_so_name is now get_os_name; dame_so_icon is now print_os_icon;
show_icon_group is now print_group_icon; give_network_profile_name is now
get_networkprofile_name; smal_event_table is now print_events_table
* include/functions_events.php: print_events_table was moved here and
fixed. Now calculates the cutoff of event and agent text.
* include/functions_html.php: Added title to print_table function and
updated documentation. print_timestamp now uses the new function
definitions (array) and handles 0-dates better. print_group_icon and
print_os_icon added and extended. Added print_agent_name. This function
fixes issues that show up when cutting off agent names with multibyte char
* operation/servers/view_server.php: Rewrite with new functions
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1295 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2008-12-17 15:26:42 +01:00
*/
2019-01-30 16:18:44 +01:00
function events_print_event_table ( $filter = '' , $limit = 10 , $width = 440 , $return = false , $agent_id = 0 , $tactical_view = false )
{
global $config ;
if ( $agent_id == 0 ) {
$agent_condition = '' ;
} else {
$agent_condition = " id_agente = $agent_id AND " ;
}
if ( $filter == '' ) {
$filter = '1 = 1' ;
}
$secondary_join = 'LEFT JOIN tagent_secondary_group tasg ON tevento.id_agente = tasg.id_agent' ;
$sql = sprintf (
' SELECT DISTINCT tevento .*
2018-11-22 10:39:48 +01:00
FROM tevento % s
2018-10-15 12:23:51 +02:00
WHERE % s % s
2019-01-30 16:18:44 +01:00
ORDER BY utimestamp DESC LIMIT % d ' ,
$secondary_join ,
$agent_condition ,
$filter ,
$limit
);
$result = db_get_all_rows_sql ( $sql );
if ( $result === false ) {
if ( $return ) {
$returned = ui_print_info_message ( __ ( 'No events' ), '' , true );
return $returned ;
} else {
echo ui_print_info_message ( __ ( 'No events' ));
}
} else {
$table = new stdClass ();
$table -> id = 'latest_events_table' ;
$table -> cellpadding = 0 ;
$table -> cellspacing = 0 ;
$table -> width = $width ;
$table -> class = 'databox data' ;
if ( ! $tactical_view ) {
$table -> title = __ ( 'Latest events' );
}
$table -> titleclass = 'tabletitle' ;
$table -> titlestyle = 'text-transform:uppercase;' ;
$table -> headclass = [];
$table -> head = [];
$table -> rowclass = [];
$table -> cellclass = [];
$table -> data = [];
$table -> align = [];
$table -> style [ 0 ] = $table -> style [ 1 ] = $table -> style [ 2 ] = 'width:25px;' ;
if ( $agent_id == 0 ) {
$table -> style [ 3 ] = 'word-break: break-all;' ;
}
$table -> style [ 4 ] = 'width:120px; word-break: break-all;' ;
$table -> head [ 0 ] = " <span title=' " . __ ( 'Validated' ) . " '> " . __ ( 'V.' ) . '</span>' ;
$table -> align [ 0 ] = 'center' ;
$table -> head [ 1 ] = " <span title=' " . __ ( 'Severity' ) . " '> " . __ ( 'S.' ) . '</span>' ;
$table -> align [ 1 ] = 'center' ;
$table -> head [ 2 ] = __ ( 'Type' );
$table -> headclass [ 2 ] = 'datos3 f9' ;
$table -> align [ 2 ] = 'center' ;
$table -> head [ 3 ] = __ ( 'Event name' );
if ( $agent_id == 0 ) {
$table -> head [ 4 ] = __ ( 'Agent name' );
$table -> size [ 4 ] = '15%' ;
}
$table -> head [ 5 ] = __ ( 'Timestamp' );
$table -> headclass [ 5 ] = 'datos3 f9' ;
$table -> align [ 5 ] = 'left' ;
$table -> size [ 5 ] = '15%' ;
$all_groups = [];
if ( $agent_id != 0 ) {
$all_groups = agents_get_all_groups_agent ( $agent_id );
}
foreach ( $result as $event ) {
// Copy all groups of the agent and append the event group
$check_events = $all_groups ;
$check_events [] = $event [ 'id_grupo' ];
if ( ! check_acl_one_of_groups ( $config [ 'id_user' ], $check_events , 'ER' )) {
continue ;
}
$data = [];
// Colored box
switch ( $event [ 'estado' ]) {
case 0 :
$img = 'images/star.png' ;
$title = __ ( 'New event' );
break ;
case 1 :
$img = 'images/tick.png' ;
$title = __ ( 'Event validated' );
break ;
case 2 :
$img = 'images/hourglass.png' ;
$title = __ ( 'Event in process' );
break ;
}
$data [ 0 ] = html_print_image (
$img ,
true ,
[
'class' => 'image_status' ,
'title' => $title ,
]
);
switch ( $event [ 'criticity' ]) {
default :
case EVENT_CRIT_MAINTENANCE :
$img = 'images/status_sets/default/severity_maintenance.png' ;
break ;
case EVENT_CRIT_INFORMATIONAL :
$img = 'images/status_sets/default/severity_informational.png' ;
break ;
case EVENT_CRIT_NORMAL :
$img = 'images/status_sets/default/severity_normal.png' ;
break ;
case EVENT_CRIT_WARNING :
$img = 'images/status_sets/default/severity_warning.png' ;
break ;
case EVENT_CRIT_CRITICAL :
$img = 'images/status_sets/default/severity_critical.png' ;
break ;
}
$data [ 1 ] = html_print_image (
$img ,
true ,
[
'class' => 'image_status' ,
'width' => 12 ,
'height' => 12 ,
'title' => get_priority_name ( $event [ 'criticity' ]),
]
);
// Event type
$data [ 2 ] = events_print_type_img ( $event [ 'event_type' ], true );
// Event text
$data [ 3 ] = ui_print_string_substr ( strip_tags ( io_safe_output ( $event [ 'evento' ])), 75 , true , '7.5' );
if ( $agent_id == 0 ) {
if ( $event [ 'id_agente' ] > 0 ) {
// Agent name
// Get class name, for the link color...
$myclass = get_priority_class ( $event [ 'criticity' ]);
$data [ 4 ] = " <a class=' $myclass ' href='index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente= " . $event [ 'id_agente' ] . " '> " . agents_get_alias ( $event [ 'id_agente' ]) . '</A>' ;
// for System or SNMP generated alerts
} else if ( $event [ 'event_type' ] == 'system' ) {
$data [ 4 ] = __ ( 'System' );
} else {
$data [ 4 ] = __ ( 'Alert' ) . 'SNMP' ;
}
}
// Timestamp
$data [ 5 ] = ui_print_timestamp ( $event [ 'timestamp' ], true , [ 'style' => 'font-size: 7.5pt; letter-spacing: 0.3pt;' ]);
$class = get_priority_class ( $event [ 'criticity' ]);
$cell_classes [ 3 ] = $cell_classes [ 4 ] = $cell_classes [ 5 ] = $class ;
array_push ( $table -> cellclass , $cell_classes );
// array_push ($table->rowclass, get_priority_class ($event["criticity"]));
array_push ( $table -> data , $data );
}
$events_table = html_print_table ( $table , true );
$out = '<table width="100%"><tr><td style="width: 90%; vertical-align: top; padding-top: 0px;">' ;
$out .= $events_table ;
if ( ! $tactical_view ) {
if ( $agent_id != 0 ) {
$out .= '</td><td style="width: 200px; vertical-align: top;">' ;
$out .= '<table cellpadding=0 cellspacing=0 class="databox"><tr><td>' ;
$out .= ' < fieldset class = " databox tactical_set " >
< legend > '.__(' Events - by module - ').' </ legend > '.graph_event_module(180, 100, $event[' id_agente ']).' </ fieldset > ' ;
$out .= '</td></tr></table>' ;
} else {
$out .= '</td><td style="width: 200px; vertical-align: top;">' ;
$out .= '<table cellpadding=0 cellspacing=0 class="databox"><tr><td>' ;
$out .= ' < fieldset class = " databox tactical_set " >
< legend > '.__(' Event graph ').' </ legend > '.grafico_eventos_total(' ', 180, 60).' </ fieldset > ' ;
$out .= ' < fieldset class = " databox tactical_set " >
< legend > '.__(' Event graph by agent ').' </ legend > '.grafico_eventos_grupo(180, 60).' </ fieldset > ' ;
$out .= '</td></tr></table>' ;
}
}
$out .= '</td></tr></table>' ;
unset ( $table );
if ( $return ) {
return $out ;
} else {
echo $out ;
}
}
2008-12-16 Evi Vanoost <vanooste@rcbi.rochester.edu>
* general/logon_ok.php, godmode/agentes/modificar_agente.php,
godmode/agentes/planned_downtime.php,
godmode/agentes/manage_recontask.php, godmode/setup/news.php,
operation/agentes/datos_agente.php, operation/agentes/estado_agente.php,
operation/agentes/status_events.php, operation/agentes/tactical.php,
operation/events/events.php, operation/incidents/incidents.php,
operation/incidents/incident_detail.php, operation/messages/message.php:
Function updates and new function definitions
* include/functions.php: safe_input used utf_decode which gives problems
with foreign chars since everything else is (or should be UTF-8) fixed.
format_datetime is no longer necessary - use print_timestamp for output.
Extended multibyte wrapper functions.
* include/functions_db.php: give_server_name is now get_server_name;
dame_so_name is now get_os_name; dame_so_icon is now print_os_icon;
show_icon_group is now print_group_icon; give_network_profile_name is now
get_networkprofile_name; smal_event_table is now print_events_table
* include/functions_events.php: print_events_table was moved here and
fixed. Now calculates the cutoff of event and agent text.
* include/functions_html.php: Added title to print_table function and
updated documentation. print_timestamp now uses the new function
definitions (array) and handles 0-dates better. print_group_icon and
print_os_icon added and extended. Added print_agent_name. This function
fixes issues that show up when cutting off agent names with multibyte char
* operation/servers/view_server.php: Rewrite with new functions
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1295 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2008-12-17 15:26:42 +01:00
}
2009-02-20 22:48:09 +01:00
2019-01-30 16:18:44 +01:00
/**
2009-02-20 22:48:09 +01:00
* Prints the event type image
2019-01-30 16:18:44 +01:00
*
* @ param string $type Event type from SQL
* @ param boolean $return Whether to return or print
* @ param boolean $only_url Flag to return only url of image , by default false .
*
* @ return string HTML with img
2009-02-20 22:48:09 +01:00
*/
2019-01-30 16:18:44 +01:00
function events_print_type_img ( $type , $return = false , $only_url = false )
{
global $config ;
$output = '' ;
$urlImage = ui_get_full_url ( false );
switch ( $type ) {
case 'alert_recovered' :
$icon = 'bell.png' ;
break ;
case 'alert_manual_validation' :
$icon = 'ok.png' ;
break ;
case 'going_down_critical' :
case 'going_up_critical' :
// This is to be backwards compatible
$icon = 'module_critical.png' ;
break ;
case 'going_up_normal' :
case 'going_down_normal' :
// This is to be backwards compatible
$icon = 'module_ok.png' ;
break ;
case 'going_up_warning' :
case 'going_down_warning' :
$icon = 'module_warning.png' ;
break ;
case 'going_unknown' :
$icon = 'module_unknown.png' ;
break ;
case 'alert_fired' :
$icon = 'bell_error.png' ;
break ;
case 'system' :
$icon = 'cog.png' ;
break ;
case 'recon_host_detected' :
$icon = 'recon.png' ;
break ;
case 'new_agent' :
$icon = 'agent.png' ;
break ;
case 'configuration_change' :
$icon = 'config.png' ;
break ;
case 'unknown' :
default :
$icon = 'lightning_go.png' ;
break ;
}
if ( $only_url ) {
$output = $urlImage . '/' . 'images/' . $icon ;
} else {
$output .= html_print_image (
'images/' . $icon ,
true ,
[ 'title' => events_print_type_description ( $type , true )]
);
}
if ( $return ) {
return $output ;
}
echo $output ;
2010-09-17 14:34:11 +02:00
}
2019-01-30 16:18:44 +01:00
/**
2010-09-17 14:34:11 +02:00
* Prints the event type description
2019-01-30 16:18:44 +01:00
*
* @ param string $type Event type from SQL
* @ param boolean $return Whether to return or print
*
* @ return string HTML with img
2010-09-17 14:34:11 +02:00
*/
2019-01-30 16:18:44 +01:00
function events_print_type_description ( $type , $return = false )
{
$output = '' ;
switch ( $type ) {
case 'going_unknown' :
$output .= __ ( 'Going to unknown' );
break ;
case 'alert_recovered' :
$output .= __ ( 'Alert recovered' );
break ;
case 'alert_manual_validation' :
$output .= __ ( 'Alert manually validated' );
break ;
case 'going_up_warning' :
$output .= __ ( 'Going from critical to warning' );
break ;
case 'going_down_critical' :
case 'going_up_critical' :
// This is to be backwards compatible
$output .= __ ( 'Going up to critical state' );
break ;
case 'going_up_normal' :
case 'going_down_normal' :
// This is to be backwards compatible
$output .= __ ( 'Going up to normal state' );
break ;
case 'going_down_warning' :
$output .= __ ( 'Going down from normal to warning' );
break ;
case 'alert_fired' :
$output .= __ ( 'Alert fired' );
break ;
case 'system' ;
$output .= __ ( 'SYSTEM' );
break ;
case 'recon_host_detected' ;
$output .= __ ( 'Recon server detected a new host' );
break ;
case 'new_agent' ;
$output .= __ ( 'New agent created' );
break ;
case 'configuration_change' ;
$output .= __ ( 'Configuration change' );
break ;
case 'alert_ceased' ;
$output .= __ ( 'Alert ceased' );
break ;
case 'error' ;
$output .= __ ( 'Error' );
break ;
case 'unknown' :
default :
$output .= __ ( 'Unknown type:' ) . ': ' . $type ;
break ;
}
if ( $return ) {
return $output ;
}
echo $output ;
2009-02-20 22:48:09 +01:00
}
* 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
2013-02-05 15:46:16 +01:00
/**
* Get all the events happened in a group during a period of time .
*
* The returned events will be in the time interval ( $date - $period , $date ]
*
2019-01-30 16:18:44 +01:00
* @ param mixed $id_group Group id to get events for .
* @ param integer $period Period of time in seconds to get events .
* @ param integer $date Beginning date to get events .
2013-02-05 15:46:16 +01:00
*
* @ return array An array with all the events happened .
*/
2019-01-30 16:18:44 +01:00
function events_get_group_events_steps (
$begin ,
& $result ,
$id_group ,
$period ,
$date ,
$filter_event_validated = false ,
$filter_event_critical = false ,
$filter_event_warning = false ,
$filter_event_no_validated = false
) {
global $config ;
$id_group = groups_safe_acl ( $config [ 'id_user' ], $id_group , 'ER' );
if ( empty ( $id_group )) {
// An empty array means the user doesn't have access
return false ;
}
$datelimit = ( $date - $period );
$sql_where = ' AND 1 = 1 ' ;
$criticities = [];
if ( $filter_event_critical ) {
$criticities [] = 4 ;
}
if ( $filter_event_warning ) {
$criticities [] = 3 ;
}
if ( ! empty ( $criticities )) {
$sql_where .= ' AND criticity IN (' . implode ( ', ' , $criticities ) . ')' ;
}
if ( $filter_event_validated ) {
$sql_where .= ' AND estado = 1 ' ;
}
if ( $filter_event_no_validated ) {
$sql_where .= ' AND estado = 0 ' ;
}
$sql = sprintf (
' SELECT * ,
2013-04-18 11:25:23 +02:00
( SELECT t2 . nombre
2015-05-04 18:27:23 +02:00
FROM tagente t2
2013-04-18 11:25:23 +02:00
WHERE t2 . id_agente = t3 . id_agente ) AS agent_name ,
( SELECT t2 . fullname
2015-05-04 18:27:23 +02:00
FROM tusuario t2
2013-04-18 11:25:23 +02:00
WHERE t2 . id_user = t3 . id_usuario ) AS user_name
2015-05-04 18:27:23 +02:00
FROM tevento t3
2013-02-05 15:46:16 +01:00
WHERE utimestamp > % d AND utimestamp <= % d
2019-01-30 16:18:44 +01:00
AND id_grupo IN ( % s ) '.$sql_where.'
2013-02-05 15:46:16 +01:00
ORDER BY utimestamp ASC ' ,
2019-01-30 16:18:44 +01:00
$datelimit ,
$date ,
implode ( ',' , $id_group )
);
return db_get_all_row_by_steps_sql ( $begin , $result , $sql );
2013-02-05 15:46:16 +01:00
}
2019-01-30 16:18:44 +01:00
* 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
/**
* Get all the events happened in an Agent during a period of time .
*
* The returned events will be in the time interval ( $date - $period , $date ]
*
2019-01-30 16:18:44 +01:00
* @ param integer $id_agent Agent id to get events .
* @ param integer $period Period of time in seconds to get events .
* @ param integer $date Beginning date to get events .
* 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
*
* @ return array An array with all the events happened .
*/
2019-01-30 16:18:44 +01:00
function events_get_agent (
$id_agent ,
$period ,
$date = 0 ,
$history = false ,
$show_summary_group = false ,
$filter_event_severity = false ,
$filter_event_type = false ,
$filter_event_status = false ,
$filter_event_filter_search = false ,
$id_group = false ,
$events_group = false ,
$id_agent_module = false ,
$events_module = false ,
$id_server = false
) {
global $config ;
if ( ! is_numeric ( $date )) {
$date = time_w_fixed_tz ( $date );
}
if ( empty ( $date )) {
$date = get_system_time ();
}
if ( $events_group ) {
$id_group = groups_safe_acl ( $config [ 'id_user' ], $id_group , 'ER' );
if ( empty ( $id_group )) {
// An empty array means the user doesn't have access
return false ;
}
}
$datelimit = ( $date - $period );
$sql_where = '' ;
$severity_all = 0 ;
if ( ! empty ( $filter_event_severity )) {
foreach ( $filter_event_severity as $key => $value ) {
switch ( $value ) {
case - 1 :
$severity_all = 1 ;
break ;
case 34 :
$filter_event_severity [ $key ] = '3, 4' ;
break ;
case 20 :
$filter_event_severity [ $key ] = '0, 1, 3, 4, 5, 6' ;
break ;
case 21 :
$filter_event_severity [ $key ] = '4, 2' ;
break ;
default :
break ;
}
}
if ( ! $severity_all ) {
$sql_where .= ' AND criticity IN (' . implode ( ', ' , $filter_event_severity ) . ')' ;
}
}
$status_all = 0 ;
if ( ! empty ( $filter_event_status )) {
foreach ( $filter_event_status as $key => $value ) {
switch ( $value ) {
case - 1 :
$status_all = 1 ;
break ;
case 3 :
$filter_event_status [ $key ] = ( '0, 2' );
default :
break ;
}
}
if ( ! $status_all ) {
$sql_where .= ' AND estado IN (' . implode ( ', ' , $filter_event_status ) . ')' ;
}
}
if ( ! empty ( $filter_event_type ) && $filter_event_type [ 0 ] != 'all' ) {
$sql_where .= ' AND (' ;
$type = [];
foreach ( $filter_event_type as $event_type ) {
if ( $event_type != '' ) {
// If normal, warning, could be several (going_up_warning, going_down_warning... too complex
// for the user so for him is presented only "warning, critical and normal"
if ( $event_type == 'warning' || $event_type == 'critical' || $event_type == 'normal' ) {
$type [] = " event_type LIKE '% $event_type %' " ;
} else if ( $event_type == 'not_normal' ) {
$type [] = " (event_type LIKE '%warning%' OR event_type LIKE '%critical%' OR event_type LIKE '%unknown%') " ;
} else if ( $event_type != 'all' ) {
$type [] = " event_type = ' " . $event_type . " ' " ;
}
}
}
$sql_where .= implode ( ' OR ' , $type ) . ')' ;
}
if ( ! empty ( $filter_event_filter_search )) {
$sql_where .= ' AND (evento LIKE "%' . io_safe_input ( $filter_event_filter_search ) . '%"' . ' OR id_evento LIKE "%' . io_safe_input ( $filter_event_filter_search ) . '%")' ;
}
if ( $events_group ) {
$sql_where .= sprintf (
' AND id_grupo IN ( % s ) AND utimestamp > % d
AND utimestamp <= % d ' ,
implode ( ',' , $id_group ),
$datelimit ,
$date
);
} else if ( $events_module ) {
$sql_where .= sprintf (
' AND id_agentmodule = % d AND utimestamp > % d
AND utimestamp <= % d ' ,
$id_agent_module ,
$datelimit ,
$date
);
} else {
$sql_where .= sprintf (
' AND id_agente = % d AND utimestamp > % d
AND utimestamp <= % d ' ,
$id_agent ,
$datelimit ,
$date
);
}
if ( is_metaconsole () && $id_server ) {
$sql_where .= ' AND server_id = ' . $id_server ;
}
if ( $show_summary_group ) {
return events_get_events_grouped (
$sql_where ,
0 ,
1000 ,
is_metaconsole (),
false ,
false ,
$history
);
} else {
return events_get_events_no_grouped (
$sql_where ,
0 ,
1000 ,
is_metaconsole (),
false ,
false ,
$history
);
}
* 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
2012-02-08 14:04:18 +01:00
/**
* Decode a numeric type into type description .
*
2019-01-30 16:18:44 +01:00
* @ param integer $type_id Numeric type .
2012-02-08 14:04:18 +01:00
*
* @ return string Type description .
*/
2019-01-30 16:18:44 +01:00
function events_get_event_types ( $type_id )
{
$diferent_types = get_event_types ();
$type_desc = '' ;
switch ( $type_id ) {
case 'unknown' :
$type_desc = __ ( 'Unknown' );
break ;
case 'critical' :
$type_desc = __ ( 'Monitor Critical' );
break ;
case 'warning' :
$type_desc = __ ( 'Monitor Warning' );
break ;
case 'normal' :
$type_desc = __ ( 'Monitor Normal' );
break ;
case 'alert_fired' :
$type_desc = __ ( 'Alert fired' );
break ;
case 'alert_recovered' :
$type_desc = __ ( 'Alert recovered' );
break ;
case 'alert_ceased' :
$type_desc = __ ( 'Alert ceased' );
break ;
case 'alert_manual_validation' :
$type_desc = __ ( 'Alert manual validation' );
break ;
case 'recon_host_detected' :
$type_desc = __ ( 'Recon host detected' );
break ;
case 'system' :
$type_desc = __ ( 'System' );
break ;
case 'error' :
$type_desc = __ ( 'Error' );
break ;
case 'configuration_change' :
$type_desc = __ ( 'Configuration change' );
break ;
case 'not_normal' :
$type_desc = __ ( 'Not normal' );
break ;
default :
if ( isset ( $config [ 'text_char_long' ])) {
foreach ( $diferent_types as $key => $type ) {
if ( $key == $type_id ) {
$type_desc = ui_print_truncate_text ( $type , $config [ 'text_char_long' ], false , true , false );
}
}
}
break ;
}
return $type_desc ;
}
2012-02-08 14:04:18 +01:00
/**
* Decode a numeric severity into severity description .
*
2019-01-30 16:18:44 +01:00
* @ param integer $severity_id Numeric severity .
2012-02-08 14:04:18 +01:00
*
* @ return string Severity description .
*/
2019-01-30 16:18:44 +01:00
function events_get_severity_types ( $severity_id )
{
$diferent_types = get_priorities ();
$severity_desc = '' ;
switch ( $severity_id ) {
case EVENT_CRIT_MAINTENANCE :
$severity_desc = __ ( 'Maintenance' );
break ;
case EVENT_CRIT_INFORMATIONAL :
$severity_desc = __ ( 'Informational' );
break ;
case EVENT_CRIT_NORMAL :
$severity_desc = __ ( 'Normal' );
break ;
case EVENT_CRIT_WARNING :
$severity_desc = __ ( 'Warning' );
break ;
case EVENT_CRIT_CRITICAL :
$severity_desc = __ ( 'Critical' );
break ;
default :
if ( isset ( $config [ 'text_char_long' ])) {
foreach ( $diferent_types as $key => $type ) {
if ( $key == $severity_id ) {
$severity_desc = ui_print_truncate_text (
$type ,
$config [ 'text_char_long' ],
false ,
true ,
false
);
}
}
}
break ;
}
return $severity_desc ;
}
2012-02-08 14:04:18 +01:00
/**
* Return all descriptions of event status .
*
* @ return array Status description array .
*/
2019-01-30 16:18:44 +01:00
function events_get_all_status ( $report = false )
{
$fields = [];
if ( ! $report ) {
$fields [ - 1 ] = __ ( 'All event' );
$fields [ 0 ] = __ ( 'Only new' );
$fields [ 1 ] = __ ( 'Only validated' );
$fields [ 2 ] = __ ( 'Only in process' );
$fields [ 3 ] = __ ( 'Only not validated' );
} else {
$fields [ - 1 ] = __ ( 'All event' );
$fields [ 0 ] = __ ( 'New' );
$fields [ 1 ] = __ ( 'Validated' );
$fields [ 2 ] = __ ( 'In process' );
$fields [ 3 ] = __ ( 'Not Validated' );
}
return $fields ;
2018-08-31 16:25:12 +02:00
}
2019-01-30 16:18:44 +01:00
2012-02-08 14:04:18 +01:00
/**
* Decode a numeric status into status description .
*
2019-01-30 16:18:44 +01:00
* @ param integer $status_id Numeric status .
2012-02-08 14:04:18 +01:00
*
* @ return string Status description .
*/
2019-01-30 16:18:44 +01:00
function events_get_status ( $status_id )
{
switch ( $status_id ) {
case - 1 :
$status_desc = __ ( 'All event' );
break ;
case 0 :
$status_desc = __ ( 'Only new' );
break ;
case 1 :
$status_desc = __ ( 'Only validated' );
break ;
case 2 :
$status_desc = __ ( 'Only in process' );
break ;
case 3 :
$status_desc = __ ( 'Only not validated' );
break ;
}
return $status_desc ;
2012-02-08 14:04:18 +01:00
}
2019-01-30 16:18:44 +01:00
2012-02-08 14:04:18 +01:00
/**
* Checks if a user has permissions to see an event filter .
*
2019-01-30 16:18:44 +01:00
* @ param integer $id_filter Id of the event filter .
2012-02-08 14:04:18 +01:00
*
2019-01-30 16:18:44 +01:00
* @ return boolean True if the user has permissions or false otherwise .
2012-02-08 14:04:18 +01:00
*/
2019-01-30 16:18:44 +01:00
function events_check_event_filter_group ( $id_filter )
{
global $config ;
$id_group = db_get_value ( 'id_group_filter' , 'tevent_filter' , 'id_filter' , $id_filter );
$own_info = get_user_info ( $config [ 'id_user' ]);
// Get group list that user has access
$groups_user = users_get_groups ( $config [ 'id_user' ], 'EW' , $own_info [ 'is_admin' ], true );
// Permissions in any group allow to edit "All group" filters
if ( $id_group == 0 && ! empty ( $groups_user )) {
return true ;
}
$groups_id = [];
$has_permission = false ;
foreach ( $groups_user as $key => $groups ) {
if ( $groups [ 'id_grupo' ] == $id_group ) {
return true ;
}
}
return false ;
2012-02-08 14:04:18 +01:00
}
2019-01-30 16:18:44 +01:00
2012-02-08 14:04:18 +01:00
/**
* Get a event filter .
2019-01-30 16:18:44 +01:00
*
2012-02-08 14:04:18 +01:00
* @ param int Filter id to be fetched .
* @ param array Extra filter .
* @ param array Fields to be fetched .
*
* @ return array A event filter matching id and filter or false .
*/
2019-01-30 16:18:44 +01:00
function events_get_event_filter ( $id_filter , $filter = false , $fields = false )
{
if ( empty ( $id_filter )) {
return false ;
}
if ( ! is_array ( $filter )) {
$filter = [];
$filter [ 'id_filter' ] = ( int ) $id_filter ;
}
return db_get_row_filter ( 'tevent_filter' , $filter , $fields );
2012-02-08 14:04:18 +01:00
}
2019-01-30 16:18:44 +01:00
2012-02-08 14:04:18 +01:00
/**
* Get a event filters in select format .
*
2019-01-30 16:18:44 +01:00
* @ param boolean If event filters are used for manage / view operations ( non admin users can see group ALL for manage ) # Fix
2012-02-08 14:04:18 +01:00
* @ return array A event filter matching id and filter or false .
*/
2019-01-30 16:18:44 +01:00
function events_get_event_filter_select ( $manage = true )
{
global $config ;
$strict_acl = db_get_value ( 'strict_acl' , 'tusuario' , 'id_user' , $config [ 'id_user' ]);
if ( $strict_acl ) {
$user_groups = users_get_strict_mode_groups (
$config [ 'id_user' ],
users_can_manage_group_all ()
);
} else {
$user_groups = users_get_groups (
$config [ 'id_user' ],
'EW' ,
users_can_manage_group_all (),
true
);
}
if ( empty ( $user_groups )) {
return [];
}
$sql = '
2015-03-23 14:17:06 +01:00
SELECT id_filter , id_name
FROM tevent_filter
2019-01-30 16:18:44 +01:00
WHERE id_group_filter IN ( '.implode(' , ', array_keys($user_groups)).' ) ' ;
$event_filters = db_get_all_rows_sql ( $sql );
if ( $event_filters === false ) {
return [];
} else {
$result = [];
foreach ( $event_filters as $event_filter ) {
$result [ $event_filter [ 'id_filter' ]] = $event_filter [ 'id_name' ];
}
}
return $result ;
2012-02-08 14:04:18 +01:00
}
2012-10-09 18:05:32 +02:00
// Events pages functions to load modal window with advanced view of an event.
// Called from include/ajax/events.php
2019-01-30 16:18:44 +01:00
function events_page_responses ( $event , $childrens_ids = [])
{
global $config ;
//
// Responses
//
$table_responses -> cellspacing = 2 ;
$table_responses -> cellpadding = 2 ;
$table_responses -> id = 'responses_table' ;
$table_responses -> width = '100%' ;
$table_responses -> data = [];
$table_responses -> head = [];
$table_responses -> style [ 0 ] = 'width:35%; font-weight: bold; text-align: left; height: 23px;' ;
$table_responses -> style [ 1 ] = 'text-align: left; height: 23px; text-align: right;' ;
$table_responses -> class = 'alternate rounded_cells' ;
if ( tags_checks_event_acl ( $config [ 'id_user' ], $event [ 'id_grupo' ], 'EM' , $event [ 'clean_tags' ], $childrens_ids )) {
// Owner
$data = [];
$data [ 0 ] = __ ( 'Change owner' );
// Owner change can be done to users that belong to the event group with ER permission
$profiles_view_events = db_get_all_rows_filter ( 'tperfil' , [ 'event_view' => '1' ], 'id_perfil' );
foreach ( $profiles_view_events as $k => $v ) {
$profiles_view_events [ $k ] = reset ( $v );
}
// Juanma (05/05/2014) Fix : Propagate ACL hell!
$_user_groups = array_keys ( users_get_groups ( $config [ 'id_user' ], 'ER' , users_can_manage_group_all ()));
$strict_user = db_get_value ( 'strict_acl' , 'tusuario' , 'id_user' , $config [ 'id_user' ]);
if ( $strict_user ) {
$user_name = db_get_value ( 'fullname' , 'tusuario' , 'id_user' , $config [ 'id_user' ]);
$users = [];
$users [ 0 ][ 'id_user' ] = $config [ 'id_user' ];
$users [ 0 ][ 'fullname' ] = $user_name ;
} else {
$users = groups_get_users ( $_user_groups , [ 'id_perfil' => $profiles_view_events ], true );
}
foreach ( $users as $u ) {
$owners [ $u [ 'id_user' ]] = $u [ 'fullname' ];
}
if ( $event [ 'owner_user' ] == '' ) {
$owner_name = __ ( 'None' );
} else {
$owner_name = db_get_value ( 'fullname' , 'tusuario' , 'id_user' , $event [ 'owner_user' ]);
$owners [ $event [ 'owner_user' ]] = $owner_name ;
}
$data [ 1 ] = html_print_select ( $owners , 'id_owner' , $event [ 'owner_user' ], '' , __ ( 'None' ), - 1 , true );
$data [ 1 ] .= html_print_button ( __ ( 'Update' ), 'owner_button' , false , 'event_change_owner();' , 'class="sub next"' , true );
$table_responses -> data [] = $data ;
}
// Status
$data = [];
$data [ 0 ] = __ ( 'Change status' );
$status_blocked = false ;
if ( tags_checks_event_acl ( $config [ 'id_user' ], $event [ 'id_grupo' ], 'EM' , $event [ 'clean_tags' ], $childrens_ids )) {
// If the user has manager acls, the status can be changed to all possibilities always
$status = [
0 => __ ( 'New' ),
2 => __ ( 'In process' ),
1 => __ ( 'Validated' ),
];
} else {
switch ( $event [ 'estado' ]) {
case 0 :
// If the user hasnt manager acls and the event is new. The status can be changed
$status = [
2 => __ ( 'In process' ),
1 => __ ( 'Validated' ),
];
break ;
case 1 :
// If the user hasnt manager acls and the event is validated. The status cannot be changed
$status = [ 1 => __ ( 'Validated' )];
$status_blocked = true ;
break ;
case 2 :
// If the user hasnt manager acls and the event is in process. The status only can be changed to validated
$status = [ 1 => __ ( 'Validated' )];
break ;
}
}
// The change status option will be enabled only when is possible change the status
$data [ 1 ] = html_print_select ( $status , 'estado' , $event [ 'estado' ], '' , '' , 0 , true , false , false , '' , $status_blocked );
if ( ! $status_blocked ) {
$data [ 1 ] .= html_print_button ( __ ( 'Update' ), 'status_button' , false , 'event_change_status(\'' . $event [ 'similar_ids' ] . '\');' , 'class="sub next"' , true );
}
$table_responses -> data [] = $data ;
// Comments
$data = [];
$data [ 0 ] = __ ( 'Comment' );
$data [ 1 ] = html_print_button ( __ ( 'Add comment' ), 'comment_button' , false , '$(\'#link_comments\').trigger(\'click\');' , 'class="sub next"' , true );
$table_responses -> data [] = $data ;
if ( tags_checks_event_acl ( $config [ 'id_user' ], $event [ 'id_grupo' ], 'EM' , $event [ 'clean_tags' ], $childrens_ids )) {
// Delete
$data = [];
$data [ 0 ] = __ ( 'Delete event' );
$data [ 1 ] = '<form method="post">' ;
$data [ 1 ] .= html_print_button ( __ ( 'Delete event' ), 'delete_button' , false , 'if(!confirm(\'' . __ ( 'Are you sure?' ) . '\')) { return false; } this.form.submit();' , 'class="sub cancel"' , true );
$data [ 1 ] .= html_print_input_hidden ( 'delete' , 1 , true );
$data [ 1 ] .= html_print_input_hidden ( 'validate_ids' , $event [ 'id_evento' ], true );
$data [ 1 ] .= '</form>' ;
$table_responses -> data [] = $data ;
}
// Custom responses
$data = [];
$data [ 0 ] = __ ( 'Custom responses' );
$id_groups = array_keys ( users_get_groups ( false , 'EW' ));
$event_responses = db_get_all_rows_filter (
'tevent_response' ,
[ 'id_group' => $id_groups ]
);
if ( empty ( $event_responses )) {
$data [ 1 ] = '<i>' . __ ( 'N/A' ) . '</i>' ;
} else {
$responses = [];
foreach ( $event_responses as $v ) {
$responses [ $v [ 'id' ]] = $v [ 'name' ];
}
$data [ 1 ] = html_print_select (
$responses ,
'select_custom_response' ,
'' ,
'' ,
'' ,
'' ,
true ,
false ,
false
);
if ( isset ( $event [ 'server_id' ])) {
$server_id = $event [ 'server_id' ];
} else {
$server_id = 0 ;
}
$data [ 1 ] .= html_print_button ( __ ( 'Execute' ), 'custom_response_button' , false , 'execute_response(' . $event [ 'id_evento' ] . ',' . $server_id . ')' , " class='sub next' " , true );
}
$table_responses -> data [] = $data ;
$responses_js = " <script>
2012-10-09 18:05:32 +02:00
$ ( '#select_custom_response' ) . change ( function () {
var id_response = $ ( '#select_custom_response' ) . val ();
var params = get_response_params ( id_response );
var description = get_response_description ( id_response );
$ ( '.params_rows' ) . remove ();
2013-01-03 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php,
extensions/resource_exportation.php,
operation/events/event_statistics.php,
operation/events/events_list.php,
operation/reporting/reporting_viewer.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.item_editor.php,
include/functions_alerts.php, include/functions_reports.php,
include/functions_events.php, include/graphs/fgraph.php,
include/functions_graph.php, include/styles/pandora.css,
include/functions_reporting.php, include/functions_agents.php: a lot
of changes and fixes from the branch for the reports.
MERGED FROM PANDORA_4.0
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7351 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-03 19:52:21 +01:00
Changes some bad colors and others aesthetic changes. Thanks Carla.
2014-09-04 Miguel de Dios <miguel.dedios@artica.es>
* pandora_console/extensions/module_groups.php,
pandora_console/general/login_help_dialog.php,
pandora_console/images/close_button_dialog.png,
pandora_console/images/documentation.png,
pandora_console/images/enterprise_version.png,
pandora_console/images/error_login.png,
pandora_console/images/online_help.png,
pandora_console/images/support.png,
pandora_console/include/ajax/events.php,
pandora_console/include/constants.php,
pandora_console/include/functions_events.php,
pandora_console/include/javascript/pandora_events.js,
pandora_console/include/styles/jquery-ui-1.10.0.custom.css,
pandora_console/include/styles/pandora.css,
pandora_console/mobile/include/style/main.css,
pandora_console/operation/events/events_list.php: changes some
bad colors and others aesthetic changes. Thanks Carla.
2014-09-04 12:19:55 +02:00
$ ( '#responses_table' )
. append ( '<tr class=\"params_rows\"><td style=\"text-align:left; font-weight: bolder;\">".__(' Description ')."</td><td style=\"text-align:left;\">' + description + '</td></tr>' );
2013-01-03 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php,
extensions/resource_exportation.php,
operation/events/event_statistics.php,
operation/events/events_list.php,
operation/reporting/reporting_viewer.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.item_editor.php,
include/functions_alerts.php, include/functions_reports.php,
include/functions_events.php, include/graphs/fgraph.php,
include/functions_graph.php, include/styles/pandora.css,
include/functions_reporting.php, include/functions_agents.php: a lot
of changes and fixes from the branch for the reports.
MERGED FROM PANDORA_4.0
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7351 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-03 19:52:21 +01:00
Changes some bad colors and others aesthetic changes. Thanks Carla.
2014-09-04 Miguel de Dios <miguel.dedios@artica.es>
* pandora_console/extensions/module_groups.php,
pandora_console/general/login_help_dialog.php,
pandora_console/images/close_button_dialog.png,
pandora_console/images/documentation.png,
pandora_console/images/enterprise_version.png,
pandora_console/images/error_login.png,
pandora_console/images/online_help.png,
pandora_console/images/support.png,
pandora_console/include/ajax/events.php,
pandora_console/include/constants.php,
pandora_console/include/functions_events.php,
pandora_console/include/javascript/pandora_events.js,
pandora_console/include/styles/jquery-ui-1.10.0.custom.css,
pandora_console/include/styles/pandora.css,
pandora_console/mobile/include/style/main.css,
pandora_console/operation/events/events_list.php: changes some
bad colors and others aesthetic changes. Thanks Carla.
2014-09-04 12:19:55 +02:00
if ( params . length == 1 && params [ 0 ] == '' ) {
2012-10-09 18:05:32 +02:00
return ;
}
Changes some bad colors and others aesthetic changes. Thanks Carla.
2014-09-04 Miguel de Dios <miguel.dedios@artica.es>
* pandora_console/extensions/module_groups.php,
pandora_console/general/login_help_dialog.php,
pandora_console/images/close_button_dialog.png,
pandora_console/images/documentation.png,
pandora_console/images/enterprise_version.png,
pandora_console/images/error_login.png,
pandora_console/images/online_help.png,
pandora_console/images/support.png,
pandora_console/include/ajax/events.php,
pandora_console/include/constants.php,
pandora_console/include/functions_events.php,
pandora_console/include/javascript/pandora_events.js,
pandora_console/include/styles/jquery-ui-1.10.0.custom.css,
pandora_console/include/styles/pandora.css,
pandora_console/mobile/include/style/main.css,
pandora_console/operation/events/events_list.php: changes some
bad colors and others aesthetic changes. Thanks Carla.
2014-09-04 12:19:55 +02:00
$ ( '#responses_table' )
. append ( '<tr class=\"params_rows\"><td style=\"text-align:left; padding-left:20px;\" colspan=\"2\">".__(' Parameters ')."</td></tr>' );
2013-01-03 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php,
extensions/resource_exportation.php,
operation/events/event_statistics.php,
operation/events/events_list.php,
operation/reporting/reporting_viewer.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.item_editor.php,
include/functions_alerts.php, include/functions_reports.php,
include/functions_events.php, include/graphs/fgraph.php,
include/functions_graph.php, include/styles/pandora.css,
include/functions_reporting.php, include/functions_agents.php: a lot
of changes and fixes from the branch for the reports.
MERGED FROM PANDORA_4.0
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7351 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-03 19:52:21 +01:00
Changes some bad colors and others aesthetic changes. Thanks Carla.
2014-09-04 Miguel de Dios <miguel.dedios@artica.es>
* pandora_console/extensions/module_groups.php,
pandora_console/general/login_help_dialog.php,
pandora_console/images/close_button_dialog.png,
pandora_console/images/documentation.png,
pandora_console/images/enterprise_version.png,
pandora_console/images/error_login.png,
pandora_console/images/online_help.png,
pandora_console/images/support.png,
pandora_console/include/ajax/events.php,
pandora_console/include/constants.php,
pandora_console/include/functions_events.php,
pandora_console/include/javascript/pandora_events.js,
pandora_console/include/styles/jquery-ui-1.10.0.custom.css,
pandora_console/include/styles/pandora.css,
pandora_console/mobile/include/style/main.css,
pandora_console/operation/events/events_list.php: changes some
bad colors and others aesthetic changes. Thanks Carla.
2014-09-04 12:19:55 +02:00
for ( i = 0 ; i < params . length ; i ++ ) {
2012-10-09 18:05:32 +02:00
add_row_param ( 'responses_table' , params [ i ]);
}
});
$ ( '#select_custom_response' ) . trigger ( 'change' );
</ script > " ;
2019-01-30 16:18:44 +01:00
$responses = '<div id="extended_event_responses_page" class="extended_event_pages">' . html_print_table ( $table_responses , true ) . $responses_js . '</div>' ;
return $responses ;
2012-10-09 18:05:32 +02:00
}
2019-01-30 16:18:44 +01:00
2012-10-09 18:05:32 +02:00
// Replace macros in the target of a response and return it
2012-12-20 16:33:23 +01:00
// If server_id > 0, is a metaconsole query
2019-01-30 16:18:44 +01:00
function events_get_response_target ( $event_id , $response_id , $server_id , $history = false )
{
global $config ;
$event_response = db_get_row ( 'tevent_response' , 'id' , $response_id );
if ( $server_id > 0 ) {
$meta = true ;
} else {
$meta = false ;
}
$event_table = events_get_events_table ( $meta , $history );
$event = db_get_row ( $event_table , 'id_evento' , $event_id );
$target = io_safe_output ( $event_response [ 'target' ]);
// Substitute each macro
if ( strpos ( $target , '_agent_address_' ) !== false ) {
if ( $meta ) {
$agente_table_name = 'tmetaconsole_agent' ;
$filter = [
'id_tagente' => $event [ 'id_agente' ],
'id_tmetaconsole_setup' => $server_id ,
];
} else {
$agente_table_name = 'tagente' ;
$filter = [ 'id_agente' => $event [ 'id_agente' ]];
}
$ip = db_get_value_filter ( 'direccion' , $agente_table_name , $filter );
// If agent has not an ip, display N/A
if ( $ip === false ) {
$ip = __ ( 'N/A' );
}
$target = str_replace ( '_agent_address_' , $ip , $target );
}
if ( strpos ( $target , '_agent_id_' ) !== false ) {
$target = str_replace ( '_agent_id_' , $event [ 'id_agente' ], $target );
}
if (( strpos ( $target , '_module_address_' ) !== false )
|| ( strpos ( $target , '_module_name_' ) !== false )
) {
if ( $event [ 'id_agentmodule' ] !== 0 ) {
if ( $meta ) {
$server = metaconsole_get_connection_by_id ( $server_id );
metaconsole_connect ( $server );
}
$module = db_get_row ( 'tagente_modulo' , 'id_agente_modulo' , $event [ 'id_agentmodule' ]);
if ( empty ( $module [ 'ip_target' ])) {
$module [ 'ip_target' ] = __ ( 'N/A' );
}
$target = str_replace ( '_module_address_' , $module [ 'ip_target' ], $target );
if ( empty ( $module [ 'nombre' ])) {
$module [ 'nombre' ] = __ ( 'N/A' );
}
$target = str_replace (
'_module_name_' ,
io_safe_output ( $module [ 'nombre' ]),
$target
);
if ( $meta ) {
metaconsole_restore_db ();
}
} else {
$target = str_replace ( '_module_address_' , __ ( 'N/A' ), $target );
$target = str_replace ( '_module_name_' , __ ( 'N/A' ), $target );
}
}
if ( strpos ( $target , '_event_id_' ) !== false ) {
$target = str_replace ( '_event_id_' , $event [ 'id_evento' ], $target );
}
if ( strpos ( $target , '_user_id_' ) !== false ) {
if ( ! empty ( $event [ 'id_usuario' ])) {
$target = str_replace ( '_user_id_' , $event [ 'id_usuario' ], $target );
} else {
$target = str_replace ( '_user_id_' , __ ( 'N/A' ), $target );
}
}
if ( strpos ( $target , '_group_id_' ) !== false ) {
$target = str_replace ( '_group_id_' , $event [ 'id_grupo' ], $target );
}
if ( strpos ( $target , '_group_name_' ) !== false ) {
$target = str_replace (
'_group_name_' ,
groups_get_name ( $event [ 'id_grupo' ], true ),
$target
);
}
if ( strpos ( $target , '_event_utimestamp_' ) !== false ) {
$target = str_replace ( '_event_utimestamp_' , $event [ 'utimestamp' ], $target );
}
if ( strpos ( $target , '_event_date_' ) !== false ) {
$target = str_replace (
'_event_date_' ,
date ( $config [ 'date_format' ], $event [ 'utimestamp' ]),
$target
);
}
if ( strpos ( $target , '_event_text_' ) !== false ) {
$target = str_replace (
'_event_text_' ,
events_display_name ( $event [ 'evento' ]),
$target
);
}
if ( strpos ( $target , '_event_type_' ) !== false ) {
$target = str_replace (
'_event_type_' ,
events_print_type_description ( $event [ 'event_type' ], true ),
$target
);
}
if ( strpos ( $target , '_alert_id_' ) !== false ) {
$target = str_replace (
'_alert_id_' ,
empty ( $event [ 'is_alert_am' ]) ? __ ( 'N/A' ) : $event [ 'is_alert_am' ],
$target
);
}
if ( strpos ( $target , '_event_severity_id_' ) !== false ) {
$target = str_replace ( '_event_severity_id_' , $event [ 'criticity' ], $target );
}
if ( strpos ( $target , '_event_severity_text_' ) !== false ) {
$target = str_replace (
'_event_severity_text_' ,
get_priority_name ( $event [ 'criticity' ]),
$target
);
}
if ( strpos ( $target , '_module_id_' ) !== false ) {
$target = str_replace ( '_module_id_' , $event [ 'id_agentmodule' ], $target );
}
if ( strpos ( $target , '_event_tags_' ) !== false ) {
$target = str_replace ( '_event_tags_' , $event [ 'tags' ], $target );
}
if ( strpos ( $target , '_event_extra_id_' ) !== false ) {
if ( empty ( $event [ 'id_extra' ])) {
$target = str_replace ( '_event_extra_id_' , __ ( 'N/A' ), $target );
} else {
$target = str_replace ( '_event_extra_id_' , $event [ 'id_extra' ], $target );
}
}
if ( strpos ( $target , '_event_source_' ) !== false ) {
$target = str_replace ( '_event_source_' , $event [ 'source' ], $target );
}
if ( strpos ( $target , '_event_instruction_' ) !== false ) {
$target = str_replace (
'_event_instruction_' ,
events_display_instructions ( $event [ 'event_type' ], $event , false ),
$target
);
}
if ( strpos ( $target , '_owner_user_' ) !== false ) {
if ( empty ( $event [ 'owner_user' ])) {
$target = str_replace ( '_owner_user_' , __ ( 'N/A' ), $target );
} else {
$target = str_replace ( '_owner_user_' , $event [ 'owner_user' ], $target );
}
}
if ( strpos ( $target , '_event_status_' ) !== false ) {
$event_st = events_display_status ( $event [ 'estado' ]);
$target = str_replace ( '_event_status_' , $event_st [ 'title' ], $target );
}
if ( strpos ( $target , '_group_custom_id_' ) !== false ) {
$group_custom_id = db_get_value ( $dbh , 'SELECT custom_id FROM tgrupo WHERE id_grupo=?' , $event [ 'id_grupo' ]);
$event_st = events_display_status ( $event [ 'estado' ]);
$target = str_replace ( '_group_custom_id_' , $group_custom_id , $target );
}
// Parse the event custom data
if ( ! empty ( $event [ 'custom_data' ])) {
$custom_data = json_decode ( base64_decode ( $event [ 'custom_data' ]));
foreach ( $custom_data as $key => $value ) {
$target = str_replace ( '_customdata_' . $key . '_' , $value , $target );
}
}
return $target ;
2012-10-09 18:05:32 +02:00
}
2019-01-30 16:18:44 +01:00
function events_page_custom_fields ( $event )
{
global $config ;
//
// Custom fields
//
$table -> cellspacing = 2 ;
$table -> cellpadding = 2 ;
$table -> width = '100%' ;
$table -> data = [];
$table -> head = [];
$table -> style [ 0 ] = 'width:35%; font-weight: bold; text-align: left; height: 23px;' ;
$table -> style [ 1 ] = 'text-align: left; height: 23px;' ;
$table -> class = 'alternate rounded_cells' ;
$all_customs_fields = ( bool ) check_acl (
$config [ 'id_user' ],
$event [ 'id_grupo' ],
'AW'
);
if ( $all_customs_fields ) {
$fields = db_get_all_rows_filter ( 'tagent_custom_fields' );
} else {
$fields = db_get_all_rows_filter (
'tagent_custom_fields' ,
[ 'display_on_front' => 1 ]
);
}
if ( $event [ 'id_agente' ] == 0 ) {
$fields_data = [];
} else {
$fields_data = db_get_all_rows_filter ( 'tagent_custom_data' , [ 'id_agent' => $event [ 'id_agente' ]]);
if ( is_array ( $fields_data )) {
$fields_data_aux = [];
foreach ( $fields_data as $fd ) {
$fields_data_aux [ $fd [ 'id_field' ]] = $fd [ 'description' ];
}
$fields_data = $fields_data_aux ;
}
}
foreach ( $fields as $field ) {
// Owner
$data = [];
$data [ 0 ] = $field [ 'name' ];
if ( empty ( $fields_data [ $field [ 'id_field' ]])) {
$data [ 1 ] = '<i>' . __ ( 'N/A' ) . '</i>' ;
} else {
if ( $field [ 'is_password_type' ]) {
$data [ 1 ] = '••••••••' ;
} else {
$data [ 1 ] = ui_bbcode_to_html ( $fields_data [ $field [ 'id_field' ]]);
}
}
$field [ 'id_field' ];
$table -> data [] = $data ;
}
$custom_fields = '<div id="extended_event_custom_fields_page" class="extended_event_pages">' . html_print_table ( $table , true ) . '</div>' ;
return $custom_fields ;
2012-10-09 18:05:32 +02:00
}
2019-01-30 16:18:44 +01:00
function events_page_details ( $event , $server = '' )
{
global $img_sev ;
global $config ;
// If server is provided, get the hash parameters
if ( ! empty ( $server ) && defined ( 'METACONSOLE' )) {
$hashdata = metaconsole_get_server_hashdata ( $server );
$hashstring = '&' . 'loginhash=auto&' . 'loginhash_data=' . $hashdata . '&' . 'loginhash_user=' . str_rot13 ( $config [ 'id_user' ]);
$serverstring = $server [ 'server_url' ] . '/' ;
if ( metaconsole_connect ( $server ) !== NOERR ) {
return ui_print_error_message ( __ ( 'There was an error connecting to the node' ), '' , true );
}
} else {
$hashstring = '' ;
$serverstring = '' ;
}
//
// Details
//
$table_details -> width = '100%' ;
$table_details -> data = [];
$table_details -> head = [];
$table_details -> cellspacing = 2 ;
$table_details -> cellpadding = 2 ;
$table_details -> style [ 0 ] = 'width:35%; font-weight: bold; text-align: left; height: 23px;' ;
$table_details -> style [ 1 ] = 'text-align: left; height: 23px;' ;
$table_details -> class = 'alternate rounded_cells' ;
switch ( $event [ 'event_type' ]) {
case 'going_unknown' :
case 'going_up_warning' :
case 'going_down_warning' :
case 'going_up_critical' :
case 'going_down_critical' :
break ;
}
if ( $event [ 'id_agente' ] != 0 ) {
$agent = db_get_row ( 'tagente' , 'id_agente' , $event [ 'id_agente' ]);
} else {
$agent = [];
}
$data = [];
$data [ 0 ] = __ ( 'Agent details' );
$data [ 1 ] = empty ( $agent ) ? '<i>' . __ ( 'N/A' ) . '</i>' : '' ;
$table_details -> data [] = $data ;
if ( ! empty ( $agent )) {
$data = [];
$data [ 0 ] = '<div style="font-weight:normal; margin-left: 20px;">' . __ ( 'Name' ) . '</div>' ;
if ( can_user_access_node ()) {
$data [ 1 ] = ui_print_agent_name ( $event [ 'id_agente' ], true , 'agent_medium' , '' , false , $serverstring , $hashstring , $agent [ 'alias' ]);
} else {
$data [ 1 ] = ui_print_truncate_text ( $agent [ 'alias' ], 'agent_medium' , true , true , true );
}
$table_details -> data [] = $data ;
$data = [];
$data [ 0 ] = '<div style="font-weight:normal; margin-left: 20px;">' . __ ( 'IP Address' ) . '</div>' ;
$data [ 1 ] = empty ( $agent [ 'direccion' ]) ? '<i>' . __ ( 'N/A' ) . '</i>' : $agent [ 'direccion' ];
$table_details -> data [] = $data ;
$data = [];
$data [ 0 ] = '<div style="font-weight:normal; margin-left: 20px;">' . __ ( 'OS' ) . '</div>' ;
$data [ 1 ] = ui_print_os_icon ( $agent [ 'id_os' ], true , true );
if ( ! empty ( $agent [ 'os_version' ])) {
$data [ 1 ] .= ' (' . $agent [ 'os_version' ] . ')' ;
}
$table_details -> data [] = $data ;
$data = [];
$data [ 0 ] = '<div style="font-weight:normal; margin-left: 20px;">' . __ ( 'Last contact' ) . '</div>' ;
$data [ 1 ] = $agent [ 'ultimo_contacto' ] == '1970-01-01 00:00:00' ? '<i>' . __ ( 'N/A' ) . '</i>' : date_w_fixed_tz ( $agent [ 'ultimo_contacto' ]);
$table_details -> data [] = $data ;
$data = [];
$data [ 0 ] = '<div style="font-weight:normal; margin-left: 20px;">' . __ ( 'Last remote contact' ) . '</div>' ;
$data [ 1 ] = $agent [ 'ultimo_contacto_remoto' ] == '1970-01-01 00:00:00' ? '<i>' . __ ( 'N/A' ) . '</i>' : date_w_fixed_tz ( $agent [ 'ultimo_contacto_remoto' ]);
$table_details -> data [] = $data ;
$data = [];
$data [ 0 ] = '<div style="font-weight:normal; margin-left: 20px;">' . __ ( 'Custom fields' ) . '</div>' ;
$data [ 1 ] = html_print_button ( __ ( 'View custom fields' ), 'custom_button' , false , '$(\'#link_custom_fields\').trigger(\'click\');' , 'class="sub next"' , true );
$table_details -> data [] = $data ;
}
if ( $event [ 'id_agentmodule' ] != 0 ) {
$module = db_get_row_filter ( 'tagente_modulo' , [ 'id_agente_modulo' => $event [ 'id_agentmodule' ], 'delete_pending' => 0 ]);
} else {
$module = [];
}
$data = [];
$data [ 0 ] = __ ( 'Module details' );
$data [ 1 ] = empty ( $module ) ? '<i>' . __ ( 'N/A' ) . '</i>' : '' ;
$table_details -> data [] = $data ;
if ( ! empty ( $module )) {
// Module name
$data = [];
$data [ 0 ] = '<div style="font-weight:normal; margin-left: 20px;">' . __ ( 'Name' ) . '</div>' ;
$data [ 1 ] = $module [ 'nombre' ];
$table_details -> data [] = $data ;
// Module group
$data = [];
$data [ 0 ] = '<div style="font-weight:normal; margin-left: 20px;">' . __ ( 'Module group' ) . '</div>' ;
$id_module_group = $module [ 'id_module_group' ];
if ( $id_module_group == 0 ) {
$data [ 1 ] = __ ( 'No assigned' );
} else {
$module_group = db_get_value ( 'name' , 'tmodule_group' , 'id_mg' , $id_module_group );
$data [ 1 ] = '<a href="' . $serverstring . 'index.php?sec=view&sec2=operation/agentes/status_monitor&status=-1&modulegroup=' . $id_module_group . $hashstring . '">' ;
$data [ 1 ] .= $module_group ;
$data [ 1 ] .= '</a>' ;
}
$table_details -> data [] = $data ;
// ACL
$acl_graph = false ;
$strict_user = ( bool ) db_get_value ( 'strict_acl' , 'tusuario' , 'id_user' , $config [ 'id_user' ]);
if ( ! empty ( $agent [ 'id_grupo' ])) {
$acl_graph = check_acl ( $config [ 'id_user' ], $agent [ 'id_grupo' ], 'RR' );
}
if ( $acl_graph ) {
$data = [];
$data [ 0 ] = '<div style="font-weight:normal; margin-left: 20px;">' . __ ( 'Graph' ) . '</div>' ;
$module_type = - 1 ;
if ( isset ( $module [ 'module_type' ])) {
$module_type = $module [ 'module_type' ];
}
$graph_type = return_graphtype ( $module_type );
$url = ui_get_full_url ( 'operation/agentes/stat_win.php' , false , false , false );
$handle = dechex ( crc32 ( $module [ 'id_agente_modulo' ] . $module [ 'nombre' ]));
$win_handle = " day_ $handle " ;
$graph_params = [
'type' => $graph_type ,
'period' => SECONDS_1DAY ,
'id' => $module [ 'id_agente_modulo' ],
'label' => base64_encode ( $module [ 'nombre' ]),
'refresh' => SECONDS_10MINUTES ,
];
if ( defined ( 'METACONSOLE' )) {
// Set the server id
$graph_params [ 'server' ] = $server [ 'id' ];
}
$graph_params_str = http_build_query ( $graph_params );
$link = " winopeng(' $url ? $graph_params_str ',' $win_handle ') " ;
$data [ 1 ] = '<a href="javascript:' . $link . '">' ;
$data [ 1 ] .= html_print_image ( 'images/chart_curve.png' , true );
$data [ 1 ] .= '</a>' ;
$table_details -> data [] = $data ;
}
}
$data = [];
$data [ 0 ] = __ ( 'Alert details' );
$data [ 1 ] = $event [ 'id_alert_am' ] == 0 ? '<i>' . __ ( 'N/A' ) . '</i>' : '' ;
$table_details -> data [] = $data ;
if ( $event [ 'id_alert_am' ] != 0 ) {
$data = [];
$data [ 0 ] = '<div style="font-weight:normal; margin-left: 20px;">' . __ ( 'Source' ) . '</div>' ;
$data [ 1 ] = '<a href="' . $serverstring . 'index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente=' . $event [ 'id_agente' ] . '&tab=alert' . $hashstring . '">' ;
$standby = db_get_value ( 'standby' , 'talert_template_modules' , 'id' , $event [ 'id_alert_am' ]);
if ( ! $standby ) {
$data [ 1 ] .= html_print_image (
'images/bell.png' ,
true ,
[ 'title' => __ ( 'Go to data overview' )]
);
} else {
$data [ 1 ] .= html_print_image (
'images/bell_pause.png' ,
true ,
[ 'title' => __ ( 'Go to data overview' )]
);
}
$sql = ' SELECT name
2012-10-09 18:05:32 +02:00
FROM talert_templates
WHERE id IN ( SELECT id_alert_template
FROM talert_template_modules
2019-01-30 16:18:44 +01:00
WHERE id = '.$event[' id_alert_am '].' ); ' ;
$templateName = db_get_sql ( $sql );
$data [ 1 ] .= $templateName ;
$data [ 1 ] .= '</a>' ;
$table_details -> data [] = $data ;
$data = [];
$data [ 0 ] = '<div style="font-weight:normal; margin-left: 20px;">' . __ ( 'Priority' ) . '</div>' ;
$priority_code = db_get_value ( 'priority' , 'talert_template_modules' , 'id' , $event [ 'id_alert_am' ]);
$alert_priority = get_priority_name ( $priority_code );
$data [ 1 ] = html_print_image (
$img_sev ,
true ,
[
'class' => 'image_status' ,
'width' => 12 ,
'height' => 12 ,
'title' => $alert_priority ,
]
);
$data [ 1 ] .= ' ' . $alert_priority ;
$table_details -> data [] = $data ;
}
$data = [];
$data [ 0 ] = __ ( 'Instructions' );
$data [ 1 ] = events_display_instructions ( $event [ 'event_type' ], $event , true );
$table_details -> data [] = $data ;
$data = [];
$data [ 0 ] = __ ( 'Extra id' );
if ( $event [ 'id_extra' ] != '' ) {
$data [ 1 ] = $event [ 'id_extra' ];
} else {
$data [ 1 ] = '<i>' . __ ( 'N/A' ) . '</i>' ;
}
$table_details -> data [] = $data ;
$data = [];
$data [ 0 ] = __ ( 'Source' );
if ( $event [ 'source' ] != '' ) {
$data [ 1 ] = $event [ 'source' ];
} else {
$data [ 1 ] = '<i>' . __ ( 'N/A' ) . '</i>' ;
}
$table_details -> data [] = $data ;
$details = '<div id="extended_event_details_page" class="extended_event_pages">' . html_print_table ( $table_details , true ) . '</div>' ;
if ( ! empty ( $server ) && defined ( 'METACONSOLE' )) {
metaconsole_restore_db ();
}
return $details ;
2012-10-09 18:05:32 +02:00
}
2019-01-30 16:18:44 +01:00
function events_page_custom_data ( $event )
{
global $config ;
//
// Custom data
//
if ( $event [ 'custom_data' ] == '' ) {
return '' ;
}
$table -> width = '100%' ;
$table -> data = [];
$table -> head = [];
$table -> style [ 0 ] = 'width:35%; font-weight: bold; text-align: left;' ;
$table -> style [ 1 ] = 'text-align: left;' ;
$table -> class = 'alternate rounded_cells' ;
$json_custom_data = base64_decode ( $event [ 'custom_data' ]);
$custom_data = json_decode ( $json_custom_data );
if ( $custom_data === null ) {
return '<div id="extended_event_custom_data_page" class="extended_event_pages">' . __ ( 'Invalid custom data: %s' , $json_custom_data ) . '</div>' ;
}
$i = 0 ;
foreach ( $custom_data as $field => $value ) {
$table -> data [ $i ][ 0 ] = io_safe_output ( $field );
$table -> data [ $i ][ 1 ] = io_safe_output ( $value );
$i ++ ;
}
$custom_data = '<div id="extended_event_custom_data_page" class="extended_event_pages">' . html_print_table ( $table , true ) . '</div>' ;
return $custom_data ;
2013-09-09 18:21:45 +02:00
}
2019-01-30 16:18:44 +01:00
2017-11-17 14:50:23 +01:00
// Get the event name from tevento and display it in console
2019-01-30 16:18:44 +01:00
function events_display_name ( $db_name = '' )
{
return io_safe_output ( str_replace ( '
' , '<br>' , $db_name ));
2017-11-17 14:50:23 +01:00
}
2019-01-30 16:18:44 +01:00
2017-11-17 14:50:23 +01:00
// Get the image and status value of event
2019-01-30 16:18:44 +01:00
function events_display_status ( $status )
{
switch ( $status ) {
case 0 :
return [
'img' => 'images/star.png' ,
'title' => __ ( 'New event' ),
];
case 1 :
return [
'img' => 'images/tick.png' ,
'title' => __ ( 'Event validated' ),
];
case 2 :
return [
'img' => 'images/hourglass.png' ,
'title' => __ ( 'Event in process' ),
];
}
2017-11-17 14:50:23 +01:00
}
2019-01-30 16:18:44 +01:00
2017-11-17 14:50:23 +01:00
// Get the instruction of an event
// $event_type: Type of event
// $inst: Array with unknown warning and critical instructions
// $italic: Display N/A between italic html marks if instruction is not found
2019-01-30 16:18:44 +01:00
function events_display_instructions ( $event_type = '' , $inst , $italic = true )
{
switch ( $event_type ) {
case 'going_unknown' :
if ( $inst [ 'unknown_instructions' ] != '' ) {
return str_replace ( " \n " , '<br>' , io_safe_output ( $inst [ 'unknown_instructions' ]));
}
break ;
case 'going_up_warning' :
case 'going_down_warning' :
if ( $inst [ 'warning_instructions' ] != '' ) {
return str_replace ( " \n " , '<br>' , io_safe_output ( $inst [ 'warning_instructions' ]));
}
break ;
case 'going_up_critical' :
case 'going_down_critical' :
if ( $inst [ 'critical_instructions' ] != '' ) {
return str_replace ( " \n " , '<br>' , io_safe_output ( $inst [ 'critical_instructions' ]));
}
break ;
case 'system' :
$data = [];
if ( $inst [ 'critical_instructions' ] != '' ) {
return str_replace ( " \n " , '<br>' , io_safe_output ( $inst [ 'critical_instructions' ]));
}
if ( $inst [ 'warning_instructions' ] != '' ) {
return str_replace ( " \n " , '<br>' , io_safe_output ( $inst [ 'warning_instructions' ]));
}
if ( $inst [ 'unknown_instructions' ] != '' ) {
return str_replace ( " \n " , '<br>' , io_safe_output ( $inst [ 'unknown_instructions' ]));
}
break ;
}
$na_return = $italic ? '<i>' . __ ( 'N/A' ) . '</i>' : __ ( 'N/A' );
return $na_return ;
2017-11-17 14:50:23 +01:00
}
2019-01-30 16:18:44 +01:00
function events_page_general ( $event )
{
global $img_sev ;
global $config ;
// $group_rep = $event['similar_ids'] == -1 ? 1 : count(explode(',',$event['similar_ids']));
global $group_rep ;
//
// General
//
$table_general -> cellspacing = 2 ;
$table_general -> cellpadding = 2 ;
$table_general -> width = '100%' ;
$table_general -> data = [];
$table_general -> head = [];
$table_general -> style [ 0 ] = 'width:35%; font-weight: bold; text-align: left; height: 23px;' ;
$table_general -> style [ 1 ] = 'text-align: left; height: 23px;' ;
$table_general -> class = 'alternate rounded_cells' ;
$data = [];
$data [ 0 ] = __ ( 'Event ID' );
$data [ 1 ] = '#' . $event [ 'id_evento' ];
$table_general -> data [] = $data ;
$data = [];
$data [ 0 ] = __ ( 'Event name' );
$data [ 1 ] = events_display_name ( $event [ 'evento' ]);
$table_general -> data [] = $data ;
$data = [];
$data [ 0 ] = __ ( 'Timestamp' );
if ( $group_rep == 1 && $event [ 'event_rep' ] > 1 ) {
$data [ 1 ] = __ ( 'First event' ) . ': ' . date ( $config [ 'date_format' ], $event [ 'timestamp_first' ]) . '<br>' . __ ( 'Last event' ) . ': ' . date ( $config [ 'date_format' ], $event [ 'timestamp_last' ]);
} else {
$data [ 1 ] = date ( $config [ 'date_format' ], $event [ 'utimestamp' ]);
}
$table_general -> data [] = $data ;
$event [ 'owner_user' ] = $event [ 'id_usuario' ];
$data = [];
$data [ 0 ] = __ ( 'Owner' );
if ( empty ( $event [ 'owner_user' ])) {
$data [ 1 ] = '<i>' . __ ( 'N/A' ) . '</i>' ;
} else {
$user_owner = db_get_value ( 'fullname' , 'tusuario' , 'id_user' , $event [ 'owner_user' ]);
if ( empty ( $user_owner )) {
$user_owner = $event [ 'owner_user' ];
}
$data [ 1 ] = $user_owner ;
}
$table_general -> data [] = $data ;
$data = [];
$data [ 0 ] = __ ( 'Type' );
$data [ 1 ] = events_print_type_img ( $event [ 'event_type' ], true ) . ' ' . events_print_type_description ( $event [ 'event_type' ], true );
$table_general -> data [] = $data ;
$data = [];
$data [ 0 ] = __ ( 'Repeated' );
if ( $group_rep != 0 ) {
if ( $event [ 'event_rep' ] <= 1 ) {
$data [ 1 ] = '<i>' . __ ( 'No' ) . '</i>' ;
} else {
$data [ 1 ] = sprintf ( '%d Times' , $event [ 'event_rep' ]);
}
} else {
$data [ 1 ] = '<i>' . __ ( 'No' ) . '</i>' ;
}
$table_general -> data [] = $data ;
$data = [];
$data [ 0 ] = __ ( 'Severity' );
$event_criticity = get_priority_name ( $event [ 'criticity' ]);
$data [ 1 ] = html_print_image (
$img_sev ,
true ,
[
'class' => 'image_status' ,
'width' => 12 ,
'height' => 12 ,
'title' => $event_criticity ,
]
);
$data [ 1 ] .= ' ' . $event_criticity ;
$table_general -> data [] = $data ;
// Get Status
$event_st = events_display_status ( $event [ 'estado' ]);
$data = [];
$data [ 0 ] = __ ( 'Status' );
$data [ 1 ] = html_print_image ( $event_st [ 'img' ], true ) . ' ' . $event_st [ 'title' ];
$table_general -> data [] = $data ;
// If event is validated, show who and when acknowleded it
$data = [];
$data [ 0 ] = __ ( 'Acknowledged by' );
if ( $event [ 'estado' ] == 1 ) {
$user_ack = db_get_value ( 'fullname' , 'tusuario' , 'id_user' , $event [ 'id_usuario' ]);
if ( empty ( $user_ack )) {
$user_ack = $event [ 'id_usuario' ];
}
$date_ack = date ( $config [ 'date_format' ], $event [ 'ack_utimestamp' ]);
$data [ 1 ] = $user_ack . ' (' . $date_ack . ')' ;
} else {
$data [ 1 ] = '<i>' . __ ( 'N/A' ) . '</i>' ;
}
$table_general -> data [] = $data ;
$data = [];
$data [ 0 ] = __ ( 'Group' );
$data [ 1 ] = '' ;
if ( ! $config [ 'show_group_name' ]) {
$data [ 1 ] = ui_print_group_icon ( $event [ 'id_grupo' ], true );
}
$data [ 1 ] .= groups_get_name ( $event [ 'id_grupo' ]);
$table_general -> data [] = $data ;
$data = [];
$data [ 0 ] = __ ( 'Tags' );
if ( $event [ 'tags' ] != '' ) {
$tags = tags_get_tags_formatted ( $event [ 'tags' ]);
$data [ 1 ] = $tags ;
} else {
$data [ 1 ] = '<i>' . __ ( 'N/A' ) . '</i>' ;
}
$table_general -> data [] = $data ;
$data = [];
$data [ 0 ] = __ ( 'ID extra' );
if ( $event [ 'id_extra' ] != '' ) {
$data [ 1 ] = $event [ 'id_extra' ];
} else {
$data [ 1 ] = '<i>' . __ ( 'N/A' ) . '</i>' ;
}
$table_general -> data [] = $data ;
$general = '<div id="extended_event_general_page" class="extended_event_pages">' . html_print_table ( $table_general , true ) . '</div>' ;
return $general ;
2012-10-09 18:05:32 +02:00
}
2013-01-03 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php,
extensions/resource_exportation.php,
operation/events/event_statistics.php,
operation/events/events_list.php,
operation/reporting/reporting_viewer.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.item_editor.php,
include/functions_alerts.php, include/functions_reports.php,
include/functions_events.php, include/graphs/fgraph.php,
include/functions_graph.php, include/styles/pandora.css,
include/functions_reporting.php, include/functions_agents.php: a lot
of changes and fixes from the branch for the reports.
MERGED FROM PANDORA_4.0
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7351 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-03 19:52:21 +01:00
2019-01-30 16:18:44 +01:00
function events_page_comments ( $event , $childrens_ids = [])
{
//
// Comments
//
global $config ;
$table_comments -> width = '100%' ;
$table_comments -> data = [];
$table_comments -> head = [];
$table_comments -> style [ 0 ] = 'width:35%; vertical-align: top; text-align: left;' ;
$table_comments -> style [ 1 ] = 'text-align: left;' ;
$table_comments -> class = 'alternate rounded_cells' ;
$event_comments = $event [ 'user_comment' ];
$event_comments = str_replace ([ " \n " , '
' ], '<br>' , $event_comments );
// If comments are not stored in json, the format is old
$event_comments_array = json_decode ( $event_comments , true );
// Show the comments more recent first
$event_comments_array = array_reverse ( $event_comments_array );
if ( is_null ( $event_comments_array )) {
$comments_format = 'old' ;
} else {
$comments_format = 'new' ;
}
switch ( $comments_format ) {
case 'new' :
if ( empty ( $event_comments_array )) {
$table_comments -> style [ 0 ] = 'text-align:center;' ;
$table_comments -> colspan [ 0 ][ 0 ] = 2 ;
$data = [];
$data [ 0 ] = __ ( 'There are no comments' );
$table_comments -> data [] = $data ;
}
foreach ( $event_comments_array as $c ) {
$data [ 0 ] = '<b>' . $c [ 'action' ] . ' by ' . $c [ 'id_user' ] . '</b>' ;
$data [ 0 ] .= '<br><br><i>' . date ( $config [ 'date_format' ], $c [ 'utimestamp' ]) . '</i>' ;
$data [ 1 ] = $c [ 'comment' ];
$table_comments -> data [] = $data ;
}
break ;
case 'old' :
$comments_array = explode ( '<br>' , $event_comments );
// Split comments and put in table
$col = 0 ;
$data = [];
foreach ( $comments_array as $c ) {
switch ( $col ) {
case 0 :
$row_text = preg_replace ( '/\s*--\s*/' , '' , $c );
$row_text = preg_replace ( '/\<\/b\>/' , '</i>' , $row_text );
$row_text = preg_replace ( '/\[/' , '</b><br><br><i>[' , $row_text );
$row_text = preg_replace ( '/[\[|\]]/' , '' , $row_text );
break ;
case 1 :
$row_text = preg_replace ( " /[ \r \n | \r | \n ]/ " , '<br>' , io_safe_output ( strip_tags ( $c )));
break ;
}
$data [ $col ] = $row_text ;
$col ++ ;
if ( $col == 2 ) {
$col = 0 ;
$table_comments -> data [] = $data ;
$data = [];
}
}
if ( count ( $comments_array ) == 1 && $comments_array [ 0 ] == '' ) {
$table_comments -> style [ 0 ] = 'text-align:center;' ;
$table_comments -> colspan [ 0 ][ 0 ] = 2 ;
$data = [];
$data [ 0 ] = __ ( 'There are no comments' );
$table_comments -> data [] = $data ;
}
break ;
}
if ((( tags_checks_event_acl ( $config [ 'id_user' ], $event [ 'id_grupo' ], 'EM' , $event [ 'clean_tags' ], $childrens_ids )) || ( tags_checks_event_acl ( $config [ 'id_user' ], $event [ 'id_grupo' ], 'EW' , $event [ 'clean_tags' ], $childrens_ids ))) && $config [ 'show_events_in_local' ] == false || $config [ 'event_replication' ] == false ) {
$comments_form = '<br><div id="comments_form" style="width:98%;">' . html_print_textarea ( 'comment' , 3 , 10 , '' , 'style="min-height: 15px; width: 100%; disabled"' , true );
$comments_form .= '<br><div style="text-align:right;">' . html_print_button ( __ ( 'Add comment' ), 'comment_button' , false , 'event_comment();' , 'class="sub next"' , true ) . '</div><br></div>' ;
} else {
$comments_form = ui_print_message ( __ ( 'If event replication is ongoing, it won\'t be possible to enter comments here. This option is only to allow local pandora users to see comments, but not to operate with them. The operation, when event replication is enabled, must be done only in the Metaconsole.' ));
}
$comments = '<div id="extended_event_comments_page" class="extended_event_pages">' . $comments_form . html_print_table ( $table_comments , true ) . '</div>' ;
return $comments ;
2013-01-09 10:25:07 +01:00
}
2019-01-30 16:18:44 +01:00
function events_clean_tags ( $tags )
{
if ( empty ( $tags )) {
return [];
}
$event_tags = tags_get_tags_formatted ( $tags , false );
return explode ( ',' , str_replace ( ' ' , '' , $event_tags ));
2012-10-09 18:05:32 +02:00
}
2013-01-03 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php,
extensions/resource_exportation.php,
operation/events/event_statistics.php,
operation/events/events_list.php,
operation/reporting/reporting_viewer.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.item_editor.php,
include/functions_alerts.php, include/functions_reports.php,
include/functions_events.php, include/graphs/fgraph.php,
include/functions_graph.php, include/styles/pandora.css,
include/functions_reporting.php, include/functions_agents.php: a lot
of changes and fixes from the branch for the reports.
MERGED FROM PANDORA_4.0
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7351 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-03 19:52:21 +01:00
2019-01-30 16:18:44 +01:00
2013-01-03 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php,
extensions/resource_exportation.php,
operation/events/event_statistics.php,
operation/events/events_list.php,
operation/reporting/reporting_viewer.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.item_editor.php,
include/functions_alerts.php, include/functions_reports.php,
include/functions_events.php, include/graphs/fgraph.php,
include/functions_graph.php, include/styles/pandora.css,
include/functions_reporting.php, include/functions_agents.php: a lot
of changes and fixes from the branch for the reports.
MERGED FROM PANDORA_4.0
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7351 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-03 19:52:21 +01:00
/**
* Get all the events happened in a group during a period of time .
*
* The returned events will be in the time interval ( $date - $period , $date ]
*
2019-01-30 16:18:44 +01:00
* @ param mixed $id_group Group id to get events for .
* @ param integer $period Period of time in seconds to get events .
* @ param integer $date Beginning date to get events .
2013-01-03 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php,
extensions/resource_exportation.php,
operation/events/event_statistics.php,
operation/events/events_list.php,
operation/reporting/reporting_viewer.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.item_editor.php,
include/functions_alerts.php, include/functions_reports.php,
include/functions_events.php, include/graphs/fgraph.php,
include/functions_graph.php, include/styles/pandora.css,
include/functions_reporting.php, include/functions_agents.php: a lot
of changes and fixes from the branch for the reports.
MERGED FROM PANDORA_4.0
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7351 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-03 19:52:21 +01:00
*
* @ return array An array with all the events happened .
*/
2019-01-30 16:18:44 +01:00
function events_get_count_events_by_agent (
$id_group ,
$period ,
$date ,
$filter_event_severity = false ,
$filter_event_type = false ,
$filter_event_status = false ,
$filter_event_filter_search = false ,
$dbmeta = false
) {
global $config ;
// date
if ( ! is_numeric ( $date )) {
$date = time_w_fixed_tz ( $date );
}
if ( empty ( $date )) {
$date = get_system_time ();
}
// group
$id_group = groups_safe_acl ( $config [ 'id_user' ], $id_group , 'AR' );
if ( empty ( $id_group )) {
// An empty array means the user doesn't have access
return false ;
}
$datelimit = ( $date - $period );
$sql_where = '' ;
$severity_all = 0 ;
if ( ! empty ( $filter_event_severity )) {
foreach ( $filter_event_severity as $key => $value ) {
switch ( $value ) {
case - 1 :
$severity_all = 1 ;
break ;
case 34 :
$filter_event_severity [ $key ] = '3, 4' ;
break ;
case 20 :
$filter_event_severity [ $key ] = '0, 1, 3, 4, 5, 6' ;
break ;
case 21 :
$filter_event_severity [ $key ] = '4, 2' ;
break ;
default :
break ;
}
}
if ( ! $severity_all ) {
$sql_where .= ' AND criticity IN (' . implode ( ', ' , $filter_event_severity ) . ')' ;
}
}
$status_all = 0 ;
if ( ! empty ( $filter_event_status )) {
foreach ( $filter_event_status as $key => $value ) {
switch ( $value ) {
case - 1 :
$status_all = 1 ;
break ;
case 3 :
$filter_event_status [ $key ] = ( '0, 2' );
default :
break ;
}
}
if ( ! $status_all ) {
$sql_where .= ' AND estado IN (' . implode ( ', ' , $filter_event_status ) . ')' ;
}
}
if ( ! empty ( $filter_event_type ) && $filter_event_type [ 0 ] != 'all' ) {
$sql_where .= ' AND (' ;
$type = [];
foreach ( $filter_event_type as $event_type ) {
if ( $event_type != '' ) {
// If normal, warning, could be several (going_up_warning, going_down_warning... too complex
// for the user so for him is presented only "warning, critical and normal"
if ( $event_type == 'warning' || $event_type == 'critical' || $event_type == 'normal' ) {
$type [] = " event_type LIKE '% $event_type %' " ;
} else if ( $event_type == 'not_normal' ) {
$type [] = " (event_type LIKE '%warning%' OR event_type LIKE '%critical%' OR event_type LIKE '%unknown%') " ;
} else if ( $event_type != 'all' ) {
$type [] = " event_type = ' " . $event_type . " ' " ;
}
}
}
$sql_where .= implode ( ' OR ' , $type ) . ')' ;
}
if ( ! empty ( $filter_event_filter_search )) {
$sql_where .= ' AND (evento LIKE "%' . io_safe_input ( $filter_event_filter_search ) . '%"' . ' OR id_evento LIKE "%' . io_safe_input ( $filter_event_filter_search ) . '%")' ;
}
$tagente = 'tagente' ;
$tevento = 'tevento' ;
if ( $dbmeta ) {
$tagente = 'tmetaconsole_agent' ;
$tevento = 'tmetaconsole_event' ;
}
$sql = sprintf (
' SELECT id_agente ,
2017-02-27 16:48:28 +01:00
( SELECT t2 . alias
2019-01-16 19:44:29 +01:00
FROM % s t2
2013-01-03 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php,
extensions/resource_exportation.php,
operation/events/event_statistics.php,
operation/events/events_list.php,
operation/reporting/reporting_viewer.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.item_editor.php,
include/functions_alerts.php, include/functions_reports.php,
include/functions_events.php, include/graphs/fgraph.php,
include/functions_graph.php, include/styles/pandora.css,
include/functions_reporting.php, include/functions_agents.php: a lot
of changes and fixes from the branch for the reports.
MERGED FROM PANDORA_4.0
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7351 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-03 19:52:21 +01:00
WHERE t2 . id_agente = t3 . id_agente ) AS agent_name ,
COUNT ( * ) AS count
2019-01-16 19:44:29 +01:00
FROM % s t3
2013-01-03 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php,
extensions/resource_exportation.php,
operation/events/event_statistics.php,
operation/events/events_list.php,
operation/reporting/reporting_viewer.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.item_editor.php,
include/functions_alerts.php, include/functions_reports.php,
include/functions_events.php, include/graphs/fgraph.php,
include/functions_graph.php, include/styles/pandora.css,
include/functions_reporting.php, include/functions_agents.php: a lot
of changes and fixes from the branch for the reports.
MERGED FROM PANDORA_4.0
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7351 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-03 19:52:21 +01:00
WHERE utimestamp > % d AND utimestamp <= % d
2017-01-11 13:26:50 +01:00
AND id_grupo IN ( % s ) % s
2013-01-03 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php,
extensions/resource_exportation.php,
operation/events/event_statistics.php,
operation/events/events_list.php,
operation/reporting/reporting_viewer.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.item_editor.php,
include/functions_alerts.php, include/functions_reports.php,
include/functions_events.php, include/graphs/fgraph.php,
include/functions_graph.php, include/styles/pandora.css,
include/functions_reporting.php, include/functions_agents.php: a lot
of changes and fixes from the branch for the reports.
MERGED FROM PANDORA_4.0
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7351 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-03 19:52:21 +01:00
GROUP BY id_agente ' ,
2019-01-30 16:18:44 +01:00
$tagente ,
$tevento ,
$datelimit ,
$date ,
implode ( ',' , $id_group ),
$sql_where
);
$rows = db_get_all_rows_sql ( $sql );
if ( $rows == false ) {
$rows = [];
}
$return = [];
foreach ( $rows as $row ) {
$agent_name = $row [ 'agent_name' ];
if ( empty ( $row [ 'agent_name' ])) {
$agent_name = __ ( 'Pandora System' );
}
$return [ $agent_name ] = $row [ 'count' ];
}
return $return ;
2013-01-03 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php,
extensions/resource_exportation.php,
operation/events/event_statistics.php,
operation/events/events_list.php,
operation/reporting/reporting_viewer.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.item_editor.php,
include/functions_alerts.php, include/functions_reports.php,
include/functions_events.php, include/graphs/fgraph.php,
include/functions_graph.php, include/styles/pandora.css,
include/functions_reporting.php, include/functions_agents.php: a lot
of changes and fixes from the branch for the reports.
MERGED FROM PANDORA_4.0
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7351 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-03 19:52:21 +01:00
}
2019-01-30 16:18:44 +01:00
2013-01-03 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php,
extensions/resource_exportation.php,
operation/events/event_statistics.php,
operation/events/events_list.php,
operation/reporting/reporting_viewer.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.item_editor.php,
include/functions_alerts.php, include/functions_reports.php,
include/functions_events.php, include/graphs/fgraph.php,
include/functions_graph.php, include/styles/pandora.css,
include/functions_reporting.php, include/functions_agents.php: a lot
of changes and fixes from the branch for the reports.
MERGED FROM PANDORA_4.0
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7351 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-03 19:52:21 +01:00
/**
* Get all the events happened in a group during a period of time .
*
* The returned events will be in the time interval ( $date - $period , $date ]
*
2019-01-30 16:18:44 +01:00
* @ param mixed $id_group Group id to get events for .
* @ param integer $period Period of time in seconds to get events .
* @ param integer $date Beginning date to get events .
2013-01-03 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php,
extensions/resource_exportation.php,
operation/events/event_statistics.php,
operation/events/events_list.php,
operation/reporting/reporting_viewer.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.item_editor.php,
include/functions_alerts.php, include/functions_reports.php,
include/functions_events.php, include/graphs/fgraph.php,
include/functions_graph.php, include/styles/pandora.css,
include/functions_reporting.php, include/functions_agents.php: a lot
of changes and fixes from the branch for the reports.
MERGED FROM PANDORA_4.0
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7351 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-03 19:52:21 +01:00
*
* @ return array An array with all the events happened .
*/
2019-01-30 16:18:44 +01:00
function events_get_count_events_validated_by_user (
$filter ,
$period ,
$date ,
$filter_event_severity = false ,
$filter_event_type = false ,
$filter_event_status = false ,
$filter_event_filter_search = false ,
$dbmeta = false
) {
global $config ;
// group
$sql_filter = ' AND 1=1 ' ;
if ( isset ( $filter [ 'id_group' ])) {
$id_group = groups_safe_acl ( $config [ 'id_user' ], $filter [ 'id_group' ], 'AR' );
if ( empty ( $id_group )) {
// An empty array means the user doesn't have access
return false ;
}
$sql_filter .= sprintf ( ' AND id_grupo IN (%s) ' , implode ( ',' , $id_group ));
}
if ( ! empty ( $filter [ 'id_agent' ])) {
$sql_filter .= sprintf ( ' AND id_agente = %d ' , $filter [ 'id_agent' ]);
}
if ( ! empty ( $filter [ 'id_agentmodule' ])) {
$sql_filter .= sprintf ( ' AND id_agentmodule = %d ' , $filter [ 'id_agentmodule' ]);
}
// date
if ( ! is_numeric ( $date )) {
$date = time_w_fixed_tz ( $date );
}
if ( empty ( $date )) {
$date = get_system_time ();
}
$datelimit = ( $date - $period );
$sql_where = '' ;
$severity_all = 0 ;
if ( ! empty ( $filter_event_severity )) {
foreach ( $filter_event_severity as $key => $value ) {
switch ( $value ) {
case - 1 :
$severity_all = 1 ;
break ;
case 34 :
$filter_event_severity [ $key ] = '3, 4' ;
break ;
case 20 :
$filter_event_severity [ $key ] = '0, 1, 3, 4, 5, 6' ;
break ;
case 21 :
$filter_event_severity [ $key ] = '4, 2' ;
break ;
default :
break ;
}
}
if ( ! $severity_all ) {
$sql_where .= ' AND criticity IN (' . implode ( ', ' , $filter_event_severity ) . ')' ;
}
}
$status_all = 0 ;
if ( ! empty ( $filter_event_status )) {
foreach ( $filter_event_status as $key => $value ) {
switch ( $value ) {
case - 1 :
$status_all = 1 ;
break ;
case 3 :
$filter_event_status [ $key ] = ( '0, 2' );
default :
break ;
}
}
if ( ! $status_all ) {
$sql_where .= ' AND estado IN (' . implode ( ', ' , $filter_event_status ) . ')' ;
}
}
if ( ! empty ( $filter_event_type ) && $filter_event_type [ 0 ] != 'all' ) {
$sql_where .= ' AND (' ;
$type = [];
foreach ( $filter_event_type as $event_type ) {
if ( $event_type != '' ) {
// If normal, warning, could be several (going_up_warning, going_down_warning... too complex
// for the user so for him is presented only "warning, critical and normal"
if ( $event_type == 'warning' || $event_type == 'critical' || $event_type == 'normal' ) {
$type [] = " event_type LIKE '% $event_type %' " ;
} else if ( $event_type == 'not_normal' ) {
$type [] = " (event_type LIKE '%warning%' OR event_type LIKE '%critical%' OR event_type LIKE '%unknown%') " ;
} else if ( $event_type != 'all' ) {
$type [] = " event_type = ' " . $event_type . " ' " ;
}
}
}
$sql_where .= implode ( ' OR ' , $type ) . ')' ;
}
if ( ! empty ( $filter_event_filter_search )) {
$sql_where .= ' AND (evento LIKE "%' . io_safe_input ( $filter_event_filter_search ) . '%"' . ' OR id_evento LIKE "%' . io_safe_input ( $filter_event_filter_search ) . '%")' ;
}
$tevento = 'tevento' ;
if ( $dbmeta ) {
$tevento = 'tmetaconsole_event' ;
}
$sql = sprintf (
' SELECT id_usuario ,
2013-01-03 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php,
extensions/resource_exportation.php,
operation/events/event_statistics.php,
operation/events/events_list.php,
operation/reporting/reporting_viewer.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.item_editor.php,
include/functions_alerts.php, include/functions_reports.php,
include/functions_events.php, include/graphs/fgraph.php,
include/functions_graph.php, include/styles/pandora.css,
include/functions_reporting.php, include/functions_agents.php: a lot
of changes and fixes from the branch for the reports.
MERGED FROM PANDORA_4.0
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7351 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-03 19:52:21 +01:00
( SELECT t2 . fullname
2015-05-04 18:27:23 +02:00
FROM tusuario t2
2013-01-03 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php,
extensions/resource_exportation.php,
operation/events/event_statistics.php,
operation/events/events_list.php,
operation/reporting/reporting_viewer.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.item_editor.php,
include/functions_alerts.php, include/functions_reports.php,
include/functions_events.php, include/graphs/fgraph.php,
include/functions_graph.php, include/styles/pandora.css,
include/functions_reporting.php, include/functions_agents.php: a lot
of changes and fixes from the branch for the reports.
MERGED FROM PANDORA_4.0
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7351 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-03 19:52:21 +01:00
WHERE t2 . id_user = t3 . id_usuario ) AS user_name ,
COUNT ( * ) AS count
2019-01-16 19:44:29 +01:00
FROM % s t3
2013-01-03 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php,
extensions/resource_exportation.php,
operation/events/event_statistics.php,
operation/events/events_list.php,
operation/reporting/reporting_viewer.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.item_editor.php,
include/functions_alerts.php, include/functions_reports.php,
include/functions_events.php, include/graphs/fgraph.php,
include/functions_graph.php, include/styles/pandora.css,
include/functions_reporting.php, include/functions_agents.php: a lot
of changes and fixes from the branch for the reports.
MERGED FROM PANDORA_4.0
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7351 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-03 19:52:21 +01:00
WHERE utimestamp > % d AND utimestamp <= % d
2017-01-11 13:26:50 +01:00
% s % s
2013-01-03 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php,
extensions/resource_exportation.php,
operation/events/event_statistics.php,
operation/events/events_list.php,
operation/reporting/reporting_viewer.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.item_editor.php,
include/functions_alerts.php, include/functions_reports.php,
include/functions_events.php, include/graphs/fgraph.php,
include/functions_graph.php, include/styles/pandora.css,
include/functions_reporting.php, include/functions_agents.php: a lot
of changes and fixes from the branch for the reports.
MERGED FROM PANDORA_4.0
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7351 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-03 19:52:21 +01:00
GROUP BY id_usuario ' ,
2019-01-30 16:18:44 +01:00
$tevento ,
$datelimit ,
$date ,
$sql_filter ,
$sql_where
);
$rows = db_get_all_rows_sql ( $sql );
if ( $rows == false ) {
$rows = [];
}
$return = [];
foreach ( $rows as $row ) {
$user_name = $row [ 'user_name' ];
if ( empty ( $row [ 'user_name' ])) {
$user_name = __ ( 'Unknown' );
}
$return [ $user_name ] = $row [ 'count' ];
}
return $return ;
2013-01-03 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php,
extensions/resource_exportation.php,
operation/events/event_statistics.php,
operation/events/events_list.php,
operation/reporting/reporting_viewer.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.item_editor.php,
include/functions_alerts.php, include/functions_reports.php,
include/functions_events.php, include/graphs/fgraph.php,
include/functions_graph.php, include/styles/pandora.css,
include/functions_reporting.php, include/functions_agents.php: a lot
of changes and fixes from the branch for the reports.
MERGED FROM PANDORA_4.0
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7351 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-03 19:52:21 +01:00
}
2019-01-30 16:18:44 +01:00
2013-01-03 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php,
extensions/resource_exportation.php,
operation/events/event_statistics.php,
operation/events/events_list.php,
operation/reporting/reporting_viewer.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.item_editor.php,
include/functions_alerts.php, include/functions_reports.php,
include/functions_events.php, include/graphs/fgraph.php,
include/functions_graph.php, include/styles/pandora.css,
include/functions_reporting.php, include/functions_agents.php: a lot
of changes and fixes from the branch for the reports.
MERGED FROM PANDORA_4.0
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7351 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-03 19:52:21 +01:00
/**
* Get all the events happened in a group during a period of time .
*
* The returned events will be in the time interval ( $date - $period , $date ]
*
2019-01-30 16:18:44 +01:00
* @ param mixed $id_group Group id to get events for .
* @ param integer $period Period of time in seconds to get events .
* @ param integer $date Beginning date to get events .
2013-01-03 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php,
extensions/resource_exportation.php,
operation/events/event_statistics.php,
operation/events/events_list.php,
operation/reporting/reporting_viewer.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.item_editor.php,
include/functions_alerts.php, include/functions_reports.php,
include/functions_events.php, include/graphs/fgraph.php,
include/functions_graph.php, include/styles/pandora.css,
include/functions_reporting.php, include/functions_agents.php: a lot
of changes and fixes from the branch for the reports.
MERGED FROM PANDORA_4.0
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7351 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-03 19:52:21 +01:00
*
* @ return array An array with all the events happened .
*/
2019-01-30 16:18:44 +01:00
function events_get_count_events_by_criticity (
$filter ,
$period ,
$date ,
$filter_event_severity = false ,
$filter_event_type = false ,
$filter_event_status = false ,
$filter_event_filter_search = false ,
$dbmeta = false
) {
global $config ;
$sql_filter = ' AND 1=1 ' ;
if ( isset ( $filter [ 'id_group' ])) {
$id_group = groups_safe_acl ( $config [ 'id_user' ], $filter [ 'id_group' ], 'AR' );
if ( empty ( $id_group )) {
// An empty array means the user doesn't have access
return false ;
}
$sql_filter .= sprintf ( ' AND id_grupo IN (%s) ' , implode ( ',' , $id_group ));
}
if ( ! empty ( $filter [ 'id_agent' ])) {
$sql_filter .= sprintf ( ' AND id_agente = %d ' , $filter [ 'id_agent' ]);
}
if ( ! empty ( $filter [ 'id_agentmodule' ])) {
$sql_filter .= sprintf ( ' AND id_agentmodule = %d ' , $filter [ 'id_agentmodule' ]);
}
if ( ! is_numeric ( $date )) {
$date = time_w_fixed_tz ( $date );
}
if ( empty ( $date )) {
$date = get_system_time ();
}
$datelimit = ( $date - $period );
$sql_where = '' ;
$severity_all = 0 ;
if ( ! empty ( $filter_event_severity )) {
foreach ( $filter_event_severity as $key => $value ) {
switch ( $value ) {
case - 1 :
$severity_all = 1 ;
break ;
case 34 :
$filter_event_severity [ $key ] = '3, 4' ;
break ;
case 20 :
$filter_event_severity [ $key ] = '0, 1, 3, 4, 5, 6' ;
break ;
case 21 :
$filter_event_severity [ $key ] = '4, 2' ;
break ;
default :
break ;
}
}
if ( ! $severity_all ) {
$sql_where .= ' AND criticity IN (' . implode ( ', ' , $filter_event_severity ) . ')' ;
}
}
$status_all = 0 ;
if ( ! empty ( $filter_event_status )) {
foreach ( $filter_event_status as $key => $value ) {
switch ( $value ) {
case - 1 :
$status_all = 1 ;
break ;
case 3 :
$filter_event_status [ $key ] = ( '0, 2' );
default :
break ;
}
}
if ( ! $status_all ) {
$sql_where .= ' AND estado IN (' . implode ( ', ' , $filter_event_status ) . ')' ;
}
}
if ( ! empty ( $filter_event_type ) && $filter_event_type [ 0 ] != 'all' ) {
$sql_where .= ' AND (' ;
$type = [];
foreach ( $filter_event_type as $event_type ) {
if ( $event_type != '' ) {
// If normal, warning, could be several (going_up_warning, going_down_warning... too complex
// for the user so for him is presented only "warning, critical and normal"
if ( $event_type == 'warning' || $event_type == 'critical' || $event_type == 'normal' ) {
$type [] = " event_type LIKE '% $event_type %' " ;
} else if ( $event_type == 'not_normal' ) {
$type [] = " (event_type LIKE '%warning%' OR event_type LIKE '%critical%' OR event_type LIKE '%unknown%') " ;
} else if ( $event_type != 'all' ) {
$type [] = " event_type = ' " . $event_type . " ' " ;
}
}
}
$sql_where .= implode ( ' OR ' , $type ) . ')' ;
}
if ( ! empty ( $filter_event_filter_search )) {
$sql_where .= ' AND (evento LIKE "%' . io_safe_input ( $filter_event_filter_search ) . '%"' . ' OR id_evento LIKE "%' . io_safe_input ( $filter_event_filter_search ) . '%")' ;
}
$tevento = 'tevento' ;
if ( $dbmeta ) {
$tevento = 'tmetaconsole_event' ;
}
$sql = sprintf (
' SELECT criticity ,
2013-01-03 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php,
extensions/resource_exportation.php,
operation/events/event_statistics.php,
operation/events/events_list.php,
operation/reporting/reporting_viewer.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.item_editor.php,
include/functions_alerts.php, include/functions_reports.php,
include/functions_events.php, include/graphs/fgraph.php,
include/functions_graph.php, include/styles/pandora.css,
include/functions_reporting.php, include/functions_agents.php: a lot
of changes and fixes from the branch for the reports.
MERGED FROM PANDORA_4.0
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7351 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-03 19:52:21 +01:00
COUNT ( * ) AS count
2019-01-16 19:44:29 +01:00
FROM % s
2013-01-03 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php,
extensions/resource_exportation.php,
operation/events/event_statistics.php,
operation/events/events_list.php,
operation/reporting/reporting_viewer.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.item_editor.php,
include/functions_alerts.php, include/functions_reports.php,
include/functions_events.php, include/graphs/fgraph.php,
include/functions_graph.php, include/styles/pandora.css,
include/functions_reporting.php, include/functions_agents.php: a lot
of changes and fixes from the branch for the reports.
MERGED FROM PANDORA_4.0
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7351 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-03 19:52:21 +01:00
WHERE utimestamp > % d AND utimestamp <= % d
2017-01-11 13:26:50 +01:00
% s % s
2013-01-03 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php,
extensions/resource_exportation.php,
operation/events/event_statistics.php,
operation/events/events_list.php,
operation/reporting/reporting_viewer.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.item_editor.php,
include/functions_alerts.php, include/functions_reports.php,
include/functions_events.php, include/graphs/fgraph.php,
include/functions_graph.php, include/styles/pandora.css,
include/functions_reporting.php, include/functions_agents.php: a lot
of changes and fixes from the branch for the reports.
MERGED FROM PANDORA_4.0
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7351 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-03 19:52:21 +01:00
GROUP BY criticity ' ,
2019-01-30 16:18:44 +01:00
$tevento ,
$datelimit ,
$date ,
$sql_filter ,
$sql_where
);
$rows = db_get_all_rows_sql ( $sql );
if ( $rows == false ) {
$rows = [];
}
$return = [];
foreach ( $rows as $row ) {
$return [ get_priority_name ( $row [ 'criticity' ])] = $row [ 'count' ];
}
return $return ;
2013-01-03 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php,
extensions/resource_exportation.php,
operation/events/event_statistics.php,
operation/events/events_list.php,
operation/reporting/reporting_viewer.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.item_editor.php,
include/functions_alerts.php, include/functions_reports.php,
include/functions_events.php, include/graphs/fgraph.php,
include/functions_graph.php, include/styles/pandora.css,
include/functions_reporting.php, include/functions_agents.php: a lot
of changes and fixes from the branch for the reports.
MERGED FROM PANDORA_4.0
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7351 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-03 19:52:21 +01:00
}
2019-01-30 16:18:44 +01:00
2013-01-03 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php,
extensions/resource_exportation.php,
operation/events/event_statistics.php,
operation/events/events_list.php,
operation/reporting/reporting_viewer.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.item_editor.php,
include/functions_alerts.php, include/functions_reports.php,
include/functions_events.php, include/graphs/fgraph.php,
include/functions_graph.php, include/styles/pandora.css,
include/functions_reporting.php, include/functions_agents.php: a lot
of changes and fixes from the branch for the reports.
MERGED FROM PANDORA_4.0
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7351 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-03 19:52:21 +01:00
/**
* Get all the events happened in a group during a period of time .
*
* The returned events will be in the time interval ( $date - $period , $date ]
*
2019-01-30 16:18:44 +01:00
* @ param mixed $id_group Group id to get events for .
* @ param integer $period Period of time in seconds to get events .
* @ param integer $date Beginning date to get events .
2013-01-03 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php,
extensions/resource_exportation.php,
operation/events/event_statistics.php,
operation/events/events_list.php,
operation/reporting/reporting_viewer.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.item_editor.php,
include/functions_alerts.php, include/functions_reports.php,
include/functions_events.php, include/graphs/fgraph.php,
include/functions_graph.php, include/styles/pandora.css,
include/functions_reporting.php, include/functions_agents.php: a lot
of changes and fixes from the branch for the reports.
MERGED FROM PANDORA_4.0
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7351 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-03 19:52:21 +01:00
*
* @ return array An array with all the events happened .
*/
2019-01-30 16:18:44 +01:00
function events_get_count_events_validated (
$filter ,
$period = null ,
$date = null ,
$filter_event_severity = false ,
$filter_event_type = false ,
$filter_event_status = false ,
$filter_event_filter_search = false ,
$dbmeta = false
) {
global $config ;
// group
$sql_filter = ' 1=1 ' ;
if ( isset ( $filter [ 'id_group' ])) {
$id_group = groups_safe_acl ( $config [ 'id_user' ], $filter [ 'id_group' ], 'AR' );
if ( empty ( $id_group )) {
// An empty array means the user doesn't have access
return false ;
}
$sql_filter .= sprintf ( ' AND id_grupo IN (%s) ' , implode ( ',' , $id_group ));
}
// agent
if ( ! empty ( $filter [ 'id_agent' ])) {
$sql_filter .= sprintf ( ' AND id_agente = %d ' , $filter [ 'id_agent' ]);
}
// module
if ( ! empty ( $filter [ 'id_agentmodule' ])) {
$sql_filter .= sprintf ( ' AND id_agentmodule = %d ' , $filter [ 'id_agentmodule' ]);
}
// date
if ( ! is_numeric ( $date )) {
$date = time_w_fixed_tz ( $date );
}
if ( empty ( $date )) {
$date = get_system_time ();
}
$date_filter = '' ;
if ( ! empty ( $date ) && ! empty ( $period )) {
$datelimit = ( $date - $period );
$date_filter .= sprintf (
' AND utimestamp > %d AND utimestamp <= %d ' ,
$datelimit ,
$date
);
} else if ( ! empty ( $period )) {
$date = time ();
$datelimit = ( $date - $period );
$date_filter .= sprintf (
' AND utimestamp > %d AND utimestamp <= %d ' ,
$datelimit ,
$date
);
} else if ( ! empty ( $date )) {
$date_filter .= sprintf ( ' AND utimestamp <= %d ' , $date );
}
$sql_where = '' ;
$severity_all = 0 ;
if ( ! empty ( $filter_event_severity )) {
foreach ( $filter_event_severity as $key => $value ) {
switch ( $value ) {
case - 1 :
$severity_all = 1 ;
break ;
case 34 :
$filter_event_severity [ $key ] = '3, 4' ;
break ;
case 20 :
$filter_event_severity [ $key ] = '0, 1, 3, 4, 5, 6' ;
break ;
case 21 :
$filter_event_severity [ $key ] = '4, 2' ;
break ;
default :
break ;
}
}
if ( ! $severity_all ) {
$sql_where .= ' AND criticity IN (' . implode ( ', ' , $filter_event_severity ) . ')' ;
}
}
$status_all = 0 ;
if ( ! empty ( $filter_event_status )) {
foreach ( $filter_event_status as $key => $value ) {
switch ( $value ) {
case - 1 :
$status_all = 1 ;
break ;
case 3 :
$filter_event_status [ $key ] = ( '0, 2' );
default :
break ;
}
}
if ( ! $status_all ) {
$sql_where .= ' AND estado IN (' . implode ( ', ' , $filter_event_status ) . ')' ;
}
}
if ( ! empty ( $filter_event_type ) && $filter_event_type [ 0 ] != 'all' ) {
$sql_where .= ' AND (' ;
$type = [];
foreach ( $filter_event_type as $event_type ) {
if ( $event_type != '' ) {
// If normal, warning, could be several (going_up_warning, going_down_warning... too complex
// for the user so for him is presented only "warning, critical and normal"
if ( $event_type == 'warning' || $event_type == 'critical' || $event_type == 'normal' ) {
$type [] = " event_type LIKE '% $event_type %' " ;
} else if ( $event_type == 'not_normal' ) {
$type [] = " (event_type LIKE '%warning%' OR event_type LIKE '%critical%' OR event_type LIKE '%unknown%') " ;
} else if ( $event_type != 'all' ) {
$type [] = " event_type = ' " . $event_type . " ' " ;
}
}
}
$sql_where .= implode ( ' OR ' , $type ) . ')' ;
}
if ( ! empty ( $filter_event_filter_search )) {
$sql_where .= ' AND (evento LIKE "%' . io_safe_input ( $filter_event_filter_search ) . '%"' . ' OR id_evento LIKE "%' . io_safe_input ( $filter_event_filter_search ) . '%")' ;
}
$tevento = 'tevento' ;
if ( $dbmeta ) {
$tevento = 'tmetaconsole_event' ;
}
$sql = sprintf ( 'SELECT estado, COUNT(*) AS count FROM %s WHERE %s %s GROUP BY estado' , $tevento , $sql_filter , $sql_where );
$rows = db_get_all_rows_sql ( $sql );
if ( $rows == false ) {
$rows = [];
}
$return = array_reduce (
$rows ,
function ( $carry , $item ) {
$status = ( int ) $item [ 'estado' ];
$count = ( int ) $item [ 'count' ];
if ( $status === 1 ) {
$carry [ __ ( 'Validated' )] += $count ;
} else if ( $status === 0 ) {
$carry [ __ ( 'Not validated' )] += $count ;
}
return $carry ;
},
[
__ ( 'Validated' ) => 0 ,
__ ( 'Not validated' ) => 0 ,
]
);
return $return ;
2013-01-03 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php,
extensions/resource_exportation.php,
operation/events/event_statistics.php,
operation/events/events_list.php,
operation/reporting/reporting_viewer.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/reporting_builder.item_editor.php,
include/functions_alerts.php, include/functions_reports.php,
include/functions_events.php, include/graphs/fgraph.php,
include/functions_graph.php, include/styles/pandora.css,
include/functions_reporting.php, include/functions_agents.php: a lot
of changes and fixes from the branch for the reports.
MERGED FROM PANDORA_4.0
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7351 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-03 19:52:21 +01:00
}
2015-01-27 11:44:26 +01:00
2019-01-30 16:18:44 +01:00
function events_checks_event_tags ( $event_data , $acltags )
{
global $config ;
if ( empty ( $acltags [ $event_data [ 'id_grupo' ]])) {
return true ;
} else {
$tags_arr_acl = explode ( ',' , $acltags [ $event_data [ 'id_grupo' ]]);
$tags_arr_event = explode ( ',' , $event_data [ 'tags' ]);
foreach ( $tags_arr_acl as $tag ) {
$tag_name = tags_get_name ( $tag );
if ( in_array ( $tag_name , $tags_arr_event )) {
return true ;
} else {
$has_tag = false ;
}
}
if ( ! $has_tag ) {
return false ;
}
}
return false ;
2015-01-27 11:44:26 +01:00
}
2016-05-23 09:22:57 +02:00
2019-01-30 16:18:44 +01:00
function events_get_events_grouped_by_agent (
$sql_post ,
$offset = 0 ,
$pagination = 1 ,
$meta = false ,
$history = false ,
$total = false
) {
global $config ;
$table = events_get_events_table ( $meta , $history );
if ( $meta ) {
$fields_extra = ', agent_name, server_id' ;
$groupby_extra = ', server_id' ;
} else {
$groupby_extra = '' ;
$fields_extra = '' ;
}
$event_lj = events_get_secondary_groups_left_join ( $table );
if ( $total ) {
$sql = " SELECT COUNT(*) FROM (select id_agente from $table $event_lj WHERE 1=1
2018-03-27 17:53:11 +02:00
$sql_post GROUP BY id_agente , event_type $groupby_extra ORDER BY id_agente ) AS t " ;
2019-01-30 16:18:44 +01:00
} else {
$sql = " select id_agente, count(*) as total $fields_extra from $table te $event_lj
2018-03-27 17:53:11 +02:00
WHERE id_agente > 0 $sql_post GROUP BY id_agente $groupby_extra ORDER BY id_agente LIMIT $offset , $pagination " ;
2019-01-30 16:18:44 +01:00
}
$result = [];
// Extract the events by filter (or not) from db
$events = db_get_all_rows_sql ( $sql );
$result = [];
if ( $events ) {
foreach ( $events as $event ) {
if ( $meta ) {
$sql = " select event_type from $table te $event_lj
2016-08-31 14:43:40 +02:00
WHERE agent_name = '".$event[' agent_name ']."' $sql_post ORDER BY utimestamp DESC " ;
2019-01-30 16:18:44 +01:00
$resultado = db_get_row_sql ( $sql );
$id_agente = $event [ 'agent_name' ];
$result [] = [
'total' => $event [ 'total' ],
'id_server' => $event [ 'server_id' ],
'id_agent' => $id_agente ,
'event_type' => $resultado [ 'event_type' ],
];
} else {
$sql = " SELECT event_type FROM $table te $event_lj
2016-07-22 16:08:45 +02:00
WHERE id_agente = " . $event['id_agente'] . " $sql_post ORDER BY utimestamp DESC " ;
2019-01-30 16:18:44 +01:00
$resultado = db_get_row_sql ( $sql );
$id_agente = $event [ 'id_agente' ];
$result [] = [
'total' => $event [ 'total' ],
'id_agent' => $id_agente ,
'event_type' => $resultado [ 'event_type' ],
];
}
}
}
return $result ;
2016-05-23 09:22:57 +02:00
}
2016-07-22 16:08:45 +02:00
2019-01-30 16:18:44 +01:00
function events_sql_events_grouped_agents (
$id_agent ,
$server_id =- 1 ,
$event_type = '' ,
$severity =- 1 ,
$status = 3 ,
$search = '' ,
$id_agent_module = 0 ,
$event_view_hr = 8 ,
$id_user_ack = false ,
$tag_with = [],
$tag_without = [],
$filter_only_alert = false ,
$date_from = '' ,
$date_to = '' ,
$id_user = false ,
$server_id_search = false
) {
global $config ;
$sql_post = ' 1 = 1 ' ;
$meta = false ;
if ( is_metaconsole ()) {
$meta = true ;
}
switch ( $status ) {
case 0 :
case 1 :
case 2 :
$sql_post .= ' AND estado = ' . $status ;
break ;
case 3 :
$sql_post .= ' AND (estado = 0 OR estado = 2)' ;
break ;
}
if ( $search != '' ) {
$sql_post .= " AND (evento LIKE '% " . io_safe_input ( $search ) . " %' OR id_evento LIKE '% $search %') " ;
}
if ( $event_type != '' ) {
// If normal, warning, could be several (going_up_warning, going_down_warning... too complex
// for the user so for him is presented only "warning, critical and normal"
if ( $event_type == 'warning' || $event_type == 'critical' || $event_type == 'normal' ) {
$sql_post .= " AND event_type LIKE '% $event_type %' " ;
} else if ( $event_type == 'not_normal' ) {
$sql_post .= " AND (event_type LIKE '%warning%' OR event_type LIKE '%critical%' OR event_type LIKE '%unknown%') " ;
} else if ( $event_type != 'all' ) {
$sql_post .= " AND event_type = ' " . $event_type . " ' " ;
}
}
if ( $severity != - 1 ) {
switch ( $severity ) {
case EVENT_CRIT_WARNING_OR_CRITICAL :
$sql_post .= '
AND ( criticity = '.EVENT_CRIT_WARNING.' OR
criticity = '.EVENT_CRIT_CRITICAL.' ) ' ;
break ;
case EVENT_CRIT_OR_NORMAL :
$sql_post .= '
AND ( criticity = '.EVENT_CRIT_NORMAL.' OR
criticity = '.EVENT_CRIT_CRITICAL.' ) ' ;
break ;
case EVENT_CRIT_NOT_NORMAL :
$sql_post .= ' AND criticity != ' . EVENT_CRIT_NORMAL ;
break ;
default :
$sql_post .= " AND criticity = $severity " ;
break ;
}
}
// In metaconsole mode the agent search is performed by name
if ( $meta ) {
if ( $id_agent != __ ( 'All' )) {
$sql_post .= " AND agent_name LIKE '% $id_agent %' " ;
}
} else {
switch ( $id_agent ) {
case 0 :
break ;
case - 1 :
// Agent doesnt exist. No results will returned
$sql_post .= ' AND 1 = 0' ;
break ;
default :
$sql_post .= ' AND id_agente = ' . $id_agent ;
break ;
}
}
if ( $meta ) {
// There is another filter.
} else {
if ( ! empty ( $text_module )) {
$sql_post .= " AND id_agentmodule IN (
2016-07-22 16:08:45 +02:00
SELECT id_agente_modulo
FROM tagente_modulo
WHERE nombre = '$text_module'
) " ;
2019-01-30 16:18:44 +01:00
}
}
if ( $id_user_ack != '0' ) {
$sql_post .= " AND id_usuario = ' " . $id_user_ack . " ' " ;
}
if ( ! isset ( $date_from )) {
$date_from = '' ;
}
if ( ! isset ( $date_to )) {
$date_to = '' ;
}
if (( $date_from == '' ) && ( $date_to == '' )) {
if ( $event_view_hr > 0 ) {
$unixtime = ( get_system_time () - ( $event_view_hr * SECONDS_1HOUR ));
$sql_post .= ' AND (utimestamp > ' . $unixtime . ')' ;
}
} else {
if ( $date_from != '' ) {
$udate_from = strtotime ( $date_from . ' 00:00:00' );
$sql_post .= ' AND (utimestamp >= ' . $udate_from . ')' ;
}
if ( $date_to != '' ) {
$udate_to = strtotime ( $date_to . ' 23:59:59' );
$sql_post .= ' AND (utimestamp <= ' . $udate_to . ')' ;
}
}
// Search by tag
if ( ! empty ( $tag_with ) && ( io_safe_output ( $tag_with ) != '[]' ) && ( io_safe_output ( $tag_with ) != '["0"]' )) {
$sql_post .= ' AND ( ' ;
$first = true ;
foreach ( $tag_with as $id_tag ) {
if ( $first ) {
$first = false ;
} else {
$sql_post .= ' OR ' ;
}
$sql_post .= " tags = ' " . tags_get_name ( $id_tag ) . " ' " ;
}
$sql_post .= ' ) ' ;
}
if ( ! empty ( $tag_without ) && ( io_safe_output ( $tag_without ) != '[]' ) && ( io_safe_output ( $tag_with ) != '["0"]' )) {
$sql_post .= ' AND ( ' ;
$first = true ;
foreach ( $tag_without as $id_tag ) {
if ( $first ) {
$first = false ;
} else {
$sql_post .= ' AND ' ;
}
$sql_post .= " tags <> ' " . tags_get_name ( $id_tag ) . " ' " ;
}
$sql_post .= ' ) ' ;
}
// Filter/Only alerts
if ( isset ( $filter_only_alert )) {
if ( $filter_only_alert == 0 ) {
$sql_post .= " AND event_type NOT LIKE '%alert%' " ;
} else if ( $filter_only_alert == 1 ) {
$sql_post .= " AND event_type LIKE '%alert%' " ;
}
}
// Tags ACLS
if ( $id_group > 0 && in_array ( $id_group , array_keys ( $groups ))) {
$group_array = ( array ) $id_group ;
} else {
$group_array = array_keys ( $groups );
}
$tags_acls_condition = tags_get_acl_tags (
$id_user ,
$group_array ,
'ER' ,
'event_condition' ,
'AND' ,
'' ,
$meta ,
[],
true
);
// FORCE CHECK SQL "(TAG = tag1 AND id_grupo = 1)"
if (( $tags_acls_condition != ERR_WRONG_PARAMETERS ) && ( $tags_acls_condition != ERR_ACL ) && ( $tags_acls_condition != - 110000 )) {
$sql_post .= $tags_acls_condition ;
}
// Metaconsole fitlers
if ( $meta ) {
if ( $server_id_search ) {
$sql_post .= ' AND server_id = ' . $server_id_search ;
} else {
$enabled_nodes = db_get_all_rows_sql (
'
2016-07-22 16:08:45 +02:00
SELECT id
FROM tmetaconsole_setup
2019-01-30 16:18:44 +01:00
WHERE disabled = 0 '
);
if ( empty ( $enabled_nodes )) {
$sql_post .= ' AND 1 = 0' ;
} else {
if ( $strict_user == 1 ) {
$enabled_nodes_id = [];
} else {
$enabled_nodes_id = [ 0 ];
}
foreach ( $enabled_nodes as $en ) {
$enabled_nodes_id [] = $en [ 'id' ];
}
$sql_post .= ' AND server_id IN (' . implode ( ',' , $enabled_nodes_id ) . ')' ;
}
}
}
return $sql_post ;
2016-07-22 16:08:45 +02:00
}
2019-01-30 16:18:44 +01:00
function events_list_events_grouped_agents ( $sql )
{
global $config ;
$table = events_get_events_table ( is_metaconsole (), $history );
$sql = " select * from $table
2018-10-05 09:40:08 +02:00
LEFT JOIN tagent_secondary_group
ON tagent_secondary_group . id_agent = tevento . id_agente
2016-07-22 16:08:45 +02:00
WHERE $sql " ;
2019-01-30 16:18:44 +01:00
$result = db_get_all_rows_sql ( $sql );
$group_rep = 0 ;
$meta = is_metaconsole ();
// fields that the user has selected to show
if ( $meta ) {
$show_fields = events_meta_get_custom_fields_user ();
} else {
$show_fields = explode ( ',' , $config [ 'event_fields' ]);
}
// headers
$i = 0 ;
$table = new stdClass ();
if ( ! isset ( $table -> width )) {
$table -> width = '100%' ;
}
$table -> id = 'eventtable' ;
$table -> cellpadding = 4 ;
$table -> cellspacing = 4 ;
if ( ! isset ( $table -> class )) {
$table -> class = 'databox data' ;
}
$table -> head = [];
$table -> data = [];
$table -> head [ $i ] = __ ( 'ID' );
$table -> align [ $i ] = 'left' ;
$i ++ ;
if ( in_array ( 'server_name' , $show_fields )) {
$table -> head [ $i ] = __ ( 'Server' );
$table -> align [ $i ] = 'left' ;
$i ++ ;
}
if ( in_array ( 'estado' , $show_fields )) {
$table -> head [ $i ] = __ ( 'Status' );
$table -> align [ $i ] = 'left' ;
$i ++ ;
}
if ( in_array ( 'id_evento' , $show_fields )) {
$table -> head [ $i ] = __ ( 'Event ID' );
$table -> align [ $i ] = 'left' ;
$i ++ ;
}
if ( in_array ( 'evento' , $show_fields )) {
$table -> head [ $i ] = __ ( 'Event Name' );
$table -> align [ $i ] = 'left' ;
$table -> style [ $i ] = 'min-width: 200px; max-width: 350px; word-break: break-all;' ;
$i ++ ;
}
if ( in_array ( 'id_agente' , $show_fields )) {
$table -> head [ $i ] = __ ( 'Agent name' );
$table -> align [ $i ] = 'left' ;
$table -> style [ $i ] = 'max-width: 350px; word-break: break-all;' ;
$i ++ ;
}
if ( in_array ( 'timestamp' , $show_fields )) {
$table -> head [ $i ] = __ ( 'Timestamp' );
$table -> align [ $i ] = 'left' ;
$i ++ ;
}
if ( in_array ( 'id_usuario' , $show_fields )) {
$table -> head [ $i ] = __ ( 'User' );
$table -> align [ $i ] = 'left' ;
$i ++ ;
}
if ( in_array ( 'owner_user' , $show_fields )) {
$table -> head [ $i ] = __ ( 'Owner' );
$table -> align [ $i ] = 'left' ;
$i ++ ;
}
if ( in_array ( 'id_grupo' , $show_fields )) {
$table -> head [ $i ] = __ ( 'Group' );
$table -> align [ $i ] = 'left' ;
$i ++ ;
}
if ( in_array ( 'event_type' , $show_fields )) {
$table -> head [ $i ] = __ ( 'Event type' );
$table -> align [ $i ] = 'left' ;
$table -> style [ $i ] = 'min-width: 85px;' ;
$i ++ ;
}
if ( in_array ( 'id_agentmodule' , $show_fields )) {
$table -> head [ $i ] = __ ( 'Agent Module' );
$table -> align [ $i ] = 'left' ;
$i ++ ;
}
if ( in_array ( 'id_alert_am' , $show_fields )) {
$table -> head [ $i ] = __ ( 'Alert' );
$table -> align [ $i ] = 'left' ;
$i ++ ;
}
if ( in_array ( 'criticity' , $show_fields )) {
$table -> head [ $i ] = __ ( 'Severity' );
$table -> align [ $i ] = 'left' ;
$i ++ ;
}
if ( in_array ( 'user_comment' , $show_fields )) {
$table -> head [ $i ] = __ ( 'Comment' );
$table -> align [ $i ] = 'left' ;
$i ++ ;
}
if ( in_array ( 'tags' , $show_fields )) {
$table -> head [ $i ] = __ ( 'Tags' );
$table -> align [ $i ] = 'left' ;
$i ++ ;
}
if ( in_array ( 'source' , $show_fields )) {
$table -> head [ $i ] = __ ( 'Source' );
$table -> align [ $i ] = 'left' ;
$i ++ ;
}
if ( in_array ( 'id_extra' , $show_fields )) {
$table -> head [ $i ] = __ ( 'Extra ID' );
$table -> align [ $i ] = 'left' ;
$i ++ ;
}
if ( in_array ( 'ack_utimestamp' , $show_fields )) {
$table -> head [ $i ] = __ ( 'ACK Timestamp' );
$table -> align [ $i ] = 'left' ;
$i ++ ;
}
if ( in_array ( 'instructions' , $show_fields )) {
$table -> head [ $i ] = __ ( 'Instructions' );
$table -> align [ $i ] = 'left' ;
$i ++ ;
}
if ( in_array ( 'data' , $show_fields )) {
$table -> head [ $i ] = __ ( 'Data' );
$table -> align [ $i ] = 'left' ;
$i ++ ;
}
if ( in_array ( 'module_status' , $show_fields )) {
$table -> head [ $i ] = __ ( 'Module status' );
$table -> align [ $i ] = 'left' ;
$i ++ ;
}
if ( $i != 0 && $allow_action ) {
$table -> head [ $i ] = __ ( 'Action' );
$table -> align [ $i ] = 'left' ;
$table -> size [ $i ] = '90px' ;
$i ++ ;
if ( check_acl ( $config [ 'id_user' ], 0 , 'EW' ) == 1 && ! $readonly ) {
$table -> head [ $i ] = html_print_checkbox ( 'all_validate_box' , '1' , false , true );
$table -> align [ $i ] = 'left' ;
}
}
if ( $meta ) {
// Get info of the all servers to use it on hash auth
$servers_url_hash = metaconsole_get_servers_url_hash ();
$servers = metaconsole_get_servers ();
}
$show_delete_button = false ;
$show_validate_button = false ;
$idx = 0 ;
// Arrange data. We already did ACL's in the query
foreach ( $result as $event ) {
$data = [];
if ( $meta ) {
$event [ 'server_url_hash' ] = $servers_url_hash [ $event [ 'server_id' ]];
$event [ 'server_url' ] = $servers [ $event [ 'server_id' ]][ 'server_url' ];
$event [ 'server_name' ] = $servers [ $event [ 'server_id' ]][ 'server_name' ];
}
// Clean url from events and store in array
$event [ 'clean_tags' ] = events_clean_tags ( $event [ 'tags' ]);
// First pass along the class of this row
$myclass = get_priority_class ( $event [ 'criticity' ]);
// print status
$estado = $event [ 'estado' ];
// Colored box
switch ( $estado ) {
case EVENT_NEW :
$img_st = 'images/star.png' ;
$title_st = __ ( 'New event' );
break ;
case EVENT_VALIDATE :
$img_st = 'images/tick.png' ;
$title_st = __ ( 'Event validated' );
break ;
case EVENT_PROCESS :
$img_st = 'images/hourglass.png' ;
$title_st = __ ( 'Event in process' );
break ;
}
$i = 0 ;
$data [ $i ] = '#' . $event [ 'id_evento' ];
$table -> cellstyle [ count ( $table -> data )][ $i ] = 'background: #F3F3F3; color: #111 !important;' ;
// Pass grouped values in hidden fields to use it from modal window
if ( $group_rep ) {
$similar_ids = $event [ 'similar_ids' ];
$timestamp_first = $event [ 'timestamp_rep_min' ];
$timestamp_last = $event [ 'timestamp_rep' ];
} else {
$similar_ids = $event [ 'id_evento' ];
$timestamp_first = $event [ 'utimestamp' ];
$timestamp_last = $event [ 'utimestamp' ];
}
// Store group data to show in extended view
$data [ $i ] .= html_print_input_hidden ( 'similar_ids_' . $event [ 'id_evento' ], $similar_ids , true );
$data [ $i ] .= html_print_input_hidden ( 'timestamp_first_' . $event [ 'id_evento' ], $timestamp_first , true );
$data [ $i ] .= html_print_input_hidden ( 'timestamp_last_' . $event [ 'id_evento' ], $timestamp_last , true );
$data [ $i ] .= html_print_input_hidden ( 'childrens_ids' , json_encode ( $childrens_ids ), true );
// Store server id if is metaconsole. 0 otherwise
if ( $meta ) {
$server_id = $event [ 'server_id' ];
// If meta activated, propagate the id of the event on node (source id)
$data [ $i ] .= html_print_input_hidden ( 'source_id_' . $event [ 'id_evento' ], $event [ 'id_source_event' ], true );
$table -> cellclass [ count ( $table -> data )][ $i ] = $myclass ;
} else {
$server_id = 0 ;
}
$data [ $i ] .= html_print_input_hidden ( 'server_id_' . $event [ 'id_evento' ], $server_id , true );
if ( empty ( $event [ 'event_rep' ])) {
$event [ 'event_rep' ] = 0 ;
}
$data [ $i ] .= html_print_input_hidden ( 'event_rep_' . $event [ 'id_evento' ], $event [ 'event_rep' ], true );
// Store concat comments to show in extended view
$data [ $i ] .= html_print_input_hidden ( 'user_comment_' . $event [ 'id_evento' ], base64_encode ( $event [ 'user_comment' ]), true );
$i ++ ;
if ( in_array ( 'server_name' , $show_fields )) {
if ( $meta ) {
if ( can_user_access_node ()) {
$data [ $i ] = " <a href=' " . $event [ 'server_url' ] . '/index.php?sec=estado&sec2=operation/agentes/group_view' . $event [ 'server_url_hash' ] . " '> " . $event [ 'server_name' ] . '</a>' ;
} else {
$data [ $i ] = $event [ 'server_name' ];
}
} else {
$data [ $i ] = db_get_value ( 'name' , 'tserver' );
}
$table -> cellclass [ count ( $table -> data )][ $i ] = $myclass ;
$i ++ ;
}
if ( in_array ( 'estado' , $show_fields )) {
$data [ $i ] = html_print_image (
$img_st ,
true ,
[
'class' => 'image_status' ,
'title' => $title_st ,
'id' => 'status_img_' . $event [ 'id_evento' ],
]
);
$table -> cellstyle [ count ( $table -> data )][ $i ] = 'background: #F3F3F3;' ;
$i ++ ;
}
if ( in_array ( 'id_evento' , $show_fields )) {
$data [ $i ] = $event [ 'id_evento' ];
$table -> cellclass [ count ( $table -> data )][ $i ] = $myclass ;
$i ++ ;
}
switch ( $event [ 'criticity' ]) {
default :
case 0 :
$img_sev = 'images/status_sets/default/severity_maintenance.png' ;
break ;
case 1 :
$img_sev = 'images/status_sets/default/severity_informational.png' ;
break ;
case 2 :
$img_sev = 'images/status_sets/default/severity_normal.png' ;
break ;
case 3 :
$img_sev = 'images/status_sets/default/severity_warning.png' ;
break ;
case 4 :
$img_sev = 'images/status_sets/default/severity_critical.png' ;
break ;
case 5 :
$img_sev = 'images/status_sets/default/severity_minor.png' ;
break ;
case 6 :
$img_sev = 'images/status_sets/default/severity_major.png' ;
break ;
}
if ( in_array ( 'evento' , $show_fields )) {
// Event description
$data [ $i ] = '<span title="' . $event [ 'evento' ] . '" class="f9">' ;
if ( $allow_action ) {
$data [ $i ] .= '<a href="javascript:" onclick="show_event_dialog(' . $event [ 'id_evento' ] . ', ' . $group_rep . ');">' ;
}
$data [ $i ] .= '<span class="' . $myclass . '" style="font-size: 7.5pt;">' . ui_print_truncate_text ( io_safe_output ( $event [ 'evento' ]), 160 ) . '</span>' ;
if ( $allow_action ) {
$data [ $i ] .= '</a>' ;
}
$data [ $i ] .= '</span>' ;
$table -> cellclass [ count ( $table -> data )][ $i ] = $myclass ;
$i ++ ;
}
if ( in_array ( 'id_agente' , $show_fields )) {
$data [ $i ] = '<span class="' . $myclass . '">' ;
if ( $event [ 'id_agente' ] > 0 ) {
// Agent name
if ( $meta ) {
$agent_link = '<a href="' . $event [ 'server_url' ] . '/index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente=' . $event [ 'id_agente' ] . $event [ 'server_url_hash' ] . '">' ;
if ( can_user_access_node ()) {
$data [ $i ] = '<b>' . $agent_link . $event [ 'agent_name' ] . '</a></b>' ;
} else {
$data [ $i ] = $event [ 'agent_name' ];
}
} else {
$data [ $i ] .= ui_print_agent_name ( $event [ 'id_agente' ], true );
}
} else {
$data [ $i ] .= '' ;
}
$data [ $i ] .= '</span>' ;
$table -> cellclass [ count ( $table -> data )][ $i ] = $myclass ;
$i ++ ;
}
if ( in_array ( 'timestamp' , $show_fields )) {
// Time
$data [ $i ] = '<span class="' . $myclass . '">' ;
if ( $group_rep == 1 ) {
$data [ $i ] .= ui_print_timestamp ( $event [ 'timestamp_rep' ], true );
} else {
$data [ $i ] .= ui_print_timestamp ( $event [ 'timestamp' ], true );
}
$data [ $i ] .= '</span>' ;
$table -> cellclass [ count ( $table -> data )][ $i ] = $myclass ;
$i ++ ;
}
if ( in_array ( 'id_usuario' , $show_fields )) {
$user_name = db_get_value ( 'fullname' , 'tusuario' , 'id_user' , $event [ 'id_usuario' ]);
if ( empty ( $user_name )) {
$user_name = $event [ 'id_usuario' ];
}
$data [ $i ] = $user_name ;
$table -> cellclass [ count ( $table -> data )][ $i ] = $myclass ;
$i ++ ;
}
if ( in_array ( 'owner_user' , $show_fields )) {
$owner_name = db_get_value ( 'fullname' , 'tusuario' , 'id_user' , $event [ 'owner_user' ]);
if ( empty ( $owner_name )) {
$owner_name = $event [ 'owner_user' ];
}
$data [ $i ] = $owner_name ;
$table -> cellclass [ count ( $table -> data )][ $i ] = $myclass ;
$i ++ ;
}
if ( in_array ( 'id_grupo' , $show_fields )) {
if ( $meta ) {
$data [ $i ] = $event [ 'group_name' ];
} else {
$id_group = $event [ 'id_grupo' ];
$group_name = db_get_value ( 'nombre' , 'tgrupo' , 'id_grupo' , $id_group );
if ( $id_group == 0 ) {
$group_name = __ ( 'All' );
}
$data [ $i ] = $group_name ;
}
$table -> cellclass [ count ( $table -> data )][ $i ] = $myclass ;
$i ++ ;
}
if ( in_array ( 'event_type' , $show_fields )) {
$data [ $i ] = events_print_type_description ( $event [ 'event_type' ], true );
$table -> cellclass [ count ( $table -> data )][ $i ] = $myclass ;
$i ++ ;
}
if ( in_array ( 'id_agentmodule' , $show_fields )) {
if ( $meta ) {
$module_link = '<a href="' . $event [ 'server_url' ] . '/index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente=' . $event [ 'id_agente' ] . $event [ 'server_url_hash' ] . '">' ;
if ( can_user_access_node ()) {
$data [ $i ] = '<b>' . $module_link . $event [ 'module_name' ] . '</a></b>' ;
} else {
$data [ $i ] = $event [ 'module_name' ];
}
} else {
$module_name = db_get_value ( 'nombre' , 'tagente_modulo' , 'id_agente_modulo' , $event [ 'id_agentmodule' ]);
$data [ $i ] = '<a href="index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente=' . $event [ 'id_agente' ] . '&status_text_monitor=' . io_safe_output ( $module_name ) . '#monitors">' . $module_name . '</a>' ;
}
$table -> cellclass [ count ( $table -> data )][ $i ] = $myclass ;
$i ++ ;
}
if ( in_array ( 'id_alert_am' , $show_fields )) {
if ( $meta ) {
$data [ $i ] = $event [ 'alert_template_name' ];
} else {
if ( $event [ 'id_alert_am' ] != 0 ) {
$sql = ' SELECT name
2016-07-22 16:08:45 +02:00
FROM talert_templates
WHERE id IN ( SELECT id_alert_template
FROM talert_template_modules
2019-01-30 16:18:44 +01:00
WHERE id = '.$event[' id_alert_am '].' ); ' ;
$templateName = db_get_sql ( $sql );
$data [ $i ] = '<a href="index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente=' . $event [ 'id_agente' ] . '&tab=alert">' . $templateName . '</a>' ;
} else {
$data [ $i ] = '' ;
}
}
$table -> cellclass [ count ( $table -> data )][ $i ] = $myclass ;
$i ++ ;
}
if ( in_array ( 'criticity' , $show_fields )) {
$data [ $i ] = get_priority_name ( $event [ 'criticity' ]);
$table -> cellclass [ count ( $table -> data )][ $i ] = $myclass ;
$i ++ ;
}
if ( in_array ( 'user_comment' , $show_fields )) {
$safe_event_user_comment = strip_tags ( io_safe_output ( $event [ 'user_comment' ]));
$line_breaks = [
" \r \n " ,
" \n " ,
" \r " ,
];
$safe_event_user_comment = str_replace ( $line_breaks , '<br>' , $safe_event_user_comment );
$event_user_comments = json_decode ( $safe_event_user_comment , true );
$event_user_comment_str = '' ;
if ( ! empty ( $event_user_comments )) {
$last_key = key ( array_slice ( $event_user_comments , - 1 , 1 , true ));
$date_format = $config [ 'date_format' ];
foreach ( $event_user_comments as $key => $event_user_comment ) {
$event_user_comment_str .= sprintf (
'%s: %s<br>%s: %s<br>%s: %s<br>' ,
__ ( 'Date' ),
date ( $date_format , $event_user_comment [ 'utimestamp' ]),
__ ( 'User' ),
$event_user_comment [ 'id_user' ],
__ ( 'Comment' ),
$event_user_comment [ 'comment' ]
);
if ( $key != $last_key ) {
$event_user_comment_str .= '<br>' ;
}
}
}
$comments_help_tip = '' ;
if ( ! empty ( $event_user_comment_str )) {
$comments_help_tip = ui_print_help_tip ( $event_user_comment_str , true );
}
$data [ $i ] = '<span id="comment_header_' . $event [ 'id_evento' ] . '">' . $comments_help_tip . '</span>' ;
$table -> cellclass [ count ( $table -> data )][ $i ] = $myclass ;
$i ++ ;
}
if ( in_array ( 'tags' , $show_fields )) {
$data [ $i ] = tags_get_tags_formatted ( $event [ 'tags' ]);
$table -> cellclass [ count ( $table -> data )][ $i ] = $myclass ;
$i ++ ;
}
if ( in_array ( 'source' , $show_fields )) {
$data [ $i ] = $event [ 'source' ];
$table -> cellclass [ count ( $table -> data )][ $i ] = $myclass ;
$i ++ ;
}
if ( in_array ( 'id_extra' , $show_fields )) {
$data [ $i ] = $event [ 'id_extra' ];
$table -> cellclass [ count ( $table -> data )][ $i ] = $myclass ;
$i ++ ;
}
if ( in_array ( 'ack_utimestamp' , $show_fields )) {
if ( $event [ 'ack_utimestamp' ] == 0 ) {
$data [ $i ] = '' ;
} else {
$data [ $i ] = date ( $config [ 'date_format' ], $event [ 'ack_utimestamp' ]);
}
$table -> cellclass [ count ( $table -> data )][ $i ] = $myclass ;
$i ++ ;
}
if ( in_array ( 'instructions' , $show_fields )) {
switch ( $event [ 'event_type' ]) {
case 'going_unknown' :
if ( ! empty ( $event [ 'unknown_instructions' ])) {
$data [ $i ] = html_print_image ( 'images/page_white_text.png' , true , [ 'title' => str_replace ( " \n " , '<br>' , io_safe_output ( $event [ 'unknown_instructions' ]))]);
}
break ;
case 'going_up_critical' :
case 'going_down_critical' :
if ( ! empty ( $event [ 'critical_instructions' ])) {
$data [ $i ] = html_print_image ( 'images/page_white_text.png' , true , [ 'title' => str_replace ( " \n " , '<br>' , io_safe_output ( $event [ 'critical_instructions' ]))]);
}
break ;
case 'going_down_warning' :
if ( ! empty ( $event [ 'warning_instructions' ])) {
$data [ $i ] = html_print_image ( 'images/page_white_text.png' , true , [ 'title' => str_replace ( " \n " , '<br>' , io_safe_output ( $event [ 'warning_instructions' ]))]);
}
break ;
case 'system' :
if ( ! empty ( $event [ 'critical_instructions' ])) {
$data [ $i ] = html_print_image ( 'images/page_white_text.png' , true , [ 'title' => str_replace ( " \n " , '<br>' , io_safe_output ( $event [ 'critical_instructions' ]))]);
} else if ( ! empty ( $event [ 'warning_instructions' ])) {
$data [ $i ] = html_print_image ( 'images/page_white_text.png' , true , [ 'title' => str_replace ( " \n " , '<br>' , io_safe_output ( $event [ 'warning_instructions' ]))]);
} else if ( ! empty ( $event [ 'unknown_instructions' ])) {
$data [ $i ] = html_print_image ( 'images/page_white_text.png' , true , [ 'title' => str_replace ( " \n " , '<br>' , io_safe_output ( $event [ 'unknown_instructions' ]))]);
}
break ;
}
if ( ! isset ( $data [ $i ])) {
$data [ $i ] = '' ;
}
$table -> cellclass [ count ( $table -> data )][ $i ] = $myclass ;
$i ++ ;
}
if ( in_array ( 'data' , $show_fields )) {
$data [ $i ] = $event [ 'data' ];
if (( $data [ $i ] % 1 ) == 0 ) {
$data [ $i ] = number_format ( $data [ $i ], 0 );
} else {
$data [ $i ] = number_format ( $data [ $i ], 2 );
}
$table -> cellclass [ count ( $table -> data )][ $i ] = $myclass ;
$i ++ ;
}
if ( in_array ( 'module_status' , $show_fields )) {
$data [ $i ] = modules_get_modules_status ( $event [ 'module_status' ]);
$table -> cellclass [ count ( $table -> data )][ $i ] = $myclass ;
$i ++ ;
}
if ( $i != 0 && $allow_action ) {
// Actions
$data [ $i ] = '' ;
if ( ! $readonly ) {
// Validate event
if (( $event [ 'estado' ] != 1 ) && ( tags_checks_event_acl ( $config [ 'id_user' ], $event [ 'id_grupo' ], 'EW' , $event [ 'clean_tags' ], $childrens_ids ))) {
$show_validate_button = true ;
$data [ $i ] .= '<a href="javascript:validate_event_advanced(' . $event [ 'id_evento' ] . ', 1)" id="validate-' . $event [ 'id_evento' ] . '">' ;
$data [ $i ] .= html_print_image (
'images/ok.png' ,
true ,
[ 'title' => __ ( 'Validate event' )]
);
$data [ $i ] .= '</a>' ;
}
// Delete event
if (( tags_checks_event_acl ( $config [ 'id_user' ], $event [ 'id_grupo' ], 'EM' , $event [ 'clean_tags' ], $childrens_ids ) == 1 )) {
if ( $event [ 'estado' ] != 2 ) {
$show_delete_button = true ;
$data [ $i ] .= '<a class="delete_event" href="javascript:" id="delete-' . $event [ 'id_evento' ] . '">' ;
$data [ $i ] .= html_print_image (
'images/cross.png' ,
true ,
[
'title' => __ ( 'Delete event' ),
'id' => 'delete_cross_' . $event [ 'id_evento' ],
]
);
$data [ $i ] .= '</a>' ;
} else {
$data [ $i ] .= html_print_image (
'images/cross.disabled.png' ,
true ,
[ 'title' => __ ( 'Is not allowed delete events in process' )]
) . ' ' ;
}
}
}
$data [ $i ] .= '<a href="javascript:" onclick="show_event_dialog(' . $event [ 'id_evento' ] . ', ' . $group_rep . ');">' ;
$data [ $i ] .= html_print_input_hidden ( 'event_title_' . $event [ 'id_evento' ], '#' . $event [ 'id_evento' ] . ' - ' . $event [ 'evento' ], true );
$data [ $i ] .= html_print_image (
'images/eye.png' ,
true ,
[ 'title' => __ ( 'Show more' )]
);
$data [ $i ] .= '</a>' ;
$table -> cellstyle [ count ( $table -> data )][ $i ] = 'background: #F3F3F3;' ;
$i ++ ;
if ( ! $readonly ) {
if ( tags_checks_event_acl ( $config [ 'id_user' ], $event [ 'id_grupo' ], 'EM' , $event [ 'clean_tags' ], $childrens_ids ) == 1 ) {
// Checkbox
// Class 'candeleted' must be the fist class to be parsed from javascript. Dont change
$data [ $i ] = html_print_checkbox_extended ( 'validate_ids[]' , $event [ 'id_evento' ], false , false , false , 'class="candeleted chk_val"' , true );
} else if ( tags_checks_event_acl ( $config [ 'id_user' ], $event [ 'id_grupo' ], 'EW' , $event [ 'clean_tags' ], $childrens_ids ) == 1 ) {
// Checkbox
$data [ $i ] = html_print_checkbox_extended ( 'validate_ids[]' , $event [ 'id_evento' ], false , false , false , 'class="chk_val"' , true );
} else if ( isset ( $table -> header [ $i ]) || true ) {
$data [ $i ] = '' ;
}
}
$table -> cellstyle [ count ( $table -> data )][ $i ] = 'background: #F3F3F3;' ;
}
array_push ( $table -> data , $data );
$idx ++ ;
}
return html_print_table ( $table , true );
2016-07-22 16:08:45 +02:00
}
2019-01-30 16:18:44 +01:00
function events_get_sql_order ( $sort_field = 'timestamp' , $sort = 'DESC' , $group_rep = 0 )
{
$sort_field_translated = $sort_field ;
switch ( $sort_field ) {
case 'event_id' :
$sort_field_translated = 'id_evento' ;
break ;
case 'event_name' :
$sort_field_translated = 'evento' ;
break ;
case 'status' :
$sort_field_translated = 'estado' ;
break ;
case 'agent_id' :
$sort_field_translated = 'id_agente' ;
break ;
case 'timestamp' :
$sort_field_translated = ( $group_rep == 0 ) ? 'timestamp' : 'timestamp_rep' ;
break ;
case 'user_id' :
$sort_field_translated = 'id_usuario' ;
break ;
case 'owner' :
$sort_field_translated = 'owner_user' ;
break ;
case 'group_id' :
$sort_field_translated = 'id_grupo' ;
break ;
case 'alert_id' :
$sort_field_translated = 'id_alert_am' ;
break ;
case 'comment' :
$sort_field_translated = 'user_comment' ;
break ;
case 'extra_id' :
$sort_field_translated = 'id_extra' ;
break ;
}
$dir = ( $sort == 'up' ) ? 'ASC' : 'DESC' ;
return " ORDER BY $sort_field_translated $dir " ;
2018-08-14 10:40:56 +02:00
}
2016-07-22 16:08:45 +02:00
2019-01-30 16:18:44 +01:00
2018-08-14 17:08:00 +02:00
/**
* SQL left join of event queries to handle secondary groups
*
* @ param string Table to see if is metaconsole or not
*
* @ return string With the query .
*/
2019-01-30 16:18:44 +01:00
function events_get_secondary_groups_left_join ( $table )
{
if ( $table == 'tevento' ) {
return 'LEFT JOIN tagent_secondary_group tasg ON te.id_agente = tasg.id_agent' ;
}
return ' LEFT JOIN tmetaconsole_agent_secondary_group tasg
ON te . id_agente = tasg . id_tagente AND te . server_id = tasg . id_tmetaconsole_setup ' ;
2018-08-14 17:06:15 +02:00
}