librenms/includes/polling/toner.inc.php
Tom Laermans d599a82262 log toner replacement
git-svn-id: http://www.observium.org/svn/observer/trunk@2122 61d68cd4-352d-0410-923a-c4978735b2b8
2011-04-21 10:37:55 +00:00

44 lines
1.3 KiB
PHP
Executable File

<?php
if ($config['enable_printers'])
{
$query = "SELECT * FROM toner WHERE device_id = '" . $device['device_id'] . "'";
$toner_data = mysql_query($query);
while ($toner = mysql_fetch_assoc($toner_data))
{
echo("Checking toner " . $toner['toner_descr'] . "... ");
# FIXME poll capacity maybe also here, when toner is replaced capacity can change, leading to "154% of toner"
$tonerperc = snmp_get($device, $toner['toner_oid'], "-OUqnv") / $toner['toner_capacity'] * 100;
$tonerrrd = $config['rrd_dir'] . "/" . $device['hostname'] . "/" . safename("toner-" . $toner['toner_descr'] . ".rrd");
if (!is_file($tonerrrd))
{
rrdtool_create($tonerrrd,"--step 300 \
DS:toner:GAUGE:600:0:20000 \
RRA:AVERAGE:0.5:1:1200 \
RRA:MIN:0.5:12:2400 \
RRA:MAX:0.5:12:2400 \
RRA:AVERAGE:0.5:12:2400");
}
echo($tonerperc . " %\n");
rrdtool_update($tonerrrd,"N:$tonerperc");
#FIXME should report for toner out... :)
# Log toner swap
if ($tonerperc > $toner['toner_current'])
{
log_event('Toner ' . $toner['toner_descr'] . ' was replaced (new level: ' . $tonerperc . '%)', $device, 'toner', $toner['toner_id']);
}
mysql_query("UPDATE toner SET toner_current = '$tonerperc', toner_capacity = '" . $toner['toner_capacity'] . "' WHERE toner_id = '" . $toner['toner_id'] . "'");
}
}
?>