2012-01-20 14:14:09 +01:00
< ? php
2019-03-11 19:36:49 +01:00
/**
* Netflow live view
*
2022-05-06 14:23:24 +02:00
* @ category Netflow
* @ package Pandora FMS
* @ subpackage Community
* @ version 1.0 . 0
* @ license See below
2019-03-11 19:36:49 +01:00
*
2022-05-06 14:23:24 +02:00
* ______ ___ _______ _______ ________
* | __ \ .-----.--.--.--| |.-----.----.-----. | ___ | | | __ |
* | __ /| _ | | _ || _ | _ | _ | | ___ | | __ |
* | ___ | | ___ . _ | __ | __ | _____ || _____ | __ | | ___ . _ | | ___ | | __ | _ | __ | _______ |
*
* ============================================================================
2023-03-14 18:15:31 +01:00
* Copyright ( c ) 2005 - 2023 Artica Soluciones Tecnologicas
2019-03-11 19:36:49 +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
2022-05-06 14:23:24 +02:00
* as published by the Free Software Foundation for version 2.
2019-03-11 19:36:49 +01:00
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
2022-05-06 14:23:24 +02:00
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
2019-03-11 19:36:49 +01:00
* GNU General Public License for more details .
2022-05-06 14:23:24 +02:00
* ============================================================================
2019-03-11 19:36:49 +01:00
*/
2012-01-20 14:14:09 +01:00
global $config ;
2019-01-30 16:18:44 +01:00
require_once $config [ 'homedir' ] . '/include/functions_graph.php' ;
require_once $config [ 'homedir' ] . '/include/functions_ui.php' ;
require_once $config [ 'homedir' ] . '/include/functions_netflow.php' ;
2012-01-20 14:14:09 +01:00
2019-01-30 16:18:44 +01:00
ui_require_javascript_file ( 'calendar' );
2012-01-20 14:14:09 +01:00
2019-03-11 19:36:49 +01:00
// ACL.
2019-01-30 16:18:44 +01:00
check_login ();
if ( ! check_acl ( $config [ 'id_user' ], 0 , 'AR' ) && ! 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 ;
2012-01-20 14:14:09 +01:00
}
2012-11-29 11:30:46 +01:00
$pure = get_parameter ( 'pure' , 0 );
2019-03-11 19:36:49 +01:00
// Ajax callbacks.
2022-05-06 14:23:24 +02:00
if ( is_ajax () === true ) {
2019-01-30 16:18:44 +01:00
$get_filter_type = get_parameter ( 'get_filter_type' , 0 );
$get_filter_values = get_parameter ( 'get_filter_values' , 0 );
2019-03-11 19:36:49 +01:00
// Get filter of the current netflow filter.
2019-01-30 16:18:44 +01:00
if ( $get_filter_type ) {
$id = get_parameter ( 'id' );
$advanced_filter = db_get_value_filter ( 'advanced_filter' , 'tnetflow_filter' , [ 'id_sg' => $id ]);
if ( empty ( $advanced_filter )) {
$type = 0 ;
} else {
$type = 1 ;
}
echo $type ;
}
2019-03-11 19:36:49 +01:00
// Get values of the current netflow filter.
2019-01-30 16:18:44 +01:00
if ( $get_filter_values ) {
$id = get_parameter ( 'id' );
$filter_values = db_get_row_filter ( 'tnetflow_filter' , [ 'id_sg' => $id ]);
2019-03-11 19:36:49 +01:00
// Decode HTML entities.
2019-01-30 16:18:44 +01:00
$filter_values [ 'advanced_filter' ] = io_safe_output ( $filter_values [ 'advanced_filter' ]);
echo json_encode ( $filter_values );
}
return ;
2012-02-09 18:55:49 +01:00
}
2019-03-11 19:36:49 +01:00
// Read filter configuration.
2019-01-30 16:18:44 +01:00
$filter_id = ( int ) get_parameter ( 'filter_id' , 0 );
$filter [ 'id_name' ] = get_parameter ( 'name' , '' );
$filter [ 'id_group' ] = ( int ) get_parameter ( 'assign_group' , 0 );
$filter [ 'aggregate' ] = get_parameter ( 'aggregate' , '' );
$filter [ 'ip_dst' ] = get_parameter ( 'ip_dst' , '' );
$filter [ 'ip_src' ] = get_parameter ( 'ip_src' , '' );
$filter [ 'dst_port' ] = get_parameter ( 'dst_port' , '' );
$filter [ 'src_port' ] = get_parameter ( 'src_port' , '' );
$filter [ 'advanced_filter' ] = get_parameter ( 'advanced_filter' , '' );
2017-02-06 09:29:13 +01:00
$filter [ 'router_ip' ] = get_parameter ( 'router_ip' );
2012-01-20 14:14:09 +01:00
2019-03-11 19:36:49 +01:00
// Read chart configuration.
2013-02-14 14:37:33 +01:00
$chart_type = get_parameter ( 'chart_type' , 'netflow_area' );
2019-03-11 19:26:50 +01:00
$max_aggregates = ( int ) get_parameter ( 'max_aggregates' , 10 );
2012-01-20 14:14:09 +01:00
$update_date = ( int ) get_parameter ( 'update_date' , 0 );
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
$connection_name = get_parameter ( 'connection_name' , '' );
2019-03-13 18:55:16 +01:00
$interval_length = get_parameter ( 'interval_length' , NETFLOW_RES_MEDD );
2023-03-13 13:25:42 +01:00
$address_resolution = ( int ) get_parameter ( 'address_resolution' , ( $config [ 'netflow_get_ip_hostname' ] ? ? '' ));
2015-04-15 12:31:31 +02:00
$filter_selected = ( int ) get_parameter ( 'filter_selected' , 0 );
2012-01-20 14:14:09 +01:00
2019-03-15 10:46:18 +01:00
// Read time values.
$date = get_parameter_post ( 'date' , date ( DATE_FORMAT , get_system_time ()));
$time = get_parameter_post ( 'time' , date ( TIME_FORMAT , get_system_time ()));
$end_date = strtotime ( $date . ' ' . $time );
$is_period = ( bool ) get_parameter ( 'is_period' , false );
$period = ( int ) get_parameter ( 'period' , SECONDS_1DAY );
$time_lower = get_parameter ( 'time_lower' , date ( TIME_FORMAT , ( $end_date - $period )));
$date_lower = get_parameter ( 'date_lower' , date ( DATE_FORMAT , ( $end_date - $period )));
$start_date = ( $is_period ) ? ( $end_date - $period ) : strtotime ( $date_lower . ' ' . $time_lower );
if ( ! $is_period ) {
$period = ( $end_date - $start_date );
} else {
$time_lower = date ( TIME_FORMAT , $start_date );
$date_lower = date ( DATE_FORMAT , $start_date );
}
2019-03-11 19:36:49 +01:00
// Read buttons.
2012-01-20 14:14:09 +01:00
$draw = get_parameter ( 'draw_button' , '' );
2012-01-23 19:17:52 +01:00
$save = get_parameter ( 'save_button' , '' );
$update = get_parameter ( 'update_button' , '' );
2012-02-09 18:55:49 +01:00
2023-03-14 18:15:31 +01:00
// Header.
ui_print_standard_header (
__ ( 'Netflow live view' ),
'images/op_netflow.png' ,
false ,
'' ,
false ,
[],
[
2019-01-30 16:18:44 +01:00
[
2023-03-14 18:15:31 +01:00
'link' => '' ,
'label' => __ ( 'Monitoring' ),
2019-01-30 16:18:44 +01:00
],
[
2023-03-14 18:15:31 +01:00
'link' => '' ,
'label' => __ ( 'Network' ),
2019-01-30 16:18:44 +01:00
],
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' ));
} else {
netflow_print_check_version_error ();
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
}
2012-01-23 19:17:52 +01:00
2019-03-11 19:36:49 +01:00
// Save user defined filter.
2019-01-30 16:18:44 +01:00
if ( $save != '' && check_acl ( $config [ 'id_user' ], 0 , 'AW' )) {
2019-03-11 19:36:49 +01:00
// Save filter args.
2020-02-21 13:01:47 +01:00
$filter [ 'filter_args' ] = netflow_get_filter_arguments ( $filter , true );
2019-01-30 16:18:44 +01:00
$filter_id = db_process_sql_insert ( 'tnetflow_filter' , $filter );
if ( $filter_id === false ) {
$filter_id = 0 ;
ui_print_error_message ( __ ( 'Error creating filter' ));
} else {
ui_print_success_message ( __ ( 'Filter created successfully' ));
}
2019-03-11 19:36:49 +01:00
} else if ( $update != '' && check_acl ( $config [ 'id_user' ], 0 , 'AW' )) {
// Update current filter.
// Do not update the filter name and group.
2019-01-30 16:18:44 +01:00
$filter_copy = $filter ;
unset ( $filter_copy [ 'id_name' ]);
unset ( $filter_copy [ 'id_group' ]);
2019-03-11 19:36:49 +01:00
// Save filter args.
2020-02-21 13:01:47 +01:00
$filter_copy [ 'filter_args' ] = netflow_get_filter_arguments ( $filter_copy , true );
2019-01-30 16:18:44 +01:00
$result = db_process_sql_update (
'tnetflow_filter' ,
$filter_copy ,
[ 'id_sg' => $filter_id ]
);
ui_print_result_message (
$result ,
__ ( 'Filter updated successfully' ),
__ ( 'Error updating filter' )
);
}
2012-02-09 18:55:49 +01:00
2012-01-23 19:17:52 +01:00
2019-03-11 19:36:49 +01:00
// The filter name will not be needed anymore.
2012-01-23 19:17:52 +01:00
$filter [ 'id_name' ] = '' ;
2012-01-20 14:14:09 +01:00
2013-02-04 18:38:02 +01:00
$netflow_disable_custom_lvfilters = false ;
if ( isset ( $config [ 'netflow_disable_custom_lvfilters' ])) {
2019-01-30 16:18:44 +01:00
$netflow_disable_custom_lvfilters = $config [ 'netflow_disable_custom_lvfilters' ];
2013-02-04 18:38:02 +01:00
}
2023-03-13 13:25:42 +01:00
// Add nodes list.
if ( is_metaconsole () === true ) {
2019-01-30 16:18:44 +01:00
$list_servers = [];
$servers = db_get_all_rows_sql (
' SELECT *
FROM tmetaconsole_setup '
);
if ( $servers === false ) {
$servers = [];
}
foreach ( $servers as $server ) {
2019-03-11 19:36:49 +01:00
// If connection was good then retrieve all data server.
2019-01-30 16:18:44 +01:00
if ( metaconsole_load_external_db ( $server )) {
$connection = true ;
} else {
$connection = false ;
}
$row = db_get_row ( 'tconfig' , 'token' , 'activate_netflow' );
if ( $row [ 'value' ]) {
$list_servers [ $server [ 'server_name' ]] = $server [ 'server_name' ];
}
metaconsole_restore_db ();
}
2023-03-13 13:25:42 +01:00
$nodeListInput = html_print_label_input_block (
__ ( 'Connection' ),
html_print_select (
$list_servers ,
'connection_name' ,
$connection_name ,
'' ,
'' ,
0 ,
true ,
false ,
false
)
);
} else {
$nodeListInput = '' ;
}
$class_not_period = ( $is_period === true ) ? 'nf_hidden' : 'nf_display' ;
$class_period = ( $is_period === true ) ? 'nf_display' : 'nf_hidden' ;
$max_values = [
'2' => '2' ,
'5' => '5' ,
'10' => '10' ,
'15' => '15' ,
'20' => '20' ,
'25' => '25' ,
'50' => '50' ,
$max_aggregates => $max_aggregates ,
];
$aggregate_list = [];
$aggregate_list = [
'srcip' => __ ( 'Src Ip Address' ),
'dstip' => __ ( 'Dst Ip Address' ),
'srcport' => __ ( 'Src Port' ),
'dstport' => __ ( 'Dst Port' ),
];
$advanced_toggle = '<table style="width:100%">' ;
$advanced_toggle .= '<tr>' ;
if ( $netflow_disable_custom_lvfilters ) {
$advanced_toggle .= '<td></td>' ;
$advanced_toggle .= '<td></td>' ;
} else {
$advanced_toggle .= '<td><b>' . __ ( 'Filter' ) . '</b></td>' ;
$advanced_toggle .= '<td colspan="2">' . __ ( 'Normal' ) . ' ' . html_print_radio_button_extended ( 'filter_type' , 0 , '' , $filter_type , false , 'displayNormalFilter();' , 'style="margin-right: 40px;"' , true ) . __ ( 'Custom' ) . ' ' . html_print_radio_button_extended ( 'filter_type' , 1 , '' , $filter_type , false , 'displayAdvancedFilter();' , 'style="margin-right: 40px;"' , true ) . '</td>' ;
}
$advanced_toggle .= '<td><b>' . __ ( 'Load filter' ) . '</b></td>' ;
$user_groups = users_get_groups ( $config [ 'id_user' ], 'AR' , $own_info [ 'is_admin' ], true );
$user_groups [ 0 ] = 0 ;
// Add all groups.
$sql = ' SELECT *
FROM tnetflow_filter
WHERE id_group IN ( '.implode(' , ', array_keys($user_groups)).' ) ' ;
$advanced_toggle .= " <td colspan='3'> " . html_print_select_from_sql ( $sql , 'filter_id' , $filter_id , '' , __ ( 'Select a filter' ), 0 , true );
$advanced_toggle .= html_print_input_hidden ( 'filter_selected' , $filter_selected , false );
$advanced_toggle .= '</td>' ;
$advanced_toggle .= '</tr>' ;
$advanced_toggle .= " <tr class='filter_normal'> " ;
if ( $netflow_disable_custom_lvfilters ) {
$advanced_toggle .= '<td></td>' ;
$advanced_toggle .= '<td></td>' ;
} else {
$advanced_toggle .= " <td style='font-weight:bold;'> " . __ ( 'Dst Ip' ) . ui_print_help_tip ( __ ( 'Destination IP. A comma separated list of destination ip. If we leave the field blank, will show all ip. Example filter by ip:<br>25.46.157.214,160.253.135.249' ), true ) . '</td>' ;
$advanced_toggle .= '<td colspan="2">' . html_print_input_text ( 'ip_dst' , $filter [ 'ip_dst' ], false , 40 , 80 , true ) . '</td>' ;
}
if ( $netflow_disable_custom_lvfilters ) {
$advanced_toggle .= '<td></td>' ;
$advanced_toggle .= '<td></td>' ;
} else {
$advanced_toggle .= " <td style='font-weight:bold;'> " . __ ( 'Src Ip' ) . ui_print_help_tip ( __ ( 'Source IP. A comma separated list of source ip. If we leave the field blank, will show all ip. Example filter by ip:<br>25.46.157.214,160.253.135.249' ), true ) . '</td>' ;
$advanced_toggle .= '<td colspan="2">' . html_print_input_text ( 'ip_src' , $filter [ 'ip_src' ], false , 40 , 80 , true ) . '</td>' ;
}
$advanced_toggle .= '</tr>' ;
$advanced_toggle .= " <tr class='filter_normal'> " ;
if ( $netflow_disable_custom_lvfilters ) {
$advanced_toggle .= '<td></td>' ;
$advanced_toggle .= '<td></td>' ;
} else {
$advanced_toggle .= " <td style='font-weight:bold;'> " . __ ( 'Dst Port' ) . ui_print_help_tip ( __ ( 'Destination port. A comma separated list of destination ports. If we leave the field blank, will show all ports. Example filter by ports 80 and 22:<br>80,22' ), true ) . '</td>' ;
$advanced_toggle .= '<td colspan="2">' . html_print_input_text ( 'dst_port' , $filter [ 'dst_port' ], false , 40 , 80 , true ) . '</td>' ;
}
if ( $netflow_disable_custom_lvfilters ) {
$advanced_toggle .= '<td></td>' ;
$advanced_toggle .= '<td></td>' ;
} else {
$advanced_toggle .= " <td style='font-weight:bold;'> " . __ ( 'Src Port' ) . ui_print_help_tip ( __ ( 'Source port. A comma separated list of source ports. If we leave the field blank, will show all ports. Example filter by ports 80 and 22:<br>80,22' ), true ) . '</td>' ;
$advanced_toggle .= '<td colspan="2">' . html_print_input_text ( 'src_port' , $filter [ 'src_port' ], false , 40 , 80 , true ) . '</td>' ;
}
$advanced_toggle .= '</tr>' ;
$advanced_toggle .= " <tr class='filter_advance' style='display: none;'> " ;
if ( $netflow_disable_custom_lvfilters ) {
$advanced_toggle .= '<td></td>' ;
$advanced_toggle .= '<td></td>' ;
} else {
$advanced_toggle .= '<td>' . ui_print_help_icon ( 'pcap_filter' , true ) . '</td>' ;
$advanced_toggle .= " <td colspan='5'> " . html_print_textarea ( 'advanced_filter' , 4 , 40 , $filter [ 'advanced_filter' ], " style='min-height: 0px; width: 90%;' " , true ) . '</td>' ;
}
$advanced_toggle .= '</tr>' ;
$advanced_toggle .= '<tr>' ;
$onclick = " if (!confirm(' " . __ ( 'Warning' ) . '. ' . __ ( 'IP address resolution can take a lot of time' ) . " ')) return false; " ;
$radio_buttons = __ ( 'Yes' ) . ' ' . html_print_radio_button_extended (
'address_resolution' ,
1 ,
'' ,
$address_resolution ,
false ,
$onclick ,
'' ,
true
) . ' ' ;
$radio_buttons .= __ ( 'No' ) . ' ' . html_print_radio_button (
'address_resolution' ,
0 ,
'' ,
$address_resolution ,
true
);
$advanced_toggle .= '<td><b>' . __ ( 'IP address resolution' ) . '</b>' . ui_print_help_tip ( __ ( 'Resolve the IP addresses to get their hostnames.' ), true ) . '</td>' ;
$advanced_toggle .= '<td colspan="2">' . $radio_buttons . '</td>' ;
$advanced_toggle .= '<td><b>' . __ ( 'Source ip' ) . '</b></td>' ;
$advanced_toggle .= '<td colspan="2">' . html_print_input_text ( 'router_ip' , $filter [ 'router_ip' ], false , 40 , 80 , true ) . '</td>' ;
$advanced_toggle .= '</tr>' ;
$advanced_toggle .= '</table>' ;
// Read filter type.
if ( empty ( $filter [ 'advanced_filter' ]) === false ) {
$filter_type = 1 ;
} else {
$filter_type = 0 ;
}
$filterTable = new stdClass ();
$filterTable -> id = '' ;
2023-03-14 18:15:31 +01:00
$filterTable -> width = '100%' ;
2023-03-13 13:25:42 +01:00
$filterTable -> class = 'filter-table-adv' ;
$filterTable -> size = [];
$filterTable -> size [ 0 ] = '33%' ;
$filterTable -> size [ 1 ] = '33%' ;
$filterTable -> size [ 2 ] = '33%' ;
$filterTable -> data = [];
if ( empty ( $nodeListInput ) === false ) {
$filterTable -> data [ - 1 ][] = $nodeListInput ;
}
$filterTable -> data [ 0 ][ 0 ] = html_print_label_input_block (
__ ( 'Interval' ),
html_print_extended_select_for_time (
'period' ,
$period ,
2019-01-30 16:18:44 +01:00
'' ,
'' ,
0 ,
false ,
2023-03-13 13:25:42 +01:00
true
),
[ 'div_id' => 'period_container' ]
);
2013-06-10 10:53:42 +02:00
2023-03-13 13:25:42 +01:00
$filterTable -> data [ 0 ][ 0 ] .= html_print_label_input_block (
__ ( 'Start date' ),
html_print_div (
2019-03-15 10:46:18 +01:00
[
2023-03-13 13:25:42 +01:00
'class' => '' ,
'content' => html_print_input_text (
'date_lower' ,
$date_lower ,
false ,
13 ,
10 ,
true
) . html_print_image (
'images/calendar_view_day.png' ,
true ,
[
'alt' => 'calendar' ,
'class' => 'main_menu_icon invert_filter' ,
]
) . html_print_input_text (
'time_lower' ,
$time_lower ,
false ,
10 ,
8 ,
true
),
],
true
),
[ 'div_id' => 'end_date_container' ]
);
2019-03-18 15:33:48 +01:00
2023-03-13 13:25:42 +01:00
$filterTable -> data [ 0 ][ 1 ] = html_print_label_input_block (
__ ( 'End date' ),
html_print_div (
[
'class' => '' ,
'content' => html_print_input_text (
'date' ,
$date ,
false ,
13 ,
10 ,
true
) . html_print_image (
'images/calendar_view_day.png' ,
true ,
[ 'alt' => 'calendar' ]
) . html_print_input_text (
'time' ,
$time ,
false ,
10 ,
8 ,
true
),
],
true
)
);
2019-01-30 16:18:44 +01:00
2023-03-13 13:25:42 +01:00
$filterTable -> data [ 0 ][ 2 ] = html_print_label_input_block (
__ ( 'Resolution' ),
html_print_select (
2019-03-13 20:15:53 +01:00
netflow_resolution_select_params (),
2019-03-13 18:55:16 +01:00
'interval_length' ,
$interval_length ,
'' ,
'' ,
0 ,
true ,
false ,
false
2023-03-13 13:25:42 +01:00
) . ui_print_input_placeholder (
__ ( 'The interval will be divided in chunks the length of the resolution.' ),
true
)
);
2019-01-30 16:18:44 +01:00
2023-03-13 13:25:42 +01:00
$filterTable -> data [ 1 ][] = html_print_label_input_block (
__ ( 'Defined period' ),
html_print_checkbox_switch (
'is_period' ,
1 ,
( $is_period === true ) ? 1 : 0 ,
true ,
false ,
'nf_view_click_period(event)'
)
);
2019-01-30 16:18:44 +01:00
2023-03-13 13:25:42 +01:00
$filterTable -> data [ 1 ][] = html_print_label_input_block (
__ ( 'Type' ),
html_print_select (
2019-01-30 16:18:44 +01:00
netflow_get_chart_types (),
'chart_type' ,
$chart_type ,
'' ,
'' ,
0 ,
true
2023-03-13 13:25:42 +01:00
)
);
$filterTable -> data [ 1 ][] = html_print_label_input_block (
__ ( 'Aggregated by' ),
html_print_select (
$aggregate_list ,
'aggregate' ,
$filter [ 'aggregate' ],
2019-03-11 19:26:50 +01:00
'' ,
'' ,
0 ,
2023-03-13 13:25:42 +01:00
true ,
false ,
true ,
2019-03-11 19:26:50 +01:00
'' ,
2023-03-13 13:25:42 +01:00
false
)
);
2019-12-02 16:11:17 +01:00
2023-03-13 13:25:42 +01:00
$filterTable -> data [ 2 ][] = html_print_label_input_block (
__ ( 'Max values' ),
html_print_div (
[
'class' => '' ,
'content' => html_print_select (
$max_values ,
'max_aggregates' ,
$max_aggregates ,
'' ,
'' ,
0 ,
true
) . html_print_anchor (
[
'id' => 'max_values' ,
'href' => '#' ,
'onClick' => 'edit_max_value()' ,
'content' => html_print_image (
'images/edit.svg' ,
true ,
[
'id' => 'pencil' ,
'class' => 'main_menu_icon invert_filter' ,
]
),
],
true
),
],
true
)
);
2019-01-30 16:18:44 +01:00
2023-03-13 13:25:42 +01:00
$filterTable -> colspan [ 3 ][ 0 ] = 3 ;
$filterTable -> data [ 3 ][ 0 ] = html_print_label_input_block (
'' ,
ui_toggle (
2019-12-02 16:11:17 +01:00
$advanced_toggle ,
__ ( 'Advanced' ),
'' ,
'' ,
true ,
true ,
2023-03-13 13:25:42 +01:00
'' ,
'white-box-content' ,
'box-flat white_table_graph'
)
);
$buttons = html_print_submit_button (
__ ( 'Draw' ),
'draw_button' ,
false ,
[
'icon' => 'cog' ,
'mode' => 'mini' ,
],
true
);
if ( ! $netflow_disable_custom_lvfilters ) {
if (( bool ) check_acl ( $config [ 'id_user' ], 0 , 'AW' ) === true ) {
$buttons .= html_print_submit_button ( __ ( 'Save as new filter' ), 'save_button' , false , [ 'icon' => 'load' , 'onClick' => 'return defineFilterName();' , 'mode' => 'mini secondary' ], true );
$buttons .= html_print_submit_button ( __ ( 'Update current filter' ), 'update_button' , false , [ 'icon' => 'load' , 'mode' => 'mini secondary' ], true );
2019-01-30 16:18:44 +01:00
}
2023-03-13 13:25:42 +01:00
}
2019-01-30 16:18:44 +01:00
2023-03-13 13:25:42 +01:00
$filterInputTable = '<form method="post" action="' . $config [ 'homeurl' ] . 'index.php?sec=netf&sec2=operation/netflow/nf_live_view&pure=' . $pure . '">' ;
$filterInputTable .= html_print_table ( $filterTable , true );
$filterInputTable .= html_print_div (
[
'class' => 'action-buttons' ,
'content' => $buttons ,
],
true
);
$filterInputTable .= '</form>' ;
ui_toggle (
$filterInputTable ,
'<span class="subsection_header_title">' . __ ( 'Filter' ) . '</span>' ,
__ ( 'Filter' ),
'search' ,
true ,
false ,
'' ,
'white-box-content no_border' ,
'box-flat white_table_graph fixed_filter_bar'
);
if ( empty ( $draw ) === false ) {
// No filter selected.
if ( $netflow_disable_custom_lvfilters && $filter_selected == 0 ) {
ui_print_error_message ( __ ( 'No filter selected' ));
} else {
// Hidden input for handle properly the text colors.
html_print_input_hidden (
'selected_style_theme' ,
$config [ 'style' ]
);
// Draw the netflow chart.
html_print_div (
[
'class' => 'white_box' ,
'content' => netflow_draw_item (
$start_date ,
$end_date ,
$interval_length ,
$chart_type ,
$filter ,
$max_aggregates ,
$connection_name ,
'HTML' ,
$address_resolution
),
]
);
2019-01-30 16:18:44 +01:00
}
2023-03-13 14:03:00 +01:00
} else {
ui_print_info_message ( __ ( 'No data to show' ));
2023-03-13 13:25:42 +01:00
}
2019-01-30 16:18:44 +01:00
2023-03-13 13:25:42 +01:00
ui_include_time_picker ();
?>
2012-01-20 14:14:09 +01:00
2023-03-13 14:03:00 +01:00
< style >
. parent_graph {
margin : 0 auto ! important ;
}
</ style >
2012-01-20 14:14:09 +01:00
< script type = " text/javascript " >
2019-01-30 16:18:44 +01:00
function edit_max_value () {
if ( $ ( " #max_values img " ) . attr ( " id " ) == " pencil " ) {
2023-03-09 23:31:40 +01:00
$ ( " #max_values img " ) . attr ( " src " , " images/logs@svg.svg " );
2019-01-30 16:18:44 +01:00
$ ( " #max_values img " ) . attr ( " id " , " select " );
var value = $ ( " #max_aggregates " ) . val ();
$ ( " #max_aggregates " ) . replaceWith ( " <input id='max_aggregates' name='max_aggregates' type='text'> " );
$ ( " #max_aggregates " ) . val ( value );
}
else {
2023-03-09 23:31:40 +01:00
$ ( " #max_values img " ) . attr ( " src " , " images/edit.svg " );
2019-01-30 16:18:44 +01:00
$ ( " #max_values img " ) . attr ( " id " , " pencil " );
$ ( " #max_aggregates " ) . replaceWith ( " <select id='max_aggregates' name='max_aggregates'> " );
var o = new Option ( " 2 " , 2 );
var o1 = new Option ( " 5 " , 5 );
var o2 = new Option ( " 10 " , 10 );
var o3 = new Option ( " 15 " , 15 );
var o4 = new Option ( " 20 " , 20 );
var o5 = new Option ( " 25 " , 25 );
var o6 = new Option ( " 50 " , 50 );
$ ( " #max_aggregates " ) . append ( o );
$ ( " #max_aggregates " ) . append ( o1 );
$ ( " #max_aggregates " ) . append ( o2 );
$ ( " #max_aggregates " ) . append ( o3 );
$ ( " #max_aggregates " ) . append ( o4 );
$ ( " #max_aggregates " ) . append ( o5 );
$ ( " #max_aggregates " ) . append ( o6 );
}
}
// Hide the normal filter and display the advanced filter
function displayAdvancedFilter () {
// Erase the normal filter
$ ( " #text-ip_dst " ) . val ( '' );
$ ( " #text-ip_src " ) . val ( '' );
$ ( " #text-dst_port " ) . val ( '' );
$ ( " #text-src_port " ) . val ( '' );
// Hide the normal filter
$ ( " .filter_normal " ) . hide ();
// Show the advanced filter
$ ( " .filter_advance " ) . show ();
};
// Hide the advanced filter and display the normal filter
function displayNormalFilter () {
// Erase the advanced filter
$ ( " #textarea_advanced_filter " ) . val ( '' );
// Hide the advanced filter
$ ( " .filter_advance " ) . hide ();
// Show the normal filter
$ ( " .filter_normal " ) . show ();
};
// Ask the user to define a name for the filter in order to save it
function defineFilterName () {
if ( $ ( " #text-name " ) . val () == '' ) {
$ ( " .filter_save " ) . show ();
return false ;
}
return true ;
};
2019-03-11 19:26:50 +01:00
2019-01-30 16:18:44 +01:00
// Display the appropriate filter
var filter_type = < ? php echo $filter_type ; ?> ;
if ( filter_type == 0 ) {
displayNormalFilter ();
}
else {
displayAdvancedFilter ();
}
$ ( " #filter_id " ) . change ( function () {
var filter_type ;
// Hide information and name/group row
$ ( " .filter_save " ) . hide ();
// Clean fields
if ( $ ( " #filter_id " ) . val () == 0 ) {
displayNormalFilter ();
// Check right filter type
$ ( " #radiobtn0001 " ) . attr ( " checked " , " checked " );
$ ( " #hidden-filter_selected " ) . val ( 0 );
$ ( " #text-ip_dst " ) . val ( '' );
$ ( " #text-ip_src " ) . val ( '' );
$ ( " #text-dst_port " ) . val ( '' );
$ ( " #text-src_port " ) . val ( '' );
$ ( " #text-router_ip " ) . val ( '' );
$ ( " #textarea_advanced_filter " ) . val ( '' );
$ ( " #aggregate " ) . val ( '' );
// Hide update filter button
$ ( " #submit-update_button " ) . hide ();
}
else {
// Load fields from DB
$ ( " #hidden-filter_selected " ) . val ( 1 );
// Get filter type
< ? php
if ( ! defined ( 'METACONSOLE' )) {
echo 'jQuery.post ("ajax.php",' ;
} else {
echo 'jQuery.post ("' . $config [ 'homeurl' ] . '../../ajax.php",' ;
}
?>
{ " page " : " operation/netflow/nf_live_view " ,
" get_filter_type " : 1 ,
" id " : $ ( " #filter_id " ) . val ()
},
function ( data ) {
filter_type = data ;
// Display the appropriate filter
if ( filter_type == 0 ) {
$ ( " .filter_normal " ) . show ();
$ ( " .filter_advance " ) . hide ();
// Check right filter type
$ ( " #radiobtn0001 " ) . attr ( " checked " , " checked " );
}
else {
$ ( " .filter_normal " ) . hide ();
$ ( " .filter_advance " ) . show ();
// Check right filter type
$ ( " #radiobtn0002 " ) . attr ( " checked " , " checked " );
}
2021-06-28 12:03:25 +02:00
}
2019-01-30 16:18:44 +01:00
// Get filter values from DB
< ? php
2021-06-28 12:03:25 +02:00
echo ');' ;
if ( is_metaconsole () === false ) {
2019-01-30 16:18:44 +01:00
echo 'jQuery.post ("ajax.php",' ;
} else {
echo 'jQuery.post ("' . $config [ 'homeurl' ] . '../../ajax.php",' ;
}
?>
{ " page " : " operation/netflow/nf_live_view " ,
" get_filter_values " : 1 ,
" id " : $ ( " #filter_id " ) . val ()
},
function ( data ) {
jQuery . each ( data , function ( i , val ) {
if ( i == 'ip_dst' )
$ ( " #text-ip_dst " ) . val ( val );
if ( i == 'ip_src' )
$ ( " #text-ip_src " ) . val ( val );
if ( i == 'dst_port' )
$ ( " #text-dst_port " ) . val ( val );
if ( i == 'src_port' )
$ ( " #text-src_port " ) . val ( val );
if ( i == 'router_ip' )
$ ( " #text-router_ip " ) . val ( val );
if ( i == 'advanced_filter' )
$ ( " #textarea_advanced_filter " ) . val ( val );
if ( i == 'aggregate' )
$ ( " #aggregate " ) . val ( val );
});
2021-06-28 12:03:25 +02:00
}
< ? php echo ', "json");' ; ?>
2019-01-30 16:18:44 +01:00
// Shows update filter button
$ ( " #submit-update_button " ) . show ();
}
});
$ ( document ) . ready ( function () {
2023-03-13 13:25:42 +01:00
// Update visibility of controls.
nf_view_click_period ();
2019-01-30 16:18:44 +01:00
// Hide update filter button
if ( $ ( " #filter_id " ) . val () == 0 ) {
$ ( " #submit-update_button " ) . hide ();
}
else {
$ ( " #submit-update_button " ) . show ();
}
// Change color of name and group if save button has been pushed
$ ( " #submit-save_button " ) . click ( function () {
if ( $ ( " #text-name " ) . val () == " " ) {
$ ( '#filter_name_color' ) . css ( 'color' , '#CC0000' );
$ ( '#filter_group_color' ) . css ( 'color' , '#CC0000' );
}
else {
$ ( '#filter_name_color' ) . css ( 'color' , '#000000' );
$ ( '#filter_group_color' ) . css ( 'color' , '#000000' );
}
});
});
2019-03-15 10:46:18 +01:00
$ ( " #text-time, #text-time_lower " ) . timepicker ({
2019-01-30 16:18:44 +01:00
showSecond : true ,
timeFormat : '<?php echo TIME_FORMAT_JS; ?>' ,
timeOnlyTitle : '<?php echo __(' Choose time '); ?>' ,
timeText : '<?php echo __(' Time '); ?>' ,
hourText : '<?php echo __(' Hour '); ?>' ,
minuteText : '<?php echo __(' Minute '); ?>' ,
secondText : '<?php echo __(' Second '); ?>' ,
currentText : '<?php echo __(' Now '); ?>' ,
closeText : '<?php echo __(' Close '); ?>' });
2019-03-15 10:46:18 +01:00
$ ( " #text-date, #text-date_lower " ) . datepicker ({ dateFormat : " <?php echo DATE_FORMAT_JS; ?> " });
2019-01-30 16:18:44 +01:00
$ . datepicker . regional [ " <?php echo get_user_language(); ?> " ];
2019-03-15 10:46:18 +01:00
2023-03-13 13:25:42 +01:00
function nf_view_click_period () {
var is_period = document . getElementById ( 'checkbox-is_period' ) . checked ;
document . getElementById ( 'period_container' ) . style . display = ! is_period ? 'none' : 'flex' ;
document . getElementById ( 'end_date_container' ) . style . display = is_period ? 'none' : 'flex' ;
2019-03-15 10:46:18 +01:00
}
2012-10-08 21:19:58 +02:00
</ script >