2022-11-14 17:43:35 +01:00
< ? php
// phpcs:disable Squiz.NamingConventions.ValidVariableName.MemberNotCamelCaps
/**
* Controller for SNMP console
*
* @ category Controller
* @ package Pandora FMS
* @ subpackage Community
* @ version 1.0 . 0
* @ license See below
*
* ______ ___ _______ _______ ________
2023-06-08 12:42:10 +02:00
* | __ \ .-----.--.--.--| |.-----.----.-----. | ___ | | | __ |
* | __ /| _ | | _ || _ | _ | _ | | ___ | | __ |
2022-11-14 17:43:35 +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
2022-11-14 17:43:35 +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 .
* ============================================================================
*/
use function Composer\Autoload\includeFile ;
// Begin.
global $config ;
// Necessary classes for extends.
require_once $config [ 'homedir' ] . '/include/class/HTML.class.php' ;
/**
* Class SatelliteAgent
*/
class SnmpConsole extends HTML
{
/**
* Allowed methods to be called using AJAX request .
*
* @ var array
*/
public $AJAXMethods = [
'draw' ,
'loadModal' ,
'deleteTrap' ,
'deleteTraps' ,
'validateTrap' ,
'validateTraps' ,
2022-12-19 11:51:43 +01:00
'showInfo' ,
2022-11-14 17:43:35 +01:00
];
/**
* Ajax page .
*
* @ var string
*/
private $ajaxController ;
2022-12-20 10:03:45 +01:00
/**
* Filter alert .
*
* @ var integer
*/
private $filter_alert ;
/**
* Filter severity .
*
* @ var integer
*/
private $filter_severity ;
/**
* Filter search .
*
* @ var string
*/
private $filter_free_search ;
/**
* Filter status .
*
* @ var integer
*/
private $filter_status ;
/**
* Filter group by .
*
* @ var integer
*/
private $filter_group_by ;
/**
* Filter hours .
*
* @ var integer
*/
private $filter_hours_ago ;
/**
* Filter trap type .
*
* @ var integer
*/
private $filter_trap_type ;
/**
* Refresh .
*
* @ var integer
*/
private $refr ;
2022-11-14 17:43:35 +01:00
/**
* Class constructor
*
* @ param string $ajaxController Ajax controller .
*/
2022-12-20 10:03:45 +01:00
public function __construct (
string $ajaxController ,
int $filter_alert ,
int $filter_severity ,
string $filter_free_search ,
int $filter_status ,
int $filter_group_by ,
int $filter_hours_ago ,
int $filter_trap_type ,
int $refr
) {
2022-11-14 17:43:35 +01:00
global $config ;
check_login ();
$agent_a = check_acl ( $config [ 'id_user' ], 0 , 'AR' );
$agent_w = check_acl ( $config [ 'id_user' ], 0 , 'AW' );
if ( $agent_a === false && $agent_w === false ) {
db_pandora_audit (
AUDIT_LOG_ACL_VIOLATION ,
'Trying to access SNMP Console'
);
include 'general/noaccess.php' ;
exit ;
}
// Set the ajax controller.
$this -> ajaxController = $ajaxController ;
2022-12-20 10:03:45 +01:00
$this -> filter_alert = $filter_alert ;
$this -> filter_severity = $filter_severity ;
$this -> filter_free_search = $filter_free_search ;
$this -> filter_status = $filter_status ;
$this -> filter_group_by = $filter_group_by ;
$this -> filter_hours_ago = $filter_hours_ago ;
$this -> filter_trap_type = $filter_trap_type ;
$this -> refr = $refr ;
2022-11-14 17:43:35 +01:00
}
/**
* Run view
*
* @ return void
*/
public function run ()
{
global $config ;
// Javascript.
ui_require_jquery_file ( 'pandora' );
// CSS.
ui_require_css_file ( 'wizard' );
ui_require_css_file ( 'discovery' );
2022-12-20 10:03:45 +01:00
$default_refr = 300 ;
2023-03-13 10:29:03 +01:00
$statistics [ 'text' ] = '<a href="index.php?sec=estado&sec2=operation/snmpconsole/snmp_statistics&pure=' . $config [ 'pure' ] . '">' . html_print_image (
'images/logs@svg.svg' ,
true ,
[
'title' => __ ( 'Statistics' ),
'class' => 'main_menu_icon invert_filter' ,
]
) . '</a>' ;
$list [ 'text' ] = '<a href="index.php?sec=snmpconsole&sec2=operation/snmpconsole/snmp_view&pure=0">' . html_print_image (
'images/SNMP-network-numeric-data@svg.svg' ,
true ,
[
'title' => __ ( 'List' ),
'class' => 'main_menu_icon invert_filter' ,
]
) . '</a>' ;
$list [ 'active' ] = true ;
// Header.
ui_print_standard_header (
__ ( 'SNMP Console' ),
'images/op_snmp.png' ,
false ,
'snmp_console' ,
false ,
[
$screen ,
$list ,
$statistics ,
],
[
2022-12-19 16:30:41 +01:00
[
2023-03-13 10:29:03 +01:00
'link' => '' ,
'label' => __ ( 'Monitoring' ),
2022-11-14 17:43:35 +01:00
],
2022-12-19 16:30:41 +01:00
[
2023-03-13 10:29:03 +01:00
'link' => '' ,
'label' => __ ( 'SNMP' ),
],
]
);
2022-11-14 17:43:35 +01:00
// Datatables list.
try {
$checkbox_all = html_print_checkbox (
'all_validate_box' ,
1 ,
false ,
true
);
$columns = [
'status' ,
[
'text' => 'snmp_agent' ,
2023-06-15 11:25:47 +02:00
'class' => 'snmp-td datos_green' ,
2022-11-14 17:43:35 +01:00
],
[
'text' => 'enterprise_string' ,
2023-06-15 11:25:47 +02:00
'class' => 'snmp-td datos_green' ,
2022-11-14 17:43:35 +01:00
],
[
'text' => 'count' ,
2023-06-15 11:25:47 +02:00
'class' => 'snmp-td datos_green' ,
2022-11-14 17:43:35 +01:00
],
[
'text' => 'trap_subtype' ,
2023-06-15 11:25:47 +02:00
'class' => 'snmp-td datos_green' ,
2022-11-14 17:43:35 +01:00
],
[
'text' => 'user_id' ,
2023-06-15 11:25:47 +02:00
'class' => 'snmp-td datos_green' ,
2022-11-14 17:43:35 +01:00
],
[
'text' => 'timestamp' ,
2023-06-15 11:25:47 +02:00
'class' => 'snmp-td datos_green' ,
2022-11-14 17:43:35 +01:00
],
'alert' ,
2023-03-15 13:53:23 +01:00
[
'text' => 'action' ,
'class' => 'table_action_buttons w120px' ,
],
2022-11-14 17:43:35 +01:00
[
'text' => 'm' ,
'class' => 'mw60px pdd_0px' ,
],
];
$column_names = [
__ ( 'Status' ),
__ ( 'SNMP Agent' ),
__ ( 'Enterprise String' ),
__ ( 'Count' ),
__ ( 'Trap subtype' ),
__ ( 'User ID' ),
__ ( 'Timestamp' ),
__ ( 'Alert' ),
__ ( 'Actions' ),
[
'text' => 'm' ,
'extra' => $checkbox_all ,
'class' => 'w20px no-text-imp' ,
],
];
$show_alerts = [
- 1 => __ ( 'All' ),
0 => __ ( 'Not triggered' ),
1 => __ ( 'Triggered' ),
];
$severities = get_priorities ();
$severities [ - 1 ] = __ ( 'All' );
$paginations = [
$config [ 'block_size' ] => __ ( 'Default' ),
25 => '25' ,
50 => '50' ,
100 => '100' ,
200 => '200' ,
500 => '500' ,
];
$status_array = [
- 1 => __ ( 'All' ),
0 => __ ( 'Not validated' ),
1 => __ ( 'Validated' ),
];
$trap_types = [
- 1 => __ ( 'None' ),
0 => __ ( 'Cold start (0)' ),
1 => __ ( 'Warm start (1)' ),
2 => __ ( 'Link down (2)' ),
3 => __ ( 'Link up (3)' ),
4 => __ ( 'Authentication failure (4)' ),
5 => __ ( 'Other' ),
];
2023-02-23 10:24:03 +01:00
$tableId = 'snmp_console' ;
2022-11-14 17:43:35 +01:00
// Load datatables user interface.
ui_print_datatable (
[
2023-02-23 10:24:03 +01:00
'id' => $tableId ,
2022-11-14 17:43:35 +01:00
'class' => 'info_table' ,
2023-05-08 14:25:57 +02:00
'style' => 'width: 100%' ,
2022-11-14 17:43:35 +01:00
'columns' => $columns ,
'column_names' => $column_names ,
'ajax_url' => $this -> ajaxController ,
'ajax_data' => [ 'method' => 'draw' ],
'ajax_postprocces' => 'process_datatables_item(item)' ,
'search_button_class' => 'sub filter float-right' ,
'no_sortable_columns' => [
0 ,
2022-12-19 16:30:41 +01:00
1 ,
2 ,
3 ,
4 ,
5 ,
6 ,
2022-11-14 17:43:35 +01:00
7 ,
8 ,
9 ,
],
'form' => [
'class' => 'flex-row' ,
'inputs' => [
[
2023-02-02 11:18:47 +01:00
'label' => __ ( 'Alert' ),
'type' => 'select' ,
'id' => 'filter_alert' ,
'input_class' => 'filter_input_datatable' ,
'name' => 'filter_alert' ,
'fields' => $show_alerts ,
'return' => true ,
'selected' => $this -> filter_alert ,
2023-02-24 12:00:02 +01:00
'style' => 'widht:100% !important' ,
2022-11-14 17:43:35 +01:00
],
[
2023-02-02 11:18:47 +01:00
'label' => __ ( 'Severity' ),
'type' => 'select' ,
'id' => 'filter_severity' ,
'input_class' => 'filter_input_datatable' ,
'name' => 'filter_severity' ,
'fields' => $severities ,
'return' => true ,
'selected' => $this -> filter_severity ,
2023-02-24 12:00:02 +01:00
'style' => 'widht:100%' ,
2022-11-14 17:43:35 +01:00
],
[
2023-02-02 11:18:47 +01:00
'label' => __ ( 'Free search' ),
'type' => 'text' ,
'id' => 'filter_free_search' ,
'input_class' => 'filter_input_datatable' ,
'name' => 'filter_free_search' ,
'value' => $this -> filter_free_search ,
2022-11-14 17:43:35 +01:00
],
[
2023-02-02 11:18:47 +01:00
'label' => __ ( 'Status' ),
'type' => 'select' ,
'id' => 'filter_status' ,
'input_class' => 'filter_input_datatable' ,
'name' => 'filter_status' ,
'fields' => $status_array ,
'return' => true ,
'selected' => $this -> filter_status ,
2023-02-24 12:00:02 +01:00
'style' => 'widht:100%' ,
2022-11-14 17:43:35 +01:00
],
[
2023-02-02 11:18:47 +01:00
'label' => __ ( 'Group by Enterprise String/IP' ),
'type' => 'select' ,
'name' => 'filter_group_by' ,
'selected' => $this -> filter_group_by ,
'disabled' => false ,
'return' => true ,
'id' => 'filter_group_by' ,
'input_class' => 'filter_input_datatable' ,
'fields' => [
2022-11-14 17:43:35 +01:00
0 => __ ( 'No' ),
1 => __ ( 'Yes' ),
],
],
[
2023-02-02 11:18:47 +01:00
'label' => __ ( 'Max. hours old' ),
'type' => 'text' ,
'id' => 'filter_hours_ago' ,
'input_class' => 'filter_input_datatable' ,
'name' => 'filter_hours_ago' ,
'value' => $this -> filter_hours_ago ,
2022-11-14 17:43:35 +01:00
],
[
2023-02-02 11:18:47 +01:00
'label' => __ ( 'Trap type' ),
'type' => 'select' ,
'id' => 'filter_trap_type' ,
'input_class' => 'filter_input_datatable' ,
'name' => 'filter_trap_type' ,
'fields' => $trap_types ,
'return' => true ,
'selected' => $this -> filter_trap_type ,
2022-11-14 17:43:35 +01:00
],
],
],
2023-02-24 12:00:02 +01:00
'pagination_options' => [
[
$config [ 'block_size' ],
5 ,
10 ,
25 ,
100 ,
200 ,
500 ,
1000 ,
],
[
$config [ 'block_size' ],
5 ,
10 ,
25 ,
100 ,
200 ,
500 ,
1000 ,
],
],
'filter_main_class' => 'box-flat white_table_graph fixed_filter_bar' ,
2022-11-14 17:43:35 +01:00
]
);
} catch ( Exception $e ) {
echo $e -> getMessage ();
}
2023-02-23 10:24:03 +01:00
$buttons [] = html_print_submit_button (
__ ( 'Validate' ),
'updatebt' ,
false ,
2023-02-24 13:21:00 +01:00
[
'class' => 'sub ok' ,
'icon' => 'next' ,
],
2023-02-23 10:24:03 +01:00
true
);
$buttons [] = html_print_submit_button (
2022-12-19 11:51:43 +01:00
__ ( 'Delete' ),
'deletebt' ,
false ,
2023-02-24 13:21:00 +01:00
[
'icon' => 'delete' ,
'mode' => 'secondary' ,
2023-02-27 16:33:54 +01:00
'onClick' => " javascript:return confirm(' " . __ ( 'Are you sure?' ) . " ') " ,
2023-02-24 13:21:00 +01:00
],
2023-02-23 10:24:03 +01:00
true
2022-12-19 11:51:43 +01:00
);
2022-11-14 17:43:35 +01:00
2023-02-23 10:24:03 +01:00
html_print_action_buttons (
implode ( '' , $buttons ),
[ 'type' => 'form_action' ]
2022-12-19 11:51:43 +01:00
);
2022-11-14 17:43:35 +01:00
2023-02-27 16:33:54 +01:00
$legend = '<table id="legend_snmp_browser"class="w100p"><td><div class="snmp_view_div w100p legend_white">' ;
$legend .= '<h3 style="position: relative;left: 50%;">' . __ ( 'Severity' ) . '</h3>' ;
$legend .= '<div class="display-flex"><div class="flex-50">' ;
2023-02-27 12:13:38 +01:00
$priorities = get_priorities ();
$half = ( count ( $priorities ) / 2 );
$count = 0 ;
foreach ( $priorities as $num => $name ) {
if ( $count == $half ) {
2023-02-27 16:33:54 +01:00
$legend .= '</div><div class="mrgn_lft_5px flex-50">' ;
2023-02-27 12:13:38 +01:00
}
2023-02-27 16:33:54 +01:00
$legend .= '<span class="' . get_priority_class ( $num ) . '">' . $name . '</span>' ;
$legend .= '<br />' ;
2023-02-27 12:13:38 +01:00
$count ++ ;
2022-11-14 17:43:35 +01:00
}
2023-02-27 16:33:54 +01:00
$legend .= '</div></div></div></td>' ;
$legend .= '<td><div class="snmp_view_div">' ;
$legend .= '<h3>' . __ ( 'Status' ) . '</h3>' ;
$legend .= '<span class="datos_green">' . __ ( 'Validated' ) . '</span>' ;
$legend .= '<br />' ;
$legend .= '<span class="datos_red">' . __ ( 'Not validated' ) . '</span>' ;
$legend .= '</div></td>' ;
$legend .= '<td><div class="snmp_view_div">' ;
$legend .= '<h3>' . __ ( 'Alert' ) . '</h3>' ;
$legend .= '<span class="datos_yellow">' . __ ( 'Alert' ) . '</span>' ;
$legend .= '<br />' ;
$legend .= '<span class="datos_grey">' . __ ( 'Not fired' ) . '</span>' ;
$legend .= '</div></td>' ;
$legend .= '<td><div class="snmp_view_div">' ;
$legend .= '<h3>' . __ ( 'Action' ) . '</h3>' ;
$legend .= '<div style=" display : flex;align-items : center;">' ;
$legend .= html_print_image ( 'images/validate.svg' , true , [ 'class' => 'main_menu_icon invert_filter' ]) . ' - ' . __ ( 'Validate' );
$legend .= '</div>' ;
$legend .= '<br />' ;
$legend .= '<div style=" display : flex;align-items : center;">' ;
$legend .= html_print_image ( 'images/delete.svg' , true , [ 'class' => 'main_menu_icon invert_filter' ]) . ' - ' . __ ( 'Delete' );
$legend .= '</div>' ;
$legend .= '</div></div></td>' ;
2023-06-20 08:24:31 +02:00
echo '<br>' ;
2023-02-27 16:33:54 +01:00
ui_toggle ( $legend , __ ( 'Legend' ));
2022-11-14 17:43:35 +01:00
// Load own javascript file.
echo $this -> loadJS ();
}
/**
* Get the data for draw the table .
*
* @ return void .
*/
public function draw ()
{
global $config ;
// Init data.
$data = [];
// Count of total records.
$count = 0 ;
// Catch post parameters.
$start = get_parameter ( 'start' , 0 );
$length = get_parameter ( 'length' , $config [ 'block_size' ]);
2022-12-22 16:32:17 +01:00
// There is a limit of (2^32)^2 (18446744073709551615) rows in a MyISAM table, show for show all use max nrows.
$length = ( $length != '-1' ) ? $length : '18446744073709551615' ;
2022-11-14 17:43:35 +01:00
$order = get_datatable_order ( true );
$filters = get_parameter ( 'filter' , []);
2023-07-18 10:40:33 +02:00
// Build ranges.
$now_timestamp = time ();
$interval_seconds = ( $filters [ 'filter_hours_ago' ] * 3600 );
$ago_timestamp = ( $now_timestamp - $interval_seconds );
2022-11-14 17:43:35 +01:00
// Build ranges.
$now = new DateTime ();
$ago = new DateTime ();
$interval = new DateInterval ( sprintf ( 'PT%dH' , $filters [ 'filter_hours_ago' ]));
$ago -> sub ( $interval );
$date_from_trap = $ago -> format ( 'Y/m/d' );
$date_to_trap = $now -> format ( 'Y/m/d' );
$time_from_trap = $ago -> format ( 'H:i:s' );
$time_to_trap = $now -> format ( 'H:i:s' );
try {
ob_start ();
$data = [];
$user_groups = users_get_groups ( $config [ 'id_user' ], 'AR' , false );
$prea = array_keys ( $user_groups );
$ids = join ( ',' , $prea );
$user_in_group_wo_agents = db_get_value_sql ( 'select count(DISTINCT(id_usuario)) from tusuario_perfil where id_usuario ="' . $config [ 'id_user' ] . '" and id_perfil = 1 and id_grupo in (select id_grupo from tgrupo where id_grupo in (' . $ids . ') and id_grupo not in (select id_grupo from tagente))' );
if ( $user_in_group_wo_agents == 0 ) {
$rows = db_get_all_rows_filter (
'tagente' ,
[ 'id_grupo' => array_keys ( $user_groups )],
[ 'id_agente' ]
);
$id_agents = [];
foreach ( $rows as $row ) {
$id_agents [] = $row [ 'id_agente' ];
}
if ( ! empty ( $id_agents )) {
$address_by_user_groups = agents_get_addresses ( $id_agents );
foreach ( $address_by_user_groups as $i => $a ) {
$address_by_user_groups [ $i ] = '"' . $a . '"' ;
}
}
} else {
$rows = db_get_all_rows_filter (
'tagente' ,
[],
[ 'id_agente' ]
);
$id_agents = [];
foreach ( $rows as $row ) {
$id_agents [] = $row [ 'id_agente' ];
}
$all_address_agents = agents_get_addresses ( $id_agents );
foreach ( $all_address_agents as $i => $a ) {
$all_address_agents [ $i ] = '"' . $a . '"' ;
}
}
if ( empty ( $address_by_user_groups )) {
$address_by_user_groups = [];
array_unshift ( $address_by_user_groups , '""' );
}
if ( empty ( $all_address_agents )) {
$all_address_agents = [];
array_unshift ( $all_address_agents , '""' );
}
$sql = ' SELECT * FROM ttrap
WHERE (
`source` IN ( '.implode(' , ' , $address_by_user_groups ) . " ) OR
`source` = '' OR
`source` NOT IN ( " .implode(',', $all_address_agents ).')
)
% s
ORDER BY timestamp DESC
LIMIT % d , % d ' ;
$whereSubquery = '' ;
if ( $filters [ 'filter_alert' ] != - 1 ) {
$whereSubquery .= ' AND alerted = ' . $filters [ 'filter_alert' ];
}
if ( $filters [ 'filter_severity' ] != - 1 ) {
// There are two special severity values aimed to match two different trap standard severities
// in database: warning/critical and critical/normal.
if ( $filters [ 'filter_severity' ] != EVENT_CRIT_OR_NORMAL
&& $filters [ 'filter_severity' ] != EVENT_CRIT_WARNING_OR_CRITICAL
) {
// Test if enterprise is installed to search oid in text or oid field in ttrap.
if ( $config [ 'enterprise_installed' ]) {
$whereSubquery .= ' AND (
( alerted = 0 AND severity = '.$filters[' filter_severity '].' ) OR
( alerted = 1 AND priority = '.$filters[' filter_severity '].' )) ' ;
} else {
$whereSubquery .= ' AND (
( alerted = 0 AND 1 = '.$filters[' filter_severity '].' ) OR
( alerted = 1 AND priority = '.$filters[' filter_severity '].' )) ' ;
}
} else if ( $filters [ 'filter_severity' ] === EVENT_CRIT_WARNING_OR_CRITICAL ) {
// Test if enterprise is installed to search oid in text or oid field in ttrap.
if ( $config [ 'enterprise_installed' ]) {
$whereSubquery .= ' AND (
( alerted = 0 AND ( severity = '.EVENT_CRIT_WARNING.' OR severity = '.EVENT_CRIT_CRITICAL.' )) OR
( alerted = 1 AND ( priority = '.EVENT_CRIT_WARNING.' OR priority = '.EVENT_CRIT_CRITICAL.' ))) ' ;
} else {
$whereSubquery .= ' AND (
( alerted = 1 AND ( priority = '.EVENT_CRIT_WARNING.' OR priority = '.EVENT_CRIT_CRITICAL.' ))) ' ;
}
} else if ( $filters [ 'filter_severity' ] === EVENT_CRIT_OR_NORMAL ) {
// Test if enterprise is installed to search oid in text or oid field in ttrap.
if ( $config [ 'enterprise_installed' ]) {
$whereSubquery .= ' AND (
( alerted = 0 AND ( severity = '.EVENT_CRIT_NORMAL.' OR severity = '.EVENT_CRIT_CRITICAL.' )) OR
( alerted = 1 AND ( priority = '.EVENT_CRIT_NORMAL.' OR priority = '.EVENT_CRIT_CRITICAL.' ))) ' ;
} else {
$whereSubquery .= ' AND (
( alerted = 1 AND ( priority = '.EVENT_CRIT_NORMAL.' OR priority = '.EVENT_CRIT_CRITICAL.' ))) ' ;
}
}
}
2022-12-19 11:51:43 +01:00
if ( $filters [ 'filter_free_search' ] !== '' ) {
2023-04-11 13:48:08 +02:00
$free_search_str = io_safe_output ( $filters [ 'filter_free_search' ]);
2022-12-19 11:51:43 +01:00
$whereSubquery .= '
2023-04-11 13:48:08 +02:00
AND ( source LIKE " %'. $free_search_str .'% " OR
oid LIKE " %'. $free_search_str .'% " OR
oid_custom LIKE " %'. $free_search_str .'% " OR
type_custom LIKE " %'. $free_search_str .'% " OR
value LIKE " %'. $free_search_str .'% " OR
value_custom LIKE " %'. $free_search_str .'% " OR
id_usuario LIKE " %'. $free_search_str .'% " OR
text LIKE " %'. $free_search_str .'% " OR
description LIKE " %'. $free_search_str .'% " ) ' ;
2022-12-19 11:51:43 +01:00
}
2022-11-14 17:43:35 +01:00
if ( $filters [ 'filter_status' ] != - 1 ) {
$whereSubquery .= ' AND status = ' . $filters [ 'filter_status' ];
}
if ( $date_from_trap != '' ) {
if ( $time_from_trap != '' ) {
$whereSubquery .= '
2023-07-18 10:40:33 +02:00
AND ( utimestamp > '.$ago_timestamp.' )
2022-11-14 17:43:35 +01:00
' ;
} else {
$whereSubquery .= '
AND ( UNIX_TIMESTAMP ( timestamp ) > UNIX_TIMESTAMP ( " '. $date_from_trap .' 23:59:59 " ))
' ;
}
}
if ( $date_to_trap != '' ) {
if ( $time_to_trap ) {
$whereSubquery .= '
2023-07-18 10:40:33 +02:00
AND ( utimestamp < '.$now_timestamp.' )
2022-11-14 17:43:35 +01:00
' ;
} else {
$whereSubquery .= '
AND ( UNIX_TIMESTAMP ( timestamp ) < UNIX_TIMESTAMP ( " '. $date_to_trap .' 23:59:59 " ))
' ;
}
}
if ( $filters [ 'filter_trap_type' ] == 5 ) {
$whereSubquery .= ' AND type NOT IN (0, 1, 2, 3, 4)' ;
} else if ( $filters [ 'filter_trap_type' ] != - 1 ) {
$whereSubquery .= ' AND type = ' . $filters [ 'filter_trap_type' ];
}
if ( $filters [ 'filter_group_by' ]) {
$where_without_group = $whereSubquery ;
$whereSubquery .= ' GROUP BY source,oid' ;
}
$sql = sprintf ( $sql , $whereSubquery , $start , $length );
2023-04-20 19:15:32 +02:00
2022-11-14 17:43:35 +01:00
$sql_count = ' SELECT COUNT ( id_trap ) FROM ttrap
WHERE (
source IN ( '.implode(' , ' , $address_by_user_groups ) . " ) OR
source = '' OR
source NOT IN ( " .implode(',', $all_address_agents ).')
)
% s ' ;
$sql_count = sprintf ( $sql_count , $whereSubquery );
$traps = db_get_all_rows_sql ( $sql , true );
2023-10-31 09:16:42 +01:00
$total = ( int ) db_get_value_sql ( $sql_count , false , false );
2022-11-14 17:43:35 +01:00
if ( empty ( $traps ) === false ) {
$data = $traps ;
$data = array_reduce (
$data ,
function ( $carry , $item ) use ( $filters , $where_without_group ) {
global $config ;
2022-12-19 11:51:43 +01:00
if ( empty ( $carry ) === true ) {
$count = 0 ;
} else {
$count = count ( $carry );
}
2022-11-14 17:43:35 +01:00
// Transforms array of arrays $data into an array
// of objects, making a post-process of certain fields.
$tmp = ( object ) $item ;
$severity_class = get_priority_class ( $tmp -> severity );
$status = $tmp -> status ;
// Status.
if ( $status == 0 ) {
$tmp -> status = html_print_image (
'images/pixel_red.png' ,
true ,
[
'title' => __ ( 'Not validated' ),
'width' => '20' ,
'height' => '20' ,
]
);
} else {
$tmp -> status = html_print_image (
'images/pixel_green.png' ,
true ,
[
'title' => __ ( 'Validated' ),
'width' => '20' ,
'height' => '20' ,
]
);
}
// SNMP Agent.
$agent = agents_get_agent_with_ip ( $tmp -> source );
if ( $agent === false ) {
$tmp -> snmp_agent .= '<a href="index.php?sec=estado&sec2=godmode/agentes/configurar_agente&new_agent=1&direccion=' . $tmp -> source . '" title="' . __ ( 'Create agent' ) . '">' . $tmp -> source . '</a>' ;
} else {
$tmp -> snmp_agent .= '<div class="' . $severity_class . ' snmp-div"><a href="index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente=' . $agent [ 'id_agente' ] . '" title="' . __ ( 'View agent details' ) . '">' ;
2023-03-07 17:24:36 +01:00
$tmp -> snmp_agent .= '<strong>' . $agent [ 'alias' ] . ui_print_help_tip ( $tmp -> source , true );
2022-11-14 17:43:35 +01:00
'</strong></a></div>' ;
}
// Enterprise string.
if ( empty ( $tmp -> text ) === false ) {
$enterprise_string = $tmp -> text ;
} else if ( empty ( $tmp -> oid ) === false ) {
$enterprise_string = $tmp -> oid ;
} else {
$enterprise_string = __ ( 'N/A' );
}
2022-12-19 11:51:43 +01:00
$tmp -> enterprise_string = '<div class="' . $severity_class . ' snmp-div"><a href="javascript: toggleVisibleExtendedInfo(' . $tmp -> id_trap . ',' . $count . ');">' . $enterprise_string . '</a></div>' ;
2022-11-14 17:43:35 +01:00
// Count.
if ( $filters [ 'filter_group_by' ]) {
2022-12-19 11:51:43 +01:00
$sql = ' SELECT count ( * ) FROM ttrap WHERE 1 = 1
'.$where_without_group.'
AND oid = " '. $tmp->oid .' "
AND source = " '. $tmp->source .' " ' ;
2022-11-14 17:43:35 +01:00
$group_traps = db_get_value_sql ( $sql );
$tmp -> count = '<div class="' . $severity_class . ' snmp-div">' . $group_traps . '</div>' ;
}
// Trap subtype.
$tmp -> trap_subtype = '<div class="' . $severity_class . ' snmp-div">' ;
if ( empty ( $tmp -> value ) === true ) {
$tmp -> trap_subtype .= __ ( 'N/A' );
} else {
$tmp -> trap_subtype .= ui_print_truncate_text ( $tmp -> value , GENERIC_SIZE_TEXT , false );
}
$tmp -> trap_subtype .= '</div>' ;
// User ID.
$tmp -> user_id = '<div class="' . $severity_class . ' snmp-div">' ;
if ( empty ( $status ) === false ) {
$tmp -> user_id .= '<a href="index.php?sec=workspace&sec2=operation/users/user_edit&ver=' . $tmp -> id_usuario . '">' . substr ( $tmp -> id_usuario , 0 , 8 ) . '</a>' ;
if ( ! empty ( $tmp -> id_usuario )) {
$tmp -> user_id .= ui_print_help_tip ( get_user_fullname ( $tmp -> id_usuario ), true );
}
} else {
$tmp -> user_id .= '--' ;
}
$tmp -> user_id .= '</div>' ;
// Timestamp.
$timestamp = $tmp -> timestamp ;
$tmp -> timestamp = '<div class="' . $severity_class . ' snmp-div">' ;
$tmp -> timestamp .= '<span title="' . $timestamp . '">' ;
$tmp -> timestamp .= ui_print_timestamp ( $timestamp , true );
$tmp -> timestamp .= '</span></div>' ;
// Use alert severity if fired.
if ( empty ( $tmp -> alerted ) === false ) {
$tmp -> alert = html_print_image ( 'images/pixel_yellow.png' , true , [ 'width' => '20' , 'height' => '20' , 'border' => '0' , 'title' => __ ( 'Alert fired' )]);
} else {
$tmp -> alert = html_print_image ( 'images/pixel_gray.png' , true , [ 'width' => '20' , 'height' => '20' , 'border' => '0' , 'title' => __ ( 'Alert not fired' )]);
}
// Actions.
$tmp -> action = '' ;
if ( $status != 1 ) {
$tmp -> action .= '<a href="#">' . html_print_image (
2023-02-24 13:21:00 +01:00
'images/validate.svg' ,
2022-11-14 17:43:35 +01:00
true ,
[
'border' => '0' ,
'title' => __ ( 'Validate' ),
'onclick' => 'validate_trap(\'' . $tmp -> id_trap . '\')' ,
2023-02-27 10:31:50 +01:00
'class' => 'invert_filter main_menu_icon' ,
2022-11-14 17:43:35 +01:00
]
) . '</a> ' ;
}
2022-12-19 11:51:43 +01:00
if ( $tmp -> source === '' ) {
if ( \users_is_admin ()) {
2022-11-14 17:43:35 +01:00
$tmp -> action .= '<a href="#">' . html_print_image (
2023-02-24 13:21:00 +01:00
'images/delete.svg' ,
2022-11-14 17:43:35 +01:00
true ,
[
'border' => '0' ,
'title' => __ ( 'Delete' ),
2023-02-24 13:21:00 +01:00
'class' => 'invert_filter main_menu_icon' ,
2022-11-14 17:43:35 +01:00
'onclick' => 'delete_trap(\'' . $tmp -> id_trap . '\')' ,
]
) . '</a> ' ;
}
} else {
$tmp -> action .= '<a href="#">' . html_print_image (
2023-02-24 13:21:00 +01:00
'images/delete.svg' ,
2022-11-14 17:43:35 +01:00
true ,
[
'border' => '0' ,
'title' => __ ( 'Delete' ),
2023-02-24 13:21:00 +01:00
'class' => 'invert_filter main_menu_icon' ,
2022-11-14 17:43:35 +01:00
'onclick' => 'delete_trap(\'' . $tmp -> id_trap . '\')' ,
]
) . '</a> ' ;
}
2023-03-09 08:37:58 +01:00
$tmp -> action .= '<a id="eye_' . $tmp -> id_trap . ' " data-show= " show "
href = " javascript: toggleVisibleExtendedInfo('. $tmp->id_trap .','. $count .'); " > ' . html_print_image (
2023-02-24 13:21:00 +01:00
'images/see-details@svg.svg' ,
2022-11-14 17:43:35 +01:00
true ,
[
2023-02-09 14:45:10 +01:00
'id' => 'img_' . $tmp -> id_trap ,
2022-11-14 17:43:35 +01:00
'alt' => __ ( 'Show more' ),
'title' => __ ( 'Show more' ),
2023-02-24 13:21:00 +01:00
'class' => 'invert_filter main_menu_icon' ,
2022-11-14 17:43:35 +01:00
]
2023-02-09 14:45:10 +01:00
) . ' ' . html_print_image (
2023-03-09 08:37:58 +01:00
'images/disable.svg' ,
2023-02-09 14:45:10 +01:00
true ,
[
'id' => 'img_hide_' . $tmp -> id_trap ,
'alt' => __ ( 'Hide details' ),
'title' => __ ( 'Hide details' ),
2023-03-09 08:37:58 +01:00
'class' => 'invert_filter main_menu_icon' ,
2023-02-09 14:45:10 +01:00
'style' => 'display:none' ,
]
2022-11-14 17:43:35 +01:00
) . '</a>' ;
2023-02-01 10:27:11 +01:00
if ( $config [ 'enterprise_installed' ]) {
2023-04-20 19:15:32 +02:00
$tmp -> action .= '<a href="index.php?sec=snmpconsole&sec2=enterprise/godmode/snmpconsole/snmp_trap_editor_form&id=' . $tmp -> id_trap . '&oid=' . $tmp -> oid . '&custom_oid=' . urlencode ( $tmp -> oid_custom ) . '&severity=' . $tmp -> severity . '&text=' . io_safe_input ( $tmp -> text ) . '&description=' . io_safe_input ( $tmp -> description , ENT_QUOTES ) . '" title="' . io_safe_input ( $tmp -> description , ENT_QUOTES ) . '">' ;
2023-03-06 08:09:29 +01:00
$tmp -> action .= html_print_image (
'images/edit.svg' ,
true ,
[
'alt' => __ ( 'SNMP trap editor' ),
'title' => __ ( 'SNMP trap editor' ),
'class' => 'main_menu_icon invert_filter' ,
]
);
$tmp -> action .= '</a>' ;
2023-02-01 10:27:11 +01:00
}
2022-11-14 17:43:35 +01:00
$tmp -> m = html_print_checkbox_extended ( 'snmptrapid[]' , $tmp -> id_trap , false , false , '' , 'class="chk"' , true );
$carry [] = $tmp ;
return $carry ;
},
);
}
if ( empty ( $data ) === true ) {
$total = 0 ;
$data = [];
}
echo json_encode (
[
'data' => $data ,
'recordsTotal' => $total ,
'recordsFiltered' => $total ,
]
);
// Capture output.
$response = ob_get_clean ();
} catch ( Exception $e ) {
echo json_encode ([ 'error' => $e -> getMessage ()]);
exit ;
}
// If not valid, show error with issue.
json_decode ( $response );
if ( json_last_error () === JSON_ERROR_NONE ) {
// If valid dump.
echo $response ;
} else {
echo json_encode (
[ 'error' => $response ]
);
}
exit ;
}
/**
* Checks if target method is available to be called using AJAX .
*
* @ param string $method Target method .
*
* @ return boolean True allowed , false not .
*/
public function ajaxMethod ( string $method )
{
return in_array ( $method , $this -> AJAXMethods );
}
/**
* Delete snmp trap .
*
* @ return void
*/
public function deleteTrap ()
{
$id_trap = get_parameter ( 'id' , 0 );
$group_by = ( bool ) get_parameter ( 'group_by' , 0 );
if ( $id_trap > 0 ) {
if ( $group_by === true ) {
$sql_ids_traps = 'SELECT id_trap, source FROM ttrap WHERE oid IN (SELECT oid FROM ttrap WHERE id_trap = ' . $id_trap . ' )
AND source IN ( SELECT source FROM ttrap WHERE id_trap = '.$id_trap.' ) ' ;
$ids_traps = db_get_all_rows_sql ( $sql_ids_traps );
foreach ( $ids_traps as $key => $value ) {
$result = db_process_sql_delete ( 'ttrap' , [ 'id_trap' => $value [ 'id_trap' ]]);
enterprise_hook ( 'snmp_update_forwarded_modules' , [ $value ]);
}
} else {
$forward_info = db_get_row ( 'ttrap' , 'id_trap' , $id_trap );
$result = db_process_sql_delete ( 'ttrap' , [ 'id_trap' => $id_trap ]);
enterprise_hook ( 'snmp_update_forwarded_modules' , [ $forward_info ]);
}
}
}
/**
* Delete snmp traps .
*
* @ return void
*/
public function deleteTraps ()
{
$ids = get_parameter ( 'ids' , []);
$group_by = ( bool ) get_parameter ( 'group_by' , false );
if ( empty ( $ids ) === false ) {
$string_ids = implode ( ',' , $ids );
if ( $group_by === true ) {
$sql_ids_traps = 'SELECT id_trap, source FROM ttrap WHERE oid IN (SELECT oid FROM ttrap WHERE id_trap IN (' . $string_ids . ' ))
AND source IN ( SELECT source FROM ttrap WHERE id_trap IN ( '.$string_ids.' )) ' ;
$ids_traps = db_get_all_rows_sql ( $sql_ids_traps );
$array = array_column ( $ids_traps , 'id_trap' );
$delete = sprintf (
'DELETE FROM `ttrap` WHERE id_trap IN (%s)' ,
implode ( ',' , $array ),
);
db_process_sql ( $delete );
foreach ( $ids_traps as $key => $value ) {
enterprise_hook ( 'snmp_update_forwarded_modules' , [ $value ]);
}
} else {
$delete = sprintf (
'DELETE FROM `ttrap` WHERE id_trap IN (%s)' ,
$string_ids ,
);
db_process_sql ( $delete );
foreach ( $ids as $id_trap ) {
enterprise_hook ( 'snmp_update_forwarded_modules' , [ $id_trap ]);
}
}
}
}
/**
* Validate snmp trap .
*
* @ return void
*/
public function validateTrap ()
{
global $config ;
$id_trap = get_parameter ( 'id' , 0 );
$values = [
'status' => 1 ,
'id_usuario' => $config [ 'id_user' ],
];
$result = db_process_sql_update ( 'ttrap' , $values , [ 'id_trap' => $id_trap ]);
enterprise_hook ( 'snmp_update_forwarded_modules' , [ $id_trap ]);
}
/**
* Validate snmp traps .
*
* @ return void
*/
public function validateTraps ()
{
global $config ;
$ids = get_parameter ( 'ids' , []);
if ( empty ( $ids ) === false ) {
$update = sprintf (
'UPDATE ttrap SET `status` = 1, `id_usuario` = "%s" WHERE id_trap IN (%s)' ,
$config [ 'id_user' ],
implode ( ',' , $ids )
);
db_process_sql ( $update );
foreach ( $ids as $id_trap ) {
enterprise_hook ( 'snmp_update_forwarded_modules' , [ $id_trap ]);
}
}
}
2022-12-19 11:51:43 +01:00
/**
* VShow info trap .
*
* @ return void
*/
public function showInfo ()
{
global $config ;
$id_trap = get_parameter ( 'id' , 0 );
2022-12-19 16:30:41 +01:00
$group_by = get_parameter ( 'group_by' , 0 );
2022-12-20 10:03:45 +01:00
$alert = get_parameter ( 'alert' , - 1 );
$severity = get_parameter ( 'severity' , - 1 );
$search = get_parameter ( 'search' , '' );
$status = get_parameter ( 'status' , 0 );
$hours_ago = get_parameter ( 'hours_ago' , 8 );
$trap_type = get_parameter ( 'trap_type' , - 1 );
2022-12-19 16:30:41 +01:00
$trap = db_get_row ( 'ttrap' , 'id_trap' , $id_trap );
if ( $group_by ) {
2022-12-20 10:03:45 +01:00
$now = new DateTime ();
$ago = new DateTime ();
$interval = new DateInterval ( sprintf ( 'PT%dH' , $hours_ago ));
$ago -> sub ( $interval );
$date_from_trap = $ago -> format ( 'Y/m/d' );
$date_to_trap = $now -> format ( 'Y/m/d' );
$time_from_trap = $ago -> format ( 'H:i:s' );
$time_to_trap = $now -> format ( 'H:i:s' );
$whereSubquery = '' ;
if ( $alert != - 1 ) {
$whereSubquery .= ' AND alerted = ' . $$alert ;
}
if ( $severity != - 1 ) {
// There are two special severity values aimed to match two different trap standard severities
// in database: warning/critical and critical/normal.
if ( $severity != EVENT_CRIT_OR_NORMAL
&& $severity != EVENT_CRIT_WARNING_OR_CRITICAL
) {
// Test if enterprise is installed to search oid in text or oid field in ttrap.
if ( $config [ 'enterprise_installed' ]) {
$whereSubquery .= ' AND (
( alerted = 0 AND severity = '.$severity.' ) OR
( alerted = 1 AND priority = '.$severity.' )) ' ;
} else {
$whereSubquery .= ' AND (
( alerted = 0 AND 1 = '.$severity.' ) OR
( alerted = 1 AND priority = '.$severity.' )) ' ;
}
} else if ( $severity === EVENT_CRIT_WARNING_OR_CRITICAL ) {
// Test if enterprise is installed to search oid in text or oid field in ttrap.
if ( $config [ 'enterprise_installed' ]) {
$whereSubquery .= ' AND (
( alerted = 0 AND ( severity = '.EVENT_CRIT_WARNING.' OR severity = '.EVENT_CRIT_CRITICAL.' )) OR
( alerted = 1 AND ( priority = '.EVENT_CRIT_WARNING.' OR priority = '.EVENT_CRIT_CRITICAL.' ))) ' ;
} else {
$whereSubquery .= ' AND (
( alerted = 1 AND ( priority = '.EVENT_CRIT_WARNING.' OR priority = '.EVENT_CRIT_CRITICAL.' ))) ' ;
}
} else if ( $severity === EVENT_CRIT_OR_NORMAL ) {
// Test if enterprise is installed to search oid in text or oid field in ttrap.
if ( $config [ 'enterprise_installed' ]) {
$whereSubquery .= ' AND (
( alerted = 0 AND ( severity = '.EVENT_CRIT_NORMAL.' OR severity = '.EVENT_CRIT_CRITICAL.' )) OR
( alerted = 1 AND ( priority = '.EVENT_CRIT_NORMAL.' OR priority = '.EVENT_CRIT_CRITICAL.' ))) ' ;
} else {
$whereSubquery .= ' AND (
( alerted = 1 AND ( priority = '.EVENT_CRIT_NORMAL.' OR priority = '.EVENT_CRIT_CRITICAL.' ))) ' ;
}
}
}
if ( $search !== '' ) {
$whereSubquery .= '
AND ( source LIKE " %'. $search .'% " OR
oid LIKE " %'. $search .'% " OR
oid_custom LIKE " %'. $search .'% " OR
type_custom LIKE " %'. $search .'% " OR
value LIKE " %'. $search .'% " OR
value_custom LIKE " %'. $search .'% " OR
id_usuario LIKE " %'. $search .'% " OR
text LIKE " %'. $search .'% " OR
description LIKE " %'. $search .'% " ) ' ;
}
if ( $status != - 1 ) {
$whereSubquery .= ' AND status = ' . $status ;
}
if ( $date_from_trap != '' ) {
if ( $time_from_trap != '' ) {
$whereSubquery .= '
AND ( UNIX_TIMESTAMP ( timestamp ) > UNIX_TIMESTAMP ( " '. $date_from_trap .' '. $time_from_trap .' " ))
' ;
} else {
$whereSubquery .= '
AND ( UNIX_TIMESTAMP ( timestamp ) > UNIX_TIMESTAMP ( " '. $date_from_trap .' 23:59:59 " ))
' ;
}
}
if ( $date_to_trap != '' ) {
if ( $time_to_trap ) {
$whereSubquery .= '
AND ( UNIX_TIMESTAMP ( timestamp ) < UNIX_TIMESTAMP ( " '. $date_to_trap .' '. $time_to_trap .' " ))
' ;
} else {
$whereSubquery .= '
AND ( UNIX_TIMESTAMP ( timestamp ) < UNIX_TIMESTAMP ( " '. $date_to_trap .' 23:59:59 " ))
' ;
}
}
if ( $trap_type == 5 ) {
$whereSubquery .= ' AND type NOT IN (0, 1, 2, 3, 4)' ;
} else if ( $trap_type != - 1 ) {
$whereSubquery .= ' AND type = ' . $trap_type ;
}
$sql = ' SELECT * FROM ttrap WHERE 1 = 1
'.$whereSubquery.'
AND oid = " '. $trap['oid'] .' "
AND source = " '. $trap['source'] .' " ' ;
2022-12-19 16:30:41 +01:00
$group_traps = db_get_all_rows_sql ( $sql );
$count_group_traps = count ( $group_traps );
2022-12-20 10:03:45 +01:00
$sql = ' SELECT timestamp FROM ttrap WHERE 1 = 1
'.$whereSubquery.'
AND oid = " '. $trap['oid'] .' "
AND source = " '. $trap['source'] .' "
ORDER BY `timestamp` DESC ' ;
2022-12-19 16:30:41 +01:00
$last_trap = db_get_value_sql ( $sql );
2022-12-20 10:03:45 +01:00
$sql = ' SELECT timestamp FROM ttrap WHERE 1 = 1
'.$whereSubquery.'
AND oid = " '. $trap['oid'] .' "
AND source = " '. $trap['source'] .' "
ORDER BY `timestamp` ASC ' ;
2022-12-19 16:30:41 +01:00
$first_trap = db_get_value_sql ( $sql );
$trap [ 'count' ] = $count_group_traps ;
$trap [ 'first' ] = $first_trap ;
$trap [ 'last' ] = $last_trap ;
}
echo json_encode ( $trap );
2022-12-19 11:51:43 +01:00
return ;
}
2022-11-14 17:43:35 +01:00
/**
* Load Javascript code .
*
* @ return string .
*/
public function loadJS ()
{
// Nothing for this moment.
ob_start ();
// Javascript content.
?>
< script type = " text/javascript " >
/**
* Delete selected snmp trap
*/
function delete_trap ( id ) {
if ( confirm ( '<?php echo __(' Are you sure ? '); ?>' )) {
$ . ajax ({
method : 'post' ,
url : '<?php echo ui_get_full_url(' ajax . php ', false, false, false); ?>' ,
data : {
page : 'operation/snmpconsole/snmp_view' ,
method : 'deleteTrap' ,
id : id ,
group_by : $ ( '#filter_group_by' ) . val (),
},
datatype : " json " ,
success : function ( data ) {
var dt_snmp = $ ( " #snmp_console " ) . DataTable ();
dt_snmp . draw ();
},
error : function ( e ) {
console . error ( e );
}
});
}
}
/**
* Validated selected snmp trap
*/
function validate_trap ( id ) {
if ( confirm ( '<?php echo __(' Are you sure ? '); ?>' )) {
$ . ajax ({
method : 'post' ,
url : '<?php echo ui_get_full_url(' ajax . php ', false, false, false); ?>' ,
data : {
page : 'operation/snmpconsole/snmp_view' ,
method : 'validateTrap' ,
id : id ,
},
datatype : " json " ,
success : function ( data ) {
var dt_snmp = $ ( " #snmp_console " ) . DataTable ();
dt_snmp . draw ();
},
error : function ( e ) {
console . error ( e );
}
});
}
}
2022-12-20 10:03:45 +01:00
function fullscreen ( pure ) {
let new_url = 'index.php?sec=snmpconsole&sec2=operation/snmpconsole/snmp_view&pure=' + pure ;
new_url += '&filter_severity=' + $ ( '#filter_severity' ) . val ();
new_url += '&filter_status=' + $ ( '#filter_status' ) . val ();
new_url += '&filter_alert=' + $ ( '#filter_alert' ) . val ();
new_url += '&filter_group_by=0&filter_free_search=' + $ ( '#text-filter_free_search' ) . val ();
new_url += '&filter_hours_ago=' + $ ( '#text-filter_hours_ago' ) . val ();
new_url += '&filter_trap_type=' + $ ( '#filter_trap_type' ) . val ();
window . location . href = new_url ;
}
2022-12-19 11:51:43 +01:00
/**
* Show more information
*/
function toggleVisibleExtendedInfo ( id , position ) {
2023-02-09 14:45:10 +01:00
var status = $ ( '#eye_' + id ) . attr ( 'data-show' );
if ( status == " show " ){
$ . ajax ({
method : 'get' ,
url : '<?php echo ui_get_full_url(' ajax . php ', false, false, false); ?>' ,
data : {
page : 'operation/snmpconsole/snmp_view' ,
method : 'showInfo' ,
id : id ,
group_by : $ ( '#filter_group_by' ) . val (),
alert : $ ( '#filter_alert' ) . val (),
severity : $ ( '#filter_severity' ) . val (),
search : $ ( '#text-filter_free_search' ) . val (),
status : $ ( '#filter_status' ) . val (),
hours_ago : $ ( '#text-filter_hours_ago' ) . val (),
trap_type : $ ( '#filter_trap_type' ) . val ()
},
datatype : " json " ,
success : function ( data ) {
let trap = JSON . parse ( data );
2023-06-20 08:24:31 +02:00
var tr = $ ( '#snmp_console tr:not([id^="show_"])' ) . eq ( position + 1 );
2022-12-19 16:30:41 +01:00
2023-02-09 14:45:10 +01:00
// Count.
if ( $ ( '#filter_group_by' ) . val () == 1 ) {
let labelCount = '<td align="left" valign="top"><b><?php echo __(' Count : '); ?></b></br><b><?php echo __(' First trap : '); ?></b></br><b><?php echo __(' Last trap : '); ?></td>' ;
let variableCount = `<td align="left" valign="top" style="line-height: 16pt">${trap['count']}</br>${trap['first']}</br>${trap['last']}</td>` ;
2022-12-19 16:30:41 +01:00
2023-06-20 08:24:31 +02:00
tr . after ( `<tr id="show_${id}" role="row">${labelCount}${variableCount}</tr>` );
2023-02-09 14:45:10 +01:00
}
2022-12-19 16:30:41 +01:00
2023-02-09 14:45:10 +01:00
// Type.
desc_trap_type = " <?php echo __('Other'); ?> " ;
switch ( trap [ 'type' ]) {
case - 1 :
desc_trap_type = " <?php echo __('None'); ?> " ;
break ;
2022-12-19 16:30:41 +01:00
2023-02-09 14:45:10 +01:00
case 0 :
desc_trap_type = " <?php echo __('Cold start (0)'); ?> " ;
break ;
2022-12-19 16:30:41 +01:00
2023-02-09 14:45:10 +01:00
case 1 :
desc_trap_type = " <?php echo __('Warm start (1)'); ?> " ;
break ;
2022-12-19 16:30:41 +01:00
2023-02-09 14:45:10 +01:00
case 2 :
desc_trap_type = " <?php echo __('Link down (2)'); ?> " ;
break ;
2022-12-19 16:30:41 +01:00
2023-02-09 14:45:10 +01:00
case 3 :
desc_trap_type = " <?php echo __('Link up (3)'); ?> " ;
break ;
2022-12-19 16:30:41 +01:00
2023-02-09 14:45:10 +01:00
case 4 :
desc_trap_type = " <?php echo __('Authentication failure (4)'); ?> " ;
break ;
2022-12-19 16:30:41 +01:00
2023-02-09 14:45:10 +01:00
default :
desc_trap_type = " <?php echo __('Other'); ?> " ;
break ;
}
2022-12-19 16:30:41 +01:00
2023-02-09 14:45:10 +01:00
let labelType = '<td align="left" valign="top"><b><?php echo __(' Type : '); ?></td>' ;
let variableType = `<td align="left" colspan="8">${desc_trap_type}</td>` ;
2022-12-19 16:30:41 +01:00
2023-06-20 08:24:31 +02:00
tr . after ( `<tr id="show_${id}" role="row">${labelType}${variableType}</tr>` );
2022-12-19 16:30:41 +01:00
2023-02-09 14:45:10 +01:00
// Description.
if ( trap [ 'description' ]) {
let labelDesc = '<td align="left" valign="top"><b><?php echo __(' Description : '); ?></td>' ;
let variableDesc = `<td align="left" colspan="8">${trap['description']}</td>` ;
2022-12-19 16:30:41 +01:00
2023-06-20 08:24:31 +02:00
tr . after ( `<tr id="show_${id}" role="row">${labelDesc}${variableDesc}</tr>` );
2023-02-09 14:45:10 +01:00
}
2022-12-19 16:30:41 +01:00
2023-02-09 14:45:10 +01:00
// Enterprise String.
let labelOid = '<td align="left" valign="top"><b><?php echo __(' Enterprise String : '); ?></td>' ;
let variableOId = `<td align="left" colspan="8">${trap['oid']}</td>` ;
2023-06-20 08:24:31 +02:00
tr . after ( `<tr id="show_${id}" role="row">${labelOid}${variableOId}</tr>` );
2023-02-09 14:45:10 +01:00
// Variable bindings.
let labelBindings = '' ;
let variableBindings = '' ;
if ( $ ( '#filter_group_by' ) . val () == 1 ) {
2023-06-20 08:24:31 +02:00
labelBindings = '<td align="left" valign="top" ><b><?php echo __(' Variable bindings : '); ?></b></td>' ;
2023-02-09 14:45:10 +01:00
let new_url = 'index.php?sec=snmpconsole&sec2=operation/snmpconsole/snmp_view' ;
new_url += '&filter_severity=' + $ ( '#filter_severity' ) . val ();
new_url += '&filter_status=' + $ ( '#filter_status' ) . val ();
new_url += '&filter_alert=' + $ ( '#filter_alert' ) . val ();
new_url += '&filter_group_by=0&filter_free_search=' + $ ( '#text-filter_free_search' ) . val ();
new_url += '&filter_hours_ago=' + $ ( '#text-filter_hours_ago' ) . val ();
new_url += '&filter_trap_type=' + $ ( '#filter_trap_type' ) . val ();
const string = '<a href="' + new_url + '"><?php echo __(' See more details '); ?></a>' ;
variableBindings = `<td align="left" colspan="8">${string}</td>` ;
} else {
2023-06-20 08:24:31 +02:00
labelBindings = '<td align="left" valign="top" ><b><?php echo __(' Variable bindings : '); ?></b></td>' ;
2023-02-09 14:45:10 +01:00
const binding_vars = trap [ 'oid_custom' ] . split ( " \t " );
let string = '' ;
binding_vars . forEach ( function ( oid ) {
string += oid + '<br/>' ;
});
2023-04-10 10:26:15 +02:00
variableBindings = `<td align="left" colspan="8" class="break-word w200px">${string}</td>` ;
2023-02-09 14:45:10 +01:00
}
2022-12-19 16:30:41 +01:00
2023-06-20 08:24:31 +02:00
tr . after ( `<tr id="show_${id}" role="row">${labelBindings}${variableBindings}</tr>` );
2023-02-09 14:45:10 +01:00
},
error : function ( e ) {
console . error ( e );
2022-12-19 16:30:41 +01:00
}
2023-02-09 14:45:10 +01:00
});
$ ( '#eye_' + id ) . attr ( 'data-show' , 'hide' );
$ ( '#img_' + id ) . hide ();
$ ( '#img_hide_' + id ) . show ();
} else {
2023-06-20 08:24:31 +02:00
$ ( `tr#show_${id}` ) . remove ();
2023-02-09 14:45:10 +01:00
$ ( '#eye_' + id ) . attr ( 'data-show' , 'show' );
$ ( '#img_' + id ) . show ();
$ ( '#img_hide_' + id ) . hide ();
}
2022-12-19 11:51:43 +01:00
}
2022-11-14 17:43:35 +01:00
$ ( document ) . ready ( function () {
var table = $ ( '#snmp_console' ) . DataTable ();
const column = table . column ( 3 );
column . visible ( false );
$ ( '#form_snmp_console_search_bt' ) . click ( function () {
if ( $ ( '#filter_group_by' ) . val () == 1 ) {
column . visible ( true );
} else {
column . visible ( false );
}
});
2023-02-27 16:33:54 +01:00
$ ( '#button-updatebt' ) . click ( function () {
2022-11-14 17:43:35 +01:00
let array = [];
$ ( 'input[name="snmptrapid[]"]:checked' ) . each ( function () {
array . push ( this . value );
});
if ( array . length > 0 ) {
$ . ajax ({
method : 'post' ,
url : '<?php echo ui_get_full_url(' ajax . php ', false, false, false); ?>' ,
data : {
page : 'operation/snmpconsole/snmp_view' ,
method : 'validateTraps' ,
ids : array ,
},
datatype : " json " ,
success : function ( data ) {
var dt_snmp = $ ( " #snmp_console " ) . DataTable ();
dt_snmp . draw ();
},
error : function ( e ) {
console . error ( e );
}
});
}
});
2023-02-27 16:33:54 +01:00
$ ( '#button-deletebt' ) . click ( function () {
2022-11-14 17:43:35 +01:00
let array = [];
$ ( 'input[name="snmptrapid[]"]:checked' ) . each ( function () {
array . push ( this . value );
});
if ( array . length > 0 ) {
$ . ajax ({
method : 'post' ,
url : '<?php echo ui_get_full_url(' ajax . php ', false, false, false); ?>' ,
data : {
page : 'operation/snmpconsole/snmp_view' ,
method : 'deleteTraps' ,
ids : array ,
group_by : $ ( '#filter_group_by' ) . val (),
},
datatype : " json " ,
success : function ( data ) {
var dt_snmp = $ ( " #snmp_console " ) . DataTable ();
dt_snmp . draw ();
},
error : function ( e ) {
console . error ( e );
}
});
}
});
$ ( '#checkbox-all_validate_box' ) . click ( function () {
const c = this . checked ;
$ ( ':checkbox' ) . prop ( 'checked' , c );
});
2022-12-20 10:03:45 +01:00
var controls = document . getElementById ( 'dashboard-controls' );
autoHideElement ( controls , 1000 );
var startCountDown = function ( duration , cb ) {
$ ( 'div.dashboard-countdown' ) . countdown ( 'destroy' );
if ( ! duration ) return ;
var t = new Date ();
t . setTime ( t . getTime () + duration * 1000 );
$ ( 'div.dashboard-countdown' ) . countdown ({
until : t ,
format : 'MS' ,
layout : '(%M%nn%M:%S%nn%S <?php echo __(' Until next '); ?>) ' ,
alwaysExpire : true ,
onExpiry : function () {
var dt_snmp = $ ( " #snmp_console " ) . DataTable ();
dt_snmp . draw ();
startCountDown ( duration );
throw " exit " ;
}
});
}
// Auto refresh select
$ ( 'form#refr-form' ) . submit ( function ( event ) {
event . preventDefault ();
});
var handleRefrChange = function ( event ) {
event . preventDefault ();
var url = $ ( 'form#refr-form' ) . prop ( 'action' );
var refr = Number . parseInt ( event . target . value , 10 );
startCountDown ( refr );
}
$ ( 'form#refr-form select' ) . change ( handleRefrChange ) . change ();
2022-11-14 17:43:35 +01:00
});
</ script >
< ? php
// EOF Javascript content.
return ob_get_clean ();
}
}