mirror of
https://github.com/librenms/librenms.git
synced 2024-10-07 16:52:45 +00:00
More updates for junos bgp polling
This commit is contained in:
@@ -111,6 +111,7 @@ else {
|
||||
echo ' | Prefixes: Unicast (';
|
||||
if ($vars['graph'] == 'prefixes_ipv4unicast') {
|
||||
echo "<span class='pagemenu-selected'>";
|
||||
$extra_sql = " AND `bgpLocalAddr` NOT LIKE '%:%'";
|
||||
}
|
||||
|
||||
echo generate_link('IPv4', $vars, array('view' => 'graphs', 'graph' => 'prefixes_ipv4unicast'));
|
||||
@@ -122,6 +123,7 @@ else {
|
||||
|
||||
if ($vars['graph'] == 'prefixes_ipv6unicast') {
|
||||
echo "<span class='pagemenu-selected'>";
|
||||
$extra_sql = " AND `bgpLocalAddr` LIKE '%:%'";
|
||||
}
|
||||
|
||||
echo generate_link('IPv6', $vars, array('view' => 'graphs', 'graph' => 'prefixes_ipv6unicast'));
|
||||
@@ -213,7 +215,7 @@ else {
|
||||
$where .= " AND (B.bgpPeerState != 'established')";
|
||||
}
|
||||
|
||||
$peer_query = 'select * from bgpPeers AS B, devices AS D WHERE B.device_id = D.device_id '.$where.' ORDER BY D.hostname, B.bgpPeerRemoteAs, B.bgpPeerIdentifier';
|
||||
$peer_query = "SELECT * FROM `bgpPeers` AS `B`, `devices` AS `D` WHERE `B`.`device_id` = `D`.`device_id` $where $extra_sql ORDER BY `D`.`hostname`, `B`.`bgpPeerRemoteAs`, `B`.`bgpPeerIdentifier`";
|
||||
foreach (dbFetchRows($peer_query) as $peer) {
|
||||
unset($alert, $bg_image);
|
||||
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
<?php
|
||||
if ($config['enable_bgp']) {
|
||||
// Discover BGP peers
|
||||
|
||||
|
||||
if( key_exists('vrf_lite_cisco', $device) && (count($device['vrf_lite_cisco'])!=0) ){
|
||||
$vrfs_lite_cisco = $device['vrf_lite_cisco'];
|
||||
}
|
||||
@@ -156,8 +156,8 @@ if ($config['enable_bgp']) {
|
||||
$safis[2] = 'multicast';
|
||||
|
||||
if (!isset($j_peerIndexes)) {
|
||||
$j_bgp = snmpwalk_cache_multi_oid($device, 'jnxBgpM2PeerTable', $jbgp, 'BGP4-V2-MIB-JUNIPER', $config['install_dir'].'/mibs/junos');
|
||||
|
||||
$j_bgp = snmpwalk_cache_multi_oid($device, 'jnxBgpM2PeerEntry', $jbgp, 'BGP4-V2-MIB-JUNIPER', $config['install_dir'].'/mibs/junos');
|
||||
print_r($j_bgp);
|
||||
foreach ($j_bgp as $index => $entry) {
|
||||
switch ($entry['jnxBgpM2PeerRemoteAddrType']) {
|
||||
case 'ipv4':
|
||||
|
||||
@@ -7,8 +7,7 @@ if ($config['enable_bgp']) {
|
||||
if (!empty($peers)) {
|
||||
|
||||
if ($device['os'] == 'junos') {
|
||||
$peer_data_check = snmp_walk($device, 'jnxBgpM2PeerIndex', '-Onq', 'BGP4-V2-MIB-JUNIPER', $config['install_dir'].'/mibs/junos');
|
||||
$peer_data_check = trim(str_replace('.1.3.6.1.4.1.2636.5.1.1.2.1.1.1.14.', '', $peer_data_check));
|
||||
$peer_data_check = snmpwalk_cache_long_oid($device, 'jnxBgpM2PeerIndex', '.1.3.6.1.4.1.2636.5.1.1.2.1.1.1.14', $peer_data_tmp, 'BGP4-V2-MIB-JUNIPER', $config['install_dir'].'/mibs/junos');
|
||||
} else {
|
||||
$peer_data_check = snmpwalk_cache_oid($device, 'cbgpPeer2RemoteAs', array(), 'CISCO-BGP4-MIB', $config['mibdir']);
|
||||
}
|
||||
@@ -92,54 +91,46 @@ if ($config['enable_bgp']) {
|
||||
// FIXME - needs moved to function
|
||||
//$peer_cmd = $config['snmpwalk'].' -M '.$config['mibdir'].'/junos -m BGP4-V2-MIB-JUNIPER -OUnq -'.$device['snmpver'].' '.snmp_gen_auth($device).' '.$device['hostname'].':'.$device['port'];
|
||||
|
||||
foreach (explode("\n", $peer_data_check) as $tmp) {
|
||||
list($peer_ip_snmp, $peer_index) = explode(' ', $tmp);
|
||||
foreach ($peer_data_check as $hash => $index) {
|
||||
$peer_ip_snmp = ltrim($index['orig'], '.');
|
||||
$octets = count(explode(".", $peer_ip_snmp));
|
||||
if ($octets > 11) {
|
||||
// ipv6
|
||||
$peer_ip = Net_IPv6::compress(snmp2ipv6(implode('.', array_slice(explode('.', $peer_ip_snmp), (count(explode('.', $peer_ip_snmp)) - 16)))));
|
||||
$tmp_peer_ip = Net_IPv6::compress(snmp2ipv6(implode('.', array_slice(explode('.', $peer_ip_snmp), (count(explode('.', $peer_ip_snmp)) - 16)))));
|
||||
} else {
|
||||
// ipv4
|
||||
$peer_ip = implode('.', array_slice(explode('.', $peer_ip_snmp), (count(explode('.', $peer_ip_snmp)) - 4)));
|
||||
$tmp_peer_ip = implode('.', array_slice(explode('.', $peer_ip_snmp), (count(explode('.', $peer_ip_snmp)) - 4)));
|
||||
}
|
||||
$junos[$peer_ip]['oid'] = $peer_ip_snmp;
|
||||
$junos[$peer_ip]['index'] = $peer_index;
|
||||
$junos[$tmp_peer_ip]['hash'] = $hash;
|
||||
$junos[$tmp_peer_ip]['index'] = $index['jnxBgpM2PeerIndex'];
|
||||
}
|
||||
}
|
||||
|
||||
$peer_data_tmp = snmp_get_multi(
|
||||
$device,
|
||||
array(
|
||||
'jnxBgpM2PeerState.'.$junos[$peer_ip]['oid'],
|
||||
'jnxBgpM2PeerStatus.'.$junos[$peer_ip]['oid'],
|
||||
'jnxBgpM2PeerInUpdates.'.$junos[$peer_ip]['oid'],
|
||||
'jnxBgpM2PeerOutUpdates.'.$junos[$peer_ip]['oid'],
|
||||
'jnxBgpM2PeerInTotalMessages.'.$junos[$peer_ip]['oid'],
|
||||
'jnxBgpM2PeerOutTotalMessages.'.$junos[$peer_ip]['oid'],
|
||||
'jnxBgpM2PeerFsmEstablishedTime.'.$junos[$peer_ip]['oid'],
|
||||
'jnxBgpM2PeerInUpdatesElapsedTime.'.$junos[$peer_ip]['oid'],
|
||||
'jnxBgpM2PeerLocalAddr.'.$junos[$peer_ip]['oid'],
|
||||
'jnxBgpM2PeerRemoteAddrType.'.$junos[$peer_ip]['oid'],
|
||||
),
|
||||
'-OQnUs',
|
||||
'BGP4-V2-MIB-JUNIPER',
|
||||
$config['mibdir'].'/junos'
|
||||
);
|
||||
$peer_data_tmp = array_shift($peer_data_tmp);
|
||||
d_echo($peer_data_tmp);
|
||||
|
||||
$bgpPeerState = $peer_data_tmp['jnxBgpM2PeerState'];
|
||||
$bgpPeerAdminStatus = $peer_data_tmp['jnxBgpM2PeerStatus'];
|
||||
$bgpPeerInUpdates = $peer_data_tmp['jnxBgpM2PeerInUpdates'];
|
||||
$bgpPeerOutUpdates = $peer_data_tmp['jnxBgpM2PeerOutUpdates'];
|
||||
$bgpPeerInTotalMessages = $peer_data_tmp['jnxBgpM2PeerInTotalMessages'];
|
||||
$bgpPeerOutTotalMessages = $peer_data_tmp['jnxBgpM2PeerOutTotalMessages'];
|
||||
$bgpPeerFsmEstablishedTime = $peer_data_tmp['jnxBgpM2PeerFsmEstablishedTime'];
|
||||
$bgpPeerInUpdateElapsedTime = $peer_data_tmp['jnxBgpM2PeerInUpdatesElapsedTime'];
|
||||
if ($peer_data_tmp['jnxBgpM2PeerRemoteAddrType'] == 'ipv4') {
|
||||
$bgpLocalAddr = long2ip(hexdec($peer_data_tmp['jnxBgpM2PeerLocalAddr']));
|
||||
} elseif ($peer_data_tmp['jnxBgpM2PeerRemoteAddrType'] == 'ipv6') {
|
||||
$ip6 = trim(str_replace(' ', '', $peer_data_tmp['jnxBgpM2PeerLocalAddr']), '"');
|
||||
if (!isset($peer_data_tmp)) {
|
||||
$peer_data_tmp = snmpwalk_cache_long_oid($device, 'jnxBgpM2PeerState', '.1.3.6.1.4.1.2636.5.1.1.2.1.1.1.2', $peer_data_tmp, 'BGP4-V2-MIB-JUNIPER', $config['install_dir'].'/mibs/junos');
|
||||
$peer_data_tmp = snmpwalk_cache_long_oid($device, 'jnxBgpM2PeerStatus', '.1.3.6.1.4.1.2636.5.1.1.2.1.1.1.3', $peer_data_tmp, 'BGP4-V2-MIB-JUNIPER', $config['install_dir'].'/mibs/junos');
|
||||
$peer_data_tmp = snmpwalk_cache_long_oid($device, 'jnxBgpM2PeerInUpdates', '.1.3.6.1.4.1.2636.5.1.1.2.6.1.1.1', $peer_data_tmp, 'BGP4-V2-MIB-JUNIPER', $config['install_dir'].'/mibs/junos');
|
||||
$peer_data_tmp = snmpwalk_cache_long_oid($device, 'jnxBgpM2PeerOutUpdates', '.1.3.6.1.4.1.2636.5.1.1.2.6.1.1.2', $peer_data_tmp, 'BGP4-V2-MIB-JUNIPER', $config['install_dir'].'/mibs/junos');
|
||||
$peer_data_tmp = snmpwalk_cache_long_oid($device, 'jnxBgpM2PeerInTotalMessages', '.1.3.6.1.4.1.2636.5.1.1.2.6.1.1.3', $peer_data_tmp, 'BGP4-V2-MIB-JUNIPER', $config['install_dir'].'/mibs/junos');
|
||||
$peer_data_tmp = snmpwalk_cache_long_oid($device, 'jnxBgpM2PeerOutTotalMessages', '.1.3.6.1.4.1.2636.5.1.1.2.6.1.1.4', $peer_data_tmp, 'BGP4-V2-MIB-JUNIPER', $config['install_dir'].'/mibs/junos');
|
||||
$peer_data_tmp = snmpwalk_cache_long_oid($device, 'jnxBgpM2PeerFsmEstablishedTime', '.1.3.6.1.4.1.2636.5.1.1.2.4.1.1.1', $peer_data_tmp, 'BGP4-V2-MIB-JUNIPER', $config['install_dir'].'/mibs/junos');
|
||||
$peer_data_tmp = snmpwalk_cache_long_oid($device, 'jnxBgpM2PeerInUpdatesElapsedTime', '.1.3.6.1.4.1.2636.5.1.1.2.4.1.1.2', $peer_data_tmp, 'BGP4-V2-MIB-JUNIPER', $config['install_dir'].'/mibs/junos');
|
||||
$peer_data_tmp = snmpwalk_cache_long_oid($device, 'jnxBgpM2PeerLocalAddr', '.1.3.6.1.4.1.2636.5.1.1.2.1.1.1.7', $peer_data_tmp, 'BGP4-V2-MIB-JUNIPER', $config['install_dir'].'/mibs/junos');
|
||||
$peer_data_tmp = snmpwalk_cache_long_oid($device, 'jnxBgpM2PeerRemoteAddrType', '.1.3.6.1.4.1.2636.5.1.1.2.1.1.1.10', $peer_data_tmp, 'BGP4-V2-MIB-JUNIPER', $config['install_dir'].'/mibs/junos');
|
||||
d_echo($peer_data_tmp);
|
||||
}
|
||||
$bgpPeerState = $peer_data_tmp[$junos[$peer_ip]['hash']]['jnxBgpM2PeerState'];
|
||||
$bgpPeerAdminStatus = $peer_data_tmp[$junos[$peer_ip]['hash']]['jnxBgpM2PeerStatus'];
|
||||
$bgpPeerInUpdates = $peer_data_tmp[$junos[$peer_ip]['hash']]['jnxBgpM2PeerInUpdates'];
|
||||
$bgpPeerOutUpdates = $peer_data_tmp[$junos[$peer_ip]['hash']]['jnxBgpM2PeerOutUpdates'];
|
||||
$bgpPeerInTotalMessages = $peer_data_tmp[$junos[$peer_ip]['hash']]['jnxBgpM2PeerInTotalMessages'];
|
||||
$bgpPeerOutTotalMessages = $peer_data_tmp[$junos[$peer_ip]['hash']]['jnxBgpM2PeerOutTotalMessages'];
|
||||
$bgpPeerFsmEstablishedTime = $peer_data_tmp[$junos[$peer_ip]['hash']]['jnxBgpM2PeerFsmEstablishedTime'];
|
||||
$bgpPeerInUpdateElapsedTime = $peer_data_tmp[$junos[$peer_ip]['hash']]['jnxBgpM2PeerInUpdatesElapsedTime'];
|
||||
if ($peer_data_tmp[$junos[$peer_ip]['hash']]['jnxBgpM2PeerRemoteAddrType'] == 'ipv4') {
|
||||
$bgpLocalAddr = long2ip(hexdec($peer_data_tmp[$junos[$peer_ip]['hash']]['jnxBgpM2PeerLocalAddr']));
|
||||
} elseif ($peer_data_tmp[$junos[$peer_ip]['hash']]['jnxBgpM2PeerRemoteAddrType'] == 'ipv6') {
|
||||
$ip6 = trim(str_replace(' ', '', $peer_data_tmp[$junos[$peer_ip]['hash']]['jnxBgpM2PeerLocalAddr']), '"');
|
||||
$ip6 = substr($ip6, 0, 4).':'.substr($ip6, 4, 4).':'.substr($ip6, 8, 4).':'.substr($ip6, 12, 4).':'.substr($ip6, 16, 4).':'.substr($ip6, 20, 4).':'.substr($ip6, 24, 4).':'.substr($ip6, 28, 4);
|
||||
$bgpLocalAddr = Net_IPv6::compress($ip6);
|
||||
}
|
||||
@@ -288,19 +279,22 @@ if ($config['enable_bgp']) {
|
||||
}//end if
|
||||
|
||||
if ($device['os'] == 'junos') {
|
||||
// Missing: cbgpPeerAdminLimit cbgpPeerPrefixThreshold cbgpPeerPrefixClearThreshold cbgpPeerSuppressedPrefixes cbgpPeerWithdrawnPrefixes
|
||||
$safis['unicast'] = 1;
|
||||
$safis['multicast'] = 2;
|
||||
$afis['ipv4'] = 1;
|
||||
$afis['ipv6'] = 2;
|
||||
|
||||
if (!isset($j_prefixes)) {
|
||||
$j_prefixes = snmpwalk_cache_multi_oid($device, 'jnxBgpM2PrefixCountersTable', $jbgp, 'BGP4-V2-MIB-JUNIPER', $config['install_dir'].'/mibs/junos');
|
||||
$j_prefixes = snmpwalk_cache_multi_oid($device, 'jnxBgpM2PrefixInPrefixesAccepted', $j_prefixes, 'BGP4-V2-MIB-JUNIPER', $config['install_dir'].'/mibs/junos', '-OQnU');
|
||||
$j_prefixes = snmpwalk_cache_multi_oid($device, 'jnxBgpM2PrefixInPrefixesRejected', $j_prefixes, 'BGP4-V2-MIB-JUNIPER', $config['install_dir'].'/mibs/junos', '-OQnU');
|
||||
$j_prefixes = snmpwalk_cache_multi_oid($device, 'jnxBgpM2PrefixOutPrefixes', $j_prefixes, 'BGP4-V2-MIB-JUNIPER', $config['install_dir'].'/mibs/junos', '-OQnU');
|
||||
d_echo($j_prefixes);
|
||||
}
|
||||
|
||||
$cbgpPeerAcceptedPrefixes = array_shift($j_prefixes['1.3.6.1.4.1.2636.5.1.1.2.6.2.1.8.'.$junos[$peer_ip]['index'].".$afis[$afi].".$safis[$safi]]);
|
||||
$cbgpPeerDeniedPrefixes = array_shift($j_prefixes['1.3.6.1.4.1.2636.5.1.1.2.6.2.1.9.'.$junos[$peer_ip]['index'].".$afis[$afi].".$safis[$safi]]);
|
||||
$cbgpPeerAdvertisedPrefixes = array_shift($j_prefixes['1.3.6.1.4.1.2636.5.1.1.2.6.2.1.10.'.$junos[$peer_ip]['index'].".$afis[$afi].".$safis[$safi]]);
|
||||
|
||||
$cbgpPeerAcceptedPrefixes = $j_prefixes[$junos[$peer_ip]['index'].".$afi.".$safis[$safi]]['jnxBgpM2PrefixInPrefixesAccepted'];
|
||||
$cbgpPeerDeniedPrefixes = $j_prefixes[$junos[$peer_ip]['index'].".$afi.".$safis[$safi]]['jnxBgpM2PrefixInPrefixesRejected'];
|
||||
$cbgpPeerAdvertisedPrefixes = $j_prefixes[$junos[$peer_ip]['index'].".$afi.".$safis[$safi]]['jnxBgpM2PrefixOutPrefixes'];
|
||||
|
||||
unset($j_prefixes);
|
||||
}//end if
|
||||
|
||||
// FIXME THESE FIELDS DO NOT EXIST IN THE DATABASE!
|
||||
@@ -357,3 +351,6 @@ if ($config['enable_bgp']) {
|
||||
} //end foreach
|
||||
} //end if
|
||||
} //end if
|
||||
|
||||
unset($$peer_data_tmp);
|
||||
unset($j_prefixes);
|
||||
|
||||
@@ -367,6 +367,26 @@ function snmpwalk_cache_oid($device, $oid, $array, $mib=null, $mibdir=null, $snm
|
||||
|
||||
}//end snmpwalk_cache_oid()
|
||||
|
||||
function snmpwalk_cache_long_oid($device, $oid, $noid, $array, $mib=null, $mibdir=null, $snmpflags='-OQnU') {
|
||||
$data = snmp_walk($device, $oid, $snmpflags, $mib, $mibdir);
|
||||
foreach (explode("\n", $data) as $entry) {
|
||||
list($tmp_oid,$value) = explode('=', $entry, 2);
|
||||
$tmp_oid = trim($tmp_oid);
|
||||
$value = trim($value);
|
||||
$tmp_index = str_replace($noid, '', $tmp_oid);
|
||||
$index = md5($tmp_index);
|
||||
if (!empty($index) && !empty($oid)) {
|
||||
$array[$index][$oid] = $value;
|
||||
if (empty($array[$index]['orig'])) {
|
||||
$array[$index]['orig'] = $tmp_index;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return $array;
|
||||
|
||||
}//end snmpwalk_cache_oid()
|
||||
|
||||
|
||||
// just like snmpwalk_cache_oid except that it returns the numerical oid as the index
|
||||
// this is useful when the oid is indexed by the mac address and snmpwalk would
|
||||
@@ -378,11 +398,11 @@ function snmpwalk_cache_oid_num($device, $oid, $array, $mib=null, $mibdir=null)
|
||||
}//end snmpwalk_cache_oid_num()
|
||||
|
||||
|
||||
function snmpwalk_cache_multi_oid($device, $oid, $array, $mib=null, $mibdir=null) {
|
||||
function snmpwalk_cache_multi_oid($device, $oid, $array, $mib=null, $mibdir=null, $snmpflags='-OQUs') {
|
||||
global $cache;
|
||||
|
||||
if (!(is_array($cache['snmp'][$device['device_id']]) && array_key_exists($oid, $cache['snmp'][$device['device_id']]))) {
|
||||
$data = snmp_walk($device, $oid, '-OQUs', $mib, $mibdir);
|
||||
$data = snmp_walk($device, $oid, $snmpflags, $mib, $mibdir);
|
||||
foreach (explode("\n", $data) as $entry) {
|
||||
list($r_oid,$value) = explode('=', $entry, 2);
|
||||
$r_oid = trim($r_oid);
|
||||
|
||||
Reference in New Issue
Block a user