Updated toner discovery (#4637)

This commit is contained in:
crcro
2016-10-03 19:49:23 +03:00
committed by Neil Lathwood
parent c5177c26af
commit 5c761eb1c7
2 changed files with 81 additions and 47 deletions

View File

@@ -891,3 +891,68 @@ function get_device_divisor($device, $serial, $sensor)
}
return $divisor;
}
/**
* @param $device
* @param $capacity_oid
* @return int
*/
function get_toner_capacity($device, $capacity_oid)
{
if ($device['os'] == 'ricoh' || $device['os'] == 'nrg' || $device['os'] == 'lanier') {
$capacity = 100;
} else {
$capacity = snmp_get($device, $capacity_oid, '-Oqv');
}
return $capacity;
}
/**
* @param $device
* @param $oid_value
* @param $oid_capacity
* @return float|int
*/
function get_toner_levels($device, $oid_value, $oid_capacity)
{
if ($device['os'] == 'ricoh' || $device['os'] == 'nrg' || $device['os'] == 'lanier') {
if ($oid_value == '-3') {
$current = 50;
} elseif ($oid_value == '-100') {
$current = 0;
} else {
$current = ($oid_value / $oid_capacity * 100);
}
} elseif ($device['os'] == 'brother') {
if (str_contains($device['hardware'], 'NC-8600h')) {
switch ($oid_value) {
case '0':
$current = 0;
break;
case '-3':
$current = 50;
break;
}
} else {
switch ($oid_value) {
case '0':
$current = 100;
break;
case '1':
$current = 5;
break;
case '2':
$current = 0;
break;
case '3':
$current = 1;
break;
}
}
} else {
$current = ($oid_value / $oid_capacity * 100);
}
return $current;
}

View File

@@ -25,6 +25,7 @@ if ($device['os_group'] == 'printer') {
if ($os == 'ricoh' || $os == 'nrg' || $os == 'lanier') {
$toner_oid = ".1.3.6.1.4.1.367.3.2.1.2.24.1.1.5.$index";
$descr_oid = ".1.3.6.1.4.1.367.3.2.1.2.24.1.1.3.$index";
$capacity_oid = '';
} else {
$toner_oid = ".1.3.6.1.2.1.43.11.1.1.9.1.$index";
$descr_oid = ".1.3.6.1.2.1.43.11.1.1.6.1.$index";
@@ -34,43 +35,11 @@ if ($device['os_group'] == 'printer') {
$descr = trim(str_replace("\n", '', preg_replace('/[^ \w]+/', '', snmp_get($device, $descr_oid, '-Oqv'))));
if ($descr != '') {
$current = snmp_get($device, $toner_oid, '-Oqv');
$oid_toner = snmp_get($device, $toner_oid, '-Oqv');
$oid_capacity = snmp_get($device, $capacity_oid, '-Oqv');
//ricoh private mibs returns values as percent, no capacity is disclosed as it is not needed
if ($os == 'ricoh' || $os == 'nrg' || $os == 'lanier') {
$capacity = 100;
} else {
$capacity = snmp_get($device, $capacity_oid, '-Oqv');
}
//fix for ricoh devices returning garbage and devices returning percentage
if ($os == 'ricoh' || $os == 'nrg' || $os == 'lanier') {
if ($current == '-3') {
$current = 50;
} elseif ($current == '-100') {
$current = 0;
} else {
$current = ($current / $capacity * 100);
}
} elseif ($os == 'brother') {
switch ($current) {
case '0':
$current = 100;
break;
case '1':
$current = 5;
break;
case '2':
$current = 0;
break;
case '3':
$current = 1;
break;
}
} else {
//normal devices returning toner values
$current = ($current / $capacity * 100);
}
$capacity = get_toner_capacity($device, $oid_capacity);
$current = get_toner_levels($device, $oid_toner, $oid_capacity);
$type = 'jetdirect';
if (isHexString($descr)) {
@@ -80,9 +49,9 @@ if ($device['os_group'] == 'printer') {
discover_toner($valid_toner, $device, $toner_oid, $index, $type, $descr, $capacity_oid, $capacity, $current);
}
}
}//end if
}//end foreach
}//end if
}
}
}
// Delete removed toners
d_echo("\n Checking ... \n");