recognise some new OSes, add an image for dlink, move sysObjectId polling to be global for os detection

git-svn-id: http://www.observium.org/svn/observer/trunk@1345 61d68cd4-352d-0410-923a-c4978735b2b8
This commit is contained in:
Adam Amstrong
2010-07-11 20:12:24 +00:00
parent 6a673c1cce
commit 2e581828b6
10 changed files with 51 additions and 12 deletions
+9 -7
View File
@@ -18,17 +18,19 @@ if($argv[1]) {
if (!$community) $community = $config['community'];
list($hostshort) = explode(".", $host);
if ( isDomainResolves($argv[1])){
if ( isPingable($argv[1])) {
if ( mysql_result(mysql_query("SELECT COUNT(*) FROM `devices` WHERE `hostname` = '".mres($host)."'"), 0) == '0' ) {
if ( mysql_result(mysql_query("SELECT COUNT(*) FROM `devices` WHERE `hostname` = '".mres($host)."'"), 0) == '0' ) {
if ( isDomainResolves($argv[1])){
if ( isPingable($argv[1])) {
if ( isSNMPable($argv[1], $community, $snmpver, $port)) {
$snmphost = trim(str_replace("\"", "", shell_exec($config['snmpget'] ." -m SNMPv2-MIB -Oqv -$snmpver -c $community $host:$port sysName.0")));
if ($snmphost == "" || $snmphost && ($snmphost == $host || $hostshort = $host)) {
if ($snmphost != "" || $snmphost && ($snmphost == $host || $hostshort = $host)) {
$return = createHost ($host, $community, $snmpver, $port);
if($return) { echo($return . "\n"); } else { echo("Adding $host failed\n"); }
} else { echo("Given hostname does not match SNMP-read hostname!\n"); }
} else { echo("Already got host $host\n"); }
} else { echo("Could not ping $host\n"); }
} else { echo("Could not resolve $host\n"); }
} else { echo("Could not reach $host with SNMP\n"); }
} else { echo("Could not ping $host\n"); }
} else { echo("Could not resolve $host\n"); }
} else { echo("Already got host $host\n"); }
} else { echo("Add Host Tool\nUsage: ./addhost.php <hostname> [community] [v1|v2c] [port]\n"); }
?>
Binary file not shown.

After

Width:  |  Height:  |  Size: 997 B

+4 -2
View File
@@ -99,8 +99,10 @@ function getHostOS($device)
{
global $config;
$sysDescr_cmd = $config['snmpget']." -m SNMPv2-MIB -O qv -" . $device['snmpver'] . " -c " . $device['community'] . " " . $device['hostname'].":".$device['port'] . " sysDescr.0";
$sysDescr = str_replace("\"", "", trim(shell_exec($sysDescr_cmd)));
$sysDescr = snmp_get ($device, "sysDescr.0", "-Ovq");
$sysObjectId = snmp_get ($device, "sysObjectID.0", "-Ovqn");
$dir_handle = @opendir($config['install_dir'] . "/includes/osdiscovery") or die("Unable to open $path");
while ($file = readdir($dir_handle))
{
@@ -0,0 +1,9 @@
<?php
if(!$os) {
if(strpos($sysDescr, "Apple AirPort") !== FALSE) { $os = "airport"; }
}
?>
-1
View File
@@ -2,7 +2,6 @@
if(!$os) {
$sysObjectId = shell_exec($config['snmpget'] . " -Ovqn -".$device['snmpver']." -c ". $device['community'] ." ". $device['hostname'].":".$device['port'] ." sysObjectID.0");
if(strstr($sysObjectId, ".1.3.6.1.4.1.207")) { $os = "allied"; }
}
@@ -0,0 +1,10 @@
<?php
if(!$os) {
if(strpos($sysDescr, "DES-") !== FALSE) { $os = "dlink"; }
}
?>
+9
View File
@@ -0,0 +1,9 @@
<?php
if(!$os) {
if(strstr($sysObjectId, ".1.3.6.1.4.1.1916.2")) { $os = "extremeware"; }
}
?>
-1
View File
@@ -2,7 +2,6 @@
if(!$os) {
$sysObjectId = shell_exec($config['snmpget'] . " -Ovqn -".$device['snmpver']." -c ". $device['community'] ." ". $device['hostname'].":".$device['port'] ." sysObjectID.0");
if(strstr($sysObjectId, ".1.3.6.1.4.1.2636")) { $os = "junos"; }
}
-1
View File
@@ -2,7 +2,6 @@
if(!$os) {
$sysObjectId = shell_exec($config['snmpget'] . " -Ovqn -".$device['snmpver']." -c ". $device['community'] ." ". $device['hostname'].":".$device['port'] ." sysObjectID.0");
if(strstr($sysObjectId, ".1.3.6.1.4.1.4874")) { $os = "junose"; }
}
+10
View File
@@ -0,0 +1,10 @@
<?php
if(!$os) {
if(strpos($sysDescr, "ZyWALL") !== FALSE) { $os = "zywall"; }
}
?>