mirror of
https://github.com/librenms/librenms.git
synced 2024-10-07 16:52:45 +00:00
Netscaler vservers table update (#10103)
* webui: Netscaler Vservers add table header and vserver type * webui: Netscaler Vserver sorting (name, traffic in/out)
This commit is contained in:
committed by
Tony Murray
parent
c96b72f103
commit
1e76915af3
@@ -15,8 +15,14 @@ if (is_numeric($vars['vsvr'])) {
|
||||
|
||||
$i = 0;
|
||||
|
||||
echo "<div style='margin: 5px;'><table border=0 cellspacing=0 cellpadding=5 width=100%>";
|
||||
foreach (dbFetchRows('SELECT * FROM `netscaler_vservers` WHERE `device_id` = ? AND `vsvr_id` = ? ORDER BY `vsvr_name`', array($device['device_id'], $vars['vsvr'])) as $vsvr) {
|
||||
echo "<div style='margin: 0px;'><table class='table'>";
|
||||
// Table header
|
||||
echo "<tr><th width=320>VServer</th><th width=320>VIP and port</th><th width=100>State</th>";
|
||||
echo "<th width=320>Type</th><th width=320>Inbound traffic</th><th width=320>Outbound traffic</th></tr>";
|
||||
// Vserver graphs
|
||||
// Can this really return more than one row?
|
||||
$vservers = dbFetchRows('SELECT * FROM `netscaler_vservers` WHERE `device_id` = ? AND `vsvr_id` = ? ORDER BY `vsvr_name`', array($device['device_id'], $vars['vsvr']));
|
||||
foreach ($vservers as $vsvr) {
|
||||
if (is_integer($i / 2)) {
|
||||
$bg_colour = $config['list_colour']['even'];
|
||||
} else {
|
||||
@@ -24,17 +30,20 @@ if (is_numeric($vars['vsvr'])) {
|
||||
}
|
||||
|
||||
if ($vsvr['vsvr_state'] == 'up') {
|
||||
$vsvr_class = 'green';
|
||||
$vsvr_label = 'success';
|
||||
} elseif ($vsvr['vsvr_state'] == 'down') {
|
||||
$vsvr_label = 'danger';
|
||||
} else {
|
||||
$vsvr_class = 'red';
|
||||
$vsvr_label = 'default';
|
||||
}
|
||||
|
||||
echo "<tr bgcolor='$bg_colour'>";
|
||||
echo '<td width=320 class=list-large><a href="'.generate_url($vars, array('vsvr' => $vsvr['vsvr_id'], 'view' => null, 'graph' => null)).'">'.$vsvr['vsvr_name'].'</a></td>';
|
||||
echo '<td width=320 class=list-small>'.$vsvr['vsvr_ip'].':'.$vsvr['vsvr_port'].'</a></td>';
|
||||
echo "<td width=100 class=list-small><span class='".$vsvr_class."'>".$vsvr['vsvr_state'].'</span></td>';
|
||||
echo ('<td width=320 class=list-small>'.format_si(($vsvr['vsvr_bps_in'] * 8)).'bps</a></td>');
|
||||
echo ('<td width=320 class=list-small>'.format_si(($vsvr['vsvr_bps_out'] * 8)).'bps</a></td>');
|
||||
echo '<td><a href="'.generate_url($vars, array('vsvr' => $vsvr['vsvr_id'], 'view' => null, 'graph' => null)).'">'.$vsvr['vsvr_name'].'</a></td>';
|
||||
echo '<td>' . $vsvr['vsvr_ip'] . ':' . $vsvr['vsvr_port'] . '</td>';
|
||||
echo "<td><span class='label label-" . $vsvr_label . "'>" . $vsvr['vsvr_state'] . '</span></td>';
|
||||
echo '<td><span class="label label-default">' . $vsvr['vsvr_type'] . '</span></td>';
|
||||
echo ('<td>'.format_si(($vsvr['vsvr_bps_in'] * 8)).'bps</a></td>');
|
||||
echo ('<td>'.format_si(($vsvr['vsvr_bps_out'] * 8)).'bps</a></td>');
|
||||
echo '</tr>';
|
||||
|
||||
foreach ($graph_types as $graph_type => $graph_text) {
|
||||
@@ -110,9 +119,34 @@ if (is_numeric($vars['vsvr'])) {
|
||||
|
||||
print_optionbar_end();
|
||||
|
||||
echo "<div style='margin: 5px;'><table border=0 cellspacing=0 cellpadding=5 width=100%>";
|
||||
echo "<div style='margin: 0px;'><table class='table'>";
|
||||
// Table header
|
||||
echo "<tr><th width=320><a href=" . generate_url($vars, array('sort' => "vsvr_name")) . ">VServer</a></th>";
|
||||
echo "<th width=320>VIP and port</th><th width=100>State</th><th width=320>Type</th>";
|
||||
echo "<th width=320><a href=" . generate_url($vars, array('sort' => "vsvr_bps_in")) . ">Inbound traffic</a></th>";
|
||||
echo "<th width=320><a href=" . generate_url($vars, array('sort' => "vsvr_bps_out")). ">Outbound traffic</a></th></tr>";
|
||||
// Vserver list
|
||||
$vservers = dbFetchRows('SELECT * FROM `netscaler_vservers` WHERE `device_id` = ? ORDER BY `vsvr_name`', array($device['device_id']));
|
||||
|
||||
// Vserver sorting
|
||||
$valid_sort_keys = array('vsvr_bps_in', 'vsvr_bps_out', 'vsrv_name');
|
||||
if (isset($vars['sort']) && in_array($vars['sort'], $valid_sort_keys)) {
|
||||
$sort_key = $vars['sort'];
|
||||
} else {
|
||||
$sort_key = 'vsvr_name';
|
||||
}
|
||||
switch ($sort_key) {
|
||||
case 'vsvr_bps_in':
|
||||
case 'vsvr_bps_out':
|
||||
$sort_direction = SORT_DESC;
|
||||
break;
|
||||
default:
|
||||
$sort_direction = SORT_ASC;
|
||||
}
|
||||
$vservers = array_sort_by_column($vservers, $sort_key, $sort_direction);
|
||||
|
||||
$i = '0';
|
||||
foreach (dbFetchRows('SELECT * FROM `netscaler_vservers` WHERE `device_id` = ? ORDER BY `vsvr_name`', array($device['device_id'])) as $vsvr) {
|
||||
foreach ($vservers as $vsvr) {
|
||||
if (is_integer($i / 2)) {
|
||||
$bg_colour = $config['list_colour']['even'];
|
||||
} else {
|
||||
@@ -120,17 +154,20 @@ if (is_numeric($vars['vsvr'])) {
|
||||
}
|
||||
|
||||
if ($vsvr['vsvr_state'] == 'up') {
|
||||
$vsvr_class = 'green';
|
||||
$vsvr_label = 'success';
|
||||
} elseif ($vsvr['vsvr_state'] == 'down') {
|
||||
$vsvr_label = 'danger';
|
||||
} else {
|
||||
$vsvr_class = 'red';
|
||||
$vsvr_label = 'default';
|
||||
}
|
||||
|
||||
echo "<tr bgcolor='$bg_colour'>";
|
||||
echo '<td width=320 class=list-large><a href="'.generate_url($vars, array('vsvr' => $vsvr['vsvr_id'], 'view' => null, 'graph' => null)).'">'.$vsvr['vsvr_name'].'</a></td>';
|
||||
echo '<td width=320 class=list-small>'.$vsvr['vsvr_ip'].':'.$vsvr['vsvr_port'].'</a></td>';
|
||||
echo "<td width=100 class=list-small><span class='".$vsvr_class."'>".$vsvr['vsvr_state'].'</span></td>';
|
||||
echo ('<td width=320 class=list-small>'.format_si(($vsvr['vsvr_bps_in'] * 8)).'bps</a></td>');
|
||||
echo ('<td width=320 class=list-small>'.format_si(($vsvr['vsvr_bps_out'] * 8)).'bps</a></td>');
|
||||
echo '<td><a href="'.generate_url($vars, array('vsvr' => $vsvr['vsvr_id'], 'view' => null, 'graph' => null)).'">'.$vsvr['vsvr_name'].'</a></td>';
|
||||
echo '<td>' . $vsvr['vsvr_ip'] . ':' . $vsvr['vsvr_port'] . '</td>';
|
||||
echo "<td><span class='label label-" . $vsvr_label . "'>" . $vsvr['vsvr_state'] . '</span></td>';
|
||||
echo '<td><span class="label label-default">' . $vsvr['vsvr_type'] . '</span></td>';
|
||||
echo ('<td>'.format_si(($vsvr['vsvr_bps_in'] * 8)).'bps</a></td>');
|
||||
echo ('<td>'.format_si(($vsvr['vsvr_bps_out'] * 8)).'bps</a></td>');
|
||||
echo '</tr>';
|
||||
if ($vars['view'] == 'graphs') {
|
||||
echo '<tr class="list-bold" bgcolor="'.$bg_colour.'">';
|
||||
|
||||
Reference in New Issue
Block a user