2009-04-29 09:43:01 +02:00
|
|
|
<?php
|
2007-06-08 17:55:53 +02:00
|
|
|
|
2009-06-08 20:21:21 +02:00
|
|
|
// Pandora FMS - http://pandorafms.com
|
|
|
|
// ==================================================
|
2020-11-27 13:52:35 +01:00
|
|
|
// Copyright (c) 2005-2021 Artica Soluciones Tecnologicas
|
2009-06-08 20:21:21 +02:00
|
|
|
// Please see http://pandorafms.org for full contribution list
|
2007-06-08 17:55:53 +02:00
|
|
|
// This program is free software; you can redistribute it and/or
|
|
|
|
// modify it under the terms of the GNU General Public License
|
2008-08-22 20:07:32 +02:00
|
|
|
// as published by the Free Software Foundation for version 2.
|
2007-06-08 17:55:53 +02:00
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License for more details.
|
2010-03-03 18:10:37 +01:00
|
|
|
global $config;
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
require_once $config['homedir'].'/include/functions_visual_map.php';
|
2011-02-16 19:39:28 +01:00
|
|
|
|
2019-04-24 13:53:18 +02:00
|
|
|
// ACL for the general permission.
|
2019-01-30 16:18:44 +01:00
|
|
|
$vconsoles_read = check_acl($config['id_user'], 0, 'VR');
|
|
|
|
$vconsoles_write = check_acl($config['id_user'], 0, 'VW');
|
|
|
|
$vconsoles_manage = check_acl($config['id_user'], 0, 'VM');
|
2015-04-09 14:00:37 +02:00
|
|
|
|
2018-08-02 10:57:00 +02:00
|
|
|
$is_enterprise = enterprise_include_once('include/functions_policies.php');
|
2018-08-02 13:07:40 +02:00
|
|
|
$is_metaconsole = is_metaconsole();
|
2018-08-02 10:57:00 +02:00
|
|
|
|
2015-04-09 14:00:37 +02:00
|
|
|
if (!$vconsoles_read && !$vconsoles_write && !$vconsoles_manage) {
|
2019-01-30 16:18:44 +01:00
|
|
|
db_pandora_audit(
|
|
|
|
'ACL Violation',
|
|
|
|
'Trying to access map builder'
|
|
|
|
);
|
|
|
|
include 'general/noaccess.php';
|
|
|
|
exit;
|
2015-04-09 14:00:37 +02:00
|
|
|
}
|
|
|
|
|
2021-03-11 15:40:23 +01:00
|
|
|
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
if (!$is_metaconsole) {
|
2018-08-02 13:07:40 +02:00
|
|
|
$url_visual_console = 'index.php?sec=network&sec2=godmode/reporting/map_builder';
|
|
|
|
$url_visual_console_favorite = 'index.php?sec=network&sec2=godmode/reporting/visual_console_favorite';
|
|
|
|
$url_visual_console_template = 'index.php?sec=network&sec2=enterprise/godmode/reporting/visual_console_template';
|
|
|
|
$url_visual_console_template_wizard = 'index.php?sec=network&sec2=enterprise/godmode/reporting/visual_console_template_wizard';
|
2019-01-30 16:18:44 +01:00
|
|
|
} else {
|
2018-08-02 13:07:40 +02:00
|
|
|
$url_visual_console = 'index.php?sec=screen&sec2=screens/screens&action=visualmap';
|
|
|
|
$url_visual_console_favorite = 'index.php?sec=screen&sec2=screens/screens&action=visualmap_favorite';
|
|
|
|
$url_visual_console_template = 'index.php?sec=screen&sec2=screens/screens&action=visualmap_template';
|
|
|
|
$url_visual_console_template_wizard = 'index.php?sec=screen&sec2=screens/screens&action=visualmap_wizard';
|
|
|
|
}
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$pure = (int) get_parameter('pure', 0);
|
2012-12-11 Miguel de Dios <miguel.dedios@artica.es>
* extras/pandoradb_migrate_4.0.x_to_5.0.mysql.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.oracle.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.postgreSQL.sql, pandoradb.sql,
pandoradb.postgreSQL.sql, pandoradb.oracle.sql: in the table
"tlayout_data" added the column "id_metaconsole" for to show
visualmaps in the metaconsole.
* operation/visual_console/render_view.php,
include/functions_visual_map.php, operation/agentes/ver_agente.php,
godmode/reporting/visual_console_builder.wizard.php,
godmode/reporting/visual_console_builder.php,
godmode/reporting/visual_console_builder.data.php,
godmode/reporting/visual_console_builder.editor.js,
godmode/reporting/visual_console_builder.elements.php,
godmode/reporting/visual_console_builder.editor.php,
godmode/reporting/map_builder.php,
include/ajax/visual_console_builder.ajax.php,
include/ajax/agent.php, include/functions_visual_map_editor.php,
* operation/agentes/datos_agente.php,
include/functions_netflow.php: cleaned source code style.
* include/functions_ui.php: in function
"ui_require_javascript_file_enterprise" fixed when need a
enterprise javascript instead metaconsole enterprise path.
* include/javascript/pandora.js: fixed the function
"agent_changed_by_multiple_agents" that needs in the metaconsole.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7258 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-12-11 16:01:45 +01:00
|
|
|
$hack_metaconsole = '';
|
2019-01-30 16:18:44 +01:00
|
|
|
if (defined('METACONSOLE')) {
|
|
|
|
$hack_metaconsole = '../../';
|
2018-08-02 10:57:00 +02:00
|
|
|
}
|
2017-12-28 15:13:06 +01:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$buttons['visual_console'] = [
|
|
|
|
'active' => true,
|
2021-03-11 15:40:23 +01:00
|
|
|
'text' => '<a href="'.$url_visual_console.'">'.html_print_image(
|
|
|
|
'images/visual_console.png',
|
|
|
|
true,
|
|
|
|
[
|
|
|
|
'title' => __('Visual Console List'),
|
|
|
|
'class' => 'invert_filter',
|
|
|
|
]
|
|
|
|
).'</a>',
|
2019-01-30 16:18:44 +01:00
|
|
|
];
|
|
|
|
|
|
|
|
$buttons['visual_console_favorite'] = [
|
|
|
|
'active' => false,
|
2021-03-11 15:40:23 +01:00
|
|
|
'text' => '<a href="'.$url_visual_console_favorite.'">'.html_print_image(
|
|
|
|
'images/list.png',
|
|
|
|
true,
|
|
|
|
[
|
|
|
|
'title' => __('Visual Favourite Console'),
|
|
|
|
'class' => 'invert_filter',
|
|
|
|
]
|
|
|
|
).'</a>',
|
2019-01-30 16:18:44 +01:00
|
|
|
];
|
|
|
|
|
2019-03-15 11:51:39 +01:00
|
|
|
if ($is_enterprise !== ENTERPRISE_NOT_HOOK && $vconsoles_manage) {
|
2019-01-30 16:18:44 +01:00
|
|
|
$buttons['visual_console_template'] = [
|
|
|
|
'active' => false,
|
2021-03-11 15:40:23 +01:00
|
|
|
'text' => '<a href="'.$url_visual_console_template.'">'.html_print_image(
|
|
|
|
'images/templates.png',
|
|
|
|
true,
|
|
|
|
[
|
|
|
|
'title' => __('Visual Console Template'),
|
|
|
|
'class' => 'invert_filter',
|
|
|
|
]
|
|
|
|
).'</a>',
|
2019-01-30 16:18:44 +01:00
|
|
|
];
|
|
|
|
|
|
|
|
$buttons['visual_console_template_wizard'] = [
|
|
|
|
'active' => false,
|
2021-03-11 15:40:23 +01:00
|
|
|
'text' => '<a href="'.$url_visual_console_template_wizard.'">'.html_print_image(
|
|
|
|
'images/wand.png',
|
|
|
|
true,
|
|
|
|
[
|
|
|
|
'title' => __('Visual Console Template Wizard'),
|
|
|
|
'class' => 'invert_filter',
|
|
|
|
]
|
|
|
|
).'</a>',
|
2019-01-30 16:18:44 +01:00
|
|
|
];
|
2018-08-02 10:57:00 +02:00
|
|
|
}
|
2017-12-28 15:13:06 +01:00
|
|
|
|
2018-08-02 13:07:40 +02:00
|
|
|
if (!$is_metaconsole) {
|
2019-01-30 16:18:44 +01:00
|
|
|
ui_print_page_header(
|
|
|
|
__('Reporting').' » '.__('Visual Console'),
|
|
|
|
'images/op_reporting.png',
|
|
|
|
false,
|
2020-05-29 11:37:06 +02:00
|
|
|
'',
|
2019-01-30 16:18:44 +01:00
|
|
|
false,
|
|
|
|
$buttons
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
ui_meta_print_header(
|
|
|
|
__('Visual console').' » '.$visualConsoleName,
|
|
|
|
'',
|
|
|
|
$buttons
|
|
|
|
);
|
2018-08-02 13:07:40 +02:00
|
|
|
}
|
2010-02-22 20:03:55 +01:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$id_layout = (int) get_parameter('id_layout');
|
|
|
|
$copy_layout = (bool) get_parameter('copy_layout');
|
|
|
|
$delete_layout = (bool) get_parameter('delete_layout');
|
2016-01-28 11:57:32 +01:00
|
|
|
$refr = (int) get_parameter('refr', $config['vc_refr']);
|
2015-07-08 16:09:00 +02:00
|
|
|
$offset = (int) get_parameter('offset', 0);
|
2019-01-30 16:18:44 +01:00
|
|
|
$pagination = (int) get_parameter('pagination', $config['block_size']);
|
|
|
|
$search = (string) get_parameter('search', '');
|
|
|
|
$ag_group = (int) get_parameter('ag_group', 0);
|
|
|
|
$recursion = get_parameter('recursion', 0);
|
2010-04-14 09:59:52 +02:00
|
|
|
|
2015-04-09 14:00:37 +02:00
|
|
|
if ($delete_layout || $copy_layout) {
|
2019-01-30 16:18:44 +01:00
|
|
|
// Visual console required
|
|
|
|
if (empty($id_layout)) {
|
|
|
|
db_pandora_audit(
|
|
|
|
'ACL Violation',
|
|
|
|
'Trying to access map builder'
|
|
|
|
);
|
|
|
|
include 'general/noaccess.php';
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
$group_id = db_get_value('id_group', 'tlayout', 'id', $id_layout);
|
|
|
|
if ($group_id === false) {
|
|
|
|
db_pandora_audit(
|
|
|
|
'ACL Violation',
|
|
|
|
'Trying to access map builder'
|
|
|
|
);
|
|
|
|
include 'general/noaccess.php';
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
// ACL for the visual console
|
|
|
|
// $vconsole_read = check_acl ($config['id_user'], $group_id, "VR");
|
2020-10-22 12:00:44 +02:00
|
|
|
$vconsole_write = check_acl_restricted_all($config['id_user'], $group_id, 'VW');
|
|
|
|
$vconsole_manage = check_acl_restricted_all($config['id_user'], $group_id, 'VM');
|
2019-01-30 16:18:44 +01:00
|
|
|
|
|
|
|
if (!$vconsole_write && !$vconsole_manage) {
|
|
|
|
db_pandora_audit(
|
|
|
|
'ACL Violation',
|
|
|
|
'Trying to access map builder'
|
|
|
|
);
|
|
|
|
include 'general/noaccess.php';
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($delete_layout) {
|
|
|
|
db_process_sql_delete(
|
|
|
|
'tlayout_data',
|
|
|
|
['id_layout' => $id_layout]
|
|
|
|
);
|
|
|
|
$result = db_process_sql_delete(
|
|
|
|
'tlayout',
|
|
|
|
['id' => $id_layout]
|
|
|
|
);
|
|
|
|
if ($result) {
|
|
|
|
db_pandora_audit(
|
|
|
|
'Visual console builder',
|
|
|
|
"Delete visual console #$id_layout"
|
|
|
|
);
|
|
|
|
ui_print_success_message(__('Successfully deleted'));
|
|
|
|
db_clean_cache();
|
|
|
|
} else {
|
|
|
|
db_pandora_audit(
|
|
|
|
'Visual console builder',
|
|
|
|
"Fail try to delete visual console #$id_layout"
|
|
|
|
);
|
|
|
|
ui_print_error_message(
|
|
|
|
__('Not deleted. Error deleting data')
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
$id_layout = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($copy_layout) {
|
|
|
|
// Number of inserts
|
|
|
|
$ninsert = (int) 0;
|
|
|
|
|
|
|
|
// Return from DB the source layout
|
|
|
|
$layout_src = db_get_all_rows_filter(
|
|
|
|
'tlayout',
|
|
|
|
['id' => $id_layout]
|
|
|
|
);
|
|
|
|
|
|
|
|
// Name of dst
|
|
|
|
$name_dst = get_parameter(
|
|
|
|
'name_dst',
|
|
|
|
$layout_src[0]['name'].' copy'
|
|
|
|
);
|
|
|
|
|
|
|
|
// Create the new Console
|
|
|
|
$idGroup = $layout_src[0]['id_group'];
|
|
|
|
$background = $layout_src[0]['background'];
|
|
|
|
$height = $layout_src[0]['height'];
|
|
|
|
$width = $layout_src[0]['width'];
|
|
|
|
$visualConsoleName = $name_dst;
|
|
|
|
|
|
|
|
$values = [
|
|
|
|
'name' => $visualConsoleName,
|
|
|
|
'id_group' => $idGroup,
|
|
|
|
'background' => $background,
|
|
|
|
'height' => $height,
|
|
|
|
'width' => $width,
|
|
|
|
];
|
|
|
|
$result = db_process_sql_insert('tlayout', $values);
|
|
|
|
|
|
|
|
$idNewVisualConsole = $result;
|
|
|
|
|
|
|
|
if ($result) {
|
|
|
|
$ninsert = 1;
|
|
|
|
|
|
|
|
// Return from DB the items of the source layout
|
|
|
|
$data_layout_src = db_get_all_rows_filter(
|
|
|
|
'tlayout_data',
|
|
|
|
['id_layout' => $id_layout]
|
|
|
|
);
|
|
|
|
|
|
|
|
if (!empty($data_layout_src)) {
|
|
|
|
// By default the id parent 0 is always 0.
|
|
|
|
$id_relations = [0 => 0];
|
|
|
|
|
|
|
|
for ($a = 0; $a < count($data_layout_src); $a++) {
|
|
|
|
// Changing the source id by the new visual console id
|
|
|
|
$data_layout_src[$a]['id_layout'] = $idNewVisualConsole;
|
|
|
|
|
|
|
|
$old_id = $data_layout_src[$a]['id'];
|
|
|
|
|
|
|
|
// Unsetting the source's id
|
|
|
|
unset($data_layout_src[$a]['id']);
|
|
|
|
|
|
|
|
// Configure the cloned Console
|
|
|
|
$result = db_process_sql_insert(
|
|
|
|
'tlayout_data',
|
|
|
|
$data_layout_src[$a]
|
|
|
|
);
|
|
|
|
|
|
|
|
$id_relations[$old_id] = 0;
|
|
|
|
|
|
|
|
if ($result !== false) {
|
|
|
|
$id_relations[$old_id] = $result;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($result) {
|
|
|
|
$ninsert++;
|
|
|
|
}
|
|
|
|
}//end for
|
|
|
|
|
|
|
|
$inserts = (count($data_layout_src) + 1);
|
|
|
|
|
|
|
|
// If the number of inserts is correct, the copy is completed
|
|
|
|
if ($ninsert == $inserts) {
|
|
|
|
// Update the ids of parents
|
|
|
|
$items = db_get_all_rows_filter(
|
|
|
|
'tlayout_data',
|
|
|
|
['id_layout' => $idNewVisualConsole]
|
|
|
|
);
|
|
|
|
|
|
|
|
foreach ($items as $item) {
|
|
|
|
$new_parent = $id_relations[$item['parent_item']];
|
|
|
|
|
|
|
|
db_process_sql_update(
|
|
|
|
'tlayout_data',
|
|
|
|
['parent_item' => $new_parent],
|
|
|
|
['id' => $item['id']]
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
ui_print_success_message(__('Successfully copied'));
|
|
|
|
db_clean_cache();
|
|
|
|
} else {
|
|
|
|
ui_print_error_message(__('Not copied. Error copying data'));
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
// If the array is empty the copy is completed
|
|
|
|
ui_print_success_message(__('Successfully copied'));
|
|
|
|
db_clean_cache();
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
ui_print_error_message(__('Not copied. Error copying data'));
|
|
|
|
}
|
|
|
|
}
|
2010-04-13 19:45:51 +02:00
|
|
|
}
|
|
|
|
|
2017-10-20 11:44:58 +02:00
|
|
|
if ($ag_group > 0) {
|
2019-01-30 16:18:44 +01:00
|
|
|
$ag_groups = [];
|
|
|
|
$ag_groups = (array) $ag_group;
|
|
|
|
if ($recursion) {
|
2020-10-21 11:38:57 +02:00
|
|
|
$ag_groups = groups_get_children_ids($ag_group, true);
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
2017-10-20 11:44:58 +02:00
|
|
|
}
|
|
|
|
|
2021-03-11 15:40:23 +01:00
|
|
|
echo "<table class='databox filters bolder mrgn_btn_10px' width='100%'>
|
2017-10-20 11:44:58 +02:00
|
|
|
<tr>";
|
2019-01-30 16:18:44 +01:00
|
|
|
if (!is_metaconsole()) {
|
|
|
|
echo "<form method='post'
|
2017-10-20 11:44:58 +02:00
|
|
|
action='index.php?sec=network&sec2=godmode/reporting/map_builder'>";
|
|
|
|
} else {
|
2019-01-30 16:18:44 +01:00
|
|
|
echo "<form method='post'
|
2017-10-20 11:44:58 +02:00
|
|
|
action='index.php?sec=screen&sec2=screens/screens&action=visualmap'>";
|
|
|
|
}
|
|
|
|
|
2021-03-11 15:40:23 +01:00
|
|
|
echo "<td class='w33p'>";
|
2019-01-30 16:18:44 +01:00
|
|
|
echo __('Search').' ';
|
|
|
|
html_print_input_text('search', $search, '', 50);
|
2017-10-20 11:44:58 +02:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
echo '</td>';
|
2021-03-11 15:40:23 +01:00
|
|
|
echo "<td class='w25p'>";
|
2017-10-20 11:44:58 +02:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
echo __('Group').' ';
|
2017-10-20 11:44:58 +02:00
|
|
|
$own_info = get_user_info($config['id_user']);
|
2019-01-30 16:18:44 +01:00
|
|
|
if (!$own_info['is_admin'] && !check_acl($config['id_user'], 0, 'VR')) {
|
|
|
|
$return_all_group = false;
|
|
|
|
} else {
|
|
|
|
$return_all_group = true;
|
|
|
|
}
|
|
|
|
|
2020-09-28 18:04:46 +02:00
|
|
|
echo '<div class="w250px inline">';
|
2019-01-30 16:18:44 +01:00
|
|
|
html_print_select_groups(false, 'AR', $return_all_group, 'ag_group', $ag_group, 'this.form.submit();', '', 0, false, false, true, '', false);
|
2020-09-28 18:04:46 +02:00
|
|
|
echo '</div>';
|
2021-03-11 15:40:23 +01:00
|
|
|
echo "<td class='w25p'>";
|
2019-01-30 16:18:44 +01:00
|
|
|
echo __('Group Recursion').' ';
|
|
|
|
html_print_checkbox('recursion', 1, $recursion, false, false, 'this.form.submit()');
|
2017-10-20 11:44:58 +02:00
|
|
|
|
2021-03-11 15:40:23 +01:00
|
|
|
echo "</td><td class='w22p'>";
|
2017-10-20 11:44:58 +02:00
|
|
|
echo "<input name='search_visual_console' type='submit' class='sub search' value='".__('Search')."'>";
|
2019-01-30 16:18:44 +01:00
|
|
|
echo '</form>';
|
|
|
|
echo '</td>';
|
|
|
|
echo '</tr></table>';
|
2017-10-20 11:44:58 +02:00
|
|
|
|
2015-06-16 17:44:15 +02:00
|
|
|
$table = new stdClass();
|
2015-04-23 17:52:16 +02:00
|
|
|
$table->width = '100%';
|
2019-03-27 17:03:55 +01:00
|
|
|
$table->class = 'info_table';
|
|
|
|
$table->cellpadding = 0;
|
|
|
|
$table->cellspacing = 0;
|
2019-01-30 16:18:44 +01:00
|
|
|
$table->data = [];
|
|
|
|
$table->head = [];
|
2010-03-31 13:44:03 +02:00
|
|
|
$table->head[0] = __('Map name');
|
|
|
|
$table->head[1] = __('Group');
|
|
|
|
$table->head[2] = __('Items');
|
2018-01-11 15:25:55 +01:00
|
|
|
$table->head[3] = __('Copy');
|
|
|
|
$table->head[4] = __('Delete');
|
2019-01-30 16:18:44 +01:00
|
|
|
$table->size[3] = '6%';
|
|
|
|
$table->size[4] = '6%';
|
2012-04-02 Dario Rodriguez <dario.rodriguez@artica.es>
*operation/visual_console/render_view.php,
operation/visual_console/index.php,
operation/agentes/networkmap.php,
operation/servers/view_server.php,
operation/servers/recon_view.php,
operation/servers/view_server_detail.php,
operation/menu.php,
operation/reporting/reporting_viewer.php,
operation/reporting/graph_viewer.php,
general/header.php,
godmode/servers/modificar_server.php,
godmode/reporting/visual_console_builder.wizard.php,
godmode/reporting/graph_builder.main.php,
godmode/reporting/visual_console_builder.php,
godmode/reporting/visual_console_builder.elements.php,
godmode/reporting/graph_builder.php,
godmode/reporting/graph_builder.graph_editor.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/visual_console_builder.editor.php,
godmode/reporting/map_builder.php,
godmode/reporting/graphs.php: Merged changes in menu structure
from 4.0.2 to trunk version
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@5860 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-04-02 09:53:24 +02:00
|
|
|
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$table->align = [];
|
2012-12-11 Miguel de Dios <miguel.dedios@artica.es>
* extras/pandoradb_migrate_4.0.x_to_5.0.mysql.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.oracle.sql,
extras/pandoradb_migrate_4.0.x_to_5.0.postgreSQL.sql, pandoradb.sql,
pandoradb.postgreSQL.sql, pandoradb.oracle.sql: in the table
"tlayout_data" added the column "id_metaconsole" for to show
visualmaps in the metaconsole.
* operation/visual_console/render_view.php,
include/functions_visual_map.php, operation/agentes/ver_agente.php,
godmode/reporting/visual_console_builder.wizard.php,
godmode/reporting/visual_console_builder.php,
godmode/reporting/visual_console_builder.data.php,
godmode/reporting/visual_console_builder.editor.js,
godmode/reporting/visual_console_builder.elements.php,
godmode/reporting/visual_console_builder.editor.php,
godmode/reporting/map_builder.php,
include/ajax/visual_console_builder.ajax.php,
include/ajax/agent.php, include/functions_visual_map_editor.php,
* operation/agentes/datos_agente.php,
include/functions_netflow.php: cleaned source code style.
* include/functions_ui.php: in function
"ui_require_javascript_file_enterprise" fixed when need a
enterprise javascript instead metaconsole enterprise path.
* include/javascript/pandora.js: fixed the function
"agent_changed_by_multiple_agents" that needs in the metaconsole.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7258 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-12-11 16:01:45 +01:00
|
|
|
$table->align[0] = 'left';
|
2015-04-23 17:52:16 +02:00
|
|
|
$table->align[1] = 'left';
|
|
|
|
$table->align[2] = 'left';
|
|
|
|
$table->align[3] = 'left';
|
|
|
|
$table->align[4] = 'left';
|
2010-03-31 13:44:03 +02:00
|
|
|
|
2014-01-23 15:26:41 +01:00
|
|
|
// Only display maps of "All" group if user is administrator
|
2015-04-09 14:00:37 +02:00
|
|
|
// or has "VR" privileges, otherwise show only maps of user group
|
2015-07-08 16:09:00 +02:00
|
|
|
$filters['offset'] = $offset;
|
|
|
|
$filters['limit'] = $pagination;
|
2019-01-30 16:18:44 +01:00
|
|
|
if (!empty($search)) {
|
|
|
|
$filters['name'] = io_safe_input($search);
|
2017-10-20 11:44:58 +02:00
|
|
|
}
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
if ($ag_group) {
|
|
|
|
$filters['group'] = array_flip($ag_groups);
|
2017-10-20 11:44:58 +02:00
|
|
|
}
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$own_info = get_user_info($config['id_user']);
|
2015-07-08 16:09:00 +02:00
|
|
|
if (!defined('METACONSOLE')) {
|
2019-01-30 16:18:44 +01:00
|
|
|
$url = 'index.php?sec=network&sec2=godmode/reporting/map_builder&recursion='.$recursion.'&ag_group='.$ag_group.'&search='.$search.'&pagination='.$pagination;
|
|
|
|
} else {
|
|
|
|
$url = 'index.php?sec=screen&sec2=screens/screens&action=visualmap&recursion='.$recursion.'&ag_group='.$ag_group.'&search='.$search.'&pagination='.$pagination;
|
2015-07-08 16:09:00 +02:00
|
|
|
}
|
2018-03-06 17:07:02 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2015-07-08 16:09:00 +02:00
|
|
|
if ($own_info['is_admin'] || $vconsoles_read) {
|
2019-01-30 16:18:44 +01:00
|
|
|
if ($ag_group) {
|
|
|
|
$maps = visual_map_get_user_layouts($config['id_user'], false, $filters, false);
|
|
|
|
unset($filters['offset']);
|
|
|
|
unset($filters['limit']);
|
|
|
|
$count_maps = visual_map_get_user_layouts($config['id_user'], false, $filters, false);
|
|
|
|
$total_maps = count($count_maps);
|
|
|
|
} else {
|
|
|
|
$maps = visual_map_get_user_layouts($config['id_user'], false, $filters, false);
|
|
|
|
unset($filters['offset']);
|
|
|
|
unset($filters['limit']);
|
|
|
|
$count_maps = visual_map_get_user_layouts($config['id_user'], false, $filters, false);
|
|
|
|
$total_maps = count($count_maps);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$maps = visual_map_get_user_layouts($config['id_user'], false, $filters, false);
|
|
|
|
unset($filters['offset']);
|
|
|
|
unset($filters['limit']);
|
|
|
|
$count_maps = visual_map_get_user_layouts($config['id_user'], false, $filters, false);
|
|
|
|
$total_maps = count($count_maps);
|
2015-07-08 16:09:00 +02:00
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2016-09-08 16:06:12 +02:00
|
|
|
if (!$maps && !is_metaconsole()) {
|
2019-01-30 16:18:44 +01:00
|
|
|
$total = count(visual_map_get_user_layouts($config['id_user'], false, false, false));
|
|
|
|
if (!$total) {
|
2019-11-21 18:21:46 +01:00
|
|
|
include_once $config['homedir'].'/general/first_task/map_builder.php';
|
2019-01-30 16:18:44 +01:00
|
|
|
} else {
|
|
|
|
ui_print_info_message(
|
|
|
|
[
|
|
|
|
'no_close' => false,
|
|
|
|
'message' => __('No available data to show'),
|
|
|
|
]
|
|
|
|
);
|
|
|
|
}
|
|
|
|
} else if (!$maps && is_metaconsole()) {
|
|
|
|
$total = count(visual_map_get_user_layouts($config['id_user'], false, false, false));
|
|
|
|
if (!$total) {
|
|
|
|
ui_print_info_message(
|
|
|
|
[
|
|
|
|
'no_close' => true,
|
|
|
|
'message' => __('There are no visual console defined yet.'),
|
|
|
|
]
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
ui_print_info_message(
|
|
|
|
[
|
|
|
|
'no_close' => false,
|
|
|
|
'message' => __('No available data to show'),
|
|
|
|
]
|
|
|
|
);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
ui_pagination($total_maps, $url, $offset, $pagination);
|
|
|
|
foreach ($maps as $map) {
|
|
|
|
// ACL for the visual console permission
|
|
|
|
$vconsole_write = false;
|
|
|
|
$vconsole_manage = false;
|
|
|
|
if (isset($map['vw'])) {
|
|
|
|
$vconsole_write = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($map['vm'])) {
|
|
|
|
$vconsole_manage = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
$data = [];
|
|
|
|
|
|
|
|
if (!is_metaconsole()) {
|
|
|
|
$data[0] = '<a href="index.php?sec=network&sec2=operation/visual_console/render_view&id='.$map['id'].'&refr='.$refr.'">'.$map['name'].'</a>';
|
|
|
|
} else {
|
|
|
|
$data[0] = '<a href="index.php?sec=screen&sec2=screens/screens&action=visualmap&pure='.$pure.'&id_visualmap='.$map['id'].'&refr='.$refr.'">'.$map['name'].'</a>';
|
|
|
|
}
|
|
|
|
|
|
|
|
$data[1] = ui_print_group_icon($map['id_group'], true);
|
|
|
|
$data[2] = db_get_sql('SELECT COUNT(*) FROM tlayout_data WHERE id_layout = '.$map['id']);
|
|
|
|
|
2020-10-22 12:00:44 +02:00
|
|
|
$vconsoles_write_action_btn = check_acl_restricted_all($config['id_user'], $map['id_group'], 'VW');
|
|
|
|
$vconsoles_manage_action_btn = check_acl_restricted_all($config['id_user'], $map['id_group'], 'VM');
|
|
|
|
|
|
|
|
if ($vconsoles_write_action_btn || $vconsoles_manage_action_btn) {
|
2019-01-30 16:18:44 +01:00
|
|
|
if (!is_metaconsole()) {
|
2019-04-02 13:42:30 +02:00
|
|
|
$table->cellclass[] = [
|
|
|
|
3 => 'action_buttons',
|
|
|
|
4 => 'action_buttons',
|
|
|
|
];
|
2021-03-11 15:40:23 +01:00
|
|
|
$data[3] = '<a class="copy_visualmap" href="index.php?sec=network&sec2=godmode/reporting/map_builder&id_layout='.$map['id'].'&copy_layout=1">'.html_print_image(
|
|
|
|
'images/copy.png',
|
|
|
|
true,
|
|
|
|
['class' => 'invert_filter']
|
|
|
|
).'</a>';
|
|
|
|
$data[4] = '<a class="delete_visualmap" href="index.php?sec=network&sec2=godmode/reporting/map_builder&id_layout='.$map['id'].'&delete_layout=1" onclick="javascript: if (!confirm(\''.__('Are you sure?').'\n'.__('Delete').': '.$map['name'].'\')) return false;">'.html_print_image(
|
|
|
|
'images/cross.png',
|
|
|
|
true,
|
|
|
|
['class' => 'invert_filter']
|
|
|
|
).'</a>';
|
2019-01-30 16:18:44 +01:00
|
|
|
} else {
|
2021-03-11 15:40:23 +01:00
|
|
|
$data[3] = '<a class="copy_visualmap" href="index.php?sec=screen&sec2=screens/screens&action=visualmap&pure='.$pure.'&id_layout='.$map['id'].'&copy_layout=1">'.html_print_image(
|
|
|
|
'images/copy.png',
|
|
|
|
true,
|
|
|
|
['class' => 'invert_filter']
|
|
|
|
).'</a>';
|
|
|
|
$data[4] = '<a class="delete_visualmap" href="index.php?sec=screen&sec2=screens/screens&action=visualmap&pure='.$pure.'&id_layout='.$map['id'].'&delete_layout=1" onclick="javascript: if (!confirm(\''.__('Are you sure?').'\n'.__('Delete').': '.$map['name'].'\')) return false;">'.html_print_image(
|
|
|
|
'images/cross.png',
|
|
|
|
true,
|
|
|
|
['class' => 'invert_filter']
|
|
|
|
).'</a>';
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$data[3] = '';
|
|
|
|
$data[4] = '';
|
|
|
|
}
|
|
|
|
|
|
|
|
array_push($table->data, $data);
|
|
|
|
}
|
|
|
|
|
|
|
|
html_print_table($table);
|
2019-03-27 17:03:55 +01:00
|
|
|
ui_pagination($total_maps, $url, $offset, $pagination, false, 'offset', true, 'pagination-bottom');
|
2009-08-14 Miguel de Dios <miguel.dedios@artica.es>
* godmode/agentes/agent_manager.php, godmode/agentes/massive_config.php,
godmode/alerts/alert_list.php, godmode/reporting/graph_builder.php,
godmode/reporting/map_builder.php, include/functions_db.php,
include/functions_html.php, operation/agentes/exportdata.php,
operation/agentes/ver_agente.php: very changes for add input text
autocomplete with ajax jquery for agent input in several forms. Add to form
this exportdata, graph_builder, map_builder.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1849 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-08-14 18:38:57 +02:00
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2015-06-26 14:52:01 +02:00
|
|
|
if ($maps) {
|
2019-01-30 16:18:44 +01:00
|
|
|
if (!is_metaconsole()) {
|
2021-03-11 15:40:23 +01:00
|
|
|
echo '<div class="action-buttons w100p right">';
|
2019-01-30 16:18:44 +01:00
|
|
|
} else {
|
2021-03-18 18:05:50 +01:00
|
|
|
echo '<div class="w100p right_align">';
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
2010-06-06 23:01:10 +02:00
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
|
|
|
|
if ($maps || defined('METACONSOLE')) {
|
|
|
|
if ($vconsoles_write || $vconsoles_manage) {
|
|
|
|
if (!defined('METACONSOLE')) {
|
|
|
|
echo '<form action="index.php?sec=network&sec2=godmode/reporting/visual_console_builder" method="post">';
|
|
|
|
} else {
|
|
|
|
echo '<form action="index.php?sec=screen&sec2=screens/screens&action=visualmap&action2=new&operation=new_visualmap&tab=data&pure='.$pure.'" method="post">';
|
|
|
|
}
|
|
|
|
|
|
|
|
html_print_input_hidden('edit_layout', 1);
|
|
|
|
html_print_submit_button(
|
|
|
|
__('Create'),
|
|
|
|
'',
|
|
|
|
false,
|
|
|
|
'class="sub next"'
|
|
|
|
);
|
|
|
|
echo '</form>';
|
|
|
|
}
|
|
|
|
|
|
|
|
echo '</div>';
|
2012-04-02 Dario Rodriguez <dario.rodriguez@artica.es>
*operation/visual_console/render_view.php,
operation/visual_console/index.php,
operation/agentes/networkmap.php,
operation/servers/view_server.php,
operation/servers/recon_view.php,
operation/servers/view_server_detail.php,
operation/menu.php,
operation/reporting/reporting_viewer.php,
operation/reporting/graph_viewer.php,
general/header.php,
godmode/servers/modificar_server.php,
godmode/reporting/visual_console_builder.wizard.php,
godmode/reporting/graph_builder.main.php,
godmode/reporting/visual_console_builder.php,
godmode/reporting/visual_console_builder.elements.php,
godmode/reporting/graph_builder.php,
godmode/reporting/graph_builder.graph_editor.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/visual_console_builder.editor.php,
godmode/reporting/map_builder.php,
godmode/reporting/graphs.php: Merged changes in menu structure
from 4.0.2 to trunk version
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@5860 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-04-02 09:53:24 +02:00
|
|
|
}
|