mirror of
https://github.com/librenms/librenms.git
synced 2024-10-07 16:52:45 +00:00
Nokia vrf bgp (#9622)
* first commit * clean code * add snmpsim data for bgp * renumber sql patch * clear public ip * update misc/db_schema.yaml * add test data and renumber sql-schema * sql-schema * sql-schema * Update module_tables.yaml * Update module_tables.yaml * Update timos.json * Update timos.snmprec * Rename 281.sql to 282.sql * update test data * db migration * Update 2019_01_16_195644_add_vrf_id_and_bgpLocalAs.php * update db schema * Update 2019_01_16_195644_add_vrf_id_and_bgpLocalAs.php * Update 2019_01_16_195644_add_vrf_id_and_bgpLocalAs.php * Update db_schema.yaml * update schema
This commit is contained in:
@@ -5,6 +5,71 @@ use LibreNMS\Exceptions\InvalidIpException;
|
||||
use LibreNMS\Util\IP;
|
||||
|
||||
if (Config::get('enable_bgp')) {
|
||||
if ($device['os'] == 'timos') {
|
||||
$bgpPeersCache =snmpwalk_cache_multi_oid($device, 'tBgpPeerNgTable', [], 'TIMETRA-BGP-MIB', 'nokia');
|
||||
foreach ($bgpPeersCache as $key => $value) {
|
||||
$oid = explode(".", $key);
|
||||
$vrfInstance = $oid[0];
|
||||
$address = str_replace($oid[0].".".$oid[1].".", '', $key);
|
||||
if (strlen($address) > 15) {
|
||||
$address = IP::fromHexString($address)->compressed();
|
||||
}
|
||||
$bgpPeers[$vrfInstance][$address] = $value;
|
||||
}
|
||||
unset($bgpPeersCache);
|
||||
|
||||
foreach ($bgpPeers as $vrfOid => $vrf) {
|
||||
$vrfId = dbFetchCell('SELECT vrf_id from `vrfs` WHERE vrf_oid = ?', [$vrfOid]);
|
||||
foreach ($vrf as $address => $value) {
|
||||
$astext = get_astext($value['tBgpPeerNgPeerAS4Byte']);
|
||||
|
||||
if (dbFetchCell('SELECT COUNT(*) from `bgpPeers` WHERE device_id = ? AND bgpPeerIdentifier = ? AND vrf_id = ?', [$device['device_id'], $address, $vrfId]) < '1') {
|
||||
$peers = [
|
||||
'device_id' => $device['device_id'],
|
||||
'vrf_id' => $vrfId,
|
||||
'bgpPeerIdentifier' => $address,
|
||||
'bgpPeerRemoteAs' => $value['tBgpPeerNgPeerAS4Byte'],
|
||||
'bgpPeerState' => 'idle',
|
||||
'bgpPeerAdminStatus' => 'stop',
|
||||
'bgpLocalAddr' => '0.0.0.0',
|
||||
'bgpPeerRemoteAddr' => '0.0.0.0',
|
||||
'bgpPeerInUpdates' => 0,
|
||||
'bgpPeerOutUpdates' => 0,
|
||||
'bgpPeerInTotalMessages' => 0,
|
||||
'bgpPeerOutTotalMessages' => 0,
|
||||
'bgpPeerFsmEstablishedTime' => 0,
|
||||
'bgpPeerInUpdateElapsedTime' => 0,
|
||||
'astext' => $astext,
|
||||
];
|
||||
dbInsert($peers, 'bgpPeers');
|
||||
if (Config::get('autodiscovery.bgp')) {
|
||||
$name = gethostbyaddr($address);
|
||||
discover_new_device($name, $device, 'BGP');
|
||||
}
|
||||
echo '+';
|
||||
} else {
|
||||
dbUpdate(['bgpPeerRemoteAs' => $value['tBgpPeerNgPeerAS4Byte'], 'astext' => $astext], 'bgpPeers', 'device_id = ? AND bgpPeerIdentifier = ? AND vrf_id = ?', [$device['device_id'], $address, $vrfId]);
|
||||
echo '.';
|
||||
}
|
||||
}
|
||||
}
|
||||
// clean up peers
|
||||
$peers = dbFetchRows('SELECT `B`.`vrf_id` AS `vrf_id`, `bgpPeerIdentifier`, `vrf_oid` FROM `bgpPeers` AS B LEFT JOIN `vrfs` AS V ON `B`.`vrf_id` = `V`.`vrf_id` WHERE `B`.`device_id` = ?', [$device['device_id']]);
|
||||
foreach ($peers as $value) {
|
||||
$vrfId = $value['vrf_id'];
|
||||
$vrfOid = $value['vrf_oid'];
|
||||
$address = $value['bgpPeerIdentifier'];
|
||||
|
||||
if (empty($bgpPeers[$vrfOid][$address])) {
|
||||
$deleted = dbDelete('bgpPeers', 'device_id = ? AND bgpPeerIdentifier = ? AND vrf_id = ?', [$device['device_id'], $address, $vrfId]);
|
||||
|
||||
echo str_repeat('-', $deleted);
|
||||
echo PHP_EOL;
|
||||
}
|
||||
}
|
||||
}
|
||||
unset($bgpPeers);
|
||||
|
||||
if (key_exists('vrf_lite_cisco', $device) && (count($device['vrf_lite_cisco'])!=0)) {
|
||||
$vrfs_lite_cisco = $device['vrf_lite_cisco'];
|
||||
} else {
|
||||
|
Reference in New Issue
Block a user