mirror of
https://github.com/librenms/librenms.git
synced 2024-10-07 16:52:45 +00:00
- Add the ability to only graph a single class map
- Add links to the classes on the policy selector.
This commit is contained in:
@@ -38,8 +38,30 @@ $rrd_additions = "";
|
||||
|
||||
$colours = array_merge($config['graph_colours']['mixed'],$config['graph_colours']['manycolours'],$config['graph_colours']['manycolours']);
|
||||
$count = 0;
|
||||
|
||||
d_echo("<pre>Policy: ".$vars['policy']);
|
||||
d_echo("\nSP-OBJ: ".$components[$vars['policy']]['sp-obj']);
|
||||
foreach ($components as $id => $array) {
|
||||
$addtograph = false;
|
||||
|
||||
// We only care about children of the selected policy.
|
||||
if ( ($array['qos-type'] == 2) && ($array['parent'] == $components[$vars['policy']]['sp-obj']) && ($array['sp-id'] == $components[$vars['policy']]['sp-id'])) {
|
||||
|
||||
// Are we trying to only graph a single class?
|
||||
if (isset($vars['class'])) {
|
||||
// Yes, is this the selected class
|
||||
if ($vars['class'] == $id) {
|
||||
$addtograph = true;
|
||||
}
|
||||
}
|
||||
else {
|
||||
// No, Graph everything
|
||||
$addtograph = true;
|
||||
}
|
||||
|
||||
// Add the class map to the graph
|
||||
if ($addtograph === true) {
|
||||
d_echo("\n Class: ".$components[$id]['label']."\t+ added to the graph");
|
||||
$rrd_filename = $config['rrd_dir'].'/'.$device['hostname'].'/'.safename("port-".$array['ifindex']."-cbqos-".$array['sp-id']."-".$array['sp-obj'].".rrd");
|
||||
|
||||
if (file_exists($rrd_filename)) {
|
||||
@@ -54,7 +76,7 @@ foreach ($components as $id => $array) {
|
||||
$colour = $colours[$count];
|
||||
}
|
||||
else {
|
||||
d_echo("<pre>Error: Out of colours. Have: ".(count($colours)-1).", Requesting:".$count."</pre>");
|
||||
d_echo("\nError: Out of colours. Have: ".(count($colours)-1).", Requesting:".$count);
|
||||
}
|
||||
|
||||
$rrd_additions .= " DEF:DS" . $count . "=" . $rrd_filename . ":bufferdrops:AVERAGE ";
|
||||
@@ -65,9 +87,14 @@ foreach ($components as $id => $array) {
|
||||
$rrd_additions .= " GPRINT:MOD" . $count . ":MAX:%6.2lf%s\\\l ";
|
||||
|
||||
$count++;
|
||||
} // End if file exists
|
||||
}
|
||||
else {
|
||||
d_echo("\n Class: ".$components[$id]['label']."\t- NOT added to the graph");
|
||||
} // End if addtograph
|
||||
}
|
||||
}
|
||||
}
|
||||
d_echo("</pre>");
|
||||
|
||||
if ($rrd_additions == "") {
|
||||
// We didn't add any data points.
|
||||
|
@@ -38,8 +38,30 @@ $rrd_additions = "";
|
||||
|
||||
$colours = array_merge($config['graph_colours']['mixed'],$config['graph_colours']['manycolours'],$config['graph_colours']['manycolours']);
|
||||
$count = 0;
|
||||
|
||||
d_echo("<pre>Policy: ".$vars['policy']);
|
||||
d_echo("\nSP-OBJ: ".$components[$vars['policy']]['sp-obj']);
|
||||
foreach ($components as $id => $array) {
|
||||
$addtograph = false;
|
||||
|
||||
// We only care about children of the selected policy.
|
||||
if ( ($array['qos-type'] == 2) && ($array['parent'] == $components[$vars['policy']]['sp-obj']) && ($array['sp-id'] == $components[$vars['policy']]['sp-id'])) {
|
||||
|
||||
// Are we trying to only graph a single class?
|
||||
if (isset($vars['class'])) {
|
||||
// Yes, is this the selected class
|
||||
if ($vars['class'] == $id) {
|
||||
$addtograph = true;
|
||||
}
|
||||
}
|
||||
else {
|
||||
// No, Graph everything
|
||||
$addtograph = true;
|
||||
}
|
||||
|
||||
// Add the class map to the graph
|
||||
if ($addtograph === true) {
|
||||
d_echo("\n Class: ".$components[$id]['label']."\t+ added to the graph");
|
||||
$rrd_filename = $config['rrd_dir'].'/'.$device['hostname'].'/'.safename("port-".$array['ifindex']."-cbqos-".$array['sp-id']."-".$array['sp-obj'].".rrd");
|
||||
|
||||
if (file_exists($rrd_filename)) {
|
||||
@@ -54,7 +76,7 @@ foreach ($components as $id => $array) {
|
||||
$colour = $colours[$count];
|
||||
}
|
||||
else {
|
||||
d_echo("<pre>Error: Out of colours. Have: ".(count($colours)-1).", Requesting:".$count."</pre>");
|
||||
d_echo("\nError: Out of colours. Have: ".(count($colours)-1).", Requesting:".$count);
|
||||
}
|
||||
|
||||
$rrd_additions .= " DEF:DS" . $count . "=" . $rrd_filename . ":qosdrops:AVERAGE ";
|
||||
@@ -65,9 +87,14 @@ foreach ($components as $id => $array) {
|
||||
$rrd_additions .= " GPRINT:MOD" . $count . ":MAX:%6.2lf%s\\\l ";
|
||||
|
||||
$count++;
|
||||
} // End if file exists
|
||||
}
|
||||
else {
|
||||
d_echo("\n Class: ".$components[$id]['label']."\t- NOT added to the graph");
|
||||
} // End if addtograph
|
||||
}
|
||||
}
|
||||
}
|
||||
d_echo("</pre>");
|
||||
|
||||
if ($rrd_additions == "") {
|
||||
// We didn't add any data points.
|
||||
|
@@ -38,8 +38,30 @@ $rrd_additions = "";
|
||||
|
||||
$colours = array_merge($config['graph_colours']['mixed'],$config['graph_colours']['manycolours'],$config['graph_colours']['manycolours']);
|
||||
$count = 0;
|
||||
|
||||
d_echo("<pre>Policy: ".$vars['policy']);
|
||||
d_echo("\nSP-OBJ: ".$components[$vars['policy']]['sp-obj']);
|
||||
foreach ($components as $id => $array) {
|
||||
$addtograph = false;
|
||||
|
||||
// We only care about children of the selected policy.
|
||||
if ( ($array['qos-type'] == 2) && ($array['parent'] == $components[$vars['policy']]['sp-obj']) && ($array['sp-id'] == $components[$vars['policy']]['sp-id'])) {
|
||||
|
||||
// Are we trying to only graph a single class?
|
||||
if (isset($vars['class'])) {
|
||||
// Yes, is this the selected class
|
||||
if ($vars['class'] == $id) {
|
||||
$addtograph = true;
|
||||
}
|
||||
}
|
||||
else {
|
||||
// No, Graph everything
|
||||
$addtograph = true;
|
||||
}
|
||||
|
||||
// Add the class map to the graph
|
||||
if ($addtograph === true) {
|
||||
d_echo("\n Class: ".$components[$id]['label']."\t+ added to the graph");
|
||||
$rrd_filename = $config['rrd_dir'].'/'.$device['hostname'].'/'.safename("port-".$array['ifindex']."-cbqos-".$array['sp-id']."-".$array['sp-obj'].".rrd");
|
||||
|
||||
if (file_exists($rrd_filename)) {
|
||||
@@ -54,7 +76,7 @@ foreach ($components as $id => $array) {
|
||||
$colour = $colours[$count];
|
||||
}
|
||||
else {
|
||||
d_echo("<pre>Error: Out of colours. Have: ".(count($colours)-1).", Requesting:".$count."</pre>");
|
||||
d_echo("\nError: Out of colours. Have: ".(count($colours)-1).", Requesting:".$count);
|
||||
}
|
||||
|
||||
$rrd_additions .= " DEF:DS" . $count . "=" . $rrd_filename . ":postbits:AVERAGE ";
|
||||
@@ -65,9 +87,14 @@ foreach ($components as $id => $array) {
|
||||
$rrd_additions .= " GPRINT:MOD" . $count . ":MAX:%6.2lf%s\\\l ";
|
||||
|
||||
$count++;
|
||||
} // End if file exists
|
||||
}
|
||||
else {
|
||||
d_echo("\n Class: ".$components[$id]['label']."\t- NOT added to the graph");
|
||||
} // End if addtograph
|
||||
}
|
||||
}
|
||||
}
|
||||
d_echo("</pre>");
|
||||
|
||||
if ($rrd_additions == "") {
|
||||
// We didn't add any data sources.
|
||||
|
@@ -23,10 +23,16 @@ function find_child($components,$parent,$level) {
|
||||
echo "<li>";
|
||||
if ($array['qos-type'] == 1) {
|
||||
// Its a policy, we need to make it a link.
|
||||
echo('<a href="' . generate_url($vars, array('policy' => $id)) . '">' . $array['label'] . '</a>');
|
||||
$linkvars = array_merge($vars, array('policy' => $id));
|
||||
unset($linkvars['class']);
|
||||
echo('<a href="' . generate_url($linkvars) . '">' . $array['label'] . '</a>');
|
||||
}
|
||||
elseif ($array['qos-type'] == 2) {
|
||||
// Its a class, we need to make it a link.
|
||||
echo('<a href="' . generate_url($vars, array('policy' => $parent,'class' => $id)) . '">' . $array['label'] . '</a>');
|
||||
}
|
||||
else {
|
||||
// No policy, no link
|
||||
// Unknown, no link
|
||||
echo $array['label'];
|
||||
}
|
||||
if (isset($array['match'])) {
|
||||
@@ -102,16 +108,25 @@ foreach ($components as $id => $array) {
|
||||
echo "<div class='col-md-12'>";
|
||||
echo "<div class='graphhead'>Traffic by CBQoS Class - ".$components[$vars['policy']]['label']."</div>";
|
||||
$graph_array['policy'] = $vars['policy'];
|
||||
if (isset($vars['class'])) {
|
||||
$graph_array['class'] = $vars['class'];
|
||||
}
|
||||
$graph_type = 'port_cbqos_traffic';
|
||||
include 'includes/print-interface-graphs.inc.php';
|
||||
|
||||
echo "<div class='graphhead'>QoS Drops by CBQoS Class - ".$components[$vars['policy']]['label']."</div>";
|
||||
$graph_array['policy'] = $vars['policy'];
|
||||
if (isset($vars['class'])) {
|
||||
$graph_array['class'] = $vars['class'];
|
||||
}
|
||||
$graph_type = 'port_cbqos_bufferdrops';
|
||||
include 'includes/print-interface-graphs.inc.php';
|
||||
|
||||
echo "<div class='graphhead'>Buffer Drops by CBQoS Class - ".$components[$vars['policy']]['label']."</div>";
|
||||
$graph_array['policy'] = $vars['policy'];
|
||||
if (isset($vars['class'])) {
|
||||
$graph_array['class'] = $vars['class'];
|
||||
}
|
||||
$graph_type = 'port_cbqos_qosdrops';
|
||||
include 'includes/print-interface-graphs.inc.php';
|
||||
echo "</div>\n\n";
|
||||
|
Reference in New Issue
Block a user