Files
librenms-librenms/includes/discovery/sensors/state/axiscam.inc.php
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

56 lines
2.0 KiB
PHP

<?php
echo 'AXIS States';
// Temp Sensor Status
$oids_tmp = snmpwalk_cache_multi_oid($device, 'tempSensorTable', [], 'AXIS-VIDEO-MIB');
$cur_oid = '.1.3.6.1.4.1.368.4.1.3.1.3.1.';
// Exclude from $oids content .common string
foreach ($oids_tmp as $key_oids_tmp => $val_oids_tmp) {
$oids[str_replace('common.', '', $key_oids_tmp)] = $val_oids_tmp;
}
if (is_array($oids)) {
//Create State Index
$state_name = 'tempSensorStatusState';
$states = [
['value' => 1, 'generic' => 0, 'graph' => 0, 'descr' => 'Normal'],
['value' => 2, 'generic' => 2, 'graph' => 0, 'descr' => 'Failed'],
['value' => 3, 'generic' => 2, 'graph' => 0, 'descr' => 'Out Of Boundary'],
];
create_state_index($state_name, $states);
foreach ($oids as $index => $entry) {
//Discover Sensors
discover_sensor($valid['sensor'], 'state', $device, $cur_oid.$index, $index, $state_name, 'Temperature Sensor '.$index, 1, 1, null, null, null, null, $entry['tempSensorStatus'], 'snmp', $index);
//Create Sensor To State Index
create_sensor_to_state_index($device, $state_name, $index);
}
}
// Storage Status
$oids = snmpwalk_cache_multi_oid($device, 'storageTable', [], 'AXIS-VIDEO-MIB');
$cur_oid = '.1.3.6.1.4.1.368.4.1.8.1.3.';
if (is_array($oids)) {
//Create State Index
$state_name = 'storageDisruptionDetectedState';
$states = [
['value' => 1, 'generic' => 0, 'graph' => 0, 'descr' => 'Normal'],
['value' => 2, 'generic' => 2, 'graph' => 0, 'descr' => 'Failed'],
];
create_state_index($state_name, $states);
foreach ($oids as $index => $entry) {
//Discover Sensors
discover_sensor($valid['sensor'], 'state', $device, $cur_oid.$index, $index, $state_name, 'Storage Status: ' .$entry['storageName'], 1, 1, null, null, null, null, $entry['storageDisruptionDetected'], 'snmp', $index);
//Create Sensor To State Index
create_sensor_to_state_index($device, $state_name, $index);
}
}
unset($oids);