Files
KodApa85 7f104d4fd9 Advanced state sensors (#9881)
* refactor: advanced sensor states

mark create_state_index($state_name) as E_USER_DEPRECATED?

* fix: minor corrections

* fix: mib has partialSync(9) and incompatibleVersion(8)

* fix: corrected netagent2upsstate - Sleeping(5)

* fix: NetAgent2 upsThreePhaseUPSStatusInverterOperating correction

* refactor: array() be gone

* Refactoring includes/discovery/sensors/state/extendair.inc.php with arrays
And tidying up array formatting in other files

* fix: minor typo

* standardising array item names

removed redundant "if ($state_index_id !== null) {"

* workaround: procurve & serverscheck

a sensor is causing create_state_index($state) to return null.
The updated code doesn't allow for this and thus a hybrid is being used.

* standardised naming of state info. Caused a typo $state_name instead of $status_name
$state_name is the standard

* converted compas to square arrays

* Converted APC states using preg_match to new create_state_index() call

* Update boss.inc.php
2019-03-04 11:31:17 -06:00

28 lines
1019 B
PHP

<?php
$oids = snmpwalk_cache_oid($device, 'tempHumidSensorEntry', [], 'Sentry3-MIB');
$divisor = '1';
$multiplier = '1';
d_echo($oids);
if ($oids) {
echo 'ServerTech Sentry3 Humidity ';
foreach ($oids as $sensor_index => $data) {
// tempHumidSensorHumidValue
$humidity_oid = '.1.3.6.1.4.1.1718.3.2.5.1.10.'.$sensor_index;
$descr = 'Removable Sensor '.$data['tempHumidSensorID'];
$low_warn_limit = null;
$low_limit = $data['tempHumidSensorHumidLowThresh'];
$high_warn_limit = null;
$high_limit = $data['tempHumidSensorHumidHighThresh'];
$current = $data['tempHumidSensorHumidValue'];
if (is_numeric($current) && $current >= 0) {
discover_sensor($valid['sensor'], 'humidity', $device, $humidity_oid, 'tempHumidSensorHumidValue'.$sensor_index, 'sentry3', $descr, $divisor, $multiplier, $low_limit, $low_warn_limit, $high_warn_limit, $high_limit, $current);
}
}
}
unset($oids);