mirror of
https://github.com/librenms/librenms.git
synced 2024-09-22 10:58:42 +00:00
bfb8aa7af5
git-svn-id: http://www.observium.org/svn/observer/trunk@38 61d68cd4-352d-0410-923a-c4978735b2b8
224 lines
9.6 KiB
PHP
Executable File
224 lines
9.6 KiB
PHP
Executable File
#!/usr/bin/php
|
|
<?
|
|
|
|
include("config.php");
|
|
include("includes/functions.php");
|
|
|
|
$device_query = mysql_query("SELECT * FROM `devices` WHERE `id` like '%$argv[1]' AND `ignore` = '0' ORDER BY `id` ASC");
|
|
while ($device = mysql_fetch_array($device_query)) {
|
|
$hostname = $device['hostname'];
|
|
$id = $device['id'];
|
|
$status = $device['status'];
|
|
$community = $device['community'];
|
|
$snmpver = $device['snmpver'];
|
|
unset($update); unset($update_query); unset($seperator); unset($newversion); unset($newuptime); unset($newfeatures);
|
|
unset($newlocation); unset($newhardware);
|
|
$pingable = isPingable($hostname);
|
|
$snmpable = FALSE;
|
|
if($pingable) {
|
|
$snmpable = isSNMPable($hostname, $community, $snmpver);
|
|
}
|
|
if ($pingable !== FALSE && $snmpable !== FALSE ) {
|
|
$newstatus = '1';
|
|
$hardware = $device['hardware'];
|
|
$version = $device['version'];
|
|
$old_rebooted = $device['rebooted'];
|
|
$features = $device['features'];
|
|
$location = $device['location'];
|
|
$old_sysDescr = $device['sysDescr'];
|
|
$uptime = $device['uptime'];
|
|
$os = $device['os'];
|
|
if($os == "FreeBSD" || $os == "OpenBSD" || $os == "Linux" || $os == "Windows") { $uptimeoid = ".1.3.6.1.2.1.25.1.1.0"; } else { $uptimeoid = "1.3.6.1.2.1.1.3.0"; }
|
|
if($device['monowall']) { $uptimeoid = ".1.3.6.1.2.1.1.3.0"; }
|
|
$snmp = "$uptimeoid sysLocation.0 .1.3.6.1.2.1.47.1.1.1.1.13.1 sysDescr.0";
|
|
$snmpdata = `snmpget -O qv -$snmpver -c $community $hostname $snmp | grep -v "Cisco Internetwork Operating System Software"`;
|
|
$snmpdata = preg_replace("/^.*IOS/","", $snmpdata);
|
|
$snmpdata = trim($snmpdata);
|
|
list($sysUptime, $sysLocation, $ciscomodel, $sysDescr) = explode("\n", $snmpdata);
|
|
$sysUptime = str_replace("(", "", $sysUptime);
|
|
$sysUptime = str_replace(")", "", $sysUptime);
|
|
list($days, $hours, $mins, $secs) = explode(":", $sysUptime);
|
|
list($secs, $microsecs) = explode(".", $secs);
|
|
$timeticks = mktime(0, $secs, $mins, $hours, $days, 0);
|
|
$hours = $hours + ($days * 24);
|
|
$mins = $mins + ($hours * 60);
|
|
$secs = $secs + ($mins * 60);
|
|
$newuptime = $secs;
|
|
|
|
include("poll-device-netstats.php");
|
|
|
|
switch ($os) {
|
|
case "FreeBSD":
|
|
case "DragonFly":
|
|
case "OpenBSD":
|
|
case "Linux":
|
|
case "m0n0wall":
|
|
case "Voswall":
|
|
case "NetBSD":
|
|
case "pfSense":
|
|
if($os == "FreeBSD") {
|
|
$sysDescr = str_replace(" 0 ", " ", $sysDescr);
|
|
list(,,$newversion) = explode (" ", $sysDescr);
|
|
$newhardware = "i386";
|
|
$newfeatures = "GENERIC";
|
|
} elseif($os == "DragonFly") {
|
|
list(,,$newversion,,,$newfeatures,,$newhardware) = explode (" ", $sysDescr);
|
|
} elseif($os == "NetBSD") {
|
|
list(,,$newversion,,,$newfeatures) = explode (" ", $sysDescr);
|
|
$newfeatures = str_replace("(", "", $newfeatures);
|
|
$newfeatures = str_replace(")", "", $newfeatures);
|
|
list(,,$newhardware) = explode ("$newfeatures", $sysDescr);
|
|
} elseif($os == "OpenBSD") {
|
|
list(,,$newversion,$newfeatures,$newhardware) = explode (" ", $sysDescr);
|
|
$newfeatures = str_replace("(", "", $newfeatures);
|
|
$newfeatures = str_replace(")", "", $newfeatures);
|
|
} elseif($os == "m0n0wall" || $os == "Voswall") {
|
|
list(,,$newversion,$newhardware,$freebsda, $freebsdb, $arch) = split(" ", $sysDescr);
|
|
$newfeatures = $freebsda . " " . $freebsdb;
|
|
$newhardware = "$newhardware ($arch)";
|
|
$newhardware = str_replace("\"", "", $newhardware);
|
|
} elseif ($os == "Linux") {
|
|
list(,,$newversion) = explode (" ", $sysDescr);
|
|
if(strstr($sysDescr, "386")|| strstr($sysDescr, "486")||strstr($sysDescr, "586")||strstr($sysDescr, "686")) { $newhardware = "Generic x86"; }
|
|
# list($newversion,$newfeatures,$newfeaturesb) = explode("-", $newversion);
|
|
$newfeatures = `snmpget -O qv -$snmpver -c $community $hostname .1.3.6.1.4.1.2021.7890.1.101.1`;
|
|
$newfeatures = str_replace("No Such Object available on this agent at this OID", "", $newfeatures);
|
|
$newfeatures = str_replace("\"", "", $newfeatures);
|
|
}
|
|
pollDeviceUnix();
|
|
break;
|
|
case "Windows":
|
|
if($os == "Windows") {
|
|
if(strstr($sysDescr, "x86")) { $newhardware = "Generic x86"; }
|
|
if(strstr($sysDescr, "Windows Version 5.2")) { $newversion = "2003 Server"; }
|
|
if(strstr($sysDescr, "Uniprocessor Free")) { $newfeatures = "Uniprocessor"; }
|
|
if(strstr($sysDescr, "Multiprocessor Free")) { $newfeatures = "Multiprocessor"; }
|
|
}
|
|
pollDeviceWin();
|
|
break;
|
|
case "IOS":
|
|
if ($os == "IOS") {
|
|
$newversion = str_replace("Cisco IOS Software,", "", $sysDescr);
|
|
$newversion = str_replace("IOS (tm) ", "", $newversion);
|
|
$newversion = str_replace(",RELEASE SOFTWARE", "", $newversion);
|
|
$newversion = str_replace(",MAINTENANCE INTERIM SOFTWARE", "", $newversion);
|
|
$newversion = str_replace("Version ","", $newversion);
|
|
$newversion = str_replace("Cisco Internetwork Operating System Software", "", $newversion);
|
|
$newversion = trim($newversion);
|
|
list($newversion) = explode("\n", $newversion);
|
|
$newversion = preg_replace("/^[A-Za-z0-9\ \_]*\(([A-Za-z0-9\-\_]*)\), (.+), .*/", "\\1|\\2", $newversion);
|
|
$newversion = str_replace("-M|", "|", $newversion);
|
|
$newversion = str_replace("-", "|", $newversion);
|
|
list($newhardware, $newfeatures, $newversion) = explode("|", $newversion);
|
|
$newfeatures = fixIOSFeatures($newfeatures);
|
|
#$newhardware = fixIOSHardware($newhardware);
|
|
$ciscomodel = str_replace("\"", "", $ciscomodel);
|
|
if(strstr($ciscomodel, "OID")){ unset($ciscomodel); }
|
|
echo("\n|$ciscomodel|$newhardware\n");
|
|
if(!strstr($ciscomodel, " ") && strlen($ciscomodel) >= '3') {
|
|
echo("$ciscomodel");
|
|
$newhardware = $ciscomodel;
|
|
}
|
|
|
|
}
|
|
pollDeviceIOS();
|
|
break;
|
|
case "ProCurve":
|
|
$sysDescr = str_replace(", ", ",", $sysDescr);
|
|
list($newhardware, $newfeatures, $newversion) = explode(",", $sysDescr);
|
|
list($newversion) = explode("(", $newversion);
|
|
if(!strstr($ciscomodel, " ")) {
|
|
echo("$ciscomodel");
|
|
$newhardware = str_replace("\"", "", $ciscomodel);
|
|
}
|
|
pollDeviceHP();
|
|
break;
|
|
case "Snom":
|
|
$sysDescr = `snmpget -Oqv -$snmpver -c $community $hostname 1.3.6.1.2.1.7526.2.4`;
|
|
$sysDescr = str_replace("-", " ", $sysDescr);
|
|
$sysDescr = str_replace("\"", "", $sysDescr);
|
|
list($newhardware, $newfeatures, $newversion) = explode(" ", $sysDescr);
|
|
pollDeviceSnom();
|
|
break;
|
|
default:
|
|
pollDevice();
|
|
}
|
|
$newlocation = str_replace("\"","", $sysLocation);
|
|
} else {
|
|
$newstatus = '0';
|
|
}
|
|
|
|
$uptimerrd = "rrd/" . $hostname . "-uptime.rrd";
|
|
if(!is_file($uptimerrd)) {
|
|
$woo = `rrdtool create $uptimerrd \
|
|
DS:uptime:GAUGE:600:0:U \
|
|
RRA:AVERAGE:0.5:1:600 \
|
|
RRA:AVERAGE:0.5:6:700 \
|
|
RRA:AVERAGE:0.5:24:775 \
|
|
RRA:AVERAGE:0.5:288:797`;
|
|
}
|
|
rrd_update($uptimerrd, "N:$newuptime");
|
|
|
|
if ( $sysDescr && $sysDescr != $old_sysDescr ) {
|
|
$update = "`sysDescr` = '$sysDescr'";
|
|
$seperator = ", ";
|
|
mysql_query("INSERT INTO eventlog (host, interface, datetime, message) VALUES ('$id', NULL, NOW(), 'New sysDescr - $sysDescr')");
|
|
}
|
|
if ( $newlocation && $location != $newlocation ) {
|
|
$update = "`location` = '$newlocation'";
|
|
$seperator = ", ";
|
|
mysql_query("INSERT INTO eventlog (host, interface, datetime, message) VALUES ('$id', NULL, NOW(), 'Changed location from $location to $newlocation')");
|
|
}
|
|
if ( $newversion && $version != $newversion ) {
|
|
$update .= $seperator . "`version` = '$newversion'";
|
|
$seperator = ", ";
|
|
mysql_query("INSERT INTO eventlog (host, interface, datetime, message) VALUES ('$id', NULL, NOW(), 'Changed version from $version to $newversion')");
|
|
}
|
|
if ( $newfeatures && $newfeatures != $features ) {
|
|
$update .= $seperator . "`features` = '$newfeatures'";
|
|
$seperator = ", ";
|
|
mysql_query("INSERT INTO eventlog (host, interface, datetime, message) VALUES ('$id', NULL, NOW(), 'Changed features from $features to $newfeatures')");
|
|
}
|
|
if ( $newhardware && $newhardware != $hardware ) {
|
|
$update .= $seperator . "`hardware` = '$newhardware'";
|
|
$seperator = ", ";
|
|
mysql_query("INSERT INTO eventlog (host, interface, datetime, message) VALUES ('$id', NULL, NOW(), 'Changed hardware from $hardware to $newhardware')");
|
|
}
|
|
if ( $newuptime && $uptime != $newuptime ) {
|
|
$update .= $seperator . "`uptime` = '$newuptime'";
|
|
$seperator = ", ";
|
|
}
|
|
|
|
if( $status != $newstatus ) {
|
|
$update .= $seperator . "`status` = '$newstatus'";
|
|
$seperator = ", ";
|
|
if ($newstatus == '1') { $stat = "Up";
|
|
mysql_query("INSERT INTO alerts (importance, device_id, message) VALUES ('0', '$id', 'Device is up\n')");
|
|
} else {
|
|
$stat = "Down";
|
|
mysql_query("INSERT INTO alerts (importance, device_id, message) VALUES ('9', '$id', 'Device is down\n')");
|
|
}
|
|
mysql_query("INSERT INTO eventlog (host, interface, datetime, message) VALUES ('$id', NULL, NOW(), 'Device status changed to $stat')");
|
|
}
|
|
|
|
if ( $newuptime ) {
|
|
$update_uptime = mysql_query("UPDATE device_uptime SET device_uptime = '$newuptime' WHERE `device_id` = '$id'");
|
|
if(mysql_affected_rows() == '0') {
|
|
$insert_uptime = mysql_query("INSERT INTO device_uptime (`device_uptime`, `device_id`) VALUES ('$newuptime','$id')");
|
|
}
|
|
}
|
|
|
|
|
|
if ($update) {
|
|
$update_query = "UPDATE `devices` SET ";
|
|
$update_query .= $update;
|
|
$update_query .= " WHERE `id` = '$id'";
|
|
echo("Updating $hostname\n$update_query\n\n");
|
|
$update_result = mysql_query($update_query);
|
|
} else {
|
|
echo("No Changes to $hostname \n\n");
|
|
}
|
|
}
|
|
|
|
?>
|