fixed billing cumulative graphs. this time with fewer bugz. from codekiller.

git-svn-id: http://www.observium.org/svn/observer/trunk@2745 61d68cd4-352d-0410-923a-c4978735b2b8
This commit is contained in:
Adam Amstrong
2011-12-01 01:09:23 +00:00
parent 00c76d5071
commit ebc74d0e99

View File

@@ -42,15 +42,14 @@
$end = $_GET['to']; $end = $_GET['to'];
$xsize = (is_numeric($_GET['x']) ? $_GET['x'] : "800" ); $xsize = (is_numeric($_GET['x']) ? $_GET['x'] : "800" );
$ysize = (is_numeric($_GET['y']) ? $_GET['y'] : "250" ); $ysize = (is_numeric($_GET['y']) ? $_GET['y'] : "250" );
$count = (is_numeric($_GET['count']) ? $_GET['count'] : "0" ); // $count = (is_numeric($_GET['count']) ? $_GET['count'] : "0" );
$iter = 1; // $type = (isset($_GET['type']) ? $_GET['type'] : "date" );
$type = (isset($_GET['type']) ? $_GET['type'] : "date" ); // $dur = $end - $start;
$dur = $end - $start; // $datefrom = date('Ymthis', $start);
$datefrom = date('Ymthis', $start); // $dateto = date('Ymthis', $end);
$dateto = date('Ymthis', $end);
$imgtype = (isset($_GET['imgtype']) ? $_GET['imgtype'] : "historical" ); $imgtype = (isset($_GET['imgtype']) ? $_GET['imgtype'] : "historical" );
$imgbill = (isset($_GET['imgbill']) ? $_GET['imgbill'] : false); $imgbill = (isset($_GET['imgbill']) ? $_GET['imgbill'] : false);
$yaxistitle = "Gigabytes"; $yaxistitle = "Bytes";
$in_data = array(); $in_data = array();
$out_data = array(); $out_data = array();
@@ -60,12 +59,31 @@
$overuse_data = array(); $overuse_data = array();
$ticklabels = array(); $ticklabels = array();
function yaxisTitle($value) { function humanReadable($value, $title = false, $max = false, $decimals = 3) {
if ($value == "TB") { $res = "Terabytes"; } $suffix = array("Bytes", "Kilobytes", "Megabytes", "Gigabytes", "Terabytes", "Petabytes");
elseif ($value == "GB") { $res = "Gigabytes"; } $max = (($max == false) ? count($suffix) : $max);
elseif ($value == "MB") { $res = "Megabytes"; } $i = 0;
elseif ($value == "KB") { $res = "Kilobytes"; } while($value >= 1024 && ($i < $max)) {
else { $res = "Bytes"; } $value /= 1024;
$i++;
}
if ($title == "suffix") {
$tmp = $i;
$res = $suffix[$tmp];
} elseif ($title == "count") {
$res = $i;
} else {
$res = round($value, $decimals);
}
return $res;
}
function formatScale($value, $max, $decimal) {
$res = array();
foreach($value as $item) {
$tmp = humanReadable($item, false, $max, $decimal);
array_push($res, $tmp);
}
return $res; return $res;
} }
@@ -109,46 +127,65 @@
$graph_name = "Historical bandwidth over the last 12 billing periods"; $graph_name = "Historical bandwidth over the last 12 billing periods";
} else { } else {
$data = array(); $data = array();
$max = 9999999999999999999999999999999999999999999;
$min_data = array("in"=>$max, "out"=>$max, "tot"=>$max);
$average = 0; $average = 0;
if ($imgtype == "day") { if ($imgtype == "day") {
foreach(dbFetch("SELECT DISTINCT UNIX_TIMESTAMP(timestamp) as timestamp, SUM(delta) as traf_total, SUM(in_delta) as traf_in, SUM(out_delta) as traf_out FROM bill_data WHERE `bill_id` = ? AND `timestamp` >= FROM_UNIXTIME(?) AND `timestamp` <= FROM_UNIXTIME(?) GROUP BY DATE(timestamp) ORDER BY timestamp ASC", array($bill_id, $start, $end)) as $data) { foreach(dbFetch("SELECT DISTINCT UNIX_TIMESTAMP(timestamp) as timestamp, SUM(delta) as traf_total, SUM(in_delta) as traf_in, SUM(out_delta) as traf_out FROM bill_data WHERE `bill_id` = ? AND `timestamp` >= FROM_UNIXTIME(?) AND `timestamp` <= FROM_UNIXTIME(?) GROUP BY DATE(timestamp) ORDER BY timestamp ASC", array($bill_id, $start, $end)) as $data) {
$traf['in'] = round(substr(formatStorage($data['traf_in']), 0, -2)); $traf['in'] = (isset($data['traf_in']) ? $data['traf_in'] : 0);
$traf['out'] = round(substr(formatStorage($data['traf_out']), 0, -2)); $traf['out'] = (isset($data['traf_out']) ? $data['traf_out'] : 0);
$traf['total'] = round(substr(formatStorage($data['traf_total']), 0, -2)); $traf['total'] = (isset($data['traf_total']) ? $data['traf_total'] : 0);
$yaxistitle = yaxisTitle(substr(formatStorage($data['traf_total']), -2));
$datelabel = strftime("%e\n%b", $data['timestamp']); $datelabel = strftime("%e\n%b", $data['timestamp']);
array_push($ticklabels, $datelabel); array_push($ticklabels, $datelabel);
array_push($in_data, $traf['in']); array_push($in_data, $traf['in']);
array_push($out_data, $traf['out']); array_push($out_data, $traf['out']);
array_push($tot_data, $traf['total']); array_push($tot_data, $traf['total']);
// $min_data['in'] = (($traf['in'] < $min_data['in']) ? $traf['in'] : $min_data['in']);
// $min_data['out']= (($traf['out'] < $min_data['out']) ? $traf['out'] : $min_data['out']);
// $min_data['tot']= (($traf['total'] < $min_data['tot']) ? $traf['total'] : $min_data['tot']);
$average += $data['traf_total']; $average += $data['traf_total'];
} }
$ave_count = count($tot_data); $min_data['in'] = min($in_data);
$min_data['out'] = min($out_data);
$min_data['tot'] = min($tot_data);
$ave_count = count($tot_data);
if ($imgbill != false) { if ($imgbill != false) {
$days = strftime("%e", date($end - $start)) - $ave_count; $days = strftime("%e", date($end - $start)) - $ave_count - 1;
for ($x=0;$x<$days;$x++) { for ($x=0;$x<$days;$x++) {
array_push($ticklabels, ""); array_push($ticklabels, "");
array_push($in_data, "0"); array_push($in_data, 0);
array_push($out_data, "0"); array_push($out_data, 0);
array_push($tot_data, "0"); array_push($tot_data, 0);
} }
} }
} elseif ($imgtype == "hour") { } elseif ($imgtype == "hour") {
foreach(dbFetch("SELECT DISTINCT UNIX_TIMESTAMP(timestamp) as timestamp, SUM(delta) as traf_total, SUM(in_delta) as traf_in, SUM(out_delta) as traf_out FROM bill_data WHERE `bill_id` = ? AND `timestamp` >= FROM_UNIXTIME(?) AND `timestamp` <= FROM_UNIXTIME(?) GROUP BY HOUR(timestamp) ORDER BY timestamp ASC", array($bill_id, $start, $end)) as $data) { foreach(dbFetch("SELECT DISTINCT UNIX_TIMESTAMP(timestamp) as timestamp, SUM(delta) as traf_total, SUM(in_delta) as traf_in, SUM(out_delta) as traf_out FROM bill_data WHERE `bill_id` = ? AND `timestamp` >= FROM_UNIXTIME(?) AND `timestamp` <= FROM_UNIXTIME(?) GROUP BY HOUR(timestamp) ORDER BY timestamp ASC", array($bill_id, $start, $end)) as $data) {
$traf['in'] = round(substr(formatStorage($data['traf_in']), 0, -2)); $traf['in'] = (isset($data['traf_in']) ? $data['traf_in'] : 0);
$traf['out'] = round(substr(formatStorage($data['traf_out']), 0, -2)); $traf['out'] = (isset($data['traf_out']) ? $data['traf_out'] : 0);
$traf['total'] = round(substr(formatStorage($data['traf_total']), 0, -2)); $traf['total'] = (isset($data['traf_total']) ? $data['traf_total'] : 0);
$datelabel = strftime("%H:%M", $data['timestamp']); $datelabel = strftime("%H:%M", $data['timestamp']);
$yaxistitle = yaxisTitle(substr(formatStorage($data['traf_total']), -2));
array_push($ticklabels, $datelabel); array_push($ticklabels, $datelabel);
array_push($in_data, $traf['in']); array_push($in_data, $traf['in']);
array_push($out_data, $traf['out']); array_push($out_data, $traf['out']);
array_push($tot_data, $traf['total']); array_push($tot_data, $traf['total']);
// $min_data['in'] = (($traf['in'] < $min_data['in']) ? $traf['in'] : $min_data['in']);
// $min_data['out']= (($traf['out'] < $min_data['out']) ? $traf['out'] : $min_data['out']);
// $min_data['tot']= (($traf['tot'] < $min_data['tot']) ? $traf['tot'] : $min_data['tot']);
$average += $data['traf_total']; $average += $data['traf_total'];
} }
$ave_count = count($tot_data); $min_data['in'] = min($in_data);
$min_data['out'] = min($out_data);
$min_data['tot'] = min($tot_data);
$ave_count = count($tot_data);
} }
$average = round(substr(formatStorage(($average / $ave_count)), 0, -2)); $decimal = 0;
$max = min($min_data);
$yaxistitle = humanReadable($max, "suffix");
$max = humanReadable($max, "count");
$in_data = formatScale($in_data, $max, $decimal);
$out_data = formatScale($out_data, $max, $decimal);
$tot_data = formatScale($tot_data, $max, $decimal);
$average = humanReadable(($average / $ave_count), false, $max, $decimal);
for ($x=0;$x<=count($tot_data);$x++) { for ($x=0;$x<=count($tot_data);$x++) {
array_push($ave_data, $average); array_push($ave_data, $average);
} }
@@ -218,7 +255,6 @@
$lineplot_allow = new LinePlot($ave_data); $lineplot_allow = new LinePlot($ave_data);
$lineplot_allow->SetLegend("Average per day"); $lineplot_allow->SetLegend("Average per day");
$lineplot_allow->SetColor('black'); $lineplot_allow->SetColor('black');
//$lineplot_allow->SetFillColor('lightred@0.4');
$lineplot_allow->SetWeight(1); $lineplot_allow->SetWeight(1);
$gbplot = new GroupBarPlot(array($barplot_in, $barplot_out, $barplot_tot)); $gbplot = new GroupBarPlot(array($barplot_in, $barplot_out, $barplot_tot));