mirror of
https://github.com/librenms/librenms.git
synced 2024-10-07 16:52:45 +00:00
refactored bgp discovery
git-svn-id: http://www.observium.org/svn/observer/trunk@649 61d68cd4-352d-0410-923a-c4978735b2b8
This commit is contained in:
@ -8,92 +8,49 @@
|
||||
$as_cmd .= ".1.3.6.1.2.1.15.2";
|
||||
$bgpLocalAs = trim(shell_exec($as_cmd));
|
||||
|
||||
if($bgpLocalAs && !strstr($bgpLocalAs, " ")) {
|
||||
|
||||
if($bgpLocalAs && !strstr($bgpLocalAs, " "))
|
||||
{
|
||||
echo("AS$bgpLocalAs ");
|
||||
|
||||
if($bgpLocalAs != $device['bgpLocalAs']) { mysql_query("UPDATE devices SET bgpLocalAs = '$bgpLocalAs' WHERE device_id = '".$device['device_id']."'"); echo("Updated AS "); }
|
||||
if($bgpLocalAs != $device['bgpLocalAs'])
|
||||
{
|
||||
mysql_query("UPDATE devices SET bgpLocalAs = '$bgpLocalAs' WHERE device_id = '".$device['device_id']."'"); echo("Updated AS ");
|
||||
}
|
||||
|
||||
$peers_cmd = $config['snmpwalk'] . " -m BGP4-MIB -CI -Oq -" . $device['snmpver'] . " -c" . $device['community'] . " " . $device['hostname'].":".$device['port'] . " ";
|
||||
$peers_cmd .= "BGP4-MIB::bgpPeerRemoteAs";
|
||||
$peers = trim(str_replace("BGP4-MIB::bgpPeerRemoteAs.", "", `$peers_cmd`));
|
||||
foreach (explode("\n", $peers) as $peer) {
|
||||
|
||||
foreach (explode("\n", $peers) as $peer)
|
||||
{
|
||||
list($peer_ip, $peer_as) = split(" ", $peer);
|
||||
if($peer && $peer_ip != "0.0.0.0") {
|
||||
|
||||
$peerlist[] = $device['device_id'] ." $peer_ip";
|
||||
|
||||
$astext = get_astext($peer_as);
|
||||
|
||||
# echo(str_pad($peer_ip, 40) . " AS$peer_as ");
|
||||
|
||||
#echo("$peer_ip AS$peer_as ");
|
||||
if(mysql_result(mysql_query("SELECT COUNT(*) FROM `bgpPeers` WHERE `device_id` = '".$device['device_id']."' AND bgpPeerIdentifier = '$peer_ip'"),0) < '1') {
|
||||
$add = mysql_query("INSERT INTO bgpPeers (`device_id`, `bgpPeerIdentifier`, `bgpPeerRemoteAS`) VALUES ('".$device['device_id']."','$peer_ip','$peer_as')");
|
||||
echo("+");
|
||||
} else {
|
||||
$update = mysql_query("UPDATE `bgpPeers` SET bgpPeerRemoteAs = " . $peer_as . ", astext = '" . mysql_escape_string($astext) . "' WHERE `device_id` = '".$device['device_id']."' AND bgpPeerIdentifier = '$peer_ip'");
|
||||
echo(".");
|
||||
}
|
||||
|
||||
## Get afi/safi and populate cbgp on cisco ios (xe/xr)
|
||||
if($device['os'] == "ios") {
|
||||
unset($af_list);
|
||||
$af_cmd = $config['snmpwalk'] . " -CI -m CISCO-BGP4-MIB -OsQ -" . $device['snmpver'] . " -c" . $device['community'] . " " . $device['hostname'].":".$device['port'] . " ";
|
||||
$af_cmd .= "cbgpPeerAddrFamilyName." . $peer_ip;
|
||||
$afs = trim(str_replace("cbgpPeerAddrFamilyName.".$peer_ip.".", "", `$af_cmd`));
|
||||
foreach (explode("\n", $afs) as $af) {
|
||||
list($afisafi, $text) = explode(" = ", $af);
|
||||
list($afi, $safi) = explode(".", $afisafi);
|
||||
if($afi && $safi) {
|
||||
# echo("($afi:$safi)");
|
||||
$af_list['$afi']['$safi'] = 1;
|
||||
if(mysql_result(mysql_query("SELECT COUNT(*) FROM `bgpPeers_cbgp` WHERE `device_id` = '".$device['device_id']."' AND bgpPeerIdentifier = '$peer_ip' AND afi = '$afi' AND safi = '$safi'"),0) == 0) {
|
||||
mysql_query("INSERT INTO `bgpPeers_cbgp` (device_id,bgpPeerIdentifier, afi, safi) VALUES ('".$device['device_id']."','$peer_ip','$afi','$safi')");
|
||||
}
|
||||
}
|
||||
}
|
||||
$af_query = mysql_query("SELECT * FROM bgpPeers_cbgp WHERE `device_id` = '".$device['device_id']."' AND bgpPeerIdentifier = '$peer_ip'");
|
||||
while ($entry = mysql_fetch_array($af_query)) {
|
||||
$afi = $entry['afi'];
|
||||
$afi = $entry['safi'];
|
||||
if (!$af_list['$afi']['$safi']) {
|
||||
mysql_query("DELETE FROM `bgpPeers_cbgp` WHERE `device_id` = '".$device['device_id']."' AND bgpPeerIdentifier = '$peer_ip' AND afi = '$afi' AND safi = '$safi'");
|
||||
}
|
||||
} # AF list
|
||||
} # if os = ios
|
||||
} # If Peer
|
||||
|
||||
if($peer && $peer_ip != "0.0.0.0")
|
||||
{
|
||||
if ($debug) echo "Found peer $peer_ip (AS$peer_as)\n";
|
||||
$peerlist[] = array('ip' => $peer_ip, 'as' => $peer_as);
|
||||
}
|
||||
} # Foreach
|
||||
|
||||
if ($device['os'] == "junos")
|
||||
## Juniper BGP4-V2 MIB, ipv6 only for now, because v4 should be covered in BGP4-MIB above
|
||||
$peers_cmd = $config['snmpwalk'] . " -m BGP4-V2-MIB-JUNIPER -CI -Onq -" . $device['snmpver'] . " -c" . $device['community'] . " " . $device['hostname'].":".$device['port'] . " ";
|
||||
$peers_cmd .= "jnxBgpM2PeerRemoteAs.0.ipv6"; # FIXME: is .0 the only possible value here?
|
||||
$peers = trim(str_replace(".1.3.6.1.4.1.2636.5.1.1.2.1.1.1.13.0.","", `$peers_cmd`));
|
||||
foreach (explode("\n", $peers) as $peer) {
|
||||
list($peer_ip_snmp, $peer_as) = split(" ", $peer);
|
||||
{
|
||||
## Juniper BGP4-V2 MIB, ipv6 only for now, because v4 should be covered in BGP4-MIB above
|
||||
$peers_cmd = $config['snmpwalk'] . " -m BGP4-V2-MIB-JUNIPER -CI -Onq -" . $device['snmpver'] . " -c" . $device['community'] . " " . $device['hostname'].":".$device['port'] . " ";
|
||||
$peers_cmd .= "jnxBgpM2PeerRemoteAs.0.ipv6"; # FIXME: is .0 the only possible value here?
|
||||
$peers = trim(str_replace(".1.3.6.1.4.1.2636.5.1.1.2.1.1.1.13.0.","", `$peers_cmd`));
|
||||
foreach (explode("\n", $peers) as $peer)
|
||||
{
|
||||
list($peer_ip_snmp, $peer_as) = split(" ", $peer);
|
||||
|
||||
# Magic! Basically, takes SNMP form and finds peer IPs from the walk OIDs.
|
||||
$peer_ip = Net_IPv6::compress(snmp2ipv6(implode('.',array_slice(explode('.',$peer_ip_snmp),count($ipv6)-16))));
|
||||
# Magic! Basically, takes SNMP form and finds peer IPs from the walk OIDs.
|
||||
$peer_ip = Net_IPv6::compress(snmp2ipv6(implode('.',array_slice(explode('.',$peer_ip_snmp),count($ipv6)-16))));
|
||||
|
||||
if($peer) {
|
||||
|
||||
$peerlist[] = $device['device_id'] ." $peer_ip";
|
||||
|
||||
$astext = get_astext($peer_as);
|
||||
|
||||
#echo("$peer_ip AS$peer_as ");
|
||||
if(mysql_result(mysql_query("SELECT COUNT(*) FROM `bgpPeers` WHERE `device_id` = '".$device['device_id']."' AND bgpPeerIdentifier = '$peer_ip'"),0) < '1') {
|
||||
$add = mysql_query("INSERT INTO bgpPeers (`device_id`, `bgpPeerIdentifier`, `bgpPeerRemoteAS`) VALUES ('".$device['device_id']."','$peer_ip','$peer_as')");
|
||||
echo("+");
|
||||
} else {
|
||||
$update = mysql_query("UPDATE `bgpPeers` SET bgpPeerRemoteAs = " . $peer_as . ", astext = '" . mysql_escape_string($astext) . "' WHERE `device_id` = '".$device['device_id']."' AND bgpPeerIdentifier = '$peer_ip'");
|
||||
echo(".");
|
||||
if($peer)
|
||||
{
|
||||
if ($debug) echo "Found peer $peer_ip (AS$peer_as)\n";
|
||||
$peerlist[] = array('ip' => $peer_ip, 'as' => $peer_as);
|
||||
}
|
||||
|
||||
} # If Peer
|
||||
} # Foreach
|
||||
} # Foreach
|
||||
} # OS junos
|
||||
} else {
|
||||
echo("No BGP on host");
|
||||
if($device['bgpLocalAs']) {
|
||||
@ -101,6 +58,55 @@
|
||||
} # End if
|
||||
} # End if
|
||||
|
||||
## Process disovered peers
|
||||
|
||||
foreach ($peerlist as $peer)
|
||||
{
|
||||
$astext = get_astext($peer['as']);
|
||||
|
||||
if(mysql_result(mysql_query("SELECT COUNT(*) FROM `bgpPeers` WHERE `device_id` = '".$device['device_id']."' AND bgpPeerIdentifier = '".$peer['ip']."'"),0) < '1')
|
||||
{
|
||||
$add = mysql_query("INSERT INTO bgpPeers (`device_id`, `bgpPeerIdentifier`, `bgpPeerRemoteAS`) VALUES ('".$device['device_id']."','".$peer['ip']."','".$peer['as']."')");
|
||||
echo("+");
|
||||
} else {
|
||||
$update = mysql_query("UPDATE `bgpPeers` SET bgpPeerRemoteAs = " . $peer['as'] . ", astext = '" . mysql_escape_string($astext) . "' WHERE `device_id` = '".$device['device_id']."' AND bgpPeerIdentifier = '".$peer['ip']."'");
|
||||
echo(".");
|
||||
}
|
||||
|
||||
## Get afi/safi and populate cbgp on cisco ios (xe/xr)
|
||||
if ($device['os'] == "ios")
|
||||
{
|
||||
unset($af_list);
|
||||
$af_cmd = $config['snmpwalk'] . " -CI -m CISCO-BGP4-MIB -OsQ -" . $device['snmpver'] . " -c" . $device['community'] . " " . $device['hostname'].":".$device['port'] . " ";
|
||||
$af_cmd .= "cbgpPeerAddrFamilyName." . $peer['ip'];
|
||||
$afs = trim(str_replace("cbgpPeerAddrFamilyName.".$peer['ip'].".", "", `$af_cmd`));
|
||||
foreach (explode("\n", $afs) as $af)
|
||||
{
|
||||
list($afisafi, $text) = explode(" = ", $af);
|
||||
list($afi, $safi) = explode(".", $afisafi);
|
||||
if($afi && $safi)
|
||||
{
|
||||
$af_list['$afi']['$safi'] = 1;
|
||||
if(mysql_result(mysql_query("SELECT COUNT(*) FROM `bgpPeers_cbgp` WHERE `device_id` = '".$device['device_id']."' AND bgpPeerIdentifier = '".$peer['ip']."' AND afi = '$afi' AND safi = '$safi'"),0) == 0)
|
||||
{
|
||||
mysql_query("INSERT INTO `bgpPeers_cbgp` (device_id,bgpPeerIdentifier, afi, safi) VALUES ('".$device['device_id']."','".$peer['ip']."','$afi','$safi')");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
$af_query = mysql_query("SELECT * FROM bgpPeers_cbgp WHERE `device_id` = '".$device['device_id']."' AND bgpPeerIdentifier = '".$peer['ip']."'");
|
||||
while ($entry = mysql_fetch_array($af_query))
|
||||
{
|
||||
$afi = $entry['afi'];
|
||||
$afi = $entry['safi'];
|
||||
if (!$af_list['$afi']['$safi'])
|
||||
{
|
||||
mysql_query("DELETE FROM `bgpPeers_cbgp` WHERE `device_id` = '".$device['device_id']."' AND bgpPeerIdentifier = '".$peer['ip']."' AND afi = '$afi' AND safi = '$safi'");
|
||||
}
|
||||
} # AF list
|
||||
} # if os = ios
|
||||
} # Foreach
|
||||
|
||||
## Delete removed peers
|
||||
|
||||
$sql = "SELECT * FROM bgpPeers AS B, devices AS D WHERE B.device_id = D.device_id AND D.device_id = '".$device['device_id']."'";
|
||||
@ -109,10 +115,10 @@ $query = mysql_query($sql);
|
||||
while ($entry = mysql_fetch_array($query)) {
|
||||
unset($exists);
|
||||
$i = 0;
|
||||
while ($i < count($peerlist) && !$exists) {
|
||||
$checkme = $entry['device_id'] . " " . $entry['bgpPeerIdentifier'];
|
||||
if ($peerlist[$i] == $checkme) { $exists = 1; }
|
||||
$i++;
|
||||
while ($i < count($peerlist) && !$exists)
|
||||
{
|
||||
if ($peerlist[$i]['ip'] == $entry['bgpPeerIdentifier']) { $exists = 1; }
|
||||
$i++;
|
||||
}
|
||||
if(!$exists) {
|
||||
mysql_query("DELETE FROM bgpPeers WHERE bgpPeer_id = '" . $entry['bgpPeer_id'] . "'");
|
||||
|
Reference in New Issue
Block a user