2006-07-12 15:43:41 +02:00
|
|
|
<?php
|
2023-02-13 10:24:07 +01:00
|
|
|
/**
|
|
|
|
* Operation menu.
|
|
|
|
*
|
|
|
|
* @category Menu
|
|
|
|
* @package Pandora FMS
|
|
|
|
* @subpackage Community
|
|
|
|
* @version 1.0.0
|
|
|
|
* @license See below
|
|
|
|
*
|
|
|
|
* ______ ___ _______ _______ ________
|
2023-06-08 12:42:10 +02:00
|
|
|
* | __ \.-----.--.--.--| |.-----.----.-----. | ___| | | __|
|
|
|
|
* | __/| _ | | _ || _ | _| _ | | ___| |__ |
|
2023-02-13 10:24:07 +01: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
|
2023-02-13 10:24:07 +01: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.
|
|
|
|
* ============================================================================
|
|
|
|
*/
|
2006-07-12 15:43:41 +02:00
|
|
|
|
2023-02-13 10:24:07 +01:00
|
|
|
// Begin.
|
2019-01-30 16:18:44 +01:00
|
|
|
if (! isset($config['id_user'])) {
|
|
|
|
return;
|
2008-08-04 10:15:16 +02:00
|
|
|
}
|
2008-10-22 11:08:03 +02:00
|
|
|
|
2020-03-26 12:29:38 +01:00
|
|
|
use PandoraFMS\Dashboard\Manager;
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
require_once 'include/functions_menu.php';
|
|
|
|
require_once $config['homedir'].'/include/functions_visual_map.php';
|
2022-10-20 09:43:02 +02:00
|
|
|
require_once 'include/class/MenuItem.class.php';
|
2009-03-03 16:21:13 +01:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
enterprise_include('operation/menu.php');
|
2006-12-15 18:39:11 +01:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$menu_operation = [];
|
2012-06-18 17:16:17 +02:00
|
|
|
$menu_operation['class'] = 'operation';
|
2023-02-13 10:24:07 +01:00
|
|
|
/*
|
|
|
|
$menuOperation = [];
|
|
|
|
|
|
|
|
$subMenuMonitoring = [];
|
|
|
|
|
|
|
|
|
|
|
|
$subMenuMonitoringViews = [];
|
|
|
|
|
|
|
|
// L0. Monitoring.
|
|
|
|
$menuOperation['monitoring'] = new MenuItem(__('Monitoring'));
|
|
|
|
$menuOperation['monitoring']->setIcon('icon');
|
|
|
|
$menuOperation['monitoring']->setClass('menu');
|
|
|
|
$menuOperation['monitoring']->setACL(['AR']);
|
|
|
|
$monitoringItems = [];
|
|
|
|
|
|
|
|
// L1. Views.
|
|
|
|
$monitoringItems['views'] = new MenuItem(__('Views'));
|
|
|
|
$monitoringItems['views']->setIcon('icono');
|
|
|
|
$monitoringItems['views']->setClass('submenu');
|
|
|
|
$monitoringViewsItems = [];
|
|
|
|
|
|
|
|
// L2. Tactical view.
|
|
|
|
$monitoringViewsItems['tacticalView'] = new MenuItem(__('Tactical view'));
|
|
|
|
$monitoringViewsItems['tacticalView']->setSec('view');
|
|
|
|
$monitoringViewsItems['tacticalView']->setSec2('operation/agentes/tactical');
|
|
|
|
$monitoringViewsItems['tacticalView']->setClass('submenu');
|
|
|
|
|
|
|
|
// L2. Group View.
|
|
|
|
$monitoringViewsItems['groupView'] = new MenuItem(__('Group view'));
|
|
|
|
$monitoringViewsItems['groupView']->setSec('view');
|
|
|
|
$monitoringViewsItems['groupView']->setSec2('operation/agentes/group_view');
|
|
|
|
$monitoringViewsItems['groupView']->setClass('submenu');
|
|
|
|
|
|
|
|
// L2. Tree View.
|
|
|
|
$monitoringViewsItems['treeView'] = new MenuItem(__('Tree view'));
|
|
|
|
$monitoringViewsItems['treeView']->setSec('view');
|
|
|
|
$monitoringViewsItems['treeView']->setSec2('operation/tree');
|
|
|
|
$monitoringViewsItems['treeView']->setClass('submenu');
|
|
|
|
|
|
|
|
// L2. Monitor detail.
|
|
|
|
$monitoringViewsItems['monitorDetail'] = new MenuItem(__('Monitor detail'));
|
|
|
|
$monitoringViewsItems['monitorDetail']->setSec('view');
|
|
|
|
$monitoringViewsItems['monitorDetail']->setSec2('operation/agentes/status_monitor');
|
|
|
|
$monitoringViewsItems['monitorDetail']->setClass('submenu');
|
|
|
|
|
|
|
|
// L2. Interface view.
|
|
|
|
$monitoringViewsItems['interfaceView'] = new MenuItem(__('Interface View'));
|
|
|
|
$monitoringViewsItems['interfaceView']->setSec('view');
|
|
|
|
$monitoringViewsItems['interfaceView']->setSec2('operation/agentes/interface_view');
|
|
|
|
$monitoringViewsItems['interfaceView']->setClass('submenu');
|
|
|
|
|
|
|
|
// L2. Enterprise Tag view.
|
|
|
|
$idTagView = 'tagView';
|
|
|
|
$monitoringViewsItems[$idTagView] = enterprise_hook('tag_view_submenu', $idTagView);
|
|
|
|
|
|
|
|
// L2. Alert detail view.
|
|
|
|
$monitoringViewsItems['alertDetail'] = new MenuItem(__('Alert Detail'));
|
|
|
|
$monitoringViewsItems['alertDetail']->setSec('view');
|
|
|
|
$monitoringViewsItems['alertDetail']->setSec2('operation/agentes/alerts_status');
|
|
|
|
$monitoringViewsItems['alertDetail']->setClass('submenu');
|
|
|
|
|
|
|
|
// L2. Heatmap view.
|
|
|
|
$monitoringViewsItems['heatmapView'] = new MenuItem(__('Heatmap view'));
|
|
|
|
$monitoringViewsItems['heatmapView']->setSec('view');
|
|
|
|
$monitoringViewsItems['heatmapView']->setSec2('operation/heatmap');
|
|
|
|
$monitoringViewsItems['heatmapView']->setClass('submenu');
|
|
|
|
|
|
|
|
$monitoringItems['views']->setSubmenu($monitoringViewsItems);
|
|
|
|
|
|
|
|
// L1. Inventory.
|
|
|
|
$monitoringItems['inventory'] = new MenuItem(__('Inventory'));
|
|
|
|
$monitoringItems['inventory']->setSec('estado');
|
|
|
|
$monitoringItems['inventory']->setSec2('enterprise/operation/inventory/inventory');
|
|
|
|
$monitoringItems['inventory']->setClass('submenu');
|
|
|
|
|
|
|
|
// L1. Network.
|
|
|
|
$monitoringItems['network'] = new MenuItem();
|
|
|
|
$monitoringItems['network']->setDisplay((bool) $config['activate_netflow'] === true);
|
|
|
|
$monitoringItems['network']->setText(__('Network'));
|
|
|
|
|
|
|
|
// L2. Netflow explorer.
|
|
|
|
$monitoringNetworkItems['netflowExplorer'] = new MenuItem();
|
|
|
|
$monitoringNetworkItems['netflowExplorer']->setText(__('Netflow Explorer'));
|
|
|
|
$monitoringNetworkItems['netflowExplorer']->setSec('network_traffic');
|
|
|
|
$monitoringNetworkItems['netflowExplorer']->setSec2('operation/netflow/netflow_explorer');
|
|
|
|
|
|
|
|
// L2. Netflow Live view.
|
|
|
|
$monitoringNetworkItems['netflowLiveView'] = new MenuItem();
|
|
|
|
$monitoringNetworkItems['netflowLiveView']->setText(__('Netflow Live View'));
|
|
|
|
$monitoringNetworkItems['netflowLiveView']->setSec('network_traffic');
|
|
|
|
$monitoringNetworkItems['netflowLiveView']->setSec2('operation/netflow/nf_live_view');
|
|
|
|
|
|
|
|
// L2. Network usage map.
|
|
|
|
$monitoringNetworkItems['networkUsageMap'] = new MenuItem();
|
|
|
|
$monitoringNetworkItems['networkUsageMap']->setText(__('Network usage map'));
|
|
|
|
$monitoringNetworkItems['networkUsageMap']->setSec('network_traffic');
|
|
|
|
$monitoringNetworkItems['networkUsageMap']->setSec2('operation/network/network_usage_map');
|
|
|
|
|
|
|
|
$monitoringItems['network']->setSubmenu($monitoringNetworkItems);
|
|
|
|
|
|
|
|
$menuOperation['monitoring']->setSubmenu($monitoringItems);
|
|
|
|
|
|
|
|
// L0. Topology Maps.
|
|
|
|
$menuOperation['topologyMaps'] = new MenuItem(__('Topology Maps'));
|
|
|
|
$menuOperation['topologyMaps']->setIcon('icon');
|
|
|
|
$menuOperation['topologyMaps']->setClass('menu');
|
|
|
|
|
|
|
|
$menuOperation['topologyMaps']->setSubmenu($topologyMapsItems);
|
|
|
|
*/
|
2009-03-02 Esteban Sanchez <estebans@artica.es>
* include/functions_menu.php: Added to repository. Functions for menu.
* operation/menu.php, godmode/menu.php: Added class to menu due to
changes in print_menu().
* general/main_menu.php: temp_print_menu() moved to functions_menu.php
* include/functions_themes.php: Added to repository. Implement
functions relative to themes (only CSS themes list at this moment).
* include/styles/pandora.css, include/styles/pandora_black.css,
include/styles/pandora_minimal.css, include/styles/pandora_red.css:
Added author, name and description comments to adopt to new
get_themes() interface.
* include/styles/pandora_width.css: Improved and make lighter by
simply rewrite some classes.
* include/functions.php: Added is_ajax().
* godmode/agentes/module_manager_editor.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/groups/group_list.php,
godmode/reporting/map_builder.php,
godmode/reporting/reporting_builder.php,
operation/agentes/estado_agente.php, operation/agentes/ver_agente.php,
operation/events/events.php, operation/messages/message.php: Use
is_ajax()
* godmode/setup/setup.php: Use enterprise_include() instead of manual
checking. Use get_css_themes() to show the theme list.
* include/styles/common.css: Added to repository. Minimal styles to
make pandora works and common with all the CSS themes.
* include/functions_ui.php: Added common.css file.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1496 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-03-02 14:43:15 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
$access_console_node = !is_reporting_console_node();
|
|
|
|
if ($access_console_node === true) {
|
|
|
|
// Agent read, Server read.
|
|
|
|
if (check_acl($config['id_user'], 0, 'AR')) {
|
|
|
|
// View agents.
|
|
|
|
$menu_operation['estado']['text'] = __('Monitoring');
|
|
|
|
$menu_operation['estado']['sec2'] = 'operation/agentes/tactical';
|
|
|
|
$menu_operation['estado']['refr'] = 0;
|
|
|
|
$menu_operation['estado']['id'] = 'oper-agents';
|
|
|
|
|
|
|
|
$sub = [];
|
|
|
|
$sub['view']['text'] = __('Views');
|
|
|
|
$sub['view']['id'] = 'Views';
|
|
|
|
$sub['view']['type'] = 'direct';
|
|
|
|
$sub['view']['subtype'] = 'nolink';
|
|
|
|
$sub['view']['refr'] = 0;
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
$sub2 = [];
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
$sub2['operation/agentes/tactical']['text'] = __('Tactical view');
|
|
|
|
$sub2['operation/agentes/tactical']['refr'] = 0;
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
$sub2['operation/agentes/group_view']['text'] = __('Group view');
|
|
|
|
$sub2['operation/agentes/group_view']['refr'] = 0;
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
$sub2['operation/tree']['text'] = __('Tree view');
|
|
|
|
$sub2['operation/tree']['refr'] = 0;
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
$sub2['operation/agentes/estado_agente']['text'] = __('Agent detail');
|
|
|
|
$sub2['operation/agentes/estado_agente']['refr'] = 0;
|
|
|
|
$sub2['operation/agentes/estado_agente']['subsecs'] = ['operation/agentes/ver_agente'];
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
$sub2['operation/agentes/status_monitor']['text'] = __('Monitor detail');
|
|
|
|
$sub2['operation/agentes/status_monitor']['refr'] = 0;
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
$sub2['operation/agentes/interface_view']['text'] = __('Interface view');
|
|
|
|
$sub2['operation/agentes/interface_view']['refr'] = 0;
|
2021-04-12 18:17:09 +02:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
enterprise_hook('tag_view_submenu');
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
$sub2['operation/agentes/alerts_status']['text'] = __('Alert detail');
|
|
|
|
$sub2['operation/agentes/alerts_status']['refr'] = 0;
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
$sub2['operation/heatmap']['text'] = __('Heatmap view');
|
|
|
|
$sub2['operation/heatmap']['refr'] = 0;
|
2022-02-11 14:50:57 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
$sub['view']['sub2'] = $sub2;
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-09-14 18:12:39 +02:00
|
|
|
if (check_acl($config['id_user'], 0, 'AR') || check_acl($config['id_user'], 0, 'AW')) {
|
|
|
|
$sub['operation/inventory/inventory']['text'] = __('Inventory');
|
|
|
|
$sub['operation/inventory/inventory']['id'] = 'Inventory';
|
|
|
|
$sub['operation/inventory/inventory']['refr'] = 0;
|
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2023-07-11 16:52:39 +02:00
|
|
|
$sub['operation/custom_fields/custom_fields_view']['text'] = __('Custom fields view');
|
|
|
|
$sub['operation/custom_fields/custom_fields_view']['id'] = 'Custom fields view';
|
|
|
|
$sub['operation/custom_fields/custom_fields_view']['refr'] = 0;
|
|
|
|
|
2023-03-10 17:12:38 +01:00
|
|
|
if ($config['activate_netflow'] || $config['activate_sflow']) {
|
2022-07-08 13:40:20 +02:00
|
|
|
$sub['network_traffic'] = [
|
|
|
|
'text' => __('Network'),
|
|
|
|
'id' => 'Network',
|
|
|
|
'type' => 'direct',
|
|
|
|
'subtype' => 'nolink',
|
|
|
|
'refr' => 0,
|
|
|
|
];
|
2023-03-10 17:12:38 +01:00
|
|
|
$netflow_sub = [
|
|
|
|
'operation/netflow/netflow_explorer' => [
|
|
|
|
'text' => __('Netflow explorer'),
|
|
|
|
'id' => 'Netflow explorer',
|
|
|
|
],
|
|
|
|
'operation/netflow/nf_live_view' => [
|
|
|
|
'text' => __('Netflow Live View'),
|
|
|
|
'id' => 'Netflow Live View',
|
|
|
|
],
|
|
|
|
'operation/network/network_usage_map' => [
|
|
|
|
'text' => __('Network usage map'),
|
|
|
|
'id' => 'Network usage map',
|
|
|
|
],
|
|
|
|
];
|
2022-07-08 13:40:20 +02:00
|
|
|
$sub['network_traffic']['sub2'] = $netflow_sub;
|
|
|
|
}
|
2021-03-24 16:16:13 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
if ($config['log_collector'] == 1) {
|
|
|
|
enterprise_hook('log_collector_menu');
|
|
|
|
}
|
2019-03-01 14:23:10 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
// End of view agents.
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
// SNMP Console.
|
|
|
|
$sub2 = [];
|
|
|
|
if (check_acl($config['id_user'], 0, 'AR') || check_acl($config['id_user'], 0, 'AW')) {
|
|
|
|
$sub2['operation/snmpconsole/snmp_view']['text'] = __('SNMP console');
|
|
|
|
$sub2['operation/snmpconsole/snmp_browser']['text'] = __('SNMP browser');
|
|
|
|
enterprise_hook('snmpconsole_submenu');
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
if (check_acl($config['id_user'], 0, 'PM')) {
|
|
|
|
$sub2['operation/snmpconsole/snmp_mib_uploader']['text'] = __('MIB uploader');
|
|
|
|
}
|
2016-09-08 16:06:12 +02:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
if (check_acl($config['id_user'], 0, 'LW') || check_acl($config['id_user'], 0, 'LM')) {
|
|
|
|
$sub2['godmode/snmpconsole/snmp_filters']['text'] = __('SNMP filters');
|
|
|
|
$sub2['godmode/snmpconsole/snmp_trap_generator']['text'] = __('SNMP trap generator');
|
|
|
|
}
|
2016-09-08 16:06:12 +02:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
if (empty($sub2) === false) {
|
|
|
|
$sub['snmpconsole']['sub2'] = $sub2;
|
|
|
|
$sub['snmpconsole']['text'] = __('SNMP');
|
|
|
|
$sub['snmpconsole']['id'] = 'SNMP';
|
|
|
|
$sub['snmpconsole']['refr'] = 0;
|
|
|
|
$sub['snmpconsole']['type'] = 'direct';
|
|
|
|
$sub['snmpconsole']['subtype'] = 'nolink';
|
|
|
|
}
|
2015-04-09 15:04:23 +02:00
|
|
|
|
2022-10-20 13:17:26 +02:00
|
|
|
if (check_acl($config['id_user'], 0, 'AR')) {
|
|
|
|
$sub['operation/cluster/cluster']['text'] = __('Cluster View');
|
|
|
|
$sub['operation/cluster/cluster']['id'] = 'cluster';
|
|
|
|
$sub['operation/cluster/cluster']['refr'] = 0;
|
|
|
|
}
|
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
enterprise_hook('aws_menu');
|
|
|
|
enterprise_hook('SAP_view');
|
2019-11-21 18:21:46 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
if (!empty($sub)) {
|
|
|
|
$menu_operation['estado']['text'] = __('Monitoring');
|
|
|
|
$menu_operation['estado']['sec2'] = 'operation/agentes/tactical';
|
|
|
|
$menu_operation['estado']['refr'] = 0;
|
|
|
|
$menu_operation['estado']['id'] = 'oper-agents';
|
|
|
|
$menu_operation['estado']['sub'] = $sub;
|
|
|
|
}
|
2018-01-16 15:41:35 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
// Start network view.
|
|
|
|
$sub = [];
|
|
|
|
if (check_acl($config['id_user'], 0, 'MR') || check_acl($config['id_user'], 0, 'MW') || check_acl($config['id_user'], 0, 'MM')) {
|
|
|
|
// Network enterprise.
|
|
|
|
$sub['operation/agentes/pandora_networkmap']['text'] = __('Network map');
|
2023-02-07 15:22:51 +01:00
|
|
|
$sub['operation/agentes/pandora_networkmap']['id'] = 'Network_map';
|
2022-07-08 13:40:20 +02:00
|
|
|
$sub['operation/agentes/pandora_networkmap']['refr'] = 0;
|
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
enterprise_hook('services_menu');
|
2016-08-29 09:40:43 +02:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
if (check_acl($config['id_user'], 0, 'VR') || check_acl($config['id_user'], 0, 'VW') || check_acl($config['id_user'], 0, 'VM')) {
|
2023-02-20 16:41:54 +01:00
|
|
|
$url_visual_console = '';
|
2019-01-30 16:18:44 +01:00
|
|
|
if (!isset($config['vc_favourite_view']) || $config['vc_favourite_view'] == 0) {
|
2022-07-08 13:40:20 +02:00
|
|
|
// Visual console.
|
|
|
|
$sub['godmode/reporting/map_builder']['text'] = __('Visual console');
|
2023-02-07 15:22:51 +01:00
|
|
|
$sub['godmode/reporting/map_builder']['id'] = 'Visual_console';
|
2023-02-20 16:41:54 +01:00
|
|
|
$sub['godmode/reporting/map_builder']['type'] = 'direct';
|
|
|
|
$sub['godmode/reporting/map_builder']['subtype'] = 'nolink';
|
|
|
|
$url_visual_console = 'godmode/reporting/map_builder';
|
2019-01-30 16:18:44 +01:00
|
|
|
} else {
|
2022-07-08 13:40:20 +02:00
|
|
|
// Visual console favorite.
|
|
|
|
$sub['godmode/reporting/visual_console_favorite']['text'] = __('Visual console');
|
2023-02-07 15:22:51 +01:00
|
|
|
$sub['godmode/reporting/visual_console_favorite']['id'] = 'Visual_console';
|
2023-02-20 16:41:54 +01:00
|
|
|
$sub['godmode/reporting/visual_console_favorite']['type'] = 'direct';
|
|
|
|
$sub['godmode/reporting/visual_console_favorite']['subtype'] = 'nolink';
|
|
|
|
$url_visual_console = 'godmode/reporting/visual_console_favorite';
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
if ($config['vc_menu_items'] != 0) {
|
|
|
|
// Set godomode path.
|
|
|
|
if (!isset($config['vc_favourite_view']) || $config['vc_favourite_view'] == 0) {
|
|
|
|
$sub['godmode/reporting/map_builder']['subsecs'] = [
|
|
|
|
'godmode/reporting/map_builder',
|
|
|
|
'godmode/reporting/visual_console_builder',
|
|
|
|
];
|
|
|
|
} else {
|
|
|
|
$sub['godmode/reporting/visual_console_favorite']['subsecs'] = [
|
|
|
|
'godmode/reporting/map_builder',
|
|
|
|
'godmode/reporting/visual_console_builder',
|
|
|
|
];
|
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
// $layouts = db_get_all_rows_in_table ('tlayout', 'name');
|
|
|
|
$own_info = get_user_info($config['id_user']);
|
|
|
|
$returnAllGroups = 0;
|
|
|
|
if ($own_info['is_admin']) {
|
|
|
|
$returnAllGroups = 1;
|
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
$layouts = visual_map_get_user_layouts($config['id_user'], false, false, $returnAllGroups, true);
|
|
|
|
$sub2 = [];
|
|
|
|
|
2023-02-20 16:41:54 +01:00
|
|
|
$sub2[$url_visual_console] = [
|
|
|
|
'text' => __('Visual console list'),
|
|
|
|
'title' => __('Visual console list'),
|
|
|
|
'refr' => 0,
|
|
|
|
];
|
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
if ($layouts === false) {
|
|
|
|
$layouts = [];
|
|
|
|
} else {
|
|
|
|
$id = (int) get_parameter('id', -1);
|
2022-09-26 11:32:07 +02:00
|
|
|
$delete_layout = (bool) get_parameter('delete_layout');
|
|
|
|
|
|
|
|
if ($delete_layout === true) {
|
|
|
|
$id_layout = (int) get_parameter('id_layout');
|
|
|
|
unset($layouts[$id_layout]);
|
|
|
|
}
|
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
$break_max_console = false;
|
|
|
|
$max = $config['vc_menu_items'];
|
|
|
|
$i = 0;
|
|
|
|
foreach ($layouts as $layout) {
|
|
|
|
$i++;
|
|
|
|
if ($i > $max) {
|
|
|
|
$break_max_console = true;
|
|
|
|
break;
|
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
$name = io_safe_output($layout['name']);
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2023-02-20 16:41:54 +01:00
|
|
|
$sub2['operation/visual_console/render_view&id='.$layout['id']]['text'] = ui_print_truncate_text($name, MENU_SIZE_TEXT, false, true, false);
|
|
|
|
$sub2['operation/visual_console/render_view&id='.$layout['id']]['id'] = mb_substr($name, 0, 19);
|
|
|
|
$sub2['operation/visual_console/render_view&id='.$layout['id']]['title'] = $name;
|
2022-07-08 13:40:20 +02:00
|
|
|
if (!empty($config['vc_refr'])) {
|
2023-02-20 16:41:54 +01:00
|
|
|
$sub2['operation/visual_console/render_view&id='.$layout['id']]['refr'] = $config['vc_refr'];
|
2022-07-08 13:40:20 +02:00
|
|
|
} else if (((int) get_parameter('refr', 0)) > 0) {
|
2023-02-20 16:41:54 +01:00
|
|
|
$sub2['operation/visual_console/render_view&id='.$layout['id']]['refr'] = (int) get_parameter('refr', 0);
|
2022-07-08 13:40:20 +02:00
|
|
|
} else {
|
2023-02-20 16:41:54 +01:00
|
|
|
$sub2['operation/visual_console/render_view&id='.$layout['id']]['refr'] = 0;
|
2022-07-08 13:40:20 +02:00
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
if ($break_max_console) {
|
|
|
|
$sub2['godmode/reporting/visual_console_favorite']['text'] = __('Show more').' >';
|
|
|
|
$sub2['godmode/reporting/visual_console_favorite']['id'] = 'visual_favourite_console';
|
|
|
|
$sub2['godmode/reporting/visual_console_favorite']['title'] = __('Show more');
|
|
|
|
$sub2['godmode/reporting/visual_console_favorite']['refr'] = 0;
|
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
if (!empty($sub2)) {
|
|
|
|
if (!isset($config['vc_favourite_view']) || $config['vc_favourite_view'] == 0) {
|
|
|
|
$sub['godmode/reporting/map_builder']['sub2'] = $sub2;
|
|
|
|
} else {
|
|
|
|
$sub['godmode/reporting/visual_console_favorite']['sub2'] = $sub2;
|
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2016-08-29 09:40:43 +02:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
if (check_acl($config['id_user'], 0, 'MR') || check_acl($config['id_user'], 0, 'MW') || check_acl($config['id_user'], 0, 'MM')) {
|
|
|
|
// INI GIS Maps.
|
|
|
|
if ($config['activate_gis']) {
|
|
|
|
$sub['gismaps']['text'] = __('GIS Maps');
|
2023-03-23 10:41:08 +01:00
|
|
|
$sub['gismaps']['id'] = 'GIS_Maps';
|
2022-07-08 13:40:20 +02:00
|
|
|
$sub['gismaps']['type'] = 'direct';
|
|
|
|
$sub['gismaps']['subtype'] = 'nolink';
|
|
|
|
$sub2 = [];
|
|
|
|
$sub2['operation/gis_maps/gis_map']['text'] = __('List of Gis maps');
|
|
|
|
$sub2['operation/gis_maps/gis_map']['id'] = 'List of Gis maps';
|
|
|
|
$gisMaps = db_get_all_rows_in_table('tgis_map', 'map_name');
|
|
|
|
if ($gisMaps === false) {
|
|
|
|
$gisMaps = [];
|
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
$id = (int) get_parameter('id', -1);
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
$own_info = get_user_info($config['id_user']);
|
|
|
|
if ($own_info['is_admin'] || check_acl($config['id_user'], 0, 'PM')) {
|
|
|
|
$own_groups = array_keys(users_get_groups($config['id_user'], 'MR'));
|
|
|
|
} else {
|
|
|
|
$own_groups = array_keys(users_get_groups($config['id_user'], 'MR', false));
|
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
foreach ($gisMaps as $gisMap) {
|
|
|
|
$is_in_group = in_array($gisMap['group_id'], $own_groups);
|
|
|
|
if (!$is_in_group) {
|
|
|
|
continue;
|
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2023-02-20 16:41:54 +01:00
|
|
|
$sub2['operation/gis_maps/render_view&map_id='.$gisMap['id_tgis_map']]['text'] = ui_print_truncate_text(io_safe_output($gisMap['map_name']), MENU_SIZE_TEXT, false, true, false);
|
|
|
|
$sub2['operation/gis_maps/render_view&map_id='.$gisMap['id_tgis_map']]['id'] = mb_substr(io_safe_output($gisMap['map_name']), 0, 15);
|
|
|
|
$sub2['operation/gis_maps/render_view&map_id='.$gisMap['id_tgis_map']]['title'] = io_safe_output($gisMap['map_name']);
|
|
|
|
$sub2['operation/gis_maps/render_view&map_id='.$gisMap['id_tgis_map']]['refr'] = 0;
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
$sub['gismaps']['sub2'] = $sub2;
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
// END GIS Maps.
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
if (!empty($sub)) {
|
|
|
|
$menu_operation['network']['text'] = __('Topology maps');
|
|
|
|
$menu_operation['network']['sec2'] = 'operation/agentes/networkmap_list';
|
|
|
|
$menu_operation['network']['refr'] = 0;
|
|
|
|
$menu_operation['network']['id'] = 'oper-networkconsole';
|
|
|
|
$menu_operation['network']['sub'] = $sub;
|
|
|
|
}
|
2016-08-29 09:40:43 +02:00
|
|
|
|
2023-08-29 15:09:41 +02:00
|
|
|
enterprise_hook('security_menu');
|
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
// End networkview.
|
|
|
|
// Reports read.
|
|
|
|
if (check_acl($config['id_user'], 0, 'RR') || check_acl($config['id_user'], 0, 'RW') || check_acl($config['id_user'], 0, 'RM')) {
|
|
|
|
// Reporting.
|
|
|
|
$menu_operation['reporting']['text'] = __('Reporting');
|
|
|
|
$menu_operation['reporting']['sec2'] = 'godmode/reporting/reporting_builder';
|
|
|
|
$menu_operation['reporting']['id'] = 'oper-reporting';
|
|
|
|
$menu_operation['reporting']['refr'] = 300;
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
$sub = [];
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
$sub['godmode/reporting/reporting_builder']['text'] = __('Custom reporting');
|
2023-02-07 15:22:51 +01:00
|
|
|
$sub['godmode/reporting/reporting_builder']['id'] = 'Custom_reporting';
|
2022-07-08 13:40:20 +02:00
|
|
|
// Set godomode path.
|
|
|
|
$sub['godmode/reporting/reporting_builder']['subsecs'] = [
|
|
|
|
'godmode/reporting/reporting_builder',
|
|
|
|
'operation/reporting/reporting_viewer',
|
|
|
|
];
|
2019-01-30 16:18:44 +01:00
|
|
|
|
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
$sub['godmode/reporting/graphs']['text'] = __('Custom graphs');
|
2023-02-07 15:22:51 +01:00
|
|
|
$sub['godmode/reporting/graphs']['id'] = 'Custom_graphs';
|
2022-07-08 13:40:20 +02:00
|
|
|
// Set godomode path.
|
|
|
|
$sub['godmode/reporting/graphs']['subsecs'] = [
|
|
|
|
'operation/reporting/graph_viewer',
|
|
|
|
'godmode/reporting/graph_builder',
|
|
|
|
];
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2023-08-10 09:13:48 +02:00
|
|
|
|
|
|
|
// Graph analytics.
|
|
|
|
$sub['operation/reporting/graph_analytics']['text'] = __('Graph analytics');
|
|
|
|
$sub['operation/reporting/graph_analytics']['id'] = 'Graph_analytics';
|
|
|
|
|
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
if (check_acl($config['id_user'], 0, 'RR')
|
|
|
|
|| check_acl($config['id_user'], 0, 'RW')
|
|
|
|
|| check_acl($config['id_user'], 0, 'RM')
|
|
|
|
) {
|
|
|
|
$sub['operation/dashboard/dashboard']['text'] = __('Dashboard');
|
|
|
|
$sub['operation/dashboard/dashboard']['id'] = 'Dashboard';
|
|
|
|
$sub['operation/dashboard/dashboard']['refr'] = 0;
|
|
|
|
$sub['operation/dashboard/dashboard']['subsecs'] = ['operation/dashboard/dashboard'];
|
2023-02-20 16:41:54 +01:00
|
|
|
$sub['operation/dashboard/dashboard']['type'] = 'direct';
|
|
|
|
$sub['operation/dashboard/dashboard']['subtype'] = 'nolink';
|
2020-03-26 12:29:38 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
$dashboards = Manager::getDashboards(-1, -1, true);
|
2020-03-26 12:29:38 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
$sub2 = [];
|
2023-02-20 16:41:54 +01:00
|
|
|
$sub2['operation/dashboard/dashboard'] = [
|
|
|
|
'text' => __('Dashboard list'),
|
|
|
|
'title' => __('Dashboard list'),
|
|
|
|
];
|
2022-07-08 13:40:20 +02:00
|
|
|
foreach ($dashboards as $dashboard) {
|
|
|
|
$name = io_safe_output($dashboard['name']);
|
2020-03-26 12:29:38 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
$sub2['operation/dashboard/dashboard&dashboardId='.$dashboard['id']] = [
|
|
|
|
'text' => ui_print_truncate_text($name, MENU_SIZE_TEXT, false, true, false),
|
|
|
|
'title' => $name,
|
|
|
|
];
|
|
|
|
}
|
2020-03-26 12:29:38 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
if (empty($sub2) === false) {
|
|
|
|
$sub['operation/dashboard/dashboard']['sub2'] = $sub2;
|
|
|
|
}
|
2020-03-26 12:29:38 +01:00
|
|
|
}
|
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
enterprise_hook('reporting_godmenu');
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
$menu_operation['reporting']['sub'] = $sub;
|
|
|
|
// End reporting.
|
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
// Events reading.
|
|
|
|
if (check_acl($config['id_user'], 0, 'ER')
|
|
|
|
|| check_acl($config['id_user'], 0, 'EW')
|
|
|
|
|| check_acl($config['id_user'], 0, 'EM')
|
|
|
|
) {
|
|
|
|
// Events.
|
|
|
|
$menu_operation['eventos']['text'] = __('Events');
|
|
|
|
$menu_operation['eventos']['refr'] = 0;
|
|
|
|
$menu_operation['eventos']['sec2'] = 'operation/events/events';
|
|
|
|
$menu_operation['eventos']['id'] = 'oper-events';
|
|
|
|
|
|
|
|
$sub = [];
|
|
|
|
$sub['operation/events/events']['text'] = __('View events');
|
2023-02-07 15:22:51 +01:00
|
|
|
$sub['operation/events/events']['id'] = 'View_events';
|
2022-07-08 13:40:20 +02:00
|
|
|
$sub['operation/events/events']['pages'] = ['godmode/events/events'];
|
|
|
|
|
|
|
|
// If ip doesn't is in list of allowed IP, isn't show this options.
|
|
|
|
include_once 'include/functions_api.php';
|
|
|
|
if (isInACL($_SERVER['REMOTE_ADDR'])) {
|
|
|
|
$pss = get_user_info($config['id_user']);
|
|
|
|
$hashup = md5($config['id_user'].$pss['password']);
|
|
|
|
|
|
|
|
$user_filter = db_get_row_sql(
|
|
|
|
sprintf(
|
|
|
|
'SELECT f.id_filter, f.id_name
|
2019-06-25 12:21:18 +02:00
|
|
|
FROM tevent_filter f
|
|
|
|
INNER JOIN tusuario u
|
|
|
|
ON u.default_event_filter=f.id_filter
|
|
|
|
WHERE u.id_user = "%s" ',
|
2022-07-08 13:40:20 +02:00
|
|
|
$config['id_user']
|
|
|
|
)
|
|
|
|
);
|
|
|
|
if ($user_filter !== false) {
|
|
|
|
$user_event_filter = events_get_event_filter($user_filter['id_filter']);
|
|
|
|
} else {
|
|
|
|
// Default.
|
|
|
|
$user_event_filter = [
|
|
|
|
'status' => EVENT_NO_VALIDATED,
|
|
|
|
'event_view_hr' => $config['event_view_hr'],
|
2022-09-27 15:08:09 +02:00
|
|
|
'group_rep' => EVENT_GROUP_REP_EVENTS,
|
2022-07-08 13:40:20 +02:00
|
|
|
'tag_with' => [],
|
|
|
|
'tag_without' => [],
|
|
|
|
'history' => false,
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
$fb64 = base64_encode(json_encode($user_event_filter));
|
|
|
|
|
|
|
|
// RSS.
|
|
|
|
$sub['operation/events/events_rss.php?user='.$config['id_user'].'&hashup='.$hashup.'&fb64='.$fb64]['text'] = __('RSS');
|
|
|
|
$sub['operation/events/events_rss.php?user='.$config['id_user'].'&hashup='.$hashup.'&fb64='.$fb64]['id'] = 'RSS';
|
|
|
|
$sub['operation/events/events_rss.php?user='.$config['id_user'].'&hashup='.$hashup.'&fb64='.$fb64]['type'] = 'direct';
|
|
|
|
}
|
|
|
|
|
2023-07-24 12:25:06 +02:00
|
|
|
if (is_metaconsole() === true) {
|
|
|
|
$urlSound = '../../include/sounds/';
|
|
|
|
} else {
|
|
|
|
$urlSound = 'include/sounds/';
|
|
|
|
}
|
|
|
|
|
2023-05-30 17:17:34 +02:00
|
|
|
// Acoustic console.
|
2022-07-08 13:40:20 +02:00
|
|
|
$data_sound = base64_encode(
|
|
|
|
json_encode(
|
|
|
|
[
|
2023-05-30 17:17:34 +02:00
|
|
|
'title' => __('Acoustic console'),
|
2022-07-08 13:40:20 +02:00
|
|
|
'start' => __('Start'),
|
|
|
|
'stop' => __('Stop'),
|
|
|
|
'noAlert' => __('No alert'),
|
|
|
|
'silenceAlarm' => __('Silence alarm'),
|
|
|
|
'url' => ui_get_full_url('ajax.php'),
|
|
|
|
'page' => 'include/ajax/events',
|
2023-07-24 12:25:06 +02:00
|
|
|
'urlSound' => $urlSound,
|
2022-07-08 13:40:20 +02:00
|
|
|
]
|
2019-06-25 12:21:18 +02:00
|
|
|
)
|
|
|
|
);
|
|
|
|
|
2022-08-23 13:22:10 +02:00
|
|
|
$javascript = 'javascript: openSoundEventModal(`'.$data_sound.'`);';
|
2023-05-30 17:17:34 +02:00
|
|
|
$sub[$javascript]['text'] = __('Acoustic console');
|
|
|
|
$sub[$javascript]['id'] = 'Acoustic console Modal';
|
2022-07-08 13:40:20 +02:00
|
|
|
$sub[$javascript]['type'] = 'direct';
|
|
|
|
|
|
|
|
echo '<div id="modal-sound" style="display:none;"></div>';
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
ui_require_javascript_file('pandora_events');
|
|
|
|
|
|
|
|
$menu_operation['eventos']['sub'] = $sub;
|
|
|
|
}
|
2009-11-27 Sancho lerena <slerena@artica.es>
* operation/menu.php: User section has no ACL check, always can be seen.
* index.php: Added suppor for user-defined custom language (this code was
on my disk for 3 months, pending to be commited!).
* include/functions_db.php,
* include/functions_agents.php,
* godmode/alerts/alert_list.php,
* godmode/agentes/modificar_agente.php,
* godmode/agentes/configurar_agente.php: Added audit calls to several
management operations who don't have or have insufficient audit info.
* godmode/users/configure_user.php: Fixed several annoyings bugs. Added
custom language support, and added more audit info on management operations.
* godmode/users/user_list.php: More audit info.
* include/config_process.php: Add new debug option to render error log to
/pandora_console.log. Also set timezone if not defined (this makes warnings
on several PHP 5.x setups). Added user custom language support.
* include/functions_events.php: More audit info. Fixed problems with HTML
encoding render.
* functions_io.php: Some cleaning.
* include/functions_messages.php: Fixed problems with HTML
encoding render.
* functions_ui.php: Fixed problems with HTML encoding render in
print_string_substr() function.
* auth/mysql.php: is_user_admin() functions seems to be broken ¿?¿!. Fixed.
* styles/pandora.css: removed green colored left border in default style.
* message.php, incident*: Fixed problems with HTML encoding render.
* user.php: Better ACL check before let user to view/edit another user.
* user_edit: Removed some un-used form fields, some arrangements in layout,
and FIXED forever problems with password change (new code written).
* users/user_statistics.php: Now user can see its own audit records.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@2139 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-11-27 21:02:12 +01:00
|
|
|
}
|
|
|
|
|
2023-02-23 09:48:13 +01:00
|
|
|
$favorite_menu = db_get_all_rows_sql(
|
|
|
|
sprintf(
|
|
|
|
'SELECT id_element, url, label, section
|
|
|
|
FROM tfavmenu_user
|
|
|
|
WHERE id_user = "%s"
|
|
|
|
ORDER BY section DESC',
|
|
|
|
$config['id_user']
|
|
|
|
)
|
|
|
|
);
|
2023-02-27 09:45:15 +01:00
|
|
|
// Favorite.
|
2023-02-23 09:48:13 +01:00
|
|
|
if ($favorite_menu !== false) {
|
|
|
|
$menu_operation['favorite']['text'] = __('Favorite');
|
|
|
|
$menu_operation['favorite']['id'] = 'fav-menu';
|
|
|
|
|
|
|
|
$section = '';
|
|
|
|
$sub = [];
|
|
|
|
$sub2 = [];
|
|
|
|
foreach ($favorite_menu as $key => $row) {
|
|
|
|
if ($row['section'] !== $section) {
|
|
|
|
$section = $row['section'];
|
|
|
|
$sub2 = [];
|
|
|
|
}
|
|
|
|
|
2023-02-23 11:37:23 +01:00
|
|
|
$sub[$section]['text'] = __(str_replace('_', ' ', $section));
|
2023-02-23 09:48:13 +01:00
|
|
|
$sub[$section]['type'] = 'direct';
|
|
|
|
$sub[$section]['subtype'] = 'nolink';
|
2023-03-21 15:40:46 +01:00
|
|
|
$sub[$section]['id'] = $row['section'].'-fav-menu';
|
2023-02-23 09:48:13 +01:00
|
|
|
|
|
|
|
$sub2[$row['url']]['text'] = io_safe_output($row['label']);
|
|
|
|
$sub[$section]['sub2'] = $sub2;
|
|
|
|
}
|
|
|
|
|
|
|
|
$menu_operation['favorite']['sub'] = $sub;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2023-04-13 11:07:09 +02:00
|
|
|
// Links.
|
|
|
|
$rows = db_get_all_rows_in_table('tlink', 'name');
|
|
|
|
// $rows = [];
|
|
|
|
if (!empty($rows)) {
|
|
|
|
$menu_operation['links']['text'] = __('Links');
|
|
|
|
$menu_operation['links']['sec2'] = '';
|
|
|
|
$menu_operation['links']['id'] = 'god-links';
|
2023-02-23 09:48:13 +01:00
|
|
|
|
2023-04-13 11:07:09 +02:00
|
|
|
$sub = [];
|
|
|
|
foreach ($rows as $row) {
|
2023-08-02 14:48:02 +02:00
|
|
|
$sub[$row['link']]['text'] = __($row['name']);
|
2023-06-30 08:35:37 +02:00
|
|
|
$sub[$row['link']]['id'] = $row['name'];
|
|
|
|
$sub[$row['link']]['type'] = 'direct';
|
|
|
|
$sub[$row['link']]['subtype'] = 'new_blank';
|
|
|
|
}
|
|
|
|
|
|
|
|
$menu_operation['links']['sub'] = $sub;
|
|
|
|
}
|
2023-02-23 09:48:13 +01:00
|
|
|
|
2019-03-01 14:26:59 +01:00
|
|
|
// Workspace.
|
2019-01-30 16:18:44 +01:00
|
|
|
$menu_operation['workspace']['text'] = __('Workspace');
|
|
|
|
$menu_operation['workspace']['sec2'] = 'operation/users/user_edit';
|
|
|
|
$menu_operation['workspace']['id'] = 'oper-users';
|
2012-04-02 16:33:34 +02:00
|
|
|
|
2011-03-17 21:51:46 +01:00
|
|
|
// ANY user can view him/herself !
|
2019-03-01 14:26:59 +01:00
|
|
|
// Users.
|
2023-04-25 10:57:21 +02:00
|
|
|
$query_paramameters_user = '&edit_user=1&pure=0';
|
2023-02-13 13:16:51 +01:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$sub = [];
|
2023-02-13 13:16:51 +01:00
|
|
|
$sub['godmode/users/configure_user'.$query_paramameters_user]['text'] = __('Edit my user');
|
|
|
|
$sub['godmode/users/configure_user'.$query_paramameters_user]['id'] = 'Edit_my_user';
|
|
|
|
$sub['godmode/users/configure_user'.$query_paramameters_user]['refr'] = 0;
|
2012-04-02 16:33:34 +02:00
|
|
|
|
2019-03-01 14:26:59 +01:00
|
|
|
// Users.
|
2019-02-12 11:41:21 +01:00
|
|
|
$sub['operation/users/user_edit_notifications']['text'] = __('Configure user notifications');
|
2023-02-07 15:22:51 +01:00
|
|
|
$sub['operation/users/user_edit_notifications']['id'] = 'Configure_user_notifications';
|
2019-02-12 11:41:21 +01:00
|
|
|
$sub['operation/users/user_edit_notifications']['refr'] = 0;
|
2019-02-06 11:36:28 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
if ($access_console_node === true) {
|
|
|
|
// Messages.
|
|
|
|
$sub['message_list']['text'] = __('Messages');
|
|
|
|
$sub['message_list']['id'] = 'Messages';
|
|
|
|
$sub['message_list']['refr'] = 0;
|
|
|
|
$sub['message_list']['type'] = 'direct';
|
|
|
|
$sub['message_list']['subtype'] = 'nolink';
|
2019-01-30 16:18:44 +01:00
|
|
|
$sub2 = [];
|
2022-07-08 13:40:20 +02:00
|
|
|
$sub2['operation/messages/message_list']['text'] = __('Messages List');
|
2023-02-20 17:08:36 +01:00
|
|
|
$sub2['operation/messages/message_edit&new_msg=1']['text'] = __('New message');
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
$sub['message_list']['sub2'] = $sub2;
|
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
$menu_operation['workspace']['sub'] = $sub;
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2023-06-16 13:47:25 +02:00
|
|
|
if ($access_console_node === true) {
|
2023-07-21 14:23:42 +02:00
|
|
|
if ((bool) $config['ITSM_enabled'] === true) {
|
2023-07-18 15:13:08 +02:00
|
|
|
// ITSM.
|
|
|
|
$menu_operation['ITSM']['text'] = __('ITSM');
|
|
|
|
$menu_operation['ITSM']['sec2'] = 'operation/ITSM/itsm';
|
|
|
|
$menu_operation['ITSM']['id'] = 'oper-itsm';
|
2023-06-16 13:47:25 +02:00
|
|
|
|
2023-07-18 15:13:08 +02:00
|
|
|
$sub = [];
|
|
|
|
// ITSM Tickets.
|
|
|
|
$sub['manageTickets']['text'] = __('Tickets');
|
|
|
|
$sub['manageTickets']['id'] = 'itsm-ticket';
|
|
|
|
$sub['manageTickets']['refr'] = 0;
|
|
|
|
$sub['manageTickets']['type'] = 'direct';
|
|
|
|
$sub['manageTickets']['subtype'] = 'nolink';
|
2023-06-16 13:47:25 +02:00
|
|
|
|
2023-07-18 15:13:08 +02:00
|
|
|
$sub2 = [];
|
|
|
|
$sub2['operation/ITSM/itsm&operation=list']['text'] = __('List');
|
|
|
|
$sub2['operation/ITSM/itsm&operation=list']['id'] = 'itsm-ticket-list';
|
2023-06-16 13:47:25 +02:00
|
|
|
|
2023-07-18 15:13:08 +02:00
|
|
|
$sub2['operation/ITSM/itsm&operation=edit']['text'] = __('Edit');
|
|
|
|
$sub2['operation/ITSM/itsm&operation=edit']['id'] = 'itsm-ticket-edit';
|
2023-06-16 13:47:25 +02:00
|
|
|
|
2023-07-18 15:13:08 +02:00
|
|
|
$sub['manageTickets']['sub2'] = $sub2;
|
2023-06-16 13:47:25 +02:00
|
|
|
|
2023-07-18 15:13:08 +02:00
|
|
|
// ITSM Dashboard.
|
|
|
|
$sub['operation/ITSM/itsm']['text'] = __('Dashboard');
|
|
|
|
$sub['operation/ITSM/itsm']['id'] = 'itsm-dashboard';
|
|
|
|
$sub['operation/ITSM/itsm']['refr'] = 0;
|
2023-06-16 13:47:25 +02:00
|
|
|
|
2023-07-18 15:13:08 +02:00
|
|
|
$menu_operation['ITSM']['sub'] = $sub;
|
|
|
|
}
|
2023-06-16 13:47:25 +02:00
|
|
|
}
|
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
if ($access_console_node === true) {
|
|
|
|
// Rest of options, all with AR privilege (or should events be with incidents?)
|
|
|
|
// ~ if (check_acl ($config['id_user'], 0, "AR")) {
|
|
|
|
// Extensions menu additions.
|
|
|
|
if (is_array($config['extensions'])) {
|
|
|
|
$sub = [];
|
|
|
|
$sub2 = [];
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
if (check_acl($config['id_user'], 0, 'RR') || check_acl($config['id_user'], 0, 'RW') || check_acl($config['id_user'], 0, 'RM')) {
|
|
|
|
$sub['operation/agentes/exportdata']['text'] = __('Export data');
|
2023-02-07 15:22:51 +01:00
|
|
|
$sub['operation/agentes/exportdata']['id'] = 'Export_data';
|
2022-07-08 13:40:20 +02:00
|
|
|
$sub['operation/agentes/exportdata']['subsecs'] = ['operation/agentes/exportdata'];
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
if (check_acl($config['id_user'], 0, 'AR') || check_acl($config['id_user'], 0, 'AD') || check_acl($config['id_user'], 0, 'AW')) {
|
|
|
|
$sub['godmode/agentes/planned_downtime.list']['text'] = __('Scheduled downtime');
|
2023-02-07 15:22:51 +01:00
|
|
|
$sub['godmode/agentes/planned_downtime.list']['id'] = 'Scheduled_downtime';
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
|
2023-11-28 08:13:00 +01:00
|
|
|
if ((bool) check_acl($config['id_user'], 0, 'PM') === true) {
|
|
|
|
$sub['godmode/files_repo/files_repo']['text'] = __('File Repository');
|
|
|
|
$sub['godmode/files_repo/files_repo']['id'] = 'File_repository';
|
|
|
|
}
|
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
foreach ($config['extensions'] as $extension) {
|
|
|
|
// If no operation_menu is a godmode extension.
|
|
|
|
if ($extension['operation_menu'] == '') {
|
2019-01-30 16:18:44 +01:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
// Check the ACL for this user.
|
|
|
|
if (! check_acl($config['id_user'], 0, $extension['operation_menu']['acl'])) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
$extension_menu = $extension['operation_menu'];
|
|
|
|
if ($extension['operation_menu']['name'] == 'Matrix'
|
2023-07-18 15:13:08 +02:00
|
|
|
&& (!check_acl($config['id_user'], 0, 'ER')
|
2022-07-08 13:40:20 +02:00
|
|
|
|| !check_acl($config['id_user'], 0, 'EW')
|
2023-07-18 15:13:08 +02:00
|
|
|
|| !check_acl($config['id_user'], 0, 'EM'))
|
2022-07-08 13:40:20 +02:00
|
|
|
) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Check if was displayed inside other menu.
|
|
|
|
if ($extension['operation_menu']['fatherId'] == '') {
|
|
|
|
if ($extension_menu['name'] == 'Update manager') {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
$sub[$extension_menu['sec2']]['text'] = $extension_menu['name'];
|
2023-02-07 15:22:51 +01:00
|
|
|
$sub[$extension_menu['sec2']]['id'] = str_replace(' ', '_', $extension_menu['name']);
|
2022-07-08 13:40:20 +02:00
|
|
|
$sub[$extension_menu['sec2']]['refr'] = 0;
|
|
|
|
} else {
|
|
|
|
if (array_key_exists('fatherId', $extension_menu)) {
|
|
|
|
// Check that extension father ID exists previously on the menu.
|
|
|
|
if ((strlen($extension_menu['fatherId']) > 0)) {
|
|
|
|
if (array_key_exists('subfatherId', $extension_menu) && empty($extension_menu['subfatherId']) === false) {
|
|
|
|
if ((strlen($extension_menu['subfatherId']) > 0)) {
|
|
|
|
$menu_operation[$extension_menu['fatherId']]['sub'][$extension_menu['subfatherId']]['sub2'][$extension_menu['sec2']]['text'] = __($extension_menu['name']);
|
2023-02-07 15:22:51 +01:00
|
|
|
$menu_operation[$extension_menu['fatherId']]['sub'][$extension_menu['subfatherId']]['sub2'][$extension_menu['sec2']]['id'] = str_replace(' ', '_', $extension_menu['name']);
|
2022-07-08 13:40:20 +02:00
|
|
|
$menu_operation[$extension_menu['fatherId']]['sub'][$extension_menu['subfatherId']]['sub2'][$extension_menu['sec2']]['refr'] = 0;
|
|
|
|
$menu_operation[$extension_menu['fatherId']]['sub'][$extension_menu['subfatherId']]['sub2'][$extension_menu['sec2']]['icon'] = $extension_menu['icon'];
|
|
|
|
$menu_operation[$extension_menu['fatherId']]['sub'][$extension_menu['subfatherId']]['sub2'][$extension_menu['sec2']]['sec'] = 'extensions';
|
|
|
|
$menu_operation[$extension_menu['fatherId']]['sub'][$extension_menu['subfatherId']]['sub2'][$extension_menu['sec2']]['extension'] = true;
|
|
|
|
$menu_operation[$extension_menu['fatherId']]['sub'][$extension_menu['subfatherId']]['sub2'][$extension_menu['sec2']]['enterprise'] = $extension['enterprise'];
|
|
|
|
$menu_operation[$extension_menu['fatherId']]['hasExtensions'] = true;
|
|
|
|
} else {
|
|
|
|
$menu_operation[$extension_menu['fatherId']]['sub'][$extension_menu['sec2']]['text'] = __($extension_menu['name']);
|
2023-02-07 15:22:51 +01:00
|
|
|
$menu_operation[$extension_menu['fatherId']]['sub'][$extension_menu['sec2']]['id'] = str_replace(' ', '_', $extension_menu['name']);
|
2022-07-08 13:40:20 +02:00
|
|
|
$menu_operation[$extension_menu['fatherId']]['sub'][$extension_menu['sec2']]['refr'] = 0;
|
|
|
|
$menu_operation[$extension_menu['fatherId']]['sub'][$extension_menu['sec2']]['icon'] = $extension_menu['icon'];
|
|
|
|
$menu_operation[$extension_menu['fatherId']]['sub'][$extension_menu['sec2']]['sec'] = 'extensions';
|
|
|
|
$menu_operation[$extension_menu['fatherId']]['sub'][$extension_menu['sec2']]['extension'] = true;
|
|
|
|
$menu_operation[$extension_menu['fatherId']]['sub'][$extension_menu['sec2']]['enterprise'] = $extension['enterprise'];
|
|
|
|
$menu_operation[$extension_menu['fatherId']]['hasExtensions'] = true;
|
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
} else {
|
|
|
|
$menu_operation[$extension_menu['fatherId']]['sub'][$extension_menu['sec2']]['text'] = __($extension_menu['name']);
|
2023-02-07 15:22:51 +01:00
|
|
|
$menu_operation[$extension_menu['fatherId']]['sub'][$extension_menu['sec2']]['id'] = str_replace(' ', '_', $extension_menu['name']);
|
2019-01-30 16:18:44 +01:00
|
|
|
$menu_operation[$extension_menu['fatherId']]['sub'][$extension_menu['sec2']]['refr'] = 0;
|
|
|
|
$menu_operation[$extension_menu['fatherId']]['sub'][$extension_menu['sec2']]['icon'] = $extension_menu['icon'];
|
|
|
|
$menu_operation[$extension_menu['fatherId']]['sub'][$extension_menu['sec2']]['sec'] = 'extensions';
|
|
|
|
$menu_operation[$extension_menu['fatherId']]['sub'][$extension_menu['sec2']]['extension'] = true;
|
|
|
|
$menu_operation[$extension_menu['fatherId']]['sub'][$extension_menu['sec2']]['enterprise'] = $extension['enterprise'];
|
|
|
|
$menu_operation[$extension_menu['fatherId']]['hasExtensions'] = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2022-07-08 13:40:20 +02:00
|
|
|
|
|
|
|
// ~ }
|
2009-10-26 Ramon Novoa <rnovoa@artica.es>
* extensions/update_manager.php,
operation/incidents/incident.php,
operation/menu.php,
godmode/setup/links.php,
godmode/users/configure_user.php,
godmode/agentes/planned_downtime.php,
godmode/agentes/agent_manager.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/map_builder.php,
godmode/reporting/graphs.php,
godmode/reporting/graph_builder.php,
godmode/alerts/alert_templates.php,
godmode/menu.php: Several ACL related fixes.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@2053 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-10-26 19:51:29 +01:00
|
|
|
}
|
2009-08-27 18:57:19 +02:00
|
|
|
|
2023-06-19 15:09:30 +02:00
|
|
|
$menu_operation['about_operation']['text'] = __('About');
|
|
|
|
$menu_operation['about_operation']['id'] = 'about_operation';
|
|
|
|
|
|
|
|
// Save operation menu array to use in operation/extensions.php view.
|
2012-06-18 17:16:17 +02:00
|
|
|
$operation_menu_array = $menu_operation;
|
2009-08-27 18:57:19 +02:00
|
|
|
|
2013-02-05 12:30:04 +01:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
if (!$config['pure']) {
|
|
|
|
menu_print_menu($menu_operation, true);
|
2012-09-27 15:02:16 +02:00
|
|
|
}
|