mirror of
https://github.com/librenms/librenms.git
synced 2024-10-07 16:52:45 +00:00
* 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
27 lines
1.2 KiB
PHP
27 lines
1.2 KiB
PHP
<?php
|
|
|
|
echo(" EXTREME-BASE-MIB ");
|
|
|
|
// Fan Speed
|
|
$oid = ".1.3.6.1.4.1.1916.1.1.1.9.1.4";
|
|
$oids = snmpwalk_cache_multi_oid($device, $oid, [], "EXTREME-BASE-MIB");
|
|
|
|
foreach ($oids as $index => $entry) {
|
|
// fix index to a proper int
|
|
preg_match('/^.*\.([^\.]*)$/', "$index", $matches);
|
|
$index = $matches[1];
|
|
// substract 100 from index to start from 1 instead of 101
|
|
$modindex = ($index - 100);
|
|
$oid = ".1.3.6.1.4.1.1916.1.1.1.9.1.4.$index";
|
|
$value = snmp_get($device, $oid, '-Oqv', 'EXTREME-BASE-MIB');
|
|
$descr = "Fan Speed $modindex";
|
|
// round function used to round limit values to hundreds to avoid h/w/l limits being changed on every discovery as a change of 1rpm for fan speed would cause the limit values to change since they're dynamically calculated
|
|
$high_limit = round_Nth(($value * 1.5), 100);
|
|
$high_warn_limit = round_Nth(($value * 1.25), 100);
|
|
$low_warn_limit = round_Nth(($value * 0.75), 100);
|
|
$low_limit = round_Nth(($value * 0.5), 100);
|
|
if (is_numeric($value)) {
|
|
discover_sensor($valid['sensor'], 'fanspeed', $device, $oid, $index, 'extreme-fanspeed', $descr, '1', '1', $low_limit, $low_warn_limit, $high_warn_limit, $high_limit, $value);
|
|
}
|
|
}
|