2010-02-09 23:19:14 +00:00
|
|
|
<?php
|
|
|
|
$id = $device['device_id'];
|
|
|
|
$hostname = $device['hostname'];
|
|
|
|
$community = $device['community'];
|
|
|
|
$snmpver = $device['snmpver'];
|
|
|
|
$port = $device['port'];
|
|
|
|
|
|
|
|
echo("Voltages : ");
|
|
|
|
|
2010-02-15 01:26:50 +00:00
|
|
|
## LMSensors Voltages (returned as 10,000ths of a volt.)
|
|
|
|
|
2010-02-09 23:19:14 +00:00
|
|
|
if ($device['os'] == "linux")
|
|
|
|
{
|
2010-02-15 05:07:18 +00:00
|
|
|
$oids = snmp_walk($device, "lmVoltSensorsDevice", "-OsqnU", "LM-SENSORS-MIB");
|
|
|
|
if ($debug) { echo($oids."\n"); }
|
2010-02-09 23:19:14 +00:00
|
|
|
if ($oids) echo("LM-SENSORS ");
|
2010-02-15 05:07:18 +00:00
|
|
|
$precision = 1000;
|
|
|
|
$type = "lmsensors";
|
2010-02-09 23:19:14 +00:00
|
|
|
foreach(explode("\n", $oids) as $data)
|
|
|
|
{
|
|
|
|
$data = trim($data);
|
|
|
|
if ($data)
|
|
|
|
{
|
|
|
|
list($oid,$descr) = explode(" ", $data,2);
|
|
|
|
$split_oid = explode('.',$oid);
|
2010-02-15 05:07:18 +00:00
|
|
|
$index = $split_oid[count($split_oid)-1];
|
|
|
|
$oid = ".1.3.6.1.4.1.2021.13.16.4.1.3." . $index;
|
|
|
|
$current = snmp_get($device, $oid, "-Oqv", "LM-SENSORS-MIB") / $precision;
|
|
|
|
discover_volt($device, $oid, $index, $type, $descr, $precision, NULL, NULL, $current);
|
|
|
|
$volt_exists[$type][$index] = 1;
|
2010-02-09 23:19:14 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2010-02-15 01:26:50 +00:00
|
|
|
|
2010-02-09 23:19:14 +00:00
|
|
|
|
|
|
|
## Supermicro Voltages
|
|
|
|
if ($device['os'] == "linux")
|
|
|
|
{
|
2010-02-15 05:07:18 +00:00
|
|
|
$oids = snmp_walk($device, "1.3.6.1.4.1.10876.2.1.1.1.1.3", "-OsqnU", "SUPERMICRO-HEALTH-MIB");
|
|
|
|
if ($debug) { echo($oids."\n"); }
|
2010-02-09 23:19:14 +00:00
|
|
|
$oids = trim($oids);
|
|
|
|
if ($oids) echo("Supermicro ");
|
2010-02-15 05:07:18 +00:00
|
|
|
$type = "supermicro";
|
|
|
|
$precision = "1000";
|
2010-02-09 23:19:14 +00:00
|
|
|
foreach(explode("\n", $oids) as $data)
|
|
|
|
{
|
|
|
|
$data = trim($data);
|
|
|
|
if ($data)
|
|
|
|
{
|
2010-02-15 05:07:18 +00:00
|
|
|
list($oid,$kind) = explode(" ", $data);
|
|
|
|
$split_oid = explode('.',$oid);
|
|
|
|
$index = $split_oid[count($split_oid)-1];
|
|
|
|
if ($kind == 1)
|
2010-02-09 23:19:14 +00:00
|
|
|
{
|
2010-02-15 05:07:18 +00:00
|
|
|
$volt_oid = "1.3.6.1.4.1.10876.2.1.1.1.1.4.".$index;
|
|
|
|
$descr_oid = "1.3.6.1.4.1.10876.2.1.1.1.1.2.".$index;
|
|
|
|
$monitor_oid = "1.3.6.1.4.1.10876.2.1.1.1.1.10.".$index;
|
2010-02-16 02:08:33 +00:00
|
|
|
$limit_oid = "1.3.6.1.4.1.10876.2.1.1.1.1.5.".$index;
|
|
|
|
$lowlimit_oid = "1.3.6.1.4.1.10876.2.1.1.1.1.6.".$index;
|
2010-02-15 05:07:18 +00:00
|
|
|
|
2010-02-16 01:42:39 +00:00
|
|
|
$descr = snmp_get($device, $descr_oid, "-Oqv", "SUPERMICRO-HEALTH-MIB");
|
2010-02-16 01:45:00 +00:00
|
|
|
$current = snmp_get($device, $volt_oid, "-Oqv", "SUPERMICRO-HEALTH-MIB") / $precision;
|
|
|
|
$limit = snmp_get($device, $limit_oid, "-Oqv", "SUPERMICRO-HEALTH-MIB") / $precision;
|
|
|
|
$lowlimit = snmp_get($device, $lowlimit_oid, "-Oqv", "SUPERMICRO-HEALTH-MIB") / $precision;
|
2010-02-16 01:42:39 +00:00
|
|
|
$monitor = snmp_get($device, $monitor_oid, "-Oqv", "SUPERMICRO-HEALTH-MIB");
|
|
|
|
$descr = trim(str_ireplace("Voltage", "", $descr));
|
2010-02-15 05:07:18 +00:00
|
|
|
|
2010-02-10 11:20:09 +00:00
|
|
|
if ($monitor == 'true')
|
2010-02-09 23:19:14 +00:00
|
|
|
{
|
2010-02-15 05:07:18 +00:00
|
|
|
echo discover_volt($device, $volt_oid, $index, $type, $descr, $precision, $lowlimit, $limit, $current);
|
|
|
|
$volt_exists[$type][$index] = 1;
|
2010-02-09 23:19:14 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
## Delete removed sensors
|
|
|
|
|
2010-02-15 05:07:18 +00:00
|
|
|
if($debug) { print_r($volt_exists); }
|
2010-02-09 23:19:14 +00:00
|
|
|
|
2010-02-15 05:07:18 +00:00
|
|
|
$sql = "SELECT * FROM voltage WHERE device_id = '".$device['device_id']."'";
|
2010-02-11 11:45:28 +00:00
|
|
|
if ($query = mysql_query($sql))
|
2010-02-09 23:19:14 +00:00
|
|
|
{
|
2010-02-15 05:07:18 +00:00
|
|
|
while ($test_volt = mysql_fetch_array($query))
|
2010-02-09 23:19:14 +00:00
|
|
|
{
|
2010-02-15 05:07:18 +00:00
|
|
|
$index = $test_volt['volt_index'];
|
|
|
|
$type = $test_volt['volt_type'];
|
|
|
|
if($debug) { echo("$type -> $index\n"); }
|
|
|
|
if(!$volt_exists[$type][$index]) {
|
2010-02-11 11:45:28 +00:00
|
|
|
echo("-");
|
2010-02-15 05:07:18 +00:00
|
|
|
mysql_query("DELETE FROM `voltage` WHERE volt_id = '" . $test_volt['volt_id'] . "'");
|
2010-02-11 11:45:28 +00:00
|
|
|
}
|
2010-02-09 23:19:14 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-02-15 05:07:18 +00:00
|
|
|
unset($fan_exists); echo("\n");
|
2010-02-09 23:19:14 +00:00
|
|
|
|
|
|
|
?>
|