mirror of
https://github.com/librenms/librenms.git
synced 2024-10-07 16:52:45 +00:00
add ability to pass an array of values to rrdtool_update, which are checked and replaced with U if invalid.
git-svn-id: http://www.observium.org/svn/observer/trunk@3152 61d68cd4-352d-0410-923a-c4978735b2b8
This commit is contained in:
@@ -24,8 +24,7 @@ if ($device['os'] != "Snom")
|
||||
|
||||
$data_array = snmpwalk_cache_oid($device, "snmp", array(), "SNMPv2-MIB");
|
||||
|
||||
$rrdupdate = "N";
|
||||
|
||||
$rrdupdate = array();
|
||||
foreach ($oids as $oid)
|
||||
{
|
||||
if (is_numeric($data_array[0][$oid]))
|
||||
@@ -34,7 +33,7 @@ if ($device['os'] != "Snom")
|
||||
} else {
|
||||
$value = "U";
|
||||
}
|
||||
$rrdupdate .= ":$value";
|
||||
$rrdupdate[] = $value;
|
||||
}
|
||||
|
||||
if (isset($data_array[0]['snmpInPkts']) && isset($data_array[0]['snmpOutPkts']))
|
||||
|
@@ -32,8 +32,6 @@ function rrdtool_pipe_open(&$rrd_process, &$rrd_pipes)
|
||||
|
||||
$command = $config['rrdtool'] . " -";
|
||||
|
||||
# $command = "/usr/bin/php /home/observium/dev/testpipe.php";
|
||||
|
||||
$descriptorspec = array(
|
||||
0 => array("pipe", "r"), // stdin is a pipe that the child will read from
|
||||
1 => array("pipe", "w"), // stdout is a pipe that the child will write to
|
||||
@@ -168,7 +166,6 @@ function rrdtool($command, $filename, $options)
|
||||
} else {
|
||||
fwrite($rrd_pipes[0], $cmd."\n");
|
||||
}
|
||||
|
||||
if ($debug)
|
||||
{
|
||||
echo stream_get_contents($rrd_pipes[1]);
|
||||
@@ -209,6 +206,18 @@ function rrdtool_create($filename, $options)
|
||||
|
||||
function rrdtool_update($filename, $options)
|
||||
{
|
||||
/// Do some sanitisation on the data if passed as an array.
|
||||
if(is_array($options))
|
||||
{
|
||||
$values[] = "N";
|
||||
foreach($options as $value)
|
||||
{
|
||||
if(!is_numeric($value)) { $value = U; }
|
||||
$values[] = $value;
|
||||
}
|
||||
$options = implode(':', $values);
|
||||
}
|
||||
|
||||
return rrdtool("update", $filename, $options);
|
||||
}
|
||||
|
||||
|
@@ -24,7 +24,7 @@ include("includes/polling/functions.inc.php");
|
||||
$poller_start = utime();
|
||||
echo("Observium Poller v".$config['version']."\n\n");
|
||||
|
||||
$options = getopt("h:m:i:n:d:r::a::");
|
||||
$options = getopt("h:m:i:n:r:d::a::");
|
||||
|
||||
if ($options['h'] == "odd") { $options['n'] = "1"; $options['i'] = "2"; }
|
||||
elseif ($options['h'] == "even") { $options['n'] = "0"; $options['i'] = "2"; }
|
||||
@@ -74,6 +74,8 @@ if (!$where)
|
||||
exit;
|
||||
}
|
||||
|
||||
print_r($options);
|
||||
|
||||
if (isset($options['d']))
|
||||
{
|
||||
echo("DEBUG!\n");
|
||||
|
Reference in New Issue
Block a user