2011-12-21 14:09:26 +01:00
|
|
|
<?php
|
|
|
|
|
2021-11-04 16:28:15 +01:00
|
|
|
// Pandora FMS - http://pandorafms.com
|
2011-12-21 14:09:26 +01:00
|
|
|
// ==================================================
|
2020-11-27 13:52:35 +01:00
|
|
|
// Copyright (c) 2005-2021 Artica Soluciones Tecnologicas
|
2011-12-21 14:09:26 +01:00
|
|
|
// Please see http://pandorafms.org for full contribution list
|
|
|
|
// This program is free software; you can redistribute it and/or
|
|
|
|
// modify it under the terms of the GNU General Public License
|
|
|
|
// as published by the Free Software Foundation; 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.
|
|
|
|
global $config;
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
require_once $config['homedir'].'/include/functions_ui.php';
|
|
|
|
require_once $config['homedir'].'/include/functions_db.php';
|
|
|
|
require_once $config['homedir'].'/include/functions_netflow.php';
|
2011-12-21 14:09:26 +01:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
check_login();
|
2011-12-21 14:09:26 +01:00
|
|
|
|
2015-03-06 12:28:05 +01:00
|
|
|
enterprise_hook('open_meta_frame');
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
if (! check_acl($config['id_user'], 0, 'AW')) {
|
|
|
|
db_pandora_audit(
|
|
|
|
'ACL Violation',
|
|
|
|
'Trying to access event viewer'
|
|
|
|
);
|
|
|
|
include 'general/noaccess.php';
|
|
|
|
return;
|
2011-12-21 14:09:26 +01:00
|
|
|
}
|
2012-11-29 11:30:46 +01:00
|
|
|
|
|
|
|
$pure = get_parameter('pure', 0);
|
2013-02-04 13:19:17 +01:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
// Header
|
|
|
|
if (! defined('METACONSOLE')) {
|
2019-04-30 10:44:53 +02:00
|
|
|
ui_print_page_header(
|
|
|
|
__('Manage Netflow Filter'),
|
|
|
|
'images/gm_netflow.png',
|
|
|
|
false,
|
2020-05-29 11:37:06 +02:00
|
|
|
'',
|
2019-04-30 10:44:53 +02:00
|
|
|
true
|
|
|
|
);
|
2019-01-30 16:18:44 +01:00
|
|
|
|
|
|
|
$is_windows = strtoupper(substr(PHP_OS, 0, 3)) == 'WIN';
|
|
|
|
if ($is_windows) {
|
|
|
|
ui_print_error_message(__('Not supported in Windows systems'));
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$nav_bar = [
|
|
|
|
[
|
|
|
|
'link' => 'index.php?sec=main',
|
|
|
|
'text' => __('Main'),
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'link' => 'index.php?sec=netf&sec2=godmode/netflow/nf_edit',
|
|
|
|
'text' => __('Netflow filters'),
|
|
|
|
],
|
|
|
|
];
|
|
|
|
|
|
|
|
ui_meta_print_page_header($nav_bar);
|
|
|
|
|
|
|
|
ui_meta_print_header(__('Netflow filters'));
|
2012-10-04 Ramon Novoa <rnovoa@artica.es>
* include/functions_html.php,
include/functions_netflow.php,
pandoradb.sql,
pandoradb.postgreSQL.sql,
pandoradb.oracle.sql,
operation/netflow/nf_live_view.php,
operation/netflow/nf_reporting.php,
operation/netflow/nf_view.php,
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,
godmode/netflow/nf_edit_form.php,
godmode/netflow/nf_item_list.php,
godmode/netflow/nf_report_item.php,
godmode/netflow/nf_report_form.php,
godmode/netflow/nf_edit.php: Added metaconsole integration to netflow
reports.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@7043 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-10-04 12:49:11 +02:00
|
|
|
}
|
2011-12-21 14:09:26 +01:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$delete = (bool) get_parameter('delete');
|
|
|
|
$multiple_delete = (bool) get_parameter('multiple_delete', 0);
|
|
|
|
$id = (int) get_parameter('id');
|
|
|
|
$name = (string) get_parameter('name');
|
2011-12-21 14:09:26 +01:00
|
|
|
|
2020-10-22 12:00:44 +02:00
|
|
|
if ($id > 0) {
|
|
|
|
$filter_group = db_get_value('id_group', 'tnetflow_filter', 'id_sg', $id);
|
|
|
|
|
|
|
|
if (!check_acl_restricted_all($config['id_user'], $filter_group, 'AW')) {
|
|
|
|
db_pandora_audit(
|
|
|
|
'ACL Violation',
|
|
|
|
'Trying to access events filter editor'
|
|
|
|
);
|
|
|
|
include 'general/noaccess.php';
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-12-21 14:09:26 +01:00
|
|
|
if ($delete) {
|
2019-01-30 16:18:44 +01:00
|
|
|
$id_filter = db_get_value('id_name', 'tnetflow_filter', 'id_sg', $id);
|
|
|
|
$result = db_process_sql_delete(
|
|
|
|
'tnetflow_filter',
|
|
|
|
['id_sg' => $id]
|
|
|
|
);
|
|
|
|
|
|
|
|
$result2 = db_process_sql_delete(
|
|
|
|
'tnetflow_report_content',
|
|
|
|
['id_filter' => $id_filter]
|
|
|
|
);
|
|
|
|
|
|
|
|
if ($result !== false) {
|
|
|
|
$result = true;
|
|
|
|
} else {
|
|
|
|
$result = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
ui_print_result_message(
|
|
|
|
$result,
|
|
|
|
__('Successfully deleted'),
|
|
|
|
__('Not deleted. Error deleting data')
|
|
|
|
);
|
2011-12-21 14:09:26 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($multiple_delete) {
|
2019-01-30 16:18:44 +01:00
|
|
|
$ids = (array) get_parameter('delete_multiple', []);
|
|
|
|
|
|
|
|
foreach ($ids as $id) {
|
|
|
|
$id_filter = db_get_value('id_name', 'tnetflow_filter', 'id_sg', $id);
|
|
|
|
$result = db_process_sql_delete(
|
|
|
|
'tnetflow_filter',
|
|
|
|
['id_sg' => $id]
|
|
|
|
);
|
|
|
|
|
|
|
|
$result2 = db_process_sql_delete(
|
|
|
|
'tnetflow_report_content',
|
|
|
|
['id_filter' => $id_filter]
|
|
|
|
);
|
|
|
|
|
|
|
|
if ($result === false) {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($result !== false) {
|
|
|
|
$result = true;
|
|
|
|
} else {
|
|
|
|
$result = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
ui_print_result_message(
|
|
|
|
$result,
|
|
|
|
__('Successfully deleted'),
|
|
|
|
__('Not deleted. Error deleting data')
|
|
|
|
);
|
2011-12-21 14:09:26 +01:00
|
|
|
}
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$own_info = get_user_info($config['id_user']);
|
2012-01-11 16:02:27 +01:00
|
|
|
// Get group list that user has access
|
2019-01-30 16:18:44 +01:00
|
|
|
$groups_user = users_get_groups($config['id_user'], 'AW', $own_info['is_admin'], true);
|
|
|
|
$sql = 'SELECT *
|
2013-02-27 17:53:14 +01:00
|
|
|
FROM tnetflow_filter
|
2019-01-30 16:18:44 +01:00
|
|
|
WHERE id_group IN (0, '.implode(',', array_keys($groups_user)).')';
|
2012-01-11 16:02:27 +01:00
|
|
|
$filters = db_get_all_rows_sql($sql);
|
2019-01-30 16:18:44 +01:00
|
|
|
if ($filters === false) {
|
|
|
|
$filters = [];
|
|
|
|
}
|
2011-12-21 14:09:26 +01:00
|
|
|
|
2018-01-30 17:44:51 +01:00
|
|
|
$table = new stdClass();
|
2015-06-12 15:50:46 +02:00
|
|
|
$table->width = '100%';
|
2019-04-02 13:42:30 +02:00
|
|
|
$table->class = 'info_table';
|
2015-06-15 15:50:28 +02:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$table->head = [];
|
2019-04-02 13:42:30 +02:00
|
|
|
$table->head[0] = html_print_checkbox('all_delete', 0, false, true, false);
|
|
|
|
$table->head[1] = __('Name');
|
|
|
|
$table->head[2] = __('Group');
|
|
|
|
$table->head[3] = __('Action');
|
2019-01-30 16:18:44 +01:00
|
|
|
$table->style = [];
|
2019-04-02 13:42:30 +02:00
|
|
|
$table->style[1] = 'font-weight: bold';
|
2019-01-30 16:18:44 +01:00
|
|
|
$table->align = [];
|
2015-03-12 10:27:28 +01:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$table->size = [];
|
2019-04-02 13:42:30 +02:00
|
|
|
$table->size[0] = '10px';
|
|
|
|
$table->size[1] = '60%';
|
|
|
|
$table->size[2] = '30%';
|
|
|
|
$table->size[3] = '80px';
|
2019-01-30 16:18:44 +01:00
|
|
|
$table->data = [];
|
2011-12-21 14:09:26 +01:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$total_filters = db_get_all_rows_filter('tnetflow_filter', false, 'COUNT(*) AS total');
|
2011-12-21 14:09:26 +01:00
|
|
|
$total_filters = $total_filters[0]['total'];
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
// ui_pagination ($total_filters, $url);
|
2011-12-21 14:09:26 +01:00
|
|
|
foreach ($filters as $filter) {
|
2019-01-30 16:18:44 +01:00
|
|
|
$data = [];
|
|
|
|
|
2020-10-22 12:00:44 +02:00
|
|
|
$data[0] = '';
|
|
|
|
|
|
|
|
if (check_acl_restricted_all($config['id_user'], $filter['id_group'], 'AW')) {
|
|
|
|
$data[0] = html_print_checkbox_extended('delete_multiple[]', $filter['id_sg'], false, false, '', 'class="check_delete"', true);
|
|
|
|
$data[1] = '<a href="'.$config['homeurl'].'index.php?sec=netf&sec2=godmode/netflow/nf_edit_form&id='.$filter['id_sg'].'&pure='.$pure.'">'.$filter['id_name'].'</a>';
|
|
|
|
} else {
|
|
|
|
$data[1] = $filter['id_name'];
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-04-02 13:42:30 +02:00
|
|
|
$data[2] = ui_print_group_icon($filter['id_group'], true, 'groups_small', '', !defined('METACONSOLE'));
|
2020-10-22 12:00:44 +02:00
|
|
|
$data[3] = '';
|
|
|
|
|
|
|
|
if (check_acl_restricted_all($config['id_user'], $filter['id_group'], 'AW')) {
|
|
|
|
$table->cellclass[][3] = 'action_buttons';
|
|
|
|
$data[3] = "<a onclick='if(confirm(\"".__('Are you sure?')."\")) return true; else return false;'
|
2021-03-11 15:40:23 +01:00
|
|
|
href='".$config['homeurl'].'index.php?sec=netf&sec2=godmode/netflow/nf_edit&delete=1&id='.$filter['id_sg']."&offset=0&pure=$pure'>".html_print_image('images/cross.png', true, ['title' => __('Delete'), 'class' => 'invert_filter']).'</a>';
|
2020-10-22 12:00:44 +02:00
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
|
|
|
|
array_push($table->data, $data);
|
2011-12-21 14:09:26 +01:00
|
|
|
}
|
|
|
|
|
2013-08-05 16:23:27 +02:00
|
|
|
if (isset($data)) {
|
2019-01-30 16:18:44 +01:00
|
|
|
echo "<form method='post' action='".$config['homeurl']."index.php?sec=netf&sec2=godmode/netflow/nf_edit&pure=$pure'>";
|
|
|
|
html_print_input_hidden('multiple_delete', 1);
|
|
|
|
html_print_table($table);
|
2021-03-11 15:40:23 +01:00
|
|
|
echo "<div class='right'>";
|
2019-01-30 16:18:44 +01:00
|
|
|
|
|
|
|
html_print_submit_button(__('Delete'), 'delete_btn', false, 'class="sub delete"');
|
|
|
|
echo '</div>';
|
|
|
|
echo '</form>';
|
|
|
|
} else {
|
|
|
|
ui_print_info_message(['no_close' => true, 'message' => __('There are no defined filters') ]);
|
2011-12-21 14:09:26 +01:00
|
|
|
}
|
2012-01-16 12:08:28 +01:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
echo '<form method="post" action="'.$config['homeurl'].'index.php?sec=netf&sec2=godmode/netflow/nf_edit_form&pure='.$pure.'">';
|
2021-03-11 15:40:23 +01:00
|
|
|
echo "<div class='mrgn_right_5px right'>";
|
2019-01-30 16:18:44 +01:00
|
|
|
html_print_submit_button(__('Create filter'), 'crt', false, 'class="sub wand"');
|
|
|
|
echo '</div>';
|
|
|
|
echo '</form>';
|
2015-03-06 12:28:05 +01:00
|
|
|
|
|
|
|
enterprise_hook('close_meta_frame');
|
2012-01-16 12:08:28 +01:00
|
|
|
|
2011-12-21 14:09:26 +01:00
|
|
|
?>
|
|
|
|
|
|
|
|
<script type="text/javascript">
|
2018-09-13 16:07:40 +02:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$( document ).ready(function() {
|
|
|
|
|
|
|
|
$('[id^=checkbox-delete_multiple]').change(function(){
|
|
|
|
if($(this).parent().parent().hasClass('checkselected')){
|
|
|
|
$(this).parent().parent().removeClass('checkselected');
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
$(this).parent().parent().addClass('checkselected');
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
$('[id^=checkbox-all_delete]').change(function(){
|
|
|
|
if ($("#checkbox-all_delete").prop("checked")) {
|
|
|
|
$('[id^=checkbox-delete_multiple]').parent().parent().addClass('checkselected');
|
|
|
|
$(".check_delete").prop("checked", true);
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
$('[id^=checkbox-delete_multiple]').parent().parent().removeClass('checkselected');
|
|
|
|
$(".check_delete").prop("checked", false);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
2018-09-13 16:07:40 +02:00
|
|
|
|
|
|
|
|
2011-12-21 14:09:26 +01:00
|
|
|
</script>
|