2006-03-27 05:37:27 +02:00
< ? php
2022-10-28 15:01:00 +02:00
/**
2023-03-07 18:10:07 +01:00
* Export data .
2022-10-28 15:01:00 +02:00
*
2023-03-07 18:10:07 +01:00
* @ category Tools
2022-10-28 15:01:00 +02:00
* @ package Pandora FMS
2023-03-07 18:10:07 +01:00
* @ subpackage Operation
2022-10-28 15:01:00 +02:00
* @ version 1.0 . 0
* @ license See below
*
* ______ ___ _______ _______ ________
* | __ \ .-----.--.--.--| |.-----.----.-----. | ___ | | | __ |
* | __ /| _ | | _ || _ | _ | _ | | ___ | | __ |
* | ___ | | ___ . _ | __ | __ | _____ || _____ | __ | | ___ . _ | | ___ | | __ | _ | __ | _______ |
*
* ============================================================================
2023-03-07 18:10:07 +01:00
* Copyright ( c ) 2005 - 2023 Artica Soluciones Tecnologicas
* Please see http :// pandorafms . org for full contribution list
* This program is free software ; you can redistribute it and / or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation for version 2.
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
2022-10-28 15:01:00 +02:00
* ============================================================================
*/
2006-03-27 05:37:27 +02:00
2011-04-11 19:05:20 +02:00
global $config ;
2008-08-11 Esteban Sanchez <estebans@artica.es>
* include/functions_db.php: Added __ as an alias of lang_string().
* include/functions_reporting_pdf.php,
include/functions_reporting.php, include/functions.php,
include/functions_visual_map.php, index.php,
operation/incidents/incident.php,
operation/incidents/incident_detail.php,
operation/incidents/incident_note.php,
operation/incidents/incident_search.php,
operation/incidents/incident_statistics.php,
operation/snmpconsole/snmp_alert.php,
operation/snmpconsole/snmp_view.php, operation/users/user.php,
operation/users/user_edit.php, operation/users/user_statistics.php,
operation/events/event_statistics.php, operation/events/events.php,
operation/visual_console/render_view.php,
operation/visual_console/index.php, operation/extensions.php,
operation/agentes/estado_alertas.php,
operation/agentes/status_monitor.php,
operation/agentes/estado_grupo.php, operation/agentes/export_csv.php,
operation/agentes/datos_agente.php,
operation/agentes/estado_ultimopaquete.php,
operation/agentes/estado_generalagente.php,
operation/agentes/estado_agente.php, operation/agentes/bulbs.php,
operation/agentes/status_events.php, operation/agentes/sla_view.php,
operation/agentes/exportdata.php,
operation/agentes/estado_monitores.php,
operation/agentes/ver_agente.php, operation/agentes/estadisticas.php,
operation/agentes/tactical.php, operation/agentes/networkmap.php,
operation/messages/message.php,
operation/reporting/reporting_viewer.php,
operation/reporting/graph_viewer.php,
operation/reporting/custom_reporting.php,
operation/servers/view_server.php,
operation/servers/view_server_detail.php, operation/menu.php,
reporting/fgraph.php, reporting/stat_win.php, ajax.php,
general/logoff.php, general/pandora_help.php, general/footer.php,
general/noaccess.php, general/logon_failed.php,
general/links_menu.php, general/login_page.php, general/logon_ok.php,
general/header.php, general/main_menu.php,
godmode/groups/configure_group.php, godmode/groups/group_list.php,
godmode/setup/news.php, godmode/setup/links.php,
godmode/setup/setup.php, godmode/users/user_list.php,
godmode/users/configure_user.php, godmode/profiles/profile_list.php,
godmode/admin_access_logs.php, godmode/db/db_info_data.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_network.php,
godmode/agentes/module_manager_editor_wmi.php,
godmode/agentes/alert_manager.php,
godmode/agentes/module_manager_editor_plugin.php,
godmode/agentes/module_manager_editor_prediction.php,
godmode/agentes/alert_manager_editor.php,
godmode/agentes/manage_config.php,
godmode/agentes/module_manager_editor_data.php,
godmode/agentes/module_manager.php,
godmode/agentes/modificar_agente.php,
godmode/agentes/configurar_agente.php,
godmode/agentes/agent_disk_conf_editor.php,
godmode/agentes/planned_downtime.php,
godmode/agentes/manage_config_remote.php,
godmode/agentes/agent_manager.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_templates_form.php,
godmode/modules/manage_network_components_form_network.php,
godmode/modules/manage_network_components_form_wmi.php,
godmode/modules/manage_network_components.php,
godmode/modules/manage_nc_groups.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/map_builder.php,
godmode/reporting/graph_builder.php, godmode/servers/plugin.php,
godmode/servers/manage_recontask.php,
godmode/servers/modificar_server.php,
godmode/servers/manage_recontask_form.php,
godmode/alerts/modify_alert.php, godmode/alerts/configure_alert.php,
godmode/menu.php: Replaced $id_user with $config['id_user']. Use __a
instead of $lang_label to future use of gettext. Style
corrections.
* godmode/agentes/planned_downtime.php: Rewritten to use Pandora
functions and adopt the UI style. Replaced lang_string with __().
* pandoradb.sql: Fields in tplanned_downtime renamed to fit
guidelines.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1005 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2008-08-11 12:59:07 +02:00
// Load global vars
2019-01-30 16:18:44 +01:00
require_once 'include/config.php' ;
require_once 'include/functions_agents.php' ;
require_once 'include/functions_reporting.php' ;
require_once 'include/functions_modules.php' ;
require_once 'include/functions_users.php' ;
2008-08-11 Esteban Sanchez <estebans@artica.es>
* include/functions_db.php: Added __ as an alias of lang_string().
* include/functions_reporting_pdf.php,
include/functions_reporting.php, include/functions.php,
include/functions_visual_map.php, index.php,
operation/incidents/incident.php,
operation/incidents/incident_detail.php,
operation/incidents/incident_note.php,
operation/incidents/incident_search.php,
operation/incidents/incident_statistics.php,
operation/snmpconsole/snmp_alert.php,
operation/snmpconsole/snmp_view.php, operation/users/user.php,
operation/users/user_edit.php, operation/users/user_statistics.php,
operation/events/event_statistics.php, operation/events/events.php,
operation/visual_console/render_view.php,
operation/visual_console/index.php, operation/extensions.php,
operation/agentes/estado_alertas.php,
operation/agentes/status_monitor.php,
operation/agentes/estado_grupo.php, operation/agentes/export_csv.php,
operation/agentes/datos_agente.php,
operation/agentes/estado_ultimopaquete.php,
operation/agentes/estado_generalagente.php,
operation/agentes/estado_agente.php, operation/agentes/bulbs.php,
operation/agentes/status_events.php, operation/agentes/sla_view.php,
operation/agentes/exportdata.php,
operation/agentes/estado_monitores.php,
operation/agentes/ver_agente.php, operation/agentes/estadisticas.php,
operation/agentes/tactical.php, operation/agentes/networkmap.php,
operation/messages/message.php,
operation/reporting/reporting_viewer.php,
operation/reporting/graph_viewer.php,
operation/reporting/custom_reporting.php,
operation/servers/view_server.php,
operation/servers/view_server_detail.php, operation/menu.php,
reporting/fgraph.php, reporting/stat_win.php, ajax.php,
general/logoff.php, general/pandora_help.php, general/footer.php,
general/noaccess.php, general/logon_failed.php,
general/links_menu.php, general/login_page.php, general/logon_ok.php,
general/header.php, general/main_menu.php,
godmode/groups/configure_group.php, godmode/groups/group_list.php,
godmode/setup/news.php, godmode/setup/links.php,
godmode/setup/setup.php, godmode/users/user_list.php,
godmode/users/configure_user.php, godmode/profiles/profile_list.php,
godmode/admin_access_logs.php, godmode/db/db_info_data.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_network.php,
godmode/agentes/module_manager_editor_wmi.php,
godmode/agentes/alert_manager.php,
godmode/agentes/module_manager_editor_plugin.php,
godmode/agentes/module_manager_editor_prediction.php,
godmode/agentes/alert_manager_editor.php,
godmode/agentes/manage_config.php,
godmode/agentes/module_manager_editor_data.php,
godmode/agentes/module_manager.php,
godmode/agentes/modificar_agente.php,
godmode/agentes/configurar_agente.php,
godmode/agentes/agent_disk_conf_editor.php,
godmode/agentes/planned_downtime.php,
godmode/agentes/manage_config_remote.php,
godmode/agentes/agent_manager.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_templates_form.php,
godmode/modules/manage_network_components_form_network.php,
godmode/modules/manage_network_components_form_wmi.php,
godmode/modules/manage_network_components.php,
godmode/modules/manage_nc_groups.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/map_builder.php,
godmode/reporting/graph_builder.php, godmode/servers/plugin.php,
godmode/servers/manage_recontask.php,
godmode/servers/modificar_server.php,
godmode/servers/manage_recontask_form.php,
godmode/alerts/modify_alert.php, godmode/alerts/configure_alert.php,
godmode/menu.php: Replaced $id_user with $config['id_user']. Use __a
instead of $lang_label to future use of gettext. Style
corrections.
* godmode/agentes/planned_downtime.php: Rewritten to use Pandora
functions and adopt the UI style. Replaced lang_string with __().
* pandoradb.sql: Fields in tplanned_downtime renamed to fit
guidelines.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1005 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2008-08-11 12:59:07 +02:00
check_login ();
2019-01-30 16:18:44 +01:00
if ( ! check_acl ( $config [ 'id_user' ], 0 , 'RR' )) {
include 'general/noaccess.php' ;
return ;
2008-08-11 Esteban Sanchez <estebans@artica.es>
* include/functions_db.php: Added __ as an alias of lang_string().
* include/functions_reporting_pdf.php,
include/functions_reporting.php, include/functions.php,
include/functions_visual_map.php, index.php,
operation/incidents/incident.php,
operation/incidents/incident_detail.php,
operation/incidents/incident_note.php,
operation/incidents/incident_search.php,
operation/incidents/incident_statistics.php,
operation/snmpconsole/snmp_alert.php,
operation/snmpconsole/snmp_view.php, operation/users/user.php,
operation/users/user_edit.php, operation/users/user_statistics.php,
operation/events/event_statistics.php, operation/events/events.php,
operation/visual_console/render_view.php,
operation/visual_console/index.php, operation/extensions.php,
operation/agentes/estado_alertas.php,
operation/agentes/status_monitor.php,
operation/agentes/estado_grupo.php, operation/agentes/export_csv.php,
operation/agentes/datos_agente.php,
operation/agentes/estado_ultimopaquete.php,
operation/agentes/estado_generalagente.php,
operation/agentes/estado_agente.php, operation/agentes/bulbs.php,
operation/agentes/status_events.php, operation/agentes/sla_view.php,
operation/agentes/exportdata.php,
operation/agentes/estado_monitores.php,
operation/agentes/ver_agente.php, operation/agentes/estadisticas.php,
operation/agentes/tactical.php, operation/agentes/networkmap.php,
operation/messages/message.php,
operation/reporting/reporting_viewer.php,
operation/reporting/graph_viewer.php,
operation/reporting/custom_reporting.php,
operation/servers/view_server.php,
operation/servers/view_server_detail.php, operation/menu.php,
reporting/fgraph.php, reporting/stat_win.php, ajax.php,
general/logoff.php, general/pandora_help.php, general/footer.php,
general/noaccess.php, general/logon_failed.php,
general/links_menu.php, general/login_page.php, general/logon_ok.php,
general/header.php, general/main_menu.php,
godmode/groups/configure_group.php, godmode/groups/group_list.php,
godmode/setup/news.php, godmode/setup/links.php,
godmode/setup/setup.php, godmode/users/user_list.php,
godmode/users/configure_user.php, godmode/profiles/profile_list.php,
godmode/admin_access_logs.php, godmode/db/db_info_data.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_network.php,
godmode/agentes/module_manager_editor_wmi.php,
godmode/agentes/alert_manager.php,
godmode/agentes/module_manager_editor_plugin.php,
godmode/agentes/module_manager_editor_prediction.php,
godmode/agentes/alert_manager_editor.php,
godmode/agentes/manage_config.php,
godmode/agentes/module_manager_editor_data.php,
godmode/agentes/module_manager.php,
godmode/agentes/modificar_agente.php,
godmode/agentes/configurar_agente.php,
godmode/agentes/agent_disk_conf_editor.php,
godmode/agentes/planned_downtime.php,
godmode/agentes/manage_config_remote.php,
godmode/agentes/agent_manager.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_templates_form.php,
godmode/modules/manage_network_components_form_network.php,
godmode/modules/manage_network_components_form_wmi.php,
godmode/modules/manage_network_components.php,
godmode/modules/manage_nc_groups.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/map_builder.php,
godmode/reporting/graph_builder.php, godmode/servers/plugin.php,
godmode/servers/manage_recontask.php,
godmode/servers/modificar_server.php,
godmode/servers/manage_recontask_form.php,
godmode/alerts/modify_alert.php, godmode/alerts/configure_alert.php,
godmode/menu.php: Replaced $id_user with $config['id_user']. Use __a
instead of $lang_label to future use of gettext. Style
corrections.
* godmode/agentes/planned_downtime.php: Rewritten to use Pandora
functions and adopt the UI style. Replaced lang_string with __().
* pandoradb.sql: Fields in tplanned_downtime renamed to fit
guidelines.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1005 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2008-08-11 12:59:07 +02:00
}
2007-05-03 Sancho Lerena <slerena@artica.es>
* include/FreeSans.ttf: Added to repos, should be here to use in graphs.
* include/functions_db.php: Deleted noaccess include from
comprueba_login(). This should return value, not render pages or
exit.
* include/config.inc.php: Modified some typos.
* include/calendar.js: Added generic calendar javascript, to be
used on exportdata and incident management code.
* include/languages/language_en.php: More strings.
* install.php: In my render, box height is too low. PLEASE recheck
before changing this kind of properties because in other browsers
could have a bad render (Sophus!).
* index.php: Added script call (need to be done on header).
* operation/agentes/export_csv.php: Added new file to create a
standalone CSV on download icon / link.
* operation/agentes/exportdata.php: New export data code, used
some code from Leando Doctors, and mixed with old code. Now have
three options to render export data.
* operation/agentes/datos_agente_calendar.php: Deleted old code from Leandro.
* operation/active_console/lib/extra_functions.php: Solved a lot
of warnings, but there are TONS of more warnings that need to be
corrected.
* operation/active_console/lib/db_functions.php:Solved a lot of
warnings, but there are TONS of more warnings that need to be
corrected.
* operation/active_console/index.php: Solved a lot of warnings,
but there are TONS of more warnings that need to be
corrected. This code DONT work if you are showing warning/notice
erros. This code is not ready for production usage, too buggy yet
:(
* pandora_graphical_console_data.sql: Cleanup.
* godmode/agentes/module_manager.php: Added wizard button.
* pandora_graphical_console.sql: Cleanup.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@448 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2007-05-03 04:08:00 +02:00
2019-01-30 16:18:44 +01:00
ui_require_javascript_file ( 'calendar' );
2009-05-19 21:04:43 +02:00
2022-10-28 15:01:00 +02:00
// Header.
2023-03-07 18:10:07 +01:00
ui_print_standard_header (
__ ( 'Export data' ),
'images/server_export_mc.png' ,
false ,
'' ,
false ,
[],
[
[
'link' => '' ,
'label' => __ ( 'Tools' ),
],
[
'link' => '' ,
'label' => __ ( 'Export data' ),
],
]
);
2010-02-19 Sancho Lerena <slerena@artica.es>
* functions_events.php: Fixed typo (switched meaning) in two labels.
* include/styles/pandora.css: Changed background color of th default style.
* include/functions_reporting.php: Improved function get_group_stats(). Now
supports stats from batch-mode and get realtime stats in a more efficient
way. Fixed get_fired_alerts_reporting_table() to avoid problems in external
reporting (PDF & XML).
* include/functions_servers.php: get_server_performance() now uses batch mode
stats reporting, and improved also the realtime stats generation. Same with
function get_server_info().
* include/functions_config.php: Added new config tokens (not fully
implemented yet) for event, trap, strings and audit automatic purge.
* include/functions_ui.php: Added new print_page_header() function to set
the new standard header in all pages, using the "tabbed" format to show
the title, subtitle and other options like help, or custom-tabs for the page
* pandoradb.sql: Added tserver.stat_utimestamp field. Added indexes to
tsession table. Fixed typo in field name in tgroup_stat: agents_uknown to
agents_unknown.
* extensions/ext_backup: New directory to place "deleted" extensions.
* extensions/dbmanager/dbmanager.css: Table names now are in it's original
lowercase/uppercase format.
* extensions/dbmanager.php: Updated headers, and now return "empty" when
a search is empty, instead "error" as before.
* extensions/users_connected.php
extensions/module_groups.php
extensions/plugin_registration.php
extensions/pandora_logs.php
operation/incidents/incident.php
operation/snmpconsole/snmp_view.php
operation/users/user.php
operation/users/user_edit.php
godmode/agentes/planned_downtime.php
operation/events/events.php
operation/visual_console/index.php
operation/agentes/estado_generalagente.php
operation/agentes/estado_agente.php
operation/agentes/exportdata.php
operation/agentes/ver_agente.php
operation/agentes/status_monitor.php
operation/agentes/alerts_status.php
operation/users/user_statistics.php: Added new header format.
* operation/agentes/estado_grupo.php: Removed old group view.
* operation/agentes/tactical.php: Adapted to use new realtime/batch
statistical system. Placed events above server info. Showing only pending
events and other minor changes.
* operation/agentes/group_view.php: NEW screen, replacing old one. Probably
most ugly, but much more useful than before.
* operation/agentes/networkmap.php: Added title.
* operation/messages/message.php: Added title and adding some exists in
code was missing before.
* operation/reporting/reporting_viewer.php: Added title.
* operation/reporting/graph_viewer.php: Added title.
* operation/reporting/custom_reporting.php: Added title.
* operation/servers/view_server.php:
* operation/menu.php: Replaced old group view with new (this has english
name). Removed autorefresh "by default" in server view.
* extras/pandoradb_migrate_v3.0_to_v3.1.sql: Fixed typo.
* extras/pandora_diag.php: Minor changes, removed some info and added other.
* general/logon_ok.php: Minor aesthetic changes.
* general/header.php: Fixed missing ";"
* operation/extensions.php,
godmode/extensions.php: Added support for delete extensions.
* godmode/menu.php: New setup items.
* godmode/setup/setup.php,
godmode/setup/performance.php,
godmode/setup/setup_visuals.php: Reordered setup options, new setup section
"Performance", added new performance options to set "realtime" statistics
or "batchmode" with it's own interval. Some setup info is now shared with
the servers (but it it's any change in setup, servers should be restarted
anyway).
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@2390 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2010-02-19 16:16:03 +01:00
2019-01-30 16:18:44 +01:00
$group = get_parameter_post ( 'group' , 0 );
$agentName = get_parameter_post ( 'agent' , 0 );
2018-10-04 19:08:01 +02:00
$agents = agents_get_agents (
2019-01-30 16:18:44 +01:00
[ 'nombre LIKE "' . $agentName . '"' ],
[ 'id_agente' ]
);
2009-08-14 Miguel de Dios <miguel.dedios@artica.es>
* godmode/agentes/agent_manager.php, godmode/agentes/massive_config.php,
godmode/alerts/alert_list.php, godmode/reporting/graph_builder.php,
godmode/reporting/map_builder.php, include/functions_db.php,
include/functions_html.php, operation/agentes/exportdata.php,
operation/agentes/ver_agente.php: very changes for add input text
autocomplete with ajax jquery for agent input in several forms. Add to form
this exportdata, graph_builder, map_builder.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1849 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-08-14 18:38:57 +02:00
$agent = $agents [ 0 ][ 'id_agente' ];
2019-01-30 16:18:44 +01:00
$module = ( array ) get_parameter_post ( 'module_arr' , []);
$start_date = get_parameter_post ( 'start_date' , 0 );
$end_date = get_parameter_post ( 'end_date' , 0 );
$start_time = get_parameter_post ( 'start_time' , 0 );
$end_time = get_parameter_post ( 'end_time' , 0 );
$export_type = get_parameter_post ( 'export_type' , 'data' );
$export_btn = get_parameter ( 'export_btn' , 0 );
2009-05-19 21:04:43 +02:00
2014-10-16 11:50:21 +02:00
$show_form = false ;
2019-01-30 16:18:44 +01:00
if ( ! empty ( $export_btn ) && ! empty ( $module )) {
// Disable SQL cache
global $sql_cache ;
$sql_cache = [ 'saved' => []];
// Convert start time and end time to unix timestamps.
// The date/time will have the user's timezone,
// so we need to change it to the system's timezone.
$fixed_offset = get_fixed_offset ();
$start = ( strtotime ( $start_date . ' ' . $start_time ) - $fixed_offset );
$end = ( strtotime ( $end_date . ' ' . $end_time ) - $fixed_offset );
$period = ( $end - $start );
$data = [];
// If time is negative or zero, don't process - it's invalid
if ( $start < 1 || $end < 1 ) {
ui_print_error_message ( __ ( 'Invalid time specified' ));
return ;
}
// ******************************************************************
// Starts, ends and dividers
// ******************************************************************
switch ( $export_type ) {
case 'data' :
case 'avg' :
default :
// HTML output - don't style or use XHTML just in case somebody needs to copy/paste it. (Office doesn't handle <thead> and <tbody>)
2021-03-11 15:40:23 +01:00
$datastart = '<table class="databox data w100p">' . '<tr>' . '<th>' . __ ( 'Agent' ) . '</th>' . '<th>' . __ ( 'Module' ) . '</th>' . '<th>' . __ ( 'Data' ) . '</th>' . '<th>' . __ ( 'Timestamp' ) . '</th>' . '</tr>' ;
2019-01-30 16:18:44 +01:00
$rowstart = '<tr><td>' ;
$divider = '</td><td>' ;
$rowend = '</td></tr>' ;
$dataend = '</table>' ;
break ;
}
// ******************************************************************
// Data processing
// ******************************************************************
$data = [];
switch ( $export_type ) {
case 'data' :
case 'avg' :
// Show header
echo $datastart ;
foreach ( $module as $selected ) {
$output = '' ;
$work_period = SECONDS_1DAY ;
if ( $work_period > $period ) {
$work_period = $period ;
}
$work_end = ( $end - $period + $work_period );
$work_start = ( $work_end - $work_period );
// Buffer to get data, anyway this will report a memory exhaustin
$flag_last_time_slice = false ;
while ( $work_end <= $end ) {
$data = [];
// Reinitialize array for each module chunk
if ( $export_type == 'avg' ) {
$arr = [];
$arr [ 'data' ] = reporting_get_agentmodule_data_average (
$selected ,
$work_period ,
$work_end
);
if ( $arr [ 'data' ] === false ) {
$work_end = ( $work_end + $work_period );
continue ;
}
$arr [ 'module_name' ] = modules_get_agentmodule_name ( $selected );
$arr [ 'agent_name' ] = modules_get_agentmodule_agent_name ( $selected );
$arr [ 'agent_id' ] = modules_get_agentmodule_agent ( $selected );
$arr [ 'utimestamp' ] = $end ;
array_push ( $data , $arr );
} else {
$data_single = modules_get_agentmodule_data (
$selected ,
$work_period ,
$work_end
);
if ( ! empty ( $data_single )) {
$data = array_merge ( $data , $data_single );
}
}
foreach ( $data as $key => $module ) {
$output .= $rowstart ;
$alias = db_get_value ( 'alias' , 'tagente' , 'id_agente' , $module [ 'agent_id' ]);
$output .= io_safe_output ( $alias );
$output .= $divider ;
$output .= io_safe_output ( $module [ 'module_name' ]);
$output .= $divider ;
$output .= $module [ 'data' ];
$output .= $divider ;
switch ( $export_type ) {
case 'data' :
// Change from the system's timezone to the user's timezone
$output .= date ( 'Y-m-d G:i:s' , ( $module [ 'utimestamp' ] + $fixed_offset ));
break ;
case 'avg' :
// Change from the system's timezone to the user's timezone
$output .= date ( 'Y-m-d G:i:s' , ( $work_start + $fixed_offset )) . ' - ' . date ( 'Y-m-d G:i:s' , ( $work_end + $fixed_offset ));
break ;
}
$output .= $rowend ;
}
switch ( $export_type ) {
default :
case 'data' :
case 'avg' :
echo $output ;
break ;
}
unset ( $output );
$output = '' ;
unset ( $data );
unset ( $data_single );
// The last time slice is executed now exit of
// while loop
if ( $flag_last_time_slice ) {
break ;
}
if (( $work_end + $work_period ) > $end || $work_period == 0 ) {
// Get the last timelapse
$work_period = ( $end - $work_end );
$work_end = $end ;
$flag_last_time_slice = true ;
} else {
$work_end = ( $work_end + $work_period );
}
$work_start = ( $work_end - $work_period );
}
unset ( $output );
$output = '' ;
} //end foreach
echo $dataend ;
break ;
}
} else if ( ! empty ( $export_btn ) && empty ( $module )) {
ui_print_error_message ( __ ( 'No modules specified' ));
$show_form = true ;
2007-05-03 Sancho Lerena <slerena@artica.es>
* include/FreeSans.ttf: Added to repos, should be here to use in graphs.
* include/functions_db.php: Deleted noaccess include from
comprueba_login(). This should return value, not render pages or
exit.
* include/config.inc.php: Modified some typos.
* include/calendar.js: Added generic calendar javascript, to be
used on exportdata and incident management code.
* include/languages/language_en.php: More strings.
* install.php: In my render, box height is too low. PLEASE recheck
before changing this kind of properties because in other browsers
could have a bad render (Sophus!).
* index.php: Added script call (need to be done on header).
* operation/agentes/export_csv.php: Added new file to create a
standalone CSV on download icon / link.
* operation/agentes/exportdata.php: New export data code, used
some code from Leando Doctors, and mixed with old code. Now have
three options to render export data.
* operation/agentes/datos_agente_calendar.php: Deleted old code from Leandro.
* operation/active_console/lib/extra_functions.php: Solved a lot
of warnings, but there are TONS of more warnings that need to be
corrected.
* operation/active_console/lib/db_functions.php:Solved a lot of
warnings, but there are TONS of more warnings that need to be
corrected.
* operation/active_console/index.php: Solved a lot of warnings,
but there are TONS of more warnings that need to be
corrected. This code DONT work if you are showing warning/notice
erros. This code is not ready for production usage, too buggy yet
:(
* pandora_graphical_console_data.sql: Cleanup.
* godmode/agentes/module_manager.php: Added wizard button.
* pandora_graphical_console.sql: Cleanup.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@448 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2007-05-03 04:08:00 +02:00
}
2014-10-16 11:50:21 +02:00
if ( empty ( $export_btn ) || $show_form ) {
2019-01-30 16:18:44 +01:00
$groups = users_get_groups ( $config [ 'id_user' ], 'RR' , users_can_manage_group_all ());
2019-07-15 11:58:27 +02:00
$filter = [];
2023-03-07 18:10:07 +01:00
$filter [ 'id_grupo' ] = ( $group > 0 ) ? ( array ) $group : array_keys ( $groups );
2019-01-30 16:18:44 +01:00
$agents = [];
$rows = agents_get_agents ( $filter , false , 'RR' );
if ( $rows == null ) {
$rows = [];
}
foreach ( $rows as $row ) {
$agents [ $row [ 'id_agente' ]] = $row [ 'nombre' ];
}
2022-10-28 15:01:00 +02:00
// Src code of lightning image with skins.
2021-03-11 15:40:23 +01:00
$src_code = html_print_image ( 'images/lightning_go.png' , true , false , true );
2019-01-30 16:18:44 +01:00
$params = [];
$params [ 'return' ] = true ;
$params [ 'show_helptip' ] = true ;
$params [ 'input_name' ] = 'agent' ;
$params [ 'selectbox_group' ] = 'group' ;
$params [ 'value' ] = agents_get_name ( $agent );
$params [ 'javascript_is_function_select' ] = true ;
$params [ 'add_none_module' ] = false ;
2022-10-28 15:01:00 +02:00
$params [ 'size' ] = 38 ;
2019-01-30 16:18:44 +01:00
$params [ 'selectbox_id' ] = 'module_arr' ;
if ( $agent > 0 ) {
$modules = agents_get_modules ( $agent );
} else {
$modules = [];
}
2022-10-28 15:01:00 +02:00
if ( empty ( $modules ) === false ) {
// Remove modules of type string because you cant calculate their average.
2019-01-30 16:18:44 +01:00
$i = 0 ;
foreach ( $modules as $key => $module ) {
$id_module_type = modules_get_agentmodule_type ( $key );
switch ( $id_module_type ) {
case 3 :
case 10 :
case 17 :
case 23 :
case 33 :
unset ( $modules [ $i ]);
break ;
2022-10-28 15:01:00 +02:00
default :
continue ;
2019-01-30 16:18:44 +01:00
}
$i ++ ;
}
}
$disabled_export_button = false ;
2022-10-28 15:01:00 +02:00
if ( empty ( $modules ) === true ) {
2019-01-30 16:18:44 +01:00
$disabled_export_button = true ;
}
2023-03-07 18:10:07 +01:00
$export_types = [];
$export_types [ 'data' ] = __ ( 'Data table' );
$export_types [ 'csv' ] = __ ( 'CSV' );
$export_types [ 'excel' ] = __ ( 'MS Excel' );
$export_types [ 'avg' ] = __ ( 'Average per hour/day' );
2019-01-30 16:18:44 +01:00
2023-03-07 18:10:07 +01:00
echo '<form method="post" action="index.php?sec=reporting&sec2=operation/agentes/exportdata" name="export_form" id="export_form">' ;
$table = new stdClass ();
$table -> width = '100%' ;
$table -> border = 0 ;
$table -> cellspacing = 3 ;
$table -> cellpadding = 5 ;
$table -> class = 'databox filter-table-adv' ;
$table -> style [ 0 ] = 'vertical-align: top;' ;
$table -> data = [];
// Group selector.
$table -> data [ 0 ][] = html_print_label_input_block (
__ ( 'Group' ),
html_print_select_groups (
$config [ 'id_user' ],
'RR' ,
true ,
'group' ,
$group ,
'' ,
'' ,
0 ,
true ,
false ,
true ,
'' ,
false
)
2019-01-30 16:18:44 +01:00
);
2023-03-07 18:10:07 +01:00
// Agent selector.
$table -> data [ 0 ][] = html_print_label_input_block (
__ ( 'Source agent' ),
ui_print_agent_autocomplete_input ( $params )
2021-03-11 15:40:23 +01:00
);
2023-03-07 18:10:07 +01:00
// Module selector.
$table -> data [ 1 ][] = html_print_label_input_block (
__ ( 'Modules' ),
html_print_select (
$modules ,
'module_arr[]' ,
array_keys ( $modules ),
'' ,
'' ,
0 ,
true ,
true ,
true ,
'w100p' ,
false
) . ui_print_input_placeholder (
__ ( 'No modules of type string. You can not calculate their average' ),
true
)
2019-01-30 16:18:44 +01:00
);
2022-10-28 15:01:00 +02:00
// Export type.
2023-03-07 18:10:07 +01:00
$table -> data [ 1 ][] = html_print_label_input_block (
__ ( 'Export type' ),
html_print_select (
$export_types ,
'export_type' ,
$export_type ,
'' ,
'' ,
0 ,
true ,
false ,
true ,
'w100p' ,
false
)
);
2019-01-30 16:18:44 +01:00
2023-03-07 18:10:07 +01:00
// Start date selector.
$table -> data [ 2 ][] = html_print_label_input_block (
__ ( 'Begin date' ),
html_print_div (
[
'class' => 'flex-content' ,
'content' => html_print_input_text (
'start_date' ,
date ( 'Y-m-d' , ( get_system_time () - SECONDS_1DAY )),
false ,
13 ,
10 ,
true
) . html_print_image (
'images/calendar_view_day.png' ,
true ,
[
'alt' => 'calendar' ,
'onclick' => " scwShow(scwID('text-start_date'),this); " ,
'class' => 'main_menu_icon invert_filter' ,
]
) . html_print_input_text (
'start_time' ,
date ( 'H:i:s' , ( get_system_time () - SECONDS_1DAY )),
false ,
10 ,
9 ,
true
),
],
true
)
);
2019-01-30 16:18:44 +01:00
2023-03-07 18:10:07 +01:00
// End date selector.
$table -> data [ 2 ][] = html_print_label_input_block (
__ ( 'End date' ),
html_print_div (
[
'class' => 'flex-content' ,
'content' => html_print_input_text (
'end_date' ,
date ( 'Y-m-d' , get_system_time ()),
false ,
13 ,
10 ,
true
) . html_print_image (
'images/calendar_view_day.png' ,
true ,
[
'alt' => 'calendar' ,
'onclick' => " scwShow(scwID('text-end_date'),this); " ,
'class' => 'main_menu_icon invert_filter' ,
]
) . html_print_input_text (
'end_time' ,
date ( 'H:i:s' , get_system_time ()),
false ,
10 ,
9 ,
true
),
],
true
),
);
2019-01-30 16:18:44 +01:00
html_print_table ( $table );
2022-10-28 15:01:00 +02:00
// Submit button.
2023-03-07 18:10:07 +01:00
html_print_action_buttons (
html_print_button (
__ ( 'Export' ),
'export_btn' ,
false ,
'change_action()' ,
[ 'icon' => 'wand' ],
true
)
2022-10-28 15:01:00 +02:00
);
echo '</form>' ;
2012-04-25 11:12:42 +02:00
}
2019-01-30 16:18:44 +01:00
ui_require_jquery_file ( 'pandora.controls' );
ui_require_jquery_file ( 'ajaxqueue' );
ui_require_jquery_file ( 'bgiframe' );
2009-06-08 20:15:58 +02:00
?>
2009-08-14 Miguel de Dios <miguel.dedios@artica.es>
* godmode/agentes/agent_manager.php, godmode/agentes/massive_config.php,
godmode/alerts/alert_list.php, godmode/reporting/graph_builder.php,
godmode/reporting/map_builder.php, include/functions_db.php,
include/functions_html.php, operation/agentes/exportdata.php,
operation/agentes/ver_agente.php: very changes for add input text
autocomplete with ajax jquery for agent input in several forms. Add to form
this exportdata, graph_builder, map_builder.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1849 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-08-14 18:38:57 +02:00
< script type = " text/javascript " >
2019-01-30 16:18:44 +01:00
/* <![CDATA[ */
function change_action () {
type = $ ( " #export_type " ) . val ();
var f = document . forms . export_form ;
switch ( type ) {
case 'csv' :
2022-12-02 15:40:47 +01:00
blockResubmit ( $ ( this ));
2019-01-30 16:18:44 +01:00
f . action = " operation/agentes/exportdata.csv.php " ;
break ;
case 'excel' :
2022-12-02 15:40:47 +01:00
blockResubmit ( $ ( this ));
2019-01-30 16:18:44 +01:00
f . action = " operation/agentes/exportdata.excel.php " ;
break ;
case 'avg' :
case 'data' :
f . action = " index.php?sec=reporting&sec2=operation/agentes/exportdata&export_btn=1 " ;
break ;
}
$ ( " #export_form " ) . submit ();
}
/* ]]> */
2013-04-10 09:57:54 +02:00
</ script >