2008-03-22 23:09:35 +00:00
|
|
|
<?
|
|
|
|
|
|
|
|
# Discover interfaces
|
|
|
|
|
|
|
|
echo("Interfaces : ");
|
|
|
|
|
2009-04-28 10:28:58 +00:00
|
|
|
$cmd = $config['snmpbulkwalk'] . " -m IF-MIB -O nsq -" . $device['snmpver'] . " -c " . $device['community'] . " " . $device['hostname'].":".$device['port'];
|
|
|
|
$cmd .= " ifDescr";
|
2008-03-22 23:09:35 +00:00
|
|
|
$interfaces = trim(shell_exec($cmd));
|
|
|
|
$interfaces = str_replace("\"", "", $interfaces);
|
|
|
|
$interfaces = str_replace("ifDescr.", "", $interfaces);
|
|
|
|
$interfaces = str_replace(" ", "||", $interfaces);
|
|
|
|
|
|
|
|
$interface_ignored = 0;
|
|
|
|
$interface_added = 0;
|
|
|
|
|
|
|
|
foreach(explode("\n", $interfaces) as $entry){
|
|
|
|
|
|
|
|
$entry = trim($entry);
|
2009-04-28 10:28:58 +00:00
|
|
|
list($ifIndex, $ifDescr) = explode("||", $entry);
|
|
|
|
|
|
|
|
# if($config['ifdescr'][$device['os']]) {
|
|
|
|
# $ifDescr = shell_exec($config['snmpget'] . " -m IF-MIB -O qv -" . $device['snmpver'] . " -c " . $device['community'] . " " . $device['hostname'].":".$device['port'] . " ifDescr.$ifIndex");
|
|
|
|
# $ifDescr = str_replace("No Such Object available on this agent at this OID", "", $ifDescr);
|
|
|
|
# $ifDescr = str_replace("No Such Instance currently exists at this OID", "", $ifDescr);
|
|
|
|
# $ifDescr = trim(str_replace("\"", "", $ifDescr));
|
|
|
|
# } else { $ifDescr = trim(str_replace("\"", "", $ifName)); }
|
2008-11-21 14:44:29 +00:00
|
|
|
|
2008-11-27 12:36:37 +00:00
|
|
|
|
2008-03-22 23:09:35 +00:00
|
|
|
if(!strstr($entry, "irtual")) {
|
2008-11-21 15:06:23 +00:00
|
|
|
$if = trim(strtolower($ifDescr));
|
2008-03-22 23:09:35 +00:00
|
|
|
$nullintf = 0;
|
|
|
|
foreach($config['bad_if'] as $bi) {
|
|
|
|
if (strstr($if, $bi)) {
|
|
|
|
$nullintf = 1;
|
|
|
|
}
|
|
|
|
}
|
2008-11-27 12:36:37 +00:00
|
|
|
$ifDescr = fixifName($ifDescr);
|
2008-03-22 23:09:35 +00:00
|
|
|
if (preg_match('/serial[0-9]:/', $if)) { $nullintf = '1'; }
|
2009-05-03 22:13:41 +00:00
|
|
|
if(!$config['allow_ng']) {
|
|
|
|
if (preg_match('/ng[0-9]+$/', $if)) { $nullintf = '1'; }
|
|
|
|
}
|
2008-03-22 23:09:35 +00:00
|
|
|
if ($nullintf == 0) {
|
|
|
|
if(mysql_result(mysql_query("SELECT COUNT(*) FROM `interfaces` WHERE `device_id` = '".$device['device_id']."' AND `ifIndex` = '$ifIndex'"), 0) == '0') {
|
2008-11-19 12:12:54 +00:00
|
|
|
mysql_query("INSERT INTO `interfaces` (`device_id`,`ifIndex`,`ifDescr`) VALUES ('".$device['device_id']."','$ifIndex','$ifDescr')");
|
2008-03-27 10:59:10 +00:00
|
|
|
# Add Interface
|
2008-03-27 11:03:16 +00:00
|
|
|
echo("+");
|
2008-04-03 21:52:59 +00:00
|
|
|
} else {
|
2008-11-21 15:06:23 +00:00
|
|
|
mysql_query("UPDATE `interfaces` SET `deleted` = '0', `ifDescr` = '$ifDescr' WHERE `device_id` = '".$device['device_id']."' AND `ifIndex` = '$ifIndex'");
|
2008-04-03 21:52:59 +00:00
|
|
|
if(mysql_affected_rows()) {
|
|
|
|
echo("*");
|
|
|
|
} else {
|
|
|
|
echo(".");
|
|
|
|
}
|
2008-03-22 23:09:35 +00:00
|
|
|
}
|
2008-04-03 21:52:59 +00:00
|
|
|
$int_exists[] = "$ifIndex";
|
2008-03-22 23:09:35 +00:00
|
|
|
} else {
|
2008-11-19 12:12:54 +00:00
|
|
|
# Ignored Interface
|
|
|
|
#echo("$if \n");
|
|
|
|
if(mysql_result(mysql_query("SELECT COUNT(*) FROM `interfaces` WHERE `device_id` = '".$device['device_id']."' AND `ifIndex` = '$ifIndex'"), 0) != '0') {
|
|
|
|
mysql_query("UPDATE `interfaces` SET `deleted` = '1' WHERE `device_id` = '".$device['device_id']."' AND `ifIndex` = '$ifIndex'");
|
|
|
|
# Delete Interface
|
|
|
|
echo("-"); ## Deleted Interface
|
|
|
|
} else {
|
|
|
|
echo("X"); ## Ignored Interface
|
|
|
|
}
|
2008-03-22 23:09:35 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2008-04-03 21:52:59 +00:00
|
|
|
|
|
|
|
$sql = "SELECT * FROM `interfaces` WHERE `device_id` = '".$device['device_id']."' AND `deleted` = '0'";
|
|
|
|
$query = mysql_query($sql);
|
|
|
|
|
|
|
|
while ($test_if = mysql_fetch_array($query)) {
|
|
|
|
unset($exists);
|
|
|
|
$i = 0;
|
|
|
|
while ($i < count($int_exists) && !$exists) {
|
|
|
|
$this_if = $test_if['ifIndex'];
|
|
|
|
if ($int_exists[$i] == $this_if) { $exists = 1; }
|
|
|
|
$i++;
|
|
|
|
}
|
|
|
|
if(!$exists) {
|
|
|
|
echo("-");
|
|
|
|
mysql_query("UPDATE `interfaces` SET `deleted` = '1' WHERE interface_id = '" . $test_if['interface_id'] . "'");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
unset($temp_exists);
|
2008-03-22 23:09:35 +00:00
|
|
|
echo("\n");
|
|
|
|
|
|
|
|
?>
|