mirror of
https://github.com/librenms/librenms.git
synced 2024-10-07 16:52:45 +00:00
refactor: populate native vlans in the ports_vlan table for cisco devices too (#4805)
This commit is contained in:
committed by
Neil Lathwood
parent
bfe59646bf
commit
4ff9e84f4e
@@ -8,7 +8,17 @@ foreach ($vlans_db_raw as $vlan_db) {
|
||||
|
||||
// Create an empty array to record what VLANs we discover this session.
|
||||
$device['vlans'] = array();
|
||||
$valid_vlan_port_ids = array();
|
||||
$per_vlan_data = array(); // fill this with data for each vlan
|
||||
$valid_vlan_port = array();
|
||||
|
||||
// get a map of base port to ifIndex and the inverse
|
||||
$base_to_index = array();
|
||||
$tmp_base_indexes = snmpwalk_cache_oid($device, 'dot1dBasePortIfIndex', array(), 'BRIDGE-MIB');
|
||||
// flatten the array
|
||||
foreach ($tmp_base_indexes as $index => $array) {
|
||||
$base_to_index[$index] = $array['dot1dBasePortIfIndex'];
|
||||
}
|
||||
$index_to_base = array_flip($base_to_index);
|
||||
|
||||
require 'includes/discovery/vlans/q-bridge-mib.inc.php';
|
||||
require 'includes/discovery/vlans/cisco-vtp.inc.php';
|
||||
@@ -16,59 +26,49 @@ require 'includes/discovery/vlans/cisco-vtp.inc.php';
|
||||
// Fetch switchport <> VLAN relationships. This is DIRTY.
|
||||
foreach ($device['vlans'] as $domain_id => $vlans) {
|
||||
foreach ($vlans as $vlan_id => $vlan) {
|
||||
// FIXME - do this only when vlan type == ethernet?
|
||||
if (is_numeric($vlan_id) && ($vlan_id < 1002 || $vlan_id > 1005)) {
|
||||
// Ignore reserved VLAN IDs
|
||||
if ($device['os_group'] == 'cisco' || $device['os'] == 'ios') {
|
||||
// This shit only seems to work on IOS
|
||||
// Probably does not work with snmpv3. I have no real idea about what this code is really doing
|
||||
$vlan_device = array_merge($device, array('community' => $device['community'].'@'.$vlan_id));
|
||||
$vlan_data = snmpwalk_cache_oid($vlan_device, 'dot1dStpPortEntry', array(), 'BRIDGE-MIB:Q-BRIDGE-MIB');
|
||||
$vlan_data = snmpwalk_cache_oid($vlan_device, 'dot1dBasePortEntry', $vlan_data, 'BRIDGE-MIB:Q-BRIDGE-MIB');
|
||||
} elseif (isset($qbridge_data)) {
|
||||
$vlan_data = $qbridge_data[$vlan_id];
|
||||
// grab the populated data for this vlan
|
||||
$vlan_data = $per_vlan_data[$vlan_id];
|
||||
|
||||
echo "VLAN $vlan_id \n";
|
||||
|
||||
if ($vlan_data) {
|
||||
echo str_pad('dot1d id', 10).str_pad('ifIndex', 10).str_pad('Port Name', 25).str_pad('Priority', 10).str_pad('State', 15).str_pad('Cost', 10)."\n";
|
||||
}
|
||||
|
||||
foreach ($vlan_data as $ifIndex => $vlan_port) {
|
||||
$port = get_port_by_index_cache($device, $ifIndex);
|
||||
echo str_pad($vlan_port_id, 10).str_pad($ifIndex, 10).str_pad($port['ifDescr'], 25).str_pad($vlan_port['dot1dStpPortPriority'], 10).str_pad($vlan_port['dot1dStpPortState'], 15).str_pad($vlan_port['dot1dStpPortPathCost'], 10);
|
||||
|
||||
$db_w = array(
|
||||
'device_id' => $device['device_id'],
|
||||
'port_id' => $port['port_id'],
|
||||
'vlan' => $vlan_id,
|
||||
);
|
||||
|
||||
$db_a['baseport'] = $index_to_base[$ifIndex];
|
||||
$db_a['priority'] = isset($vlan_port['dot1dStpPortPriority']) ? $vlan_port['dot1dStpPortPriority'] : 0;
|
||||
$db_a['state'] = isset($vlan_port['dot1dStpPortState']) ? $vlan_port['dot1dStpPortState'] : 'unknown';
|
||||
$db_a['cost'] = isset($vlan_port['dot1dStpPortPathCost']) ? $vlan_port['dot1dStpPortPathCost'] : 0;
|
||||
$db_a['untagged'] = isset($vlan_port['untagged']) ? $vlan_port['untagged'] : 0;
|
||||
|
||||
$from_db = dbFetchRow('SELECT * FROM `ports_vlans` WHERE device_id = ? AND port_id = ? AND `vlan` = ?', array($device['device_id'], $port['port_id'], $vlan_id));
|
||||
|
||||
if ($from_db['port_vlan_id']) {
|
||||
$db_id = $from_db['port_vlan_id'];
|
||||
dbUpdate($db_a, 'ports_vlans', '`port_vlan_id` = ?', array($db_id));
|
||||
echo 'Updated';
|
||||
} else {
|
||||
$db_id = dbInsert(array_merge($db_w, $db_a), 'ports_vlans');
|
||||
echo 'Inserted';
|
||||
}
|
||||
$valid_vlan_port_ids[] = $db_id;
|
||||
|
||||
echo "VLAN $vlan_id \n";
|
||||
|
||||
if ($vlan_data) {
|
||||
echo str_pad('dot1d id', 10).str_pad('ifIndex', 10).str_pad('Port Name', 25).str_pad('Priority', 10).str_pad('State', 15).str_pad('Cost', 10)."\n";
|
||||
}
|
||||
|
||||
foreach ($vlan_data as $vlan_port_id => $vlan_port) {
|
||||
$port = get_port_by_index_cache($device, $vlan_port['dot1dBasePortIfIndex']);
|
||||
echo str_pad($vlan_port_id, 10).str_pad($vlan_port['dot1dBasePortIfIndex'], 10).str_pad($port['ifDescr'], 25).str_pad($vlan_port['dot1dStpPortPriority'], 10).str_pad($vlan_port['dot1dStpPortState'], 15).str_pad($vlan_port['dot1dStpPortPathCost'], 10);
|
||||
|
||||
$db_w = array(
|
||||
'device_id' => $device['device_id'],
|
||||
'port_id' => $port['port_id'],
|
||||
'vlan' => $vlan_id,
|
||||
);
|
||||
|
||||
$db_a['baseport'] = $vlan_port_id;
|
||||
$db_a['priority'] = isset($vlan_port['dot1dStpPortPriority']) ? $vlan_port['dot1dStpPortPriority'] : 0;
|
||||
$db_a['state'] = isset($vlan_port['dot1dStpPortState']) ? $vlan_port['dot1dStpPortState'] : 'unknown';
|
||||
$db_a['cost'] = isset($vlan_port['dot1dStpPortPathCost']) ? $vlan_port['dot1dStpPortPathCost'] : 0;
|
||||
$db_a['untagged'] = isset($vlan_port['untagged']) ? $vlan_port['untagged'] : 0;
|
||||
|
||||
$from_db = dbFetchRow('SELECT * FROM `ports_vlans` WHERE device_id = ? AND port_id = ? AND `vlan` = ?', array($device['device_id'], $port['port_id'], $vlan_id));
|
||||
|
||||
if ($from_db['port_vlan_id']) {
|
||||
$db_id = $from_db['port_vlan_id'];
|
||||
dbUpdate($db_a, 'ports_vlans', '`port_vlan_id` = ?', array($db_id));
|
||||
echo 'Updated';
|
||||
} else {
|
||||
$db_id = dbInsert(array_merge($db_w, $db_a), 'ports_vlans');
|
||||
echo 'Inserted';
|
||||
}
|
||||
$valid_vlan_port_ids[] = $db_id;
|
||||
|
||||
echo PHP_EOL;
|
||||
}//end foreach
|
||||
}//end if
|
||||
echo PHP_EOL;
|
||||
}//end foreach
|
||||
}//end foreach
|
||||
}//end foreach
|
||||
|
||||
// remove non-existent vlans
|
||||
foreach ($vlans_db as $domain_id => $vlans) {
|
||||
foreach ($vlans as $vlan_id => $vlan) {
|
||||
if (empty($device['vlans'][$domain_id][$vlan_id])) {
|
||||
@@ -82,3 +82,4 @@ $num = dbDelete('ports_vlans', '`device_id`=? AND `port_vlan_id` NOT IN ('.join(
|
||||
d_echo("Deleted $num vlan mappings\n");
|
||||
|
||||
unset($device['vlans']);
|
||||
unset($base_to_index, $tmp_base_indexes, $index_to_base, $per_vlan_data, $valid_vlan_port, $num);
|
||||
|
Reference in New Issue
Block a user