2011-12-21 14:09:26 +01:00
|
|
|
<?php
|
2023-03-14 18:15:31 +01:00
|
|
|
/**
|
|
|
|
* Netflow Filter view
|
|
|
|
*
|
|
|
|
* @category Netflow
|
|
|
|
* @package Pandora FMS
|
|
|
|
* @subpackage Community
|
|
|
|
* @version 1.0.0
|
|
|
|
* @license See below
|
|
|
|
*
|
|
|
|
* ______ ___ _______ _______ ________
|
2023-06-08 12:42:10 +02:00
|
|
|
* | __ \.-----.--.--.--| |.-----.----.-----. | ___| | | __|
|
|
|
|
* | __/| _ | | _ || _ | _| _ | | ___| |__ |
|
2023-03-14 18:15:31 +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-03-14 18:15:31 +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.
|
|
|
|
* ============================================================================
|
|
|
|
*/
|
2011-12-21 14:09:26 +01:00
|
|
|
|
|
|
|
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
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
if (! check_acl($config['id_user'], 0, 'AW')) {
|
|
|
|
db_pandora_audit(
|
2022-01-20 10:55:23 +01:00
|
|
|
AUDIT_LOG_ACL_VIOLATION,
|
2019-01-30 16:18:44 +01:00
|
|
|
'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
|
|
|
|
2023-03-14 18:15:31 +01:00
|
|
|
// Header.
|
|
|
|
ui_print_standard_header(
|
|
|
|
__('Manage Filters'),
|
|
|
|
'images/gm_netflow.png',
|
|
|
|
false,
|
|
|
|
'',
|
|
|
|
true,
|
|
|
|
[],
|
|
|
|
[
|
2019-01-30 16:18:44 +01:00
|
|
|
[
|
2023-03-14 18:15:31 +01:00
|
|
|
'link' => '',
|
2023-03-21 17:02:03 +01:00
|
|
|
'label' => __('Resources'),
|
2019-01-30 16:18:44 +01:00
|
|
|
],
|
2023-03-21 17:02:03 +01:00
|
|
|
[
|
|
|
|
'link' => '',
|
|
|
|
'label' => __('Netflow filters'),
|
|
|
|
],
|
|
|
|
]
|
2023-03-14 18:15:31 +01:00
|
|
|
);
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2023-03-14 18:15:31 +01:00
|
|
|
$is_windows = (strtoupper(substr(PHP_OS, 0, 3)) === 'WIN');
|
|
|
|
if ($is_windows === true) {
|
|
|
|
ui_print_error_message(__('Not supported in Windows systems'));
|
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(
|
2022-01-20 10:55:23 +01:00
|
|
|
AUDIT_LOG_ACL_VIOLATION,
|
2020-10-22 12:00:44 +02:00
|
|
|
'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'];
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2022-12-20 17:22:35 +01:00
|
|
|
$data[2] = ui_print_group_icon($filter['id_group'], true);
|
2020-10-22 12:00:44 +02:00
|
|
|
$data[3] = '';
|
|
|
|
|
|
|
|
if (check_acl_restricted_all($config['id_user'], $filter['id_group'], 'AW')) {
|
2022-11-30 10:14:42 +01:00
|
|
|
$table->cellclass[][3] = 'table_action_buttons';
|
2023-03-14 18:15:31 +01:00
|
|
|
$data[3] = '<a onclick="if(confirm(\''.__('Are you sure?').'\')) return true; else return false;" href="'.$config['homeurl'].'index.php?sec=netf&sec2=godmode/netflow/nf_edit&delete=1&id='.$filter['id_sg'].'&offset=0&pure='.$pure.'">';
|
|
|
|
$data[3] .= html_print_image('images/delete.svg', true, ['title' => __('Delete'), 'class' => 'main_menu_icon invert_filter']);
|
|
|
|
$data[3] .= '</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
|
|
|
}
|
|
|
|
|
2023-03-14 18:15:31 +01:00
|
|
|
$buttons = html_print_submit_button(
|
|
|
|
__('Create filter'),
|
|
|
|
'crt',
|
|
|
|
false,
|
|
|
|
['icon' => 'wand'],
|
|
|
|
true
|
|
|
|
);
|
|
|
|
|
|
|
|
if (empty($filters) === false) {
|
|
|
|
echo '<form id="multiple_delete" method="POST" action="'.$config['homeurl'].'index.php?sec=netf&sec2=godmode/netflow/nf_edit&pure='.$pure.'">';
|
2019-01-30 16:18:44 +01:00
|
|
|
html_print_input_hidden('multiple_delete', 1);
|
|
|
|
html_print_table($table);
|
|
|
|
echo '</form>';
|
2023-03-14 18:15:31 +01:00
|
|
|
$buttons .= html_print_submit_button(__('Delete'), 'delete_btn', false, ['icon' => 'delete', 'mode' => 'secondary', 'form' => 'multiple_delete'], true);
|
2019-01-30 16:18:44 +01:00
|
|
|
} 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.'">';
|
2023-03-14 18:15:31 +01:00
|
|
|
html_print_action_buttons(
|
|
|
|
$buttons
|
|
|
|
);
|
2019-01-30 16:18:44 +01:00
|
|
|
echo '</form>';
|
2015-03-06 12:28:05 +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() {
|
2023-03-14 18:15:31 +01:00
|
|
|
$('[id^=checkbox-all_delete]').change(function() {
|
|
|
|
if ($("input[name=all_delete]").prop("checked")) {
|
|
|
|
$(".custom_checkbox_input").prop("checked", true);
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
2023-03-14 18:15:31 +01:00
|
|
|
else {
|
|
|
|
$(".custom_checkbox_input").prop("checked", false);
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
2018-09-13 16:07:40 +02:00
|
|
|
|
|
|
|
|
2011-12-21 14:09:26 +01:00
|
|
|
</script>
|