2009-01-07 11:42:38 +01:00
< ? php
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-05-28 09:48:09 +02:00
* Library . User interface functions .
*
* @ category Library .
* @ package Pandora FMS
* @ subpackage User interface .
* @ version 1.0 . 0
* @ license See below
*
* ______ ___ _______ _______ ________
2023-06-08 12:42:10 +02:00
* | __ \ .-----.--.--.--| |.-----.----.-----. | ___ | | | __ |
* | __ /| _ | | _ || _ | _ | _ | | ___ | | __ |
2019-05-28 09:48:09 +02:00
* | ___ | | ___ . _ | __ | __ | _____ || _____ | __ | | ___ . _ | | ___ | | __ | _ | __ | _______ |
*
* ============================================================================
2023-06-08 11:53:13 +02:00
* Copyright ( c ) 2005 - 2023 Pandora FMS
2023-06-08 13:19:01 +02:00
* Please see https :// pandorafms . com / community / for full contribution list
2019-05-28 09:48:09 +02:00
* This program is free software ; you can redistribute it and / or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation for version 2.
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
* ============================================================================
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
*/
2023-02-10 11:47:20 +01:00
use Mpdf\Tag\Tr ;
2019-05-28 09:48:09 +02:00
// Begin.
2021-05-28 13:47:14 +02:00
global $config ;
2019-05-28 09:48:09 +02:00
// Check to avoid error when load this library in error screen situations.
2013-07-16 Miguel de Dios <miguel.dedios@artica.es>
* include/functions.php,
include/javascript/jquery.pandora.controls.js: improved the
functions to pass the php vars to js, now it supports json.
* include/javascript/d3.v3.js: added this library for to make
beautiful things.
* include/functions_ui.php, include/graphs/fgraph.php,
include/javascript/pandora_events.js, include/javascript/pandora.js,
include/functions_treeview.php,
include/include_graph_dependencies.php,
include/functions_categories.php, include/db/postgresql.php,
include/db/oracle.php, include/db/mysql.php: cleaned source code
style.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@8528 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-07-16 16:13:23 +02:00
if ( isset ( $config [ 'homedir' ])) {
2019-01-30 16:18:44 +01:00
include_once $config [ 'homedir' ] . '/include/functions_agents.php' ;
include_once $config [ 'homedir' ] . '/include/functions_modules.php' ;
include_once $config [ 'homedir' ] . '/include/functions.php' ;
include_once $config [ 'homedir' ] . '/include/functions_groups.php' ;
include_once $config [ 'homedir' ] . '/include/functions_users.php' ;
include_once $config [ 'homedir' ] . '/include/functions_html.php' ;
2013-04-22 12:31:20 +02: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
2019-05-28 09:48:09 +02:00
/**
2019-08-27 16:01:18 +02:00
* Transform bbcode to HTML and truncate log .
2019-05-28 09:48:09 +02:00
*
* @ param string $text Text .
* @ param array $allowed_tags Allowed_tags .
*
* @ return string HTML .
*/
2019-01-30 16:18:44 +01:00
function ui_bbcode_to_html ( $text , $allowed_tags = [ '[url]' ])
{
2019-08-27 16:01:18 +02:00
if ( array_search ( '[url]' , $allowed_tags ) !== false || a ) {
// Replace bbcode format [url=www.example.org] String [/url] with or without http and slashes
preg_match ( '/\[url(?|](((?:https?:\/\/)?[^[]+))|(?:=[\'"]?((?:https?:\/\/)?[^]]+?)[\'"]?)](.+?))\[\/url]/' , $text , $matches );
if ( $matches ) {
$url = $matches [ 1 ];
// Truncate text
$t_text = ui_print_truncate_text ( $matches [ 2 ]);
// If link hasn't http, add it.
if ( preg_match ( '/https?:\/\//' , $text )) {
$return = '<a target="_blank" rel="noopener noreferrer" href="' . $matches [ 1 ] . '">' . $t_text . '</a>' ;
} else {
$return = '<a target="_blank" rel="noopener noreferrer" href="http://' . $matches [ 1 ] . '">' . $t_text . '</a>' ;
}
2019-06-21 16:26:13 +02:00
} else {
2019-08-27 16:01:18 +02:00
$return = ui_print_truncate_text ( $text );
2019-06-21 16:26:13 +02:00
}
2019-01-30 16:18:44 +01:00
}
return $return ;
2014-12-02 16:38:07 +01:00
}
2019-01-30 16:18:44 +01:00
2010-04-29 17:39:19 +02:00
/**
* Truncate a text to num chars ( pass as parameter ) and if flag show tooltip is
* true the html artifal to show the tooltip with rest of text .
2019-01-30 16:18:44 +01:00
*
* @ param string $text The text to truncate .
* @ param mixed $numChars Number chars ( - 3 for char " [...] " ) max the text . Or the strings " agent_small " , " agent_medium " , " module_small " , " module_medium " , " description " or " generic " for to take the values from user config .
2010-04-29 17:39:19 +02:00
* @ param boolean $showTextInAToopTip Flag to show the tooltip .
2019-01-30 16:18:44 +01:00
* @ param boolean $return Flag to return as string or not .
* @ param boolean $showTextInTitle Flag to show the text on title .
* @ param string $suffix String at the end of a strimmed string .
* @ param string $style Style associated to the text .
2011-04-13 18:11:02 +02:00
*
* @ return string Truncated text .
2010-04-29 17:39:19 +02:00
*/
2023-07-28 10:39:46 +02:00
function ui_print_truncate_text (
$text ,
$numChars = GENERIC_SIZE_TEXT ,
$showTextInAToopTip = true ,
$return = true ,
$showTextInTitle = true ,
$suffix = '…' ,
$style = false ,
2023-12-18 16:32:39 +01:00
$forced_title = false ,
$text_title = ''
2023-07-28 10:39:46 +02:00
) {
2019-01-30 16:18:44 +01:00
global $config ;
2023-09-08 10:42:40 +02:00
$truncate_at_end = false ;
2019-01-30 16:18:44 +01:00
if ( is_string ( $numChars )) {
switch ( $numChars ) {
case 'agent_small' :
$numChars = $config [ 'agent_size_text_small' ];
2023-09-11 10:09:34 +02:00
$truncate_at_end = ( bool ) $config [ 'truncate_agent_at_end' ];
2019-01-30 16:18:44 +01:00
break ;
case 'agent_medium' :
$numChars = $config [ 'agent_size_text_medium' ];
2023-09-11 10:09:34 +02:00
$truncate_at_end = ( bool ) $config [ 'truncate_agent_at_end' ];
2019-01-30 16:18:44 +01:00
break ;
case 'module_small' :
$numChars = $config [ 'module_size_text_small' ];
2023-09-11 10:09:34 +02:00
$truncate_at_end = ( bool ) $config [ 'truncate_module_at_end' ];
2019-01-30 16:18:44 +01:00
break ;
case 'module_medium' :
$numChars = $config [ 'module_size_text_medium' ];
2023-09-11 10:09:34 +02:00
$truncate_at_end = ( bool ) $config [ 'truncate_module_at_end' ];
2019-01-30 16:18:44 +01:00
break ;
case 'description' :
$numChars = $config [ 'description_size_text' ];
break ;
case 'item_title' :
$numChars = $config [ 'item_title_size_text' ];
break ;
default :
$numChars = ( int ) $numChars ;
break ;
}
}
if ( $numChars == 0 ) {
if ( $return == true ) {
return $text ;
} else {
echo $text ;
}
}
$text_html_decoded = io_safe_output ( $text );
$text_has_entities = $text != $text_html_decoded ;
if ( mb_strlen ( $text_html_decoded , 'UTF-8' ) > ( $numChars )) {
// '/2' because [...] is in the middle of the word.
$half_length = intval (( $numChars - 3 ) / 2 );
2023-09-08 10:42:40 +02:00
if ( $truncate_at_end === true ) {
// Recover the html entities to avoid XSS attacks.
2023-09-11 10:09:34 +02:00
$truncateText = ( $text_has_entities ) ? io_safe_input ( substr ( $text_html_decoded , 0 , $numChars )) : substr ( $text_html_decoded , 0 , $numChars );
if ( strlen ( $text_html_decoded ) > $numChars ) {
$truncateText .= '...' ;
}
2023-09-08 10:42:40 +02:00
} else {
// Depending on the strange behavior of mb_strimwidth() itself,
// the 3rd parameter is not to be $numChars but the length of
// original text (just means 'large enough').
$truncateText2 = mb_strimwidth (
$text_html_decoded ,
( mb_strlen ( $text_html_decoded , 'UTF-8' ) - $half_length ),
mb_strlen ( $text_html_decoded , 'UTF-8' ),
'' ,
'UTF-8'
);
$truncateText = mb_strimwidth (
$text_html_decoded ,
0 ,
( $numChars - $half_length ),
'' ,
'UTF-8'
);
// Recover the html entities to avoid XSS attacks.
$truncateText = ( $text_has_entities ) ? io_safe_input ( $truncateText ) . $suffix . io_safe_input ( $truncateText2 ) : $truncateText . $suffix . $truncateText2 ;
}
2019-01-30 16:18:44 +01:00
if ( $showTextInTitle ) {
if ( $style === null ) {
$truncateText = $truncateText ;
} else if ( $style !== false ) {
$truncateText = '<span style="' . $style . '" title="' . $text . '">' . $truncateText . '</span>' ;
} else {
$truncateText = '<span title="' . $text . '">' . $truncateText . '</span>' ;
}
}
if ( $showTextInAToopTip ) {
2019-10-01 11:22:25 +02:00
if ( is_string ( $showTextInAToopTip )) {
$text = ui_print_truncate_text ( $showTextInAToopTip , ( $numChars * 2 ), false , true , false );
}
2019-01-30 16:18:44 +01:00
$truncateText = $truncateText . ui_print_help_tip ( htmlspecialchars ( $text ), true );
} else {
if ( $style !== false ) {
$truncateText = '<span style="' . $style . '">' . $truncateText . '</span>' ;
}
}
} else {
if ( $style !== false ) {
$truncateText = '<span style="' . $style . '">' . $text . '</span>' ;
} else {
$truncateText = $text ;
}
}
2023-07-28 10:39:46 +02:00
if ( $forced_title === true ) {
2023-12-18 16:32:39 +01:00
if ( $text_title !== '' ) {
$truncateText = '<span class="forced_title" style="' . $style . '" data-title="' . $text_title . '" data-use_title_for_force_title="1">' . $truncateText . '</span>' ;
} else {
$truncateText = '<span class="forced_title" style="' . $style . '" data-title="' . $text . '" data-use_title_for_force_title="1">' . $truncateText . '</span>' ;
}
2023-07-28 10:39:46 +02:00
}
2019-01-30 16:18:44 +01:00
if ( $return == true ) {
return $truncateText ;
} else {
echo $truncateText ;
}
2010-04-29 17:39:19 +02:00
}
2019-01-30 16:18:44 +01:00
2011-04-12 19:20:16 +02:00
/**
* Print a string with a smaller font depending on its size .
2019-01-30 16:18:44 +01:00
*
* @ param string $string String to be display with a smaller font .
2011-04-12 19:20:16 +02:00
* @ param boolean $return Flag to return as string or not .
2019-05-28 09:48:09 +02:00
*
* @ return string HTML .
2011-04-12 19:20:16 +02:00
*/
2019-01-30 16:18:44 +01:00
function printSmallFont ( $string , $return = true )
{
$str = io_safe_output ( $string );
$length = strlen ( $str );
if ( $length >= 30 ) {
$size = 0.7 ;
} else if ( $length >= 20 ) {
$size = 0.8 ;
} else if ( $length >= 10 ) {
$size = 0.9 ;
} else if ( $length < 10 ) {
$size = 1 ;
}
$s = '<span style="font-size: ' . $size . 'em;">' ;
$s .= $string ;
$s .= '</span>' ;
if ( $return ) {
return $s ;
} else {
echo $s ;
}
2011-04-12 19:20:16 +02:00
}
2019-01-30 16:18:44 +01:00
2016-03-30 13:05:08 +02:00
/**
2009-03-30 11:27:04 +02:00
* Prints a generic message between tags .
2019-01-30 16:18:44 +01:00
*
2019-05-28 09:48:09 +02:00
* @ param mixed $message The string message or array [
* 'title' , 'message' , 'icon' , 'no_close' , 'force_style' ] to be displayed .
* @ param string $class The class to be used .
* @ param string $attributes Any other attributes to be set for the tag .
* @ param boolean $return Whether to output the string or return it .
* @ param string $tag What tag to use ( you could specify something else
* than h3 like div or h2 ) .
2009-03-30 11:27:04 +02:00
*
* @ return string HTML code if return parameter is true .
*/
2019-01-30 16:18:44 +01:00
function ui_print_message ( $message , $class = '' , $attributes = '' , $return = false , $tag = 'h3' )
{
2023-01-13 14:23:48 +01:00
global $config ;
2019-01-30 16:18:44 +01:00
2023-01-16 01:26:21 +01:00
static $first_execution = true ;
2019-01-30 16:18:44 +01:00
$text_title = '' ;
$text_message = '' ;
$icon_image = '' ;
$no_close_bool = false ;
$force_style = '' ;
2022-02-07 13:07:48 +01:00
$force_class = '' ;
2023-02-13 18:03:31 +01:00
$classes = [];
2023-01-13 14:23:48 +01:00
$autoclose = ( $class === 'suc' );
if ( is_array ( $message ) === true ) {
if ( empty ( $message [ 'title' ]) === false ) {
2019-01-30 16:18:44 +01:00
$text_title = $message [ 'title' ];
}
2023-01-13 14:23:48 +01:00
if ( empty ( $message [ 'message' ]) === false ) {
2019-01-30 16:18:44 +01:00
$text_message = $message [ 'message' ];
}
2023-01-13 14:23:48 +01:00
if ( empty ( $message [ 'icon' ]) === false ) {
2019-01-30 16:18:44 +01:00
$icon_image = $message [ 'icon' ];
}
2023-01-13 14:23:48 +01:00
if ( empty ( $message [ 'no_close' ]) === false ) {
2023-02-13 18:03:31 +01:00
// Workaround.
$no_close_bool = false ;
// $no_close_bool = (bool) $message['no_close'];
2019-01-30 16:18:44 +01:00
}
2023-01-13 14:23:48 +01:00
if ( empty ( $message [ 'force_style' ]) === false ) {
2019-01-30 16:18:44 +01:00
$force_style = $message [ 'force_style' ];
}
2022-02-07 13:07:48 +01:00
if ( empty ( $message [ 'force_class' ]) === false ) {
$force_class = $message [ 'force_class' ];
}
2023-03-21 12:07:10 +01:00
if ( isset ( $message [ 'autoclose' ]) === true ) {
if ( $message [ 'autoclose' ] === true ) {
$autoclose = true ;
} else {
$autoclose = false ;
}
}
2019-01-30 16:18:44 +01:00
} else {
$text_message = $message ;
}
2022-11-10 15:59:23 +01:00
if ( empty ( $text_title ) === true ) {
2019-01-30 16:18:44 +01:00
switch ( $class ) {
default :
case 'info' :
2023-02-13 18:03:31 +01:00
$classes [] = 'info_box_information' ;
2019-01-30 16:18:44 +01:00
$text_title = __ ( 'Information' );
break ;
case 'error' :
$text_title = __ ( 'Error' );
break ;
case 'suc' :
$text_title = __ ( 'Success' );
break ;
case 'warning' :
$text_title = __ ( 'Warning' );
break ;
}
}
2022-11-10 15:59:23 +01:00
if ( empty ( $icon_image ) === true ) {
2019-01-30 16:18:44 +01:00
switch ( $class ) {
default :
case 'info' :
$icon_image = 'images/information_big.png' ;
break ;
case 'error' :
$icon_image = 'images/err.png' ;
break ;
case 'suc' :
$icon_image = 'images/suc.png' ;
break ;
case 'warning' :
$icon_image = 'images/warning_big.png' ;
break ;
}
$icon_image = $icon_image ;
}
$id = 'info_box_' . uniqid ();
2022-02-07 13:07:48 +01:00
if ( empty ( $force_class ) === false ) {
$class = $class . ' ' . $force_class ;
}
2023-01-13 14:23:48 +01:00
if ( $no_close_bool === false ) {
2019-05-28 09:48:09 +02:00
// Use the no_meta parameter because this image is only in
// the base console.
2023-01-13 14:23:48 +01:00
$iconCloseButton = html_print_anchor (
[
'href' => 'javascript: close_info_box(\'' . $id . '\')' ,
'content' => html_print_image (
2023-02-22 08:08:11 +01:00
'images/close@svg.svg' ,
2023-01-13 14:23:48 +01:00
true ,
false ,
false ,
false ,
),
],
true
);
$closeButton = html_print_div (
[
'class' => 'icon right pdd_r_3px' ,
'content' => $iconCloseButton ,
],
true
);
} else {
$closeButton = '' ;
2019-01-30 16:18:44 +01:00
}
2023-01-13 14:23:48 +01:00
$messageTable = new stdClass ();
$messageTable -> cellpadding = 0 ;
$messageTable -> cellspacing = 0 ;
2023-01-16 01:26:21 +01:00
$messageTable -> id = 'table_' . $id ;
$messageTable -> class = 'info_box ' . $class . ' textodialogo' ;
2023-01-13 14:23:48 +01:00
$messageTable -> styleTable = $force_style ;
$messageTable -> rowclass = [];
$messageTable -> rowclass [ 0 ] = 'title font_16pt text_left' ;
$messageTable -> rowclass [ 1 ] = 'black font_10pt invert_filter' ;
$messageTable -> colspan [ 1 ][ 0 ] = 2 ;
$messageTable -> data = [];
2023-09-27 11:53:05 +02:00
$messageTable -> data [ 0 ][ 0 ] = '<b>' . $text_title . '</b>' . $closeButton ;
2023-02-22 21:19:28 +01:00
$messageTable -> data [ 1 ][ 0 ] = '<span>' . $text_message . '</b>' ;
2023-01-13 14:23:48 +01:00
2023-01-16 01:26:21 +01:00
// JavaScript help vars.
2023-01-13 14:23:48 +01:00
$messageCreated = html_print_table ( $messageTable , true );
$autocloseTime = (( int ) $config [ 'notification_autoclose_time' ] * 1000 );
2023-01-26 16:00:08 +01:00
2023-03-13 12:03:33 +01:00
if ( empty ( $message [ 'div_class' ]) === false ) {
$classes [] = $message [ 'div_class' ];
} else {
$classes [] = 'info_box_container' ;
}
2023-02-13 18:03:31 +01:00
$classes [] = (( $autoclose === true ) && ( $autocloseTime > 0 )) ? ' info_box_autoclose' : '' ;
2023-01-26 16:00:08 +01:00
// This session var is defined in index.
if ( isset ( $_SESSION [ 'info_box_count' ]) === false ) {
$_SESSION [ 'info_box_count' ] = 1 ;
} else {
$_SESSION [ 'info_box_count' ] ++ ;
}
$position = ( 20 + (( int ) $_SESSION [ 'info_box_count' ] * 100 ));
2023-01-13 14:23:48 +01:00
$output = html_print_div (
[
'id' => $id ,
2023-01-26 16:00:08 +01:00
'style' => 'top: ' . $position . 'px;' ,
2023-02-13 18:03:31 +01:00
'class' => implode ( ' ' , $classes ),
2023-01-26 16:00:08 +01:00
'content' => $messageCreated ,
2023-01-13 14:23:48 +01:00
],
true
);
if ( $return === true ) {
2019-01-30 16:18:44 +01:00
return $output ;
} else {
echo $output ;
}
2009-03-30 11:27:04 +02:00
}
2019-01-30 16:18:44 +01:00
2016-03-30 13:05:08 +02:00
/**
2009-03-30 11:27:04 +02:00
* Prints an error message .
2019-01-30 16:18:44 +01:00
*
2019-05-28 09:48:09 +02:00
* @ param mixed $message The string error message or array
* ( 'title' , 'message' , 'icon' , 'no_close' ) to be displayed .
* @ param string $attributes Any other attributes to be set for the tag .
* @ param boolean $return Whether to output the string or return it .
* @ param string $tag What tag to use ( you could specify something else
* than h3 like div or h2 ) .
2009-03-30 11:27:04 +02:00
*
* @ return string HTML code if return parameter is true .
*/
2019-01-30 16:18:44 +01:00
function ui_print_error_message ( $message , $attributes = '' , $return = false , $tag = 'h3' )
{
return ui_print_message ( $message , 'error' , $attributes , $return , $tag );
2009-03-30 11:27:04 +02:00
}
2019-01-30 16:18:44 +01:00
2016-03-30 13:05:08 +02:00
/**
2009-03-30 11:27:04 +02:00
* Prints an operation success message .
2019-01-30 16:18:44 +01:00
*
2019-05-28 09:48:09 +02:00
* @ param mixed $message The string message or array
* ( 'title' , 'message' , 'icon' , 'no_close' ) to be displayed .
* @ param string $attributes Any other attributes to be set for the tag .
* @ param boolean $return Whether to output the string or return it .
* @ param string $tag What tag to use ( you could specify something else
* than h3 like div or h2 ) .
2009-03-30 11:27:04 +02:00
*
* @ return string HTML code if return parameter is true .
*/
2019-01-30 16:18:44 +01:00
function ui_print_success_message ( $message , $attributes = '' , $return = false , $tag = 'h3' )
{
return ui_print_message ( $message , 'suc' , $attributes , $return , $tag );
2009-03-30 11:27:04 +02:00
}
2019-01-30 16:18:44 +01:00
2016-03-30 13:05:08 +02:00
/**
2012-04-12 14:20:38 +02:00
* Prints an operation info message .
2019-01-30 16:18:44 +01:00
*
2019-05-28 09:48:09 +02:00
* @ param mixed $message The string message or array
* ( 'title' , 'message' , 'icon' , 'no_close' ) to be displayed .
* @ param string $attributes Any other attributes to be set for the tag .
* @ param boolean $return Whether to output the string or return it .
* @ param string $tag What tag to use ( you could specify something else
* than h3 like div or h2 ) .
2012-04-12 14:20:38 +02:00
*
* @ return string HTML code if return parameter is true .
*/
2019-01-30 16:18:44 +01:00
function ui_print_info_message ( $message , $attributes = '' , $return = false , $tag = 'h3' )
{
return ui_print_message ( $message , 'info' , $attributes , $return , $tag );
2012-04-12 14:20:38 +02:00
}
2019-01-30 16:18:44 +01:00
2019-05-28 09:48:09 +02:00
/**
* Prints an operation info message - empty data .
*
* @ param mixed $message The string message or array
* ( 'title' , 'message' , 'icon' , 'no_close' ) to be displayed .
* @ param string $attributes Any other attributes to be set for the tag .
* @ param boolean $return Whether to output the string or return it .
* @ param string $tag What tag to use ( you could specify something else
* than h3 like div or h2 ) .
*
* @ return string HTML code if return parameter is true .
*/
2019-01-30 16:18:44 +01:00
function ui_print_empty_data ( $message , $attributes = '' , $return = false , $tag = 'h3' )
{
return ui_print_message ( $message , 'info' , $attributes , $return , $tag );
2013-05-17 14:26:16 +02:00
}
2019-01-30 16:18:44 +01:00
2016-03-30 13:05:08 +02:00
/**
2009-03-26 Esteban Sanchez <estebans@artica.es>
* godmode/users/configure_user.php: Complete rewritten to fix minor
errors and fit the Pandora style.
* include/auth/ldap.php: Removed process_user_isadmin(). Renamed
process_user_password() to update_user_password(). Renamed
process_user_info to update_user(). update_user_password() does not
require old password anymore.
* include/functions_db.php: Added empty checks on
create_user_profile().
* include/functions_ui.php: print_error_message() renamed to
print_result_message().
* godmode/agentes/configurar_agente.php,
godmode/alerts/alert_actions.php, godmode/alerts/alert_commands.php,
godmode/alerts/alert_compounds.php, godmode/alerts/alert_list.php,
godmode/alerts/alert_templates.php,
godmode/alerts/configure_alert_template.php,
godmode/modules/manage_nc_groups.php,
godmode/modules/manage_network_templates.php,
godmode/modules/manage_network_templates_form.php,
godmode/reporting/map_builder_wizard.php,
godmode/reporting/reporting_builder.php,
operation/agentes/alerts_status.php, operation/events/events.php,
operation/incidents/incident.php,
operation/incidents/incident_detail.php,
operation/messages/message.php, operation/snmpconsole/snmp_view.php,
operation/users/user_edit.php: Renamed print_result_message(). Some
translatable strings reused to simplify i18n work.
* godmode/users/user_list.php: Renamed print_result_message(). Use
cross.png for deletion links. Style corrections.
* godmode/setup/news.php: Renamed print_result_message(). Use
process_sql_delete() instead of direct mysql_query.
* godmode/reporting/map_builder.php: Renamed print_result_message().
Style correction on process_sql_update().
* godmode/alerts/configure_alert_compound.php: Renamed
print_result_message(). Fixed steps_clean div.
* godmode/setup/setup.php: Return control to index instead of exit.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1567 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-03-26 12:14:49 +01:00
* Evaluates a result using empty () and then prints an error or success message
2019-01-30 16:18:44 +01:00
*
2019-05-28 09:48:09 +02:00
* @ param mixed $result The results to evaluate . 0 , NULL , false , '' or
* array () is bad , the rest is good .
* @ param mixed $good The string or array ( 'title' , 'message' ) to be
* displayed if the result was good .
* @ param mixed $bad The string or array ( 'title' , 'message' ) to be
* displayed if the result was bad .
* @ param string $attributes Any other attributes to be set for the h3 .
* @ param boolean $return Whether to output the string or return it .
* @ param string $tag What tag to use ( you could specify something else
* than h3 like div or h2 ) .
2009-01-07 11:42:38 +01:00
*
2009-03-30 11:27:04 +02:00
* @ return string HTML code if return parameter is true .
2009-01-08 16:52:13 +01:00
*/
2019-01-30 16:18:44 +01:00
function ui_print_result_message ( $result , $good = '' , $bad = '' , $attributes = '' , $return = false , $tag = 'h3' )
{
2023-02-13 14:23:31 +01:00
if ( empty ( $good ) === true || $good === false ) {
2019-01-30 16:18:44 +01:00
$good = __ ( 'Request successfully processed' );
}
2023-02-13 14:23:31 +01:00
if ( empty ( $bad ) === true || $bad === false ) {
2019-01-30 16:18:44 +01:00
$bad = __ ( 'Error processing request' );
}
2023-01-13 14:23:48 +01:00
if ( empty ( $result ) === true ) {
2019-01-30 16:18:44 +01:00
return ui_print_error_message ( $bad , $attributes , $return , $tag );
} else {
return ui_print_success_message ( $good , $attributes , $return , $tag );
}
2009-01-07 11:42:38 +01:00
}
2019-01-30 16:18:44 +01:00
2016-03-30 13:05:08 +02:00
/**
2015-04-21 17:26:20 +02:00
* Prints an warning message .
2019-01-30 16:18:44 +01:00
*
2019-05-28 09:48:09 +02:00
* @ param mixed $message The string message or array
* ( 'title' , 'message' , 'icon' , 'no_close' ) to be displayed .
* @ param string $attributes Any other attributes to be set for the tag .
* @ param boolean $return Whether to output the string or return it .
* @ param string $tag What tag to use ( you could specify something else
* than h3 like div or h2 ) .
2015-04-21 17:26:20 +02:00
*
* @ return string HTML code if return parameter is true .
*/
2019-01-30 16:18:44 +01:00
function ui_print_warning_message ( $message , $attributes = '' , $return = false , $tag = 'h3' )
{
return ui_print_message ( $message , 'warning' , $attributes , $return , $tag );
2015-04-21 17:26:20 +02:00
}
2019-01-30 16:18:44 +01:00
2009-01-07 11:42:38 +01:00
/**
* Evaluates a unix timestamp and returns a span ( or whatever tag specified )
* with as title the correctly formatted full timestamp and a time comparation
* in the tag
*
2019-05-28 09:48:09 +02:00
* @ param integer $unixtime Any type of timestamp really , but we prefer unixtime .
* @ param boolean $return Whether to output the string or return it .
* @ param array $option An array with different options for this function
* Key html_attr : which html attributes to add ( defaults to none )
* Key tag : Which html tag to use ( defaults to span )
* Key prominent : Overrides user preference and display " comparation " or " timestamp "
* key units : The type of units .
2009-01-07 11:42:38 +01:00
*
* @ return string HTML code if return parameter is true .
*/
2019-01-30 16:18:44 +01:00
function ui_print_timestamp ( $unixtime , $return = false , $option = [])
{
global $config ;
2019-05-28 09:48:09 +02:00
// TODO: Add/use a javascript timer for the seconds so it automatically
// updates as time passes by.
2023-01-04 15:46:32 +01:00
if ( isset ( $option [ 'html_attr' ]) === true ) {
2019-01-30 16:18:44 +01:00
$attributes = $option [ 'html_attr' ];
} else {
$attributes = '' ;
}
2023-01-04 15:46:32 +01:00
if ( isset ( $option [ 'tag' ]) === true ) {
2019-01-30 16:18:44 +01:00
$tag = $option [ 'tag' ];
} else {
$tag = 'span' ;
}
2023-09-19 17:21:44 +02:00
if ( empty ( $option [ 'class' ]) === false ) {
$class = 'class="nowrap ' . $option [ 'class' ] . '"' ;
2019-01-30 16:18:44 +01:00
} else {
2023-09-19 17:21:44 +02:00
$class = 'class="nowrap"' ;
}
if ( empty ( $option [ 'style' ]) === false ) {
2019-01-30 16:18:44 +01:00
$style = 'style="' . $option [ 'style' ] . '"' ;
2023-09-19 17:21:44 +02:00
} else {
$style = 'style=""' ;
2019-01-30 16:18:44 +01:00
}
2023-09-19 17:21:44 +02:00
$style .= ' ' . $class ;
2023-01-04 15:46:32 +01:00
if ( empty ( $option [ 'prominent' ]) === false ) {
2019-01-30 16:18:44 +01:00
$prominent = $option [ 'prominent' ];
} else {
$prominent = $config [ 'prominent_time' ];
}
2023-01-04 15:46:32 +01:00
if ( is_numeric ( $unixtime ) === false ) {
2019-01-30 16:18:44 +01:00
$unixtime = time_w_fixed_tz ( $unixtime );
}
2019-05-28 09:48:09 +02:00
// Prominent_time is either timestamp or comparation.
2019-01-30 16:18:44 +01:00
if ( $unixtime <= 0 ) {
$title = __ ( 'Unknown' ) . '/' . __ ( 'Never' );
$data = __ ( 'Unknown' );
} else if ( $prominent == 'timestamp' ) {
pandora_setlocale ();
$title = human_time_comparation ( $unixtime );
2020-09-14 17:56:09 +02:00
$date = new DateTime ();
$date -> setTimestamp ( $unixtime );
2020-09-14 17:59:41 +02:00
$data = $date -> format ( $config [ 'date_format' ]);
2019-08-29 10:07:50 +02:00
} else if ( $prominent == 'compact' ) {
$units = 'tiny' ;
2019-12-13 13:40:19 +01:00
$title = date ( $config [ 'date_format' ], $unixtime );
2019-08-29 10:07:50 +02:00
$data = human_time_comparation ( $unixtime , $units );
2019-01-30 16:18:44 +01:00
} else {
$title = date ( $config [ 'date_format' ], $unixtime );
$units = 'large' ;
2023-01-04 15:46:32 +01:00
if ( isset ( $option [ 'units' ]) === true ) {
2019-01-30 16:18:44 +01:00
$units = $option [ 'units' ];
}
$data = human_time_comparation ( $unixtime , $units );
}
$output = '<' . $tag ;
switch ( $tag ) {
default :
// Usually tags have title attributes, so by default we add,
2019-05-28 09:48:09 +02:00
// then fall through to add attributes and data.
2019-01-30 16:18:44 +01:00
$output .= ' title="' . $title . '" ' . $style . '>' . $data . '</' . $tag . '>' ;
break ;
case 'h1' :
case 'h2' :
case 'h3' :
2019-05-28 09:48:09 +02:00
// Above tags don't have title attributes.
2019-01-30 16:18:44 +01:00
$output .= ' ' . $attributes . ' ' . $style . '>' . $data . '</' . $tag . '>' ;
break ;
}
2023-01-04 15:46:32 +01:00
if ( $return === true ) {
2019-01-30 16:18:44 +01:00
return $output ;
2023-01-04 15:46:32 +01:00
} else {
echo $output ;
2019-01-30 16:18:44 +01:00
}
2009-01-07 11:42:38 +01:00
}
2019-01-30 16:18:44 +01:00
2009-01-07 11:42:38 +01:00
/**
* Prints a username with real name , link to the user_edit page etc .
*
2019-05-28 09:48:09 +02:00
* @ param string $username The username to render .
2023-02-03 12:37:09 +01:00
* @ param boolean $fullname If true , returns the user fullname .
2019-05-28 09:48:09 +02:00
* @ param boolean $return Whether to return or print .
2009-01-07 11:42:38 +01:00
*
2023-02-03 12:37:09 +01:00
* @ return void | string HTML code if return parameter is true .
2009-01-07 11:42:38 +01:00
*/
2023-02-03 12:37:09 +01:00
function ui_print_username ( $username , $fullname = false , $return = false )
2019-01-30 16:18:44 +01:00
{
2023-02-03 12:37:09 +01:00
return html_print_anchor (
[
'href' => sprintf ( 'index.php?sec=gusuarios&sec2=godmode/users/configure_user&edit_user=1&pure=0&id_user=%s' , $username ),
'content' => ( $fullname === true ) ? get_user_fullname ( $username ) : $username ,
],
$return
);
2009-01-07 11:42:38 +01:00
}
2019-01-30 16:18:44 +01:00
2019-05-28 09:48:09 +02:00
/**
* Show a notification .
*
* @ param boolean $return Return or direct echo .
*
* @ return string HTML .
*/
2019-01-30 16:18:44 +01:00
function ui_print_tags_warning ( $return = false )
{
$msg = '<div id="notify_conf" class="notify">' ;
$msg .= __ ( 'Is possible that this view uses part of information which your user has not access' );
$msg .= '</div>' ;
if ( $return ) {
return $msg ;
} else {
echo $msg ;
}
2013-01-10 17:00:30 +01:00
}
2019-01-30 16:18:44 +01:00
2016-03-30 13:05:08 +02:00
/**
2009-01-07 11:42:38 +01:00
* Print group icon within a link
2019-01-30 16:18:44 +01:00
*
2019-05-28 09:48:09 +02:00
* @ param integer $id_group Group id .
* @ param boolean $return Whether to return or print .
* @ param string $path What path to use ( relative to images / ) .
* Defaults to groups_small .
* @ param string $style Style for group image .
* @ param boolean $link Whether the group have link or not .
* @ param boolean $force_show_image Force show image .
* @ param boolean $show_as_image Show as image .
2022-12-15 12:42:35 +01:00
* @ param string $class Overrides the default class .
2009-01-07 11:42:38 +01:00
*
* @ return string HTML code if return parameter is true .
*/
2023-03-07 13:19:52 +01:00
function ui_print_group_icon ( $id_group , $return = false , $path = '' , $style = '' , $link = true , $force_show_image = false , $show_as_image = false , $class = '' , $tactical_view = false )
2019-01-30 16:18:44 +01:00
{
global $config ;
$output = '' ;
2023-04-14 10:02:41 +02:00
$icon = 'world@svg.svg' ;
if ( $id_group > 0 ) {
$icon = db_get_value ( 'icon' , 'tgrupo' , 'id_grupo' , ( int ) $id_group );
if ( empty ( $icon ) === true ) {
$icon = 'unknown@groups.svg' ;
}
}
2023-04-12 15:10:05 +02:00
$extension = pathinfo ( $icon , PATHINFO_EXTENSION );
if ( empty ( $extension ) === true ) {
$icon .= '.png' ;
}
2022-12-20 17:22:35 +01:00
2019-05-28 09:48:09 +02:00
// Don't show link in metaconsole.
2022-12-15 12:42:35 +01:00
if ( is_metaconsole () === true ) {
2019-01-30 16:18:44 +01:00
$link = false ;
}
2022-12-15 12:42:35 +01:00
if ( $link === true ) {
2023-03-07 13:19:52 +01:00
if ( $tactical_view === true ) {
2023-03-10 12:40:21 +01:00
$output = '<a href="' . $config [ 'homeurl' ] . 'index.php?sec=gagent&sec2=godmode/groups/tactical&id_group=' . $id_group . '">' ;
2023-03-07 13:19:52 +01:00
} else {
$output = '<a href="' . $config [ 'homeurl' ] . 'index.php?sec=estado&sec2=operation/agentes/estado_agente&refr=60&group_id=' . $id_group . '">' ;
}
2019-01-30 16:18:44 +01:00
}
2022-12-20 17:22:35 +01:00
if (( bool ) $config [ 'show_group_name' ] === true ) {
2019-01-30 16:18:44 +01:00
$output .= '<span title="' . groups_get_name ( $id_group , true ) . '">' . groups_get_name ( $id_group , true ) . ' </span>' ;
} else {
2022-12-15 12:42:35 +01:00
if ( empty ( $icon ) === true ) {
2023-03-15 11:30:22 +01:00
$output .= '<span title="' . groups_get_name ( $id_group , true ) . '">' ;
$output .= '</span>' ;
$output .= html_print_image (
'images/unknown@groups.svg' ,
true ,
[
'style' => $style ,
2023-03-17 13:20:58 +01:00
'class' => 'main_menu_icon invert_filter ' . $class ,
2023-03-15 11:30:22 +01:00
'alt' => groups_get_name ( $id_group , true ),
'title' => groups_get_name ( $id_group , true ),
],
false ,
false ,
false ,
true
);
$output .= '</span>' ;
2019-01-30 16:18:44 +01:00
} else {
2022-12-15 12:42:35 +01:00
if ( empty ( $class ) === true ) {
$class = 'bot' ;
if ( $icon === 'transmit' ) {
$class .= ' invert_filter' ;
}
2021-03-17 16:44:10 +01:00
}
2023-04-12 15:10:05 +02:00
$icon = ( str_contains ( $icon , '.svg' ) === true || str_contains ( $icon , '.png' ) === true ) ? $icon : $icon . '.svg' ;
$folder = '' ;
if ( str_contains ( $icon , '.png' )) {
$folder = 'groups_small/' ;
}
2023-03-10 12:40:21 +01:00
2019-01-30 16:18:44 +01:00
$output .= html_print_image (
2023-04-12 15:10:05 +02:00
'images/' . $folder . $icon ,
2019-01-30 16:18:44 +01:00
true ,
[
'style' => $style ,
2023-03-17 13:20:58 +01:00
'class' => 'main_menu_icon invert_filter ' . $class ,
2019-01-30 16:18:44 +01:00
'alt' => groups_get_name ( $id_group , true ),
'title' => groups_get_name ( $id_group , true ),
],
false ,
false ,
false ,
true
);
}
}
2022-12-20 17:22:35 +01:00
if ( $link === true ) {
2019-01-30 16:18:44 +01:00
$output .= '</a>' ;
}
2022-12-20 17:22:35 +01:00
if ( $return === false ) {
2019-01-30 16:18:44 +01:00
echo $output ;
2022-12-20 17:22:35 +01:00
} else {
return $output ;
2019-01-30 16:18:44 +01:00
}
2009-01-07 11:42:38 +01:00
}
2019-01-30 16:18:44 +01:00
2016-03-30 13:05:08 +02:00
/**
2010-09-15 Miguel de Dios <miguel.dedios@artica.es>
* include/functions_reporting.php: in function "get_agent_module_info" added
the return "status" and "alert_value".
* include/auth/mysql.php: in function "process_user_login" cleaned the
source code style.
* include/functions_ui.php: in function "print_timestamp" added in the
parameter $option the check of units ('large' and 'tiny' at the moment).
Added the function "print_group_icon2" that it is the same of
"print_group_icon" but it has a new parameter $path for to set the images
path.
* include/functions.php: in function "human_time_comparation" added the
parameter $units to set the type return text for time unit (at the moment
only "large" and "tiny"). And in the function "human_time_description_raw"
added the paramter $units for to set the type of return text for units, at
the moment only "large" and "tiny".
* include/functions_db.php, operation/agentes/ver_agente.php: cleaned source
code.
* mobile/index.php, mobile/operation/agents,
mobile/operation/agents/view_agents.php, mobile/include/db.class.php,
mobile/include/style, mobile/include/style/main.css,
mobile/include/user.class.php, mobile/include/functions_web.php,
mobile/include/system.class.php, mobile/images/bricks.png,
mobile/images/up.png, mobile/images/zoom.png, mobile/images/down.png: added
first version of file for Pandora Mobile version.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@3246 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2010-09-15 17:54:59 +02:00
* Print group icon within a link . Other version .
2019-01-30 16:18:44 +01:00
*
2019-05-28 09:48:09 +02:00
* @ param integer $id_group Group id .
* @ param boolean $return Whether to return or print .
* @ param string $path What path to use ( relative to images / ) .
* Defaults to groups_small .
* @ param string $style Extra styles .
* @ param boolean $link Add anchor .
2010-09-15 Miguel de Dios <miguel.dedios@artica.es>
* include/functions_reporting.php: in function "get_agent_module_info" added
the return "status" and "alert_value".
* include/auth/mysql.php: in function "process_user_login" cleaned the
source code style.
* include/functions_ui.php: in function "print_timestamp" added in the
parameter $option the check of units ('large' and 'tiny' at the moment).
Added the function "print_group_icon2" that it is the same of
"print_group_icon" but it has a new parameter $path for to set the images
path.
* include/functions.php: in function "human_time_comparation" added the
parameter $units to set the type return text for time unit (at the moment
only "large" and "tiny"). And in the function "human_time_description_raw"
added the paramter $units for to set the type of return text for units, at
the moment only "large" and "tiny".
* include/functions_db.php, operation/agentes/ver_agente.php: cleaned source
code.
* mobile/index.php, mobile/operation/agents,
mobile/operation/agents/view_agents.php, mobile/include/db.class.php,
mobile/include/style, mobile/include/style/main.css,
mobile/include/user.class.php, mobile/include/functions_web.php,
mobile/include/system.class.php, mobile/images/bricks.png,
mobile/images/up.png, mobile/images/zoom.png, mobile/images/down.png: added
first version of file for Pandora Mobile version.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@3246 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2010-09-15 17:54:59 +02:00
*
* @ return string HTML code if return parameter is true .
*/
2023-01-19 00:31:11 +01:00
function ui_print_group_icon_path ( $id_group , $return = false , $path = 'images' , $style = '' , $link = true )
2019-01-30 16:18:44 +01:00
{
if ( $id_group > 0 ) {
$icon = ( string ) db_get_value ( 'icon' , 'tgrupo' , 'id_grupo' , ( int ) $id_group );
} else {
$icon = 'world' ;
}
if ( $style == '' ) {
$style = 'width: 16px; height: 16px;' ;
}
$output = '' ;
if ( $link ) {
$output = '<a href="index.php?sec=estado&sec2=operation/agentes/estado_agente&refr=60&group_id=' . $id_group . '">' ;
}
if ( empty ( $icon )) {
$output .= '<span title="' . groups_get_name ( $id_group , true ) . '"> - </span>' ;
} else {
$output .= '<img style="' . $style . '" class="bot" src="' . $path . '/' . $icon . '.png" alt="' . groups_get_name ( $id_group , true ) . '" title="' . groups_get_name ( $id_group , true ) . '" />' ;
}
if ( $link ) {
$output .= '</a>' ;
}
if ( ! $return ) {
echo $output ;
}
return $output ;
2010-09-15 Miguel de Dios <miguel.dedios@artica.es>
* include/functions_reporting.php: in function "get_agent_module_info" added
the return "status" and "alert_value".
* include/auth/mysql.php: in function "process_user_login" cleaned the
source code style.
* include/functions_ui.php: in function "print_timestamp" added in the
parameter $option the check of units ('large' and 'tiny' at the moment).
Added the function "print_group_icon2" that it is the same of
"print_group_icon" but it has a new parameter $path for to set the images
path.
* include/functions.php: in function "human_time_comparation" added the
parameter $units to set the type return text for time unit (at the moment
only "large" and "tiny"). And in the function "human_time_description_raw"
added the paramter $units for to set the type of return text for units, at
the moment only "large" and "tiny".
* include/functions_db.php, operation/agentes/ver_agente.php: cleaned source
code.
* mobile/index.php, mobile/operation/agents,
mobile/operation/agents/view_agents.php, mobile/include/db.class.php,
mobile/include/style, mobile/include/style/main.css,
mobile/include/user.class.php, mobile/include/functions_web.php,
mobile/include/system.class.php, mobile/images/bricks.png,
mobile/images/up.png, mobile/images/zoom.png, mobile/images/down.png: added
first version of file for Pandora Mobile version.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@3246 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2010-09-15 17:54:59 +02:00
}
2019-01-30 16:18:44 +01:00
2016-03-30 13:05:08 +02:00
/**
2009-01-07 11:42:38 +01:00
* Get the icon of an operating system .
*
2019-05-28 09:48:09 +02:00
* @ param integer $id_os Operating system id .
* @ param boolean $name Whether to also append the name of OS after icon .
* @ param boolean $return Whether to return or echo the result .
* @ param boolean $apply_skin Whether to apply skin or not .
* @ param boolean $networkmap Networkmap .
* @ param boolean $only_src Only_src .
* @ param boolean $relative Relative .
* @ param boolean $options Options .
* @ param boolean $big_icons Big_icons .
2019-01-30 16:18:44 +01:00
*
2009-01-07 11:42:38 +01:00
* @ return string HTML with icon of the OS
*/
2019-01-30 16:18:44 +01:00
function ui_print_os_icon (
$id_os ,
$name = true ,
$return = false ,
$apply_skin = true ,
$networkmap = false ,
$only_src = false ,
$relative = false ,
2023-08-01 14:51:31 +02:00
$options = [],
2019-01-30 16:18:44 +01:00
$big_icons = false
) {
2022-12-15 12:42:35 +01:00
$subfolder = '.' ;
2019-01-30 16:18:44 +01:00
if ( $networkmap ) {
$subfolder = 'networkmap' ;
}
if ( $big_icons ) {
$subfolder .= '/so_big_icons' ;
}
2023-03-10 12:40:21 +01:00
if ( isset ( $options [ 'class' ]) === false ) {
2023-03-17 13:20:58 +01:00
$options [ 'class' ] = 'main_menu_icon invert_filter' ;
2023-03-10 12:40:21 +01:00
}
2022-12-15 12:42:35 +01:00
$no_in_meta = ( is_metaconsole () === false );
2019-06-13 15:04:39 +02:00
2019-01-30 16:18:44 +01:00
$icon = ( string ) db_get_value ( 'icon_name' , 'tconfig_os' , 'id_os' , ( int ) $id_os );
2023-04-12 14:44:01 +02:00
$extension = pathinfo ( $icon , PATHINFO_EXTENSION );
if ( empty ( $extension ) === true ) {
$icon .= '.png' ;
}
if ( empty ( $extension ) === true || $extension === 'png'
|| $extension === 'jpg' || $extension === 'gif' && $subfolder === '.'
) {
$subfolder = 'os_icons' ;
}
2019-01-30 16:18:44 +01:00
$os_name = get_os_name ( $id_os );
2022-12-15 12:42:35 +01:00
if ( empty ( $icon ) === true ) {
2019-01-30 16:18:44 +01:00
if ( $only_src ) {
$output = html_print_image (
'images/' . $subfolder . '/unknown.png' ,
true ,
$options ,
true ,
$relative ,
2019-06-13 15:04:39 +02:00
$no_in_meta ,
2019-01-30 16:18:44 +01:00
true
);
} else {
return '-' ;
}
} else if ( $apply_skin ) {
if ( $only_src ) {
2023-03-10 12:40:21 +01:00
$output = html_print_image (
'images/' . $subfolder . '/' . $icon ,
true ,
$options ,
true ,
$relative ,
$no_in_meta ,
true
);
2019-01-30 16:18:44 +01:00
} else {
if ( ! isset ( $options [ 'title' ])) {
$options [ 'title' ] = $os_name ;
}
2023-03-10 12:40:21 +01:00
$output = html_print_image (
'images/' . $subfolder . '/' . $icon ,
true ,
$options ,
false ,
$relative ,
$no_in_meta ,
true
);
2019-01-30 16:18:44 +01:00
}
} else {
// $output = "<img src='images/os_icons/" . $icon . "' alt='" . $os_name . "' title='" . $os_name . "'>";
$output = 'images/' . $subfolder . '/' . $icon ;
}
if ( $name === true ) {
$output .= ' ' . $os_name ;
}
if ( ! $return ) {
echo $output ;
}
return $output ;
2009-01-07 11:42:38 +01:00
}
2019-01-30 16:18:44 +01:00
2019-05-28 09:48:09 +02:00
/**
* Print type agent icon .
*
* @ param boolean $id_os Id_os .
* @ param boolean $remote_contact Remote_contact .
* @ param boolean $contact Contact .
* @ param boolean $return Return .
* @ param integer $remote Remote .
* @ param string $version Version .
*
* @ return string HTML .
*/
2019-01-30 16:18:44 +01:00
function ui_print_type_agent_icon (
$id_os = false ,
$remote_contact = false ,
$contact = false ,
$return = false ,
$remote = 0 ,
$version = ''
) {
2021-03-11 15:40:23 +01:00
global $config ;
2023-01-13 14:23:48 +01:00
if (( int ) $id_os === SATELLITE_OS_ID ) {
2019-05-28 09:48:09 +02:00
// Satellite.
2019-01-30 16:18:44 +01:00
$options [ 'title' ] = __ ( 'Satellite' );
2023-03-22 11:13:56 +01:00
$output = html_print_image (
'images/satellite@os.svg' ,
true ,
2023-05-08 14:26:28 +02:00
[
'class' => 'main_menu_icon invert_filter' ,
'style' => 'padding-right: 10px;' ,
],
2023-03-22 11:13:56 +01:00
false ,
false ,
false ,
true
);
2023-01-13 14:23:48 +01:00
} else if ( $remote_contact === $contact && $remote === 0 && empty ( $version ) === true ) {
2019-05-28 09:48:09 +02:00
// Network.
2019-01-30 16:18:44 +01:00
$options [ 'title' ] = __ ( 'Network' );
2023-03-22 11:13:56 +01:00
$output = html_print_image (
'images/network-server@os.svg' ,
true ,
2023-05-08 14:26:28 +02:00
[
'class' => 'main_menu_icon invert_filter' ,
'style' => 'padding-right: 10px;' ,
],
2023-03-22 11:13:56 +01:00
false ,
false ,
false ,
true
);
2019-01-30 16:18:44 +01:00
} else {
2019-05-28 09:48:09 +02:00
// Software.
2019-01-30 16:18:44 +01:00
$options [ 'title' ] = __ ( 'Software' );
2023-03-22 11:13:56 +01:00
$output = html_print_image (
'images/data-server@svg.svg' ,
true ,
2023-05-08 14:26:28 +02:00
[
'class' => 'main_menu_icon invert_filter' ,
'style' => 'padding-right: 10px;' ,
],
2023-03-22 11:13:56 +01:00
false ,
false ,
false ,
true
);
2019-01-30 16:18:44 +01:00
}
return $output ;
2017-07-24 15:53:31 +02:00
}
2019-01-30 16:18:44 +01:00
2009-01-07 11:42:38 +01:00
/**
* Prints an agent name with the correct link
2019-01-30 16:18:44 +01:00
*
2019-05-28 09:48:09 +02:00
* @ param integer $id_agent Agent id .
* @ param boolean $return Whether to return the string or echo it too .
* @ param integer $cutoff Now uses styles to accomplish this .
* @ param string $style Style of name in css .
* @ param boolean $cutname Cut names .
* @ param string $server_url Server url to concatenate at the begin of the link .
* @ param string $extra_params Extra parameters to concatenate in the link .
* @ param string $known_agent_name Name of the agent to avoid the query in some cases .
* @ param boolean $link If the agent will provided with link or not .
* @ param boolean $alias Use the agent alias or the name .
2019-01-30 16:18:44 +01:00
*
2009-01-07 11:42:38 +01:00
* @ return string HTML with agent name and link
2009-01-08 16:52:13 +01:00
*/
2019-05-28 09:48:09 +02:00
function ui_print_agent_name (
$id_agent ,
$return = false ,
$cutoff = 'agent_medium' ,
$style = '' ,
$cutname = false ,
$server_url = '' ,
$extra_params = '' ,
$known_agent_name = false ,
$link = true ,
$alias = true
) {
2019-01-30 16:18:44 +01:00
if ( $known_agent_name === false ) {
if ( $alias ) {
$agent_name = ( string ) agents_get_alias ( $id_agent );
} else {
$agent_name = ( string ) agents_get_name ( $id_agent );
}
} else {
$agent_name = $known_agent_name ;
}
if ( $alias ) {
$agent_name_full = ( string ) agents_get_name ( $id_agent );
} else {
$agent_name_full = $agent_name ;
}
if ( $cutname ) {
$agent_name = ui_print_truncate_text ( $agent_name , $cutoff , true , true , true , '[…]' , $style );
}
if ( $link ) {
2019-05-28 09:48:09 +02:00
$url = $server_url . 'index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente=' . $id_agent . $extra_params ;
2019-01-30 16:18:44 +01:00
2019-05-28 09:48:09 +02:00
$output = '<a style="' . $style . '" href="' . $url . '" title="' . $agent_name_full . '"><b><span style="' . $style . '">' . $agent_name . '</span></b></a>' ;
2019-01-30 16:18:44 +01:00
} else {
$output = '<b><span style="' . $style . '">' . $agent_name . '</span></b>' ;
}
2019-05-28 09:48:09 +02:00
// TODO: Add a pretty javascript (using jQuery) popup-box with agent details.
2019-01-30 16:18:44 +01:00
if ( $return ) {
return $output ;
}
echo $output ;
2009-01-07 11:42:38 +01:00
}
2009-01-15 11:21:38 +01:00
2019-01-30 16:18:44 +01:00
2016-03-30 13:05:08 +02:00
/**
2009-01-15 11:21:38 +01:00
* Formats a row from the alert table and returns an array usable in the table function
2019-01-30 16:18:44 +01:00
*
2019-05-28 09:48:09 +02:00
* @ param array $alert A valid ( non empty ) row from the alert table .
* @ param boolean $agent Whether or not this is a combined alert .
* @ param string $url Tab where the function was called from ( used for urls ) .
* @ param mixed $agent_style Style for agent name or default ( false ) .
2019-01-30 16:18:44 +01:00
*
2009-01-15 11:21:38 +01:00
* @ return array A formatted array with proper html for use in $table -> data ( 6 columns )
*/
2019-05-28 09:48:09 +02:00
function ui_format_alert_row (
$alert ,
$agent = true ,
$url = '' ,
$agent_style = false
) {
2019-01-30 16:18:44 +01:00
global $config ;
if ( ! isset ( $alert [ 'server_data' ])) {
$server_name = '' ;
$server_id = '' ;
$url_hash = '' ;
$console_url = '' ;
} else {
$server_data = $alert [ 'server_data' ];
$server_name = $server_data [ 'server_name' ];
$server_id = $server_data [ 'id' ];
$console_url = $server_data [ 'server_url' ] . '/' ;
$url_hash = metaconsole_get_servers_url_hash ( $server_data );
}
$actionText = '' ;
include_once $config [ 'homedir' ] . '/include/functions_alerts.php' ;
$isFunctionPolicies = enterprise_include_once ( 'include/functions_policies.php' );
$id_group = ( int ) get_parameter ( 'ag_group' , 0 );
2019-05-28 09:48:09 +02:00
// 0 is the All group (selects all groups).
2019-01-30 16:18:44 +01:00
if ( $isFunctionPolicies !== ENTERPRISE_NOT_HOOK ) {
if ( $agent ) {
$index = [
'policy' => 0 ,
'standby' => 1 ,
'force_execution' => 2 ,
'agent_name' => 3 ,
'module_name' => 4 ,
'description' => 5 ,
2023-05-10 16:24:22 +02:00
'template' => 6 ,
'action' => 7 ,
'last_fired' => 8 ,
'status' => 9 ,
'validate' => 10 ,
2023-07-03 10:21:55 +02:00
'actions' => 11 ,
2019-01-30 16:18:44 +01:00
];
} else {
$index = [
'policy' => 0 ,
'standby' => 1 ,
'force_execution' => 2 ,
'agent_name' => 3 ,
2023-05-10 16:24:22 +02:00
'module_name' => 4 ,
'description' => 5 ,
'template' => 6 ,
'action' => 7 ,
'last_fired' => 8 ,
'status' => 9 ,
'validate' => 10 ,
2019-01-30 16:18:44 +01:00
];
}
} else {
if ( $agent ) {
$index = [
'standby' => 0 ,
'force_execution' => 1 ,
'agent_name' => 2 ,
'module_name' => 3 ,
'description' => 4 ,
2023-05-10 16:24:22 +02:00
'template' => 5 ,
'action' => 6 ,
'last_fired' => 7 ,
'status' => 8 ,
'validate' => 9 ,
2019-01-30 16:18:44 +01:00
];
} else {
$index = [
'standby' => 0 ,
'force_execution' => 1 ,
'agent_name' => 2 ,
2023-05-10 16:24:22 +02:00
'module_name' => 3 ,
'description' => 4 ,
'template' => 5 ,
'action' => 6 ,
'last_fired' => 7 ,
'status' => 8 ,
'validate' => 9 ,
2019-01-30 16:18:44 +01:00
];
}
}
if ( $alert [ 'disabled' ]) {
2021-03-11 15:40:23 +01:00
$disabledHtmlStart = '<span class="italic_a">' ;
2019-01-30 16:18:44 +01:00
$disabledHtmlEnd = '</span>' ;
$styleDisabled = 'font-style: italic; color: #aaaaaa;' ;
} else {
$disabledHtmlStart = '' ;
$disabledHtmlEnd = '' ;
$styleDisabled = '' ;
}
2021-09-06 14:08:24 +02:00
if ( empty ( $alert ) === true ) {
2019-01-30 16:18:44 +01:00
if ( $isFunctionPolicies !== ENTERPRISE_NOT_HOOK ) {
return [
'' ,
'' ,
'' ,
'' ,
'' ,
'' ,
'' ,
'' ,
];
} else {
return [
'' ,
'' ,
'' ,
'' ,
'' ,
'' ,
'' ,
];
}
}
2022-09-19 14:02:50 +02:00
if ( is_metaconsole () === true && ( int ) $server_id !== 0 ) {
2019-01-30 16:18:44 +01:00
$server = db_get_row ( 'tmetaconsole_setup' , 'id' , $alert [ 'server_data' ][ 'id' ]);
if ( metaconsole_connect ( $server ) == NOERR ) {
2019-05-28 09:48:09 +02:00
// Get agent data from node.
2019-01-30 16:18:44 +01:00
$agente = db_get_row ( 'tagente' , 'id_agente' , $alert [ 'id_agent' ]);
metaconsole_restore_db ();
}
} else {
2019-05-28 09:48:09 +02:00
// Get agent id.
2019-01-30 16:18:44 +01:00
$id_agent = modules_get_agentmodule_agent ( $alert [ 'id_agent_module' ]);
$agente = db_get_row ( 'tagente' , 'id_agente' , $id_agent );
}
$template = alerts_get_alert_template ( $alert [ 'id_alert_template' ]);
$description = io_safe_output ( $template [ 'name' ]);
$data = [];
2019-05-28 09:48:09 +02:00
// Validate checkbox.
2021-09-06 14:08:24 +02:00
if ( is_metaconsole () === false ) {
2019-05-28 09:48:09 +02:00
if ( check_acl ( $config [ 'id_user' ], $id_group , 'LW' )
|| check_acl ( $config [ 'id_user' ], $id_group , 'LM' )
) {
2019-04-02 13:42:30 +02:00
$data [ $index [ 'validate' ]] = '' ;
$data [ $index [ 'validate' ]] .= html_print_checkbox (
'validate[]' ,
$alert [ 'id' ],
false ,
true ,
false ,
'' ,
true
);
}
}
2019-01-30 16:18:44 +01:00
if ( $isFunctionPolicies !== ENTERPRISE_NOT_HOOK ) {
2021-09-06 14:08:24 +02:00
if ( is_metaconsole () === true && ( int ) $alert [ 'server_data' ][ 'id' ] !== 0 ) {
2019-01-30 16:18:44 +01:00
$node = metaconsole_get_connection_by_id ( $alert [ 'server_data' ][ 'id' ]);
if ( metaconsole_load_external_db ( $node ) !== NOERR ) {
// Restore the default connection.
metaconsole_restore_db ();
$errors ++ ;
return false ;
}
}
$policyInfo = policies_is_alert_in_policy2 ( $alert [ 'id' ], false );
2021-09-23 19:02:31 +02:00
$module_linked = policies_is_module_linked ( $alert [ 'id_agent_module' ]);
2023-03-28 17:22:25 +02:00
if (( is_array ( $policyInfo ) === false && $module_linked === false )
|| ( is_array ( $policyInfo ) === false && $module_linked === '1' )
) {
2019-01-30 16:18:44 +01:00
$data [ $index [ 'policy' ]] = '' ;
} else {
2021-09-23 19:02:31 +02:00
$module_linked = policies_is_module_linked ( $alert [ 'id_agent_module' ]);
if ( $module_linked === '0' ) {
$img = 'images/unlinkpolicy.png' ;
} else {
2023-03-29 13:37:07 +02:00
$img = 'images/policy@svg.svg' ;
2021-09-23 19:02:31 +02:00
}
2021-09-06 14:08:24 +02:00
if ( is_metaconsole () === false ) {
2023-03-29 13:37:07 +02:00
$data [ $index [ 'policy' ]] = '<a href="?sec=gmodules&sec2=enterprise/godmode/policies/policies&id=' . $policyInfo [ 'id' ] . '">' . html_print_image ( $img , true , [ 'title' => $policyInfo [ 'name' ], 'class' => 'invert_filter main_menu_icon' ]) . '</a>' ;
2019-01-30 16:18:44 +01:00
} else {
2023-03-29 13:37:07 +02:00
$data [ $index [ 'policy' ]] = '<a href="?sec=gmodules&sec2=advanced/policymanager&id=' . $policyInfo [ 'id' ] . '">' . html_print_image ( $img , true , [ 'title' => $policyInfo [ 'name' ], 'class' => 'invert_filter main_menu_icon' ]) . '</a>' ;
2019-01-30 16:18:44 +01:00
}
}
2021-09-06 14:08:24 +02:00
if ( is_metaconsole () === true ) {
2019-01-30 16:18:44 +01:00
metaconsole_restore_db ();
}
}
2019-05-28 09:48:09 +02:00
// Standby.
2019-01-30 16:18:44 +01:00
$data [ $index [ 'standby' ]] = '' ;
if ( isset ( $alert [ 'standby' ]) && $alert [ 'standby' ] == 1 ) {
$data [ $index [ 'standby' ]] = html_print_image ( 'images/bell_pause.png' , true , [ 'title' => __ ( 'Standby on' )]);
}
2021-09-06 14:08:24 +02:00
if ( is_metaconsole () === false ) {
2019-05-28 09:48:09 +02:00
// Force alert execution.
2023-01-10 10:18:37 +01:00
if (( bool ) check_acl ( $config [ 'id_user' ], $id_group , 'AW' ) === true || ( bool ) check_acl ( $config [ 'id_user' ], $id_group , 'LM' ) === true ) {
if (( int ) $alert [ 'force_execution' ] === 0 ) {
$forceTitle = __ ( 'Force check' );
$additionUrl = '&force_execution=1' ;
2019-01-30 16:18:44 +01:00
} else {
2023-01-10 10:18:37 +01:00
$forceTitle = __ ( 'Refresh' );
$additionUrl = '' ;
2019-01-30 16:18:44 +01:00
}
2023-01-10 10:18:37 +01:00
2023-05-10 16:24:22 +02:00
$forceExecButtons [ 'force_check' ] = html_print_anchor (
2023-03-31 10:44:51 +02:00
[
'href' => $url . '&id_alert=' . $alert [ 'id' ] . '&refr=60' . $additionUrl ,
'content' => html_print_image (
'images/force@svg.svg' ,
true ,
[
'title' => $forceTitle ,
'class' => 'main_menu_icon invert_filter' ,
]
),
],
2023-01-10 10:18:37 +01:00
true
);
2019-01-30 16:18:44 +01:00
}
2023-01-10 10:18:37 +01:00
2023-05-10 16:24:22 +02:00
$forceExecButtons [ 'template' ] = html_print_anchor (
2023-01-10 10:18:37 +01:00
[
2023-03-31 10:44:51 +02:00
'href' => 'ajax.php?page=godmode/alerts/alert_templates&get_template_tooltip=1&id_template=' . $template [ 'id' ],
2023-05-10 16:24:22 +02:00
'style' => 'margin-left: 5px;' ,
2023-03-31 10:44:51 +02:00
'class' => 'template_details' ,
'content' => html_print_image (
'images/details.svg' ,
true ,
[ 'class' => 'main_menu_icon invert_filter' ]
),
2023-01-10 10:18:37 +01:00
],
true
);
} else {
2023-05-10 16:24:22 +02:00
$forceExecButtons [ 'template' ] = html_print_anchor (
2023-01-10 10:18:37 +01:00
[
2023-03-31 10:44:51 +02:00
'href' => ui_get_full_url ( '/' , false , false , false ) . '/ajax.php?page=enterprise/meta/include/ajax/tree_view.ajax&action=get_template_tooltip&id_template=' . $template [ 'id' ] . '&server_name=' . $alert [ 'server_data' ][ 'server_name' ],
2023-05-10 16:24:22 +02:00
'style' => 'margin-left: 5px;' ,
2023-03-31 10:44:51 +02:00
'class' => 'template_details' ,
'content' => html_print_image (
'images/details.svg' ,
true ,
[ 'class' => 'main_menu_icon invert_filter' ]
),
2023-01-10 10:18:37 +01:00
],
true
);
2019-01-30 16:18:44 +01:00
}
2023-05-10 16:24:22 +02:00
if ( isset ( $forceExecButtons [ 'force_check' ])) {
$data [ $index [ 'force_execution' ]] = html_print_div (
[
'class' => 'table_action_buttons flex' ,
'content' => $forceExecButtons [ 'force_check' ],
],
true
);
}
if ( isset ( $forceExecButtons [ 'template' ])) {
$data [ $index [ 'template' ]] = $forceExecButtons [ 'template' ];
}
2023-01-10 10:18:37 +01:00
2019-01-30 16:18:44 +01:00
$data [ $index [ 'agent_name' ]] = $disabledHtmlStart ;
if ( $agent == 0 ) {
2019-12-27 10:24:48 +01:00
$data [ $index [ 'module_name' ]] .= ui_print_truncate_text ( isset ( $alert [ 'agent_module_name' ]) ? $alert [ 'agent_module_name' ] : modules_get_agentmodule_name ( $alert [ 'id_agent_module' ]), 'module_small' , false , true , true , '[…]' , '' );
2019-01-30 16:18:44 +01:00
} else {
2021-09-06 14:08:24 +02:00
if ( is_metaconsole () === true ) {
2019-01-30 16:18:44 +01:00
$agent_name = $alert [ 'agent_name' ];
$id_agent = $alert [ 'id_agent' ];
} else {
$agent_name = false ;
$id_agent = modules_get_agentmodule_agent ( $alert [ 'id_agent_module' ]);
}
2022-07-21 11:52:45 +02:00
if ( is_metaconsole () === true ) {
// Do not show link if user cannot access node
if (( bool ) can_user_access_node () === true ) {
$url = $server [ 'server_url' ] . '/index.php?' . 'sec=estado&' . 'sec2=operation/agentes/ver_agente&' . 'id_agente=' . $agente [ 'id_agente' ];
2023-01-10 10:18:37 +01:00
$data [ $index [ 'agent_name' ]] .= html_print_anchor (
[
'href' => $url ,
'content' => '<span class="bolder" title="' . $agente [ 'nombre' ] . '">' . $agente [ 'alias' ] . '</span>' ,
],
true
);
2022-07-21 11:52:45 +02:00
} else {
2023-01-10 10:18:37 +01:00
$data [ $index [ 'agent_name' ]] .= '<span class="bolder" title="' . $agente [ 'nombre' ] . '">' . $agente [ 'alias' ] . '</span>' ;
2022-07-21 11:52:45 +02:00
}
2019-01-30 16:18:44 +01:00
} else {
2023-01-10 10:18:37 +01:00
$data [ $index [ 'agent_name' ]] .= html_print_anchor (
[
'href' => 'index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente=' . $id_agent ,
'content' => '<span class="bolder" title="' . $agente [ 'nombre' ] . '">' . $agente [ 'alias' ] . '</span>' ,
],
true
);
2019-01-30 16:18:44 +01:00
}
2023-07-04 12:47:04 +02:00
$alert_module_name = isset ( $alert [ 'agent_module_name' ]) ? $alert [ 'agent_module_name' ] : modules_get_agentmodule_name ( $alert [ 'id_agent_module' ]);
$data [ $index [ 'module_name' ]] = ui_print_truncate_text ( $alert_module_name , 'module_small' , false , true , true , '[…]' , '' );
2019-01-30 16:18:44 +01:00
}
$data [ $index [ 'agent_name' ]] .= $disabledHtmlEnd ;
$data [ $index [ 'description' ]] = '' ;
$actionDefault = db_get_value_sql (
' SELECT id_alert_action
FROM talert_templates WHERE id = '.$alert[' id_alert_template ' ]
);
2019-12-27 10:24:48 +01:00
$data [ $index [ 'description' ]] .= $disabledHtmlStart . ui_print_truncate_text ( io_safe_output ( $description ), 'description' , false , true , true , '[…]' , '' ) . $disabledHtmlEnd ;
2019-01-30 16:18:44 +01:00
2023-07-04 12:47:04 +02:00
if ( is_metaconsole ()) {
if ( enterprise_include_once ( 'include/functions_metaconsole.php' ) !== ENTERPRISE_NOT_HOOK ) {
$connection = metaconsole_get_connection ( $agente [ 'server_name' ]);
if ( metaconsole_load_external_db ( $connection ) !== NOERR ) {
echo json_encode ( false );
// Restore db connection.
metaconsole_restore_db ();
return ;
}
}
}
$actions = alerts_get_alert_agent_module_actions ( $alert [ 'id' ], false , - 1 , true );
if ( is_metaconsole ()) {
// Restore db connection.
metaconsole_restore_db ();
}
2019-01-30 16:18:44 +01:00
2021-12-27 19:01:53 +01:00
if ( empty ( $actions ) === false || $actionDefault != '' ) {
2019-01-30 16:18:44 +01:00
$actionText = '<div><ul class="action_list">' ;
foreach ( $actions as $action ) {
2021-03-11 15:40:23 +01:00
$actionText .= '<div class="mrgn_btn_5px" ><span class="action_name"><li>' . $action [ 'name' ];
2019-01-30 16:18:44 +01:00
if ( $action [ 'fires_min' ] != $action [ 'fires_max' ]) {
$actionText .= ' (' . $action [ 'fires_min' ] . ' / ' . $action [ 'fires_max' ] . ')' ;
}
2023-07-04 12:47:04 +02:00
$actionText .= ui_print_help_tip ( __ ( 'The default actions will be executed every time that the alert is fired and no other action is executed' ), true );
// Is possible manage actions if have LW permissions in the agent group of the alert module.
2023-09-12 12:30:52 +02:00
if ( is_metaconsole () === true ) {
if ( check_acl ( $config [ 'id_user' ], $id_group , 'LM' )) {
$actionText .= '<a href="index.php?sec=galertas&sec2=godmode/alerts/alert_list&tab=list&delete_action=1&id_alert=' . $alert [ 'id' ] . '&id_agent=' . $agente [ 'alias' ] . '&id_action=' . $action [ 'original_id' ] . '" onClick="if (!confirm(\' ' . __ ( 'Are you sure you want to delete alert action?' ) . '\')) return false;">' . html_print_image (
'images/delete.svg' ,
true ,
[
'alt' => __ ( 'Delete action' ),
'title' => __ ( 'Delete action' ),
'class' => 'main_menu_icon invert_filter vertical_baseline' ,
]
) . '</a>' ;
}
2023-07-04 12:47:04 +02:00
2023-09-12 12:30:52 +02:00
if ( check_acl ( $config [ 'id_user' ], $id_group , 'LW' )) {
$actionText .= html_print_input_image (
'update_action' ,
'/images/edit.svg' ,
1 ,
'padding:0px;' ,
true ,
[
'title' => __ ( 'Update action' ),
'class' => 'main_menu_icon invert_filter' ,
'onclick' => 'show_display_update_action(\'' . $action [ 'original_id' ] . '\',\'' . $alert [ 'id' ] . '\',\'' . $alert [ 'id_agent_module' ] . '\',\'' . $action [ 'original_id' ] . '\',\'' . $alert [ 'agent_name' ] . '\')' ,
]
);
$actionText .= html_print_input_hidden ( 'id_agent_module' , $alert [ 'id_agent_module' ], true );
}
2023-07-04 12:47:04 +02:00
}
$actionText .= '<div id="update_action-div-' . $alert [ 'id' ] . '" class="invisible">' ;
$actionText .= '</div>' ;
2019-01-30 16:18:44 +01:00
$actionText .= '</li></span></div>' ;
}
$actionText .= '</ul></div>' ;
2021-12-27 19:01:53 +01:00
2023-07-04 12:47:04 +02:00
if ( $actionDefault !== '' && $actionDefault !== false ) {
2023-06-29 12:59:32 +02:00
$actionDefault_name = db_get_sql (
2019-05-28 10:47:31 +02:00
sprintf (
'SELECT name FROM talert_actions WHERE id = %d' ,
$actionDefault
)
2023-06-29 12:59:32 +02:00
);
foreach ( $actions as $action ) {
if ( $actionDefault_name === $action [ 'name' ]) {
$hide_actionDefault = true ;
2023-07-04 12:47:04 +02:00
} else {
$hide_actionDefault = false ;
2023-06-29 12:59:32 +02:00
}
}
if ( $hide_actionDefault !== true ) {
$actionText .= $actionDefault_name . ' <i>(' . __ ( 'Default' ) . ')</i>' ;
}
2019-01-30 16:18:44 +01:00
}
}
$data [ $index [ 'action' ]] = $actionText ;
$data [ $index [ 'last_fired' ]] = $disabledHtmlStart . ui_print_timestamp ( $alert [ 'last_fired' ], true ) . $disabledHtmlEnd ;
$status = STATUS_ALERT_NOT_FIRED ;
$title = '' ;
if ( $alert [ 'times_fired' ] > 0 ) {
$status = STATUS_ALERT_FIRED ;
$title = __ ( 'Alert fired' ) . ' ' . $alert [ 'internal_counter' ] . ' ' . __ ( 'time(s)' );
} else if ( $alert [ 'disabled' ] > 0 ) {
$status = STATUS_ALERT_DISABLED ;
$title = __ ( 'Alert disabled' );
} else {
$status = STATUS_ALERT_NOT_FIRED ;
$title = __ ( 'Alert not fired' );
}
$data [ $index [ 'status' ]] = ui_print_status_image ( $status , $title , true );
2023-04-27 16:05:37 +02:00
$data [ $index [ 'status' ]] .= '<div id="update_action-div-' . $alert [ 'id' ] . '" class="invisible">' ;
if ( is_metaconsole ()) {
if ( enterprise_include_once ( 'include/functions_metaconsole.php' ) !== ENTERPRISE_NOT_HOOK ) {
$connection = metaconsole_get_connection ( $agente [ 'server_name' ]);
if ( metaconsole_load_external_db ( $connection ) !== NOERR ) {
echo json_encode ( false );
// Restore db connection.
metaconsole_restore_db ();
return ;
}
}
$action = db_get_all_rows_filter (
'talert_template_module_actions' ,
[ 'id_alert_template_module' => $alert [ 'id' ]],
'id'
)[ 0 ];
if ( is_metaconsole ()) {
// Restore db connection.
metaconsole_restore_db ();
}
2023-07-04 12:47:04 +02:00
$tableActionButtons [] = '' ;
2023-04-27 16:05:37 +02:00
// Edit.
2023-07-05 11:14:09 +02:00
if ( check_acl ( $config [ 'id_user' ], $id_group , 'LM' )) {
2023-07-03 14:56:39 +02:00
$tableActionButtons [] = html_print_input_hidden ( 'id_agent_module' , $alert [ 'id_agent_module' ], true );
2023-07-05 11:14:09 +02:00
$tableActionButtons [] = '<a href="index.php?sec=galertas&sec2=godmode/alerts/alert_list&tab=list&delete_alert=1&id_alert=' . $alert [ 'id' ] . '&id_agent=' . $alert [ 'agent_name' ] . '" onClick="if (!confirm(\' ' . __ ( 'Are you sure you want to delete alert?' ) . '\')) return false;">' . html_print_image (
'images/delete.svg' ,
true ,
[
'alt' => __ ( 'Delete' ),
'title' => __ ( 'Delete' ),
'class' => 'main_menu_icon invert_filter vertical_baseline' ,
]
) . '</a>' ;
2023-07-04 12:47:04 +02:00
$tableActionButtons [] = '<a href="javascript:show_add_action(\'' . $alert [ 'id' ] . '\');">' . html_print_image (
'images/plus-black.svg' ,
2023-07-03 14:56:39 +02:00
true ,
[
2023-07-04 12:47:04 +02:00
'title' => __ ( 'Add action' ),
'class' => 'invert_filter main_menu_icon' ,
'style' => 'margin-bottom: 12px;' ,
2023-07-03 14:56:39 +02:00
]
) . '</a>' ;
}
2023-04-27 16:05:37 +02:00
$data [ $index [ 'actions' ]] = html_print_div (
[
'style' => 'padding-top: 8px;' ,
'content' => implode ( '' , $tableActionButtons ),
],
true
);
}
2019-01-30 16:18:44 +01:00
2023-07-04 12:47:04 +02:00
// Is possible manage actions if have LW permissions in the agent group of the alert module.
if ( check_acl_one_of_groups ( $config [ 'id_user' ], $all_groups , 'LW' ) || check_acl ( $config [ 'id_user' ], $template_group , 'LM' )) {
if ( check_acl ( $config [ 'id_user' ], $template_group , 'LW' )) {
$own_groups = users_get_groups ( $config [ 'id_user' ], 'LW' , true );
} else if ( check_acl ( $config [ 'id_user' ], $template_group , 'LM' )) {
$own_groups = users_get_groups ( $config [ 'id_user' ], 'LM' , true );
}
$filter_groups = '' ;
$filter_groups = implode ( ',' , array_keys ( $own_groups ));
if ( $filter_groups != null ) {
$actions = alerts_get_alert_actions_filter ( true , 'id_group IN (' . $filter_groups . ')' );
}
$data [ $index [ 'actions' ]] .= '<div id="add_action-div-' . $alert [ 'id' ] . '" class="invisible">' ;
$data [ $index [ 'actions' ]] .= '<form id="add_action_form-' . $alert [ 'id' ] . '" method="post" style="height:85%;" action="index.php?sec=galertas&sec2=godmode/alerts/alert_list">' ;
$data [ $index [ 'actions' ]] .= '<table class="w100p bg_color222 filter-table-adv">' ;
$data [ $index [ 'actions' ]] .= html_print_input_hidden ( 'add_action' , 1 , true );
$data [ $index [ 'actions' ]] .= html_print_input_hidden ( 'id_agent' , $agente [ 'alias' ], true );
$data [ $index [ 'actions' ]] .= html_print_input_hidden ( 'id_alert_module' , $alert [ 'id' ], true );
if ( ! $id_agente ) {
$data [ $index [ 'actions' ]] .= '<tr class="datos2">' ;
$data [ $index [ 'actions' ]] .= '<td class="w50p">' . html_print_label_input_block (
__ ( 'Agent' ),
2023-09-11 11:41:30 +02:00
ui_print_truncate_text ( $agente [ 'alias' ], 'agent_medium' , false , true , true , '[…]' )
2023-07-04 12:47:04 +02:00
) . '</td>' ;
$data [ $index [ 'actions' ]] .= '<td class="w50p">' . html_print_label_input_block (
__ ( 'Module' ),
ui_print_truncate_text ( $alert_module_name , 'module_small' , false , true , true , '[…]' )
) . '</td>' ;
$data [ $index [ 'actions' ]] .= '</tr>' ;
}
$data [ $index [ 'actions' ]] .= '<tr class="datos2">' ;
$data [ $index [ 'actions' ]] .= '<td class="w50p">' . html_print_label_input_block (
__ ( 'Action' ),
html_print_select (
$actions ,
'action_select' ,
'' ,
'' ,
__ ( 'None' ),
0 ,
true ,
false ,
true ,
'' ,
false ,
'width:100%'
)
) . '</td>' ;
$data [ $index [ 'actions' ]] .= '<td class="w50p">' . html_print_label_input_block (
__ ( 'Number of alerts match from' ),
'<div class="inline">' . html_print_input_text (
'fires_min' ,
0 ,
'' ,
4 ,
10 ,
true ,
false ,
false ,
'' ,
'w40p'
) . ' ' . __ ( 'to' ) . ' ' . html_print_input_text (
'fires_max' ,
0 ,
'' ,
4 ,
10 ,
true ,
false ,
false ,
'' ,
'w40p'
) . '</div>'
) . '</td>' ;
$data [ $index [ 'actions' ]] .= '</tr>' ;
$data [ $index [ 'actions' ]] .= '<tr class="datos2">' ;
$data [ $index [ 'actions' ]] .= '<td class="w50p">' . html_print_label_input_block (
__ ( 'Threshold' ),
html_print_extended_select_for_time (
'module_action_threshold' ,
0 ,
'' ,
'' ,
'' ,
false ,
true ,
false ,
true ,
'' ,
false ,
false ,
'' ,
false ,
true
)
) . '</td>' ;
$data [ $index [ 'actions' ]] .= '</tr>' ;
$data [ $index [ 'actions' ]] .= '</table>' ;
$data [ $index [ 'actions' ]] .= html_print_submit_button (
__ ( 'Add' ),
'addbutton' ,
false ,
[
'icon' => 'next' ,
'class' => 'mini float-right' ,
],
true
);
$data [ $index [ 'actions' ]] .= '</form>' ;
$data [ $index [ 'actions' ]] .= '</div>' ;
}
2019-01-30 16:18:44 +01:00
return $data ;
2009-01-15 11:21:38 +01:00
}
2009-01-20 Evi Vanoost <vanooste@rcbi.rochester.edu>
* ajax.php, include/config.inc.php, include/config_process.php,
include/functions.php, include/functions_db.php,
include/functions_ui.php, index.php, install.php,
operation/users/user.php, operation/users/user_edit.php,
reporting/fgraph.php: Added pluggable authentication and moved functions
* general/login_page.php, general/logon_ok.php,
godmode/agentes/modificar_agente.php,
godmode/users/configure_users.php, godmode/users/user_list.php,
operation/agentes/estado_agente.php, operation/incidents/incident.php,
operation/incidents/incident_search.php: Updated functions
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1366 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-01-20 19:21:20 +01:00
2019-01-30 16:18:44 +01:00
2009-01-20 Evi Vanoost <vanooste@rcbi.rochester.edu>
* ajax.php, include/config.inc.php, include/config_process.php,
include/functions.php, include/functions_db.php,
include/functions_ui.php, index.php, install.php,
operation/users/user.php, operation/users/user_edit.php,
reporting/fgraph.php: Added pluggable authentication and moved functions
* general/login_page.php, general/logon_ok.php,
godmode/agentes/modificar_agente.php,
godmode/users/configure_users.php, godmode/users/user_list.php,
operation/agentes/estado_agente.php, operation/incidents/incident.php,
operation/incidents/incident_search.php: Updated functions
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1366 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-01-20 19:21:20 +01:00
/**
2016-03-30 13:05:08 +02:00
* Prints a substracted string , length specified by cutoff , the full string will be in a rollover .
2009-01-20 Evi Vanoost <vanooste@rcbi.rochester.edu>
* ajax.php, include/config.inc.php, include/config_process.php,
include/functions.php, include/functions_db.php,
include/functions_ui.php, index.php, install.php,
operation/users/user.php, operation/users/user_edit.php,
reporting/fgraph.php: Added pluggable authentication and moved functions
* general/login_page.php, general/logon_ok.php,
godmode/agentes/modificar_agente.php,
godmode/users/configure_users.php, godmode/users/user_list.php,
operation/agentes/estado_agente.php, operation/incidents/incident.php,
operation/incidents/incident_search.php: Updated functions
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1366 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-01-20 19:21:20 +01:00
*
2019-05-28 10:47:31 +02:00
* @ param string $string The string to be cut ..
* @ param integer $cutoff At how much characters to cut .
* @ param boolean $return Whether to return or print it out .
* @ param integer $fontsize Size font ( fixed ) in px , applyed as CSS style ( optional ) .
2009-01-20 Evi Vanoost <vanooste@rcbi.rochester.edu>
* ajax.php, include/config.inc.php, include/config_process.php,
include/functions.php, include/functions_db.php,
include/functions_ui.php, index.php, install.php,
operation/users/user.php, operation/users/user_edit.php,
reporting/fgraph.php: Added pluggable authentication and moved functions
* general/login_page.php, general/logon_ok.php,
godmode/agentes/modificar_agente.php,
godmode/users/configure_users.php, godmode/users/user_list.php,
operation/agentes/estado_agente.php, operation/incidents/incident.php,
operation/incidents/incident_search.php: Updated functions
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1366 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-01-20 19:21:20 +01:00
*
2019-05-28 10:47:31 +02:00
* @ return string HTML string .
2009-01-20 Evi Vanoost <vanooste@rcbi.rochester.edu>
* ajax.php, include/config.inc.php, include/config_process.php,
include/functions.php, include/functions_db.php,
include/functions_ui.php, index.php, install.php,
operation/users/user.php, operation/users/user_edit.php,
reporting/fgraph.php: Added pluggable authentication and moved functions
* general/login_page.php, general/logon_ok.php,
godmode/agentes/modificar_agente.php,
godmode/users/configure_users.php, godmode/users/user_list.php,
operation/agentes/estado_agente.php, operation/incidents/incident.php,
operation/incidents/incident_search.php: Updated functions
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1366 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-01-20 19:21:20 +01:00
*/
2019-01-30 16:18:44 +01:00
function ui_print_string_substr ( $string , $cutoff = 16 , $return = false , $fontsize = 0 )
{
if ( empty ( $string )) {
return '' ;
}
$string2 = io_safe_output ( $string );
if ( mb_strlen ( $string2 , 'UTF-8' ) > $cutoff ) {
$string3 = '...' ;
} else {
$string3 = '' ;
}
$font_size_mod = '' ;
if ( $fontsize > 0 ) {
$font_size_mod = " style='font-size: " . $fontsize . " pt' " ;
}
2019-05-28 10:47:31 +02:00
$string = '<span ' . $font_size_mod . ' title="' . io_safe_input ( $string2 ) . '">' ;
$string .= mb_substr ( $string2 , 0 , $cutoff , 'UTF-8' ) . $string3 . '</span>' ;
2019-01-30 16:18:44 +01:00
if ( $return === false ) {
echo $string ;
}
return $string ;
2009-01-20 Evi Vanoost <vanooste@rcbi.rochester.edu>
* ajax.php, include/config.inc.php, include/config_process.php,
include/functions.php, include/functions_db.php,
include/functions_ui.php, index.php, install.php,
operation/users/user.php, operation/users/user_edit.php,
reporting/fgraph.php: Added pluggable authentication and moved functions
* general/login_page.php, general/logon_ok.php,
godmode/agentes/modificar_agente.php,
godmode/users/configure_users.php, godmode/users/user_list.php,
operation/agentes/estado_agente.php, operation/incidents/incident.php,
operation/incidents/incident_search.php: Updated functions
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1366 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-01-20 19:21:20 +01:00
}
2009-01-21 15:56:55 +01:00
2019-01-30 16:18:44 +01:00
2009-01-21 15:56:55 +01:00
/**
* Gets a helper text explaining the requirement needs for an alert template
* to get it fired .
*
2019-05-28 10:47:31 +02:00
* @ param integer $id_alert_template Alert template id .
* @ param boolean $return Wheter to return or print it out .
* @ param boolean $print_values Wheter to put the values in the string or not .
2009-01-21 15:56:55 +01:00
*
* @ return An HTML string if return was true .
*/
2023-09-01 14:06:48 +02:00
function ui_print_alert_template_example ( $id_alert_template , $return = false , $print_values = true , $print_icon = true )
2019-01-30 16:18:44 +01:00
{
$output = '' ;
2023-09-01 14:06:48 +02:00
if ( $print_icon === true ) {
$output .= html_print_image ( 'images/information.png' , true , [ 'class' => 'invert_filter' ]);
}
2019-01-30 16:18:44 +01:00
$output .= '<span id="example">' ;
$template = alerts_get_alert_template ( $id_alert_template );
switch ( $template [ 'type' ]) {
case 'equal' :
2019-05-28 10:47:31 +02:00
// Do not translate the HTML attributes.
2019-01-30 16:18:44 +01:00
$output .= __ ( 'The alert would fire when the value is <span id="value"></span>' );
break ;
case 'not_equal' :
2019-05-28 10:47:31 +02:00
// Do not translate the HTML attributes.
2019-01-30 16:18:44 +01:00
$output .= __ ( 'The alert would fire when the value is not <span id="value"></span>' );
break ;
case 'regex' :
if ( $template [ 'matches_value' ]) {
2019-05-28 10:47:31 +02:00
// Do not translate the HTML attributes.
2019-01-30 16:18:44 +01:00
$output .= __ ( 'The alert would fire when the value matches <span id="value"></span>' );
} else {
2019-05-28 10:47:31 +02:00
// End if.
2019-01-30 16:18:44 +01:00
$output .= __ ( 'The alert would fire when the value doesn\'t match <span id="value"></span>' );
}
$value = $template [ 'value' ];
break ;
case 'max_min' :
if ( $template [ 'matches_value' ]) {
2019-05-28 10:47:31 +02:00
// Do not translate the HTML attributes.
2019-01-30 16:18:44 +01:00
$output .= __ ( 'The alert would fire when the value is between <span id="min"></span> and <span id="max"></span>' );
} else {
2019-05-28 10:47:31 +02:00
// End if.
2019-01-30 16:18:44 +01:00
$output .= __ ( 'The alert would fire when the value is not between <span id="min"></span> and <span id="max"></span>' );
}
break ;
case 'max' :
2019-05-28 10:47:31 +02:00
// Do not translate the HTML attributes.
2019-01-30 16:18:44 +01:00
$output .= __ ( 'The alert would fire when the value is over <span id="max"></span>' );
break ;
case 'min' :
2019-05-28 10:47:31 +02:00
// Do not translate the HTML attributes.
2019-01-30 16:18:44 +01:00
$output .= __ ( 'The alert would fire when the value is under <span id="min"></span>' );
break ;
case 'warning' :
2019-05-28 10:47:31 +02:00
// Do not translate the HTML attributes.
2019-01-30 16:18:44 +01:00
$output .= __ ( 'The alert would fire when the module is in warning status' );
break ;
case 'critical' :
2019-05-28 10:47:31 +02:00
// Do not translate the HTML attributes.
2019-01-30 16:18:44 +01:00
$output .= __ ( 'The alert would fire when the module is in critical status' );
break ;
2019-05-28 10:47:31 +02:00
default :
// Do nothing.
$output .= __ ( 'Unknown option.' );
break ;
2019-01-30 16:18:44 +01:00
}
if ( $print_values ) {
/*
2019-05-28 10:47:31 +02:00
* Replace span elements with real values . This is done in such way to avoid
* duplicating strings and make it easily modificable via Javascript .
*/
2019-01-30 16:18:44 +01:00
$output = str_replace ( '<span id="value"></span>' , $template [ 'value' ], $output );
$output = str_replace ( '<span id="max"></span>' , $template [ 'max_value' ], $output );
$output = str_replace ( '<span id="min"></span>' , $template [ 'min_value' ], $output );
}
$output .= '</span>' ;
if ( $return ) {
return $output ;
}
echo $output ;
2009-01-21 15:56:55 +01:00
}
2019-01-30 16:18:44 +01:00
2009-02-13 21:23:44 +01:00
/**
* Prints a help tip icon .
2019-01-30 16:18:44 +01:00
*
2019-05-28 10:47:31 +02:00
* @ param string $help_id Id of the help article .
* @ param boolean $return Whether to return or output the result .
* @ param string $home_url Home url if its necessary .
* @ param string $image Image path .
* @ param boolean $is_relative Route is relative or not .
* @ param string $id Target id .
2023-03-07 11:14:10 +01:00
* @ param string $isHeader If true , the view is header .
2019-01-30 16:18:44 +01:00
*
2009-02-13 21:23:44 +01:00
* @ return string The help tip
*/
2019-05-28 10:47:31 +02:00
function ui_print_help_icon (
$help_id ,
$return = false ,
$home_url = '' ,
2023-03-03 14:16:06 +01:00
$image = 'images/info@svg.svg' ,
2019-05-28 10:47:31 +02:00
$is_relative = false ,
2023-03-07 11:14:10 +01:00
$id = '' ,
$isHeader = false
2019-05-28 10:47:31 +02:00
) {
2019-01-30 16:18:44 +01:00
global $config ;
2023-03-07 11:14:10 +01:00
if ( empty ( $image ) === true ) {
$image = 'images/info@svg.svg' ;
}
$iconClass = ( $isHeader === true ) ? 'header_help_icon' : 'main_menu_icon' ;
2019-04-24 13:53:18 +02:00
// Do not display the help icon if help is disabled.
2022-12-07 18:16:47 +01:00
if (( bool ) $config [ 'disable_help' ] === true ) {
2019-01-30 16:18:44 +01:00
return '' ;
}
2022-12-07 18:16:47 +01:00
if ( empty ( $home_url ) === true ) {
2019-01-30 16:18:44 +01:00
$home_url = '' ;
}
2022-12-07 18:16:47 +01:00
if ( is_metaconsole () === true ) {
2019-01-30 16:18:44 +01:00
$home_url = '../../' . $home_url ;
}
2019-04-24 13:53:18 +02:00
$url = get_help_info ( $help_id );
2019-11-21 18:21:46 +01:00
$b = base64_encode ( $url );
2019-04-24 13:53:18 +02:00
2019-11-21 18:21:46 +01:00
$help_handler = 'index.php?sec=view&sec2=general/help_feedback' ;
// Needs to use url encoded to avoid anchor lost.
$help_handler .= '&b=' . $b ;
$help_handler .= '&pure=1&url=' . $url ;
2019-01-30 16:18:44 +01:00
$output = html_print_image (
$image ,
true ,
[
2023-03-07 11:14:10 +01:00
'class' => 'img_help ' . $iconClass ,
2019-01-30 16:18:44 +01:00
'title' => __ ( 'Help' ),
2019-11-21 18:21:46 +01:00
'onclick' => " open_help (' " . ui_get_full_url ( $help_handler ) . " ') " ,
2019-05-09 13:43:53 +02:00
'id' => $id ,
2019-01-30 16:18:44 +01:00
],
false ,
$is_relative && is_metaconsole ()
);
if ( ! $return ) {
echo $output ;
}
return $output ;
2009-02-13 21:23:44 +01:00
}
2009-02-19 Esteban Sanchez <estebans@artica.es>
* include/functions_ui.php: Added require_css_file(),
require_javascript_file() and require_jquery_file() to add CSS,
javascript and jQuery files to the header easily without changing
config object. A path parameter is addded to allow the use on
enterprise code.
* include/functions_db.php: Added
get_db_value_filter(), get_db_all_rows_filter() and
process_sql_delete(). Fixed delete_agent() style and use these
functions. Added process_page_head() from functions_ui.php and changed
a bit the config javascript object part.
* include/functions_custom_graphs.php: Get results indexed by id on
get_user_custom_graphs().
* include/functions.php: Moved process_page_head to functions_ui.php.
* godmode/agentes/manage_delete.php: New interface to perform massive
agents deletion.
* godmode/menu.php: Added new option to massive agents deletion.
* general/main_menu.php, godmode/agentes/manage_config.php,
godmode/agentes/module_manager_editor.php,
godmode/agentes/planned_downtime.php,
godmode/alerts/alert_compounds.php, godmode/alerts/alert_list.php,
godmode/alerts/configure_alert_compound.php,
godmode/alerts/configure_alert_template.php,
godmode/reporting/map_builder.php, operation/agentes/networkmap.php,
operation/reporting/reporting_viewer.php,
operation/visual_console/render_view.php: Use new functions in include
CSS and javascript files.
* index.php: Bit of style when printing the header so the HTML can be
readed easily in a editor.
* include/javascript/pandora.js: Added a variable to determine the
enterprise directory.
* include/styles/pandora.css: Added style for manage_delete.php
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1467 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-02-19 17:10:04 +01:00
2019-01-30 16:18:44 +01:00
2009-02-19 Esteban Sanchez <estebans@artica.es>
* include/functions_ui.php: Added require_css_file(),
require_javascript_file() and require_jquery_file() to add CSS,
javascript and jQuery files to the header easily without changing
config object. A path parameter is addded to allow the use on
enterprise code.
* include/functions_db.php: Added
get_db_value_filter(), get_db_all_rows_filter() and
process_sql_delete(). Fixed delete_agent() style and use these
functions. Added process_page_head() from functions_ui.php and changed
a bit the config javascript object part.
* include/functions_custom_graphs.php: Get results indexed by id on
get_user_custom_graphs().
* include/functions.php: Moved process_page_head to functions_ui.php.
* godmode/agentes/manage_delete.php: New interface to perform massive
agents deletion.
* godmode/menu.php: Added new option to massive agents deletion.
* general/main_menu.php, godmode/agentes/manage_config.php,
godmode/agentes/module_manager_editor.php,
godmode/agentes/planned_downtime.php,
godmode/alerts/alert_compounds.php, godmode/alerts/alert_list.php,
godmode/alerts/configure_alert_compound.php,
godmode/alerts/configure_alert_template.php,
godmode/reporting/map_builder.php, operation/agentes/networkmap.php,
operation/reporting/reporting_viewer.php,
operation/visual_console/render_view.php: Use new functions in include
CSS and javascript files.
* index.php: Bit of style when printing the header so the HTML can be
readed easily in a editor.
* include/javascript/pandora.js: Added a variable to determine the
enterprise directory.
* include/styles/pandora.css: Added style for manage_delete.php
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1467 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-02-19 17:10:04 +01:00
/**
* Add a CSS file to the HTML head tag .
*
* To make a CSS file available just put it in include / styles . The
* file name should be like " name.css " . The " name " would be the value
* needed to pass to this function .
2019-01-30 16:18:44 +01:00
*
2019-05-28 10:47:31 +02:00
* @ param string $name Script name to add without the " jquery. " prefix and the " .js "
2009-02-19 Esteban Sanchez <estebans@artica.es>
* include/functions_ui.php: Added require_css_file(),
require_javascript_file() and require_jquery_file() to add CSS,
javascript and jQuery files to the header easily without changing
config object. A path parameter is addded to allow the use on
enterprise code.
* include/functions_db.php: Added
get_db_value_filter(), get_db_all_rows_filter() and
process_sql_delete(). Fixed delete_agent() style and use these
functions. Added process_page_head() from functions_ui.php and changed
a bit the config javascript object part.
* include/functions_custom_graphs.php: Get results indexed by id on
get_user_custom_graphs().
* include/functions.php: Moved process_page_head to functions_ui.php.
* godmode/agentes/manage_delete.php: New interface to perform massive
agents deletion.
* godmode/menu.php: Added new option to massive agents deletion.
* general/main_menu.php, godmode/agentes/manage_config.php,
godmode/agentes/module_manager_editor.php,
godmode/agentes/planned_downtime.php,
godmode/alerts/alert_compounds.php, godmode/alerts/alert_list.php,
godmode/alerts/configure_alert_compound.php,
godmode/alerts/configure_alert_template.php,
godmode/reporting/map_builder.php, operation/agentes/networkmap.php,
operation/reporting/reporting_viewer.php,
operation/visual_console/render_view.php: Use new functions in include
CSS and javascript files.
* index.php: Bit of style when printing the header so the HTML can be
readed easily in a editor.
* include/javascript/pandora.js: Added a variable to determine the
enterprise directory.
* include/styles/pandora.css: Added style for manage_delete.php
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1467 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-02-19 17:10:04 +01:00
* suffix . Example :
2011-04-13 18:11:02 +02:00
* < code >
* ui_require_css_file ( 'pandora' );
* // Would include include/styles/pandora.js
2019-05-28 10:47:31 +02:00
* </ code >.
* @ param string $path Path where script is placed .
2009-02-19 Esteban Sanchez <estebans@artica.es>
* include/functions_ui.php: Added require_css_file(),
require_javascript_file() and require_jquery_file() to add CSS,
javascript and jQuery files to the header easily without changing
config object. A path parameter is addded to allow the use on
enterprise code.
* include/functions_db.php: Added
get_db_value_filter(), get_db_all_rows_filter() and
process_sql_delete(). Fixed delete_agent() style and use these
functions. Added process_page_head() from functions_ui.php and changed
a bit the config javascript object part.
* include/functions_custom_graphs.php: Get results indexed by id on
get_user_custom_graphs().
* include/functions.php: Moved process_page_head to functions_ui.php.
* godmode/agentes/manage_delete.php: New interface to perform massive
agents deletion.
* godmode/menu.php: Added new option to massive agents deletion.
* general/main_menu.php, godmode/agentes/manage_config.php,
godmode/agentes/module_manager_editor.php,
godmode/agentes/planned_downtime.php,
godmode/alerts/alert_compounds.php, godmode/alerts/alert_list.php,
godmode/alerts/configure_alert_compound.php,
godmode/alerts/configure_alert_template.php,
godmode/reporting/map_builder.php, operation/agentes/networkmap.php,
operation/reporting/reporting_viewer.php,
operation/visual_console/render_view.php: Use new functions in include
CSS and javascript files.
* index.php: Bit of style when printing the header so the HTML can be
readed easily in a editor.
* include/javascript/pandora.js: Added a variable to determine the
enterprise directory.
* include/styles/pandora.css: Added style for manage_delete.php
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1467 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-02-19 17:10:04 +01:00
*
2019-01-30 16:18:44 +01:00
* @ return boolean True if the file was added . False if the file doesn ' t exist .
2009-02-19 Esteban Sanchez <estebans@artica.es>
* include/functions_ui.php: Added require_css_file(),
require_javascript_file() and require_jquery_file() to add CSS,
javascript and jQuery files to the header easily without changing
config object. A path parameter is addded to allow the use on
enterprise code.
* include/functions_db.php: Added
get_db_value_filter(), get_db_all_rows_filter() and
process_sql_delete(). Fixed delete_agent() style and use these
functions. Added process_page_head() from functions_ui.php and changed
a bit the config javascript object part.
* include/functions_custom_graphs.php: Get results indexed by id on
get_user_custom_graphs().
* include/functions.php: Moved process_page_head to functions_ui.php.
* godmode/agentes/manage_delete.php: New interface to perform massive
agents deletion.
* godmode/menu.php: Added new option to massive agents deletion.
* general/main_menu.php, godmode/agentes/manage_config.php,
godmode/agentes/module_manager_editor.php,
godmode/agentes/planned_downtime.php,
godmode/alerts/alert_compounds.php, godmode/alerts/alert_list.php,
godmode/alerts/configure_alert_compound.php,
godmode/alerts/configure_alert_template.php,
godmode/reporting/map_builder.php, operation/agentes/networkmap.php,
operation/reporting/reporting_viewer.php,
operation/visual_console/render_view.php: Use new functions in include
CSS and javascript files.
* index.php: Bit of style when printing the header so the HTML can be
readed easily in a editor.
* include/javascript/pandora.js: Added a variable to determine the
enterprise directory.
* include/styles/pandora.css: Added style for manage_delete.php
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1467 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-02-19 17:10:04 +01:00
*/
2023-11-16 13:17:25 +01:00
function ui_require_css_file ( $name , $path = 'include/styles/' , $echo_tag = false , $return = false )
2019-01-30 16:18:44 +01:00
{
global $config ;
$filename = $path . $name . '.css' ;
2020-03-26 12:29:38 +01:00
if ( $echo_tag === true ) {
2023-11-16 13:17:25 +01:00
$filename .= '?v=' . $config [ 'current_package' ];
$tag_name = '<link type="text/css" rel="stylesheet" href="' . ui_get_full_url ( $filename , false , false , false ) . '">' ;
if ( $return === false ) {
echo $tag_name ;
return null ;
} else {
return $tag_name ;
}
2020-03-26 12:29:38 +01:00
}
2019-01-30 16:18:44 +01:00
if ( ! isset ( $config [ 'css' ])) {
$config [ 'css' ] = [];
}
if ( isset ( $config [ 'css' ][ $name ])) {
return true ;
}
if ( ! file_exists ( $filename )
&& ! file_exists ( $config [ 'homedir' ] . '/' . $filename )
2019-06-18 19:17:21 +02:00
&& ! file_exists ( $config [ 'homedir' ] . '/' . ENTERPRISE_DIR . '/' . $filename )
2019-01-30 16:18:44 +01:00
) {
return false ;
}
2021-05-07 10:50:25 +02:00
if ( is_metaconsole ()
&& ( isset ( $config [ 'requirements_use_base_url' ]) === false
|| $config [ 'requirements_use_base_url' ] === false )
) {
2019-06-18 19:17:21 +02:00
$config [ 'css' ][ $name ] = '/../../' . $filename ;
} else {
$config [ 'css' ][ $name ] = $filename ;
}
2019-01-30 16:18:44 +01:00
return true ;
2009-02-19 Esteban Sanchez <estebans@artica.es>
* include/functions_ui.php: Added require_css_file(),
require_javascript_file() and require_jquery_file() to add CSS,
javascript and jQuery files to the header easily without changing
config object. A path parameter is addded to allow the use on
enterprise code.
* include/functions_db.php: Added
get_db_value_filter(), get_db_all_rows_filter() and
process_sql_delete(). Fixed delete_agent() style and use these
functions. Added process_page_head() from functions_ui.php and changed
a bit the config javascript object part.
* include/functions_custom_graphs.php: Get results indexed by id on
get_user_custom_graphs().
* include/functions.php: Moved process_page_head to functions_ui.php.
* godmode/agentes/manage_delete.php: New interface to perform massive
agents deletion.
* godmode/menu.php: Added new option to massive agents deletion.
* general/main_menu.php, godmode/agentes/manage_config.php,
godmode/agentes/module_manager_editor.php,
godmode/agentes/planned_downtime.php,
godmode/alerts/alert_compounds.php, godmode/alerts/alert_list.php,
godmode/alerts/configure_alert_compound.php,
godmode/alerts/configure_alert_template.php,
godmode/reporting/map_builder.php, operation/agentes/networkmap.php,
operation/reporting/reporting_viewer.php,
operation/visual_console/render_view.php: Use new functions in include
CSS and javascript files.
* index.php: Bit of style when printing the header so the HTML can be
readed easily in a editor.
* include/javascript/pandora.js: Added a variable to determine the
enterprise directory.
* include/styles/pandora.css: Added style for manage_delete.php
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1467 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-02-19 17:10:04 +01:00
}
2019-01-30 16:18:44 +01:00
2009-02-19 Esteban Sanchez <estebans@artica.es>
* include/functions_ui.php: Added require_css_file(),
require_javascript_file() and require_jquery_file() to add CSS,
javascript and jQuery files to the header easily without changing
config object. A path parameter is addded to allow the use on
enterprise code.
* include/functions_db.php: Added
get_db_value_filter(), get_db_all_rows_filter() and
process_sql_delete(). Fixed delete_agent() style and use these
functions. Added process_page_head() from functions_ui.php and changed
a bit the config javascript object part.
* include/functions_custom_graphs.php: Get results indexed by id on
get_user_custom_graphs().
* include/functions.php: Moved process_page_head to functions_ui.php.
* godmode/agentes/manage_delete.php: New interface to perform massive
agents deletion.
* godmode/menu.php: Added new option to massive agents deletion.
* general/main_menu.php, godmode/agentes/manage_config.php,
godmode/agentes/module_manager_editor.php,
godmode/agentes/planned_downtime.php,
godmode/alerts/alert_compounds.php, godmode/alerts/alert_list.php,
godmode/alerts/configure_alert_compound.php,
godmode/alerts/configure_alert_template.php,
godmode/reporting/map_builder.php, operation/agentes/networkmap.php,
operation/reporting/reporting_viewer.php,
operation/visual_console/render_view.php: Use new functions in include
CSS and javascript files.
* index.php: Bit of style when printing the header so the HTML can be
readed easily in a editor.
* include/javascript/pandora.js: Added a variable to determine the
enterprise directory.
* include/styles/pandora.css: Added style for manage_delete.php
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1467 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-02-19 17:10:04 +01:00
/**
* Add a javascript file to the HTML head tag .
*
* To make a javascript file available just put it in include / javascript . The
* file name should be like " name.js " . The " name " would be the value
* needed to pass to this function .
2019-01-30 16:18:44 +01:00
*
2019-05-28 10:47:31 +02:00
* @ param string $name Script name to add without the " jquery. " prefix and the " .js "
* suffix . Example :
* < code >
* ui_require_javascript_file ( 'pandora' );
* // Would include include/javascript/pandora.js
* </ code >.
* @ param string $path Path where script is placed .
* @ param boolean $echo_tag Just echo the script tag of the file .
2009-02-19 Esteban Sanchez <estebans@artica.es>
* include/functions_ui.php: Added require_css_file(),
require_javascript_file() and require_jquery_file() to add CSS,
javascript and jQuery files to the header easily without changing
config object. A path parameter is addded to allow the use on
enterprise code.
* include/functions_db.php: Added
get_db_value_filter(), get_db_all_rows_filter() and
process_sql_delete(). Fixed delete_agent() style and use these
functions. Added process_page_head() from functions_ui.php and changed
a bit the config javascript object part.
* include/functions_custom_graphs.php: Get results indexed by id on
get_user_custom_graphs().
* include/functions.php: Moved process_page_head to functions_ui.php.
* godmode/agentes/manage_delete.php: New interface to perform massive
agents deletion.
* godmode/menu.php: Added new option to massive agents deletion.
* general/main_menu.php, godmode/agentes/manage_config.php,
godmode/agentes/module_manager_editor.php,
godmode/agentes/planned_downtime.php,
godmode/alerts/alert_compounds.php, godmode/alerts/alert_list.php,
godmode/alerts/configure_alert_compound.php,
godmode/alerts/configure_alert_template.php,
godmode/reporting/map_builder.php, operation/agentes/networkmap.php,
operation/reporting/reporting_viewer.php,
operation/visual_console/render_view.php: Use new functions in include
CSS and javascript files.
* index.php: Bit of style when printing the header so the HTML can be
readed easily in a editor.
* include/javascript/pandora.js: Added a variable to determine the
enterprise directory.
* include/styles/pandora.css: Added style for manage_delete.php
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1467 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-02-19 17:10:04 +01:00
*
2019-01-30 16:18:44 +01:00
* @ return boolean True if the file was added . False if the file doesn ' t exist .
2009-02-19 Esteban Sanchez <estebans@artica.es>
* include/functions_ui.php: Added require_css_file(),
require_javascript_file() and require_jquery_file() to add CSS,
javascript and jQuery files to the header easily without changing
config object. A path parameter is addded to allow the use on
enterprise code.
* include/functions_db.php: Added
get_db_value_filter(), get_db_all_rows_filter() and
process_sql_delete(). Fixed delete_agent() style and use these
functions. Added process_page_head() from functions_ui.php and changed
a bit the config javascript object part.
* include/functions_custom_graphs.php: Get results indexed by id on
get_user_custom_graphs().
* include/functions.php: Moved process_page_head to functions_ui.php.
* godmode/agentes/manage_delete.php: New interface to perform massive
agents deletion.
* godmode/menu.php: Added new option to massive agents deletion.
* general/main_menu.php, godmode/agentes/manage_config.php,
godmode/agentes/module_manager_editor.php,
godmode/agentes/planned_downtime.php,
godmode/alerts/alert_compounds.php, godmode/alerts/alert_list.php,
godmode/alerts/configure_alert_compound.php,
godmode/alerts/configure_alert_template.php,
godmode/reporting/map_builder.php, operation/agentes/networkmap.php,
operation/reporting/reporting_viewer.php,
operation/visual_console/render_view.php: Use new functions in include
CSS and javascript files.
* index.php: Bit of style when printing the header so the HTML can be
readed easily in a editor.
* include/javascript/pandora.js: Added a variable to determine the
enterprise directory.
* include/styles/pandora.css: Added style for manage_delete.php
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1467 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-02-19 17:10:04 +01:00
*/
2023-11-16 13:17:25 +01:00
function ui_require_javascript_file ( $name , $path = 'include/javascript/' , $echo_tag = false , $return = false )
2019-01-30 16:18:44 +01:00
{
global $config ;
$filename = $path . $name . '.js' ;
2023-11-16 13:17:25 +01:00
if ( $echo_tag === true ) {
$filename .= '?v=' . $config [ 'current_package' ];
$tag_name = '<script type="text/javascript" src="' . ui_get_full_url ( $filename , false , false , false ) . '"></script>' ;
if ( $return === false ) {
echo $tag_name ;
return null ;
} else {
return $tag_name ;
}
2019-01-30 16:18:44 +01:00
}
if ( ! isset ( $config [ 'js' ])) {
$config [ 'js' ] = [];
}
if ( isset ( $config [ 'js' ][ $name ])) {
return true ;
}
2019-05-28 10:47:31 +02:00
// We checks two paths because it may fails on enterprise.
2019-01-30 16:18:44 +01:00
if ( ! file_exists ( $filename ) && ! file_exists ( $config [ 'homedir' ] . '/' . $filename )) {
return false ;
}
2021-05-07 10:50:25 +02:00
if ( is_metaconsole ()
&& ( isset ( $config [ 'requirements_use_base_url' ]) === false
|| $config [ 'requirements_use_base_url' ] === false )
) {
2019-01-30 16:18:44 +01:00
$config [ 'js' ][ $name ] = '../../' . $filename ;
} else {
$config [ 'js' ][ $name ] = $filename ;
}
return true ;
2012-07-03 Miguel de Dios <miguel.dedios@artica.es>
* ajax.php: added support for the enterprise, because some case
this file can't call enterprise functions.
* godmode/reporting/visual_console_builder.wizard.php,
godmode/reporting/visual_console_builder.php,
godmode/reporting/visual_console_builder.editor.js,
godmode/reporting/visual_console_builder.elements.php,
godmode/reporting/visual_console_builder.editor.php,
godmode/reporting/visual_console_builder.constans.php (delete),
include/functions_visual_map_editor.php,
include/ajax/visual_console_builder.ajax.php,
include/functions_visual_map.php: some parts of code had been
refactored because it is necesary for to add enterprise feature to
Visual map.
* include/constants.php: cleaned source code style and added and
reordened the constants for visual maps.
* include/functions_html.php, include/styles/pandora.css,
include/functions_ui.php, include/functions.php, index.php: cleaned
source code style.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6732 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-07-03 17:39:37 +02:00
}
2019-01-30 16:18:44 +01:00
2012-07-03 Miguel de Dios <miguel.dedios@artica.es>
* ajax.php: added support for the enterprise, because some case
this file can't call enterprise functions.
* godmode/reporting/visual_console_builder.wizard.php,
godmode/reporting/visual_console_builder.php,
godmode/reporting/visual_console_builder.editor.js,
godmode/reporting/visual_console_builder.elements.php,
godmode/reporting/visual_console_builder.editor.php,
godmode/reporting/visual_console_builder.constans.php (delete),
include/functions_visual_map_editor.php,
include/ajax/visual_console_builder.ajax.php,
include/functions_visual_map.php: some parts of code had been
refactored because it is necesary for to add enterprise feature to
Visual map.
* include/constants.php: cleaned source code style and added and
reordened the constants for visual maps.
* include/functions_html.php, include/styles/pandora.css,
include/functions_ui.php, include/functions.php, index.php: cleaned
source code style.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6732 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-07-03 17:39:37 +02:00
/**
* Add a enteprise javascript file to the HTML head tag .
*
2019-11-25 13:03:55 +01:00
* * THIS FUNCTION COULD PRODUCE ISSUES WHILE INCLUDING JS FILES .
* * USE ui_require_javascript_file ( 'file' , ENTERPRISE_DIR . '/location' ) INSTEAD .
*
2012-07-03 Miguel de Dios <miguel.dedios@artica.es>
* ajax.php: added support for the enterprise, because some case
this file can't call enterprise functions.
* godmode/reporting/visual_console_builder.wizard.php,
godmode/reporting/visual_console_builder.php,
godmode/reporting/visual_console_builder.editor.js,
godmode/reporting/visual_console_builder.elements.php,
godmode/reporting/visual_console_builder.editor.php,
godmode/reporting/visual_console_builder.constans.php (delete),
include/functions_visual_map_editor.php,
include/ajax/visual_console_builder.ajax.php,
include/functions_visual_map.php: some parts of code had been
refactored because it is necesary for to add enterprise feature to
Visual map.
* include/constants.php: cleaned source code style and added and
reordened the constants for visual maps.
* include/functions_html.php, include/styles/pandora.css,
include/functions_ui.php, include/functions.php, index.php: cleaned
source code style.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6732 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-07-03 17:39:37 +02:00
* To make a javascript file available just put it in < ENTERPRISE_DIR >/ include / javascript . The
* file name should be like " name.js " . The " name " would be the value
* needed to pass to this function .
2019-01-30 16:18:44 +01:00
*
2019-05-28 10:47:31 +02:00
* @ param string $name Script name to add without the " jquery. "
* prefix and the " .js "
* suffix . Example :
* < code >
* ui_require_javascript_file ( 'pandora' );
* // Would include include/javascript/pandora.js
* </ code >.
* @ param boolean $disabled_metaconsole Disabled metaconsole .
2012-07-03 Miguel de Dios <miguel.dedios@artica.es>
* ajax.php: added support for the enterprise, because some case
this file can't call enterprise functions.
* godmode/reporting/visual_console_builder.wizard.php,
godmode/reporting/visual_console_builder.php,
godmode/reporting/visual_console_builder.editor.js,
godmode/reporting/visual_console_builder.elements.php,
godmode/reporting/visual_console_builder.editor.php,
godmode/reporting/visual_console_builder.constans.php (delete),
include/functions_visual_map_editor.php,
include/ajax/visual_console_builder.ajax.php,
include/functions_visual_map.php: some parts of code had been
refactored because it is necesary for to add enterprise feature to
Visual map.
* include/constants.php: cleaned source code style and added and
reordened the constants for visual maps.
* include/functions_html.php, include/styles/pandora.css,
include/functions_ui.php, include/functions.php, index.php: cleaned
source code style.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6732 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-07-03 17:39:37 +02:00
*
2019-01-30 16:18:44 +01:00
* @ return boolean True if the file was added . False if the file doesn ' t exist .
2012-07-03 Miguel de Dios <miguel.dedios@artica.es>
* ajax.php: added support for the enterprise, because some case
this file can't call enterprise functions.
* godmode/reporting/visual_console_builder.wizard.php,
godmode/reporting/visual_console_builder.php,
godmode/reporting/visual_console_builder.editor.js,
godmode/reporting/visual_console_builder.elements.php,
godmode/reporting/visual_console_builder.editor.php,
godmode/reporting/visual_console_builder.constans.php (delete),
include/functions_visual_map_editor.php,
include/ajax/visual_console_builder.ajax.php,
include/functions_visual_map.php: some parts of code had been
refactored because it is necesary for to add enterprise feature to
Visual map.
* include/constants.php: cleaned source code style and added and
reordened the constants for visual maps.
* include/functions_html.php, include/styles/pandora.css,
include/functions_ui.php, include/functions.php, index.php: cleaned
source code style.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6732 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-07-03 17:39:37 +02:00
*/
2019-01-30 16:18:44 +01:00
function ui_require_javascript_file_enterprise ( $name , $disabled_metaconsole = false )
{
global $config ;
$metaconsole_hack = '' ;
if ( $disabled_metaconsole ) {
$metaconsole_hack = '../../' ;
}
$filename = $metaconsole_hack . ENTERPRISE_DIR . '/include/javascript/' . $name . '.js' ;
if ( ! isset ( $config [ 'js' ])) {
$config [ 'js' ] = [];
}
if ( isset ( $config [ 'js' ][ $name ])) {
return true ;
}
2019-05-28 10:47:31 +02:00
// We checks two paths because it may fails on enterprise.
2019-01-30 16:18:44 +01:00
if ( ! file_exists ( $filename )
&& ! file_exists ( $config [ 'homedir' ] . '/' . $filename )
) {
return false ;
}
$config [ 'js' ][ $name ] = $filename ;
return true ;
2009-02-19 Esteban Sanchez <estebans@artica.es>
* include/functions_ui.php: Added require_css_file(),
require_javascript_file() and require_jquery_file() to add CSS,
javascript and jQuery files to the header easily without changing
config object. A path parameter is addded to allow the use on
enterprise code.
* include/functions_db.php: Added
get_db_value_filter(), get_db_all_rows_filter() and
process_sql_delete(). Fixed delete_agent() style and use these
functions. Added process_page_head() from functions_ui.php and changed
a bit the config javascript object part.
* include/functions_custom_graphs.php: Get results indexed by id on
get_user_custom_graphs().
* include/functions.php: Moved process_page_head to functions_ui.php.
* godmode/agentes/manage_delete.php: New interface to perform massive
agents deletion.
* godmode/menu.php: Added new option to massive agents deletion.
* general/main_menu.php, godmode/agentes/manage_config.php,
godmode/agentes/module_manager_editor.php,
godmode/agentes/planned_downtime.php,
godmode/alerts/alert_compounds.php, godmode/alerts/alert_list.php,
godmode/alerts/configure_alert_compound.php,
godmode/alerts/configure_alert_template.php,
godmode/reporting/map_builder.php, operation/agentes/networkmap.php,
operation/reporting/reporting_viewer.php,
operation/visual_console/render_view.php: Use new functions in include
CSS and javascript files.
* index.php: Bit of style when printing the header so the HTML can be
readed easily in a editor.
* include/javascript/pandora.js: Added a variable to determine the
enterprise directory.
* include/styles/pandora.css: Added style for manage_delete.php
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1467 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-02-19 17:10:04 +01:00
}
2019-01-30 16:18:44 +01:00
2009-02-19 Esteban Sanchez <estebans@artica.es>
* include/functions_ui.php: Added require_css_file(),
require_javascript_file() and require_jquery_file() to add CSS,
javascript and jQuery files to the header easily without changing
config object. A path parameter is addded to allow the use on
enterprise code.
* include/functions_db.php: Added
get_db_value_filter(), get_db_all_rows_filter() and
process_sql_delete(). Fixed delete_agent() style and use these
functions. Added process_page_head() from functions_ui.php and changed
a bit the config javascript object part.
* include/functions_custom_graphs.php: Get results indexed by id on
get_user_custom_graphs().
* include/functions.php: Moved process_page_head to functions_ui.php.
* godmode/agentes/manage_delete.php: New interface to perform massive
agents deletion.
* godmode/menu.php: Added new option to massive agents deletion.
* general/main_menu.php, godmode/agentes/manage_config.php,
godmode/agentes/module_manager_editor.php,
godmode/agentes/planned_downtime.php,
godmode/alerts/alert_compounds.php, godmode/alerts/alert_list.php,
godmode/alerts/configure_alert_compound.php,
godmode/alerts/configure_alert_template.php,
godmode/reporting/map_builder.php, operation/agentes/networkmap.php,
operation/reporting/reporting_viewer.php,
operation/visual_console/render_view.php: Use new functions in include
CSS and javascript files.
* index.php: Bit of style when printing the header so the HTML can be
readed easily in a editor.
* include/javascript/pandora.js: Added a variable to determine the
enterprise directory.
* include/styles/pandora.css: Added style for manage_delete.php
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1467 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-02-19 17:10:04 +01:00
/**
* Add a jQuery file to the HTML head tag .
*
* To make a jQuery script available just put it in include / javascript . The
* file name should be like " jquery.name.js " . The " name " would be the value
* needed to pass to this function . Notice that this function does not manage
* jQuery denpendencies .
2019-01-30 16:18:44 +01:00
*
2019-05-28 10:47:31 +02:00
* @ param string $name Script name to add without the " jquery. " prefix and the " .js "
* suffix . Example :
* < code >
* ui_require_jquery_file ( 'form' );
* // Would include include/javascript/jquery.form.js
* </ code >.
* @ param string $path Path where script is placed .
* @ param boolean $echo_tag Just echo the script tag of the file .
2009-02-19 Esteban Sanchez <estebans@artica.es>
* include/functions_ui.php: Added require_css_file(),
require_javascript_file() and require_jquery_file() to add CSS,
javascript and jQuery files to the header easily without changing
config object. A path parameter is addded to allow the use on
enterprise code.
* include/functions_db.php: Added
get_db_value_filter(), get_db_all_rows_filter() and
process_sql_delete(). Fixed delete_agent() style and use these
functions. Added process_page_head() from functions_ui.php and changed
a bit the config javascript object part.
* include/functions_custom_graphs.php: Get results indexed by id on
get_user_custom_graphs().
* include/functions.php: Moved process_page_head to functions_ui.php.
* godmode/agentes/manage_delete.php: New interface to perform massive
agents deletion.
* godmode/menu.php: Added new option to massive agents deletion.
* general/main_menu.php, godmode/agentes/manage_config.php,
godmode/agentes/module_manager_editor.php,
godmode/agentes/planned_downtime.php,
godmode/alerts/alert_compounds.php, godmode/alerts/alert_list.php,
godmode/alerts/configure_alert_compound.php,
godmode/alerts/configure_alert_template.php,
godmode/reporting/map_builder.php, operation/agentes/networkmap.php,
operation/reporting/reporting_viewer.php,
operation/visual_console/render_view.php: Use new functions in include
CSS and javascript files.
* index.php: Bit of style when printing the header so the HTML can be
readed easily in a editor.
* include/javascript/pandora.js: Added a variable to determine the
enterprise directory.
* include/styles/pandora.css: Added style for manage_delete.php
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1467 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-02-19 17:10:04 +01:00
*
2019-01-30 16:18:44 +01:00
* @ return boolean True if the file was added . False if the file doesn ' t exist .
2009-02-19 Esteban Sanchez <estebans@artica.es>
* include/functions_ui.php: Added require_css_file(),
require_javascript_file() and require_jquery_file() to add CSS,
javascript and jQuery files to the header easily without changing
config object. A path parameter is addded to allow the use on
enterprise code.
* include/functions_db.php: Added
get_db_value_filter(), get_db_all_rows_filter() and
process_sql_delete(). Fixed delete_agent() style and use these
functions. Added process_page_head() from functions_ui.php and changed
a bit the config javascript object part.
* include/functions_custom_graphs.php: Get results indexed by id on
get_user_custom_graphs().
* include/functions.php: Moved process_page_head to functions_ui.php.
* godmode/agentes/manage_delete.php: New interface to perform massive
agents deletion.
* godmode/menu.php: Added new option to massive agents deletion.
* general/main_menu.php, godmode/agentes/manage_config.php,
godmode/agentes/module_manager_editor.php,
godmode/agentes/planned_downtime.php,
godmode/alerts/alert_compounds.php, godmode/alerts/alert_list.php,
godmode/alerts/configure_alert_compound.php,
godmode/alerts/configure_alert_template.php,
godmode/reporting/map_builder.php, operation/agentes/networkmap.php,
operation/reporting/reporting_viewer.php,
operation/visual_console/render_view.php: Use new functions in include
CSS and javascript files.
* index.php: Bit of style when printing the header so the HTML can be
readed easily in a editor.
* include/javascript/pandora.js: Added a variable to determine the
enterprise directory.
* include/styles/pandora.css: Added style for manage_delete.php
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1467 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-02-19 17:10:04 +01:00
*/
2019-01-30 16:18:44 +01:00
function ui_require_jquery_file ( $name , $path = 'include/javascript/' , $echo_tag = false )
{
global $config ;
$filename = $path . 'jquery.' . $name . '.js' ;
if ( $echo_tag ) {
echo '<script type="text/javascript" src="' . ui_get_full_url ( false , false , false , false ) . $filename . '"></script>' ;
2019-05-28 10:47:31 +02:00
return null ;
2019-01-30 16:18:44 +01:00
}
if ( ! isset ( $config [ 'jquery' ])) {
$config [ 'jquery' ] = [];
}
if ( isset ( $config [ 'jquery' ][ $name ])) {
return true ;
}
2019-05-28 10:47:31 +02:00
// We checks two paths because it may fails on enterprise.
if ( ! file_exists ( $filename )
&& ! file_exists ( $config [ 'homedir' ] . '/' . $filename )
) {
2019-01-30 16:18:44 +01:00
return false ;
}
$config [ 'jquery' ][ $name ] = $filename ;
return true ;
2009-02-19 Esteban Sanchez <estebans@artica.es>
* include/functions_ui.php: Added require_css_file(),
require_javascript_file() and require_jquery_file() to add CSS,
javascript and jQuery files to the header easily without changing
config object. A path parameter is addded to allow the use on
enterprise code.
* include/functions_db.php: Added
get_db_value_filter(), get_db_all_rows_filter() and
process_sql_delete(). Fixed delete_agent() style and use these
functions. Added process_page_head() from functions_ui.php and changed
a bit the config javascript object part.
* include/functions_custom_graphs.php: Get results indexed by id on
get_user_custom_graphs().
* include/functions.php: Moved process_page_head to functions_ui.php.
* godmode/agentes/manage_delete.php: New interface to perform massive
agents deletion.
* godmode/menu.php: Added new option to massive agents deletion.
* general/main_menu.php, godmode/agentes/manage_config.php,
godmode/agentes/module_manager_editor.php,
godmode/agentes/planned_downtime.php,
godmode/alerts/alert_compounds.php, godmode/alerts/alert_list.php,
godmode/alerts/configure_alert_compound.php,
godmode/alerts/configure_alert_template.php,
godmode/reporting/map_builder.php, operation/agentes/networkmap.php,
operation/reporting/reporting_viewer.php,
operation/visual_console/render_view.php: Use new functions in include
CSS and javascript files.
* index.php: Bit of style when printing the header so the HTML can be
readed easily in a editor.
* include/javascript/pandora.js: Added a variable to determine the
enterprise directory.
* include/styles/pandora.css: Added style for manage_delete.php
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1467 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-02-19 17:10:04 +01:00
}
2019-01-30 16:18:44 +01:00
2009-02-19 Esteban Sanchez <estebans@artica.es>
* include/functions_ui.php: Added require_css_file(),
require_javascript_file() and require_jquery_file() to add CSS,
javascript and jQuery files to the header easily without changing
config object. A path parameter is addded to allow the use on
enterprise code.
* include/functions_db.php: Added
get_db_value_filter(), get_db_all_rows_filter() and
process_sql_delete(). Fixed delete_agent() style and use these
functions. Added process_page_head() from functions_ui.php and changed
a bit the config javascript object part.
* include/functions_custom_graphs.php: Get results indexed by id on
get_user_custom_graphs().
* include/functions.php: Moved process_page_head to functions_ui.php.
* godmode/agentes/manage_delete.php: New interface to perform massive
agents deletion.
* godmode/menu.php: Added new option to massive agents deletion.
* general/main_menu.php, godmode/agentes/manage_config.php,
godmode/agentes/module_manager_editor.php,
godmode/agentes/planned_downtime.php,
godmode/alerts/alert_compounds.php, godmode/alerts/alert_list.php,
godmode/alerts/configure_alert_compound.php,
godmode/alerts/configure_alert_template.php,
godmode/reporting/map_builder.php, operation/agentes/networkmap.php,
operation/reporting/reporting_viewer.php,
operation/visual_console/render_view.php: Use new functions in include
CSS and javascript files.
* index.php: Bit of style when printing the header so the HTML can be
readed easily in a editor.
* include/javascript/pandora.js: Added a variable to determine the
enterprise directory.
* include/styles/pandora.css: Added style for manage_delete.php
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1467 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-02-19 17:10:04 +01:00
/**
* Callback function to add stuff to the head . This allows us to add scripts
* to the header after the fact as well as extensive validation .
*
* DO NOT CALL print_f , echo , ob_start , ob_flush , ob_end functions here .
*
* To add css just put them in include / styles and then add them to the
* $config [ 'css' ] array
*
2019-05-28 10:47:31 +02:00
* @ param string $string Callback will fill this with the current buffer .
* @ param mixed $bitfield Callback will fill this with a bitfield ( see ob_start ) .
2019-01-30 16:18:44 +01:00
*
2016-03-30 13:05:08 +02:00
* @ return string String to return to the browser
2009-02-19 Esteban Sanchez <estebans@artica.es>
* include/functions_ui.php: Added require_css_file(),
require_javascript_file() and require_jquery_file() to add CSS,
javascript and jQuery files to the header easily without changing
config object. A path parameter is addded to allow the use on
enterprise code.
* include/functions_db.php: Added
get_db_value_filter(), get_db_all_rows_filter() and
process_sql_delete(). Fixed delete_agent() style and use these
functions. Added process_page_head() from functions_ui.php and changed
a bit the config javascript object part.
* include/functions_custom_graphs.php: Get results indexed by id on
get_user_custom_graphs().
* include/functions.php: Moved process_page_head to functions_ui.php.
* godmode/agentes/manage_delete.php: New interface to perform massive
agents deletion.
* godmode/menu.php: Added new option to massive agents deletion.
* general/main_menu.php, godmode/agentes/manage_config.php,
godmode/agentes/module_manager_editor.php,
godmode/agentes/planned_downtime.php,
godmode/alerts/alert_compounds.php, godmode/alerts/alert_list.php,
godmode/alerts/configure_alert_compound.php,
godmode/alerts/configure_alert_template.php,
godmode/reporting/map_builder.php, operation/agentes/networkmap.php,
operation/reporting/reporting_viewer.php,
operation/visual_console/render_view.php: Use new functions in include
CSS and javascript files.
* index.php: Bit of style when printing the header so the HTML can be
readed easily in a editor.
* include/javascript/pandora.js: Added a variable to determine the
enterprise directory.
* include/styles/pandora.css: Added style for manage_delete.php
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1467 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-02-19 17:10:04 +01:00
*/
2019-01-30 16:18:44 +01:00
function ui_process_page_head ( $string , $bitfield )
{
global $config ;
global $vc_public_view ;
if ( isset ( $config [ 'ignore_callback' ]) && $config [ 'ignore_callback' ] == true ) {
2019-05-28 10:47:31 +02:00
return '' ;
2019-01-30 16:18:44 +01:00
}
$output = '' ;
$config_refr = - 1 ;
if ( isset ( $config [ 'refr' ])) {
$config_refr = $config [ 'refr' ];
}
2019-05-28 10:47:31 +02:00
// If user is logged or displayed view is the public view of visual console.
2019-01-30 16:18:44 +01:00
if ( $config_refr > 0
&& ( isset ( $config [ 'id_user' ]) || $vc_public_view == 1 )
) {
if ( $config [ 'enable_refr' ]
|| $_GET [ 'sec2' ] == 'operation/agentes/estado_agente'
|| $_GET [ 'sec2' ] == 'operation/agentes/tactical'
|| $_GET [ 'sec2' ] == 'operation/agentes/group_view'
|| $_GET [ 'sec2' ] == 'operation/events/events'
|| $_GET [ 'sec2' ] == 'operation/snmpconsole/snmp_view'
2020-03-26 12:29:38 +01:00
|| $_GET [ 'sec2' ] == 'operation/dashboard/dashboard'
2019-01-30 16:18:44 +01:00
) {
$query = ui_get_url_refresh ( false , false );
2019-05-28 10:47:31 +02:00
/*
* $output .= '<meta http-equiv="refresh" content="' .
* $config_refr . '; URL=' . $query . '" />' ;
*/
// End.
2019-01-30 16:18:44 +01:00
}
}
2020-01-24 13:52:09 +01:00
$text_subtitle = isset ( $config [ 'rb_product_name_alt' ]) ? '' : ' - ' . __ ( 'the Flexible Monitoring System' );
2019-01-30 16:18:44 +01:00
$output .= " \n \t " ;
2020-01-24 13:52:09 +01:00
$output .= '<title>' . get_product_name () . $text_subtitle . ' </ title >
2014-03-13 12:00:12 +01:00
< meta http - equiv = " expires " content = " never " />
< meta http - equiv = " content-type " content = " text/html; charset=utf-8 " />
< meta http - equiv = " Content-Style-Type " content = " text/css " />
< meta name = " resource-type " content = " document " />
< meta name = " distribution " content = " global " />
2019-01-30 16:18:44 +01:00
< meta name = " author " content = " '.get_copyright_notice().' " />
< meta name = " copyright " content = " (c) '.get_copyright_notice().' " />
2016-09-28 13:26:58 +02:00
< meta name = " robots " content = " index, follow " /> ' ;
2020-07-22 10:56:16 +02:00
$output .= '<link rel="icon" href="' . ui_get_full_url ( '/' ) . ui_get_favicon () . '" type="image/ico" />' ;
$output .= '<link rel="shortcut icon" href="' . ui_get_full_url ( '/' ) . ui_get_favicon () . ' " type= " image / x - icon " />
2014-03-13 12:00:12 +01:00
< link rel = " alternate " href = " operation/events/events_rss.php " title = " Pandora RSS Feed " type = " application/rss+xml " /> ' ;
2019-01-30 16:18:44 +01:00
if ( $config [ 'language' ] != 'en' ) {
2019-05-28 10:47:31 +02:00
// Load translated strings - load them last so they overload all
// the objects.
2019-01-30 16:18:44 +01:00
ui_require_javascript_file ( 'time_' . $config [ 'language' ]);
ui_require_javascript_file ( 'date' . $config [ 'language' ]);
ui_require_javascript_file ( 'countdown_' . $config [ 'language' ]);
}
$output .= " \n \t " ;
2019-05-28 10:47:31 +02:00
/*
* Load CSS
*/
2019-01-30 16:18:44 +01:00
if ( empty ( $config [ 'css' ])) {
$config [ 'css' ] = [];
}
$login_ok = true ;
if ( ! isset ( $config [ 'id_user' ]) && isset ( $_GET [ 'login' ])) {
2019-05-28 10:47:31 +02:00
if ( isset ( $_POST [ 'nick' ]) && isset ( $_POST [ 'pass' ])) {
2019-01-30 16:18:44 +01:00
$nick = get_parameter_post ( 'nick' );
2019-05-28 10:47:31 +02:00
// This is the variable with the login.
2019-01-30 16:18:44 +01:00
$pass = get_parameter_post ( 'pass' );
2019-05-28 10:47:31 +02:00
// This is the variable with the password.
2019-01-30 16:18:44 +01:00
$nick = db_escape_string_sql ( $nick );
$pass = db_escape_string_sql ( $pass );
2019-05-28 10:47:31 +02:00
// Process_user_login is a virtual function which should be defined
// in each auth file.
// It accepts username and password. The rest should be internal to
// the auth file.
// The auth file can set $config["auth_error"] to an informative
// error output or reference their internal error messages to it
// process_user_login should return false in case of errors or
// invalid login, the nickname if correct.
2019-01-30 16:18:44 +01:00
$nick_in_db = process_user_login ( $nick , $pass );
if ( $nick_in_db === false ) {
$login_ok = false ;
}
}
}
// First, if user has assigned a skin then try to use css files of
2019-05-28 10:47:31 +02:00
// skin subdirectory.
2019-01-30 16:18:44 +01:00
$isFunctionSkins = enterprise_include_once ( 'include/functions_skins.php' );
if ( ! $login_ok ) {
if ( $isFunctionSkins !== ENTERPRISE_NOT_HOOK ) {
enterprise_hook ( 'skins_cleanup' );
}
}
$exists_css = false ;
2019-05-28 10:47:31 +02:00
if ( $login_ok && $isFunctionSkins !== ENTERPRISE_NOT_HOOK ) {
// Checks if user's skin is available.
2019-01-30 16:18:44 +01:00
$exists_skin = enterprise_hook ( 'skins_is_path_set' );
if ( $exists_skin ) {
$skin_path = enterprise_hook ( 'skins_get_skin_path' );
$skin_styles = themes_get_css ( $skin_path . 'include/styles/' );
$exists_css = ! empty ( $skin_styles );
}
}
2019-05-28 10:47:31 +02:00
// Add the jquery UI styles CSS.
2019-02-05 09:23:53 +01:00
$config [ 'css' ][ 'jquery-UI' ] = 'include/styles/js/jquery-ui.min.css' ;
2019-06-03 11:55:56 +02:00
$config [ 'css' ][ 'jquery-UI-custom' ] = 'include/styles/js/jquery-ui_custom.css' ;
2019-05-28 10:47:31 +02:00
// Add the dialog styles CSS.
2019-01-30 16:18:44 +01:00
$config [ 'css' ][ 'dialog' ] = 'include/styles/dialog.css' ;
2019-05-28 10:47:31 +02:00
// Add the dialog styles CSS.
2019-02-05 09:23:53 +01:00
$config [ 'css' ][ 'dialog' ] = 'include/styles/js/introjs.css' ;
2019-01-30 16:18:44 +01:00
2019-07-01 16:57:33 +02:00
// If the theme is the default, we don't load it twice.
if ( $config [ 'style' ] !== 'pandora' ) {
// It loads the last of all.
$config [ 'css' ][ 'theme' ] = 'include/styles/' . $config [ 'style' ] . '.css' ;
}
2019-05-28 10:47:31 +02:00
// If skin's css files exists then add them.
2019-01-30 16:18:44 +01:00
if ( $exists_css ) {
foreach ( $skin_styles as $filename => $name ) {
$style = substr ( $filename , 0 , ( strlen ( $filename ) - 4 ));
$config [ 'css' ][ $style ] = $skin_path . 'include/styles/' . $filename ;
}
2019-05-28 10:47:31 +02:00
} else {
// Otherwise assign default and user's css.
// User style should go last so it can rewrite common styles.
2019-01-30 16:18:44 +01:00
$config [ 'css' ] = array_merge (
[
2019-07-01 16:57:33 +02:00
'common' => 'include/styles/common.css' ,
'menu' => 'include/styles/menu.css' ,
'tables' => 'include/styles/tables.css' ,
2021-11-04 16:28:15 +01:00
'general' => 'include/styles/pandora.css' ,
2019-01-30 16:18:44 +01:00
],
$config [ 'css' ]
);
}
2019-05-28 10:47:31 +02:00
// We can't load empty and we loaded (conditionally) ie.
2019-01-30 16:18:44 +01:00
$loaded = [
'' ,
'ie' ,
];
foreach ( $config [ 'css' ] as $name => $filename ) {
if ( in_array ( $name , $loaded )) {
continue ;
}
array_push ( $loaded , $name );
2019-08-21 09:22:13 +02:00
$url_css = ui_get_full_url ( $filename , false , false , false );
2023-03-23 14:43:13 +01:00
$output .= '<link rel="stylesheet" href="' . $url_css . '?v=' . $config [ 'current_package' ] . '" type="text/css" />' . " \n \t " ;
2019-01-30 16:18:44 +01:00
}
2019-05-28 10:47:31 +02:00
/*
* End load CSS
*/
/*
* Load jQuery
*/
2019-01-30 16:18:44 +01:00
if ( empty ( $config [ 'jquery' ])) {
$config [ 'jquery' ] = [];
2019-05-28 10:47:31 +02:00
// If it's empty, false or not init set array to empty just in case.
2019-01-30 16:18:44 +01:00
}
2019-05-28 10:47:31 +02:00
// Pandora specific jquery should go first.
2019-01-30 16:18:44 +01:00
$black_list_pages_old_jquery = [ 'operation/gis_maps/index' ];
if ( in_array ( get_parameter ( 'sec2' ), $black_list_pages_old_jquery )) {
$config [ 'jquery' ] = array_merge (
[
'jquery' => 'include/javascript/jquery.js' ,
'ui' => 'include/javascript/jquery.ui.core.js' ,
'dialog' => 'include/javascript/jquery.ui.dialog.js' ,
'pandora' => 'include/javascript/jquery.pandora.js' ,
],
$config [ 'jquery' ]
);
} else {
$config [ 'jquery' ] = array_merge (
[
2021-08-12 09:30:43 +02:00
'jquery' => 'include/javascript/jquery.current.js' ,
2019-01-30 16:18:44 +01:00
'pandora' => 'include/javascript/jquery.pandora.js' ,
'jquery-ui' => 'include/javascript/jquery-ui.min.js' ,
],
$config [ 'jquery' ]
);
}
2019-05-28 10:47:31 +02:00
// Include the datapicker language if exists.
2019-01-30 16:18:44 +01:00
if ( file_exists ( 'include/languages/datepicker/jquery.ui.datepicker-' . $config [ 'language' ] . '.js' )) {
$config [ 'jquery' ][ 'datepicker_language' ] = 'include/languages/datepicker/jquery.ui.datepicker-' . $config [ 'language' ] . '.js' ;
}
2019-05-28 10:47:31 +02:00
// Include countdown library.
2019-01-30 16:18:44 +01:00
$config [ 'jquery' ][ 'countdown' ] = 'include/javascript/jquery.countdown.js' ;
2019-05-28 10:47:31 +02:00
// Then add each script as necessary.
2019-01-30 16:18:44 +01:00
$loaded = [ '' ];
foreach ( $config [ 'jquery' ] as $name => $filename ) {
if ( in_array ( $name , $loaded )) {
continue ;
}
array_push ( $loaded , $name );
2019-08-21 09:22:13 +02:00
$url_js = ui_get_full_url ( $filename , false , false , false );
2023-03-23 14:43:13 +01:00
$output .= '<script type="text/javascript" src="' . $url_js . '?v=' . $config [ 'current_package' ] . '"></script>' . " \n \t " ;
2019-01-30 16:18:44 +01:00
}
2019-05-28 10:47:31 +02:00
/*
* End load JQuery
*/
2019-06-06 17:50:47 +02:00
/*
* Load JS
*/
if ( empty ( $config [ 'js' ])) {
$config [ 'js' ] = [];
// If it's empty, false or not init set array to empty just in case.
}
// Pandora specific JavaScript should go first.
2019-11-21 16:42:39 +01:00
$config [ 'js' ] = array_merge (
[
'pandora' => 'include/javascript/pandora.js' ,
'pandora_ui' => 'include/javascript/pandora_ui.js' ,
],
$config [ 'js' ]
);
2019-06-06 17:50:47 +02:00
// Load base64 javascript library.
$config [ 'js' ][ 'base64' ] = 'include/javascript/encode_decode_base64.js' ;
// Load qrcode library.
$config [ 'js' ][ 'qrcode' ] = 'include/javascript/qrcode.js' ;
// Load intro.js library (for bubbles and clippy).
$config [ 'js' ][ 'intro' ] = 'include/javascript/intro.js' ;
$config [ 'js' ][ 'clippy' ] = 'include/javascript/clippy.js' ;
// Load Underscore.js library.
$config [ 'js' ][ 'underscore' ] = 'include/javascript/underscore-min.js' ;
// Load other javascript.
// We can't load empty.
$loaded = [ '' ];
foreach ( $config [ 'js' ] as $name => $filename ) {
if ( in_array ( $name , $loaded )) {
continue ;
}
array_push ( $loaded , $name );
2019-08-21 09:22:13 +02:00
$url_js = ui_get_full_url ( $filename , false , false , false );
2023-03-23 14:43:13 +01:00
$output .= '<script type="text/javascript" src="' . $url_js . '?v=' . $config [ 'current_package' ] . '"></script>' . " \n \t " ;
2019-06-06 17:50:47 +02:00
}
/*
* End load JS
*/
2019-01-30 16:18:44 +01:00
include_once __DIR__ . '/graphs/functions_flot.php' ;
$output .= include_javascript_dependencies_flot_graph ( true );
$output .= ' <!-- [ if gte IE 6 ] >
2012-09-06 Miguel de Dios <miguel.dedios@artica.es>
* general/header.php, general/login_page.php,
godmode/setup/setup.php, include/functions_ui.php,
include/functions_graph.php, include/functions_html.php,
include/graphs/fgraph.php, include/graphs/functions_pchart.php,
include/graphs/functions_flot.php, include/functions_reporting.php,
include/functions_visual_map.php, include/functions_config.php,
operation/reporting/reporting_viewer.php,
operation/visual_console/render_view.php,
operation/agentes/tactical.php, operation/menu.php,
operation/events/events.php: added the feature to set a
public url for inverse proxy or for example mod_proxy of Apache.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6936 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-09-06 19:01:22 +02:00
< link rel = " stylesheet " href = " include/styles/ie.css " type = " text/css " />
<! [ endif ] --> ' ;
2018-10-19 11:31:06 +02:00
2019-01-30 16:18:44 +01:00
$output .= $string ;
2018-10-19 11:31:06 +02:00
2019-01-30 16:18:44 +01:00
return $output ;
2009-02-19 Esteban Sanchez <estebans@artica.es>
* include/functions_ui.php: Added require_css_file(),
require_javascript_file() and require_jquery_file() to add CSS,
javascript and jQuery files to the header easily without changing
config object. A path parameter is addded to allow the use on
enterprise code.
* include/functions_db.php: Added
get_db_value_filter(), get_db_all_rows_filter() and
process_sql_delete(). Fixed delete_agent() style and use these
functions. Added process_page_head() from functions_ui.php and changed
a bit the config javascript object part.
* include/functions_custom_graphs.php: Get results indexed by id on
get_user_custom_graphs().
* include/functions.php: Moved process_page_head to functions_ui.php.
* godmode/agentes/manage_delete.php: New interface to perform massive
agents deletion.
* godmode/menu.php: Added new option to massive agents deletion.
* general/main_menu.php, godmode/agentes/manage_config.php,
godmode/agentes/module_manager_editor.php,
godmode/agentes/planned_downtime.php,
godmode/alerts/alert_compounds.php, godmode/alerts/alert_list.php,
godmode/alerts/configure_alert_compound.php,
godmode/alerts/configure_alert_template.php,
godmode/reporting/map_builder.php, operation/agentes/networkmap.php,
operation/reporting/reporting_viewer.php,
operation/visual_console/render_view.php: Use new functions in include
CSS and javascript files.
* index.php: Bit of style when printing the header so the HTML can be
readed easily in a editor.
* include/javascript/pandora.js: Added a variable to determine the
enterprise directory.
* include/styles/pandora.css: Added style for manage_delete.php
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1467 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-02-19 17:10:04 +01:00
}
2019-01-30 16:18:44 +01:00
2009-02-19 Esteban Sanchez <estebans@artica.es>
* include/functions_ui.php: Added require_css_file(),
require_javascript_file() and require_jquery_file() to add CSS,
javascript and jQuery files to the header easily without changing
config object. A path parameter is addded to allow the use on
enterprise code.
* include/functions_db.php: Added
get_db_value_filter(), get_db_all_rows_filter() and
process_sql_delete(). Fixed delete_agent() style and use these
functions. Added process_page_head() from functions_ui.php and changed
a bit the config javascript object part.
* include/functions_custom_graphs.php: Get results indexed by id on
get_user_custom_graphs().
* include/functions.php: Moved process_page_head to functions_ui.php.
* godmode/agentes/manage_delete.php: New interface to perform massive
agents deletion.
* godmode/menu.php: Added new option to massive agents deletion.
* general/main_menu.php, godmode/agentes/manage_config.php,
godmode/agentes/module_manager_editor.php,
godmode/agentes/planned_downtime.php,
godmode/alerts/alert_compounds.php, godmode/alerts/alert_list.php,
godmode/alerts/configure_alert_compound.php,
godmode/alerts/configure_alert_template.php,
godmode/reporting/map_builder.php, operation/agentes/networkmap.php,
operation/reporting/reporting_viewer.php,
operation/visual_console/render_view.php: Use new functions in include
CSS and javascript files.
* index.php: Bit of style when printing the header so the HTML can be
readed easily in a editor.
* include/javascript/pandora.js: Added a variable to determine the
enterprise directory.
* include/styles/pandora.css: Added style for manage_delete.php
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1467 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-02-19 17:10:04 +01:00
/**
* Callback function to add stuff to the body
*
2019-05-28 10:47:31 +02:00
* @ param string $string Callback will fill this with the current buffer .
* @ param mixed $bitfield Callback will fill this with a bitfield ( see ob_start ) .
2019-01-30 16:18:44 +01:00
*
2011-03-02 22:56:48 +01:00
* @ return string String to return to the browser
2009-02-19 Esteban Sanchez <estebans@artica.es>
* include/functions_ui.php: Added require_css_file(),
require_javascript_file() and require_jquery_file() to add CSS,
javascript and jQuery files to the header easily without changing
config object. A path parameter is addded to allow the use on
enterprise code.
* include/functions_db.php: Added
get_db_value_filter(), get_db_all_rows_filter() and
process_sql_delete(). Fixed delete_agent() style and use these
functions. Added process_page_head() from functions_ui.php and changed
a bit the config javascript object part.
* include/functions_custom_graphs.php: Get results indexed by id on
get_user_custom_graphs().
* include/functions.php: Moved process_page_head to functions_ui.php.
* godmode/agentes/manage_delete.php: New interface to perform massive
agents deletion.
* godmode/menu.php: Added new option to massive agents deletion.
* general/main_menu.php, godmode/agentes/manage_config.php,
godmode/agentes/module_manager_editor.php,
godmode/agentes/planned_downtime.php,
godmode/alerts/alert_compounds.php, godmode/alerts/alert_list.php,
godmode/alerts/configure_alert_compound.php,
godmode/alerts/configure_alert_template.php,
godmode/reporting/map_builder.php, operation/agentes/networkmap.php,
operation/reporting/reporting_viewer.php,
operation/visual_console/render_view.php: Use new functions in include
CSS and javascript files.
* index.php: Bit of style when printing the header so the HTML can be
readed easily in a editor.
* include/javascript/pandora.js: Added a variable to determine the
enterprise directory.
* include/styles/pandora.css: Added style for manage_delete.php
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1467 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-02-19 17:10:04 +01:00
*/
2019-01-30 16:18:44 +01:00
function ui_process_page_body ( $string , $bitfield )
{
global $config ;
if ( isset ( $config [ 'ignore_callback' ])
&& $config [ 'ignore_callback' ] == true
) {
2019-05-28 10:47:31 +02:00
return null ;
2019-01-30 16:18:44 +01:00
}
2019-05-28 10:47:31 +02:00
// Show custom background.
$output = '<body' . (( $config [ 'pure' ]) ? ' class="pure"' : '' ) . '>' ;
2019-01-30 16:18:44 +01:00
$output .= $string ;
$output .= '</body>' ;
return $output ;
2009-02-19 Esteban Sanchez <estebans@artica.es>
* include/functions_ui.php: Added require_css_file(),
require_javascript_file() and require_jquery_file() to add CSS,
javascript and jQuery files to the header easily without changing
config object. A path parameter is addded to allow the use on
enterprise code.
* include/functions_db.php: Added
get_db_value_filter(), get_db_all_rows_filter() and
process_sql_delete(). Fixed delete_agent() style and use these
functions. Added process_page_head() from functions_ui.php and changed
a bit the config javascript object part.
* include/functions_custom_graphs.php: Get results indexed by id on
get_user_custom_graphs().
* include/functions.php: Moved process_page_head to functions_ui.php.
* godmode/agentes/manage_delete.php: New interface to perform massive
agents deletion.
* godmode/menu.php: Added new option to massive agents deletion.
* general/main_menu.php, godmode/agentes/manage_config.php,
godmode/agentes/module_manager_editor.php,
godmode/agentes/planned_downtime.php,
godmode/alerts/alert_compounds.php, godmode/alerts/alert_list.php,
godmode/alerts/configure_alert_compound.php,
godmode/alerts/configure_alert_template.php,
godmode/reporting/map_builder.php, operation/agentes/networkmap.php,
operation/reporting/reporting_viewer.php,
operation/visual_console/render_view.php: Use new functions in include
CSS and javascript files.
* index.php: Bit of style when printing the header so the HTML can be
readed easily in a editor.
* include/javascript/pandora.js: Added a variable to determine the
enterprise directory.
* include/styles/pandora.css: Added style for manage_delete.php
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1467 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-02-19 17:10:04 +01:00
}
2009-02-20 22:48:09 +01:00
2019-01-30 16:18:44 +01:00
2016-03-30 13:05:08 +02:00
/**
2009-02-20 22:48:09 +01:00
* Prints a pagination menu to browse into a collection of data .
2019-01-30 16:18:44 +01:00
*
* @ param integer $count Number of elements in the collection .
* @ param string $url URL of the pagination links . It must include all form
* values as GET form .
* @ param integer $offset Current offset for the pagination . Default value would be
2019-05-28 10:47:31 +02:00
* taken from $_REQUEST [ 'offset' ] .
2019-01-30 16:18:44 +01:00
* @ param integer $pagination Current pagination size . If a user requests a larger
2019-05-28 10:47:31 +02:00
* pagination than config [ " block_size " ] .
* @ param boolean $return Whether to return or print this .
2019-01-30 16:18:44 +01:00
* @ param string $offset_name The name of parameter for the offset .
* @ param boolean $print_total_items Show the text with the total items . By default true .
2019-05-28 10:47:31 +02:00
* @ param mixed $other_class Other_class .
* @ param mixed $script Script .
* @ param mixed $parameter_script Parameter_script .
2019-01-30 16:18:44 +01:00
* @ param string $set_id Set id of div .
2009-02-20 22:48:09 +01:00
*
* @ return string The pagination div or nothing if no pagination needs to be done
*/
2019-01-30 16:18:44 +01:00
function ui_pagination (
$count ,
$url = false ,
$offset = 0 ,
$pagination = 0 ,
$return = false ,
$offset_name = 'offset' ,
$print_total_items = true ,
$other_class = '' ,
$script = '' ,
$parameter_script = [
'count' => '' ,
'offset' => 'offset_param' ,
],
$set_id = ''
) {
global $config ;
2023-02-08 17:20:52 +01:00
ui_require_css_file ( 'tables' );
2019-01-30 16:18:44 +01:00
2023-02-08 17:20:52 +01:00
if ( empty ( $pagination ) === true ) {
2019-01-30 16:18:44 +01:00
$pagination = ( int ) $config [ 'block_size' ];
}
2023-02-08 17:20:52 +01:00
if ( is_string ( $offset ) === true ) {
2019-01-30 16:18:44 +01:00
$offset_name = $offset ;
$offset = ( int ) get_parameter ( $offset_name );
}
2023-02-08 17:20:52 +01:00
if ( empty ( $offset ) === true ) {
2019-01-30 16:18:44 +01:00
$offset = ( int ) get_parameter ( $offset_name );
}
2023-02-08 17:20:52 +01:00
if ( empty ( $url ) === true ) {
2019-01-30 16:18:44 +01:00
$url = ui_get_url_refresh ([ $offset_name => false ]);
}
2023-02-08 17:20:52 +01:00
if ( empty ( $set_id ) === false ) {
2019-05-28 10:47:31 +02:00
$set_id = " id = ' " . $set_id . " ' " ;
2019-01-30 16:18:44 +01:00
}
2019-05-28 10:47:31 +02:00
// Pagination links for users include delete, create and other params,
// now not use these params, and not retry the previous action when go to
// pagination link.
2019-01-30 16:18:44 +01:00
$remove = [
'user_del' ,
'disable_user' ,
'delete_user' ,
];
2020-11-23 10:40:28 +01:00
// Check if url has   blankspace and replace it.
preg_replace ( '/\ /' , '%20' , $url );
2019-01-30 16:18:44 +01:00
$url = explode ( '&' , $url );
$finalUrl = [];
foreach ( $url as $key => $value ) {
2019-05-28 10:47:31 +02:00
if ( strpos ( $value , $remove [ 0 ]) === false
&& strpos ( $value , $remove [ 1 ]) === false
&& strpos ( $value , $remove [ 2 ]) === false
) {
2019-01-30 16:18:44 +01:00
array_push ( $finalUrl , $value );
}
}
$url = implode ( '&' , $finalUrl );
/*
URL passed render links with some parameter
& offset - Offset records passed to next page
& counter - Number of items to be blocked
Pagination needs $url to build the base URL to render links , its a base url , like
" http://pandora/index.php?sec=godmode&sec2=godmode/admin_access_logs "
*/
2019-05-28 10:47:31 +02:00
2019-01-30 16:18:44 +01:00
$block_limit = PAGINATION_BLOCKS_LIMIT ;
2019-05-28 10:47:31 +02:00
// Visualize only $block_limit blocks.
2019-01-30 16:18:44 +01:00
if ( $count <= $pagination ) {
if ( $print_total_items ) {
2023-02-08 12:43:08 +01:00
$output = " <div class=' " . $other_class . " ' " . $set_id . '>' ;
2019-05-28 10:47:31 +02:00
// Show the count of items.
2019-03-27 17:03:55 +01:00
$output .= '<div class="total_pages">' . sprintf ( __ ( 'Total items: %s' ), $count ) . '</div>' ;
2019-05-28 10:47:31 +02:00
// End div and layout.
2019-01-30 16:18:44 +01:00
$output .= '</div>' ;
if ( $return === false ) {
echo $output ;
}
return $output ;
}
return false ;
}
$number_of_pages = ceil ( $count / $pagination );
$actual_page = floor ( $offset / $pagination );
$ini_page = ( floor ( $actual_page / $block_limit ) * $block_limit );
$end_page = ( $ini_page + $block_limit - 1 );
2019-07-05 09:31:23 +02:00
if ( $end_page >= $number_of_pages ) {
2019-01-30 16:18:44 +01:00
$end_page = ( $number_of_pages - 1 );
}
2023-02-08 12:43:08 +01:00
$output = " <div class=' " . $other_class . " ' " . $set_id . '>' ;
2019-01-30 16:18:44 +01:00
2019-05-28 10:47:31 +02:00
// Show the count of items.
2019-01-30 16:18:44 +01:00
if ( $print_total_items ) {
2019-03-27 17:03:55 +01:00
$output .= '<div class="total_pages">' . sprintf ( __ ( 'Total items: %s' ), $count ) . '</div>' ;
2019-01-30 16:18:44 +01:00
}
2019-03-27 17:03:55 +01:00
$output .= " <div class='total_number'> " ;
2019-05-28 10:47:31 +02:00
// Show GOTO FIRST PAGE button.
2019-01-30 16:18:44 +01:00
if ( $number_of_pages > $block_limit ) {
2023-02-08 12:43:08 +01:00
if ( empty ( $script ) === false ) {
2019-01-30 16:18:44 +01:00
$script_modified = $script ;
$script_modified = str_replace (
$parameter_script [ 'count' ],
$count ,
$script_modified
);
$script_modified = str_replace (
$parameter_script [ 'offset' ],
0 ,
$script_modified
);
2023-02-08 12:43:08 +01:00
$firstHref = 'javascript: ' . $script_modified . ';' ;
2019-01-30 16:18:44 +01:00
} else {
2023-02-08 12:43:08 +01:00
$firstHref = io_safe_output ( $url ) . '&' . $offset_name . '=0' ;
2019-01-30 16:18:44 +01:00
}
2023-02-08 12:43:08 +01:00
$output .= html_print_anchor (
[
'href' => $firstHref ,
'class' => 'pandora_pagination ' . $other_class . ' offset_0 previous' ,
'content' => __ ( 'First' ),
],
true
);
2019-01-30 16:18:44 +01:00
}
2019-05-28 10:47:31 +02:00
/*
* Show PREVIOUS PAGE GROUP OF PAGES
* For example
* You are in the 12 page with a block of 5 pages
* << < 10 - 11 - [ 12 ] - 13 - 14 > >>
* Click in <
* Result << < 5 - 6 - 7 - 8 - [ 9 ] > >>
*/
2019-01-30 16:18:44 +01:00
if ( $ini_page >= $block_limit ) {
$offset_previous_page = (( $ini_page - 1 ) * $pagination );
if ( ! empty ( $script )) {
$script_modified = $script ;
$script_modified = str_replace (
$parameter_script [ 'count' ],
$count ,
$script_modified
);
$script_modified = str_replace (
$parameter_script [ 'offset' ],
$offset_previous_page ,
$script_modified
);
2023-02-08 12:43:08 +01:00
$previousHref = 'javascript: ' . $script_modified . ';' ;
2019-01-30 16:18:44 +01:00
} else {
2023-02-08 12:43:08 +01:00
$previousHref = io_safe_output ( $url ) . '&' . $offset_name . '=' . $offset_previous_page ;
2019-01-30 16:18:44 +01:00
}
2023-02-08 12:43:08 +01:00
$output .= html_print_anchor (
[
'href' => $previousHref ,
'class' => 'pandora_pagination ' . $other_class . ' offset_' . $offset_previous_page ,
'content' => __ ( 'Previous' ),
],
true
);
2019-01-30 16:18:44 +01:00
}
2019-05-28 10:47:31 +02:00
// Show pages.
2019-01-30 16:18:44 +01:00
for ( $iterator = $ini_page ; $iterator <= $end_page ; $iterator ++ ) {
$actual_page = ( int ) ( $offset / $pagination );
2023-02-08 12:43:08 +01:00
$activePageClass = (( int ) $iterator === ( int ) $actual_page ) ? 'current' : '' ;
2019-01-30 16:18:44 +01:00
$offset_page = ( $iterator * $pagination );
2023-02-08 12:43:08 +01:00
if ( empty ( $script ) === false ) {
2019-01-30 16:18:44 +01:00
$script_modified = $script ;
$script_modified = str_replace (
$parameter_script [ 'count' ],
$count ,
$script_modified
);
$script_modified = str_replace (
$parameter_script [ 'offset' ],
$offset_page ,
$script_modified
);
2023-04-24 09:51:33 +02:00
$anchorHref = 'javascript: ' . $script_modified . ';' ;
2019-01-30 16:18:44 +01:00
} else {
2023-02-08 12:43:08 +01:00
$anchorHref = $url . '&' . $offset_name . '=' . $offset_page ;
2019-01-30 16:18:44 +01:00
}
2023-02-08 12:43:08 +01:00
$output .= html_print_anchor (
[
'href' => $anchorHref ,
'class' => sprintf (
'pandora_pagination %s offset_%s %s' ,
$other_class ,
$offset_page ,
$activePageClass
),
'content' => $iterator ,
],
true
);
2019-01-30 16:18:44 +01:00
}
2019-05-28 10:47:31 +02:00
/*
* Show NEXT PAGE GROUP OF PAGES
* For example
* You are in the 12 page with a block of 5 pages
* << < 10 - 11 - [ 12 ] - 13 - 14 > >>
* Click in >
* Result << < [ 15 ] - 16 - 17 - 18 - 19 > >>
*/
2019-01-30 16:18:44 +01:00
if (( $number_of_pages - $ini_page ) > $block_limit ) {
$offset_next_page = (( $end_page + 1 ) * $pagination );
if ( ! empty ( $script )) {
$script_modified = $script ;
$script_modified = str_replace (
$parameter_script [ 'count' ],
$count ,
$script_modified
);
$script_modified = str_replace (
$parameter_script [ 'offset' ],
$offset_next_page ,
$script_modified
);
2023-04-24 09:51:33 +02:00
$nextHref = 'javascript: ' . $script_modified . ';' ;
2019-01-30 16:18:44 +01:00
} else {
2023-02-08 12:43:08 +01:00
$nextHref = $url . '&' . $offset_name . '=' . $offset_next_page ;
2019-01-30 16:18:44 +01:00
}
2023-02-08 12:43:08 +01:00
$output .= html_print_anchor (
[
'href' => $nextHref ,
'class' => 'pandora_pagination ' . $other_class . ' offset_' . $offset_next_page ,
'content' => __ ( 'Next' ),
],
true
);
2019-01-30 16:18:44 +01:00
}
2019-05-28 10:47:31 +02:00
// Show GOTO LAST PAGE button.
2019-01-30 16:18:44 +01:00
if ( $number_of_pages > $block_limit ) {
$offset_lastpage = (( $number_of_pages - 1 ) * $pagination );
if ( ! empty ( $script )) {
$script_modified = $script ;
$script_modified = str_replace (
$parameter_script [ 'count' ],
$count ,
$script_modified
);
$script_modified = str_replace (
$parameter_script [ 'offset' ],
$offset_lastpage ,
$script_modified
);
2023-04-24 09:51:33 +02:00
$lastHref = 'javascript: ' . $script_modified . ';' ;
2019-01-30 16:18:44 +01:00
} else {
2023-02-08 12:43:08 +01:00
$lastHref = $url . '&' . $offset_name . '=' . $offset_lastpage ;
2019-01-30 16:18:44 +01:00
}
2023-02-08 12:43:08 +01:00
$output .= html_print_anchor (
[
'href' => $lastHref ,
'class' => 'pandora_pagination ' . $other_class . ' offset_' . $offset_lastpage . ' next' ,
'content' => __ ( 'Last' ),
],
true
);
2019-01-30 16:18:44 +01:00
}
2019-03-27 17:03:55 +01:00
$output .= '</div>' ;
2019-01-30 16:18:44 +01:00
// End div and layout
2019-05-28 10:47:31 +02:00
// total_number.
2019-01-30 16:18:44 +01:00
$output .= '</div>' ;
if ( $return === false ) {
echo $output ;
}
return $output ;
2009-02-20 22:48:09 +01:00
}
2019-01-30 16:18:44 +01:00
2016-03-30 13:05:08 +02:00
/**
2013-02-28 12:43:10 +01:00
* Prints only a tip button which shows a text when the user puts the mouse over it .
2019-01-30 16:18:44 +01:00
*
2019-05-28 10:47:31 +02:00
* @ param string $action Complete text to show in the tip .
* @ param boolean $return Whether to return an output string or echo now .
2013-02-28 12:43:10 +01:00
*
* @ return string HTML code if return parameter is true .
*/
2019-01-30 16:18:44 +01:00
function ui_print_session_action_icon ( $action , $return = false )
{
2021-03-11 15:40:23 +01:00
global $config ;
2019-01-30 16:18:44 +01:00
$key_icon = [
2023-03-07 15:59:10 +01:00
'acl' => 'images/delete.svg' ,
'agent' => 'images/agents@svg.svg' ,
'module' => 'images/modules@svg.svg' ,
'alert' => 'images/alerts.svg' ,
'incident' => 'images/logs@svg.svg' ,
'logon' => 'images/house@svg.svg' ,
'logoff' => 'images/house@svg.svg' ,
'massive' => 'images/configuration@svg.svg' ,
'hack' => 'images/custom-input@svg.svg' ,
'event' => 'images/event.svg' ,
'policy' => 'images/policy@svg.svg' ,
'report' => 'images/agent-fields.svg' ,
'file collection' => 'images/file-collection@svg.svg' ,
'user' => 'images/user.svg' ,
'password' => 'images/password.svg' ,
'session' => 'images/star@svg.svg' ,
'snmp' => 'images/SNMP-network-numeric-data@svg.svg' ,
'command' => 'images/external-tools@svg.svg' ,
'category' => 'images/tag@svg.svg' ,
'dashboard' => 'images/workstation@groups.svg' ,
'api' => 'images/enable.svg' ,
'db' => 'images/data-server@svg.svg' ,
'setup' => 'images/configuration@svg.svg' ,
2019-01-30 16:18:44 +01:00
];
$output = '' ;
foreach ( $key_icon as $key => $icon ) {
if ( stristr ( $action , $key ) !== false ) {
2023-03-07 15:59:10 +01:00
$output = html_print_image ( $icon , true , [ 'title' => $action , 'class' => 'main_menu_icon invert_filter' ], false , false , false , true ) . ' ' ;
2019-01-30 16:18:44 +01:00
break ;
}
}
if ( $return ) {
return $output ;
}
echo $output ;
2013-02-28 12:43:10 +01:00
}
2019-01-30 16:18:44 +01:00
2016-03-30 13:05:08 +02:00
/**
2009-02-20 22:48:09 +01:00
* Prints only a tip button which shows a text when the user puts the mouse over it .
2019-01-30 16:18:44 +01:00
*
2019-05-28 10:47:31 +02:00
* @ param string $text Complete text to show in the tip .
* @ param boolean $return Whether to return an output string or echo now .
* @ param string $img Displayed image .
* @ param boolean $is_relative Print image in relative way .
2019-05-29 17:34:11 +02:00
* @ param string $style Specific style .
2009-02-20 22:48:09 +01:00
*
* @ return string HTML code if return parameter is true .
*/
2019-05-28 10:47:31 +02:00
function ui_print_help_tip (
$text ,
$return = false ,
2023-03-01 12:07:03 +01:00
$img = 'images/info@svg.svg' ,
2019-05-29 17:34:11 +02:00
$is_relative = false ,
2022-12-29 17:20:34 +01:00
$style = '' ,
$blink = false
2019-05-28 10:47:31 +02:00
) {
2023-03-08 15:01:41 +01:00
if ( empty ( $img ) === true ) {
$img = 'images/info@svg.svg' ;
}
2019-05-29 17:34:11 +02:00
$output = '<a href="javascript:" class="tip" style="' . $style . '" >' ;
$output .= html_print_image (
2019-01-30 16:18:44 +01:00
$img ,
true ,
2022-12-29 17:20:34 +01:00
[
'title' => $text ,
'class' => $blink === true ? 'blink' : '' ,
2023-03-01 12:07:03 +01:00
'style' => 'width: 16px; height: 16px;' ,
2022-12-29 17:20:34 +01:00
],
2019-01-30 16:18:44 +01:00
false ,
$is_relative && is_metaconsole ()
) . '</a>' ;
if ( $return ) {
return $output ;
}
echo $output ;
2009-02-20 22:48:09 +01:00
}
2009-02-25 13:24:06 +01:00
2019-01-30 16:18:44 +01:00
2023-02-07 13:20:23 +01:00
/**
* Generate a placeholder for inputs .
*
* @ param string $text Text for show .
* @ param boolean $return Text for show .
* @ param array $options Text for show .
*
* @ return string | void Formed element .
*/
function ui_print_input_placeholder (
string $text ,
bool $return = false ,
array $options = []
) {
$wrapper = ( isset ( $options [ 'wrapper' ]) === true ) ? $options [ 'wrapper' ] : 'span' ;
$attibutes = [];
$attibutes [] = 'class="' . (( isset ( $options [ 'class' ]) === true ) ? $options [ 'class' ] : 'input_sub_placeholder' ) . '"' ;
$attibutes [] = ( isset ( $options [ 'rawattributes' ]) === true ) ? $options [ 'rawattributes' ] : '' ;
$attibutes [] = ( isset ( $options [ 'style' ]) === true ) ? 'style="' . $options [ 'style' ] . '"' : '' ;
2023-02-27 16:33:46 +01:00
$attibutes [] = ( isset ( $options [ 'id' ]) === true ) ? 'id="' . $options [ 'id' ] . '"' : '' ;
2023-02-07 13:20:23 +01:00
$attibutes [] = ( isset ( $options [ 'title' ]) === true ) ? 'title="' . $options [ 'title' ] . '"' : '' ;
$output = sprintf (
'<%s %s>%s</%s>' ,
$wrapper ,
implode ( ' ' , $attibutes ),
$text ,
$wrapper
);
if ( $return === true ) {
return $output ;
} else {
echo $output ;
}
}
2019-05-28 10:47:31 +02:00
/**
* Prints link to show something .
*
* @ param string $text Complete text to show in the tip .
* @ param boolean $return Whether to return an output string or echo now .
* @ param string $img Displayed image .
* @ param boolean $is_relative Print image in relative way .
*
* @ return string HTML .
*/
function ui_print_help_tip_border (
$text ,
$return = false ,
$img = 'images/tip_border.png' ,
$is_relative = false
) {
2019-01-30 16:18:44 +01:00
$output = '<a href="javascript:" class="tip" >' . html_print_image (
$img ,
true ,
[ 'title' => $text ],
false ,
$is_relative && is_metaconsole ()
) . '</a>' ;
if ( $return ) {
return $output ;
}
echo $output ;
2018-09-10 13:22:02 +02:00
}
2019-01-30 16:18:44 +01:00
2009-02-25 13:24:06 +01:00
/**
* Powerful debug function that also shows a backtrace .
2019-01-30 16:18:44 +01:00
*
2009-02-25 13:24:06 +01:00
* This functions need to have active $config [ 'debug' ] variable to work .
*
2019-05-28 10:47:31 +02:00
* @ param mixed $var Variable name to debug .
* @ param boolean $backtrace Wheter to print the backtrace or not .
2019-01-30 16:18:44 +01:00
*
* @ return boolean Tru if the debug was actived . False if not .
2009-02-25 13:24:06 +01:00
*/
2019-01-30 16:18:44 +01:00
function ui_debug ( $var , $backtrace = true )
{
global $config ;
if ( ! isset ( $config [ 'debug' ])) {
return false ;
}
static $id = 0 ;
static $trace_id = 0 ;
$id ++ ;
if ( $backtrace ) {
echo '<div class="debug">' ;
echo '<a href="#" onclick="$(\'#trace-' . $id . '\').toggle ();return false;">Backtrace</a>' ;
echo '<div id="trace-' . $id . '" class="backtrace invisible">' ;
echo '<ol>' ;
$traces = debug_backtrace ();
2019-05-28 10:47:31 +02:00
// Ignore debug function.
2019-01-30 16:18:44 +01:00
unset ( $traces [ 0 ]);
foreach ( $traces as $trace ) {
$trace_id ++ ;
/*
2019-05-28 10:47:31 +02:00
* Many classes are used to allow better customization .
* Please , do not remove them
*/
2019-01-30 16:18:44 +01:00
echo '<li>' ;
if ( isset ( $trace [ 'class' ])) {
echo '<span class="class">' . $trace [ 'class' ] . '</span>' ;
}
if ( isset ( $trace [ 'type' ])) {
echo '<span class="type">' . $trace [ 'type' ] . '</span>' ;
}
echo '<span class="function">' ;
echo '<a href="#" onclick="$(\'#args-' . $trace_id . '\').toggle ();return false;">' . $trace [ 'function' ] . '()</a>' ;
echo '</span>' ;
if ( isset ( $trace [ 'file' ])) {
echo ' - <span class="filename">' ;
echo str_replace ( $config [ 'homedir' ] . '/' , '' , $trace [ 'file' ]);
echo ':' . $trace [ 'line' ] . '</span>' ;
} else {
echo ' - <span class="filename"><em>Unknown file</em></span>' ;
}
echo '<pre id="args-' . $trace_id . '" class="invisible">' ;
echo '<div class="parameters">Parameter values:</div>' ;
echo '<ol>' ;
foreach ( $trace [ 'args' ] as $arg ) {
echo '<li>' ;
print_r ( $arg );
echo '</li>' ;
}
echo '</ol>' ;
echo '</pre>' ;
echo '</li>' ;
}
echo '</ol>' ;
echo '</div></div>' ;
}
2019-05-28 10:47:31 +02:00
// Actually print the variable given.
2019-01-30 16:18:44 +01:00
echo '<pre class="debug">' ;
print_r ( $var );
echo '</pre>' ;
return true ;
2009-02-25 13:24:06 +01:00
}
2009-03-02 Evi Vanoost <vanooste@rcbi.rochester.edu>
* include/functions_reporting.php: Rewrote get_agentmodule_sla with
faster calculations (count in SQL).
* include/functions_ui.php: Added print_moduletype_icon that prints the
whole (correct) icon including rollover text
* include/functions_db.php: Updated some documenation and removed
deprecated functions that are now in the auth parts. Renamed
return_status_agent_module to get_agentmodule_status
* operation/agentes/sla_view.php: Made it use the 2.0 SQL and HTML
functions
* godmode/agentes/configurar_agente.php: Fixed tab links
* operation/events/events.php, include/functions_visual_map.php,
operation/agentes/networkmap.php, operation/agentes/status_monitor.php,
operation/agentes/estado_grupo.php, operation/agentes/ver_agente.php,
operation/reporting/custom_reporting.php,
operation/reporting/reporting_viewer.php,
operation/reporting/reporting_xml.php, godmode/setup/links.php,
godmode/setup/setup.php, godmode/reporting/map_builder.php,
godmode/reporting/reporting_builder.php: Fixed renamed functions
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1497 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-03-02 20:16:46 +01:00
2019-01-30 16:18:44 +01:00
2009-03-02 Evi Vanoost <vanooste@rcbi.rochester.edu>
* include/functions_reporting.php: Rewrote get_agentmodule_sla with
faster calculations (count in SQL).
* include/functions_ui.php: Added print_moduletype_icon that prints the
whole (correct) icon including rollover text
* include/functions_db.php: Updated some documenation and removed
deprecated functions that are now in the auth parts. Renamed
return_status_agent_module to get_agentmodule_status
* operation/agentes/sla_view.php: Made it use the 2.0 SQL and HTML
functions
* godmode/agentes/configurar_agente.php: Fixed tab links
* operation/events/events.php, include/functions_visual_map.php,
operation/agentes/networkmap.php, operation/agentes/status_monitor.php,
operation/agentes/estado_grupo.php, operation/agentes/ver_agente.php,
operation/reporting/custom_reporting.php,
operation/reporting/reporting_viewer.php,
operation/reporting/reporting_xml.php, godmode/setup/links.php,
godmode/setup/setup.php, godmode/reporting/map_builder.php,
godmode/reporting/reporting_builder.php: Fixed renamed functions
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1497 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-03-02 20:16:46 +01:00
/**
* Prints icon of a module type
2019-01-30 16:18:44 +01:00
*
2019-05-28 10:47:31 +02:00
* @ param integer $id_moduletype Module Type ID .
* @ param boolean $return Whether to return or print .
* @ param boolean $relative Whether to use relative path to image or not ( i . e . $relative = true : / pandora /< img_src > ) .
* @ param boolean $options Whether to use image options like style , border or title on the icon .
* @ param boolean $src Src .
2009-03-02 Evi Vanoost <vanooste@rcbi.rochester.edu>
* include/functions_reporting.php: Rewrote get_agentmodule_sla with
faster calculations (count in SQL).
* include/functions_ui.php: Added print_moduletype_icon that prints the
whole (correct) icon including rollover text
* include/functions_db.php: Updated some documenation and removed
deprecated functions that are now in the auth parts. Renamed
return_status_agent_module to get_agentmodule_status
* operation/agentes/sla_view.php: Made it use the 2.0 SQL and HTML
functions
* godmode/agentes/configurar_agente.php: Fixed tab links
* operation/events/events.php, include/functions_visual_map.php,
operation/agentes/networkmap.php, operation/agentes/status_monitor.php,
operation/agentes/estado_grupo.php, operation/agentes/ver_agente.php,
operation/reporting/custom_reporting.php,
operation/reporting/reporting_viewer.php,
operation/reporting/reporting_xml.php, godmode/setup/links.php,
godmode/setup/setup.php, godmode/reporting/map_builder.php,
godmode/reporting/reporting_builder.php: Fixed renamed functions
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1497 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-03-02 20:16:46 +01:00
*
* @ return string An HTML string with the icon . Printed if return is false
*/
2019-05-28 10:47:31 +02:00
function ui_print_moduletype_icon (
$id_moduletype ,
$return = false ,
$relative = false ,
$options = true ,
$src = false
) {
2019-01-30 16:18:44 +01:00
global $config ;
2019-05-28 10:47:31 +02:00
$type = db_get_row (
'ttipo_modulo' ,
'id_tipo' ,
( int ) $id_moduletype ,
[
'descripcion' ,
'icon' ,
]
);
2019-01-30 16:18:44 +01:00
if ( $type === false ) {
$type = [];
$type [ 'descripcion' ] = __ ( 'Unknown type' );
$type [ 'icon' ] = 'b_down.png' ;
}
$imagepath = 'images/' . $type [ 'icon' ];
if ( ! file_exists ( $config [ 'homedir' ] . '/' . $imagepath )) {
$imagepath = ENTERPRISE_DIR . '/' . $imagepath ;
}
if ( $src ) {
return $imagepath ;
}
if ( $options ) {
return html_print_image (
$imagepath ,
$return ,
[
'border' => 0 ,
'title' => $type [ 'descripcion' ],
2022-12-15 12:42:35 +01:00
'class' => 'invert_filter main_menu_icon' ,
2019-01-30 16:18:44 +01:00
],
false ,
$relative
);
} else {
return html_print_image (
$imagepath ,
$return ,
false ,
false ,
$relative
);
}
2009-03-02 Evi Vanoost <vanooste@rcbi.rochester.edu>
* include/functions_reporting.php: Rewrote get_agentmodule_sla with
faster calculations (count in SQL).
* include/functions_ui.php: Added print_moduletype_icon that prints the
whole (correct) icon including rollover text
* include/functions_db.php: Updated some documenation and removed
deprecated functions that are now in the auth parts. Renamed
return_status_agent_module to get_agentmodule_status
* operation/agentes/sla_view.php: Made it use the 2.0 SQL and HTML
functions
* godmode/agentes/configurar_agente.php: Fixed tab links
* operation/events/events.php, include/functions_visual_map.php,
operation/agentes/networkmap.php, operation/agentes/status_monitor.php,
operation/agentes/estado_grupo.php, operation/agentes/ver_agente.php,
operation/reporting/custom_reporting.php,
operation/reporting/reporting_viewer.php,
operation/reporting/reporting_xml.php, godmode/setup/links.php,
godmode/setup/setup.php, godmode/reporting/map_builder.php,
godmode/reporting/reporting_builder.php: Fixed renamed functions
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1497 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-03-02 20:16:46 +01:00
}
2009-03-04 16:59:00 +01:00
2019-01-30 16:18:44 +01:00
2011-06-27 07:56:55 +02:00
/**
* Print module max / min values for warning / critical state
*
2019-05-28 10:47:31 +02:00
* @ param float $max_warning Max value for warning state .
* @ param float $min_warning Min value for warning state .
* @ param string $str_warning String warning state .
* @ param float $max_critical Max value for critical state .
* @ param float $min_critical Min value for critical state .
* @ param string $str_critical String for critical state .
2023-01-04 15:46:32 +01:00
* @ param string $attributes String with raw format attributes for span .
2011-06-27 07:56:55 +02:00
*
* @ return string HTML string
*/
2019-05-28 10:47:31 +02:00
function ui_print_module_warn_value (
$max_warning ,
$min_warning ,
$str_warning ,
$max_critical ,
$min_critical ,
2019-10-17 11:50:50 +02:00
$str_critical ,
$warning_inverse = 0 ,
2023-01-04 15:46:32 +01:00
$critical_inverse = 0 ,
$attributes = ''
2019-05-28 10:47:31 +02:00
) {
2019-10-17 11:50:50 +02:00
$war_inv = '' ;
$crit_inv = '' ;
if ( $warning_inverse == 1 ) {
$war_inv = ' (inv)' ;
}
if ( $critical_inverse == 1 ) {
$crit_inv = ' (inv)' ;
}
2023-01-04 15:46:32 +01:00
$data = '<span ' . $attributes . ' title="' . __ ( 'Warning' ) . ': ' . __ ( 'Max' ) . $max_warning . '/' . __ ( 'Min' ) . $min_warning . $war_inv . ' - ' . __ ( 'Critical' ) . ': ' . __ ( 'Max' ) . $max_critical . '/' . __ ( 'Min' ) . $min_critical . $crit_inv . '">' ;
2019-01-30 16:18:44 +01:00
if ( $max_warning != $min_warning ) {
$data .= format_for_graph ( $max_warning ) . '/' . format_for_graph ( $min_warning );
} else {
$data .= __ ( 'N/A' );
}
$data .= ' - ' ;
if ( $max_critical != $min_critical ) {
$data .= format_for_graph ( $max_critical ) . '/' . format_for_graph ( $min_critical );
} else {
$data .= __ ( 'N/A' );
}
$data .= '</span>' ;
return $data ;
2011-06-27 07:56:55 +02:00
}
2019-01-30 16:18:44 +01:00
2009-03-04 16:59:00 +01:00
/**
2019-01-30 16:18:44 +01:00
* Format a file size from bytes to a human readable meassure .
*
2019-05-28 10:47:31 +02:00
* @ param integer $bytes File size in bytes .
*
2019-01-30 16:18:44 +01:00
* @ return string Bytes converted to a human readable meassure .
*/
function ui_format_filesize ( $bytes )
{
$bytes = ( int ) $bytes ;
$strs = [
'B' ,
'kB' ,
'MB' ,
'GB' ,
'TB' ,
];
if ( $bytes <= 0 ) {
return '0 ' . $strs [ 0 ];
}
$con = 1024 ;
$log = ( int ) ( log ( $bytes , $con ));
return format_numeric (( $bytes / pow ( $con , $log )), 1 ) . ' ' . $strs [ $log ];
2009-03-04 16:59:00 +01:00
}
2009-04-06 13:02:05 +02:00
/**
* Returns the current path to the selected image set to show the
* status of agents and alerts .
*
* @ return array An array with the image path , image width and image height .
*/
2019-01-30 16:18:44 +01:00
function ui_get_status_images_path ()
{
global $config ;
2018-10-04 11:43:08 +02:00
2019-01-30 16:18:44 +01:00
$imageset = $config [ 'status_images_set' ];
2018-10-04 11:43:08 +02:00
2019-01-30 16:18:44 +01:00
if ( strpos ( $imageset , ',' ) === false ) {
$imageset .= ',40x18' ;
}
2018-10-04 11:43:08 +02:00
2019-01-30 16:18:44 +01:00
$array_split = preg_split ( '/\,/' , $imageset );
$imageset = $array_split [ 0 ];
$sizes = $array_split [ 1 ];
2018-10-04 11:43:08 +02:00
2019-01-30 16:18:44 +01:00
if ( strpos ( $sizes , 'x' ) === false ) {
$sizes .= 'x18' ;
}
2018-10-04 11:43:08 +02:00
2019-01-30 16:18:44 +01:00
$array_split_size = preg_split ( '/x/' , $sizes );
$imagewidth = $array_split_size [ 0 ];
$imageheight = $array_split_size [ 1 ];
2018-10-04 11:43:08 +02:00
2019-01-30 16:18:44 +01:00
$imagespath = 'images/status_sets/' . $imageset ;
2018-10-04 11:43:08 +02:00
2019-01-30 16:18:44 +01:00
return [ $imagespath ];
2009-04-06 13:02:05 +02:00
}
2019-01-30 16:18:44 +01:00
2009-04-20 16:00:27 +02:00
/**
* Prints an image representing a status .
*
2019-06-24 11:59:17 +02:00
* @ param string $type Type .
* @ param string $title Title .
* @ param boolean $return Whether to return an output string or echo now ( optional , echo by default ) .
* @ param array $options Options to set image attributes : I . E .: style .
* @ param string $path Path of the image , if not provided use the status path .
* @ param boolean $image_with_css Don ' t use an image . Draw an image with css styles .
2020-03-23 12:47:58 +01:00
* @ param string $extra_text Text that is displayed after title ( i . e . time elapsed since last status change of module ) .
2009-04-20 16:00:27 +02:00
*
* @ return string HTML code if return parameter is true .
*/
2019-05-28 10:47:31 +02:00
function ui_print_status_image (
$type ,
$title = '' ,
$return = false ,
$options = false ,
$path = false ,
2020-03-19 15:18:20 +01:00
$image_with_css = false ,
2020-03-23 12:47:58 +01:00
$extra_info = ''
2019-05-28 10:47:31 +02:00
) {
2019-01-30 16:18:44 +01:00
if ( $path === false ) {
$imagepath_array = ui_get_status_images_path ();
$imagepath = $imagepath_array [ 0 ];
} else {
$imagepath = $path ;
}
2018-10-04 11:43:08 +02:00
2022-02-24 11:04:18 +01:00
if ( $imagepath === 'images/status_sets/default' ) {
2019-06-24 11:59:17 +02:00
$image_with_css = true ;
}
if ( $image_with_css === true ) {
$shape_status = get_shape_status_set ( $type );
2023-02-21 14:16:37 +01:00
// $shape_status['is_tree_view'] = true;
2020-03-23 12:47:58 +01:00
return ui_print_status_sets ( $type , $title , $return , $shape_status , $extra_info );
2019-06-24 11:59:17 +02:00
} else {
2022-02-24 11:04:18 +01:00
$imagepath .= '/' . $type ;
2019-06-24 11:59:17 +02:00
if ( $options === false ) {
$options = [];
}
$options [ 'title' ] = $title ;
return html_print_image ( $imagepath , $return , $options , false , false , false , true );
2019-01-30 16:18:44 +01:00
}
2019-06-24 11:59:17 +02:00
}
2018-10-04 11:43:08 +02:00
2020-05-20 19:04:42 +02:00
/**
* Returns html code to print a shape for a module .
*
2022-02-10 16:33:58 +01:00
* @ param integer $status Module status .
* @ param boolean $return True or false .
* @ param string $class Custom class or use defined .
* @ param string $title Custom title or inherit from module status .
* @ param string $div_content Content .
2020-05-20 19:04:42 +02:00
*
* @ return string HTML code for shape .
*/
function ui_print_module_status (
$status ,
$return = false ,
2021-10-13 22:47:31 +02:00
$class = 'status_rounded_rectangles' ,
2022-02-10 16:33:58 +01:00
$title = null ,
$div_content = ''
2020-05-20 19:04:42 +02:00
) {
$color = modules_get_color_status ( $status , true );
2021-10-13 22:47:31 +02:00
if ( $title === null ) {
$title = modules_get_modules_status ( $status );
}
2020-05-20 19:04:42 +02:00
$output = '<div style="background: ' . $color ;
$output .= '" class="' . $class ;
2021-11-15 18:58:57 +01:00
$output .= ' forced_title" data-title="' . $title . '" title="' ;
2022-02-10 16:33:58 +01:00
$output .= $title . '" data-use_title_for_force_title="1">' . $div_content . '</div>' ;
2020-05-20 19:04:42 +02:00
if ( $return === false ) {
echo $output ;
}
return $output ;
}
2023-05-23 16:54:40 +02:00
/**
* Returns html code to print a shape for a module .
*
* @ param integer $color Hex color .
* @ param boolean $return True or false .
* @ param string $class Custom class or use defined .
* @ param string $div_content Content .
*
* @ return string HTML code for shape .
*/
function ui_print_diagnosis_status (
$color ,
$return = false ,
$class = 'status_rounded_rectangles' ,
$div_content = ''
) {
$output = '<div style="background: ' . $color . '" class="' . $class . '">' . $div_content . '</div>' ;
2020-05-20 19:04:42 +02:00
if ( $return === false ) {
echo $output ;
}
return $output ;
}
2019-06-24 11:59:17 +02:00
/**
* Get the shape of an image by assigning it a CSS class . Prints an image with CSS representing a status .
*
* @ param string $type Module / Agent / Alert status .
*
* @ return array With CSS class .
*/
function get_shape_status_set ( $type )
{
switch ( $type ) {
2023-01-10 10:18:37 +01:00
// Rounded rectangles.
2019-06-24 11:59:17 +02:00
case STATUS_ALERT_NOT_FIRED :
case STATUS_ALERT_FIRED :
case STATUS_ALERT_DISABLED :
case STATUS_MODULE_OK :
case STATUS_AGENT_OK :
case STATUS_MODULE_NO_DATA :
case STATUS_AGENT_NO_DATA :
case STATUS_MODULE_CRITICAL :
2020-03-04 12:09:54 +01:00
case STATUS_MODULE_ALERT_TRIGGERED :
2019-06-24 11:59:17 +02:00
case STATUS_AGENT_CRITICAL :
case STATUS_MODULE_WARNING :
case STATUS_AGENT_WARNING :
case STATUS_MODULE_UNKNOWN :
case STATUS_AGENT_UNKNOWN :
case STATUS_AGENT_DOWN :
2019-08-10 02:13:01 +02:00
case STATUS_AGENT_NO_MONITORS :
2019-06-24 11:59:17 +02:00
$return = [ 'class' => 'status_rounded_rectangles' ];
break ;
// Small squares.
case STATUS_SERVER_OK :
case STATUS_SERVER_DOWN :
2020-10-21 14:03:46 +02:00
case STATUS_SERVER_CRASH :
2019-06-24 11:59:17 +02:00
$return = [ 'class' => 'status_small_squares' ];
break ;
2018-10-04 11:43:08 +02:00
2019-06-24 11:59:17 +02:00
// Balls.
case STATUS_AGENT_CRITICAL_BALL :
case STATUS_AGENT_WARNING_BALL :
case STATUS_AGENT_DOWN_BALL :
case STATUS_AGENT_UNKNOWN_BALL :
case STATUS_AGENT_OK_BALL :
case STATUS_AGENT_NO_DATA_BALL :
case STATUS_AGENT_NO_MONITORS_BALL :
2020-10-21 14:03:46 +02:00
case STATUS_SERVER_OK_BALL :
case STATUS_SERVER_DOWN_BALL :
case STATUS_SERVER_CRASH_BALL :
2019-06-24 11:59:17 +02:00
$return = [ 'class' => 'status_balls' ];
break ;
2018-10-04 11:43:08 +02:00
2019-06-24 11:59:17 +02:00
// Small Balls.
case STATUS_MODULE_OK_BALL :
case STATUS_MODULE_CRITICAL_BALL :
case STATUS_MODULE_WARNING_BALL :
case STATUS_MODULE_NO_DATA_BALL :
case STATUS_MODULE_UNKNOWN_BALL :
case STATUS_ALERT_FIRED_BALL :
case STATUS_ALERT_NOT_FIRED_BALL :
case STATUS_ALERT_DISABLED_BALL :
$return = [ 'class' => 'status_small_balls' ];
2023-01-30 13:39:27 +01:00
// $return = ['class' => 'status_balls'];
2019-06-24 11:59:17 +02:00
break ;
default :
// Ignored.
break ;
}
return $return ;
2009-04-06 13:02:05 +02:00
}
2019-01-30 16:18:44 +01:00
2019-05-28 12:13:29 +02:00
/**
* Prints an image representing a status .
*
2020-03-23 12:47:58 +01:00
* @ param string $status Module status .
* @ param string $title Title .
* @ param boolean $return Whether to return an output string or echo now ( optional , echo by default ) .
* @ param array $options Options to set image attributes : I . E .: style .
* @ param string $extra_info Text that is displayed after title ( i . e . time elapsed since last status change of module ) .
2019-05-28 12:13:29 +02:00
*
* @ return string HTML .
*/
2019-06-24 11:59:17 +02:00
function ui_print_status_sets (
2019-05-28 12:13:29 +02:00
$status ,
$title = '' ,
$return = false ,
2020-03-19 15:18:20 +01:00
$options = false ,
2020-11-25 17:00:37 +01:00
$extra_info = '' ,
$get_status_color = true
2019-05-28 12:13:29 +02:00
) {
global $config ;
if ( $options === false ) {
$options = [];
}
2022-02-24 11:04:18 +01:00
if ( isset ( $options [ 'style' ]) === true ) {
2020-11-25 17:00:37 +01:00
$options [ 'style' ] .= ' display: inline-block;' ;
2019-06-24 11:59:17 +02:00
} else {
2020-11-25 17:00:37 +01:00
$options [ 'style' ] = 'display: inline-block;' ;
}
if ( $get_status_color === true ) {
$options [ 'style' ] .= ' background: ' . modules_get_color_status ( $status ) . ';' ;
2019-06-24 11:59:17 +02:00
}
2019-05-28 12:13:29 +02:00
2023-01-26 13:25:24 +01:00
if ( isset ( $options [ 'is_tree_view' ]) === true ) {
$options [ 'class' ] = 'item_status_tree_view' ;
} else if ( isset ( $options [ 'class' ]) === true ) {
2019-06-24 11:59:17 +02:00
$options [ 'class' ] = $options [ 'class' ];
2019-05-28 12:13:29 +02:00
}
2022-02-24 11:04:18 +01:00
if ( empty ( $title ) === false ) {
$options [ 'title' ] = ( empty ( $extra_info ) === true ) ? $title : $title . '
' . $extra_info ;
$options [ 'data-title' ] = ( empty ( $extra_info ) === true ) ? $title : $title . '<br>' . $extra_info ;
2019-06-24 11:59:17 +02:00
$options [ 'data-use_title_for_force_title' ] = 1 ;
2022-02-24 11:04:18 +01:00
if ( isset ( $options [ 'class' ]) === true ) {
2019-06-24 11:59:17 +02:00
$options [ 'class' ] .= ' forced_title' ;
} else {
$options [ 'class' ] = 'forced_title' ;
}
}
2019-05-28 12:13:29 +02:00
$output = '<div ' ;
foreach ( $options as $k => $v ) {
$output .= $k . '="' . $v . '"' ;
}
2022-02-24 11:04:18 +01:00
$output .= '> </div>' ;
2019-05-28 12:13:29 +02:00
2023-01-26 13:25:24 +01:00
if ( isset ( $options [ 'is_tree_view' ]) === true ) {
$output = html_print_div (
[
'class' => '' ,
'content' => $output ,
],
true
);
}
2019-05-28 12:13:29 +02:00
if ( $return === false ) {
echo $output ;
2022-02-24 11:04:18 +01:00
} else {
return $output ;
2019-05-28 12:13:29 +02:00
}
}
2019-05-27 21:30:46 +02:00
/**
* Generates a progress bar CSS based .
* Requires css progress . css
*
2023-01-26 13:25:24 +01:00
* @ param integer $progress Progress .
* @ param string $width Width .
* @ param integer $height Height in 'em' .
* @ param string $color Color .
* @ param boolean $return Return or paint ( if false ) .
* @ param boolean $text Text to be displayed , by default progress %.
* @ param array $ajax Ajax : [ 'page' => 'page' , 'data' => 'data' ] Sample :
2019-06-14 10:35:10 +02:00
* [
2019-06-14 10:40:30 +02:00
* 'page' => 'operation/agentes/ver_agente' , Target page .
* 'interval' => 100 / $agent [ " intervalo " ], Ask every interval seconds .
2020-03-16 23:52:20 +01:00
* 'simple' => 0 ,
2019-06-14 10:40:30 +02:00
* 'data' => [ Data to be sent to target page .
2019-06-14 10:35:10 +02:00
* 'id_agente' => $id_agente ,
* 'refresh_contact' => 1 ,
* ],
2019-06-14 10:40:30 +02:00
* ] .
2019-05-27 21:30:46 +02:00
*
2023-01-26 13:25:24 +01:00
* @ param string $otherStyles Raw styles for control .
*
2019-05-27 21:30:46 +02:00
* @ return string HTML code .
*/
function ui_progress (
$progress ,
$width = '100%' ,
2019-05-28 09:48:09 +02:00
$height = '2.5' ,
2019-06-04 14:08:07 +02:00
$color = '#82b92e' ,
2019-05-29 12:42:55 +02:00
$return = true ,
2019-06-14 10:35:10 +02:00
$text = '' ,
2023-01-26 13:25:24 +01:00
$ajax = false ,
$otherStyles = ''
2019-05-27 21:30:46 +02:00
) {
if ( ! $progress ) {
$progress = 0 ;
}
if ( $progress > 100 ) {
$progress = 100 ;
}
if ( $progress < 0 ) {
$progress = 0 ;
}
2019-05-29 12:42:55 +02:00
if ( empty ( $text )) {
$text = $progress . '%' ;
}
2020-03-19 14:26:01 +01:00
$id = uniqid ();
2019-05-27 21:30:46 +02:00
ui_require_css_file ( 'progress' );
2021-02-05 12:37:27 +01:00
$output = '<span id="' . $id . '" class="progress_main" data-label="' . $text ;
2023-01-26 13:25:24 +01:00
$output .= '" style="width: ' . $width . '; height: ' . $height . 'em; border-color: ' . $color . '; ' . $otherStyles . '">' ;
2020-03-19 14:26:01 +01:00
$output .= '<span id="' . $id . '_progress" class="progress" style="width: ' . $progress . '%; background: ' . $color . '"></span>' ;
2019-06-14 10:35:10 +02:00
$output .= '</span>' ;
if ( $ajax !== false && is_array ( $ajax )) {
2020-03-16 23:52:20 +01:00
if ( $ajax [ 'simple' ]) {
$output .= ' < script type = " text/javascript " >
$ ( document ) . ready ( function () {
setInterval (() => {
$ . post ({
url : " '.ui_get_full_url('ajax.php', false, false, false).' " ,
data : { ' ;
if ( is_array ( $ajax [ 'data' ])) {
foreach ( $ajax [ 'data' ] as $token => $value ) {
$output .= '
'.$token.' : " '. $value .' " , ' ;
}
}
$output .= '
page : " '. $ajax['page'] .' "
},
success : function ( data ) {
2023-10-16 15:47:48 +02:00
let data_text = data ;
if ( data . includes ( " script " )) {
const data_array = data_text . split ( " /script> " );
data = data_array [ 1 ];
}
2020-03-16 23:52:20 +01:00
try {
val = JSON . parse ( data );
2023-10-16 15:47:48 +02:00
2020-03-19 14:26:01 +01:00
$ ( " #'. $id .' " ) . attr ( " data-label " , val + " % " );
2023-10-16 15:47:48 +02:00
$ ( " #'. $id .'_progress " ) . width ( val + " % " );
let parent_id = $ ( " #'. $id .' " ) . parent () . parent () . attr ( " id " );
if ( val == 100 ) {
$ ( " # " + parent_id + " -5 " ) . html ( " '.__('Finish').' " );
} ' ;
2020-04-14 11:57:18 +02:00
if ( isset ( $ajax [ 'oncomplete' ])) {
$output .= '
if ( val == 100 ) {
'.$ajax[' oncomplete '].' ( $ ( " #'. $id .' " ));
}
' ;
}
$output .= '
2020-03-16 23:52:20 +01:00
} catch ( e ) {
console . error ( e );
}
}
});
}, '.($ajax[' interval '] > 0 ? $ajax[' interval '] * 1000 : 30000 ).' );
});
</ script > ' ;
} else {
$output .= ' < script type = " text/javascript " >
2019-06-14 10:35:10 +02:00
$ ( document ) . ready ( function () {
setInterval (() => {
2020-03-19 14:26:01 +01:00
last = $ ( " #'. $id .' " ) . attr ( " data-label " ) . split ( " " )[ 0 ] * 1 ;
width = $ ( " #'. $id .'_progress " ) . width () / $ ( " #'. $id .'_progress " ) . parent () . width () * 100 ;
2019-06-14 10:35:10 +02:00
width_interval = '.$ajax[' interval '].' ;
if ( last % 10 == 0 ) {
$ . post ({
2019-08-21 09:22:13 +02:00
url : " '.ui_get_full_url('ajax.php', false, false, false).' " ,
2019-06-14 10:35:10 +02:00
data : { ' ;
2020-03-16 23:52:20 +01:00
if ( is_array ( $ajax [ 'data' ])) {
foreach ( $ajax [ 'data' ] as $token => $value ) {
$output .= '
'.$token.' : " '. $value .' " , ' ;
}
2019-06-14 10:35:10 +02:00
}
2020-03-16 23:52:20 +01:00
$output .= '
2019-06-14 10:35:10 +02:00
page : " '. $ajax['page'] .' "
},
success : function ( data ) {
try {
val = JSON . parse ( data );
2023-02-09 16:13:30 +01:00
if ( isNaN ( val [ " last_contact " ]) == false ) {
$ ( " #'. $id .' " ) . attr ( " data-label " , val [ " last_contact " ] + " s " );
}
2020-03-19 14:26:01 +01:00
$ ( " #'. $id .'_progress " ) . width ( val [ " progress " ] + " % " );
2019-06-14 10:35:10 +02:00
} catch ( e ) {
console . error ( e );
$ ( " .progress_text " ) . attr ( " data-label " , ( last - 1 ) + " s " );
if ( width < 100 ) {
2020-03-19 14:26:01 +01:00
$ ( " #'. $id .'_progress " ) . width (( width + width_interval ) + " % " );
2019-06-14 10:35:10 +02:00
}
}
}
});
} else {
2023-02-09 16:13:30 +01:00
if ( isNaN ( last ) === false ) {
$ ( " #'. $id .' " ) . attr ( " data-label " , ( last - 1 ) + " s " );
}
2019-06-14 10:35:10 +02:00
if ( width < 100 ) {
2020-03-19 14:26:01 +01:00
$ ( " #'. $id .'_progress " ) . width (( width + width_interval ) + " % " );
2019-06-14 10:35:10 +02:00
}
}
}, 1000 );
});
</ script > ' ;
2020-03-16 23:52:20 +01:00
}
2019-06-14 10:35:10 +02:00
}
2019-05-27 21:30:46 +02:00
if ( ! $return ) {
echo $output ;
}
return $output ;
}
2019-11-21 18:21:46 +01:00
/**
* Generates a progress bar CSS based .
* Requires css progress . css
*
* @ param array $data With following content :
*
* 'slices' => [
* 'label' => [ // Name of the slice
* 'value' => value
* 'color' => color of the slice .
* ]
* ],
* 'width' => Width
* 'height' => Height in 'em'
* 'return' => Boolean , return or paint .
*
* @ return string HTML code .
*/
function ui_progress_extend (
array $data
) {
if ( is_array ( $data ) === false ) {
// Failed.
return false ;
}
if ( is_array ( $data [ 'slices' ]) === false ) {
// Failed.
return false ;
}
if ( isset ( $data [ 'width' ]) === false ) {
$data [ 'width' ] = '100' ;
}
if ( isset ( $data [ 'height' ]) === false ) {
$data [ 'height' ] = '1.3' ;
}
$total = array_reduce (
$data [ 'slices' ],
function ( $carry , $item ) {
$carry += $item [ 'value' ];
return $carry ;
}
);
if ( $total == 0 ) {
return null ;
}
ui_require_css_file ( 'progress' );
// Main container.
2021-02-05 12:37:27 +01:00
$output = '<div class="progress_main_noborder" ' ;
2019-11-21 18:21:46 +01:00
$output .= '" style="width:' . $data [ 'width' ] . '%;' ;
$output .= ' height:' . $data [ 'height' ] . 'em;">' ;
foreach ( $data [ 'slices' ] as $label => $def ) {
$width = ( $def [ 'value' ] * 100 / $total );
$output .= '<div class="progress forced_title" ' ;
$output .= ' data-title="' . $label . ': ' . $def [ 'value' ] . '" ' ;
$output .= ' data-use_title_for_force_title="1"' ;
$output .= ' style="width:' . $width . '%;' ;
$output .= ' background-color:' . $def [ 'color' ] . ';' ;
$output .= '">' ;
$output .= '</div>' ;
}
$output .= '</div>' ;
if ( ! $data [ 'return' ]) {
echo $output ;
}
return $output ;
}
2019-06-06 17:50:47 +02:00
/**
* Generate needed code to print a datatables jquery plugin .
*
* @ param array $parameters All desired data using following format :
2023-05-08 14:25:57 +02:00
*
* `` ` php
* $parameters = [
* // JS Parameters
* 'serverside' => true ,
* 'paging' => true ,
* 'default_pagination' => $config [ 'block_size' ],
* 'searching' => false ,
* 'dom_elements' => " plfrtiB " ,
* 'pagination_options' => [ default_pagination , 5 , 10 , 20 , 100 , 200 , 500 , 1000 , " All " ],
* 'ordering' => true ,
* 'order' => [[ 0 , " asc " ]], //['field' => 'column_name', 'direction' => 'asc/desc']
* 'zeroRecords' => " No matching records found " ,
* 'emptyTable' => " No data available in table " ,
* 'no_sortable_columns' => [], //Allows the column name (db) from "columns" parameter
* 'csv_field_separator' => " , " ,
* 'csv_header' => true ,
* 'mini_csv' => false ,
* 'mini_pagination' => false ,
* 'mini_search' => false ,
* 'drawCallback' => undefined , //'console.log(123),'
* 'data_element' => undefined , //Rows processed
* 'ajax_postprocess' => undefined , //'process_datatables_item(item)'
* 'ajax_data' => undefined , //Extra data to be sent ['field1' => 1, 'field2 => 0]
* 'ajax_url' => undefined ,
* 'caption' => undefined ,
*
* // PHP Parameters
* 'id' => undefined , //Used for table and form id,
* 'columns' => ,
* 'column_names' => ,
* 'filter_main_class' => ,
* 'toggle_collapsed' => true ,
* 'search_button_class' => 'sub filter' ,
* 'csv' =>= 1 ,
* 'form' =>
* .. [
* .... 'id' => $form_id ,
* .... 'class' => 'flex-row' ,
* .... 'style' => 'width: 100%,' ,
* .... 'js' => '' ,
* .... 'html' => $filter ,
* .... 'inputs' => [],
* .... 'extra_buttons' => $buttons ,
* .. ],
* 'no_toggle' => false ,
* 'form_html' => undefined ,
* 'toggle_collapsed' => true ,
* 'class' => " " , //Datatable class.
* 'style' => " " , //Datatable style.
* 'return' => false ,
* 'print' => true ,
* ]
*
* `` `
*
* `` ` php
* ajax_postprocess => a javscript function to postprocess data received
* by ajax call . It is applied foreach row and must
* use following format :
* function ( item ) {
* // Process received item, for instance, name:
* tmp = '<span class=label>' + item . name + '</span>' ;
* item . name = tmp ;
* }
2019-06-07 17:35:13 +02:00
* 'columns_names' => [
2019-06-06 17:50:47 +02:00
* 'column1' :: Used as th text . Direct text entry . It could be array :
* OR
* [
* 'id' => th id .
* 'class' => th class .
* 'style' => th style .
* 'text' => 'column1' .
2022-07-19 09:40:56 +02:00
* 'title' => 'column title' .
2019-06-06 17:50:47 +02:00
* ]
* ],
2019-06-07 17:35:13 +02:00
* 'columns' => [
2019-06-06 17:50:47 +02:00
* 'column1' ,
* 'column2' ,
* ...
* ],
* 'form' => [
* 'html' => 'html code' a directly defined inputs in HTML .
2019-06-11 12:58:18 +02:00
* 'extra_buttons' => [
* [
* 'id' => button id ,
* 'class' => button class ,
* 'style' => button style ,
* 'text' => button text ,
* 'onclick' => button onclick ,
* ]
* ],
2019-06-06 17:50:47 +02:00
* 'search_button_class' => search button class .
* 'class' => form class .
* 'id' => form id .
* 'style' => form style .
* 'js' => optional extra actions onsubmit .
* 'inputs' => [
* 'label' => Input label .
* 'type' => Input type .
* 'value' => Input value .
* 'name' => Input name .
* 'id' => Input id .
* 'options' => [
* 'option1'
* 'option2'
* ...
* ]
2022-07-19 09:40:56 +02:00
* 'no_toggle' => Pint form withouth UI toggle .
2019-06-06 17:50:47 +02:00
* ]
* ],
2019-06-10 15:18:35 +02:00
* 'extra_html' => HTML content to be placed after 'filter' section .
2023-05-08 14:25:57 +02:00
* `` `
2019-06-06 17:50:47 +02:00
*
* @ return string HTML code with datatable .
* @ throws Exception On error .
*/
function ui_print_datatable ( array $parameters )
{
2019-06-07 17:35:13 +02:00
global $config ;
2019-06-06 17:50:47 +02:00
if ( isset ( $parameters [ 'id' ])) {
$table_id = $parameters [ 'id' ];
2019-06-21 12:03:25 +02:00
$form_id = 'form_' . $parameters [ 'id' ];
2019-06-06 17:50:47 +02:00
} else {
$table_id = uniqid ( 'datatable_' );
2019-06-21 12:03:25 +02:00
$form_id = uniqid ( 'datatable_filter_' );
2019-06-06 17:50:47 +02:00
}
2023-05-08 14:25:57 +02:00
$parameters [ 'table_id' ] = $table_id ;
$parameters [ 'form_id' ] = $form_id ;
2019-06-07 17:35:13 +02:00
if ( ! isset ( $parameters [ 'columns' ]) || ! is_array ( $parameters [ 'columns' ])) {
throw new Exception ( '[ui_print_datatable]: You must define columns for datatable' );
2019-06-06 17:50:47 +02:00
}
2020-05-14 17:42:58 +02:00
if ( isset ( $parameters [ 'column_names' ])
&& is_array ( $parameters [ 'column_names' ])
&& count ( $parameters [ 'columns' ]) != count ( $parameters [ 'column_names' ])
) {
throw new Exception ( '[ui_print_datatable]: Columns and columns names must have same length' );
}
2023-01-24 09:33:47 +01:00
if ( ! isset ( $parameters [ 'ajax_url' ]) && ! isset ( $parameters [ 'data_element' ])) {
throw new Exception ( '[ui_print_datatable]: Parameter ajax_url or data_element is required' );
2019-06-07 17:35:13 +02:00
}
if ( ! isset ( $parameters [ 'default_pagination' ])) {
$parameters [ 'default_pagination' ] = $config [ 'block_size' ];
}
2023-02-24 10:04:23 +01:00
if ( ! isset ( $parameters [ 'filter_main_class' ])) {
$parameters [ 'filter_main_class' ] = '' ;
}
if ( ! isset ( $parameters [ 'toggle_collapsed' ])) {
$parameters [ 'toggle_collapsed' ] = true ;
}
2023-08-31 14:58:47 +02:00
$parameters [ 'startDisabled' ] = false ;
if ( isset ( $parameters [ 'start_disabled' ]) && $parameters [ 'start_disabled' ] === true ) {
$parameters [ 'startDisabled' ] = true ;
}
2023-09-07 11:08:31 +02:00
$columns_tmp = [];
foreach ( $parameters [ 'columns' ] as $k_column => $v_column ) {
if ( isset ( $parameters [ 'columns' ][ $k_column ][ 'text' ]) === true ) {
array_push ( $columns_tmp , $v_column [ 'text' ]);
} else {
array_push ( $columns_tmp , $v_column );
}
}
2019-06-07 17:35:13 +02:00
if ( ! is_array ( $parameters [ 'order' ])) {
2023-05-08 14:25:57 +02:00
$order = 0 ;
$direction = 'asc' ;
2019-06-07 17:35:13 +02:00
} else {
if ( ! isset ( $parameters [ 'order' ][ 'direction' ])) {
$direction = 'asc' ;
}
if ( ! isset ( $parameters [ 'order' ][ 'field' ])) {
2019-06-19 12:56:16 +02:00
$order = 0 ;
2019-06-07 17:35:13 +02:00
} else {
$order = array_search (
$parameters [ 'order' ][ 'field' ],
2023-09-07 11:08:31 +02:00
$columns_tmp
2019-06-07 17:35:13 +02:00
);
2019-06-10 15:18:35 +02:00
2019-06-19 12:56:16 +02:00
if ( $order === false ) {
$order = 0 ;
2019-06-10 15:18:35 +02:00
}
2019-06-07 17:35:13 +02:00
}
2023-05-08 14:25:57 +02:00
$direction = $parameters [ 'order' ][ 'direction' ];
2019-06-06 17:50:47 +02:00
}
2023-05-08 14:25:57 +02:00
$parameters [ 'order' ][ 'order' ] = $order ;
$parameters [ 'order' ][ 'direction' ] = $direction ;
foreach ( $parameters [ 'no_sortable_columns' ] as $key => $find ) {
$found = array_search (
$parameters [ 'no_sortable_columns' ][ $key ],
2023-09-07 11:08:31 +02:00
$columns_tmp
2023-05-08 14:25:57 +02:00
);
if ( $found !== false ) {
unset ( $parameters [ 'no_sortable_columns' ][ $key ]);
array_push ( $parameters [ 'no_sortable_columns' ], $found );
}
if ( is_int ( $parameters [ 'no_sortable_columns' ][ $key ]) === false ) {
unset ( $parameters [ 'no_sortable_columns' ][ $key ]);
}
2019-06-06 17:50:47 +02:00
}
2023-05-08 14:25:57 +02:00
$parameters [ 'csvTextInfo' ] = __ ( 'Export current page to CSV' );
$parameters [ 'csvFileTitle' ] = sprintf ( __ ( 'export_%s_current_page_%s' ), $table_id , date ( 'Y-m-d' ));
2019-06-06 17:50:47 +02:00
if ( isset ( $parameters [ 'search_button_class' ])) {
$search_button_class = $parameters [ 'search_button_class' ];
} else {
2023-05-08 14:25:57 +02:00
$search_button_class = 'sub filter' ;
2019-06-06 17:50:47 +02:00
}
2022-03-30 14:41:47 +02:00
if ( isset ( $parameters [ 'datacolumns' ]) === false
|| is_array ( $parameters [ 'datacolumns' ]) === false
) {
2019-06-06 17:50:47 +02:00
$parameters [ 'datacolumns' ] = $parameters [ 'columns' ];
}
2022-06-21 11:17:18 +02:00
if ( isset ( $parameters [ 'csv' ]) === false ) {
$parameters [ 'csv' ] = 1 ;
}
2023-09-21 10:21:45 +02:00
if ( isset ( $parameters [ 'no_move_elements_to_action' ]) === false ) {
$parameters [ 'no_move_elements_to_action' ] = false ;
}
2022-06-21 11:17:18 +02:00
$filter = '' ;
2019-06-06 17:50:47 +02:00
// Datatable filter.
if ( isset ( $parameters [ 'form' ]) && is_array ( $parameters [ 'form' ])) {
if ( isset ( $parameters [ 'form' ][ 'id' ])) {
$form_id = $parameters [ 'form' ][ 'id' ];
2023-05-08 14:25:57 +02:00
$parameters [ 'form_id' ] = $form_id ;
2019-06-06 17:50:47 +02:00
}
if ( isset ( $parameters [ 'form' ][ 'class' ])) {
$form_class = $parameters [ 'form' ][ 'class' ];
} else {
$form_class = '' ;
}
if ( isset ( $parameters [ 'form' ][ 'style' ])) {
$form_style = $parameters [ 'form' ][ 'style' ];
} else {
$form_style = '' ;
}
if ( isset ( $parameters [ 'form' ][ 'js' ])) {
$form_js = $parameters [ 'form' ][ 'js' ];
} else {
$form_js = '' ;
}
$filter = '<form class="' . $form_class . '" ' ;
$filter .= ' id="' . $form_id . '" ' ;
$filter .= ' style="' . $form_style . '" ' ;
$filter .= ' onsubmit="' . $form_js . ';return false;">' ;
if ( isset ( $parameters [ 'form' ][ 'html' ])) {
$filter .= $parameters [ 'form' ][ 'html' ];
}
2023-02-24 10:04:23 +01:00
$filter .= '<ul class="datatable_filter content filter_table no_border">' ;
2019-06-06 17:50:47 +02:00
foreach ( $parameters [ 'form' ][ 'inputs' ] as $input ) {
2023-09-07 11:08:31 +02:00
if ( $input [ 'type' ] === 'date_range' ) {
$filter .= '<li><label>' . $input [ 'label' ] . '</label>' . html_print_select_date_range ( 'date' , true ) . '</li>' ;
} else {
$filter .= html_print_input (( $input + [ 'return' => true ]), 'li' );
}
2019-06-06 17:50:47 +02:00
}
2023-02-27 14:38:39 +01:00
$filter .= '</ul>' ;
2019-06-12 18:19:39 +02:00
// Extra buttons.
2023-02-24 10:04:23 +01:00
$extra_buttons = '' ;
2022-03-30 14:41:47 +02:00
if ( isset ( $parameters [ 'form' ][ 'extra_buttons' ]) === true
&& is_array ( $parameters [ 'form' ][ 'extra_buttons' ]) === true
) {
2019-06-11 12:58:18 +02:00
foreach ( $parameters [ 'form' ][ 'extra_buttons' ] as $button ) {
2023-02-24 10:04:23 +01:00
$extra_buttons .= html_print_button (
2022-10-25 11:46:28 +02:00
$button [ 'text' ],
$button [ 'id' ],
false ,
$button [ 'onclick' ],
[
'style' => ( $button [ 'style' ] ? ? '' ),
2023-02-24 10:04:23 +01:00
'mode' => 'secondary mini' ,
2022-10-25 11:46:28 +02:00
'class' => $button [ 'class' ],
2023-02-24 10:04:23 +01:00
'icon' => $button [ 'icon' ],
2022-10-25 11:46:28 +02:00
],
true
);
2019-06-11 12:58:18 +02:00
}
}
2022-10-25 11:46:28 +02:00
// Search button.
$filter .= html_print_div (
[
'class' => 'action-buttons' ,
'content' => html_print_submit_button (
__ ( 'Filter' ),
$form_id . '_search_bt' ,
false ,
[
'icon' => 'search' ,
'mode' => 'mini' ,
'class' => $search_button_class ,
],
true
2023-02-24 10:04:23 +01:00
) . $extra_buttons ,
2022-10-25 11:46:28 +02:00
],
true
);
2023-02-27 14:38:39 +01:00
$filter .= '<div id="both"></div></form>' ;
2022-09-23 13:55:01 +02:00
if ( isset ( $parameters [ 'form' ][ 'no_toggle' ]) === false ) {
2022-07-15 12:15:37 +02:00
$filter = ui_toggle (
$filter ,
2023-02-24 10:04:23 +01:00
'<span class="subsection_header_title">' . __ ( 'Filters' ) . '</span>' ,
2022-07-15 12:15:37 +02:00
'' ,
'' ,
2023-02-24 10:04:23 +01:00
$parameters [ 'toggle_collapsed' ],
2023-07-20 15:13:58 +02:00
( isset ( $parameters [ 'form' ][ 'return_filter' ]) === false ) ? false : $parameters [ 'form' ][ 'return_filter' ],
2023-02-24 10:04:23 +01:00
'' ,
'no-border filter-datatable-submain' ,
'filter-datatable-main ' . $parameters [ 'filter_main_class' ]
2022-07-15 12:15:37 +02:00
);
}
2019-06-06 17:50:47 +02:00
} else if ( isset ( $parameters [ 'form_html' ])) {
$filter = ui_toggle (
$parameters [ 'form_html' ],
2023-02-24 10:04:23 +01:00
'<span class="subsection_header_title">' . __ ( 'Filters' ) . '</span>' ,
2019-06-06 17:50:47 +02:00
'' ,
'' ,
2023-02-24 10:04:23 +01:00
$parameters [ 'toggle_collapsed' ],
2019-06-06 17:50:47 +02:00
false ,
2023-02-24 10:04:23 +01:00
'' ,
'no-border filter-datatable-submain' ,
'box-float white_table_graph filter-datatable-main ' . $parameters [ 'filter_main_class' ]
2019-06-06 17:50:47 +02:00
);
}
2019-11-12 16:22:58 +01:00
// Languages.
2022-07-13 12:28:18 +02:00
$processing = '<div class=\'processing-datatables-inside\'>' ;
$processing .= '<i>' . __ ( 'Processing' ) . '</i> ' ;
$processing .= str_replace (
'"' ,
" ' " ,
html_print_image (
'images/spinner.gif' ,
true
)
);
$processing .= '</div>' ;
2023-05-08 14:25:57 +02:00
$parameters [ 'processing' ] = $processing ;
2019-11-12 16:22:58 +01:00
2022-07-15 12:15:37 +02:00
$zeroRecords = isset ( $parameters [ 'zeroRecords' ]) === true ? $parameters [ 'zeroRecords' ] : __ ( 'No matching records found' );
$emptyTable = isset ( $parameters [ 'emptyTable' ]) === true ? $parameters [ 'emptyTable' ] : __ ( 'No data available in table' );
2019-11-12 16:22:58 +01:00
2023-05-08 14:25:57 +02:00
$parameters [ 'zeroRecords' ] = $zeroRecords ;
$parameters [ 'emptyTable' ] = $emptyTable ;
2019-06-10 15:18:35 +02:00
// Extra html.
$extra = '' ;
if ( isset ( $parameters [ 'extra_html' ]) && ! empty ( $parameters [ 'extra_html' ])) {
$extra = $parameters [ 'extra_html' ];
}
2019-06-06 17:50:47 +02:00
// Base table.
$table = '<table id="' . $table_id . '" ' ;
2023-08-31 14:58:47 +02:00
$table .= 'class="invisible ' . $parameters [ 'class' ] . '"' ;
2023-05-08 14:25:57 +02:00
$table .= 'style="box-sizing: border-box;' . $parameters [ 'style' ] . '">' ;
2019-10-17 15:17:28 +02:00
$table .= '<thead><tr class="datatables_thead_tr">' ;
2019-06-07 17:35:13 +02:00
if ( isset ( $parameters [ 'column_names' ])
&& is_array ( $parameters [ 'column_names' ])
) {
$names = $parameters [ 'column_names' ];
} else {
$names = $parameters [ 'columns' ];
2019-06-06 17:50:47 +02:00
}
2019-06-07 17:35:13 +02:00
foreach ( $names as $column ) {
2019-06-06 17:50:47 +02:00
if ( is_array ( $column )) {
2023-07-14 15:42:35 +02:00
$table .= '<th id="' . ( $column [ 'id' ] ? ? '' ) . '" class="' . ( $column [ 'class' ] ? ? '' ) . '" ' ;
2022-09-23 13:55:01 +02:00
if ( isset ( $column [ 'title' ]) === true ) {
$table .= 'title="' . __ ( $column [ 'title' ]) . '" ' ;
}
2023-07-14 15:42:35 +02:00
$table .= ' style="' . ( $column [ 'style' ] ? ? '' ) . '">' . __ ( $column [ 'text' ]);
$table .= ( $column [ 'extra' ] ? ? '' );
2019-06-06 17:50:47 +02:00
$table .= '</th>' ;
} else {
$table .= '<th>' . __ ( $column ) . '</th>' ;
}
}
$table .= '</tr></thead>' ;
$table .= '</table>' ;
2023-05-08 14:25:57 +02:00
$parameters [ 'ajax_url_full' ] = ui_get_full_url ( 'ajax.php' , false , false , false );
2019-06-18 12:48:28 +02:00
2023-05-08 14:25:57 +02:00
$parameters [ 'spinnerLoading' ] = html_print_image (
'images/spinner.gif' ,
true ,
[
'id' => $form_id . '_loading' ,
'class' => 'loading-search-datatables-button' ,
]
);
2020-06-17 13:05:04 +02:00
2023-05-08 14:25:57 +02:00
$language = substr ( get_user_language (), 0 , 2 );
if ( is_metaconsole () === false ) {
$parameters [ 'language' ] = 'include/javascript/i18n/dataTables.' . $language . '.json' ;
} else {
$parameters [ 'language' ] = '../../include/javascript/i18n/dataTables.' . $language . '.json' ;
2021-12-10 13:43:05 +01:00
}
2023-05-08 14:25:57 +02:00
$parameters [ 'phpDate' ] = date ( 'Y-m-d' );
$parameters [ 'dataElements' ] = json_encode ( $parameters [ 'data_element' ]);
2023-01-24 09:33:47 +01:00
2023-05-08 14:25:57 +02:00
// * START JAVASCRIPT.
2023-08-28 14:10:03 +02:00
$file_path = $config [ 'homedir' ] . '/include/javascript/datatablesFunction.js' ;
2023-03-29 17:09:41 +02:00
2023-05-08 14:25:57 +02:00
$file_content = file_get_contents ( $file_path );
$json_data = json_encode ( $parameters );
$json_config = json_encode ( $config );
2019-10-04 14:17:14 +02:00
2023-05-08 14:25:57 +02:00
$js = '<script>' ;
$js .= 'var dt = ' . $json_data . ';' ;
$js .= 'var config = ' . $json_config . ';' ;
$js .= '</script>' ;
2019-06-06 17:50:47 +02:00
2023-05-08 14:25:57 +02:00
$js .= '<script>' ;
$js .= 'function ' . $table_id . '(dt, config) { ' ;
$js .= $file_content ;
$js .= '}' ;
$js .= $table_id . '(dt, config)' ;
$js .= '</script>' ;
// * END JAVASCRIPT.
2023-03-13 12:03:33 +01:00
$info_msg_arr = [];
$info_msg_arr [ 'message' ] = $emptyTable ;
2024-01-26 09:18:47 +01:00
$info_msg_arr [ 'div_class' ] = 'info_box_container invisible_important datatable-info-massage datatable-msg-info-' . $table_id ;
2023-03-13 12:03:33 +01:00
2023-08-31 14:58:47 +02:00
$info_msg_arr_filter = [];
$info_msg_arr_filter [ 'message' ] = __ ( 'Please apply a filter to display the data.' );
2024-01-26 09:18:47 +01:00
$info_msg_arr_filter [ 'div_class' ] = 'info_box_container invisible_important datatable-info-massage datatable-msg-info-filter-' . $table_id ;
2023-08-31 14:58:47 +02:00
$spinner = '<div id="' . $table_id . '-spinner" class="invisible spinner-fixed"><span></span><span></span><span></span><span></span></div>' ;
2023-03-28 17:07:06 +02:00
2024-01-26 09:18:47 +01:00
$info_msg = '<div class="datatable-container-info-massage">' . ui_print_info_message ( $info_msg_arr , '' , true ) . '</div>' ;
2023-05-08 14:25:57 +02:00
2023-08-31 14:58:47 +02:00
$info_msg_filter = '<div>' . ui_print_info_message ( $info_msg_arr_filter , true ) . '</div>' ;
2019-06-18 10:32:04 +02:00
$err_msg = '<div id="error-' . $table_id . '"></div>' ;
2023-08-31 14:58:47 +02:00
$output = $info_msg . $info_msg_filter . $err_msg . $filter . $extra . $spinner . $table . $js ;
2021-10-29 13:45:18 +02:00
if ( is_ajax () === false ) {
ui_require_css_file ( 'datatables.min' , 'include/styles/js/' );
ui_require_css_file ( 'tables' );
if ( is_metaconsole ()) {
2023-02-28 17:47:49 +01:00
ui_require_css_file ( 'meta_tables' , ENTERPRISE_DIR . '/include/styles/' );
2021-10-29 13:45:18 +02:00
}
ui_require_javascript_file ( 'datatables.min' );
ui_require_javascript_file ( 'buttons.dataTables.min' );
ui_require_javascript_file ( 'dataTables.buttons.min' );
ui_require_javascript_file ( 'buttons.html5.min' );
ui_require_javascript_file ( 'buttons.print.min' );
} else {
2022-02-09 14:57:36 +01:00
// Load datatable.min.css.
$output .= '<link rel="stylesheet" href="' ;
$output .= ui_get_full_url (
'include/styles/js/datatables.min.css' ,
false ,
false ,
false
);
2023-05-08 14:25:57 +02:00
$output .= '"/>' ;
2021-10-29 13:45:18 +02:00
// Load tables.css.
$output .= '<link rel="stylesheet" href="' ;
$output .= ui_get_full_url (
'include/styles/tables.css' ,
false ,
false ,
false
);
2023-03-24 12:06:40 +01:00
$output .= '?v=' . $config [ 'current_package' ] . '"/>' ;
2023-08-28 14:10:03 +02:00
// if (is_metaconsole() === true) {
// Load meta_tables.css.
// $output .= '<link rel="stylesheet" href="';
// $output .= ui_get_full_url(
// ENTERPRISE_DIR.'/include/styles/meta_tables.css',
// false,
// false,
// false
// );
// $output .= '?v='.$config['current_package'].'"/>';
// }
2021-10-29 13:45:18 +02:00
// Load datatables.js.
$output .= '<script src="' ;
$output .= ui_get_full_url (
'include/javascript/datatables.min.js' ,
false ,
false ,
false
);
$output .= '" type="text/javascript"></script>' ;
// Load buttons.dataTables.min.js.
$output .= '<script src="' ;
$output .= ui_get_full_url (
'include/javascript/buttons.dataTables.min.js' ,
false ,
false ,
false
);
$output .= '" type="text/javascript"></script>' ;
// Load dataTables.buttons.min.js.
$output .= '<script src="' ;
$output .= ui_get_full_url (
'include/javascript/dataTables.buttons.min.js' ,
false ,
false ,
false
);
$output .= '" type="text/javascript"></script>' ;
// Load buttons.html5.min.js.
$output .= '<script src="' ;
$output .= ui_get_full_url (
'include/javascript/buttons.html5.min.js' ,
false ,
false ,
false
);
$output .= '" type="text/javascript"></script>' ;
// Load buttons.print.min.js.
$output .= '<script src="' ;
$output .= ui_get_full_url (
'include/javascript/buttons.print.min.js' ,
false ,
false ,
false
);
$output .= '" type="text/javascript"></script>' ;
2020-09-17 11:42:53 +02:00
}
2020-03-27 11:41:56 +01:00
if ( isset ( $parameters [ 'return' ]) && $parameters [ 'return' ] == true ) {
// Compat.
$parameters [ 'print' ] = false ;
}
2019-06-06 17:50:47 +02:00
// Print datatable if needed.
2020-03-27 11:41:56 +01:00
if ( isset ( $parameters [ 'print' ]) === false || $parameters [ 'print' ] === true ) {
2019-06-06 17:50:47 +02:00
echo $output ;
}
return $output ;
}
2019-05-29 11:21:57 +02:00
/**
* Returns a div wich represents the type received .
*
* Requires ui_require_css_file ( 'events' ); .
*
* @ param integer $type Event type .
* @ param boolean $return Or print .
* @ param boolean $mini Show mini div .
*
* @ return string HTML .
*/
function ui_print_event_type (
$type ,
$return = false ,
$mini = false
) {
global $config ;
$output = '' ;
switch ( $type ) {
case EVENTS_ALERT_FIRED :
case EVENTS_ALERT_RECOVERED :
case EVENTS_ALERT_CEASED :
case EVENTS_ALERT_MANUAL_VALIDATION :
$text = __ ( 'ALERT' );
$color = COL_ALERTFIRED ;
break ;
case EVENTS_RECON_HOST_DETECTED :
case EVENTS_SYSTEM :
case EVENTS_ERROR :
case EVENTS_NEW_AGENT :
case EVENTS_CONFIGURATION_CHANGE :
$text = __ ( 'SYSTEM' );
$color = COL_MAINTENANCE ;
break ;
case EVENTS_GOING_UP_WARNING :
case EVENTS_GOING_DOWN_WARNING :
$color = COL_WARNING ;
$text = __ ( 'WARNING' );
break ;
case EVENTS_GOING_DOWN_NORMAL :
case EVENTS_GOING_UP_NORMAL :
$color = COL_NORMAL ;
$text = __ ( 'NORMAL' );
break ;
case EVENTS_GOING_DOWN_CRITICAL :
case EVENTS_GOING_UP_CRITICAL :
$color = COL_CRITICAL ;
$text = __ ( 'CRITICAL' );
break ;
case EVENTS_UNKNOWN :
case EVENTS_GOING_UNKNOWN :
default :
$color = COL_UNKNOWN ;
$text = __ ( 'UNKNOWN' );
break ;
}
2023-01-10 10:18:37 +01:00
if ( $mini === true ) {
$output = html_print_div (
[
'class' => 'status_rounded_rectangles' ,
'style' => sprintf ( 'display: inline-block; background: %s' , $color ),
'content' => '' ,
'title' => $text ,
],
true
);
2019-05-29 11:21:57 +02:00
} else {
2019-05-29 11:24:17 +02:00
$output = '<div data-title="' ;
$output .= $text ;
$output .= '" data-use_title_for_force_title="1" ' ;
$output .= 'class="forced_title mini-criticity" ' ;
$output .= 'style="background: ' . $color . '">' ;
2019-05-29 11:21:57 +02:00
$output .= '</div>' ;
}
2023-01-10 10:18:37 +01:00
if ( $return === true ) {
return $output ;
} else {
echo $output ;
}
2019-05-29 11:21:57 +02:00
}
2019-05-28 18:03:01 +02:00
/**
* Returns a div wich represents the priority received .
*
* Requires ui_require_css_file ( 'events' ); .
*
2019-05-29 11:21:57 +02:00
* @ param integer $priority Priority level .
2019-05-28 18:03:01 +02:00
* @ param boolean $return Or print .
2019-05-29 11:21:57 +02:00
* @ param boolean $mini Show mini div .
2019-05-28 18:03:01 +02:00
*
* @ return string HTML .
*/
function ui_print_event_priority (
$priority ,
$return = false ,
$mini = false
) {
global $config ;
$output = '' ;
switch ( $priority ) {
case EVENT_CRIT_MAINTENANCE :
$color = COL_MAINTENANCE ;
$criticity = __ ( 'MAINTENANCE' );
break ;
case EVENT_CRIT_INFORMATIONAL :
$color = COL_INFORMATIONAL ;
$criticity = __ ( 'INFORMATIONAL' );
break ;
case EVENT_CRIT_NORMAL :
$color = COL_NORMAL ;
$criticity = __ ( 'NORMAL' );
break ;
case EVENT_CRIT_WARNING :
$color = COL_WARNING ;
$criticity = __ ( 'WARNING' );
break ;
case EVENT_CRIT_CRITICAL :
$color = COL_CRITICAL ;
$criticity = __ ( 'CRITICAL' );
break ;
case EVENT_CRIT_MINOR :
$color = COL_MINOR ;
$criticity = __ ( 'MINOR' );
break ;
case EVENT_CRIT_MAJOR :
$color = COL_MAJOR ;
$criticity = __ ( 'MAJOR' );
break ;
default :
$color = COL_UNKNOWN ;
$criticity = __ ( 'UNKNOWN' );
break ;
}
2023-01-10 10:18:37 +01:00
if ( $mini === true ) {
2019-05-28 18:03:01 +02:00
$output = '<div class="criticity" style="background: ' . $color . '">' ;
$output .= $criticity ;
$output .= '</div>' ;
} else {
2019-05-29 11:24:17 +02:00
$output = '<div data-title="' ;
$output .= $criticity ;
$output .= '" data-use_title_for_force_title="1" ' ;
$output .= 'class="forced_title mini-criticity" ' ;
$output .= 'style="background: ' . $color . '">' ;
2019-05-28 18:03:01 +02:00
$output .= '</div>' ;
}
return $output ;
}
2010-08-23 18:35:25 +02:00
/**
2019-05-28 10:47:31 +02:00
* Print a code into a DIV and enable a toggle to show and hide it .
*
2021-02-05 15:10:31 +01:00
* @ param string $code Html code .
* @ param string $name Name of the link .
* @ param string $title Title of the link .
* @ param string $id Block id .
* @ param boolean $hidden_default If the div will be hidden by default ( default : true ) .
* @ param boolean $return Whether to return an output string or echo now ( default : true ) .
* @ param string $toggle_class Toggle class .
* @ param string $container_class Container class .
* @ param string $main_class Main object class .
* @ param string $img_a Image ( closed ) .
* @ param string $img_b Image ( opened ) .
* @ param string $clean Do not encapsulate with class boxes , clean print .
* @ param boolean $reverseImg Reverse img .
* @ param boolean $switch Use switch .
* @ param string $attributes_switch Switch attributes .
* @ param string $toggl_attr Main box extra attributes .
* @ param boolean | null $switch_on Switch enabled disabled or depending on hidden_Default .
2021-02-22 12:01:29 +01:00
* @ param string | null $switch_name Use custom switch input name or generate one .
2023-01-26 13:25:24 +01:00
* @ param boolean | null $disableToggle If True , the toggle is disabled .
2023-01-24 09:33:47 +01:00
* @ param string $id_table ID of the table to apply w100p class .
2019-01-30 16:18:44 +01:00
*
2019-05-28 10:47:31 +02:00
* @ return string HTML .
2010-08-23 18:35:25 +02:00
*/
2019-05-28 10:47:31 +02:00
function ui_toggle (
$code ,
$name ,
$title = '' ,
2019-06-04 13:57:55 +02:00
$id = '' ,
2019-05-28 10:47:31 +02:00
$hidden_default = true ,
$return = false ,
2019-05-29 18:13:21 +02:00
$toggle_class = '' ,
2019-06-04 13:57:55 +02:00
$container_class = 'white-box-content' ,
2023-02-14 14:06:51 +01:00
$main_class = 'box-flat white_table_graph' ,
2023-02-14 16:41:24 +01:00
$img_a = 'images/arrow@svg.svg' ,
$img_b = 'images/arrow@svg.svg' ,
2020-06-30 12:16:51 +02:00
$clean = false ,
$reverseImg = false ,
$switch = false ,
2021-02-05 12:37:27 +01:00
$attributes_switch = '' ,
2021-02-05 15:10:31 +01:00
$toggl_attr = '' ,
2021-02-22 12:01:29 +01:00
$switch_on = null ,
2023-01-26 13:25:24 +01:00
$switch_name = null ,
2023-02-27 18:25:45 +01:00
$disableToggle = false ,
2023-08-16 15:12:31 +02:00
$id_table = false ,
$position_tgl_div = false
2019-05-28 10:47:31 +02:00
) {
// Generate unique Id.
2019-01-30 16:18:44 +01:00
$uniqid = uniqid ( '' );
2023-03-01 13:32:15 +01:00
$rotateA = '90deg' ;
$rotateB = '180deg' ;
2019-01-30 16:18:44 +01:00
2019-05-28 10:47:31 +02:00
// Options.
2023-02-15 14:45:28 +01:00
$style = 'overflow:hidden;width: -webkit-fill-available;width: -moz-available;' ;
2023-02-14 14:06:51 +01:00
$style = 'overflow:hidden;' ;
2023-02-14 16:41:24 +01:00
if ( $hidden_default === true ) {
2023-03-01 13:32:15 +01:00
$imageRotate = $rotateB ;
2022-11-22 14:08:40 +01:00
$style .= 'height:0;position:absolute;' ;
2019-11-07 17:26:32 +01:00
$original = $img_b ;
2019-01-30 16:18:44 +01:00
} else {
2023-03-01 13:32:15 +01:00
$imageRotate = $rotateA ;
2022-11-22 14:08:40 +01:00
$style .= 'height:auto;position:relative;' ;
2019-11-07 17:26:32 +01:00
$original = $img_a ;
2019-01-30 16:18:44 +01:00
}
2019-11-21 18:21:46 +01:00
$header_class = '' ;
if ( $clean === false ) {
$header_class = 'white_table_graph_header' ;
} else {
2023-02-14 14:06:51 +01:00
if ( $main_class == 'box-flat white_table_graph' ) {
2020-11-30 17:50:36 +01:00
// Default value, clean class.
$main_class = '' ;
}
2021-01-27 12:35:37 +01:00
if ( $container_class == 'white-box-content' ) {
2021-02-19 13:36:29 +01:00
$container_class = 'white-box-content-clean' ;
}
2019-11-21 18:21:46 +01:00
}
2019-05-28 10:47:31 +02:00
// Link to toggle.
2022-11-21 14:49:07 +01:00
$output = '<div class="' . $main_class . '" id="' . $id . '" ' . $toggl_attr . '>' ;
2023-01-26 13:25:24 +01:00
$output .= '<div class="' . $header_class . '" ' . (( $disableToggle === false ) ? 'style="cursor: pointer;" ' : '' ) . ' id="tgl_ctrl_' . $uniqid . '">' ;
2020-06-30 12:16:51 +02:00
if ( $reverseImg === false ) {
if ( $switch === true ) {
2021-01-27 12:35:37 +01:00
if ( empty ( $switch_name ) === true ) {
$switch_name = 'box_enable_toggle' . $uniqid ;
}
2020-06-30 12:16:51 +02:00
$output .= html_print_div (
[
'class' => 'float-left' ,
'content' => html_print_checkbox_switch_extended (
2021-01-27 12:35:37 +01:00
$switch_name ,
2020-06-30 12:16:51 +02:00
1 ,
2021-02-05 15:10:31 +01:00
( $switch_on === null ) ? (( $hidden_default === true ) ? 0 : 1 ) : $switch_on ,
2020-06-30 12:16:51 +02:00
false ,
'' ,
$attributes_switch ,
true
),
],
true
);
} else {
$output .= html_print_image (
$original ,
true ,
[
2023-03-17 13:20:58 +01:00
'class' => 'float-left main_menu_icon mrgn_right_10px invert_filter' ,
2023-02-14 16:41:24 +01:00
'style' => 'object-fit: contain; margin-right:10px; rotate:' . $imageRotate ,
2020-06-30 12:16:51 +02:00
'title' => $title ,
'id' => 'image_' . $uniqid ,
]
);
}
2023-02-14 16:41:24 +01:00
$output .= $name ;
2020-06-30 12:16:51 +02:00
} else {
$output .= $name ;
if ( $switch === true ) {
$output .= html_print_div (
[
'class' => 'float-left' ,
'content' => html_print_checkbox_switch_extended (
'box_enable_toggle' . $uniqid ,
1 ,
( $hidden_default === true ) ? 0 : 1 ,
false ,
'' ,
'' ,
true
),
],
true
);
} else {
$output .= html_print_image (
$original ,
true ,
[
2023-03-17 13:20:58 +01:00
'class' => 'main_menu_icon mrgn_right_10px invert_filter' ,
2023-02-14 16:41:24 +01:00
'style' => 'object-fit: contain; float:right; margin-right:10px; rotate:' . $imageRotate ,
2020-06-30 12:16:51 +02:00
'title' => $title ,
'id' => 'image_' . $uniqid ,
]
);
}
}
$output .= '</div>' ;
2019-01-30 16:18:44 +01:00
// Code into a div
2019-05-28 16:24:28 +02:00
$output .= " <div id='tgl_div_ " . $uniqid . " ' style=' " . $style . " ;margin-top: -1px;' class=' " . $toggle_class . " '> \n " ;
2019-05-29 18:13:21 +02:00
$output .= '<div class="' . $container_class . '">' ;
2019-01-30 16:18:44 +01:00
$output .= $code ;
$output .= '</div>' ;
2019-05-29 17:49:09 +02:00
$output .= '</div>' ;
2019-01-30 16:18:44 +01:00
2023-01-24 09:33:47 +01:00
$class_table = '' ;
if ( $id_table !== false ) {
2023-02-28 19:01:37 +01:00
$class_table = '$("#' . $id_table . '_wrapper").addClass("w100p");' . " \n " ;
2023-01-24 09:33:47 +01:00
}
2023-01-26 13:25:24 +01:00
if ( $disableToggle === false ) {
2023-08-16 15:12:31 +02:00
$position_div = 'relative' ;
if ( $position_tgl_div !== false ) {
$position_div = $position_tgl_div ;
}
2023-01-26 13:25:24 +01:00
// JQuery Toggle.
$output .= '<script type="text/javascript">' . " \n " ;
$output .= ' var hide_tgl_ctrl_' . $uniqid . ' = ' . ( int ) $hidden_default . " ; \n " ;
$output .= ' var is_metaconsole = ' . ( int ) is_metaconsole () . " ; \n " ;
$output .= ' /* <![CDATA[ */' . " \n " ;
$output .= " $ (document).ready (function () { \n " ;
2023-05-23 12:25:56 +02:00
$output .= ' var switch_enable = ' . ( int ) $switch . " ; \n " ;
2023-01-26 13:25:24 +01:00
$output .= " $ ('#checkbox- " . $switch_name . " ').click(function() { \n " ;
2023-05-23 12:25:56 +02:00
$output .= ' if (hide_tgl_ctrl_' . $uniqid . " ) { \n " ;
$output .= ' hide_tgl_ctrl_' . $uniqid . " = 0; \n " ;
$output .= " $ ('#tgl_div_ " . $uniqid . " ').css('height', 'auto'); \n " ;
$output .= " $ ('#tgl_div_ " . $uniqid . " ').css('position', 'relative'); \n " ;
2023-01-26 13:25:24 +01:00
$output .= " } \n " ;
$output .= " else { \n " ;
2023-05-23 12:25:56 +02:00
$output .= ' hide_tgl_ctrl_' . $uniqid . " = 1; \n " ;
$output .= " $ ('#tgl_div_ " . $uniqid . " ').css('height', 0); \n " ;
$output .= " $ ('#tgl_div_ " . $uniqid . " ').css('position', 'absolute'); \n " ;
2023-01-26 13:25:24 +01:00
$output .= " } \n " ;
$output .= " }); \n " ;
2023-05-23 12:25:56 +02:00
$output .= ' if (switch_enable === 0) {' ;
$output .= " $ ('#tgl_ctrl_ " . $uniqid . " ').click(function() { \n " ;
$output .= ' if (hide_tgl_ctrl_' . $uniqid . " ) { \n " ;
$output .= ' hide_tgl_ctrl_' . $uniqid . " = 0; \n " ;
$output .= " $ ('#tgl_div_ " . $uniqid . " ').css('height', 'auto'); \n " ;
2023-08-16 15:12:31 +02:00
$output .= " $ ('#tgl_div_ " . $uniqid . " ').css('position', ' " . $position_div . " '); \n " ;
2023-05-23 12:25:56 +02:00
$output .= " $ ('#image_ " . $uniqid . " ').attr('style', 'rotate: " . $rotateA . " '); \n " ;
$output .= " $ ('#checkbox- " . $switch_name . " ').prop('checked', true); \n " ;
$output .= $class_table ;
$output .= " } \n " ;
$output .= " else { \n " ;
$output .= ' hide_tgl_ctrl_' . $uniqid . " = 1; \n " ;
$output .= " $ ('#tgl_div_ " . $uniqid . " ').css('height', 0); \n " ;
$output .= " $ ('#tgl_div_ " . $uniqid . " ').css('position', 'absolute'); \n " ;
$output .= " $ ('#image_ " . $uniqid . " ').attr('style', 'rotate: " . $rotateB . " '); \n " ;
$output .= " $ ('#checkbox- " . $switch_name . " ').prop('checked', false); \n " ;
$output .= " } \n " ;
$output .= " }); \n " ;
$output .= " } \n " ;
2023-01-26 13:25:24 +01:00
$output .= " }); \n " ;
$output .= '/* ]]> */' ;
$output .= '</script>' ;
2023-02-27 18:25:45 +01:00
$output .= '</div>' ;
2023-01-26 13:25:24 +01:00
}
2019-01-30 16:18:44 +01:00
if ( ! $return ) {
echo $output ;
} else {
return $output ;
}
2010-08-23 18:35:25 +02:00
}
2009-04-21 21:03:16 +02:00
2019-01-30 16:18:44 +01:00
2019-11-07 17:26:32 +01:00
/**
* Simplified way of ui_toggle ussage .
*
2021-02-19 13:36:29 +01:00
* @ param array $data Arguments :
2021-01-25 19:29:22 +01:00
* - content
* - name
* - title
* - id
* - hidden_default
* - return
* - toggle_class
* - container_class
* - main_class
* - img_a
* - img_b
2021-01-27 12:35:37 +01:00
* - clean
* - reverseImg
* - switch
* - attributes_switch
2021-02-22 12:01:29 +01:00
* - toggl_attr
* - switch_on
2021-01-27 12:35:37 +01:00
* - switch_name .
2019-11-07 17:26:32 +01:00
*
* @ return string HTML code with toggle content .
*/
function ui_print_toggle ( $data )
{
return ui_toggle (
$data [ 'content' ],
$data [ 'name' ],
( isset ( $data [ 'title' ]) === true ) ? $data [ 'title' ] : '' ,
( isset ( $data [ 'id' ]) === true ) ? $data [ 'id' ] : '' ,
( isset ( $data [ 'hidden_default' ]) === true ) ? $data [ 'hidden_default' ] : true ,
( isset ( $data [ 'return' ]) === true ) ? $data [ 'return' ] : false ,
( isset ( $data [ 'toggle_class' ]) === true ) ? $data [ 'toggle_class' ] : '' ,
( isset ( $data [ 'container_class' ]) === true ) ? $data [ 'container_class' ] : 'white-box-content' ,
2023-02-14 14:06:51 +01:00
( isset ( $data [ 'main_class' ]) === true ) ? $data [ 'main_class' ] : 'box-flat white_table_graph' ,
2023-03-08 19:25:25 +01:00
( isset ( $data [ 'img_a' ]) === true ) ? $data [ 'img_a' ] : 'images/arrow@svg.svg' ,
( isset ( $data [ 'img_b' ]) === true ) ? $data [ 'img_b' ] : 'images/arrow@svg.svg' ,
2021-02-05 12:37:27 +01:00
( isset ( $data [ 'clean' ]) === true ) ? $data [ 'clean' ] : false ,
( isset ( $data [ 'reverseImg' ]) === true ) ? $data [ 'reverseImg' ] : false ,
( isset ( $data [ 'switch' ]) === true ) ? $data [ 'switch' ] : false ,
( isset ( $data [ 'attributes_switch' ]) === true ) ? $data [ 'attributes_switch' ] : '' ,
2021-02-05 15:10:31 +01:00
( isset ( $data [ 'toggl_attr' ]) === true ) ? $data [ 'toggl_attr' ] : '' ,
2021-02-22 12:01:29 +01:00
( isset ( $data [ 'switch_on' ]) === true ) ? $data [ 'switch_on' ] : null ,
2021-01-27 12:35:37 +01:00
( isset ( $data [ 'switch_name' ]) === true ) ? $data [ 'switch_name' ] : null
2019-11-07 17:26:32 +01:00
);
}
2009-04-21 21:03:16 +02:00
/**
* Construct and return the URL to be used in order to refresh the current page correctly .
*
2019-05-28 10:47:31 +02:00
* @ param array $params Extra parameters to be added to the URL . It has prevalence over
* GET and POST . False values will be ignored .
* @ param boolean $relative Whether to return the relative URL or the absolute URL . Returns
* relative by default .
* @ param boolean $add_post Whether to add POST values to the URL .
*
* @ return string Url .
2012-09-10 17:51:47 +02:00
*/
2019-01-30 16:18:44 +01:00
function ui_get_url_refresh ( $params = false , $relative = true , $add_post = true )
{
2019-05-28 10:47:31 +02:00
// Agent selection filters and refresh.
2019-01-30 16:18:44 +01:00
global $config ;
2019-05-28 10:47:31 +02:00
// Slerena, 8/Ene/2015 - Need to put index.php on URL which have it.
2019-01-30 16:18:44 +01:00
if ( strpos ( $_SERVER [ 'REQUEST_URI' ], 'index.php' ) === false ) {
$url = '' ;
} else {
$url = 'index.php' ;
}
2019-05-28 10:47:31 +02:00
if ( count ( $_REQUEST )) {
// Some (old) browsers don't like the ?&key=var.
2019-01-30 16:18:44 +01:00
$url .= '?' ;
}
if ( ! is_array ( $params )) {
$params = [];
}
2019-05-28 10:47:31 +02:00
// Avoid showing login info.
2019-01-30 16:18:44 +01:00
$params [ 'pass' ] = false ;
$params [ 'nick' ] = false ;
$params [ 'unnamed' ] = false ;
2019-05-28 10:47:31 +02:00
// We don't clean these variables up as they're only being passed along.
2019-01-30 16:18:44 +01:00
foreach ( $_GET as $key => $value ) {
if ( isset ( $params [ $key ])) {
continue ;
}
if ( strstr ( $key , 'create' )) {
continue ;
}
if ( strstr ( $key , 'update' )) {
continue ;
}
if ( strstr ( $key , 'new' )) {
continue ;
}
if ( strstr ( $key , 'delete' )) {
continue ;
}
if ( is_array ( $value )) {
foreach ( $value as $k => $v ) {
$url .= $key . '[' . $k . ']=' . $v . '&' ;
}
} else {
2023-07-26 14:18:20 +02:00
$aux = ( empty ( $value ) === false )
? io_safe_input ( rawurlencode ( $value ))
: '' ;
$url .= $key . '=' . $aux . '&' ;
2019-01-30 16:18:44 +01:00
}
}
if ( $add_post ) {
foreach ( $_POST as $key => $value ) {
if ( isset ( $params [ $key ])) {
continue ;
}
if ( strstr ( $key , 'create' )) {
continue ;
}
if ( strstr ( $key , 'update' )) {
continue ;
}
if ( strstr ( $key , 'new' )) {
continue ;
}
if ( strstr ( $key , 'delete' )) {
continue ;
}
if ( is_array ( $value )) {
foreach ( $value as $k => $v ) {
$url .= $key . '[' . $k . ']=' . $v . '&' ;
}
} else {
$url .= $key . '=' . $value . '&' ;
}
}
}
foreach ( $params as $key => $value ) {
if ( $value === false ) {
continue ;
}
if ( is_array ( $value )) {
foreach ( $value as $k => $v ) {
$url .= $key . '[' . $k . ']=' . $v . '&' ;
}
} else {
$url .= $key . '=' . $value . '&' ;
}
}
2019-05-28 10:47:31 +02:00
// Removes final &.
2019-01-30 16:18:44 +01:00
$pos = strrpos ( $url , '&' , 0 );
if ( $pos ) {
$url = substr_replace ( $url , '' , $pos , 5 );
}
2023-06-28 17:21:06 +02:00
$url = ( isset ( $params [ 'alert_flag' ]) && $params [ 'alert_flag' ]) ? $url : htmlspecialchars ( $url );
2019-01-30 16:18:44 +01:00
if ( ! $relative ) {
2019-08-21 09:22:13 +02:00
return ui_get_full_url ( $url , false , false , false );
2019-01-30 16:18:44 +01:00
}
return $url ;
2009-04-21 21:03:16 +02:00
}
2009-05-07 16:44:26 +02:00
2019-01-30 16:18:44 +01:00
2019-07-02 14:17:53 +02:00
/**
* Checks if public_url usage is being forced to target 'visitor' .
*
* @ return boolean
*/
function ui_forced_public_url ()
{
global $config ;
2020-11-25 20:16:30 +01:00
$exclusions = [];
if ( empty ( $config [ 'public_url_exclusions' ]) === false ) {
$exclusions = preg_split ( " /[ \n \ s,]+/ " , io_safe_output ( $config [ 'public_url_exclusions' ]));
}
2019-07-02 14:17:53 +02:00
2022-01-21 17:39:11 +01:00
if ( isset ( $_SERVER [ 'REMOTE_ADDR' ]) === true
&& in_array ( $_SERVER [ 'REMOTE_ADDR' ], $exclusions )
) {
2019-07-02 14:17:53 +02:00
return false ;
}
2020-11-25 20:16:30 +01:00
return isset ( $config [ 'force_public_url' ]) && ( bool ) $config [ 'force_public_url' ];
2019-07-02 14:17:53 +02:00
}
2021-06-24 19:48:07 +02:00
/**
* Returns a full built url for given section .
*
* @ param string $url
* @ return void
*/
function ui_get_meta_url ( $url )
{
global $config ;
if ( is_metaconsole () === true ) {
return ui_get_full_url ( $url );
}
$mc_db_conn = \enterprise_hook (
'metaconsole_load_external_db' ,
[
[
'dbhost' => $config [ 'replication_dbhost' ],
'dbuser' => $config [ 'replication_dbuser' ],
'dbpass' => \io_output_password (
$config [ 'replication_dbpass' ]
),
'dbname' => $config [ 'replication_dbname' ],
],
]
);
if ( $mc_db_conn === NOERR ) {
$public_url_meta = \db_get_value (
'value' ,
'tconfig' ,
'token' ,
'public_url' ,
false ,
false
);
// Restore the default connection.
\enterprise_hook ( 'metaconsole_restore_db' );
if ( empty ( $public_url_meta ) === false
&& $public_url_meta !== $config [ 'metaconsole_base_url' ]
) {
config_update_value (
'metaconsole_base_url' ,
$public_url_meta
);
}
}
if ( isset ( $config [ 'metaconsole_base_url' ]) === true ) {
return $config [ 'metaconsole_base_url' ] . 'enterprise/meta/' . $url ;
}
return $url ;
}
2009-05-07 16:44:26 +02:00
/**
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
* Returns a full URL in Pandora . ( with the port and https in some systems )
2009-05-07 16:44:26 +02:00
*
* An example of full URL is http :/ localhost / pandora_console / index . php ? sec = gsetup & sec2 = godmode / setup / setup
*
2019-05-28 10:47:31 +02:00
* @ param mixed $url If provided , it will be added after the index . php , but it is false boolean value , put the homeurl in the url .
* @ param boolean $no_proxy To avoid the proxy checks , by default it is false .
* @ param boolean $add_name_php_file Something .
* @ param boolean $metaconsole_root Set the root to the metaconsole dir if the metaconsole is enabled , true by default .
2009-05-07 16:44:26 +02:00
*
* @ return string A full URL in Pandora .
*/
2019-01-30 16:18:44 +01:00
function ui_get_full_url ( $url = '' , $no_proxy = false , $add_name_php_file = false , $metaconsole_root = true )
{
global $config ;
$port = null ;
2019-05-28 10:47:31 +02:00
// Null means 'use the starndard port'.
2019-01-30 16:18:44 +01:00
$proxy = false ;
// By default Pandora FMS doesn't run across proxy.
if ( isset ( $_SERVER [ 'HTTP_X_FORWARDED_PROTO' ])
&& $_SERVER [ 'HTTP_X_FORWARDED_PROTO' ] == 'https'
) {
$_SERVER [ 'HTTPS' ] = 'on' ;
}
if ( isset ( $_SERVER [ 'HTTPS' ])
&& ( $_SERVER [ 'HTTPS' ] === true
|| $_SERVER [ 'HTTPS' ] == 'on' )
) {
$protocol = 'https' ;
if ( $_SERVER [ 'SERVER_PORT' ] != 443 ) {
$port = $_SERVER [ 'SERVER_PORT' ];
}
} else if ( $config [ 'https' ]) {
2019-05-28 10:47:31 +02:00
// When $config["https"] is set, enforce https.
2019-01-30 16:18:44 +01:00
$protocol = 'https' ;
} else {
$protocol = 'http' ;
2022-01-21 17:39:11 +01:00
if (( $_SERVER [ 'SERVER_PORT' ] ? ? 80 ) != 80 ) {
2019-01-30 16:18:44 +01:00
$port = $_SERVER [ 'SERVER_PORT' ];
}
}
if ( ! $no_proxy ) {
2019-07-02 14:17:53 +02:00
// Check proxy.
$proxy = false ;
if ( ui_forced_public_url ()) {
$proxy = true ;
$fullurl = $config [ 'public_url' ];
2019-07-31 10:59:51 +02:00
if ( substr ( $fullurl , - 1 ) != '/' ) {
$fullurl .= '/' ;
}
2019-07-02 14:17:53 +02:00
} else if ( ! empty ( $config [ 'public_url' ])
2019-01-30 16:18:44 +01:00
&& ( ! empty ( $_SERVER [ 'HTTP_X_FORWARDED_HOST' ]))
) {
2019-07-02 14:17:53 +02:00
// Forced to use public url when being forwarder by a reverse proxy.
2019-01-30 16:18:44 +01:00
$fullurl = $config [ 'public_url' ];
2019-07-31 10:59:51 +02:00
if ( substr ( $fullurl , - 1 ) != '/' ) {
$fullurl .= '/' ;
}
2019-01-30 16:18:44 +01:00
$proxy = true ;
} else {
2022-01-21 17:39:11 +01:00
$fullurl = $protocol . '://' . ( $_SERVER [ 'SERVER_NAME' ] ? ? '' );
2019-01-30 16:18:44 +01:00
}
} else {
2022-01-21 17:39:11 +01:00
$fullurl = $protocol . '://' . ( $_SERVER [ 'SERVER_NAME' ] ? ? '' );
2019-01-30 16:18:44 +01:00
}
2019-05-28 10:47:31 +02:00
// Using a different port than the standard.
2019-01-30 16:18:44 +01:00
if ( ! $proxy ) {
2019-05-28 10:47:31 +02:00
// Using a different port than the standard.
2019-01-30 16:18:44 +01:00
if ( $port != null ) {
$fullurl .= ':' . $port ;
}
}
2021-10-06 15:07:46 +02:00
$skip_meta_tag = false ;
2019-01-30 16:18:44 +01:00
if ( $url === '' ) {
2021-10-06 15:07:46 +02:00
if ( $proxy === false ) {
2019-01-30 16:18:44 +01:00
$url = $_SERVER [ 'REQUEST_URI' ];
2021-10-06 15:07:46 +02:00
// Already inserted in request_uri.
$skip_meta_tag = true ;
2019-01-30 16:18:44 +01:00
} else {
2021-10-06 15:07:46 +02:00
// Redirect to main.
$url = '?' . $_SERVER [ 'QUERY_STRING' ];
2019-01-30 16:18:44 +01:00
}
2021-10-06 15:13:21 +02:00
} else if ( empty ( $url ) === true ) {
if ( $proxy === false ) {
$url = $config [ 'homeurl_static' ] . '/' ;
2021-10-07 12:25:41 +02:00
if ( $metaconsole_root === true
&& is_metaconsole ()
) {
2021-10-06 15:13:21 +02:00
$url = $config [ 'homeurl_static' ] . '/' . ENTERPRISE_DIR . '/meta/' ;
}
2019-01-30 16:18:44 +01:00
2021-10-06 15:13:21 +02:00
$skip_meta_tag = true ;
} else {
$url = '' ;
2019-01-30 16:18:44 +01:00
}
} else if ( ! strstr ( $url , '.php' )) {
if ( $proxy ) {
$fullurl .= '/' ;
} else {
$fullurl .= $config [ 'homeurl_static' ] . '/' ;
}
} else {
2021-10-05 17:03:06 +02:00
if (( bool ) $proxy === false ) {
2019-01-30 16:18:44 +01:00
if ( $add_name_php_file ) {
$fullurl .= $_SERVER [ 'SCRIPT_NAME' ];
} else {
$fullurl .= $config [ 'homeurl_static' ] . '/' ;
}
}
}
2021-10-05 15:09:30 +02:00
// Add last slash if missing.
if ( substr ( $fullurl , - 1 , 1 ) !== '/' ) {
$fullurl .= '/' ;
}
// Remove starting slash if present.
if ( substr ( $url , 0 , 1 ) === '/' ) {
$url = substr ( $url , 1 );
2019-01-30 16:18:44 +01:00
}
2021-10-06 15:07:46 +02:00
if ( $skip_meta_tag === false
&& $metaconsole_root
&& is_metaconsole ()
) {
2021-10-06 15:13:21 +02:00
$fullurl .= ENTERPRISE_DIR . '/meta/' ;
2019-01-30 16:18:44 +01:00
}
return $fullurl . $url ;
2009-05-07 16:44:26 +02:00
}
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
2021-04-29 13:28:03 +02:00
/**
* Generates the Pandora 75 x Standard views header .
* This function should be the standard for
* generating the headers of all PFMS views .
*
* @ param string $title The title of this view .
* @ param string $icon Icon for show .
* @ param boolean $return If true , the string with the formed header is returned .
* @ param string $help String for attach at end a link for help .
* @ param boolean $godmode If false , it will created like operation mode .
* @ param array $options Tabs allowed
* @ param array $breadcrumbs Breadcrumbs with the walk .
*
* EXAMPLE :
* `` `
* $buttons [ 'option_1' ] = [
* 'active' => false ,
* 'text' => '<a href="' . $url . '">' . html_print_image (
* 'images/wand.png' ,
* true ,
* [ 'title' => __ ( 'Option 1 for show' ), 'class' => 'invert_filter' ]
* ) . '</a>' ,
* ];
*
* ui_print_standard_header (
* __ ( 'Favorites' ),
* 'images/op_reporting.png' ,
* false ,
* '' ,
* true ,
* $buttons ,
* [
* [ 'link' => '' , 'label' => __ ( 'Topology maps' ) ],
* [ 'link' => '' , 'label' => __ ( 'Visual console' ) ],
* ]
* );
* `` `
*
* @ return string If apply
*/
function ui_print_standard_header (
string $title ,
string $icon = '' ,
bool $return = false ,
string $help = '' ,
bool $godmode = false ,
array $options = [],
2023-02-23 09:48:13 +01:00
array $breadcrumbs = [],
array $fav_menu_config = []
2021-04-29 13:28:03 +02:00
) {
2021-05-28 13:47:14 +02:00
// For standard breadcrumbs.
ui_require_css_file ( 'discovery' );
2021-04-29 13:28:03 +02:00
// Create the breadcrumb.
$headerInformation = new HTML ();
$headerInformation -> setBreadcrum ([]);
// Prepare the breadcrumbs.
$countBreadcrumbs = count ( $breadcrumbs );
$countUnitBreadcrumb = 0 ;
$applyBreadcrumbs = [];
foreach ( $breadcrumbs as $unitBreadcrumb ) {
// Count new breadcrumb.
$countUnitBreadcrumb ++ ;
// Apply selected if is the last.
$unitBreadcrumb [ 'selected' ] = ( $countBreadcrumbs === $countUnitBreadcrumb );
// Apply for another breadcrumb.
$applyBreadcrumbs [] = $unitBreadcrumb ;
}
// Attach breadcrumbs.
$headerInformation -> prepareBreadcrum (
$applyBreadcrumbs ,
true
);
2023-03-21 14:06:28 +01:00
$output = ui_print_page_header (
$title ,
$icon ,
true ,
$help ,
$godmode ,
$options ,
false ,
'' ,
GENERIC_SIZE_TEXT ,
'' ,
$headerInformation -> printHeader ( true ),
false ,
$fav_menu_config
);
2021-04-29 13:28:03 +02:00
if ( $return !== true ) {
echo $output ;
} else {
return $output ;
}
}
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
/**
* Return a standard page header ( Pandora FMS 3.1 version )
*
2022-03-09 17:20:24 +01:00
* @ param string $title Title .
* @ param string $icon Icon path .
* @ param boolean $return Return ( false will print using a echo ) .
* @ param boolean $help Help ( Help ID to print the Help link ) .
* @ param boolean $godmode Godmode ( false = operation mode ) .
* @ param string $options Options ( HTML code for make tabs or just a brief
* info string .
* @ param mixed $modal Modal .
* @ param mixed $message Message .
* @ param mixed $numChars NumChars .
* @ param mixed $alias Alias .
* @ param mixed $breadcrumbs Breadcrumbs .
* @ param boolean $hide_left_small Hide title id screen is small .
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
* @ return string Header HTML
*/
2019-01-30 16:18:44 +01:00
function ui_print_page_header (
$title ,
$icon = '' ,
$return = false ,
$help = '' ,
$godmode = false ,
$options = '' ,
$modal = false ,
$message = '' ,
$numChars = GENERIC_SIZE_TEXT ,
2019-03-26 15:42:33 +01:00
$alias = '' ,
2022-03-09 17:20:24 +01:00
$breadcrumbs = '' ,
2023-02-23 09:48:13 +01:00
$hide_left_small = false ,
$fav_menu_config = []
2019-01-30 16:18:44 +01:00
) {
2023-03-13 10:29:03 +01:00
global $config ;
2019-01-30 16:18:44 +01:00
$title = io_safe_input_html ( $title );
if (( $icon == '' ) && ( $godmode == true )) {
$icon = 'images/gm_setup.png' ;
}
if (( $icon == '' ) && ( $godmode == false )) {
$icon = '' ;
}
if ( $godmode == true ) {
$type = 'view' ;
2019-05-30 18:21:13 +02:00
$type2 = 'menu_tab_frame_view' ;
2019-01-30 16:18:44 +01:00
$separator_class = 'separator' ;
2023-03-13 10:29:03 +01:00
$div_style = '' ;
2019-01-30 16:18:44 +01:00
} else {
$type = 'view' ;
2019-05-30 18:21:13 +02:00
$type2 = 'menu_tab_frame_view' ;
2019-01-30 16:18:44 +01:00
$separator_class = 'separator_view' ;
2023-03-13 10:29:03 +01:00
$div_style = '' ;
if ( $config [ 'pure' ] === true ) {
$div_style = 'top:0px;' ;
}
2019-01-30 16:18:44 +01:00
}
2023-03-13 10:29:03 +01:00
$buffer = '<div id="' . $type2 . '" style="' . $div_style . '" >' ;
2019-03-26 15:42:33 +01:00
2019-03-27 12:11:23 +01:00
if ( ! empty ( $breadcrumbs )) {
2019-05-27 19:00:48 +02:00
$buffer .= '<div class="menu_tab_left_bc">' ;
$buffer .= '<div class="breadcrumbs_container">' . $breadcrumbs . '</div>' ;
2019-03-27 12:11:23 +01:00
}
2019-03-26 15:42:33 +01:00
2022-03-23 17:55:52 +01:00
$buffer .= '<div id="menu_tab_left">' ;
2019-01-30 16:18:44 +01:00
$buffer .= '<ul class="mn"><li class="' . $type . '">' ;
if ( strpos ( $title , 'Monitoring » Services »' ) != - 1 ) {
$title = str_replace ( 'Monitoring » Services » Service Map » ' , '' , $title );
}
$buffer .= '<span>' ;
2022-03-21 10:04:11 +01:00
$buffer .= '<span class="breadcrumbs-title">' ;
2019-01-30 16:18:44 +01:00
if ( empty ( $alias )) {
$buffer .= ui_print_truncate_text ( $title , $numChars );
} else {
$buffer .= ui_print_truncate_text ( $alias , $numChars );
}
2022-03-21 10:04:11 +01:00
$buffer .= '</span>' ;
2022-11-21 23:47:18 +01:00
if ( $modal && enterprise_installed () === false ) {
2019-01-30 16:18:44 +01:00
$buffer .= "
2021-03-31 10:29:57 +02:00
< div id = '".$message."' class = 'publienterprise right mrgn_top-2px' title = 'Community version' >< img data - title = '".__(' Enterprise version not installed ')."' class = 'img_help forced_title' data - use_title_for_force_title = '1' src = 'images/alert_enterprise.png' ></ div >
2016-09-19 16:20:18 +02:00
" ;
2019-01-30 16:18:44 +01:00
}
2022-11-21 23:47:18 +01:00
if ( is_metaconsole () === false ) {
2019-01-30 16:18:44 +01:00
if ( $help != '' ) {
2023-03-07 11:14:10 +01:00
$buffer .= " <div class='head_help head_tip'> " . ui_print_help_icon ( $help , true , '' , '' , false , '' , true ) . '</div>' ;
2019-01-30 16:18:44 +01:00
}
}
2023-03-14 09:42:26 +01:00
if ( is_array ( $fav_menu_config ) === true && is_metaconsole () === false ) {
2023-02-23 09:48:13 +01:00
if ( count ( $fav_menu_config ) > 0 ) {
$buffer .= ui_print_fav_menu (
$fav_menu_config [ 'id_element' ],
$fav_menu_config [ 'url' ],
$fav_menu_config [ 'label' ],
$fav_menu_config [ 'section' ]
);
}
}
2019-01-30 16:18:44 +01:00
$buffer .= '</span>' ;
2022-11-21 23:47:18 +01:00
if ( is_metaconsole () === true ) {
2019-01-30 16:18:44 +01:00
if ( $help != '' ) {
$buffer .= " <div class='head_help'> " . ui_print_help_icon ( $help , true , '' , 'images/help_30.png' ) . '</div>' ;
}
}
$buffer .= '</li></ul></div>' ;
2019-05-27 19:00:48 +02:00
if ( ! empty ( $breadcrumbs )) {
$buffer .= '</div>' ;
}
2019-01-30 16:18:44 +01:00
if ( is_array ( $options )) {
$buffer .= '<div id="menu_tab"><ul class="mn">' ;
foreach ( $options as $key => $option ) {
if ( empty ( $option )) {
continue ;
} else if ( $key === 'separator' ) {
continue ;
// $buffer .= '<li class='.$separator_class.'>';
// $buffer .= '</li>';
} else {
if ( is_array ( $option )) {
$class = 'nomn' ;
if ( isset ( $option [ 'active' ])) {
if ( $option [ 'active' ]) {
$class = 'nomn_high' ;
}
}
2019-05-28 10:47:31 +02:00
// Tabs forced to other styles.
2019-01-30 16:18:44 +01:00
if ( isset ( $option [ 'godmode' ]) && $option [ 'godmode' ]) {
$class .= ' tab_godmode' ;
} else if ( isset ( $option [ 'operation' ]) && ( $option [ 'operation' ])) {
$class .= ' tab_operation' ;
} else {
2019-05-28 10:47:31 +02:00
$class .= ( $godmode ) ? ' tab_godmode' : ' tab_operation' ;
2019-01-30 16:18:44 +01:00
}
2021-03-11 15:40:23 +01:00
$buffer .= '<li class="' . $class . ' ">' ;
2019-01-30 16:18:44 +01:00
$buffer .= $option [ 'text' ];
if ( isset ( $option [ 'sub_menu' ])) {
$buffer .= $option [ 'sub_menu' ];
}
$buffer .= '</li>' ;
} else {
$buffer .= '<li class="nomn">' ;
$buffer .= $option ;
$buffer .= '</li>' ;
}
}
}
$buffer .= '</ul></div>' ;
} else {
if ( $options != '' ) {
$buffer .= '<div id="menu_tab"><ul class="mn"><li>' ;
$buffer .= $options ;
$buffer .= '</li></ul></div>' ;
}
}
$buffer .= '</div>' ;
2022-03-23 17:55:52 +01:00
if ( $hide_left_small ) {
$buffer .= ' < script >
$ ( window ) . resize ( function () {
hideLeftHeader ()
});
$ ( document ) . ready ( function () {
hideLeftHeader ();
});
function hideLeftHeader () {
var right_width = 0 ;
$ ( " #menu_tab " ) . find ( " li " ) . each ( function ( index ) {
right_width += parseInt ( $ ( this ) . outerWidth (), 10 );
});
if ( $ ( " #menu_tab " ) . outerWidth () < right_width ) {
$ ( " #menu_tab_left " ) . children () . hide ()
} else {
$ ( " #menu_tab_left " ) . children () . show ();
}
}
</ script > ' ;
}
2019-01-30 16:18:44 +01:00
if ( ! $return ) {
echo $buffer ;
}
return $buffer ;
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
}
2012-09-20 15:45:23 +02:00
/**
* Print a input for agent autocomplete , this input search into your
* pandora DB ( or pandoras DBs when you have metaconsole ) for agents
* that have name near to equal that you are writing into the input .
2019-01-30 16:18:44 +01:00
*
2012-09-20 15:45:23 +02:00
* This generate a lot of lines of html and javascript code .
*
2019-05-28 10:47:31 +02:00
* @ param array $parameters Array with several properties :
* - $parameters [ 'return' ] boolean , by default is false
* true - return as html string the code ( html and js )
* false - print the code .
*
* - $parameters [ 'input_name' ] the input name ( needs to get the value )
* string - The name .
* default - " agent_autocomplete_<aleatory_uniq_raw_letters/numbers> "
*
* - $parameters [ 'input_id' ] the input id ( needs to get the value )
* string - The ID .
* default - " text-<input_name> "
*
* - $parameters [ 'selectbox_group' ] the id of selectbox with the group
* string - The ID of selectbox .
* default - " " empty string
*
* - $parameters [ 'icon_image' ] the small icon to show into the input in
* the right side .
* string - The url for the image .
* default - " images/lightning.png "
*
* - $parameters [ 'value' ] The initial value to set the input .
* string - The value .
* default - " " emtpy string
*
* - $parameters [ 'show_helptip' ] boolean , by default is false
* true - print the icon out the field in side right the tiny star
* for tip .
* false - does not print
*
* - $parameters [ 'helptip_text' ] The text to show in the tooltip .
* string - The text to show into the tooltip .
* default - " Type at least two characters to search. " ( translate )
*
* - $parameters [ 'use_hidden_input_idagent' ] boolean , Use a field for
* store the id of agent from the ajax query . By default is false .
* true - Use the field for id agent and the sourcecode work with
* this .
* false - Doesn 't use the field (maybe this doesn' t exist outer )
*
* - $parameters [ 'print_hidden_input_idagent' ] boolean , Print a field
* for store the id of agent from the ajax query . By default is
* false .
* true - Print the field for id agent and the sourcecode work with
* this .
* false - Doesn 't print the field (maybe this doesn' t exist outer )
*
* - $parameters [ 'hidden_input_idagent_name' ] The name of hidden input
* for to store the id agent .
* string - The name of hidden input .
* default - " agent_autocomplete_idagent_<aleatory_uniq_raw_letters/numbers> "
*
* - $parameters [ 'hidden_input_idagent_id' ] The id of hidden input
* for to store the id agent .
* string - The id of hidden input .
* default - " hidden-<hidden_input_idagent_name> "
*
* - $parameters [ 'hidden_input_idagent_value' ] The initial value to set
* the input id agent for store the id agent .
* string - The value .
* default - 0
*
* - $parameters [ 'size' ] The size in characters for the input of agent .
* string - A number of characters .
* default - 30
*
* - $parameters [ 'maxlength' ] The max characters that can store the
* input of agent .
* string - A number of characters max to store
* default - 100
*
* - $parameters [ 'disabled' ] Set as disabled the input of agent . By
* default is false
* true - Set disabled the input of agent .
* false - Set enabled the input of agent .
*
* - $parameters [ 'selectbox_id' ] The id of select box that stores the
* list of modules of agent select .
* string - The id of select box .
* default - " id_agent_module "
*
* - $parameters [ 'add_none_module' ] Boolean , add the list of modules
* the " none " entry , with value 0. By default is true
* true - add the none entry .
* false - does not add the none entry .
*
* - $parameters [ 'none_module_text' ] Boolean , add the list of modules
* the " none " entry , with value 0.
* string - The text to put for none module for example " select a
* module "
* default - " none " ( translate )
*
* - $parameters [ 'print_input_server' ] Boolean , print the hidden field
* to store the server ( metaconsole ) . By default false .
* true - Print the hidden input for the server .
* false - Does not print .
*
* - $parameters [ 'use_input_server' ] Boolean , use the hidden field
* to store the server ( metaconsole ) . By default false .
* true - Use the hidden input for the server .
* false - Does not print .
*
* - $parameters [ 'input_server_name' ] The name for hidden field to
* store the server .
* string - The name of field for server .
* default - " server_<aleatory_uniq_raw_letters/numbers> "
*
* - $parameters [ 'input_server_id' ] The id for hidden field to store
* the server .
* string - The id of field for server .
* default - " hidden-<input_server_name> "
*
* - $parameters [ 'input_server_value' ] The value to store into the
* field server .
* string - The name of server .
* default - " " empty string
*
* - $parameters [ 'metaconsole_enabled' ] Boolean , set the sourcecode for
* to make some others things that run of without metaconsole . By
* default false .
* true - Set the gears for metaconsole .
* false - Run as without metaconsole .
*
* - $parameters [ 'javascript_ajax_page' ] The page to send the ajax
* queries .
* string - The url to ajax page , remember the url must be into your
* domain ( ajax security ) .
* default - " ajax.php "
*
* - $parameters [ 'javascript_function_action_after_select' ] The name of
* function to call after the user select a agent into the list in
* the autocomplete field .
* string - The name of function .
* default - " "
*
* - $parameters [ 'javascript_function_action_after_select_js_call' ] The
* call of this function to call after user select a agent into the
* list in the autocomplete field . Instead the
* $parameters [ 'javascript_function_action_after_select' ], this is
* overwrite the previous element . And this is necesary when you need
* to set some params in your custom function .
* string - The call line as javascript code .
* default - " "
*
* - $parameters [ 'javascript_function_action_into_source' ] The source
* code as block string to call when the autocomplete starts to get
* the data from ajax .
* string - A huge string with your function as javascript .
* default - " "
*
* - $parameters [ 'javascript' ] Boolean , set the autocomplete agent to
* use javascript or enabled javascript . By default true .
* true - Enabled the javascript .
* false - Disabled the javascript .
*
* - $parameters [ 'javascript_is_function_select' ] Boolean , set to
* enable to call a function when user select a agent in the
* autocomplete list . By default false .
* true - Enabled this feature .
* false - Disabled this feature .
*
* - $parameters [ 'javascript_code_function_select' ] The name of
* function to call when user select a agent in the autocomplete
* list .
* string - The name of function but remembers this function pass
* the parameter agent_name .
* default - " function_select_<input_name> "
*
* - $parameters [ 'javascript_name_function_select' ] The source
* code as block string to call when user select a agent into the
* list in the autocomplete field . Althought use this element , you
* need use the previous parameter to set name of your custom
* function or call line .
* string - A huge string with your function as javascript .
* default - A lot of lines of source code into a string , please this
* lines you can read in the source code of function .
*
* - $parameters [ 'javascript_change_ajax_params' ] The params to pass in
* the ajax query for the list of agents .
* array - The associative array with the key and value to pass in
* the ajax query .
* default - A lot of lines of source code into a string , please this
* lines you can read in the source code of function .
*
* - $parameters [ 'javascript_function_change' ] The source code as block
* string with all javascript code to run autocomplete field .
* string - The source code javascript into a string .
* default - A lot of lines of source code into a string , please this
* lines you can read in the source code of function .
*
* - $parameters [ 'javascript_document_ready' ] Boolean , set the
* javascript sourcecode to run with the document is ready . By
* default is true .
* true - Set to run when document is ready .
* false - Not set to run .
*
* - $parameters [ 'javascript_tags' ] Boolean , print the html tags for
* javascript . By default is true .
* true - Print the javascript tags .
* false - Doesn ' t print the tags .
*
* - $parameters [ 'javascript_tags' ] Boolean , print the html tags for
* javascript . By default is true .
* true - Print the javascript tags .
* false - Doesn ' t print the tags .
2012-09-20 15:45:23 +02:00
*
2022-11-21 14:49:07 +01:00
* - $parameters [ 'input_style' ] String , Set additional styles to input .
*
2012-09-20 15:45:23 +02:00
* @ return string HTML code if return parameter is true .
*/
2019-01-30 16:18:44 +01:00
function ui_print_agent_autocomplete_input ( $parameters )
{
global $config ;
2021-03-18 10:03:52 +01:00
$text_color = '' ;
2019-01-30 16:18:44 +01:00
// Normalize and extract the data from $parameters
2019-05-28 10:47:31 +02:00
// ------------------------------------------------------------------.
2019-01-30 16:18:44 +01:00
$return = false ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'return' ])) {
$return = $parameters [ 'return' ];
}
$input_name = uniqid ( 'agent_autocomplete_' );
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'input_name' ])) {
$input_name = $parameters [ 'input_name' ];
}
$input_id = 'text-' . $input_name ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'input_id' ])) {
$input_id = $parameters [ 'input_id' ];
}
$selectbox_group = '' ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'selectbox_group' ])) {
$selectbox_group = $parameters [ 'selectbox_group' ];
}
2019-05-28 10:47:31 +02:00
// Default value.
2022-12-14 09:09:46 +01:00
$icon_agent = 'images/agents@svg.svg' ;
2021-03-11 15:40:23 +01:00
2022-01-17 10:22:30 +01:00
if ( $config [ 'style' ] === 'pandora_black' && ! is_metaconsole ()) {
2021-03-18 10:03:52 +01:00
$text_color = 'style="color: white"' ;
2021-03-11 15:40:23 +01:00
$icon_agent = 'images/agent_mc.menu.png' ;
2023-06-14 11:11:22 +02:00
$background_results = 'background: #111;' ;
} else {
$background_results = 'background: #a8e7eb;' ;
2021-03-11 15:40:23 +01:00
}
$icon_image = html_print_image ( $icon_agent , true , false , true );
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'icon_image' ])) {
$icon_image = $parameters [ 'icon_image' ];
}
$value = '' ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'value' ])) {
$value = $parameters [ 'value' ];
}
$show_helptip = true ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'show_helptip' ])) {
$show_helptip = $parameters [ 'show_helptip' ];
}
$helptip_text = __ ( 'Type at least two characters to search.' );
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'helptip_text' ])) {
$helptip_text = $parameters [ 'helptip_text' ];
}
$use_hidden_input_idagent = false ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'use_hidden_input_idagent' ])) {
$use_hidden_input_idagent = $parameters [ 'use_hidden_input_idagent' ];
}
$print_hidden_input_idagent = false ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'print_hidden_input_idagent' ])) {
$print_hidden_input_idagent = $parameters [ 'print_hidden_input_idagent' ];
}
$hidden_input_idagent_name = uniqid ( 'agent_autocomplete_idagent_' );
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'hidden_input_idagent_name' ])) {
$hidden_input_idagent_name = $parameters [ 'hidden_input_idagent_name' ];
}
$hidden_input_idagent_id = 'hidden-' . $input_name ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'hidden_input_idagent_id' ])) {
$hidden_input_idagent_id = $parameters [ 'hidden_input_idagent_id' ];
}
$hidden_input_idagent_value = ( int ) get_parameter ( $hidden_input_idagent_name , 0 );
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'hidden_input_idagent_value' ])) {
$hidden_input_idagent_value = $parameters [ 'hidden_input_idagent_value' ];
}
$size = 30 ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'size' ])) {
$size = $parameters [ 'size' ];
}
$maxlength = 100 ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'maxlength' ])) {
$maxlength = $parameters [ 'maxlength' ];
}
$disabled = false ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'disabled' ])) {
$disabled = $parameters [ 'disabled' ];
}
$selectbox_id = 'id_agent_module' ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'selectbox_id' ])) {
$selectbox_id = $parameters [ 'selectbox_id' ];
}
$add_none_module = true ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'add_none_module' ])) {
$add_none_module = $parameters [ 'add_none_module' ];
}
$none_module_text = '--' ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'none_module_text' ])) {
$none_module_text = $parameters [ 'none_module_text' ];
}
$print_input_server = false ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'print_input_server' ])) {
$print_input_server = $parameters [ 'print_input_server' ];
}
$print_input_id_server = false ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'print_input_id_server' ])) {
$print_input_id_server = $parameters [ 'print_input_id_server' ];
}
$use_input_server = false ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'use_input_server' ])) {
$use_input_server = $parameters [ 'use_input_server' ];
}
$use_input_id_server = false ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'use_input_id_server' ])) {
$use_input_id_server = $parameters [ 'use_input_id_server' ];
}
$input_server_name = uniqid ( 'server_' );
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'input_server_name' ])) {
$input_server_name = $parameters [ 'input_server_name' ];
}
$input_id_server_name = uniqid ( 'server_' );
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'input_id_server_name' ])) {
$input_id_server_name = $parameters [ 'input_id_server_name' ];
}
$input_server_id = 'hidden-' . $input_server_name ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'input_server_id' ])) {
$input_server_id = $parameters [ 'input_server_id' ];
}
$input_id_server_id = 'hidden-' . $input_id_server_name ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'input_id_server_id' ])) {
$input_id_server_id = $parameters [ 'input_id_server_id' ];
}
$input_server_value = '' ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'input_server_value' ])) {
$input_server_value = $parameters [ 'input_server_value' ];
}
$input_id_server_value = '' ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'input_id_server_value' ])) {
$input_id_server_value = $parameters [ 'input_id_server_value' ];
}
$from_ux_transaction = '' ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'from_ux' ])) {
$from_ux_transaction = $parameters [ 'from_ux' ];
}
$from_wux_transaction = '' ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'from_wux' ])) {
$from_wux_transaction = $parameters [ 'from_wux' ];
}
$cascade_protection = false ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'cascade_protection' ])) {
$cascade_protection = $parameters [ 'cascade_protection' ];
}
$metaconsole_enabled = false ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'metaconsole_enabled' ])) {
$metaconsole_enabled = $parameters [ 'metaconsole_enabled' ];
} else {
2019-05-28 10:47:31 +02:00
// If metaconsole_enabled param is not setted then pick source configuration.
2021-07-13 17:26:03 +02:00
$metaconsole_enabled = is_metaconsole ();
2019-01-30 16:18:44 +01:00
}
$get_only_string_modules = false ;
if ( isset ( $parameters [ 'get_only_string_modules' ])) {
$get_only_string_modules = true ;
}
2021-03-11 12:18:13 +01:00
$no_disabled_modules = true ;
2019-08-07 14:23:10 +02:00
if ( isset ( $parameters [ 'no_disabled_modules' ])) {
$no_disabled_modules = $parameters [ 'no_disabled_modules' ];
}
2019-01-30 16:18:44 +01:00
$spinner_image = html_print_image ( 'images/spinner.gif' , true , false , true );
if ( isset ( $parameters [ 'spinner_image' ])) {
$spinner_image = $parameters [ 'spinner_image' ];
}
// Javascript configurations
2019-05-28 10:47:31 +02:00
// ------------------------------------------------------------------.
2019-08-21 09:22:13 +02:00
$javascript_ajax_page = ui_get_full_url ( 'ajax.php' , false , false , false );
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'javascript_ajax_page' ])) {
$javascript_ajax_page = $parameters [ 'javascript_ajax_page' ];
}
$javascript_function_action_after_select = '' ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
$javascript_function_action_after_select_js_call = '' ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'javascript_function_action_after_select' ])) {
$javascript_function_action_after_select = $parameters [ 'javascript_function_action_after_select' ];
$javascript_function_action_after_select_js_call = $javascript_function_action_after_select . '();' ;
}
if ( isset ( $parameters [ 'javascript_function_action_after_select_js_call' ])) {
if ( $javascript_function_action_after_select_js_call != $parameters [ 'javascript_function_action_after_select_js_call' ]
) {
$javascript_function_action_after_select_js_call = $parameters [ 'javascript_function_action_after_select_js_call' ];
}
}
$javascript_function_action_into_source = '' ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
$javascript_function_action_into_source_js_call = '' ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'javascript_function_action_into_source' ])) {
$javascript_function_action_into_source = $parameters [ 'javascript_function_action_into_source' ];
$javascript_function_action_into_source_js_call = $javascript_function_action_into_source . '();' ;
}
if ( isset ( $parameters [ 'javascript_function_action_into_source_js_call' ])) {
if ( $javascript_function_action_into_source_js_call != $parameters [ 'javascript_function_action_into_source_js_call' ]
) {
$javascript_function_action_into_source_js_call = $parameters [ 'javascript_function_action_into_source_js_call' ];
}
}
$javascript = true ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'javascript' ])) {
$javascript = $parameters [ 'javascript' ];
}
$get_order_json = false ;
if ( isset ( $parameters [ 'get_order_json' ])) {
$get_order_json = true ;
}
$javascript_is_function_select = false ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'javascript_is_function_select' ])) {
$javascript_is_function_select = $parameters [ 'javascript_is_function_select' ];
}
$javascript_name_function_select = 'function_select_' . $input_name ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'javascript_name_function_select' ])) {
$javascript_name_function_select = $parameters [ 'javascript_name_function_select' ];
}
2022-11-21 14:49:07 +01:00
$inputStyles = ( $parameters [ 'input_style' ] ? ? '' );
2019-01-30 16:18:44 +01:00
if ( $from_ux_transaction != '' ) {
$javascript_code_function_select = '
function function_select_ '.$input_name.' ( agent_name ) {
$ ( " #'. $selectbox_id .' " ) . empty ();
2017-04-21 14:32:31 +02:00
var inputs = [];
2019-01-30 16:18:44 +01:00
inputs . push ( " id_agent= " + $ ( " #'. $hidden_input_idagent_id .' " ) . val ());
2017-04-21 14:32:31 +02:00
inputs . push ( " get_agent_transactions=1 " );
inputs . push ( " page=enterprise/include/ajax/ux_transaction.ajax " );
jQuery . ajax ({
data : inputs . join ( " & " ),
type : " POST " ,
2019-01-30 16:18:44 +01:00
url : action = " '. $javascript_ajax_page .' " ,
2017-04-21 14:32:31 +02:00
dataType : " json " ,
success : function ( data ) {
if ( data ) {
2019-01-30 16:18:44 +01:00
$ ( " #'. $selectbox_id .' " ) . append ( $ ( " <option value=0>None</option> " ));
2017-08-23 17:21:15 +02:00
jQuery . each ( data , function ( id , value ) {
2019-01-30 16:18:44 +01:00
$ ( " #'. $selectbox_id .' " ) . append ( $ ( " <option value= " + id + " > " + value + " </option> " ));
2017-08-23 17:21:15 +02:00
});
}
}
});
return false ;
}
' ;
2019-01-30 16:18:44 +01:00
} else if ( $from_wux_transaction != '' ) {
2021-07-12 12:32:05 +02:00
if ( is_metaconsole () === true ) {
$inputNode = 'inputs.push ("server_id=" + $("#' . $input_id_server_id . '").val());' ;
} else {
$inputNode = '' ;
}
2019-01-30 16:18:44 +01:00
$javascript_code_function_select = '
function function_select_ '.$input_name.' ( agent_name ) {
$ ( " #'. $selectbox_id .' " ) . empty ();
2017-08-23 17:21:15 +02:00
var inputs = [];
2019-01-30 16:18:44 +01:00
inputs . push ( " id_agent= " + $ ( " #'. $hidden_input_idagent_id .' " ) . val ());
2021-07-12 12:32:05 +02:00
inputs . push ( " get_agent_transactions=1 " );
2017-08-23 17:21:15 +02:00
inputs . push ( " page=enterprise/include/ajax/wux_transaction.ajax " );
2021-07-12 12:32:05 +02:00
'.$inputNode.'
2017-08-23 17:21:15 +02:00
jQuery . ajax ({
data : inputs . join ( " & " ),
type : " POST " ,
2019-01-30 16:18:44 +01:00
url : action = " '. $javascript_ajax_page .' " ,
2017-08-23 17:21:15 +02:00
dataType : " json " ,
success : function ( data ) {
if ( data ) {
2019-01-30 16:18:44 +01:00
$ ( " #'. $selectbox_id .' " ) . append ( $ ( " <option value=0>None</option> " ));
2017-04-21 14:32:31 +02:00
jQuery . each ( data , function ( id , value ) {
2019-01-30 16:18:44 +01:00
$ ( " #'. $selectbox_id .' " ) . append ( $ ( " <option value= " + id + " > " + value + " </option> " ));
2017-04-21 14:32:31 +02:00
});
}
}
});
return false ;
}
' ;
2019-01-30 16:18:44 +01:00
} else {
$javascript_code_function_select = '
function function_select_ '.$input_name.' ( agent_name ) {
2012-09-12 17:53:58 +02:00
2019-01-30 16:18:44 +01:00
$ ( " #'. $selectbox_id .' " ) . empty ();
2012-09-13 19:47:21 +02:00
2012-09-12 17:53:58 +02:00
var inputs = [];
inputs . push ( " agent_name= " + agent_name );
2015-08-04 12:49:21 +02:00
inputs . push ( " delete_pending=0 " );
2012-09-12 17:53:58 +02:00
inputs . push ( " get_agent_modules_json=1 " );
inputs . push ( " page=operation/agentes/ver_agente " );
2012-09-13 19:47:21 +02:00
2019-01-30 16:18:44 +01:00
if ( '.((int) !$metaconsole_enabled).' ) {
2012-12-11 18:39:48 +01:00
inputs . push ( " force_local_modules=1 " );
2013-01-31 Miguel de Dios <miguel.dedios@artica.es>
* include/styles/jquery-ui-1.10.0.custom.css,
include/styles/images/ui-*,
include/javascript/jquery.jquery-ui-1.10.0.custom.js,
include/javascript/jquery-1.9.0.js: added the last version of
jquery and jqueryUI.
* godmode/reporting/visual_console_builder.editor.js,
include/ajax/events.php, include/functions_events.php,
include/functions_reporting.php,
include/javascript/pandora_events.js,
include/javascript/jquery.scrollTo.js,
include/javascript/jquery.tablesorter.pager.js,
include/javascript/jquery.tablesorter.js, include/functions_ui.php,
extensions/update_manager/lib/functions.php,
extensions/update_manager/main.php, extensions/agents_alerts.php,
operation/events/events.php, general/login_page.php,
general/logoff.php, general/header.php,
general/login_help_dialog.php: fixes about the new jquery and
jqueryUI version.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7554 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-31 17:49:08 +01:00
}
2017-10-31 16:39:58 +01:00
2020-03-17 14:23:52 +01:00
inputs . push ( " get_order_json=1 " );
2017-11-10 15:03:52 +01:00
2019-01-30 16:18:44 +01:00
if ( '.((int) $get_only_string_modules).' ) {
2017-11-10 15:03:52 +01:00
inputs . push ( " get_only_string_modules=1 " );
}
2019-08-07 14:23:10 +02:00
if ( '.((int) $no_disabled_modules).' ) {
inputs . push ( " disabled=0 " );
}
2019-01-30 16:18:44 +01:00
if ( '.((int) $metaconsole_enabled).' ) {
if (( '.((int) $use_input_server).' )
|| ( '.((int) $print_input_server).' )) {
inputs . push ( " server_name= " + $ ( " #'. $input_server_id .' " ) . val ());
2013-03-04 15:31:30 +01:00
}
2019-01-30 16:18:44 +01:00
if (( '.((int) $use_input_id_server).' )
|| ( '.((int) $print_input_id_server).' )) {
inputs . push ( " server_id= " + $ ( " #'. $input_id_server_id .' " ) . val ());
2013-03-04 15:31:30 +01:00
}
2012-09-19 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php, extensions/system_info.php,
extensions/update_manager/lib/libupdate_manager.php,
godmode/agentes/modificar_agente.php,
godmode/alerts/alert_actions.php,
godmode/alerts/alert_list.list.php,
godmode/massive/massive_add_profiles.php,
godmode/massive/massive_edit_modules.php,
godmode/servers/manage_recontask.php,
godmode/setup/setup_visuals.php, include/functions_api.php,
include/functions_graph.php, include/functions_messages.php,
include/graphs/functions_flot.php,
include/graphs/flot/pandora.flot.js, operation/tree.php,
operation/agentes/status_events.php,
operation/agentes/ver_agente.php, operation/events/events_list.php,
operation/events/events_marquee.php,
operation/events/events_rss.php: cleaned source code style.
* godmode/reporting/reporting_builder.item_editor.php,
include/functions_ui.php, include/ajax/agent.php: continue to change
to the new function "ui_print_agent_autocomplete_input" to make more
easy (and standar) the autocomplete agent input.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6988 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-09-19 16:45:59 +02:00
}
2019-01-30 16:18:44 +01:00
if (( '.((int) $print_hidden_input_idagent).' )
|| ( '.((int) $use_hidden_input_idagent).' )) {
2012-11-02 20:18:20 +01:00
2019-01-30 16:18:44 +01:00
inputs . push ( " id_agent= " + $ ( " #'. $hidden_input_idagent_id .' " ) . val ());
2012-09-19 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php, extensions/system_info.php,
extensions/update_manager/lib/libupdate_manager.php,
godmode/agentes/modificar_agente.php,
godmode/alerts/alert_actions.php,
godmode/alerts/alert_list.list.php,
godmode/massive/massive_add_profiles.php,
godmode/massive/massive_edit_modules.php,
godmode/servers/manage_recontask.php,
godmode/setup/setup_visuals.php, include/functions_api.php,
include/functions_graph.php, include/functions_messages.php,
include/graphs/functions_flot.php,
include/graphs/flot/pandora.flot.js, operation/tree.php,
operation/agentes/status_events.php,
operation/agentes/ver_agente.php, operation/events/events_list.php,
operation/events/events_marquee.php,
operation/events/events_rss.php: cleaned source code style.
* godmode/reporting/reporting_builder.item_editor.php,
include/functions_ui.php, include/ajax/agent.php: continue to change
to the new function "ui_print_agent_autocomplete_input" to make more
easy (and standar) the autocomplete agent input.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6988 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-09-19 16:45:59 +02:00
}
2012-09-12 17:53:58 +02:00
jQuery . ajax ({
data : inputs . join ( " & " ),
2012-09-19 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php, extensions/system_info.php,
extensions/update_manager/lib/libupdate_manager.php,
godmode/agentes/modificar_agente.php,
godmode/alerts/alert_actions.php,
godmode/alerts/alert_list.list.php,
godmode/massive/massive_add_profiles.php,
godmode/massive/massive_edit_modules.php,
godmode/servers/manage_recontask.php,
godmode/setup/setup_visuals.php, include/functions_api.php,
include/functions_graph.php, include/functions_messages.php,
include/graphs/functions_flot.php,
include/graphs/flot/pandora.flot.js, operation/tree.php,
operation/agentes/status_events.php,
operation/agentes/ver_agente.php, operation/events/events_list.php,
operation/events/events_marquee.php,
operation/events/events_rss.php: cleaned source code style.
* godmode/reporting/reporting_builder.item_editor.php,
include/functions_ui.php, include/ajax/agent.php: continue to change
to the new function "ui_print_agent_autocomplete_input" to make more
easy (and standar) the autocomplete agent input.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6988 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-09-19 16:45:59 +02:00
type : " POST " ,
2019-01-30 16:18:44 +01:00
url : action = " '. $javascript_ajax_page .' " ,
2012-09-12 17:53:58 +02:00
dataType : " json " ,
success : function ( data ) {
2020-03-17 14:23:52 +01:00
if ( Array . isArray ( data ) === true ) {
data . sort ( function ( a , b ) {
var textA = a . nombre . toUpperCase ();
var textB = b . nombre . toUpperCase ();
return ( textA < textB ) ? - 1 : ( textA > textB ) ? 1 : 0 ;
});
}
2020-03-16 14:07:54 +01:00
2019-01-30 16:18:44 +01:00
if ( '.((int) $add_none_module).' ) {
$ ( " #'. $selectbox_id .' " )
2012-09-13 19:47:21 +02:00
. append ( $ ( " <option></option> " )
2019-01-30 16:18:44 +01:00
. attr ( " value " , 0 ) . text ( " '. $none_module_text .' " ));
2012-09-13 19:47:21 +02:00
}
2012-09-12 17:53:58 +02:00
jQuery . each ( data , function ( i , val ) {
s = js_html_entity_decode ( val [ " nombre " ]);
2019-01-30 16:18:44 +01:00
$ ( " #'. $selectbox_id .' " )
2012-09-12 17:53:58 +02:00
. append ( $ ( " <option></option> " )
. attr ( " value " , val [ " id_agente_modulo " ]) . text ( s ));
});
2019-01-30 16:18:44 +01:00
if ( '.(int) $cascade_protection.' == 0 ){
$ ( " #'. $selectbox_id .' " ) . enable ();
2017-09-05 12:35:21 +02:00
}
2019-01-30 16:18:44 +01:00
$ ( " #'. $selectbox_id .' " ) . fadeIn ( " normal " );
2012-09-12 17:53:58 +02:00
}
});
return false ;
}
' ;
2019-01-30 16:18:44 +01:00
}
if ( isset ( $parameters [ 'javascript_code_function_select' ])) {
$javascript_code_function_select = $parameters [ 'javascript_code_function_select' ];
}
// ============ INIT javascript_change_ajax_params ==================
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
$javascript_page = 'include/ajax/agent' ;
if ( isset ( $parameters [ 'javascript_page' ])) {
$javascript_page = $parameters [ 'javascript_page' ];
}
$javascript_change_ajax_params_original = [
'page' => '"' . $javascript_page . '"' ,
'search_agents' => 1 ,
'id_group' => ' function () {
2012-09-18 Miguel de Dios <miguel.dedios@artica.es>
* godmode/reporting/visual_console_builder.editor.js,
godmode/alerts/alert_list.builder.php,
godmode/alerts/alert_list.list.php,
godmode/gis_maps/configure_gis_map.php,
include/functions_visual_map_editor.php, include/functions_ui.php,
operation/tree.php, operation/agentes/exportdata.excel.php,
operation/agentes/exportdata.php, operation/agentes/ver_agente.php,
operation/snmpconsole/snmp_view.php, operation/users/user_edit.php,
operation/gis_maps/ajax.php, operation/events/events_validate.php,
operation/messages/message_edit.php,
operation/messages/message_list.php,
operation/reporting/reporting_viewer.php,
operation/netflow/nf_live_view.php,
operation/incidents/incident.php, operation/search_modules.php:
started to use the new function "ui_print_agent_autocomplete_input"
to make more easy (and standar) the autocomplete agent input.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6983 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-09-18 13:28:09 +02:00
var group_id = 0 ;
2019-01-30 16:18:44 +01:00
if ( '.((int) !empty($selectbox_group)).' ) {
group_id = $ ( " #'. $selectbox_group .' " ) . val ();
2012-09-18 Miguel de Dios <miguel.dedios@artica.es>
* godmode/reporting/visual_console_builder.editor.js,
godmode/alerts/alert_list.builder.php,
godmode/alerts/alert_list.list.php,
godmode/gis_maps/configure_gis_map.php,
include/functions_visual_map_editor.php, include/functions_ui.php,
operation/tree.php, operation/agentes/exportdata.excel.php,
operation/agentes/exportdata.php, operation/agentes/ver_agente.php,
operation/snmpconsole/snmp_view.php, operation/users/user_edit.php,
operation/gis_maps/ajax.php, operation/events/events_validate.php,
operation/messages/message_edit.php,
operation/messages/message_list.php,
operation/reporting/reporting_viewer.php,
operation/netflow/nf_live_view.php,
operation/incidents/incident.php, operation/search_modules.php:
started to use the new function "ui_print_agent_autocomplete_input"
to make more easy (and standar) the autocomplete agent input.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6983 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-09-18 13:28:09 +02:00
}
return group_id ;
} ' ,
2019-01-30 16:18:44 +01:00
'q' => 'term' ,
];
2022-05-30 11:29:17 +02:00
if ( isset ( $parameters [ 'delete_offspring_agents' ]) === true ) {
$javascript_change_ajax_params_original [ 'delete_offspring_agents' ] = $parameters [ 'delete_offspring_agents' ];
}
2019-01-30 16:18:44 +01:00
if ( ! $metaconsole_enabled ) {
$javascript_change_ajax_params_original [ 'force_local' ] = 1 ;
}
if ( isset ( $parameters [ 'javascript_change_ajax_params' ])) {
$javascript_change_ajax_params = [];
$found_page = false ;
foreach ( $parameters [ 'javascript_change_ajax_params' ] as $key => $param_ajax ) {
if ( $key == 'page' ) {
$found_page = true ;
if ( $javascript_page != $param_ajax ) {
$javascript_change_ajax_params [ 'page' ] = $param_ajax ;
} else {
$javascript_change_ajax_params [ 'page' ] = $javascript_page ;
}
} else {
$javascript_change_ajax_params [ $key ] = $param_ajax ;
}
}
if ( ! $found_page ) {
$javascript_change_ajax_params [ 'page' ] = $javascript_page ;
}
} else {
$javascript_change_ajax_params = $javascript_change_ajax_params_original ;
}
$first = true ;
$javascript_change_ajax_params_text = 'var data_params = {' ;
foreach ( $javascript_change_ajax_params as $key => $param_ajax ) {
if ( ! $first ) {
$javascript_change_ajax_params_text .= " , \n " ;
} else {
$first = false ;
}
$javascript_change_ajax_params_text .= '"' . $key . '":' . $param_ajax ;
}
$javascript_change_ajax_params_text .= '};' ;
// ============ END javascript_change_ajax_params ===================
$javascript_function_change = '' ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
$javascript_function_change .= '
2021-05-07 12:40:38 +02:00
function setInputBackground ( inputId , image ) {
$ ( " # " + inputId )
2023-03-21 18:42:31 +01:00
. attr ( " style " , " background-image: url( \ ' " + image + " \ '); background-repeat: no-repeat; background-position: 97% center; background-size: 20px; width:100%; '. $inputStyles .' " );
2021-05-07 12:40:38 +02:00
}
2023-02-22 10:33:45 +01:00
$ ( document ) . ready ( function () {
$ ( " #'. $input_id .' " ) . focusout ( function ( e ) {
setTimeout (() => {
let iconImage = " '. $icon_image .' " ;
2023-03-21 18:42:31 +01:00
$ ( " #'. $input_id .' " ) . attr ( " style " , " background-image: url( \ ' " + iconImage + " \ '); background-repeat: no-repeat; background-position: 97% center; background-size: 20px; width:100%; '. $inputStyles .' " );
2023-02-22 10:33:45 +01:00
}, 100 );
});
});
2019-01-30 16:18:44 +01:00
function set_functions_change_autocomplete_ '.$input_name.' () {
var cache_ '.$input_name.' = {};
2022-11-11 16:15:17 +01:00
2019-01-30 16:18:44 +01:00
$ ( " #'. $input_id .' " ) . autocomplete ({
2012-09-12 17:53:58 +02:00
minLength : 2 ,
source : function ( request , response ) {
var term = request . term ; //Word to search
2019-01-30 16:18:44 +01:00
'.$javascript_change_ajax_params_text.'
2018-08-17 15:03:24 +02:00
var groupId = data_params . id_group ();
// Index cache by group Id
2019-01-30 16:18:44 +01:00
if ( cache_ '.$input_name.' [ groupId ] == null ) {
cache_ '.$input_name.' [ groupId ] = {};
2018-08-17 15:03:24 +02:00
}
2021-05-07 13:50:28 +02:00
2012-09-20 15:45:23 +02:00
//Set loading
2021-05-07 12:40:38 +02:00
setInputBackground ( " '. $input_id .' " , " '. $spinner_image .' " );
2012-09-18 Miguel de Dios <miguel.dedios@artica.es>
* godmode/reporting/visual_console_builder.editor.js,
godmode/alerts/alert_list.builder.php,
godmode/alerts/alert_list.list.php,
godmode/gis_maps/configure_gis_map.php,
include/functions_visual_map_editor.php, include/functions_ui.php,
operation/tree.php, operation/agentes/exportdata.excel.php,
operation/agentes/exportdata.php, operation/agentes/ver_agente.php,
operation/snmpconsole/snmp_view.php, operation/users/user_edit.php,
operation/gis_maps/ajax.php, operation/events/events_validate.php,
operation/messages/message_edit.php,
operation/messages/message_list.php,
operation/reporting/reporting_viewer.php,
operation/netflow/nf_live_view.php,
operation/incidents/incident.php, operation/search_modules.php:
started to use the new function "ui_print_agent_autocomplete_input"
to make more easy (and standar) the autocomplete agent input.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6983 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-09-18 13:28:09 +02:00
//Function to call when the source
2019-01-30 16:18:44 +01:00
if ( '.((int) !empty($javascript_function_action_into_source_js_call)).' ) {
'.$javascript_function_action_into_source_js_call.'
2012-09-18 Miguel de Dios <miguel.dedios@artica.es>
* godmode/reporting/visual_console_builder.editor.js,
godmode/alerts/alert_list.builder.php,
godmode/alerts/alert_list.list.php,
godmode/gis_maps/configure_gis_map.php,
include/functions_visual_map_editor.php, include/functions_ui.php,
operation/tree.php, operation/agentes/exportdata.excel.php,
operation/agentes/exportdata.php, operation/agentes/ver_agente.php,
operation/snmpconsole/snmp_view.php, operation/users/user_edit.php,
operation/gis_maps/ajax.php, operation/events/events_validate.php,
operation/messages/message_edit.php,
operation/messages/message_list.php,
operation/reporting/reporting_viewer.php,
operation/netflow/nf_live_view.php,
operation/incidents/incident.php, operation/search_modules.php:
started to use the new function "ui_print_agent_autocomplete_input"
to make more easy (and standar) the autocomplete agent input.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6983 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-09-18 13:28:09 +02:00
}
2013-06-10 13:54:58 +02:00
//==== CACHE CODE ==================================
2012-09-20 15:45:23 +02:00
//Check the cache
var found = false ;
2019-01-30 16:18:44 +01:00
if ( term in cache_ '.$input_name.' [ groupId ]) {
response ( cache_ '.$input_name.' [ groupId ][ term ]);
2012-09-20 15:45:23 +02:00
//Set icon
2021-05-07 12:40:38 +02:00
setInputBackground ( " '. $input_id .' " , " '. $icon_image .' " );
2012-09-20 15:45:23 +02:00
return ;
}
else {
//Check if other terms cached start with same
//letters.
2019-05-28 10:47:31 +02:00
//TODO: At the moment DISABLED CODE.
2012-09-20 15:45:23 +02:00
/*
for ( i = 1 ; i < term . length ; i ++ ) {
var term_match = term . substr ( 0 , term . length - i );
2019-01-30 16:18:44 +01:00
$ . each ( cache_ '.$input_name.' [ groupId ], function ( oldterm , olddata ) {
2012-09-20 15:45:23 +02:00
var pattern = new RegExp ( " ^ " + term_match + " .* " , " gi " );
if ( oldterm . match ( pattern )) {
2019-01-30 16:18:44 +01:00
response ( cache_ '.$input_name.' [ groupId ][ oldterm ]);
2012-09-20 15:45:23 +02:00
found = true ;
2021-05-07 12:40:38 +02:00
//Set icon
setInputBackground ( " '. $input_id .' " , " '. $icon_image .' " );
2012-09-20 15:45:23 +02:00
return ;
}
});
2013-06-10 13:54:58 +02:00
if ( found ) {
2012-09-20 15:45:23 +02:00
break ;
2013-06-10 13:54:58 +02:00
}
2012-09-20 15:45:23 +02:00
}
*/
}
2013-06-10 13:54:58 +02:00
//==================================================
2012-09-20 15:45:23 +02:00
if ( found ) {
//Set icon
2021-05-07 12:40:38 +02:00
setInputBackground ( " '. $input_id .' " , " '. $icon_image .' " );
2021-05-07 13:11:36 +02:00
2013-06-10 13:54:58 +02:00
select_item_click = 0 ;
2021-05-07 13:11:36 +02:00
2012-09-20 15:45:23 +02:00
return ;
}
2012-09-12 17:53:58 +02:00
jQuery . ajax ({
data : data_params ,
type : " POST " ,
2019-01-30 16:18:44 +01:00
url : action = " '. $javascript_ajax_page .' " ,
2012-09-12 17:53:58 +02:00
dataType : " json " ,
success : function ( data ) {
2019-01-30 16:18:44 +01:00
cache_ '.$input_name.' [ groupId ][ term ] = data ; //Save the cache
2021-05-07 13:11:36 +02:00
2012-09-12 17:53:58 +02:00
response ( data );
2021-05-07 13:11:36 +02:00
//Set icon
2021-05-07 12:40:38 +02:00
setInputBackground ( " '. $input_id .' " , " '. $icon_image .' " );
select_item_click = 0 ;
2021-05-07 13:11:36 +02:00
2012-09-12 17:53:58 +02:00
return ;
}
});
2021-05-07 12:40:38 +02:00
2012-09-12 17:53:58 +02:00
return ;
},
2013-04-17 16:45:17 +02:00
//---END source-----------------------------------------
2013-06-10 13:54:58 +02:00
2012-09-12 17:53:58 +02:00
select : function ( event , ui ) {
2016-10-06 12:10:10 +02:00
var agent_name = ui . item . alias ;
2012-09-13 19:47:21 +02:00
var agent_id = ui . item . id ;
2013-03-04 15:31:30 +01:00
var server_name = " " ;
var server_id = " " ;
2012-09-19 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php, extensions/system_info.php,
extensions/update_manager/lib/libupdate_manager.php,
godmode/agentes/modificar_agente.php,
godmode/alerts/alert_actions.php,
godmode/alerts/alert_list.list.php,
godmode/massive/massive_add_profiles.php,
godmode/massive/massive_edit_modules.php,
godmode/servers/manage_recontask.php,
godmode/setup/setup_visuals.php, include/functions_api.php,
include/functions_graph.php, include/functions_messages.php,
include/graphs/functions_flot.php,
include/graphs/flot/pandora.flot.js, operation/tree.php,
operation/agentes/status_events.php,
operation/agentes/ver_agente.php, operation/events/events_list.php,
operation/events/events_marquee.php,
operation/events/events_rss.php: cleaned source code style.
* godmode/reporting/reporting_builder.item_editor.php,
include/functions_ui.php, include/ajax/agent.php: continue to change
to the new function "ui_print_agent_autocomplete_input" to make more
easy (and standar) the autocomplete agent input.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6988 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-09-19 16:45:59 +02:00
2019-01-30 16:18:44 +01:00
if ( '.((int) $metaconsole_enabled).' ) {
2012-09-19 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php, extensions/system_info.php,
extensions/update_manager/lib/libupdate_manager.php,
godmode/agentes/modificar_agente.php,
godmode/alerts/alert_actions.php,
godmode/alerts/alert_list.list.php,
godmode/massive/massive_add_profiles.php,
godmode/massive/massive_edit_modules.php,
godmode/servers/manage_recontask.php,
godmode/setup/setup_visuals.php, include/functions_api.php,
include/functions_graph.php, include/functions_messages.php,
include/graphs/functions_flot.php,
include/graphs/flot/pandora.flot.js, operation/tree.php,
operation/agentes/status_events.php,
operation/agentes/ver_agente.php, operation/events/events_list.php,
operation/events/events_marquee.php,
operation/events/events_rss.php: cleaned source code style.
* godmode/reporting/reporting_builder.item_editor.php,
include/functions_ui.php, include/ajax/agent.php: continue to change
to the new function "ui_print_agent_autocomplete_input" to make more
easy (and standar) the autocomplete agent input.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6988 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-09-19 16:45:59 +02:00
server_name = ui . item . server ;
}
else {
server_name = ui . item . ip ;
}
2019-01-30 16:18:44 +01:00
if (( '.((int) $use_input_id_server).' )
|| ( '.((int) $print_input_id_server).' )) {
2013-03-04 15:31:30 +01:00
server_id = ui . item . id_server ;
}
2021-07-13 17:26:03 +02:00
2012-09-12 17:53:58 +02:00
//Put the name
$ ( this ) . val ( agent_name );
2019-01-30 16:18:44 +01:00
if (( '.((int) $print_hidden_input_idagent).' )
|| ( '.((int) $use_hidden_input_idagent).' )) {
$ ( " #'. $hidden_input_idagent_id .' " ) . val ( agent_id );
2012-09-13 19:47:21 +02:00
}
2012-09-18 Miguel de Dios <miguel.dedios@artica.es>
* godmode/reporting/visual_console_builder.editor.js,
godmode/alerts/alert_list.builder.php,
godmode/alerts/alert_list.list.php,
godmode/gis_maps/configure_gis_map.php,
include/functions_visual_map_editor.php, include/functions_ui.php,
operation/tree.php, operation/agentes/exportdata.excel.php,
operation/agentes/exportdata.php, operation/agentes/ver_agente.php,
operation/snmpconsole/snmp_view.php, operation/users/user_edit.php,
operation/gis_maps/ajax.php, operation/events/events_validate.php,
operation/messages/message_edit.php,
operation/messages/message_list.php,
operation/reporting/reporting_viewer.php,
operation/netflow/nf_live_view.php,
operation/incidents/incident.php, operation/search_modules.php:
started to use the new function "ui_print_agent_autocomplete_input"
to make more easy (and standar) the autocomplete agent input.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6983 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-09-18 13:28:09 +02:00
//Put the server id into the hidden input
2019-01-30 16:18:44 +01:00
if (( '.((int) $use_input_server).' )
|| ( '.((int) $print_input_server).' )) {
$ ( " #'. $input_server_id .' " ) . val ( server_name );
2012-09-14 19:54:33 +02:00
}
2013-03-04 15:31:30 +01:00
//Put the server id into the hidden input
2019-01-30 16:18:44 +01:00
if (( '.((int) $use_input_id_server).' )
|| ( '.((int) $print_input_id_server).' )) {
$ ( " #'. $input_id_server_id .' " ) . val ( server_id );
2013-03-04 15:31:30 +01:00
}
2012-09-19 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php, extensions/system_info.php,
extensions/update_manager/lib/libupdate_manager.php,
godmode/agentes/modificar_agente.php,
godmode/alerts/alert_actions.php,
godmode/alerts/alert_list.list.php,
godmode/massive/massive_add_profiles.php,
godmode/massive/massive_edit_modules.php,
godmode/servers/manage_recontask.php,
godmode/setup/setup_visuals.php, include/functions_api.php,
include/functions_graph.php, include/functions_messages.php,
include/graphs/functions_flot.php,
include/graphs/flot/pandora.flot.js, operation/tree.php,
operation/agentes/status_events.php,
operation/agentes/ver_agente.php, operation/events/events_list.php,
operation/events/events_marquee.php,
operation/events/events_rss.php: cleaned source code style.
* godmode/reporting/reporting_builder.item_editor.php,
include/functions_ui.php, include/ajax/agent.php: continue to change
to the new function "ui_print_agent_autocomplete_input" to make more
easy (and standar) the autocomplete agent input.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6988 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-09-19 16:45:59 +02:00
//Call the function to select (example fill the modules)
2019-01-30 16:18:44 +01:00
if ( '.((int) $javascript_is_function_select).' ) {
'.$javascript_name_function_select.' ( agent_name );
2012-09-19 Miguel de Dios <miguel.dedios@artica.es>
* extensions/resource_registration.php, extensions/system_info.php,
extensions/update_manager/lib/libupdate_manager.php,
godmode/agentes/modificar_agente.php,
godmode/alerts/alert_actions.php,
godmode/alerts/alert_list.list.php,
godmode/massive/massive_add_profiles.php,
godmode/massive/massive_edit_modules.php,
godmode/servers/manage_recontask.php,
godmode/setup/setup_visuals.php, include/functions_api.php,
include/functions_graph.php, include/functions_messages.php,
include/graphs/functions_flot.php,
include/graphs/flot/pandora.flot.js, operation/tree.php,
operation/agentes/status_events.php,
operation/agentes/ver_agente.php, operation/events/events_list.php,
operation/events/events_marquee.php,
operation/events/events_rss.php: cleaned source code style.
* godmode/reporting/reporting_builder.item_editor.php,
include/functions_ui.php, include/ajax/agent.php: continue to change
to the new function "ui_print_agent_autocomplete_input" to make more
easy (and standar) the autocomplete agent input.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6988 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-09-19 16:45:59 +02:00
}
2012-09-18 Miguel de Dios <miguel.dedios@artica.es>
* godmode/reporting/visual_console_builder.editor.js,
godmode/alerts/alert_list.builder.php,
godmode/alerts/alert_list.list.php,
godmode/gis_maps/configure_gis_map.php,
include/functions_visual_map_editor.php, include/functions_ui.php,
operation/tree.php, operation/agentes/exportdata.excel.php,
operation/agentes/exportdata.php, operation/agentes/ver_agente.php,
operation/snmpconsole/snmp_view.php, operation/users/user_edit.php,
operation/gis_maps/ajax.php, operation/events/events_validate.php,
operation/messages/message_edit.php,
operation/messages/message_list.php,
operation/reporting/reporting_viewer.php,
operation/netflow/nf_live_view.php,
operation/incidents/incident.php, operation/search_modules.php:
started to use the new function "ui_print_agent_autocomplete_input"
to make more easy (and standar) the autocomplete agent input.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6983 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-09-18 13:28:09 +02:00
//Function to call after the select
2019-01-30 16:18:44 +01:00
if ( '.((int) !empty($javascript_function_action_after_select_js_call)).' ) {
'.$javascript_function_action_after_select_js_call.'
2012-09-18 Miguel de Dios <miguel.dedios@artica.es>
* godmode/reporting/visual_console_builder.editor.js,
godmode/alerts/alert_list.builder.php,
godmode/alerts/alert_list.list.php,
godmode/gis_maps/configure_gis_map.php,
include/functions_visual_map_editor.php, include/functions_ui.php,
operation/tree.php, operation/agentes/exportdata.excel.php,
operation/agentes/exportdata.php, operation/agentes/ver_agente.php,
operation/snmpconsole/snmp_view.php, operation/users/user_edit.php,
operation/gis_maps/ajax.php, operation/events/events_validate.php,
operation/messages/message_edit.php,
operation/messages/message_list.php,
operation/reporting/reporting_viewer.php,
operation/netflow/nf_live_view.php,
operation/incidents/incident.php, operation/search_modules.php:
started to use the new function "ui_print_agent_autocomplete_input"
to make more easy (and standar) the autocomplete agent input.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6983 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-09-18 13:28:09 +02:00
}
2013-06-10 13:54:58 +02:00
select_item_click = 1 ;
2012-09-12 17:53:58 +02:00
return false ;
}
})
2013-01-31 Miguel de Dios <miguel.dedios@artica.es>
* include/styles/jquery-ui-1.10.0.custom.css,
include/styles/images/ui-*,
include/javascript/jquery.jquery-ui-1.10.0.custom.js,
include/javascript/jquery-1.9.0.js: added the last version of
jquery and jqueryUI.
* godmode/reporting/visual_console_builder.editor.js,
include/ajax/events.php, include/functions_events.php,
include/functions_reporting.php,
include/javascript/pandora_events.js,
include/javascript/jquery.scrollTo.js,
include/javascript/jquery.tablesorter.pager.js,
include/javascript/jquery.tablesorter.js, include/functions_ui.php,
extensions/update_manager/lib/functions.php,
extensions/update_manager/main.php, extensions/agents_alerts.php,
operation/events/events.php, general/login_page.php,
general/logoff.php, general/header.php,
general/login_help_dialog.php: fixes about the new jquery and
jqueryUI version.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7554 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-01-31 17:49:08 +01:00
. data ( " ui-autocomplete " ) . _renderItem = function ( ul , item ) {
2012-09-12 17:53:58 +02:00
if ( item . ip == " " ) {
2016-09-22 10:27:35 +02:00
text = " <a> " + item . alias + " </a> " ;
2012-09-12 17:53:58 +02:00
}
else {
2016-09-22 10:27:35 +02:00
text = " <a> " + item . alias
2012-09-12 17:53:58 +02:00
+ " <br><span style= \" font-size: 70%; font-style: italic; \" >IP: " + item . ip + " </span></a> " ;
}
2013-02-07 16:53:04 +01:00
switch ( item . filter ) {
2013-04-17 16:45:17 +02:00
default :
2013-02-07 16:53:04 +01:00
case \ ' agent\ ' :
return $ ( " <li style= \ 'background: #DFFFC4; \ '></li> " )
. data ( " item.autocomplete " , item )
. append ( text )
. appendTo ( ul );
break ;
case \ ' address\ ' :
return $ ( " <li style= \ 'background: #F7CFFF; \ '></li> " )
. data ( " item.autocomplete " , item )
. append ( text )
. appendTo ( ul );
break ;
case \ ' description\ ' :
return $ ( " <li style= \ 'background: #FEFCC6; \ '></li> " )
. data ( " item.autocomplete " , item )
2016-09-22 10:27:35 +02:00
. append ( text )
. appendTo ( ul );
break ;
case \ ' alias\ ' :
2023-06-14 11:11:22 +02:00
return $ ( " <li style= \" '. $background_results .' \" ></li> " )
2016-09-22 10:27:35 +02:00
. data ( " item.autocomplete " , item )
2013-02-07 16:53:04 +01:00
. append ( text )
. appendTo ( ul );
break ;
}
2012-09-12 17:53:58 +02:00
};
2012-09-13 19:47:21 +02:00
//Force the size of autocomplete
$ ( " .ui-autocomplete " ) . css ( " max-height " , " 100px " );
$ ( " .ui-autocomplete " ) . css ( " overflow-y " , " auto " );
/* prevent horizontal scrollbar */
$ ( " .ui-autocomplete " ) . css ( " overflow-x " , " hidden " );
/* add padding to account for vertical scrollbar */
$ ( " .ui-autocomplete " ) . css ( " padding-right " , " 20px " );
//Force to style of items
$ ( " .ui-autocomplete " ) . css ( " text-align " , " left " );
} ' ;
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'javascript_function_change' ])) {
$javascript_function_change = $parameters [ 'javascript_function_change' ];
}
$javascript_document_ready = true ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'javascript_document_ready' ])) {
$javascript_document_ready = $parameters [ 'javascript_document_ready' ];
}
$javascript_tags = true ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'javascript_tags' ])) {
$javascript_tags = $parameters [ 'javascript_tags' ];
}
$disabled_javascript_on_blur_function = false ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'disabled_javascript_on_blur_function' ])) {
$disabled_javascript_on_blur_function = $parameters [ 'disabled_javascript_on_blur_function' ];
}
$javascript_on_blur_function_name = 'function_on_blur_' . $input_name ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'javascript_on_blur_function_name' ])) {
$javascript_on_blur_function_name = $parameters [ 'javascript_on_blur_function_name' ];
}
$check_only_empty_javascript_on_blur_function = false ;
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'check_only_empty_javascript_on_blur_function' ])) {
$check_only_empty_javascript_on_blur_function = $parameters [ 'check_only_empty_javascript_on_blur_function' ];
}
2019-05-28 10:47:31 +02:00
// Default value.
2019-01-30 16:18:44 +01:00
$javascript_on_blur = '
2012-11-02 20:18:20 +01:00
/*
This function is a callback when the autocomplete agent
input lost the focus .
*/
2019-01-30 16:18:44 +01:00
function '.$javascript_on_blur_function_name.' () {
input_value = $ ( " #'. $input_id .' " ) . val ();
2012-11-28 19:29:24 +01:00
2019-05-17 16:36:21 +02:00
if ( input_value . length < 2 ) {
2019-01-30 16:18:44 +01:00
if (( '.((int) $print_hidden_input_idagent).' )
|| ( '.((int) $use_hidden_input_idagent).' )) {
$ ( " #'. $hidden_input_idagent_id .' " ) . val ( 0 );
2012-11-28 19:29:24 +01:00
}
//Put the server id into the hidden input
2019-01-30 16:18:44 +01:00
if (( '.((int) $use_input_server).' )
|| ( '.((int) $print_input_server).' )) {
$ ( " #'. $input_server_id .' " ) . val ( " " );
2012-11-28 19:29:24 +01:00
}
2013-03-04 15:31:30 +01:00
//Put the server id into the hidden input
2019-01-30 16:18:44 +01:00
if (( '.((int) $use_input_id_server).' )
|| ( '.((int) $print_input_id_server).' )) {
$ ( " #'. $input_id_server_id .' " ) . val ( " " );
2013-03-04 15:31:30 +01:00
}
2012-11-28 19:29:24 +01:00
return ;
}
2013-06-10 13:54:58 +02:00
if ( select_item_click ) {
2021-04-06 15:25:43 +02:00
select_item_click = 0 ;
$ ( " #'. $input_id .' " )
2023-03-21 18:42:31 +01:00
. attr ( " style " , " background-image: url( \" '. $spinner_image .' \" ); background-repeat: no-repeat; background-position: 97% center; background-size: 20px; width:100%; '. $inputStyles .' " );
2013-06-10 13:54:58 +02:00
return ;
2021-04-06 15:25:43 +02:00
} else {
// Clear selectbox if item is not selected.
$ ( " #'. $selectbox_id .' " ) . empty ();
$ ( " #'. $selectbox_id .' " ) . append ( $ ( " <option value=0>'.__('Select an Agent first').'</option> " ));
$ ( " #'. $selectbox_id .' " ) . attr ( " disabled " , " disabled " );
// Not allow continue on blur .
if ( '.((int) $check_only_empty_javascript_on_blur_function).' ) {
return
}
}
2012-11-02 20:18:20 +01:00
//Set loading
2019-01-30 16:18:44 +01:00
$ ( " #'. $input_id .' " )
2023-03-21 18:42:31 +01:00
. attr ( " style " , " background-image: url( \" '. $spinner_image .' \" ); background-repeat: no-repeat; background-position: 97% center; background-size: 20px; width:100%; '. $inputStyles .' " );
2012-11-02 20:18:20 +01:00
var term = input_value ; //Word to search
2019-01-30 16:18:44 +01:00
'.$javascript_change_ajax_params_text.'
2013-02-14 11:05:16 +01:00
2019-01-30 16:18:44 +01:00
if ( '.((int) !$metaconsole_enabled).' ) {
2012-12-11 18:39:48 +01:00
data_params [ \ ' force_local\ ' ] = 1 ;
2013-02-14 11:05:16 +01:00
}
2012-11-02 20:18:20 +01:00
jQuery . ajax ({
data : data_params ,
type : " POST " ,
2019-01-30 16:18:44 +01:00
url : action = " '. $javascript_ajax_page .' " ,
2012-11-02 20:18:20 +01:00
dataType : " json " ,
success : function ( data ) {
2019-05-17 16:36:21 +02:00
if ( data . length < 2 ) {
2012-11-02 20:18:20 +01:00
//Set icon
2023-03-21 18:42:31 +01:00
$ ( " #'. $input_id .' " ) . attr ( " style " , " background-image: url( \" '. $spinner_image .' \" ); background-repeat: no-repeat; background-position: 97% center; background-size: 20px; width:100%; '. $inputStyles .' " );
2012-11-02 20:18:20 +01:00
return ;
}
2022-11-11 16:15:17 +01:00
2012-11-02 20:18:20 +01:00
var agent_name = data [ 0 ] . name ;
var agent_id = data [ 0 ] . id ;
2013-03-04 15:31:30 +01:00
var server_name = " " ;
var server_id = " " ;
2012-11-02 20:18:20 +01:00
2019-01-30 16:18:44 +01:00
if ( '.((int) $metaconsole_enabled).' ) {
2012-11-02 20:18:20 +01:00
server_name = data [ 0 ] . server ;
}
else {
server_name = data [ 0 ] . ip ;
}
2019-01-30 16:18:44 +01:00
if (( '.((int) $use_input_id_server).' )
|| ( '.((int) $print_input_id_server).' )) {
2013-03-04 15:31:30 +01:00
server_id = data [ 0 ] . id_server ;
}
2019-01-30 16:18:44 +01:00
if (( '.((int) $print_hidden_input_idagent).' )
|| ( '.((int) $use_hidden_input_idagent).' )) {
$ ( " #'. $hidden_input_idagent_id .' " ) . val ( agent_id );
2012-11-02 20:18:20 +01:00
}
//Put the server id into the hidden input
2019-01-30 16:18:44 +01:00
if (( '.((int) $use_input_server).' )
|| ( '.((int) $print_input_server).' )) {
$ ( " #'. $input_server_id .' " ) . val ( server_name );
2012-11-02 20:18:20 +01:00
}
2013-03-04 15:31:30 +01:00
//Put the server id into the hidden input
2019-01-30 16:18:44 +01:00
if (( '.((int) $use_input_id_server).' )
|| ( '.((int) $print_input_id_server).' )) {
$ ( " #'. $input_id_server_id .' " ) . val ( server_id );
2013-03-04 15:31:30 +01:00
}
2012-11-02 20:18:20 +01:00
//Call the function to select (example fill the modules)
2019-01-30 16:18:44 +01:00
if ( '.((int) $javascript_is_function_select).' ) {
'.$javascript_name_function_select.' ( agent_name );
2012-11-02 20:18:20 +01:00
}
//Function to call after the select
2019-01-30 16:18:44 +01:00
if ( '.((int) !empty($javascript_function_action_after_select_js_call)).' ) {
'.$javascript_function_action_after_select_js_call.'
2012-11-02 20:18:20 +01:00
}
2021-04-06 15:25:43 +02:00
2012-11-02 20:18:20 +01:00
//Set icon
2019-01-30 16:18:44 +01:00
$ ( " #'. $input_id .' " )
2023-03-21 18:42:31 +01:00
. attr ( " style " , " background: url( \" '. $icon_image .' \" ) 97% center no-repeat; background-size: 20px; width:100%; '. $inputStyles .' " )
2012-11-02 20:18:20 +01:00
return ;
}
});
}
' ;
2019-01-30 16:18:44 +01:00
if ( isset ( $parameters [ 'javascript_on_blur' ])) {
$javascript_on_blur = $parameters [ 'javascript_on_blur' ];
}
2019-05-28 10:47:31 +02:00
// ------------------------------------------------------------------.
2019-01-30 16:18:44 +01:00
$html = '' ;
2021-03-18 10:03:52 +01:00
$text_color = '' ;
2022-11-11 16:15:17 +01:00
if ( $config [ 'style' ] === 'pandora_black' && is_metaconsole () === false ) {
2021-03-18 10:03:52 +01:00
$text_color = 'color: white' ;
}
2019-01-30 16:18:44 +01:00
$attrs = [];
2023-03-21 18:42:31 +01:00
$attrs [ 'style' ] = 'background-image: url(' . $icon_image . '); background-repeat: no-repeat; background-position: 97% center; background-size: 20px; width:100%; ' . $text_color . ' ' . $inputStyles . '' ;
2019-01-30 16:18:44 +01:00
if ( ! $disabled_javascript_on_blur_function ) {
$attrs [ 'onblur' ] = $javascript_on_blur_function_name . '()' ;
}
$html = html_print_input_text_extended (
$input_name ,
$value ,
$input_id ,
$helptip_text ,
$size ,
$maxlength ,
$disabled ,
'' ,
$attrs ,
true
);
if ( $show_helptip ) {
2023-02-28 17:53:10 +01:00
$html .= ui_print_input_placeholder ( $helptip_text , true );
2019-01-30 16:18:44 +01:00
}
if ( $print_hidden_input_idagent ) {
$html .= html_print_input_hidden_extended (
$hidden_input_idagent_name ,
$hidden_input_idagent_value ,
$hidden_input_idagent_id ,
true
);
}
if ( $print_input_server ) {
$html .= html_print_input_hidden_extended (
$input_server_name ,
$input_server_value ,
$input_server_id ,
true
);
}
if ( $print_input_id_server ) {
$html .= html_print_input_hidden_extended (
$input_id_server_name ,
$input_id_server_value ,
$input_id_server_id ,
true
);
}
2019-05-28 10:47:31 +02:00
// Write the javascript.
2019-01-30 16:18:44 +01:00
if ( $javascript ) {
if ( $javascript_tags ) {
$html .= ' < script type = " text/javascript " >
2012-09-12 17:53:58 +02:00
/* <![CDATA[ */ ' ;
2019-01-30 16:18:44 +01:00
}
$html .= 'var select_item_click = 0;' . " \n " ;
$html .= $javascript_function_change ;
if ( $javascript_is_function_select ) {
$html .= $javascript_code_function_select ;
}
$html .= $javascript_on_blur ;
if ( $javascript_document_ready ) {
$html .= ' $ ( document ) . ready ( function () {
set_functions_change_autocomplete_ '.$input_name.' ();
2012-09-12 17:53:58 +02:00
}); ' ;
2019-01-30 16:18:44 +01:00
}
if ( $javascript_tags ) {
$html .= ' /* ]]> */
2012-09-12 17:53:58 +02:00
</ script > ' ;
2019-01-30 16:18:44 +01:00
}
}
if ( $return ) {
return $html ;
} else {
echo $html ;
}
2011-04-13 19:11:10 +02:00
}
2013-04-22 12:31:20 +02:00
/**
* Return error strings ( title and message ) for each error code
2019-01-30 16:18:44 +01:00
*
2019-05-28 10:47:31 +02:00
* @ param string $error_code Error code .
*
* @ return array .
2013-04-22 12:31:20 +02:00
*/
2019-01-30 16:18:44 +01:00
function ui_get_error ( $error_code = '' )
{
2019-05-28 10:47:31 +02:00
// XXX: Deprecated. Pandora shouldn't go inside this.
2019-01-30 16:18:44 +01:00
return [
'title' => __ ( 'Unhandled error' ),
'message' => __ ( 'An unhandled error occurs' ),
];
2013-04-22 12:31:20 +02:00
}
2019-01-30 16:18:44 +01:00
2019-05-28 10:47:31 +02:00
/**
* Include time picker .
*
* @ param boolean $echo_tags Tags .
*
* @ return void
*/
2019-01-30 16:18:44 +01:00
function ui_include_time_picker ( $echo_tags = false )
{
if ( is_ajax () || $echo_tags ) {
2019-05-28 09:48:09 +02:00
echo '<script type="text/javascript" src="' . ui_get_full_url ( false , false , false , false ) . 'include/javascript/jquery.ui-timepicker-addon.js"></script>' ;
2019-01-30 16:18:44 +01:00
} else {
ui_require_jquery_file ( 'ui-timepicker-addon' );
}
if ( file_exists ( 'include/javascript/i18n/jquery-ui-timepicker-' . substr ( get_user_language (), 0 , 2 ) . '.js' )) {
echo '<script type="text/javascript" src="' . ui_get_full_url ( 'include/javascript/i18n/jquery-ui-timepicker-' . substr ( get_user_language (), 0 , 2 ) . '.js' , false , false , false ) . '"></script>' ;
}
2014-06-02 Miguel de Dios <miguel.dedios@artica.es>
* godmode/alerts/configure_alert_template.php,
godmode/reporting/reporting_builder.item_editor.php,
godmode/agentes/planned_downtime.editor.php, godmode/setup/news.php,
include/ajax/module.php, include/functions.php,
include/functions_ui.php, extensions/insert_data.php,
operation/netflow/nf_live_view.php,
operation/reporting/reporting_viewer.php,
operation/reporting/graph_viewer.php, operation/tree.php,
operation/agentes/datos_agente.php,
operation/agentes/estado_monitores.php: fixed the i18n of the
timepicker.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@10076 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2014-06-02 17:57:36 +02:00
}
2016-01-18 16:58:24 +01:00
2019-01-30 16:18:44 +01:00
2019-05-28 10:47:31 +02:00
/**
* Print string value .
*
* @ param string $value Value .
* @ param integer $id_agente_module Id_agente_module .
* @ param integer $current_interval Current_interval .
* @ param string $module_name Module_name .
*
* @ return string HTML .
*/
2019-01-30 16:18:44 +01:00
function ui_print_module_string_value (
$value ,
$id_agente_module ,
$current_interval ,
2020-11-23 17:09:58 +01:00
$module_name = null ,
$server_id = 0
2019-01-30 16:18:44 +01:00
) {
global $config ;
2019-05-28 10:47:31 +02:00
if ( $module_name == null ) {
2019-01-30 16:18:44 +01:00
$module_name = modules_get_agentmodule_name ( $id_agente_module );
}
$id_type_web_content_string = db_get_value (
'id_tipo' ,
'ttipo_modulo' ,
'nombre' ,
'web_content_string'
);
$is_web_content_string = ( bool ) db_get_value_filter (
'id_agente_modulo' ,
'tagente_modulo' ,
[
'id_agente_modulo' => $id_agente_module ,
'id_tipo_modulo' => $id_type_web_content_string ,
]
);
// Fixed the goliat sends the strings from web
2019-05-28 10:47:31 +02:00
// without HTML entities.
2019-01-30 16:18:44 +01:00
if ( $is_web_content_string ) {
$value = io_safe_input ( $value );
}
$is_snapshot = is_snapshot_data ( $module [ 'datos' ]);
$is_large_image = is_text_to_black_string ( $module [ 'datos' ]);
if (( $config [ 'command_snapshot' ]) && ( $is_snapshot || $is_large_image )) {
$row [ 7 ] = ui_get_snapshot_image ( $link , $is_snapshot ) . ' ' ;
}
$is_snapshot = is_snapshot_data ( $value );
$is_large_image = is_text_to_black_string ( $value );
if (( $config [ 'command_snapshot' ]) && ( $is_snapshot || $is_large_image )) {
$link = ui_get_snapshot_link (
[
'id_module' => $id_agente_module ,
'last_data' => $value ,
'interval' => $current_interval ,
'module_name' => $module_name ,
2020-11-23 17:09:58 +01:00
'id_node' => $server_id ? $server_id : 0 ,
2019-01-30 16:18:44 +01:00
]
);
$salida = ui_get_snapshot_image ( $link , $is_snapshot ) . ' ' ;
} else {
$sub_string = substr ( io_safe_output ( $value ), 0 , 12 );
if ( $value == $sub_string ) {
if ( $value == 0 && ! $sub_string ) {
$salida = 0 ;
} else {
$salida = $value ;
}
} else {
// Fixed the goliat sends the strings from web
2019-05-28 10:47:31 +02:00
// without HTML entities.
2019-01-30 16:18:44 +01:00
if ( $is_web_content_string ) {
$sub_string = substr ( $value , 0 , 12 );
} else {
2019-05-28 10:47:31 +02:00
// Fixed the data from Selenium Plugin.
2019-01-30 16:18:44 +01:00
if ( $value != strip_tags ( $value )) {
$value = io_safe_input ( $value );
$sub_string = substr ( $value , 0 , 12 );
} else {
$sub_string = substr ( io_safe_output ( $value ), 0 , 12 );
}
}
if ( $value == $sub_string ) {
$salida = $value ;
} else {
$value = preg_replace ( '/</' , '<' , $value );
$value = preg_replace ( '/>/' , '>' , $value );
$value = preg_replace ( '/\n/i' , '<br>' , $value );
$value = preg_replace ( '/\s/i' , ' ' , $value );
$title_dialog = modules_get_agentmodule_agent_alias ( $id_agente_module ) . ' / ' . $module_name ;
$salida = '<div ' . " id='hidden_value_module_ " . $id_agente_module . " '
2021-03-11 15:40:23 +01:00
class = 'title_dialog' title = '".$title_dialog."' > " . $value .'</div><span '. " id = 'value_module_".$id_agente_module."'
class = 'nowrap' > " .'<span id= " value_module_text_ '.$id_agente_module.' " >'. $sub_string .'</span> '. " < a href = 'javascript: toggle_full_value(".$id_agente_module.")' > " .html_print_image('images/zoom.png', true, ['style' => 'max-height: 20px; vertical-align: middle;', 'class' => 'invert_filter']).'</a></span>';
2019-01-30 16:18:44 +01:00
}
}
}
return $salida ;
2016-01-18 16:58:24 +01:00
}
2017-02-28 15:41:03 +01:00
2019-01-30 16:18:44 +01:00
2017-02-28 15:41:03 +01:00
/**
2019-05-28 10:47:31 +02:00
* Displays a tag list .
*
* @ param string $title Title .
* @ param array $tags Tags .
*
* @ return void
2019-01-30 16:18:44 +01:00
*/
function ui_print_tags_view ( $title = '' , $tags = [])
{
2021-02-05 12:37:27 +01:00
$tv = '' ;
2019-01-30 16:18:44 +01:00
if ( ! empty ( $title )) {
$tv .= '<div class="tag-wrapper">' ;
$tv .= '<h3>' . $title . '</h3>' ;
} else {
2021-03-11 15:40:23 +01:00
$tv .= '<div class="tag-wrapper pdd_t_10px">' ;
2019-01-30 16:18:44 +01:00
}
foreach ( $tags as $tag ) {
$tv .= '<div class=pandora-tag>' ;
$tv .= '<span class=pandora-tag-title>' ;
$tv .= $tag [ 'title' ];
$tv .= '</span>' ;
$tv .= '<span class=pandora-tag-value>' ;
$tv .= $tag [ 'value' ];
$tv .= '</span>' ;
$tv .= '</div>' ;
}
$tv .= '</div>' ;
echo $tv ;
2017-02-28 15:41:03 +01:00
}
2018-03-12 15:17:59 +01:00
2019-01-30 16:18:44 +01:00
2018-03-12 15:17:59 +01:00
/**
2019-05-28 10:47:31 +02:00
* Gets the link to open a snapshot into a new page .
2018-03-12 15:17:59 +01:00
*
2019-05-28 10:47:31 +02:00
* @ param array $params Params to build the link ( see $default_params ) .
* @ param boolean $only_params Flag to choose de return value :
* true : Get the four params required in the function of pandora . js winopen_var ( js use )
* false : Get an inline winopen_var function call ( php user ) .
*
* @ return string Link .
2018-03-12 15:17:59 +01:00
*/
2019-01-30 16:18:44 +01:00
function ui_get_snapshot_link ( $params , $only_params = false )
{
global $config ;
$default_params = [
2019-05-28 10:47:31 +02:00
// Id_agente_modulo.
2019-01-30 16:18:44 +01:00
'id_module' => 0 ,
'module_name' => '' ,
'interval' => 300 ,
'timestamp' => 0 ,
'id_node' => 0 ,
];
2019-05-28 10:47:31 +02:00
// Merge default params with passed params.
2019-01-30 16:18:44 +01:00
$params = array_merge ( $default_params , $params );
2019-05-28 10:47:31 +02:00
// First parameter of js winopeng_var.
2020-11-23 17:09:58 +01:00
$page = ui_get_full_url ( 'operation/agentes/snapshot_view.php' , false , false , false );
2019-01-30 16:18:44 +01:00
2019-05-28 10:47:31 +02:00
$url = $page . '?id=' . $params [ 'id_module' ] . '&label=' . rawurlencode ( urlencode ( io_safe_output ( $params [ 'module_name' ]))) . '&id_node=' . $params [ 'id_node' ];
2019-01-30 16:18:44 +01:00
if ( $params [ 'timestamp' ] != 0 ) {
$url .= '×tamp=' . $params [ 'timestamp' ];
}
if ( $params [ 'interval' ] != 0 ) {
$url .= '&refr=' . $params [ 'interval' ];
}
2019-05-28 10:47:31 +02:00
// Second parameter of js winopeng_var.
2019-01-30 16:18:44 +01:00
$win_handle = dechex ( crc32 ( 'snapshot_' . $params [ 'id_module' ]));
$link_parts = [
$url ,
$win_handle ,
700 ,
480 ,
];
2019-05-28 10:47:31 +02:00
// Return only the params to js execution.
2019-01-30 16:18:44 +01:00
if ( $only_params ) {
return $link_parts ;
}
2019-05-28 10:47:31 +02:00
// Return the function call to inline js execution.
2019-01-30 16:18:44 +01:00
return " winopeng_var(' " . implode ( " ', ' " , $link_parts ) . " ') " ;
2018-03-12 15:17:59 +01:00
}
2018-06-11 16:40:10 +02:00
2019-01-30 16:18:44 +01:00
2018-08-02 13:02:33 +02:00
/**
2019-05-28 10:47:31 +02:00
* Get the snapshot image with the link to open a snapshot into a new page
2018-08-02 13:02:33 +02:00
*
2019-05-28 10:47:31 +02:00
* @ param string $link Built link .
* @ param boolean $is_image Picture image or list image .
2018-08-02 13:02:33 +02:00
*
2019-05-28 10:47:31 +02:00
* @ return string HTML anchor link with image .
2018-08-02 13:02:33 +02:00
*/
2019-01-30 16:18:44 +01:00
function ui_get_snapshot_image ( $link , $is_image )
{
2019-05-28 10:47:31 +02:00
$image_name = ( $is_image ) ? 'photo.png' : 'default_list.png' ;
2019-01-30 16:18:44 +01:00
$link = '<a href="javascript:' . $link . '">' . html_print_image (
2019-05-28 10:47:31 +02:00
'images/' . $image_name ,
2019-01-30 16:18:44 +01:00
true ,
[
'border' => '0' ,
'alt' => '' ,
'title' => __ ( 'Snapshot view' ),
2020-11-25 17:00:37 +01:00
'style' => 'max-height: 20px; vertical-align: middle;' ,
2021-03-11 15:40:23 +01:00
'class' => 'invert_filter' ,
2019-01-30 16:18:44 +01:00
]
) . '</a>' ;
return $link ;
2018-08-02 13:02:33 +02:00
}
2019-01-30 16:18:44 +01:00
2019-05-28 10:47:31 +02:00
/**
* Show warning timezone missmatch .
*
* @ param string $tag Tag .
* @ param boolean $return Return .
*
* @ return string HTML .
*/
2019-01-30 16:18:44 +01:00
function ui_get_using_system_timezone_warning ( $tag = 'h3' , $return = true )
{
global $config ;
$user_offset = (( - get_fixed_offset () / 60 ) / 60 );
if ( $config [ 'timezone' ] != date_default_timezone_get ()) {
$message = sprintf (
__ ( 'These controls are using the timezone of the system (%s) instead of yours (%s). The difference with your time zone in hours is %s.' ),
$config [ 'timezone' ],
date_default_timezone_get (),
2019-05-28 10:47:31 +02:00
( $user_offset > 0 ) ? '+' . $user_offset : $user_offset
2019-01-30 16:18:44 +01:00
);
return ui_print_info_message ( $message , '' , $return , $tag );
} else {
return '' ;
}
2018-06-11 16:40:10 +02:00
}
2019-01-30 16:18:44 +01:00
2018-05-21 14:29:11 +02:00
/**
* Get the custom docs logo
*
2019-05-28 10:47:31 +02:00
* @ return string with the path to logo . False if it should not be displayed .
2018-05-21 14:29:11 +02:00
*/
2019-01-30 16:18:44 +01:00
function ui_get_docs_logo ()
{
global $config ;
2019-05-28 10:47:31 +02:00
// Default logo to open version (enterprise_installed function only works in login status).
2019-11-21 11:14:50 +01:00
if ( ! file_exists ( ENTERPRISE_DIR . '/load_enterprise.php' ) || ! isset ( $config [ 'custom_docs_logo' ])) {
2023-02-23 10:32:01 +01:00
if ( is_metaconsole () === true ) {
return '../../images/icono_docs.png' ;
}
2019-01-30 16:18:44 +01:00
return 'images/icono_docs.png' ;
}
2018-05-21 14:29:11 +02:00
2019-11-21 11:14:50 +01:00
if ( $config [ 'custom_docs_logo' ] === '' ) {
2019-01-30 16:18:44 +01:00
return false ;
}
2018-05-21 14:29:11 +02:00
2019-01-30 16:18:44 +01:00
return 'enterprise/images/custom_general_logos/' . $config [ 'custom_docs_logo' ];
2018-05-21 14:29:11 +02:00
}
2019-01-30 16:18:44 +01:00
2018-05-21 14:29:11 +02:00
/**
* Get the custom support logo
*
2019-05-28 10:47:31 +02:00
* @ return string with the path to logo . False if it should not be displayed .
2018-05-21 14:29:11 +02:00
*/
2019-01-30 16:18:44 +01:00
function ui_get_support_logo ()
{
global $config ;
2019-05-28 10:47:31 +02:00
// Default logo to open version (enterprise_installed function only works in login status).
2019-11-21 11:14:50 +01:00
if ( ! file_exists ( ENTERPRISE_DIR . '/load_enterprise.php' ) || ! isset ( $config [ 'custom_support_logo' ])) {
2023-02-23 10:32:01 +01:00
if ( is_metaconsole () === true ) {
return '../../images/icono_support.png' ;
}
2019-01-30 16:18:44 +01:00
return 'images/icono_support.png' ;
}
2018-05-21 14:29:11 +02:00
2019-11-21 11:14:50 +01:00
if ( $config [ 'custom_support_logo' ] === '' ) {
2019-01-30 16:18:44 +01:00
return false ;
}
2018-05-21 14:29:11 +02:00
2019-01-30 16:18:44 +01:00
return 'enterprise/images/custom_general_logos/' . $config [ 'custom_support_logo' ];
2018-05-21 14:29:11 +02:00
}
2019-01-30 16:18:44 +01:00
2018-05-22 13:40:23 +02:00
/**
* Get the custom header logo
*
2019-05-28 10:47:31 +02:00
* @ param boolean $white_bg Using white bg or not .
*
* @ return string with the path to logo . If it is not set , return the default value .
2018-05-22 13:40:23 +02:00
*/
2019-01-30 16:18:44 +01:00
function ui_get_custom_header_logo ( $white_bg = false )
{
global $config ;
if ( empty ( $config [ 'enterprise_installed' ])) {
return 'images/pandora_tinylogo_open.png' ;
}
2019-05-28 10:47:31 +02:00
$stored_logo = ( is_metaconsole ()) ? (( $white_bg ) ? $config [ 'meta_custom_logo_white_bg' ] : $config [ 'meta_custom_logo' ]) : (( $white_bg ) ? $config [ 'custom_logo_white_bg' ] : $config [ 'custom_logo' ]);
2019-01-30 16:18:44 +01:00
if ( empty ( $stored_logo )) {
return 'images/pandora_tinylogo.png' ;
}
return 'enterprise/images/custom_logo/' . $stored_logo ;
2018-05-22 13:40:23 +02:00
}
2019-01-30 16:18:44 +01:00
2018-05-23 18:19:24 +02:00
/**
* Get the central networkmap logo
*
* @ return string with the path to logo . If it is not set , return the default .
*/
2019-01-30 16:18:44 +01:00
function ui_get_logo_to_center_networkmap ()
{
global $config ;
2018-05-23 18:19:24 +02:00
2019-01-30 16:18:44 +01:00
if (( ! enterprise_installed ()) || empty ( $config [ 'custom_network_center_logo' ])) {
return 'images/networkmap/bola_pandora_network_maps.png' ;
}
2018-05-23 18:19:24 +02:00
2019-01-30 16:18:44 +01:00
return 'enterprise/images/custom_general_logos/' . $config [ 'custom_support_logo' ];
2018-05-23 18:19:24 +02:00
}
2018-05-24 16:59:50 +02:00
2019-01-30 16:18:44 +01:00
2018-05-24 16:59:50 +02:00
/**
* Get the mobile console login logo
*
* @ return string with the path to logo . If it is not set , return the default .
*/
2019-01-30 16:18:44 +01:00
function ui_get_mobile_login_icon ()
{
global $config ;
2018-05-24 16:59:50 +02:00
2019-01-30 16:18:44 +01:00
if (( ! enterprise_installed ()) || empty ( $config [ 'custom_mobile_console_logo' ])) {
return is_metaconsole () ? 'mobile/images/metaconsole_mobile.png' : 'mobile/images/pandora_mobile_console.png' ;
}
2018-05-24 16:59:50 +02:00
2019-01-30 16:18:44 +01:00
return 'enterprise/images/custom_general_logos/' . $config [ 'custom_mobile_console_logo' ];
2018-05-24 16:59:50 +02:00
}
2019-01-30 16:18:44 +01:00
2018-05-24 16:59:50 +02:00
/**
* Get the favicon
*
* @ return string with the path to logo . If it is not set , return the default .
*/
2019-01-30 16:18:44 +01:00
function ui_get_favicon ()
{
global $config ;
2018-05-24 16:59:50 +02:00
2019-01-30 16:18:44 +01:00
if ( empty ( $config [ 'custom_favicon' ])) {
2023-04-12 13:01:53 +02:00
return ( ! is_metaconsole ()) ? 'images/pandora.ico' : '/images/custom_favicon/favicon_meta.ico' ;
2019-01-30 16:18:44 +01:00
}
2018-05-24 16:59:50 +02:00
2019-01-30 16:18:44 +01:00
return 'images/custom_favicon/' . $config [ 'custom_favicon' ];
2018-05-24 16:59:50 +02:00
}
2019-04-05 13:18:38 +02:00
/**
* Show sorting arrows for tables
*
2019-05-28 10:47:31 +02:00
* @ param string $url_up Url_up .
* @ param string $url_down Url_down .
* @ param string $selectUp SelectUp .
* @ param string $selectDown SelectDown .
*
2019-04-05 13:18:38 +02:00
* @ return string HTML anchor link with the arrow icon .
*/
function ui_get_sorting_arrows ( $url_up , $url_down , $selectUp , $selectDown )
{
$arrow_up = 'images/sort_up_black.png' ;
$arrow_down = 'images/sort_down_black.png' ;
2023-05-29 10:32:43 +02:00
if ( is_metaconsole ()) {
$arrow_up = 'images/sort_up_black.png' ;
$arrow_down = 'images/sort_down_black.png' ;
}
2019-04-05 13:51:35 +02:00
// Green arrows for the selected.
2019-04-05 13:18:38 +02:00
if ( $selectUp === true ) {
$arrow_up = 'images/sort_up_green.png' ;
}
if ( $selectDown === true ) {
$arrow_down = 'images/sort_down_green.png' ;
}
return ' < span class = " sort_arrow " >
< a href = " '. $url_up .' " > '.html_print_image($arrow_up, true, [' alt ' => ' up ']).' </ a >
< a href = " '. $url_down .' " > '.html_print_image($arrow_down, true, [' alt ' => ' down ']).' </ a >
</ span > ' ;
}
2019-05-27 19:00:48 +02:00
/**
* Show breadcrums in the page titles
*
2019-05-28 10:47:31 +02:00
* @ param string $tab_name Tab name .
*
2019-05-27 19:00:48 +02:00
* @ return string HTML anchor with the name of the section .
*/
function ui_print_breadcrums ( $tab_name )
{
2019-05-29 17:10:21 +02:00
if ( is_array ( $tab_name )) {
return join ( ' / ' , $tab_name );
} else if ( $tab_name != '' ) {
2019-05-27 19:00:48 +02:00
$section = str_replace ( '_' , ' ' , $tab_name );
$section = ucwords ( $section );
2019-05-29 17:10:21 +02:00
$section = ' / ' . ___ ( $section );
2019-05-27 19:00:48 +02:00
}
return $section ;
}
2019-10-01 16:24:02 +02:00
/**
* Show last comment
*
2022-10-10 13:18:57 +02:00
* @ param string $comments String with comments .
2019-10-01 16:24:02 +02:00
*
* @ return string HTML string with the last comment of the events .
*/
2023-09-07 11:08:31 +02:00
function ui_print_comments ( $comment , $truncate_limit = 255 )
2019-10-01 16:24:02 +02:00
{
global $config ;
2023-07-07 12:53:14 +02:00
if ( empty ( $comment ) === true ) {
2022-10-10 13:18:57 +02:00
return '' ;
}
2019-10-01 16:24:02 +02:00
// Only show the last comment. If commment its too long,the comment will short with ...
2023-12-04 15:05:01 +01:00
// Forced time commentary to use copact date for optimize space in table.
2019-10-01 16:24:02 +02:00
// Else show comments hours ago
2023-07-07 12:53:14 +02:00
if ( $comment [ 'action' ] != 'Added comment' ) {
$comment [ 'comment' ] = $comment [ 'action' ];
2019-10-15 11:13:40 +02:00
}
2019-10-17 11:50:50 +02:00
2023-12-04 15:05:01 +01:00
$comment [ 'comment' ] = io_safe_output ( $comment [ 'comment' ]);
2022-12-15 15:28:58 +01:00
2023-12-04 15:05:01 +01:00
$short_comment = substr ( $comment [ 'comment' ], 0 , 20 );
2023-12-11 17:01:40 +01:00
$comentario = $comment [ 'comment' ];
2019-10-01 16:24:02 +02:00
2023-07-28 10:39:46 +02:00
if ( strlen ( $comentario ) >= $truncate_limit ) {
$comentario = ui_print_truncate_text (
$comentario ,
$truncate_limit ,
false ,
true ,
false ,
'…' ,
true ,
true ,
);
}
2019-10-01 16:24:02 +02:00
2023-12-11 17:01:40 +01:00
$comentario = '<i class="forced_title" data-use_title_for_force_title="1" data-title="' . date ( $config [ 'date_format' ], $comment [ 'utimestamp' ]) . '">' . ui_print_timestamp ( $comment [ 'utimestamp' ], true , [ 'style' => 'font-size: 10px; display: contents;' , 'prominent' => 'compact' ]) . ' (' . $comment [ 'id_user' ] . '): ' . $comment [ 'comment' ] . '' ;
if ( strlen ( $comentario ) > '200px' && $truncate_limit >= 255 ) {
$comentario = '<i class="forced_title" data-use_title_for_force_title="1" data-title="' . date ( $config [ 'date_format' ], $comment [ 'utimestamp' ]) . '">' . ui_print_timestamp ( $comment [ 'utimestamp' ], true , [ 'style' => 'font-size: 10px; display: contents;' , 'prominent' => 'compact' ]) . ' (' . $comment [ 'id_user' ] . '): ' . $short_comment . '...' ;
}
2023-07-28 10:39:46 +02:00
return $comentario ;
2019-10-01 16:24:02 +02:00
}
2019-11-05 17:09:29 +01:00
/**
* Get complete external pandora url .
*
* @ param string $url Url to be parsed .
*
* @ return string Full url .
*/
function ui_get_full_external_url ( string $url )
{
$url_parsed = parse_url ( $url );
if ( $url_parsed ) {
if ( ! isset ( $url_parsed [ 'scheme' ])) {
$url = 'http://' . $url ;
}
}
return $url ;
}
2020-06-19 23:03:37 +02:00
function ui_print_message_dialog ( $title , $text , $id = '' , $img = '' , $text_button = '' , $hidden = true )
{
if ( $hidden == true ) {
$style = 'display:none' ;
}
echo '<div id="message_dialog_' . $id . '" title="' . $title . '" style="' . $style . '">' ;
echo '<div class="content_dialog">' ;
echo '<div class="icon_message_dialog">' ;
2023-03-15 09:01:49 +01:00
echo html_print_image ( $img , true , [ 'alt' => $title , 'border' => 0 , 'class' => 'icon_connection_check' ]);
2020-06-19 23:03:37 +02:00
echo '</div>' ;
echo '<div class="content_message_dialog">' ;
echo '<div class="text_message_dialog">' ;
echo '<h1>' . $title . '</h1>' ;
echo '<p>' . $text . '</p>' ;
echo '<div id="err_msg"></div>' ;
echo '</div>' ;
echo '</div>' ;
echo '</div>' ;
echo '</div>' ;
}
2020-09-29 09:44:20 +02:00
2020-10-08 13:47:26 +02:00
/**
* Build a Query - Result editor structure
*
* @ param string $name Name of the structure
*
* @ return null
*/
function ui_query_result_editor ( $name = 'default' )
{
$editorSubContainer = html_print_div (
[
'id' => $name . '_editor_title' ,
'content' => '<p>' . __ ( 'Query' ) . '</p>' ,
],
true
);
$editorSubContainer .= html_print_div (
[
'id' => $name . '_editor' ,
'class' => 'query_result_editor' ,
],
true
);
$editorContainer = html_print_div (
[
'id' => $name . '_editor_container' ,
'class' => 'query_result_editor_container' ,
'content' => $editorSubContainer ,
],
true
);
$viewSubContainer = html_print_div (
[
'id' => $name . '_view_title' ,
'content' => '<p>' . __ ( 'Results' ) . '</p>' ,
],
true
);
$viewSubContainer .= html_print_div (
[
'id' => $name . '_view' ,
'class' => 'query_result_view' ,
],
true
);
$viewSubContainer .= html_print_div (
[
'class' => 'action-buttons' ,
'content' => '' ,
],
true
);
$viewContainer = html_print_div (
[
'id' => $name . '_view_container' ,
'class' => 'query_result_view_container' ,
'content' => $viewSubContainer ,
],
true
);
html_print_div (
[
'id' => 'query_result_container' ,
'class' => 'databox' ,
'content' => $editorContainer . $viewContainer ,
]
);
// This is needed for Javascript
html_print_div (
[
'id' => 'pandora_full_url' ,
'hidden' => true ,
'content' => ui_get_full_url ( false , false , false , false ),
]
);
2023-03-14 17:28:17 +01:00
2023-09-13 15:19:42 +02:00
$execute_button = html_print_submit_button ( __ ( 'Execute query' ), 'execute_query' , false , [ 'icon' => 'update' ], true );
html_print_action_buttons ( $execute_button );
2023-05-11 15:39:58 +02:00
2020-12-02 11:28:46 +01:00
}
2020-09-29 09:44:20 +02:00
/**
* Generate a button for reveal the content of the password field .
*
* @ param string $name Name of the field .
* @ param boolean $return If true , return the string with the formed element .
*
* @ return string
*/
function ui_print_reveal_password ( string $name , bool $return = false )
{
2020-09-29 12:21:52 +02:00
if ( is_metaconsole ()) {
$imagePath = '../../images/' ;
} else {
$imagePath = 'images/' ;
}
2021-03-11 15:40:23 +01:00
$output = ' <img class="clickable forced_title invert_filter" id="reveal_password_' . $name . '" src="' . $imagePath . 'eye_show.png" onclick="reveal_password(\'' . $name . '\')" data-use_title_for_force_title="1" data-title="' . __ ( 'Show password' ) . '">' ;
2020-09-29 09:44:20 +02:00
if ( $return === true ) {
return $output ;
}
echo $output ;
}
2021-02-08 16:33:54 +01:00
/**
* Generate a spinner box for waiting times
2021-02-12 11:28:13 +01:00
* TIP : It ' s made for Massive Operations , but it migth used in entire project .
2021-02-08 16:33:54 +01:00
*
2021-02-12 11:28:13 +01:00
* @ param string $text Text for show in spinner . English term Loading for default .
2021-02-08 16:33:54 +01:00
* @ param boolean $return If true , return the string with the formed element .
*
* @ return string
*/
function ui_print_spinner ( string $text = 'Loading' , bool $return = false )
{
$output = '' ;
$output .= '<center>' ;
$output .= html_print_div (
[
'id' => 'loading_spinner' ,
'class' => 'white_box invisible' ,
'content' => '<span style="font-size:25px;">' . $text . '...</span>' . html_print_image (
'images/spinner.gif' ,
true ,
[
2023-03-01 13:32:15 +01:00
'class' => 'main_menu_icon' ,
2021-02-08 16:33:54 +01:00
'border' => '0' ,
'width' => '25px' ,
'heigth' => '25px' ,
]
),
],
true
);
$output .= '</center>' ;
$output .= '
< script type = " text/javascript " >
function hideSpinner () {
document . getElementById ( " loading_spinner " ) . classList . add ( " invisible " );
}
function showSpinner () {
document . getElementById ( " loading_spinner " ) . classList . remove ( " invisible " );
}
</ script >
' ;
if ( $return === true ) {
return $output ;
} else {
echo $output ;
}
}
2022-12-19 16:38:47 +01:00
/**
* Return a formed server type icon .
*
* @ param integer $id Id of server type .
*
* @ return string .
*/
function ui_print_servertype_icon ( int $id )
{
switch ( $id ) {
case MODULE_DATA :
$title = __ ( 'Data server' );
$image = 'images/data-server@svg.svg' ;
break ;
case MODULE_NETWORK :
$title = __ ( 'Network server' );
2023-03-07 11:48:14 +01:00
$image = 'images/network-server@os.svg' ;
2022-12-19 16:38:47 +01:00
break ;
case MODULE_PLUGIN :
$title = __ ( 'Plugin server' );
$image = 'images/plugins@svg.svg' ;
break ;
case MODULE_PREDICTION :
$title = __ ( 'Prediction server' );
$image = 'images/prediction@svg.svg' ;
break ;
case MODULE_WMI :
$title = __ ( 'WMI server' );
$image = 'images/WMI@svg.svg' ;
break ;
case MODULE_WEB :
$title = __ ( 'WEB server' );
$image = 'images/server-web@svg.svg' ;
break ;
case MODULE_WUX :
$title = __ ( 'WUX server' );
$image = 'images/wux@svg.svg' ;
break ;
case MODULE_WIZARD :
$title = __ ( 'Wizard Module' );
$image = 'images/wizard@svg.svg' ;
break ;
default :
$title = '' ;
$image = '' ;
break ;
}
if ( empty ( $title ) === true && empty ( $image ) === true ) {
$return = '--' ;
} else {
$return = html_print_image (
$image ,
true ,
[
'title' => sprintf ( '%s %s' , get_product_name (), $title ),
'class' => 'invert_filter main_menu_icon' ,
]
);
}
return $return ;
}
2023-01-31 17:35:44 +01:00
2022-09-14 18:12:39 +02:00
function ui_get_inventory_module_add_form (
$form_action ,
$form_buttons = '' ,
$inventory_module_id = 0 ,
$os_id = false ,
$target = false ,
$interval = 3600 ,
$username = '' ,
$password = '' ,
$custom_fields_enabled = false ,
$custom_fields = []
) {
$table = new stdClass ();
$table -> id = 'inventory-module-form' ;
$table -> width = '100%' ;
2023-03-13 16:13:49 +01:00
$table -> class = 'databox filters filter-table-adv' ;
$table -> size [ 'module' ] = '50%' ;
$table -> size [ 'interval' ] = '50%' ;
$table -> size [ 'target' ] = '50%' ;
$table -> size [ 'chkbx-custom-fields' ] = '50%' ;
$table -> size [ 'username' ] = '50%' ;
$table -> size [ 'password' ] = '50%' ;
2022-09-14 18:12:39 +02:00
$table -> rowstyle = [];
$table -> rowstyle [ 'hidden-custom-field-row' ] = 'display: none;' ;
2023-03-13 16:13:49 +01:00
$table -> rowstyle [ 'custom-fields-button' ] = 'display: none;' ;
2022-09-14 18:12:39 +02:00
$table -> data = [];
$row = [];
if ( empty ( $inventory_module_id )) {
if ( empty ( $os_id )) {
$sql = ' SELECT mi . id_module_inventory AS id , mi . name AS name , co . name AS os
FROM tmodule_inventory mi , tconfig_os co
WHERE co . id_os = mi . id_os
ORDER BY co . name , mi . name ' ;
$inventory_modules_raw = db_get_all_rows_sql ( $sql );
$inventory_modules = [];
foreach ( $inventory_modules_raw as $im ) {
$inventory_modules [ $im [ 'id' ]] = [
'name' => $im [ 'name' ],
'optgroup' => $im [ 'os' ],
];
}
} else {
$sql = sprintf (
' SELECT id_module_inventory AS id , name
FROM tmodule_inventory
WHERE id_os = % d
ORDER BY name ' ,
$os_id
);
$inventory_modules_raw = db_get_all_rows_sql ( $sql );
$inventory_modules = [];
foreach ( $inventory_modules_raw as $im ) {
$inventory_modules [ $im [ 'id' ]] = $im [ 'name' ];
}
}
2023-03-13 16:13:49 +01:00
$row [ 'module' ] = html_print_label_input_block (
__ ( 'Module' ),
html_print_select (
$inventory_modules ,
'id_module_inventory' ,
0 ,
'' ,
__ ( 'Select inventory module' ),
2023-04-18 11:36:17 +02:00
'' ,
2023-03-13 16:13:49 +01:00
true ,
false ,
false ,
'w100p' ,
false ,
2023-04-18 11:36:17 +02:00
'width: 100%' ,
false ,
false ,
false ,
'' ,
false ,
false ,
true
2023-03-13 16:13:49 +01:00
)
);
2022-09-14 18:12:39 +02:00
} else {
2023-03-13 16:13:49 +01:00
$row [ 'module' ] = html_print_label_input_block (
__ ( 'Module' ),
db_get_sql ( 'SELECT name FROM tmodule_inventory WHERE id_module_inventory = ' . $inventory_module_id )
);
2022-09-14 18:12:39 +02:00
}
2023-03-13 16:13:49 +01:00
$row [ 'interval' ] = html_print_label_input_block (
__ ( 'Interval' ),
html_print_extended_select_for_time (
'interval' ,
$interval ,
'' ,
'' ,
'' ,
false ,
true ,
false ,
true ,
'w100p'
)
);
2022-09-14 18:12:39 +02:00
$table -> data [ 'first-row' ] = $row ;
$row = [];
if ( $target !== false ) {
2023-03-13 16:13:49 +01:00
$row [ 'target' ] = html_print_label_input_block (
__ ( 'Target' ),
html_print_input_text (
'target' ,
$target ,
'' ,
25 ,
40 ,
true ,
false ,
false ,
'' ,
'w100p'
)
);
2022-09-14 18:12:39 +02:00
}
2023-03-13 16:13:49 +01:00
$row [ 'chkbx-custom-fields' ] = html_print_label_input_block (
__ ( 'Use custom fields' ),
html_print_checkbox (
'custom_fields_enabled' ,
1 ,
$custom_fields_enabled ,
true
)
);
2022-09-14 18:12:39 +02:00
$table -> data [ 'second-row' ] = $row ;
$row = [];
2023-03-13 16:13:49 +01:00
$row [ 'username' ] = html_print_label_input_block (
__ ( 'Username' ),
html_print_input_text (
'username' ,
$username ,
'' ,
25 ,
40 ,
true ,
false ,
false ,
'' ,
'w100p'
)
);
$row [ 'password' ] = html_print_label_input_block (
__ ( 'Password' ),
html_print_input_password (
'password' ,
$password ,
'' ,
25 ,
40 ,
true ,
false ,
false ,
'w100p'
)
);
2022-09-14 18:12:39 +02:00
$table -> data [ 'userpass-row' ] = $row ;
$row = [];
2023-04-14 12:24:39 +02:00
$table -> data [ 'hidden-custom-field-row' ] = html_print_label_input_block (
2023-03-13 16:13:49 +01:00
'' ,
2023-04-14 12:24:39 +02:00
'<div class="agent_details_agent_data">' . html_print_input_hidden (
'hidden-custom-field-name' ,
'' ,
true
) . html_print_input_hidden (
'hidden-custom-field-is-secure' ,
0 ,
true
) . html_print_input_text (
'hidden-custom-field-input' ,
'' ,
'' ,
25 ,
40 ,
true ,
false ,
false ,
'' ,
'w100p'
) . html_print_image (
'images/delete.svg' ,
true ,
[
'border' => '0' ,
'title' => __ ( 'Remove' ),
'style' => 'cursor: pointer;' ,
'class' => 'remove-custom-field invert_filter main_menu_icon' ,
]
) . '</div>'
2022-09-14 18:12:39 +02:00
);
2023-04-14 12:24:39 +02:00
$table -> colspan [ 'hidden-custom-field-row' ][ 0 ] = 2 ;
2022-09-14 18:12:39 +02:00
if ( $custom_fields_enabled ) {
foreach ( $custom_fields as $i => $field ) {
if ( $field [ 'secure' ]) {
2023-04-14 12:24:39 +02:00
$secure = html_print_input_password (
2022-09-14 18:12:39 +02:00
'custom_fields[' . $i . '][value]' ,
2023-04-18 09:49:35 +02:00
io_safe_input ( $field [ 'value' ]),
2022-09-14 18:12:39 +02:00
'' ,
2023-04-14 12:24:39 +02:00
false ,
2022-09-14 18:12:39 +02:00
40 ,
2023-04-14 12:24:39 +02:00
true ,
false ,
false ,
'' ,
'off' ,
false ,
'w100p'
2022-09-14 18:12:39 +02:00
);
} else {
2023-04-14 12:24:39 +02:00
$secure = html_print_input_text (
2022-09-14 18:12:39 +02:00
'custom_fields[' . $i . '][value]' ,
2023-04-18 09:49:35 +02:00
io_safe_input ( $field [ 'value' ]),
2022-09-14 18:12:39 +02:00
'' ,
2023-04-12 10:25:35 +02:00
false ,
2022-09-14 18:12:39 +02:00
40 ,
2023-04-12 10:25:35 +02:00
true ,
false ,
false ,
'' ,
2023-04-14 12:24:39 +02:00
'w100p'
2022-09-14 18:12:39 +02:00
);
}
2023-04-14 12:24:39 +02:00
$table -> colspan [ 'custom-field-row-' . $i ][ 0 ] = 2 ;
$table -> data [ 'custom-field-row-' . $i ] = html_print_label_input_block (
$field [ 'name' ],
'<div class="agent_details_agent_data">' . html_print_input_hidden (
'custom_fields[' . $i . '][name]' ,
$field [ 'name' ],
true
) . html_print_input_hidden (
'custom_fields[' . $i . '][secure]' ,
$field [ 'secure' ],
true
) . $secure . html_print_image (
'images/delete.svg' ,
true ,
[
'border' => '0' ,
'title' => __ ( 'Remove' ),
'style' => 'cursor: pointer;' ,
'class' => 'remove-custom-field invert_filter main_menu_icon' ,
]
) . '</div>'
2022-09-14 18:12:39 +02:00
);
}
}
$row = [];
2023-03-13 16:13:49 +01:00
$row [ 'custom-fields-column' ] = html_print_label_input_block (
__ ( 'Field name' ),
'<div class="flex">' . html_print_input_text (
'field-name' ,
'' ,
'' ,
25 ,
40 ,
true ,
false ,
false ,
'' ,
'w60p mrgn_right_10px'
) . html_print_checkbox (
'field-is-password' ,
1 ,
false ,
true
) . ' ' . __ ( " It's a password " ) . '</div>'
);
2022-09-14 18:12:39 +02:00
$table -> data [ 'custom-fields-row' ] = $row ;
2023-03-13 16:13:49 +01:00
$row = [];
$row [ 'custom-fields-button-title' ] = '' ;
$row [ 'custom-fields-button' ] = html_print_button (
__ ( 'Add field' ),
'add-field' ,
false ,
'' ,
[
'class' => 'mini float-right' ,
'icon' => 'plus' ,
],
true
);
$table -> data [ 'custom-fields-button' ] = $row ;
2022-09-14 18:12:39 +02:00
ob_start ();
2023-03-21 14:06:28 +01:00
echo '<form id="policy_inventory_module_edit_form" name="modulo" method="post" action="' . $form_action . '" class="max_floating_element_size">' ;
2022-09-14 18:12:39 +02:00
echo html_print_table ( $table );
echo $form_buttons ;
echo '</form>' ;
?>
< script type = " text/javascript " >
( function () {
function toggle_custom_fields () {
if ( $ ( " #checkbox-custom_fields_enabled " ) . prop ( " checked " )) {
$ ( " #inventory-module-form-userpass-row " ) . hide ();
$ ( " #inventory-module-form-custom-fields-row " ) . show ();
$ ( " tr[id^=inventory-module-form-custom-field-row-] " ) . show ();
2023-04-12 10:25:35 +02:00
$ ( '#inventory-module-form-custom-fields-button' ) . show ();
2022-09-14 18:12:39 +02:00
} else {
$ ( " #inventory-module-form-userpass-row " ) . show ();
$ ( " #inventory-module-form-custom-fields-row " ) . hide ();
$ ( " tr[id^=inventory-module-form-custom-field-row-] " ) . hide ();
2023-04-12 10:25:35 +02:00
$ ( '#inventory-module-form-custom-fields-button' ) . hide ();
2022-09-14 18:12:39 +02:00
}
}
function add_row_for_custom_field ( fieldName , isSecure ) {
var custom_fields_num = $ ( " tr[id^=inventory-module-form-custom-field-row-] " ) . length ;
$ ( " #inventory-module-form-hidden-custom-field-row " )
2023-04-14 12:24:39 +02:00
. clone ()
. prop ( " id " , " inventory-module-form-custom-field-row- " + custom_fields_num )
. children ( " [id^='inventory-module-form-hidden-custom-field-row'] " ) // go to TD
. prop ( " id " , " inventory-module-form-hidden-custom-field-row- " + custom_fields_num )
. children () // go to DIV
. find ( 'label' )
. html ( fieldName )
. parent () // up to DIV padre
. find ( 'div' ) //go to DIV no label
. children ( " [id^=hidden-hidden-custom-field-name] " )
2022-09-14 18:12:39 +02:00
. prop ( " id " , " custom-field-name- " + custom_fields_num )
. prop ( " name " , " custom_fields[ " + custom_fields_num + " ][name] " )
2023-04-14 12:24:39 +02:00
. prop ( " value " , fieldName )
2022-09-14 18:12:39 +02:00
. parent ()
2023-04-14 12:24:39 +02:00
. children ( " input[name=hidden-custom-field-is-secure] " )
. prop ( " id " , " custom-field-is-secure- " + custom_fields_num )
. prop ( " name " , " custom_fields[ " + custom_fields_num + " ][secure] " )
. val ( isSecure ? 1 : 0 )
. parent ()
. children ( " input[name=hidden-custom-field-input] " )
. prop ( " id " , " custom-field-input- " + custom_fields_num )
. prop ( " type " , isSecure ? " password " : " text " )
. prop ( " name " , " custom_fields[ " + custom_fields_num + " ][value] " )
. parent ()
. children ( " img.remove-custom-field " )
. click ( remove_custom_field )
. parent ()
. parent ()
. parent () // up to TD
. parent () // up to TR
. insertBefore ( $ ( " #inventory-module-form-custom-fields-row " ))
. show ();
2022-09-14 18:12:39 +02:00
}
function add_custom_field () {
var fieldName = $ ( " #text-field-name " ) . val ();
var isSecure = $ ( " #checkbox-field-is-password " ) . prop ( " checked " );
if ( fieldName . length === 0 ) return ;
add_row_for_custom_field ( fieldName , isSecure );
// Clean the fields
$ ( " #text-field-name " ) . val ( " " );
$ ( " #checkbox-field-is-password " ) . prop ( " checked " , false );
}
function remove_custom_field ( event ) {
$ ( event . target ) . parents ( " tr[id^=inventory-module-form-custom-field-row-] " ) . remove ();
}
$ ( " #checkbox-custom_fields_enabled " ) . click ( toggle_custom_fields );
$ ( " #button-add-field " ) . click ( add_custom_field );
$ ( " img.remove-custom-field " ) . click ( remove_custom_field );
toggle_custom_fields ();
})();
</ script >
< ? php
return ob_get_clean ();
}
2023-02-10 11:47:20 +01:00
/**
* Print Fullscreen Bar .
*
* @ param array $options Fullsreen options .
* @ param boolean $return If true , return the formed element .
*
* @ return void | string
*/
function ui_print_fullscreen_bar ( array $options , bool $return = false )
{
// Always requery file.
ui_require_jquery_file ( 'countdown' );
// Vars.
$url = ( $options [ 'url' ] ? ? '' );
$normalScreenTitle = ( $options [ 'normal_screen_title' ] ? ? 'Back to normal mode' );
$mainTitle = ( $options [ 'title' ] ? ? 'Full screen mode' );
$title = '<span class="">' . __ ( 'Refresh' ) . '</span>' ;
$select = html_print_select (
get_refresh_time_array (),
'refresh' ,
( int ) get_parameter ( 'refresh' ),
'' ,
'' ,
0 ,
true ,
false ,
false ,
'' ,
false ,
'margin-top: 3px;'
);
$vcRefrDivContent = [];
$vcRefrDivContent [] = html_print_div ([ 'class' => 'vc-countdown inline_line' ], true );
$vcRefrDivContent [] = html_print_div (
[
'id' => 'vc-refr-form' ,
'content' => $title . $select ,
],
true
);
// Floating menu - Start.
$menuTabContent [] = '<ul class="mn">' ;
// Quit fullscreen.
$menuTabContent [] = '<li class="nomn">' ;
$menuTabContent [] = html_print_anchor (
[
'href' => $url ,
'content' => html_print_image (
'images/exit_fullscreen@svg.svg' ,
true ,
[
'title' => __ ( $normalScreenTitle ),
'class' => 'invert_filter main_menu_icon' ,
]
),
],
true
);
$menuTabContent [] = '</li>' ;
// Countdown.
$menuTabContent [] = '<li class="nomn">' ;
$menuTabContent [] = html_print_div (
[
'class' => 'vc-refr' ,
'content' => implode ( '' , $vcRefrDivContent ),
],
true
);
$menuTabContent [] = '</li>' ;
// Console name.
$menuTabContent [] = '<li class="nomn">' ;
$menuTabContent [] = html_print_div (
[
'class' => 'vc-title' ,
'content' => __ ( $mainTitle ),
],
true
);
$menuTabContent [] = '</li>' ;
$menuTabContent [] = '</ul>' ;
return html_print_div (
[
'id' => 'menu_tab' ,
'class' => 'full_screen_control_bar' ,
'content' => implode ( '' , $menuTabContent ),
],
$return
);
}
2023-03-03 08:20:44 +01:00
2023-02-06 16:34:40 +01:00
function ui_print_status_div ( $status )
{
switch (( int ) $status ) {
case 0 :
$return = '<div class="status_rounded_rectangles forced_title" style="display: inline-block; background: #82b92e;" title="OK" data-title="OK" data-use_title_for_force_title="1"> </div>' ;
break ;
case 1 :
$return = '<div class="status_rounded_rectangles forced_title" style="display: inline-block; background: #e63c52;" title="FAILED" data-title="FAILED" data-use_title_for_force_title="1"> </div>' ;
break ;
default :
$return = '<div class="status_rounded_rectangles forced_title" style="display: inline-block; background: #fff;" title="UNDEFINED" data-title="UNDEFINED" data-use_title_for_force_title="1"> </div>' ;
break ;
}
return $return ;
2023-03-08 12:55:53 +01:00
}
2023-09-21 10:21:45 +02:00
function ui_print_div ( ? string $class = '' , ? string $title = '' )
{
$return = '<div class="' . $class . '" title="' . $title . '" data-title="' . $title . '" data-use_title_for_force_title="1">' ;
$return .= ' ' ;
$return .= '</div>' ;
return $return ;
}
function ui_print_status_agent_div ( int $status , ? string $title = null )
{
$return = '' ;
$class = 'status_rounded_rectangles forced_title' ;
switch (( int ) $status ) {
case AGENT_STATUS_CRITICAL :
$return = ui_print_div ( 'group_view_crit ' . $class , $title );
break ;
case AGENT_STATUS_NORMAL :
$return = ui_print_div ( 'group_view_ok ' . $class , $title );
break ;
case AGENT_STATUS_NOT_INIT :
$return = ui_print_div ( 'group_view_not_init ' . $class , $title );
break ;
case AGENT_STATUS_UNKNOWN :
$return = ui_print_div ( 'group_view_unk ' . $class , $title );
break ;
case AGENT_STATUS_WARNING :
$return = ui_print_div ( 'group_view_warn ' . $class , $title );
break ;
case AGENT_STATUS_ALERT_FIRED :
$return = ui_print_div ( 'group_view_alrm ' . $class , $title );
break ;
default :
// Not posible.
break ;
}
return $return ;
}
2023-02-23 09:48:13 +01:00
function ui_print_fav_menu ( $id_element , $url , $label , $section )
{
global $config ;
$label = io_safe_output ( $label );
if ( strlen ( $label ) > 18 ) {
$label = io_safe_input ( substr ( $label , 0 , 18 ) . '...' );
}
$fav = db_get_row_filter (
'tfavmenu_user' ,
[
'url' => $url ,
'id_user' => $config [ 'id_user' ],
],
[ '*' ]
);
$config_fav_menu = [
'id_element' => $id_element ,
'url' => $url ,
'label' => $label ,
'section' => $section ,
];
$output = '<span class="fav-menu">' ;
$output .= html_print_input_image (
'fav-menu-action' ,
2023-02-27 09:45:15 +01:00
(( $fav !== false ) ? 'images/star_fav_menu.png' : 'images/star_dark.png' ),
2023-02-23 09:48:13 +01:00
base64_encode ( json_encode ( $config_fav_menu )),
'' ,
true ,
2023-02-27 10:05:16 +01:00
[
'onclick' => 'favMenuAction(this)' ,
'class' => (( $fav !== false ) ? 'active' : '' ),
]
2023-02-23 09:48:13 +01:00
);
$output .= '</span>' ;
2023-02-24 10:23:14 +01:00
$output .= '<div id="dialog-fav-menu">' ;
$output .= '<p><b>' . __ ( 'Title' ) . '</b></p>' ;
$output .= html_print_input_text ( 'label_fav_menu' , '' , '' , 25 , 255 , true , false , true );
$output .= '</div>' ;
2023-02-23 09:48:13 +01:00
return $output ;
2023-03-17 12:25:43 +01:00
}
2023-03-30 18:27:03 +02:00
function ui_print_tree (
$tree ,
$id = 0 ,
$depth = 0 ,
$last = 0 ,
$last_array = [],
$sufix = false ,
$descriptive_ids = false ,
$previous_id = ''
) {
static $url = false ;
$output = '' ;
// Get the base URL for images.
if ( $url === false ) {
$url = ui_get_full_url ( 'operation/tree' , false , false , false );
}
// Leaf.
if ( empty ( $tree [ '__LEAVES__' ])) {
return '' ;
}
$count = 0 ;
$total = ( count ( array_keys ( $tree [ '__LEAVES__' ])) - 1 );
$last_array [ $depth ] = $last ;
$class = 'item_' . $depth ;
if ( $depth > 0 ) {
$output .= '<ul id="ul_' . $id . '" class="mrgn_0px pdd_0px invisible">' ;
} else {
$output .= '<ul id="ul_' . $id . '" class="mrgn_0px pdd_0px">' ;
}
foreach ( $tree [ '__LEAVES__' ] as $level => $sub_level ) {
// Id used to expand leafs.
$sub_id = time () . rand ( 0 , getrandmax ());
// Display the branch.
$output .= '<li id="li_' . $sub_id . '" class="' . $class . ' mrgn_0px pdd_0px">' ;
// Indent sub branches.
for ( $i = 1 ; $i <= $depth ; $i ++ ) {
if ( $last_array [ $i ] == 1 ) {
$output .= '<img src="' . $url . '/no_branch.png" class="vertical_middle">' ;
} else {
$output .= '<img src="' . $url . '/branch.png" class="vertical_middle">' ;
}
}
// Branch.
if ( ! empty ( $sub_level [ 'sublevel' ][ '__LEAVES__' ])) {
$output .= " <a id='anchor_ $sub_id ' onfocus='javascript: this.blur();' href='javascript: toggleTreeNode( \" $sub_id\ " , \ " $id\ " ); ' > " ;
if ( $depth == 0 && $count == 0 ) {
if ( $count == $total ) {
$output .= '<img src="' . $url . '/one_closed.png" class="vertical_middle">' ;
} else {
$output .= '<img src="' . $url . '/first_closed.png" class="vertical_middle">' ;
}
} else if ( $count == $total ) {
$output .= '<img src="' . $url . '/last_closed.png" class="vertical_middle">' ;
} else {
$output .= '<img src="' . $url . '/closed.png" class="vertical_middle">' ;
}
$output .= '</a>' ;
}
// Leave.
else {
if ( $depth == 0 && $count == 0 ) {
if ( $count == $total ) {
$output .= '<img src="' . $url . '/no_branch.png" class="vertical_middle">' ;
} else {
$output .= '<img src="' . $url . '/first_leaf.png" class="vertical_middle">' ;
}
} else if ( $count == $total ) {
$output .= '<img src="' . $url . '/last_leaf.png" class="vertical_middle">' ;
} else {
$output .= '<img src="' . $url . '/leaf.png" class="vertical_middle">' ;
}
}
$checkbox_name_sufix = ( $sufix === true ) ? '_' . $level : '' ;
if ( $descriptive_ids === true ) {
$checkbox_name = 'create_' . $sub_id . $previous_id . $checkbox_name_sufix ;
} else {
$checkbox_name = 'create_' . $sub_id . $checkbox_name_sufix ;
}
$previous_id = $checkbox_name_sufix ;
if ( $sub_level [ 'selectable' ] === true ) {
2023-03-31 13:46:28 +02:00
$output .= html_print_checkbox (
$sub_level [ 'name' ],
$sub_level [ 'value' ],
$sub_level [ 'checked' ],
true ,
false ,
'' ,
true
);
2023-03-30 18:27:03 +02:00
}
$output .= ' <span>' . $sub_level [ 'label' ] . '</span>' ;
$output .= '</li>' ;
// Recursively print sub levels.
$output .= ui_print_tree (
$sub_level [ 'sublevel' ],
$sub_id ,
( $depth + 1 ),
(( $count == $total ) ? 1 : 0 ),
$last_array ,
$sufix ,
$descriptive_ids ,
$previous_id
);
$count ++ ;
}
$output .= '</ul>' ;
2023-02-23 09:48:13 +01:00
return $output ;
2023-04-12 12:32:30 +02:00
}
2023-03-17 12:25:43 +01:00
function ui_update_name_fav_element ( $id_element , $section , $label )
{
$label = io_safe_output ( $label );
if ( strlen ( $label ) > 18 ) {
$label = io_safe_input ( substr ( $label , 0 , 18 ) . '...' );
}
db_process_sql_update (
'tfavmenu_user' ,
[ 'label' => $label ],
[
'section' => $section ,
'id_element' => $id_element ,
]
);
2023-05-23 12:25:56 +02:00
}
2023-11-13 09:38:24 +01:00
function ui_print_status_vulnerability_div ( float $score )
{
$return = '' ;
$class = 'status_rounded_rectangles forced_title' ;
if ((( float ) $score ) <= 5 ) {
return ui_print_div ( 'group_view_ok ' . $class , $score );
}
if ((( float ) $score ) > 5 && (( float ) $score ) <= 7.5 ) {
return ui_print_div ( 'group_view_warn ' . $class , $score );
}
if ((( float ) $score ) > 7.5 ) {
return ui_print_div ( 'group_view_crit ' . $class , $score );
}
return $return ;
2023-11-13 15:27:07 +01:00
}
2023-11-14 09:33:04 +01:00
function ui_print_status_secmon_div ( $status , $title = false )
2023-11-13 15:27:07 +01:00
{
$class = 'status_rounded_rectangles forced_title' ;
if (( $status ) === 'normal' ) {
2023-11-14 09:33:04 +01:00
$title = ( $title === false ) ? __ ( 'normal' ) : $title ;
return ui_print_div ( 'group_view_ok ' . $class , $title );
2023-11-13 15:27:07 +01:00
}
if (( $status ) === 'warning' ) {
2023-11-14 09:33:04 +01:00
$title = ( $title === false ) ? __ ( 'warning' ) : $title ;
return ui_print_div ( 'group_view_warn ' . $class , $title );
2023-11-13 15:27:07 +01:00
}
if (( $status ) === 'critical' ) {
2023-11-14 09:33:04 +01:00
$title = ( $title === false ) ? __ ( 'critical' ) : $title ;
return ui_print_div ( 'group_view_crit ' . $class , $title );
2023-11-13 15:27:07 +01:00
}
2023-11-13 09:38:24 +01:00
}