diff --git a/html/includes/graphs/common.inc.php b/html/includes/graphs/common.inc.php index 5bce925d46..3f1c630b9e 100644 --- a/html/includes/graphs/common.inc.php +++ b/html/includes/graphs/common.inc.php @@ -7,6 +7,8 @@ if($config['trim_tobias']) { $width+=12; } if ($_GET['height']) { $height = mres($_GET['height']); } if ($_GET['inverse']) { $in = 'out'; $out = 'in'; $inverse=TRUE; } else { $in = 'in'; $out = 'out'; } if ($_GET['legend'] == "no") { $rrd_options .= " -g"; } +if ($_GET['nototal']) { $nototal=TRUE;} else { $nototal=FALSE;} +if ($_GET['nodetails']) { $nodetails=TRUE; } else { $nodetails=FALSE; } if ($_GET['title'] == "yes") { $rrd_options .= " --title='".$graph_title."' "; } if (isset($_GET['graph_title'])) { $rrd_options .= " --title='".$_GET['graph_title']."' "; } diff --git a/html/includes/graphs/generic_multi_bits_separated.inc.php b/html/includes/graphs/generic_multi_bits_separated.inc.php index a3834b26cd..d2d917b4bb 100644 --- a/html/includes/graphs/generic_multi_bits_separated.inc.php +++ b/html/includes/graphs/generic_multi_bits_separated.inc.php @@ -15,12 +15,12 @@ $unit_text = "Bits/sec"; if($width > "500") { - $rrd_options .= " COMMENT:'".substr(str_pad($unit_text, $descr_len+5),0,$descr_len+5)." Current Average Maximum '"; + $rrd_options .= " COMMENT:'".substr(str_pad($unit_text, $descr_len+5),0,$descr_len+5)." Current Average Maximum '"; if (!$nototal) { $rrd_options .= " COMMENT:'Total '"; } $rrd_options .= " COMMENT:'\l'"; } else { + $nototal=TRUE; $rrd_options .= " COMMENT:'".substr(str_pad($unit_text, $descr_len+5),0,$descr_len+5)." Now Ave Max\l'"; - } if(!isset($multiplier)) { $multiplier = "8"; } @@ -32,15 +32,16 @@ foreach ($rrd_list as $rrd) $colour_in=$config['graph_colours'][$colours_in][$iter]; $colour_out=$config['graph_colours'][$colours_out][$iter]; - if (isset($rrd['descr_in'])) - { - $descr = rrdtool_escape($rrd['descr_in'], $descr_len) . " In"; - } else { - $descr = rrdtool_escape($rrd['descr'], $descr_len) . " In"; + if (!$nodetails) { + if (isset($rrd['descr_in'])) { + $descr = rrdtool_escape($rrd['descr_in'], $descr_len) . " In"; + } else { + $descr = rrdtool_escape($rrd['descr'], $descr_len) . " In"; + } + $descr_out = rrdtool_escape($rrd['descr_out'], $descr_len) . " Out"; + $descr = str_replace("'", "", $descr); // FIXME does this mean ' should be filtered in rrdtool_escape? probably... + $descr_out = str_replace("'", "", $descr_out); } - $descr_out = rrdtool_escape($rrd['descr_out'], $descr_len) . " Out"; - $descr = str_replace("'", "", $descr); // FIXME does this mean ' should be filtered in rrdtool_escape? probably... - $descr_out = str_replace("'", "", $descr_out); $rrd_options .= " DEF:".$in.$i."=".$rrd['filename'].":".$ds_in.":AVERAGE "; $rrd_options .= " DEF:".$out.$i."=".$rrd['filename'].":".$ds_out.":AVERAGE "; @@ -49,8 +50,7 @@ foreach ($rrd_list as $rrd) $rrd_options .= " CDEF:outB".$i."_neg=outB".$i.",-1,*"; $rrd_options .= " CDEF:octets".$i."=inB".$i.",outB".$i.",+"; - if (!$args['nototal']) - { + if (!$nototal) { $rrd_options .= " VDEF:totin".$i."=inB".$i.",TOTAL"; $rrd_options .= " VDEF:totout".$i."=outB".$i.",TOTAL"; $rrd_options .= " VDEF:tot".$i."=octets".$i.",TOTAL"; @@ -59,24 +59,69 @@ foreach ($rrd_list as $rrd) if ($i) { $stack="STACK"; } $rrd_options .= " AREA:inB".$i."#" . $colour_in . ":'" . $descr . "':$stack"; - $rrd_options .= " GPRINT:inB".$i.":LAST:%6.2lf%s$units"; - $rrd_options .= " GPRINT:inB".$i.":AVERAGE:%6.2lf%s$units"; - $rrd_options .= " GPRINT:inB".$i.":MAX:%6.2lf%s$units\l"; - - if (!$nototal) { $rrd_options .= " GPRINT:totin".$i.":%6.2lf%s$total_units"; } + if (!$nodetails) { + $rrd_options .= " GPRINT:inB".$i.":LAST:%6.2lf%s$units"; + $rrd_options .= " GPRINT:inB".$i.":AVERAGE:%6.2lf%s$units"; + $rrd_options .= " GPRINT:inB".$i.":MAX:%6.2lf%s$units"; + if (!$nototal) { + $rrd_options .= " GPRINT:totin".$i.":%6.2lf%s$total_units"; + } + $rrd_options .= "\l"; + } $rrd_options .= " 'HRULE:0#" . $colour_out.":".$descr_out."'"; $rrd_optionsb .= " 'AREA:outB".$i."_neg#" . $colour_out . "::$stack'"; - $rrd_options .= " GPRINT:outB".$i.":LAST:%6.2lf%s$units"; - $rrd_options .= " GPRINT:outB".$i.":AVERAGE:%6.2lf%s$units"; - $rrd_options .= " GPRINT:outB".$i.":MAX:%6.2lf%s$units\l"; - if (!$nototal) { $rrd_options .= " GPRINT:totout".$i.":%6.2lf%s$total_unit"; } + if (!$nodetails) { + $rrd_options .= " GPRINT:outB".$i.":LAST:%6.2lf%s$units"; + $rrd_options .= " GPRINT:outB".$i.":AVERAGE:%6.2lf%s$units"; + $rrd_options .= " GPRINT:outB".$i.":MAX:%6.2lf%s$units"; + if (!$nototal) { + $rrd_options .= " GPRINT:totout".$i.":%6.2lf%s$total_unit"; + } + $rrd_options .= "\l"; + } $rrd_options .= " 'COMMENT:\l'"; + + if ($i >= 1) { + $aggr_in .= ","; + $aggr_out .= ","; + } + if ($i > 1) { + $aggr_in .= "ADDNAN,"; + $aggr_out .= "ADDNAN,"; + } + $aggr_in .= $in.$i ; + $aggr_out .= $out.$i ; + $i++; $iter++; } +$rrd_options .= " CDEF:aggr".$in."bytes=" . $aggr_in.",ADDNAN"; +$rrd_options .= " CDEF:aggr".$out."bytes=" . $aggr_out.",ADDNAN"; +$rrd_options .= " CDEF:aggrinbits=aggrinbytes,".$multiplier.",*"; +$rrd_options .= " CDEF:aggroutbits=aggroutbytes,".$multiplier.",*"; +$rrd_options .= " VDEF:totalin=aggrinbytes,TOTAL"; +$rrd_options .= " VDEF:totalout=aggroutbytes,TOTAL"; +$rrd_options .= " COMMENT:' \\\\n'"; +$rrd_options .= " COMMENT:'".substr(str_pad("Aggregate In", $descr_len+5),0,$descr_len+5)."'"; +$rrd_options .= " GPRINT:aggrinbits:LAST:%6.2lf%s$units"; +$rrd_options .= " GPRINT:aggrinbits:AVERAGE:%6.2lf%s$units"; +$rrd_options .= " GPRINT:aggrinbits:MAX:%6.2lf%s$units"; +if (!$nototal) { + $rrd_options .= " GPRINT:totalin:%6.2lf%s$total_units"; +} +$rrd_options .= "\\\\n"; +$rrd_options .= " COMMENT:'".substr(str_pad("Aggregate Out", $descr_len+5),0,$descr_len+5)."'"; +$rrd_options .= " GPRINT:aggroutbits:LAST:%6.2lf%s$units"; +$rrd_options .= " GPRINT:aggroutbits:AVERAGE:%6.2lf%s$units"; +$rrd_options .= " GPRINT:aggroutbits:MAX:%6.2lf%s$units"; +if (!$nototal) { + $rrd_options .= " GPRINT:totalout:%6.2lf%s$total_units"; +} +$rrd_options .= "\\\\n"; + if ($custom_graph) { $rrd_options .= $custom_graph; } $rrd_options .= $rrd_optionsb;