2021-04-12 18:17:09 +02:00
|
|
|
<?php
|
|
|
|
/**
|
2023-06-08 13:19:01 +02:00
|
|
|
* Pandora FMS - https://pandorafms.com
|
2021-04-12 18:17:09 +02:00
|
|
|
* ==================================================
|
2023-06-08 11:53:13 +02:00
|
|
|
* Copyright (c) 2005-2023 Pandora FMS
|
2023-06-08 13:19:01 +02:00
|
|
|
* Please see https://pandorafms.com/community/ for full contribution list
|
2021-04-12 18:17:09 +02:00
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Print filters for interface view.
|
|
|
|
*
|
|
|
|
* @param string sec Section (type of filter will vary across sections).
|
|
|
|
*/
|
|
|
|
function print_filters($sec)
|
|
|
|
{
|
2023-02-23 16:30:18 +01:00
|
|
|
global $config;
|
|
|
|
|
2021-04-12 18:17:09 +02:00
|
|
|
$table = new StdClass();
|
|
|
|
$table->width = '100%';
|
2023-02-23 16:30:18 +01:00
|
|
|
$table->rowspan = [];
|
|
|
|
$table->size = [];
|
|
|
|
$table->size[0] = '33%';
|
|
|
|
$table->size[1] = '33%';
|
|
|
|
$table->size[2] = '33%';
|
|
|
|
$table->class = 'filter-table-adv';
|
2021-04-12 18:17:09 +02:00
|
|
|
|
|
|
|
if ($sec === 'view') {
|
2023-02-23 16:30:18 +01:00
|
|
|
$table->data[0][0] = html_print_label_input_block(
|
|
|
|
__('Group'),
|
|
|
|
html_print_select_groups(
|
|
|
|
$config['id_user'],
|
|
|
|
'AR',
|
|
|
|
true,
|
|
|
|
'group_id',
|
|
|
|
'',
|
|
|
|
'',
|
|
|
|
'',
|
|
|
|
'0',
|
|
|
|
true,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
'',
|
|
|
|
false,
|
|
|
|
'',
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
'id_grupo',
|
|
|
|
false
|
|
|
|
)
|
2021-04-12 18:17:09 +02:00
|
|
|
);
|
|
|
|
|
2023-02-23 16:30:18 +01:00
|
|
|
$table->data[0][0] .= html_print_label_input_block(
|
|
|
|
__('Recursion'),
|
|
|
|
html_print_input(
|
|
|
|
[
|
|
|
|
'type' => 'switch',
|
|
|
|
'name' => 'recursion',
|
|
|
|
'return' => true,
|
|
|
|
'checked' => false,
|
|
|
|
'value' => 1,
|
|
|
|
]
|
|
|
|
),
|
2021-04-12 18:17:09 +02:00
|
|
|
[
|
2023-02-23 16:30:18 +01:00
|
|
|
'div_class' => 'add-input-reverse',
|
|
|
|
'label_class' => 'label-thin',
|
2021-04-12 18:17:09 +02:00
|
|
|
]
|
|
|
|
);
|
2023-02-23 16:30:18 +01:00
|
|
|
$table->rowspan[0][1] = 2;
|
|
|
|
$table->data[0][1] = html_print_label_input_block(
|
|
|
|
__('Agents'),
|
|
|
|
html_print_select(
|
|
|
|
[],
|
|
|
|
'selected_agents[]',
|
|
|
|
'',
|
|
|
|
'',
|
|
|
|
'',
|
|
|
|
0,
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
'',
|
|
|
|
false,
|
|
|
|
'width:100%'
|
|
|
|
)
|
|
|
|
);
|
2021-04-12 18:17:09 +02:00
|
|
|
|
2023-02-23 16:30:18 +01:00
|
|
|
$table->rowspan[0][2] = 2;
|
|
|
|
$table->data[0][2] = html_print_label_input_block(
|
|
|
|
__('Interfaces'),
|
|
|
|
html_print_select(
|
|
|
|
[],
|
|
|
|
'selected_interfaces[]',
|
|
|
|
'',
|
|
|
|
'',
|
|
|
|
'',
|
|
|
|
0,
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
'',
|
|
|
|
false,
|
|
|
|
'width:100%'
|
|
|
|
)
|
2021-04-12 18:17:09 +02:00
|
|
|
);
|
|
|
|
|
2023-02-23 16:30:18 +01:00
|
|
|
$table->data[1][0] = html_print_label_input_block(
|
|
|
|
__('Filter Agents'),
|
|
|
|
html_print_input_text(
|
|
|
|
'filter_agents',
|
|
|
|
'',
|
|
|
|
'',
|
|
|
|
20,
|
|
|
|
255,
|
|
|
|
true
|
|
|
|
)
|
2021-04-12 18:17:09 +02:00
|
|
|
);
|
|
|
|
|
2023-02-23 16:30:18 +01:00
|
|
|
$filters = '<form method="post" action="'.ui_get_url_refresh().'">';
|
2021-04-12 18:17:09 +02:00
|
|
|
|
|
|
|
$filters .= html_print_table($table, true);
|
2021-05-14 10:10:42 +02:00
|
|
|
|
2023-02-23 16:30:18 +01:00
|
|
|
$filters .= html_print_div(
|
|
|
|
[
|
|
|
|
'class' => 'action-buttons',
|
|
|
|
'content' => html_print_submit_button(
|
|
|
|
__('Filter'),
|
|
|
|
'srcbutton',
|
|
|
|
false,
|
|
|
|
[
|
|
|
|
'icon' => 'search',
|
|
|
|
'mode' => 'mini',
|
|
|
|
],
|
|
|
|
true
|
|
|
|
),
|
|
|
|
],
|
2021-05-14 10:10:42 +02:00
|
|
|
true
|
2023-02-23 16:30:18 +01:00
|
|
|
);
|
2021-05-14 10:10:42 +02:00
|
|
|
|
2021-04-12 18:17:09 +02:00
|
|
|
$filters .= '</form>';
|
|
|
|
} else {
|
2023-03-15 15:58:28 +01:00
|
|
|
$table->data[0][0] = html_print_label_input_block(
|
|
|
|
__('Interfaces'),
|
|
|
|
html_print_select(
|
|
|
|
[],
|
|
|
|
'selected_interfaces[]',
|
|
|
|
'',
|
|
|
|
'',
|
|
|
|
'',
|
|
|
|
0,
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
'',
|
|
|
|
false,
|
|
|
|
'min-width: 200px; max-width: 250px; min-height: 70px;'
|
|
|
|
)
|
2021-04-12 18:17:09 +02:00
|
|
|
);
|
|
|
|
|
2023-02-23 16:30:18 +01:00
|
|
|
$filters = '<form method="post" action="'.ui_get_url_refresh().'">';
|
2021-04-12 18:17:09 +02:00
|
|
|
|
|
|
|
$filters .= html_print_table($table, true);
|
2021-05-14 10:14:53 +02:00
|
|
|
|
2023-03-15 15:58:28 +01:00
|
|
|
$filters .= html_print_submit_button(
|
2021-05-14 10:14:53 +02:00
|
|
|
__('Show'),
|
|
|
|
'uptbutton',
|
|
|
|
false,
|
2023-03-15 15:58:28 +01:00
|
|
|
['class' => 'float-right mini'],
|
2021-05-14 10:14:53 +02:00
|
|
|
true
|
2023-03-15 15:58:28 +01:00
|
|
|
);
|
2021-05-14 10:14:53 +02:00
|
|
|
|
2021-04-12 18:17:09 +02:00
|
|
|
$filters .= '</form>';
|
|
|
|
}
|
|
|
|
|
|
|
|
ui_toggle(
|
|
|
|
$filters,
|
2023-02-23 16:30:18 +01:00
|
|
|
'<span class="subsection_header_title">'.__('Interface filter').'</span>',
|
2021-04-12 18:17:09 +02:00
|
|
|
__('Interface filter'),
|
2023-02-23 10:24:03 +01:00
|
|
|
'ui_toggle_if_filter',
|
|
|
|
true,
|
|
|
|
false,
|
|
|
|
'',
|
|
|
|
'white-box-content',
|
|
|
|
'box-flat white_table_graph fixed_filter_bar'
|
2021-04-12 18:17:09 +02:00
|
|
|
);
|
2021-05-14 10:10:42 +02:00
|
|
|
|
2021-04-12 18:17:09 +02:00
|
|
|
unset($table);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Print interfaces table.
|
|
|
|
*
|
|
|
|
* @param array data Array containing data of interfaces.
|
|
|
|
* @param array selected_agents Selected agents.
|
|
|
|
* @param array selected_interfaces Selected interfaces.
|
|
|
|
* @param string sort_field Field used to sort table.
|
|
|
|
* @param string sort Direction used to sort by field.
|
|
|
|
* @param int pagination_index Active page (used for pagination).
|
|
|
|
* @param string sec Active section of page.
|
|
|
|
*/
|
|
|
|
function print_table(
|
|
|
|
$data,
|
|
|
|
$selected_agents,
|
|
|
|
$selected_interfaces,
|
|
|
|
$sort_field,
|
|
|
|
$sort,
|
|
|
|
$pagination_index,
|
|
|
|
$sec
|
|
|
|
) {
|
|
|
|
global $config;
|
|
|
|
|
|
|
|
$selected = true;
|
|
|
|
$select_if_name_up = false;
|
|
|
|
$select_if_name_down = false;
|
|
|
|
$select_if_speed_data_up = false;
|
|
|
|
$select_if_speed_data_down = false;
|
|
|
|
$select_if_in_octets_up = false;
|
|
|
|
$select_if_in_octets_down = false;
|
|
|
|
$select_if_out_octets_up = false;
|
|
|
|
$select_if_out_octets_down = false;
|
|
|
|
$select_if_usage_module_data_in_up = false;
|
|
|
|
$select_if_usage_module_data_in_down = false;
|
|
|
|
$select_if_usage_module_data_out_up = false;
|
|
|
|
$select_if_usage_module_data_out_down = false;
|
|
|
|
$select_if_last_data_up = false;
|
|
|
|
$select_if_last_data_down = false;
|
|
|
|
$order = null;
|
|
|
|
|
|
|
|
switch ($sort_field) {
|
|
|
|
case 'if_agent_name':
|
|
|
|
switch ($sort) {
|
|
|
|
case 'up':
|
|
|
|
$select_if_agent_name_up = $selected;
|
|
|
|
$order = [
|
|
|
|
'field' => 'if_agent_name',
|
|
|
|
'order' => 'ASC',
|
|
|
|
];
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'down':
|
|
|
|
default:
|
|
|
|
$select_if_agent_name_down = $selected;
|
|
|
|
$order = [
|
|
|
|
'field' => 'if_agent_name',
|
|
|
|
'order' => 'DESC',
|
|
|
|
];
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'if_name':
|
|
|
|
switch ($sort) {
|
|
|
|
case 'up':
|
|
|
|
$select_if_name_up = $selected;
|
|
|
|
$order = [
|
|
|
|
'field' => 'if_name',
|
|
|
|
'order' => 'ASC',
|
|
|
|
];
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'down':
|
|
|
|
default:
|
|
|
|
$select_if_name_down = $selected;
|
|
|
|
$order = [
|
|
|
|
'field' => 'if_name',
|
|
|
|
'order' => 'DESC',
|
|
|
|
];
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'if_speed_data':
|
|
|
|
switch ($sort) {
|
|
|
|
case 'up':
|
|
|
|
$select_if_speed_data_up = $selected;
|
|
|
|
$order = [
|
|
|
|
'field' => 'if_speed_data',
|
|
|
|
'order' => 'ASC',
|
|
|
|
];
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'down':
|
|
|
|
default:
|
|
|
|
$select_if_speed_data_down = $selected;
|
|
|
|
$order = [
|
|
|
|
'field' => 'if_speed_data',
|
|
|
|
'order' => 'DESC',
|
|
|
|
];
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'if_in_octets':
|
|
|
|
switch ($sort) {
|
|
|
|
case 'up':
|
|
|
|
$select_if_in_octets_up = $selected;
|
|
|
|
$order = [
|
|
|
|
'field' => 'if_in_octets',
|
|
|
|
'order' => 'ASC',
|
|
|
|
];
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'down':
|
|
|
|
default:
|
|
|
|
$select_if_in_octets_down = $selected;
|
|
|
|
$order = [
|
|
|
|
'field' => 'if_in_octets',
|
|
|
|
'order' => 'DESC',
|
|
|
|
];
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'if_out_octets':
|
|
|
|
switch ($sort) {
|
|
|
|
case 'up':
|
|
|
|
$select_if_out_octets_up = $selected;
|
|
|
|
$order = [
|
|
|
|
'field' => 'if_out_octets',
|
|
|
|
'order' => 'ASC',
|
|
|
|
];
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'down':
|
|
|
|
default:
|
|
|
|
$select_if_out_octets_down = $selected;
|
|
|
|
$order = [
|
|
|
|
'field' => 'if_out_octets',
|
|
|
|
'order' => 'DESC',
|
|
|
|
];
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'if_usage_module_data_in':
|
|
|
|
switch ($sort) {
|
|
|
|
case 'up':
|
|
|
|
$select_if_usage_module_data_in_up = $selected;
|
|
|
|
$order = [
|
|
|
|
'field' => 'if_usage_module_data_in',
|
|
|
|
'order' => 'ASC',
|
|
|
|
];
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'down':
|
|
|
|
default:
|
|
|
|
$select_if_usage_module_data_in_down = $selected;
|
|
|
|
$order = [
|
|
|
|
'field' => 'if_usage_module_data_in',
|
|
|
|
'order' => 'DESC',
|
|
|
|
];
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'if_usage_module_data_out':
|
|
|
|
switch ($sort) {
|
|
|
|
case 'up':
|
|
|
|
$select_if_usage_module_data_out_up = $selected;
|
|
|
|
$order = [
|
|
|
|
'field' => 'if_usage_module_data_out',
|
|
|
|
'order' => 'ASC',
|
|
|
|
];
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'down':
|
|
|
|
default:
|
|
|
|
$select_if_usage_module_data_out_down = $selected;
|
|
|
|
$order = [
|
|
|
|
'field' => 'if_usage_module_data_out',
|
|
|
|
'order' => 'DESC',
|
|
|
|
];
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'if_last_data':
|
|
|
|
switch ($sort) {
|
|
|
|
case 'up':
|
|
|
|
$select_if_last_data_up = $selected;
|
|
|
|
$order = [
|
|
|
|
'field' => 'if_last_data',
|
|
|
|
'order' => 'ASC',
|
|
|
|
];
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'down':
|
|
|
|
default:
|
|
|
|
$select_if_last_data_down = $selected;
|
|
|
|
$order = [
|
|
|
|
'field' => 'if_last_data',
|
|
|
|
'order' => 'DESC',
|
|
|
|
];
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
$select_if_agent_name = ($sec === 'view') ? true : false;
|
|
|
|
$select_if_name_up = ($sec === 'estado') ? true : false;
|
|
|
|
$select_if_name_down = false;
|
|
|
|
$select_if_speed_data_up = false;
|
|
|
|
$select_if_speed_data_down = false;
|
|
|
|
$select_if_in_octets_up = false;
|
|
|
|
$select_if_in_octets_down = false;
|
|
|
|
$select_if_out_octets_up = false;
|
|
|
|
$select_if_out_octets_down = false;
|
|
|
|
$select_if_usage_module_data_in_up = false;
|
|
|
|
$select_if_usage_module_data_in_down = false;
|
|
|
|
$select_if_usage_module_data_out_up = false;
|
|
|
|
$select_if_usage_module_data_out_down = false;
|
|
|
|
$select_if_last_data_up = false;
|
|
|
|
$select_if_last_data_down = false;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($sec === 'estado') {
|
|
|
|
$agent_id = (int) get_parameter('id_agente', 0);
|
|
|
|
|
|
|
|
$sort_url_page = 'ver_agente';
|
|
|
|
$sec = 'estado';
|
|
|
|
$query_params = '&id_agente='.$agent_id.'&tab=interface';
|
|
|
|
} else {
|
|
|
|
$sort_url_page = 'interface_view';
|
|
|
|
$sec = 'view';
|
|
|
|
$query_params = '';
|
|
|
|
}
|
|
|
|
|
|
|
|
// Build URLs to sort the table.
|
|
|
|
$url_if_agent_name = 'index.php?sec='.$sec.'&sec2=operation/agentes/'.$sort_url_page.$query_params;
|
|
|
|
$url_if_name = 'index.php?sec='.$sec.'&sec2=operation/agentes/'.$sort_url_page.$query_params;
|
|
|
|
$url_if_speed = 'index.php?sec='.$sec.'&sec2=operation/agentes/'.$sort_url_page.$query_params;
|
|
|
|
$url_if_in_octets = 'index.php?sec='.$sec.'&sec2=operation/agentes/'.$sort_url_page.$query_params;
|
|
|
|
$url_if_out_octets = 'index.php?sec='.$sec.'&sec2=operation/agentes/'.$sort_url_page.$query_params;
|
|
|
|
$url_if_bandwidth_usage_in = 'index.php?sec='.$sec.'&sec2=operation/agentes/'.$sort_url_page.$query_params;
|
|
|
|
$url_if_bandwidth_usage_out = 'index.php?sec='.$sec.'&sec2=operation/agentes/'.$sort_url_page.$query_params;
|
|
|
|
$last_data = 'index.php?sec='.$sec.'&sec2=operation/agentes/'.$sort_url_page.$query_params;
|
|
|
|
|
|
|
|
$selected_agents_query_str = '';
|
|
|
|
$selected_interfaces_query_str = '';
|
|
|
|
|
|
|
|
foreach ($selected_agents as $key => $agent) {
|
|
|
|
$selected_agents_query_str .= '&selected_agents['.$key.']='.$agent;
|
|
|
|
}
|
|
|
|
|
|
|
|
foreach ($selected_interfaces as $key => $interface) {
|
|
|
|
$selected_interfaces_query_str .= '&selected_interfaces['.$key.']='.$interface;
|
|
|
|
}
|
|
|
|
|
|
|
|
$url_if_agent_name .= $selected_agents_query_str.'&'.$selected_interfaces_query_str;
|
|
|
|
$url_if_name .= $selected_agents_query_str.'&'.$selected_interfaces_query_str;
|
|
|
|
$url_if_speed .= $selected_agents_query_str.'&'.$selected_interfaces_query_str;
|
|
|
|
$url_if_in_octets .= $selected_agents_query_str.'&'.$selected_interfaces_query_str;
|
|
|
|
$url_if_out_octets .= $selected_agents_query_str.'&'.$selected_interfaces_query_str;
|
|
|
|
$url_if_bandwidth_usage_in .= $selected_agents_query_str.'&'.$selected_interfaces_query_str;
|
|
|
|
$url_if_bandwidth_usage_out .= $selected_agents_query_str.'&'.$selected_interfaces_query_str;
|
|
|
|
$last_data .= $selected_agents_query_str.'&'.$selected_interfaces_query_str;
|
|
|
|
|
|
|
|
$url_if_agent_name .= '&recursion='.$recursion;
|
|
|
|
$url_if_name .= '&recursion='.$recursion;
|
|
|
|
$url_if_speed .= '&recursion='.$recursion;
|
|
|
|
$url_if_in_octets .= '&recursion='.$recursion;
|
|
|
|
$url_if_out_octets .= '&recursion='.$recursion;
|
|
|
|
$url_if_bandwidth_usage_in .= '&recursion='.$recursion;
|
|
|
|
$url_if_bandwidth_usage_out .= '&recursion='.$recursion;
|
|
|
|
$last_data .= '&recursion='.$recursion;
|
|
|
|
|
|
|
|
$url_if_agent_name .= '&sort_field=if_agent_name&sort=';
|
|
|
|
$url_if_name .= '&sort_field=if_name&sort=';
|
|
|
|
$url_if_speed .= '&sort_field=if_speed_data&sort=';
|
|
|
|
$url_if_in_octets .= '&sort_field=if_in_octets&sort=';
|
|
|
|
$url_if_out_octets .= '&sort_field=if_out_octets&sort=';
|
|
|
|
$url_if_bandwidth_usage_in .= '&sort_field=if_usage_module_data_in&sort=';
|
|
|
|
$url_if_bandwidth_usage_out .= '&sort_field=if_usage_module_data_out&sort=';
|
|
|
|
$last_data .= '&sort_field=if_last_data&sort=';
|
|
|
|
|
|
|
|
if (empty($data) === false) {
|
|
|
|
$table = new StdClass();
|
|
|
|
$table->cellpadding = 0;
|
|
|
|
$table->cellspacing = 0;
|
|
|
|
$table->width = '100%';
|
|
|
|
$table->class = 'info_table';
|
|
|
|
$table->head = [];
|
|
|
|
$table->data = [];
|
|
|
|
$table->size = [];
|
|
|
|
$table->align = [];
|
|
|
|
|
|
|
|
$show_fields = explode(',', $config['status_monitor_fields']);
|
|
|
|
|
|
|
|
if ($sec === 'view') {
|
|
|
|
$table->head[0] = __('Agent');
|
|
|
|
$table->head[0] .= ui_get_sorting_arrows(
|
|
|
|
$url_if_agent_name.'up',
|
|
|
|
$url_if_agent_name.'down',
|
|
|
|
$select_if_agent_name_up,
|
|
|
|
$select_if_agent_name_down
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
$table->head[1] = __('IfName');
|
|
|
|
$table->head[1] .= ui_get_sorting_arrows(
|
|
|
|
$url_if_name.'up',
|
|
|
|
$url_if_name.'down',
|
|
|
|
$select_if_name_up,
|
|
|
|
$select_if_name_down
|
|
|
|
);
|
|
|
|
|
|
|
|
$table->head[2] = __('Status');
|
|
|
|
|
|
|
|
$table->head[3] = __('IfSpeed');
|
|
|
|
$table->head[3] .= ui_get_sorting_arrows(
|
|
|
|
$url_if_speed.'up',
|
|
|
|
$url_if_speed.'down',
|
|
|
|
$select_if_speed_data_up,
|
|
|
|
$select_if_speed_data_down
|
|
|
|
);
|
|
|
|
|
|
|
|
$table->head[4] = __('IfInOctets');
|
|
|
|
$table->head[4] .= ui_get_sorting_arrows(
|
|
|
|
$url_if_in_octets.'up',
|
|
|
|
$url_if_in_octets.'down',
|
|
|
|
$select_if_in_octets_up,
|
|
|
|
$select_if_in_octets_down
|
|
|
|
);
|
|
|
|
|
|
|
|
$table->head[5] = __('IfOutOctets');
|
|
|
|
$table->head[5] .= ui_get_sorting_arrows(
|
|
|
|
$url_if_out_octets.'up',
|
|
|
|
$url_if_out_octets.'down',
|
|
|
|
$select_if_out_octets_up,
|
|
|
|
$select_if_out_octets_down
|
|
|
|
);
|
|
|
|
|
|
|
|
$table->head[6] = __('% Bandwidth usage (in)');
|
|
|
|
$table->head[6] .= ui_get_sorting_arrows(
|
|
|
|
$url_if_bandwidth_usage_in.'up',
|
|
|
|
$url_if_bandwidth_usage_in.'down',
|
|
|
|
$select_if_usage_module_data_in_up,
|
|
|
|
$select_if_usage_module_data_in_down
|
|
|
|
);
|
|
|
|
|
|
|
|
$table->head[7] = __('% Bandwidth usage (out)');
|
|
|
|
$table->head[7] .= ui_get_sorting_arrows(
|
|
|
|
$url_if_bandwidth_usage_out.'up',
|
|
|
|
$url_if_bandwidth_usage_out.'down',
|
|
|
|
$select_if_usage_module_data_out_up,
|
|
|
|
$select_if_usage_module_data_out_down
|
|
|
|
);
|
|
|
|
|
2023-01-30 17:01:06 +01:00
|
|
|
$table->head[8] = __('Graph');
|
|
|
|
|
|
|
|
$table->head[9] = __('Last data');
|
|
|
|
$table->head[9] .= ui_get_sorting_arrows(
|
2021-04-12 18:17:09 +02:00
|
|
|
$last_data.'up',
|
|
|
|
$last_data.'down',
|
|
|
|
$select_if_last_data_up,
|
|
|
|
$select_if_last_data_down
|
|
|
|
);
|
|
|
|
|
|
|
|
$loop_index = 0;
|
|
|
|
$table_data = [];
|
|
|
|
|
|
|
|
$interfaces_array = array_column($data, 'interfaces');
|
|
|
|
$agents = array_column($data, 'name');
|
|
|
|
|
|
|
|
$all_interfaces = [];
|
|
|
|
|
2022-04-05 13:00:15 +02:00
|
|
|
foreach ($data as $key => $value) {
|
|
|
|
if (empty($value['name']) === false) {
|
|
|
|
$agent_alias = $value['name'];
|
|
|
|
} else {
|
|
|
|
$agent_alias = agents_get_alias($key);
|
|
|
|
}
|
2021-04-12 18:17:09 +02:00
|
|
|
|
|
|
|
foreach ($value['interfaces'] as $if_name => $interface) {
|
2022-04-05 13:00:15 +02:00
|
|
|
$interface['agent_id'] = $key;
|
2021-04-12 18:17:09 +02:00
|
|
|
$interface['agent_alias'] = $agent_alias;
|
|
|
|
$interface['if_name'] = $if_name;
|
2022-04-05 13:00:15 +02:00
|
|
|
$all_interfaces[$key][$if_name] = $interface;
|
2021-04-12 18:17:09 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($sec === 'estado'
|
|
|
|
&& is_array($selected_interfaces) === true
|
|
|
|
&& empty($selected_interfaces) === true
|
|
|
|
) {
|
|
|
|
$filtered_interfaces = $all_interfaces;
|
|
|
|
} else {
|
2022-04-05 13:00:15 +02:00
|
|
|
foreach ($all_interfaces as $key => $value) {
|
|
|
|
// Filter interfaces array.
|
|
|
|
$filtered_interfaces[$key] = array_filter(
|
|
|
|
$value,
|
|
|
|
function ($interface) use ($selected_interfaces) {
|
|
|
|
return in_array(
|
|
|
|
$interface['status_module_id'],
|
|
|
|
$selected_interfaces
|
|
|
|
);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
}
|
2021-04-12 18:17:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
$data = [];
|
|
|
|
|
2022-04-05 13:00:15 +02:00
|
|
|
foreach ($filtered_interfaces as $interfaces) {
|
|
|
|
foreach ($interfaces as $if_name => $agent_interfaces) {
|
|
|
|
// Get usage modules.
|
|
|
|
$usage_module_in = db_get_row(
|
|
|
|
'tagente_modulo',
|
|
|
|
'nombre',
|
|
|
|
$if_name.'_inUsage'
|
|
|
|
);
|
|
|
|
$usage_module_out = db_get_row(
|
|
|
|
'tagente_modulo',
|
|
|
|
'nombre',
|
|
|
|
$if_name.'_outUsage'
|
|
|
|
);
|
|
|
|
|
|
|
|
$usage_module_id_in = $usage_module_in['id_agente_modulo'];
|
|
|
|
$usage_module_id_out = $usage_module_out['id_agente_modulo'];
|
|
|
|
$usage_module_description = $usage_module_in['descripcion'];
|
|
|
|
|
|
|
|
// Get usage modules data.
|
|
|
|
$usage_module_data_in = modules_get_previous_data(
|
|
|
|
$usage_module_id_in,
|
|
|
|
time()
|
|
|
|
);
|
|
|
|
|
|
|
|
$usage_module_data_out = modules_get_previous_data(
|
|
|
|
$usage_module_id_out,
|
|
|
|
time()
|
|
|
|
);
|
|
|
|
|
|
|
|
// Extract ifSpeed from description of usage module.
|
|
|
|
$if_speed_str = strstr($usage_module_description, 'Speed:');
|
|
|
|
$if_speed_str = substr($if_speed_str, 0, -1);
|
|
|
|
$if_speed_str = explode(':', $if_speed_str)[1];
|
|
|
|
|
|
|
|
$matches = [];
|
|
|
|
preg_match_all('/\d+/', $if_speed_str, $matches);
|
|
|
|
|
|
|
|
$if_speed_value = $matches[0][0];
|
|
|
|
|
|
|
|
// Transform ifSpeed unit.
|
|
|
|
$divisor = 1000;
|
|
|
|
$counter = 0;
|
|
|
|
while ($if_speed_value >= $divisor) {
|
|
|
|
if ($if_speed_value >= $divisor) {
|
|
|
|
$if_speed_value = ($if_speed_value / $divisor);
|
|
|
|
}
|
2021-04-12 18:17:09 +02:00
|
|
|
|
2022-04-05 13:00:15 +02:00
|
|
|
$counter++;
|
2021-04-12 18:17:09 +02:00
|
|
|
}
|
|
|
|
|
2022-04-05 13:00:15 +02:00
|
|
|
$if_speed_unit = 'bps';
|
2021-04-12 18:17:09 +02:00
|
|
|
|
2022-04-05 13:00:15 +02:00
|
|
|
switch ($counter) {
|
|
|
|
case 1:
|
|
|
|
$if_speed_unit = 'Kbps';
|
|
|
|
break;
|
2021-04-12 18:17:09 +02:00
|
|
|
|
2022-04-05 13:00:15 +02:00
|
|
|
case 2:
|
|
|
|
$if_speed_unit = 'Mbps';
|
|
|
|
break;
|
2021-04-12 18:17:09 +02:00
|
|
|
|
2022-04-05 13:00:15 +02:00
|
|
|
case 3:
|
|
|
|
$if_speed_unit = 'Gbps';
|
|
|
|
break;
|
2021-04-12 18:17:09 +02:00
|
|
|
|
2022-04-05 13:00:15 +02:00
|
|
|
case 4:
|
|
|
|
$if_speed_unit = 'Tbps';
|
|
|
|
break;
|
2021-04-12 18:17:09 +02:00
|
|
|
|
2022-04-05 13:00:15 +02:00
|
|
|
default:
|
|
|
|
$if_speed_unit = 'bps';
|
|
|
|
break;
|
|
|
|
}
|
2021-04-12 18:17:09 +02:00
|
|
|
|
2022-04-05 13:00:15 +02:00
|
|
|
// Get in and out traffic.
|
|
|
|
$ifInOctets = modules_get_previous_data(
|
|
|
|
$agent_interfaces['traffic']['in'],
|
|
|
|
time()
|
|
|
|
);
|
|
|
|
$ifOutOctets = modules_get_previous_data(
|
|
|
|
$agent_interfaces['traffic']['out'],
|
|
|
|
time()
|
|
|
|
);
|
|
|
|
|
|
|
|
if ($sec === 'view') {
|
|
|
|
$table_data[$loop_index]['if_agent_name'] = '<a href="index.php?sec=gagente&sec2=godmode/agentes/configurar_agente&tab=main&id_agente='.$agent_interfaces['agent_id'].'">'.$agent_interfaces['agent_alias'].'</a>';
|
|
|
|
}
|
2021-04-12 18:17:09 +02:00
|
|
|
|
2023-01-18 13:44:40 +01:00
|
|
|
$all_groups = agents_get_all_groups_agent($agent_interfaces['agent_id']);
|
|
|
|
$permission = check_acl_one_of_groups($config['id_user'], $all_groups, 'RR');
|
|
|
|
|
|
|
|
if ($permission) {
|
2023-01-30 17:01:06 +01:00
|
|
|
if ($agent_interfaces['traffic']['in'] > 0 && $agent_interfaces['traffic']['out'] > 0) {
|
|
|
|
$params = [
|
|
|
|
'interface_name' => $agent_interfaces['if_name'],
|
|
|
|
'agent_id' => $agent_interfaces['agent_id'],
|
|
|
|
'traffic_module_in' => $agent_interfaces['traffic']['in'],
|
|
|
|
'traffic_module_out' => $agent_interfaces['traffic']['out'],
|
|
|
|
];
|
|
|
|
$params_json = json_encode($params);
|
|
|
|
$params_encoded = base64_encode($params_json);
|
|
|
|
$win_handle = dechex(crc32($interface['status_module_id'].$agent_interfaces['if_name']));
|
|
|
|
$graph_link = "<a href=\"javascript:winopeng_var('operation/agentes/interface_traffic_graph_win.php?params=";
|
|
|
|
$graph_link .= $params_encoded."','";
|
|
|
|
$graph_link .= $win_handle."', 800, 480)\">";
|
|
|
|
$graph_link .= html_print_image(
|
2023-02-27 18:05:51 +01:00
|
|
|
'images/graph@svg.svg',
|
2023-01-30 17:01:06 +01:00
|
|
|
true,
|
|
|
|
[
|
|
|
|
'title' => __('Interface traffic'),
|
2023-02-27 18:05:51 +01:00
|
|
|
'class' => 'invert_filter main_menu_icon',
|
2023-01-30 17:01:06 +01:00
|
|
|
]
|
|
|
|
).'</a>';
|
|
|
|
} else {
|
2023-01-31 09:32:06 +01:00
|
|
|
$graph_link = html_print_image(
|
2023-02-27 18:05:51 +01:00
|
|
|
'images/graph@svg.svg',
|
2023-01-31 09:32:06 +01:00
|
|
|
true,
|
2023-02-27 18:05:51 +01:00
|
|
|
[
|
|
|
|
'title' => __('inOctets and outOctets must be enabled.'),
|
|
|
|
'class' => 'invert_filter main_menu_icon alpha50',
|
|
|
|
]
|
2023-01-31 09:32:06 +01:00
|
|
|
);
|
2023-01-30 17:01:06 +01:00
|
|
|
}
|
2023-01-18 13:44:40 +01:00
|
|
|
} else {
|
|
|
|
$graph_link = '';
|
|
|
|
}
|
|
|
|
|
2022-04-05 13:00:15 +02:00
|
|
|
$table_data[$loop_index]['if_name'] = $agent_interfaces['if_name'];
|
|
|
|
$table_data[$loop_index]['if_status_image'] = $agent_interfaces['status_image'];
|
|
|
|
$table_data[$loop_index]['if_speed_data'] = ($if_speed_value === null) ? __('N/A') : $if_speed_value.' '.$if_speed_unit;
|
|
|
|
$table_data[$loop_index]['if_in_octets'] = ($ifInOctets['datos'] === null) ? __('N/A') : $ifInOctets['datos'];
|
|
|
|
$table_data[$loop_index]['if_out_octets'] = ($ifOutOctets['datos'] === null) ? __('N/A') : $ifOutOctets['datos'];
|
|
|
|
$table_data[$loop_index]['if_usage_module_data_in'] = ($usage_module_data_in['datos'] === null) ? __('N/A') : $usage_module_data_in['datos'];
|
|
|
|
$table_data[$loop_index]['if_usage_module_data_out'] = ($usage_module_data_out['datos'] === null) ? __('N/A') : $usage_module_data_out['datos'];
|
2023-01-30 17:01:06 +01:00
|
|
|
$table_data[$loop_index]['if_graph'] = $graph_link;
|
2022-04-05 13:00:15 +02:00
|
|
|
$table_data[$loop_index]['if_last_data'] = human_time_comparation($agent_interfaces['last_contact']);
|
2021-04-12 18:17:09 +02:00
|
|
|
|
2022-04-05 13:00:15 +02:00
|
|
|
$loop_index++;
|
2021-04-12 18:17:09 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Sort array of previously processed table values.
|
|
|
|
if ($sort === 'up') {
|
|
|
|
$res = usort(
|
|
|
|
$table_data,
|
|
|
|
function ($a, $b) use ($sort_field) {
|
|
|
|
if ($a[$sort_field] > $b[$sort_field]) {
|
|
|
|
return 1;
|
|
|
|
} else {
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($sort === 'down') {
|
|
|
|
$res = usort(
|
|
|
|
$table_data,
|
|
|
|
function ($a, $b) use ($sort_field) {
|
|
|
|
if ($b[$sort_field] > $a[$sort_field]) {
|
|
|
|
return 1;
|
|
|
|
} else {
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
$sliced_table_data = array_slice(
|
|
|
|
$table_data,
|
|
|
|
$pagination_index,
|
|
|
|
$config['block_size']
|
|
|
|
);
|
|
|
|
|
|
|
|
foreach ($sliced_table_data as $value) {
|
|
|
|
array_push($table->data, array_values($value));
|
|
|
|
}
|
|
|
|
|
|
|
|
html_print_table($table);
|
|
|
|
} else {
|
|
|
|
ui_print_info_message(['no_close' => true, 'message' => __('No search parameters')]);
|
|
|
|
}
|
|
|
|
}
|