mirror of
https://github.com/librenms/librenms.git
synced 2024-10-07 16:52:45 +00:00
humidity discovery for akcp/minkelsrms - still needs discover_humidity function, db table, webinterface, polling
git-svn-id: http://www.observium.org/svn/observer/trunk@1247 61d68cd4-352d-0410-923a-c4978735b2b8
This commit is contained in:
@@ -110,6 +110,7 @@ while ($device = mysql_fetch_array($device_query))
|
|||||||
include("includes/discovery/ipv4-addresses.inc.php");
|
include("includes/discovery/ipv4-addresses.inc.php");
|
||||||
include("includes/discovery/ipv6-addresses.inc.php");
|
include("includes/discovery/ipv6-addresses.inc.php");
|
||||||
include("includes/discovery/temperatures.inc.php");
|
include("includes/discovery/temperatures.inc.php");
|
||||||
|
include("includes/discovery/humidity.inc.php");
|
||||||
include("includes/discovery/voltages.inc.php");
|
include("includes/discovery/voltages.inc.php");
|
||||||
include("includes/discovery/frequencies.inc.php");
|
include("includes/discovery/frequencies.inc.php");
|
||||||
include("includes/discovery/current.inc.php");
|
include("includes/discovery/current.inc.php");
|
||||||
|
72
includes/discovery/humidity.inc.php
Executable file
72
includes/discovery/humidity.inc.php
Executable file
@@ -0,0 +1,72 @@
|
|||||||
|
f<?php
|
||||||
|
$id = $device['device_id'];
|
||||||
|
$hostname = $device['hostname'];
|
||||||
|
$community = $device['community'];
|
||||||
|
$snmpver = $device['snmpver'];
|
||||||
|
$port = $device['port'];
|
||||||
|
|
||||||
|
echo("Humidity : ");
|
||||||
|
|
||||||
|
$valid_humidity = array();
|
||||||
|
|
||||||
|
switch ($device['os'])
|
||||||
|
{
|
||||||
|
case "akcp":
|
||||||
|
case "minkelsrms":
|
||||||
|
$oids = snmp_walk($device, ".1.3.6.1.4.1.3854.1.2.2.1.16.1.4", "-Osqn", "");
|
||||||
|
if ($debug) { echo($oids."\n"); }
|
||||||
|
$oids = trim($oids);
|
||||||
|
if ($oids) echo("AKCP ");
|
||||||
|
foreach(explode("\n", $oids) as $data)
|
||||||
|
{
|
||||||
|
$data = trim($data);
|
||||||
|
if ($data)
|
||||||
|
{
|
||||||
|
list($oid,$status) = explode(" ", $data,2);
|
||||||
|
if ($status == 2) # 2 = normal, 0 = not connected
|
||||||
|
{
|
||||||
|
$split_oid = explode('.',$oid);
|
||||||
|
$humidity_id = $split_oid[count($split_oid)-1];
|
||||||
|
$descr_oid = ".1.3.6.1.4.1.3854.1.2.2.1.17.1.1.$humidity_id";
|
||||||
|
$humidity_oid = ".1.3.6.1.4.1.3854.1.2.2.1.17.1.3.$humidity_id";
|
||||||
|
$warnlimit_oid = ".1.3.6.1.4.1.3854.1.2.2.1.17.1.7.$humidity_id";
|
||||||
|
$limit_oid = ".1.3.6.1.4.1.3854.1.2.2.1.17.1.8.$humidity_id";
|
||||||
|
# .9 = low warn limit
|
||||||
|
$lowlimit_oid = ".1.3.6.1.4.1.3854.1.2.2.1.17.1.10.$humidity_id";
|
||||||
|
|
||||||
|
$descr = trim(snmp_get($device, $descr_oid, "-Oqv", ""),'"');
|
||||||
|
$humidity = snmp_get($device, $humidity_oid, "-Oqv", "");
|
||||||
|
$warnlimit = snmp_get($device, $warnlimit_oid, "-Oqv", "");
|
||||||
|
$limit = snmp_get($device, $limit_oid, "-Oqv", "");
|
||||||
|
$lowlimit = snmp_get($device, $lowlimit_oid, "-Oqv", "");
|
||||||
|
|
||||||
|
# FIXME no warnlimit in table/discover function yet...
|
||||||
|
# discover_humidity($valid_humidity, $device, $humidity_oid, $humidity_id, "akcp", $descr, 1, $lowlimit, $limit, $humidity);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if($debug) { print_r($valid_humidity); }
|
||||||
|
|
||||||
|
$sql = "SELECT * FROM humidity AS T, devices AS D WHERE T.device_id = D.device_id AND D.device_id = '".$device['device_id']."'";
|
||||||
|
if ($query = mysql_query($sql))
|
||||||
|
{
|
||||||
|
while ($test_humidity = mysql_fetch_array($query))
|
||||||
|
{
|
||||||
|
$humidity_index = $test_humidity['humidity_index'];
|
||||||
|
$humidity_type = $test_humidity['humidity_type'];
|
||||||
|
if($debug) { echo($humidity_index . " -> " . $humidity_type . "\n"); }
|
||||||
|
if(!$valid_humidity[$humidity_type][$humidity_index])
|
||||||
|
{
|
||||||
|
echo("-");
|
||||||
|
mysql_query("DELETE FROM `humidity` WHERE humidity_id = '" . $test_humidity['humidity_id'] . "'");
|
||||||
|
}
|
||||||
|
unset($humidity_oid); unset($humidity_type);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
unset($valid_humidity); echo("\n");
|
||||||
|
|
||||||
|
?>
|
Reference in New Issue
Block a user