Skip to content

Commit

Permalink
Update Dell MIBs
Browse files Browse the repository at this point in the history
tidy up some related code a bit too to make it more readable
  • Loading branch information
murrant committed Jun 14, 2024
1 parent 3ad5bbc commit a9a4eeb
Show file tree
Hide file tree
Showing 5 changed files with 7,168 additions and 2,304 deletions.
19 changes: 9 additions & 10 deletions includes/discovery/sensors/state/dell.inc.php
Original file line number Diff line number Diff line change
Expand Up @@ -22,13 +22,12 @@
['batteryTable', '.1.3.6.1.4.1.674.10893.1.20.130.15.1.4.', 'batteryState', 'batteryName', 'StorageManagement-MIB', 'dell'],
];

foreach ($tables as $tablevalue) {
$temp = snmpwalk_cache_multi_oid($device, $tablevalue[0], [], $tablevalue[4], $tablevalue[5]);
$cur_oid = $tablevalue[1];
foreach ($tables as [$table, $num_oid, $value_oid, $descr_oid, $mib, $mib_dir]) {
$temp = snmpwalk_cache_multi_oid($device, $table, [], $mib, $mib_dir);

if (is_array($temp)) {
//Create State Index
$state_name = 'dell.' . $tablevalue[2];
$state_name = 'dell.' . $value_oid;
if ($state_name == 'dell.processorDeviceStatusStatus' || $state_name == 'dell.memoryDeviceStatus' || $state_name == 'dell.powerSupplyStatus' || $state_name == 'dell.intrusionStatus') {
$states = [
['value' => 1, 'generic' => 3, 'graph' => 0, 'descr' => 'other'],
Expand Down Expand Up @@ -107,18 +106,18 @@
create_state_index($state_name, $states);

foreach ($temp as $index => $entry) {
if (strpos($index, '54.') === false) { //Because Dell is buggy
if (! str_contains($index, '54.')) { //Because Dell is buggy
if ($state_name == 'dell.intrusionStatus') {
$descr = $tablevalue[3];
$descr = $descr_oid;
} elseif ($state_name == 'dell.batteryState') {
$descr = str_replace('"', '', snmp_get($device, 'batteryConnectionControllerName.' . $index . '', '-Ovqn', $tablevalue[4])) . ' - ' . $temp[$index][$tablevalue[3]];
$descr = str_replace('"', '', snmp_get($device, 'batteryConnectionControllerName.' . $index, '-Ovqn', $mib)) . ' - ' . $entry[$descr_oid];
} elseif ($state_name == 'dell.arrayDiskState') {
$descr = str_replace('"', '', snmp_get($device, 'arrayDiskEnclosureConnectionEnclosureName.' . $index . '', '-Ovqn', $tablevalue[4])) . ' - ' . $temp[$index][$tablevalue[3]];
$descr = str_replace('"', '', snmp_get($device, 'arrayDiskEnclosureConnectionEnclosureName.' . $index, '-Ovqn', $mib)) . ' - ' . $entry[$descr_oid];
} else {
$descr = strip_tags($temp[$index][$tablevalue[3]]); // Use clean as virtualDiskDeviceName is user defined
$descr = strip_tags($entry[$descr_oid]); // Use clean as virtualDiskDeviceName is user defined
}
//Discover Sensors
discover_sensor($valid['sensor'], 'state', $device, $cur_oid . $index, $index, $state_name, $descr, 1, 1, null, null, null, null, $temp[$index][$tablevalue[2]], 'snmp', $index);
discover_sensor($valid['sensor'], 'state', $device, $num_oid . $index, $index, $state_name, $descr, 1, 1, null, null, null, null, $entry[$value_oid], 'snmp', $index);

//Create Sensor To State Index
create_sensor_to_state_index($device, $state_name, $index);
Expand Down
3 changes: 1 addition & 2 deletions includes/discovery/sensors/state/drac.inc.php
Original file line number Diff line number Diff line change
Expand Up @@ -20,8 +20,7 @@
['systemBatteryTable', '.1.3.6.1.4.1.674.10892.5.4.600.50.1.5.', 'systemBatteryStatus', 'systemBatteryLocationName'],
];

foreach ($tables as $tablevalue) {
[$table_oid, $num_oid, $value_oid, $descr_oid] = $tablevalue;
foreach ($tables as [$table_oid, $num_oid, $value_oid, $descr_oid]) {
$temp = snmpwalk_cache_multi_oid($device, $table_oid, [], 'IDRAC-MIB-SMIv2', null, '-OQUse');
// '-OQUsetX'

Expand Down
Loading

0 comments on commit a9a4eeb

Please sign in to comment.