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'); $user_groups = users_get_groups($config['id_user'], $access, false); $str_user_groups = ''; $i = 0; foreach ($user_groups as $id => $name) { if ($i == 0) { $str_user_groups .= $id; } else { $str_user_groups .= ','.$id; } $i++; } $url = 'index.php?sec=estado&sec2=operation/snmpconsole/snmp_view'; $url .= '&filter_severity='.$filter_severity.'&filter_fired='.$filter_fired; $url .= '&free_search_string='.$free_search_string.'&pagination='.$pagination; $url .= '&offset='.$offset.'&trap_type='.$trap_type.'&group_by='.$group_by; $url .= '&hours_ago='.$hours_ago.'&pure='.$pure; $statistics['text'] = ''.html_print_image( 'images/op_reporting.png', true, [ 'title' => __('Statistics'), 'class' => 'invert_filter', ] ).''; $list['text'] = ''.html_print_image( 'images/op_snmp.png', true, [ 'title' => __('List'), 'class' => 'invert_filter', ] ).''; $list['active'] = true; if ($config['pure']) { $fullscreen['text'] = ''.html_print_image( 'images/normal_screen.png', true, [ 'title' => __('Normal screen'), 'class' => 'invert_filter', ] ).''; } else { // Fullscreen. $fullscreen['text'] = ''.html_print_image( 'images/full_screen.png', true, [ 'title' => __('Full screen'), 'class' => 'invert_filter', ] ).''; } // OPERATIONS // Delete SNMP Trap entry Event. if (isset($_GET['delete'])) { $id_trap = (int) get_parameter_get('delete', 0); if ($id_trap > 0) { if ($group_by) { $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]); ui_print_result_message( $result, __('Successfully deleted'), __('Could not be deleted') ); } } } // Check Event. if (isset($_GET['check'])) { $id_trap = (int) get_parameter_get('check', 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]); ui_print_result_message( $result, __('Successfully updated'), __('Could not be updated') ); } // Mass-process DELETE. if (isset($_POST['deletebt'])) { $trap_ids = get_parameter_post('snmptrapid', []); if (is_array($trap_ids)) { if ($group_by) { foreach ($trap_ids as $key => $value) { $sql_ids_traps = 'SELECT id_trap, source FROM ttrap WHERE oid IN (SELECT oid FROM ttrap WHERE id_trap = '.$value.') AND source IN (SELECT source FROM ttrap WHERE id_trap = '.$value.')'; $ids_traps = db_get_all_rows_sql($sql_ids_traps); foreach ($ids_traps as $key2 => $value2) { $result = db_process_sql_delete('ttrap', ['id_trap' => $value2['id_trap']]); enterprise_hook('snmp_update_forwarded_modules', [$value2]); } } } else { foreach ($trap_ids as $id_trap) { $forward_info = db_get_row('ttrap', 'id_trap', $id_trap); db_process_sql_delete('ttrap', ['id_trap' => $id_trap]); enterprise_hook('snmp_update_forwarded_modules', [$forward_info]); } } } } // Mass-process UPDATE. if (isset($_POST['updatebt'])) { $trap_ids = get_parameter_post('snmptrapid', []); if (is_array($trap_ids)) { foreach ($trap_ids as $id_trap) { $sql = sprintf("UPDATE ttrap SET status = 1, id_usuario = '%s' WHERE id_trap = %d", $config['id_user'], $id_trap); db_process_sql($sql); enterprise_hook('snmp_update_forwarded_modules', [$id_trap]); } } } // All traps. $all_traps = db_get_all_rows_sql('SELECT DISTINCT source FROM ttrap'); if (empty($all_traps)) { $all_traps = []; } // Set filters. $agents = []; $oids = []; $severities = get_priorities(); $alerted = [ __('Not fired'), __('Fired'), ]; foreach ($all_traps as $trap) { $agent = agents_get_agent_with_ip($trap['source']); $agents[$trap['source']] = $agent !== false ? ($agent['alias'] ? $agent['alias'] : $agent['nombre']) : $trap['source']; $oid = enterprise_hook('get_oid', [$trap]); if ($oid === ENTERPRISE_NOT_HOOK) { $oid = $trap['oid']; } $oids[$oid] = $oid; } $prea = array_keys($user_groups); $ids = join(',', $prea); // Cuantos usuarios hay operadores con un grupo que exista y no lo tenga ningun usuario. $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))'); switch ($config['dbtype']) { case 'mysql': case 'postgresql': 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.'"'; } } break; default: // Default. break; } 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, '""'); } // Make query to extract traps of DB. switch ($config['dbtype']) { case 'mysql': $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'; break; case 'postgresql': $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 OFFSET %d'; break; case 'oracle': $sql = "SELECT * FROM ttrap WHERE (source IN ( SELECT direccion FROM tagente WHERE id_grupo IN ($str_user_groups) ) OR source='' OR source NOT IN (SELECT direccion FROM tagente WHERE direccion IS NOT NULL)) %s ORDER BY timestamp DESC"; break; default: // Default. break; } switch ($config['dbtype']) { case 'mysql': case 'postgresql': $sql_all = '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'; $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'; break; case 'oracle': $sql_all = "SELECT * FROM ttrap WHERE (source IN ( SELECT direccion FROM tagente WHERE id_grupo IN ($str_user_groups) ) OR source='' OR source NOT IN (SELECT direccion FROM tagente WHERE direccion IS NOT NULL)) %s ORDER BY timestamp DESC"; $sql_count = "SELECT COUNT(id_trap) FROM ttrap WHERE ( source IN ( SELECT direccion FROM tagente WHERE id_grupo IN ($str_user_groups) ) OR source='' OR source NOT IN (SELECT direccion FROM tagente WHERE direccion IS NOT NULL)) %s"; break; default: // Default. break; } // $whereSubquery = 'WHERE 1=1'; $whereSubquery = ''; if ($filter_fired != -1) { $whereSubquery .= ' AND alerted = '.$filter_fired; } if ($free_search_string != '') { switch ($config['dbtype']) { case 'mysql': $whereSubquery .= ' AND (source LIKE "%'.$free_search_string.'%" OR oid LIKE "%'.$free_search_string.'%" OR oid_custom LIKE "%'.$free_search_string.'%" OR type_custom LIKE "%'.$free_search_string.'%" OR value LIKE "%'.$free_search_string.'%" OR value_custom LIKE "%'.$free_search_string.'%" OR id_usuario LIKE "%'.$free_search_string.'%" OR text LIKE "%'.$free_search_string.'%" OR description LIKE "%'.$free_search_string.'%")'; break; case 'postgresql': case 'oracle': $whereSubquery .= ' AND (source LIKE \'%'.$free_search_string.'%\' OR oid LIKE \'%'.$free_search_string.'%\' OR oid_custom LIKE \'%'.$free_search_string.'%\' OR type_custom LIKE \'%'.$free_search_string.'%\' OR value LIKE \'%'.$free_search_string.'%\' OR value_custom LIKE \'%'.$free_search_string.'%\' OR id_usuario LIKE \'%'.$free_search_string.'%\' OR text LIKE \'%'.$free_search_string.'%\' OR description LIKE \'%'.$free_search_string.'%\')'; break; default: // Default. break; } } 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 ($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 ($filter_severity != EVENT_CRIT_OR_NORMAL && $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 = '.$filter_severity.') OR (alerted = 1 AND priority = '.$filter_severity.'))'; } else { $whereSubquery .= ' AND ( (alerted = 0 AND 1 = '.$filter_severity.') OR (alerted = 1 AND priority = '.$filter_severity.'))'; } } else if ($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 ($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.')))'; } } } if ($filter_status != -1) { $whereSubquery .= ' AND status = '.$filter_status; } if ($trap_type == 5) { $whereSubquery .= ' AND type NOT IN (0, 1, 2, 3, 4)'; } else if ($trap_type != -1) { $whereSubquery .= ' AND type = '.$trap_type; } // Disable this feature (time will decide if temporarily) in Oracle cause the group by is very confictive. if ($group_by && $config['dbtype'] != 'oracle') { $where_without_group = $whereSubquery; $whereSubquery .= ' GROUP BY source,oid'; } switch ($config['dbtype']) { case 'mysql': $sql = sprintf($sql, $whereSubquery, $offset, $pagination); break; case 'postgresql': $sql = sprintf($sql, $whereSubquery, $pagination, $offset); break; case 'oracle': $set = []; $set['limit'] = $pagination; $set['offset'] = $offset; $sql = sprintf($sql, $whereSubquery); $sql = oracle_recode_query($sql, $set); break; default: // Default. break; } $sql_all = sprintf($sql_all, $whereSubquery); $sql_count = sprintf($sql_count, $whereSubquery); $table = new stdClass(); $table->width = '100%'; $table->cellpadding = 0; $table->cellspacing = 0; $table->class = 'databox filters'; $table->size = []; $table->size[0] = '120px'; $table->data = []; // Alert status select. $table->data[1][0] = ''.__('Alert').''; $table->data[1][1] = html_print_select( $alerted, 'filter_fired', $filter_fired, '', __('All'), '-1', true ); // Block size for pagination select. $table->data[2][0] = ''.__('Block size for pagination').''; $paginations[25] = 25; $paginations[50] = 50; $paginations[100] = 100; $paginations[200] = 200; $paginations[500] = 500; $table->data[2][1] = html_print_select( $paginations, 'pagination', $pagination, '', __('Default'), $config['block_size'], true ); // Severity select. $table->data[1][2] = ''.__('Severity').''; $table->data[1][3] = html_print_select( $severities, 'filter_severity', $filter_severity, '', __('All'), -1, true ); // Status. $table->data[3][0] = ''.__('Status').''; $status_array[-1] = __('All'); $status_array[0] = __('Not validated'); $status_array[1] = __('Validated'); $table->data[3][1] = html_print_select( $status_array, 'filter_status', $filter_status, '', '', '', true ); // Free search (search by all alphanumeric fields). $table->data[2][3] = ''.__('Free search').''.ui_print_help_tip( __( 'Search by any alphanumeric field in the trap. REMEMBER trap sources need to be searched by IP Address' ), true ); $table->data[2][4] = html_print_input_text( 'free_search_string', $free_search_string, '', 40, 0, true ); $table->data[4][0] = ''.__('Max. hours old').''; $table->data[4][1] = html_print_input( [ 'type' => 'number', 'name' => 'hours_ago', 'value' => $hours_ago, 'step' => 1, 'return' => true, ] ); // Type filter (ColdStart, WarmStart, LinkDown, LinkUp, authenticationFailure, Other). $table->data[4][3] = ''.__('Trap type').''.ui_print_help_tip(__('Search by trap type'), true); $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'), ]; $table->data[4][4] = html_print_select( $trap_types, 'trap_type', $trap_type, '', '', '', true, false, false ); // Disable this feature (time will decide if temporarily) in Oracle cause the group by is very confictive. if ($config['dbtype'] != 'oracle') { $table->data[3][3] = ''.__('Group by Enterprise String/IP').''; $table->data[3][4] = __('Yes').' '.html_print_radio_button('group_by', 1, '', $group_by, true).'  '; $table->data[3][4] .= __('No').' '.html_print_radio_button('group_by', 0, '', $group_by, true); } $filter = '
'; $filter .= html_print_table($table, true); $filter .= '
'; $filter .= html_print_submit_button(__('Update'), 'search', false, 'class="sub upd"', true); $filter .= '
'; $filter .= '
'; $filter_resume = []; $filter_resume['filter_fired'] = $alerted[$filter_fired]; $filter_resume['filter_severity'] = $severities[$filter_severity]; $filter_resume['pagination'] = $paginations[$pagination]; $filter_resume['free_search_string'] = $free_search_string; $filter_resume['filter_status'] = $status_array[$filter_status]; $filter_resume['group_by'] = $group_by; $filter_resume['hours_ago'] = $hours_ago; $filter_resume['trap_type'] = $trap_types[$trap_type]; $traps = db_get_all_rows_sql($sql); $trapcount = (int) db_get_value_sql($sql_count); // No traps. if (empty($traps)) { // Header ui_print_standard_header( __('SNMP Console'), 'images/op_snmp.png', false, 'snmp_console', false, [ $list, $statistics, ], [ [ 'link' => '', 'label' => __('Monitoring'), ], [ 'link' => '', 'label' => __('SNMP'), ], ] ); $sql2 = 'SELECT * FROM ttrap WHERE ( `source` IN ('.implode(',', $address_by_user_groups).") OR `source`='' OR `source` NOT IN (".implode(',', $all_address_agents).') ) AND status = 0 ORDER BY timestamp DESC'; $traps2 = db_get_all_rows_sql($sql2); if (!empty($traps2)) { ui_toggle($filter, __('Toggle filter(s)')); print_snmp_tags_active_filters($filter_resume); ui_print_info_message(['no_close' => true, 'message' => __('There are no SNMP traps in database that contains this filter') ]); } else { ui_print_info_message(['no_close' => true, 'message' => __('There are no SNMP traps in database') ]); } return; } else { if ($config['pure']) { echo '
'; echo ''; echo '
'; ui_require_css_file('pandora_enterprise', ENTERPRISE_DIR.'/include/styles/'); ui_require_css_file('pandora_dashboard', ENTERPRISE_DIR.'/include/styles/'); ui_require_css_file('cluetip', 'include/styles/js/'); ui_require_jquery_file('countdown'); ui_require_javascript_file('pandora_dashboard', ENTERPRISE_DIR.'/include/javascript/'); ui_require_javascript_file('wz_jsgraphics'); ui_require_javascript_file('pandora_visual_console'); } else { // Header ui_print_standard_header( __('SNMP Console'), 'images/op_snmp.png', false, '', false, [ $fullscreen, $list, $statistics, ], [ [ 'link' => '', 'label' => __('Monitoring'), ], [ 'link' => '', 'label' => __('SNMP'), ], ] ); } } ui_toggle($filter, __('Toggle filter(s)')); unset($table); print_snmp_tags_active_filters($filter_resume); if (($config['dbtype'] == 'oracle') && ($traps !== false)) { $traps_size = count($traps); for ($i = 0; $i < $traps_size; $i++) { unset($traps[$i]['rnum']); } } $url_snmp = 'index.php?sec=snmpconsole&sec2=operation/snmpconsole/snmp_view'; $url_snmp .= '&filter_severity='.$filter_severity.'&filter_fired='.$filter_fired; $url_snmp .= '&filter_status='.$filter_status.'&refresh='.((int) get_parameter('refresh', 0)); $url_snmp .= '&pure='.$config['pure'].'&trap_type='.$trap_type; $url_snmp .= '&group_by='.$group_by.'&free_search_string='.$free_search_string; $url_snmp .= '&hours_ago='.$hours_ago; $urlPagination = $url_snmp.'&pagination='.$pagination.'&offset='.$offset; ui_pagination($trapcount, $urlPagination, $offset, $pagination); echo '
'; $table = new StdClass(); $table->cellpadding = 0; $table->cellspacing = 0; $table->width = '100%'; $table->class = 'databox data'; $table->head = []; $table->size = []; $table->data = []; $table->align = []; $table->headstyle = []; $table->head[0] = __('Status'); $table->align[0] = 'center'; $table->size[0] = '5%'; $table->headstyle[0] = 'text-align: center'; $table->head[1] = __('SNMP Agent'); $table->align[1] = 'center'; $table->size[1] = '15%'; $table->headstyle[1] = 'text-align: center'; $table->head[2] = __('Enterprise String'); $table->align[2] = 'center'; $table->size[2] = '18%'; $table->headstyle[2] = 'text-align: center'; if ($group_by) { $table->head[3] = __('Count'); $table->align[3] = 'center'; $table->size[3] = '5%'; $table->headstyle[3] = 'text-align: center'; } $table->head[4] = __('Trap subtype'); $table->align[4] = 'center'; $table->size[4] = '10%'; $table->headstyle[4] = 'text-align: center'; $table->head[5] = __('User ID'); $table->align[5] = 'center'; $table->size[5] = '10%'; $table->headstyle[5] = 'text-align: center'; $table->head[6] = __('Timestamp'); $table->align[6] = 'center'; $table->size[6] = '10%'; $table->headstyle[6] = 'text-align: center'; $table->head[7] = __('Alert'); $table->align[7] = 'center'; $table->size[7] = '5%'; $table->headstyle[7] = 'text-align: center'; $table->head[8] = __('Action'); $table->align[8] = 'center'; $table->size[8] = '10%'; $table->headstyle[8] = 'min-width: 125px;text-align: center'; $table->head[9] = html_print_checkbox_extended( 'allbox', 1, false, false, 'javascript:CheckAll();', 'class="chk" title="'.__('All').'"', true ); $table->align[9] = 'center'; $table->size[9] = '5%'; $table->headstyle[9] = 'text-align: center'; $table->style[8] = 'background: #F3F3F3; color: #111 !important;'; // Skip offset records. $idx = 0; if ($traps !== false) { foreach ($traps as $trap) { $data = []; if (empty($trap['description'])) { $trap['description'] = ''; } $severity = enterprise_hook('get_severity', [$trap]); if ($severity === ENTERPRISE_NOT_HOOK) { $severity = $trap['alerted'] == 1 ? $trap['priority'] : 1; } // Status. if ($trap['status'] == 0) { $data[0] = html_print_image( 'images/pixel_red.png', true, [ 'title' => __('Not validated'), 'width' => '20', 'height' => '20', ] ); } else { $data[0] = html_print_image( 'images/pixel_green.png', true, [ 'title' => __('Validated'), 'width' => '20', 'height' => '20', ] ); } // Agent matching source address. $table->cellclass[$idx][1] = get_priority_class($severity); $agent = agents_get_agent_with_ip($trap['source']); if ($agent === false) { if (! check_acl($config['id_user'], 0, 'AR')) { continue; } $data[1] = ''.$trap['source'].''; } else { if (! check_acl($config['id_user'], $agent['id_grupo'], 'AR')) { continue; } $data[1] = ''; $data[1] .= ''.$agent['alias'].ui_print_help_tip($trap['source'], true, 'images/tip-blanco.png'); ''; } // OID. $table->cellclass[$idx][2] = get_priority_class($severity); if (! empty($trap['text'])) { $enterprise_string = $trap['text']; } else if (! empty($trap['oid'])) { $enterprise_string = $trap['oid']; } else { $enterprise_string = __('N/A'); } $data[2] = ''.$enterprise_string.''; // Count. if ($group_by) { $sql = "SELECT * FROM ttrap WHERE 1=1 $where_without_group AND oid='".$trap['oid']."' AND source='".$trap['source']."'"; $group_traps = db_get_all_rows_sql($sql); $count_group_traps = count($group_traps); $table->cellclass[$idx][3] = get_priority_class($severity); $data[3] = ''.$count_group_traps.''; } // Value. $table->cellclass[$idx][4] = get_priority_class($severity); if (empty($trap['value'])) { $data[4] = __('N/A'); } else { $data[4] = ui_print_truncate_text($trap['value'], GENERIC_SIZE_TEXT, false); } // User. $table->cellclass[$idx][5] = get_priority_class($severity); if (!empty($trap['status'])) { $data[5] = ''.substr($trap['id_usuario'], 0, 8).''; if (!empty($trap['id_usuario'])) { $data[5] .= ui_print_help_tip(get_user_fullname($trap['id_usuario']), true); } } else { $data[5] = '--'; } // Timestamp. $table->cellclass[$idx][6] = get_priority_class($severity); $data[6] = ''; $data[6] .= ui_print_timestamp($trap['timestamp'], true); $data[6] .= ''; // Use alert severity if fired. if (!empty($trap['alerted'])) { $data[7] = html_print_image('images/pixel_yellow.png', true, ['width' => '20', 'height' => '20', 'border' => '0', 'title' => __('Alert fired')]); } else { $data[7] = html_print_image('images/pixel_gray.png', true, ['width' => '20', 'height' => '20', 'border' => '0', 'title' => __('Alert not fired')]); } // Actions. $data[8] = ''; if (empty($trap['status'])) { $data[8] .= ''.html_print_image('images/ok.png', true, ['border' => '0', 'title' => __('Validate')]).' '; } if ($trap['source'] == '') { $is_admin = db_get_value('is_admin', 'tusuario', 'id_user', $config['id_user']); if ($is_admin) { $data[8] .= ''.html_print_image( 'images/cross.png', true, [ 'border' => '0', 'title' => __('Delete'), 'class' => 'invert_filter', ] ).' '; } } else { $agent_trap_group = db_get_value('id_grupo', 'tagente', 'nombre', $trap['source']); $data[8] .= ''.html_print_image( 'images/cross.png', true, [ 'border' => '0', 'title' => __('Delete'), 'class' => 'invert_filter', ] ).' '; } $data[8] .= ''.html_print_image( 'images/eye.png', true, [ 'alt' => __('Show more'), 'title' => __('Show more'), 'class' => 'invert_filter', ] ).''; $data[8] .= enterprise_hook('editor_link', [$trap]); $data[9] = html_print_checkbox_extended('snmptrapid[]', $trap['id_trap'], false, false, '', 'class="chk"', true); array_push($table->data, $data); // Hiden file for description. $string = ''; if ($trap['description'] != '') { $string .= ''; } if ($trap['type'] != '') { $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'), ]; switch ($trap['type']) { case -1: $desc_trap_type = __('None'); break; case 0: $desc_trap_type = __('Cold start (0)'); break; case 1: $desc_trap_type = __('Warm start (1)'); break; case 2: $desc_trap_type = __('Link down (2)'); break; case 3: $desc_trap_type = __('Link up (3)'); break; case 4: $desc_trap_type = __('Authentication failure (4)'); break; default: $desc_trap_type = __('Other'); break; } $string .= ''; } if ($group_by) { $sql = "SELECT * FROM ttrap WHERE 1=1 $where_without_group AND oid='".$trap['oid']."' AND source='".$trap['source']."'"; $group_traps = db_get_all_rows_sql($sql); $count_group_traps = count($group_traps); $sql = "SELECT timestamp FROM ttrap WHERE 1=1 $where_without_group AND oid='".$trap['oid']."' AND source='".$trap['source']."' ORDER BY `timestamp` DESC"; $last_trap = db_get_value_sql($sql); $sql = "SELECT timestamp FROM ttrap WHERE 1=1 $where_without_group AND oid='".$trap['oid']."' AND source='".$trap['source']."' ORDER BY `timestamp` ASC"; $first_trap = db_get_value_sql($sql); $string .= ''; $string .= ''; $string .= ''; } $string .= '
'.''.__('Variable bindings:').' '; if ($group_by) { $new_url = 'index.php?sec=snmpconsole&sec2=operation/snmpconsole/snmp_view'; $new_url .= '&filter_severity='.$filter_severity; $new_url .= '&filter_fired='.$filter_fired; $new_url .= '&filter_status='.$filter_status; $new_url .= '&refresh='.((int) get_parameter('refresh', 0)); $new_url .= '&pure='.$config['pure']; $new_url .= '&group_by=0&free_search_string='.$free_search_string; $new_url .= '&hours_ago='.$hours_ago; $string .= ''.__('See more details').''; } else { // Print binding vars separately. $binding_vars = explode("\t", $trap['oid_custom']); foreach ($binding_vars as $var) { $string .= $var.'
'; } } $string .= '
'.''.__('Enterprise String:').' '.$trap['oid'].'
'.''.__('Description:').' '.$trap['description'].'
'.__('Trap type:').''.$desc_trap_type.'
'.''.__('Count:').' '.$count_group_traps.'
'.''.__('First trap:').' '.$first_trap.'
'.''.__('Last trap:').' '.$last_trap.'
'; $data = [$string]; // $data = array($trap['description']); $idx++; $table->rowclass[$idx] = 'trap_info_'.$trap['id_trap']; $table->colspan[$idx][0] = 10; $table->rowstyle[$idx] = 'display: none;'; array_push($table->data, $data); $idx++; } } // No matching traps. if ($idx == 0) { echo '
'.__('No matching traps found').'
'; } else { html_print_table($table); } unset($table); echo '
'; html_print_submit_button(__('Validate'), 'updatebt', false, 'class="sub ok"'); echo ' '; html_print_submit_button(__('Delete'), 'deletebt', false, 'class="sub delete" onClick="javascript:return confirm(\''.__('Are you sure?').'\')"'); echo '
'; echo '
'; echo '

'.__('Status').'

'; echo html_print_image( 'images/pixel_green.png', true, [ 'width' => '20', 'height' => '20', ] ).' - '.__('Validated'); echo '
'; echo html_print_image( 'images/pixel_red.png', true, [ 'width' => '20', 'height' => '20', ] ).' - '.__('Not validated'); echo '
'; echo '
'; echo '

'.__('Alert').'

'; echo html_print_image( 'images/pixel_yellow.png', true, [ 'width' => '20', 'height' => '20', ] ).' - '.__('Fired'); echo '
'; echo html_print_image( 'images/pixel_gray.png', true, [ 'width' => '20', 'height' => '20', ] ).' - '.__('Not fired'); echo '
'; echo '
'; echo '

'.__('Action').'

'; echo html_print_image('images/ok.png', true).' - '.__('Validate'); echo '
'; echo html_print_image('images/cross.png', true, ['class' => 'invert_filter']).' - '.__('Delete'); echo '
'; echo '
'; echo '

'.__('Legend').'

'; foreach (get_priorities() as $num => $name) { echo ''.$name.''; echo '
'; } echo '
'; echo '
 
'; ui_include_time_picker(); ?>