Files
librenms-librenms/includes/discovery/ports.inc.php
Julian Lehrhuber a3ec263f78 Bintec be.IP plus support (#12993)
* Introduce OS flag to support devices that deliver OIDs out of order

* Add MIB for Bintec Be.IP Plus

* Add YAML definitions for Bintec Be.IP Plus

* Add Bintec be.IP plus test files

* Rename bintec mib files

mib-standards.mib was deleted, because it included definitions that also
existed in separate files

* Add test data

* Remove standard mib files from bintec dir

* Add regex to parse Bintec Be.IP Plus OS version

* Update test data for Bintec Be.IP Plus

* Calculate Bintec Be.IP Plus CPU load from inverse of idle time

* Improve Bintec Be.IP Plus discovery and tests

* Use MIB instead of numerical OIDs where possible

* Update tests to comply with updated discovery

* Remove unused MIBs

* Remove json props that let tests fail

* Update Settings.md

* Remove `snmp_out_of_order_oids` definition from bintec-beip-plus

* Add `-Cc` snmp param for prots module

* Add `-Cc` snmp param for arp-table module

* remove snmp_out_of_order_oids

* Remove snmp_out_of_order_oids

* Update snmp.inc.php

Co-authored-by: Tony Murray <murraytony@gmail.com>
2021-10-28 13:05:43 -05:00

130 lines
4.8 KiB
PHP

<?php
// Build SNMP Cache Array
use App\Models\PortGroup;
use LibreNMS\Config;
use LibreNMS\Util\StringHelpers;
$descrSnmpFlags = '-OQUs';
$typeSnmpFlags = '-OQUs';
$operStatusSnmpFlags = '-OQUs';
if ($device['os'] == 'bintec-beip-plus') {
$descrSnmpFlags = ['-OQUs', '-Cc'];
$typeSnmpFlags = ['-OQUs', '-Cc'];
$operStatusSnmpFlags = ['-OQUs', '-Cc'];
}
$port_stats = [];
$port_stats = snmpwalk_cache_oid($device, 'ifDescr', $port_stats, 'IF-MIB', null, $descrSnmpFlags);
$port_stats = snmpwalk_cache_oid($device, 'ifName', $port_stats, 'IF-MIB');
$port_stats = snmpwalk_cache_oid($device, 'ifAlias', $port_stats, 'IF-MIB');
$port_stats = snmpwalk_cache_oid($device, 'ifType', $port_stats, 'IF-MIB', null, $typeSnmpFlags);
$port_stats = snmpwalk_cache_oid($device, 'ifOperStatus', $port_stats, 'IF-MIB', null, $operStatusSnmpFlags);
// Get correct eth0 port status for AirFiber 5XHD devices
if ($device['os'] == 'airos-af-ltu') {
require 'ports/airos-af-ltu.inc.php';
}
// End Building SNMP Cache Array
d_echo($port_stats);
// By default libreNMS uses the ifIndex to associate ports on devices with ports discoverd/polled
// before and stored in the database. On Linux boxes this is a problem as ifIndexes may be
// unstable between reboots or (re)configuration of tunnel interfaces (think: GRE/OpenVPN/Tinc/...)
// The port association configuration allows to choose between association via ifIndex, ifName,
// or maybe other means in the future. The default port association mode still is ifIndex for
// compatibility reasons.
$port_association_mode = Config::get('default_port_association_mode');
if ($device['port_association_mode']) {
$port_association_mode = get_port_assoc_mode_name($device['port_association_mode']);
}
// Build array of ports in the database and an ifIndex/ifName -> port_id map
$ports_mapped = get_ports_mapped($device['device_id']);
$ports_db = $ports_mapped['ports'];
//
// Rename any old RRD files still named after the previous ifIndex based naming schema.
foreach ($ports_mapped['maps']['ifIndex'] as $ifIndex => $port_id) {
foreach (['', '-adsl', '-dot3'] as $suffix) {
$old_rrd_name = "port-$ifIndex$suffix.rrd";
$new_rrd_name = \Rrd::portName($port_id, ltrim($suffix, '-'));
\Rrd::renameFile($device, $old_rrd_name, $new_rrd_name);
}
}
// Fill ifAlias for fibrechannel ports
if ($device['os'] == 'fabos') {
require base_path('includes/discovery/ports/brocade.inc.php');
}
//Shorten Ekinops Interfaces
if ($device['os'] == 'ekinops') {
require base_path('includes/discovery/ports/ekinops.inc.php');
}
$default_port_group = Config::get('default_port_group');
// New interface detection
foreach ($port_stats as $ifIndex => $snmp_data) {
$snmp_data['ifIndex'] = $ifIndex; // Store ifIndex in port entry
$snmp_data['ifAlias'] = StringHelpers::inferEncoding($snmp_data['ifAlias']);
// Get port_id according to port_association_mode used for this device
$port_id = get_port_id($ports_mapped, $snmp_data, $port_association_mode);
if (is_port_valid($snmp_data, $device)) {
port_fill_missing($snmp_data, $device);
// Port newly discovered?
if (! is_array($ports_db[$port_id])) {
$snmp_data['device_id'] = $device['device_id'];
$port_id = dbInsert($snmp_data, 'ports');
//default Port Group for new Ports defined?
if (! empty($default_port_group)) {
$port_group = PortGroup::find($default_port_group);
if (isset($port_group)) {
$port_group->ports()->attach([$port_id]);
}
}
$ports[$port_id] = dbFetchRow('SELECT * FROM `ports` WHERE `device_id` = ? AND `port_id` = ?', [$device['device_id'], $port_id]);
echo 'Adding: ' . $snmp_data['ifName'] . '(' . $ifIndex . ')(' . $port_id . ')';
} elseif ($ports_db[$port_id]['deleted'] == 1) {
// Port re-discovered after previous deletion?
$snmp_data['deleted'] = 0;
dbUpdate($snmp_data, 'ports', '`port_id` = ?', [$port_id]);
$ports_db[$port_id]['deleted'] = 0;
echo 'U';
} else { // port is existing, let's update it with some data we have collected here
dbUpdate($snmp_data, 'ports', '`port_id` = ?', [$port_id]);
echo '.';
}
} else {
// Port vanished (mark as deleted)
if (is_array($ports_db[$port_id])) {
if ($ports_db[$port_id]['deleted'] != 1) {
dbUpdate(['deleted' => 1], 'ports', '`port_id` = ?', [$port_id]);
$ports_db[$port_id]['deleted'] = 1;
echo '-';
}
}
echo 'X';
}//end if
}//end foreach
unset(
$ports_mapped,
$port
);
echo "\n";
// Clear Variables Here
unset($port_stats);
unset($ports_db);