'device',
'device' => $device['device_id'],
'tab' => 'routing',
'proto' => 'bgp',
);
if (!isset($vars['view'])) {
$vars['view'] = 'basic';
}
print_optionbar_start();
echo 'Local AS : '.$device['bgpLocalAs'].' ';
echo "BGP » ";
if ($vars['view'] == 'basic') {
echo "';
}
echo ' | ';
if ($vars['view'] == 'updates') {
echo "';
}
echo ' | Prefixes: ';
if ($vars['view'] == 'prefixes_ipv4unicast') {
echo "';
}
echo ' | ';
if ($vars['view'] == 'prefixes_vpnv4unicast') {
echo "';
}
echo ' | ';
if ($vars['view'] == 'prefixes_ipv6unicast') {
echo "';
}
echo ' | Traffic: ';
if ($vars['view'] == 'macaccounting_bits') {
echo "';
}
echo ' | ';
if ($vars['view'] == 'macaccounting_pkts') {
echo "';
}
print_optionbar_end();
echo '
';
echo '| Peer address | Type | Family | Remote AS | State | Uptime |
';
$i = '1';
foreach (dbFetchRows("SELECT * FROM `bgpPeers` WHERE `device_id` = ? $extra_sql ORDER BY `bgpPeerRemoteAs`, `bgpPeerIdentifier`", array($device['device_id'])) as $peer) {
$has_macaccounting = dbFetchCell('SELECT COUNT(*) FROM `ipv4_mac` AS I, mac_accounting AS M WHERE I.ipv4_address = ? AND M.mac = I.mac_address', array($peer['bgpPeerIdentifier']));
unset($bg_image);
if (!is_integer($i / 2)) {
$bg_colour = $config['list_colour']['even'];
} else {
$bg_colour = $config['list_colour']['odd'];
}
unset($alert, $bg_image);
unset($peerhost, $peername);
if (!is_integer($i / 2)) {
$bg_colour = $config['list_colour']['odd'];
} else {
$bg_colour = $config['list_colour']['even'];
}
if ($peer['bgpPeerState'] == 'established') {
$col = 'green';
} else {
$col = 'red';
$peer['alert'] = 1;
}
if ($peer['bgpPeerAdminStatus'] == 'start' || $peer['bgpPeerAdminStatus'] == 'running') {
$admin_col = 'green';
} else {
$admin_col = 'gray';
}
if ($peer['bgpPeerAdminStatus'] == 'stop') {
$peer['alert'] = 0;
$peer['disabled'] = 1;
}
if ($peer['bgpPeerRemoteAs'] == $device['bgpLocalAs']) {
$peer_type = "iBGP";
} else {
$peer_type = "eBGP";
}
$query = 'SELECT * FROM ipv4_addresses AS A, ports AS I, devices AS D WHERE ';
$query .= '(A.ipv4_address = ? AND I.port_id = A.port_id)';
$query .= ' AND D.device_id = I.device_id';
$ipv4_host = dbFetchRow($query, array($peer['bgpPeerIdentifier']));
$query = 'SELECT * FROM ipv6_addresses AS A, ports AS I, devices AS D WHERE ';
$query .= '(A.ipv6_address = ? AND I.port_id = A.port_id)';
$query .= ' AND D.device_id = I.device_id';
$ipv6_host = dbFetchRow($query, array($peer['bgpPeerIdentifier']));
if ($ipv4_host) {
$peerhost = $ipv4_host;
} elseif ($ipv6_host) {
$peerhost = $ipv6_host;
} else {
unset($peerhost);
}
$peerhost = cleanPort($peerhost);
if (is_array($peerhost)) {
// $peername = generate_device_link($peerhost);
$peername = generate_device_link($peerhost).' '.generate_port_link($peerhost);
$peer_url = 'device/device='.$peer['device_id'].'/tab=routing/proto=bgp/view=updates/';
} else {
// FIXME
// $peername = gethostbyaddr($peer['bgpPeerIdentifier']); // FFffuuu DNS // Cache this in discovery?
// if ($peername == $peer['bgpPeerIdentifier'])
// {
// unset($peername);
// } else {
// $peername = "".$peername."";
// }
}
unset($peer_af);
unset($sep);
foreach (dbFetchRows('SELECT * FROM `bgpPeers_cbgp` WHERE `device_id` = ? AND bgpPeerIdentifier = ?', array($device['device_id'], $peer['bgpPeerIdentifier'])) as $afisafi) {
$afi = $afisafi['afi'];
$safi = $afisafi['safi'];
$this_afisafi = $afi.$safi;
$peer['afi'] .= $sep.$afi.'.'.$safi;
$sep = '
';
$peer['afisafi'][$this_afisafi] = 1;
// Build a list of valid AFI/SAFI for this peer
}
unset($sep);
// make ipv6 look pretty
$peer['bgpPeerIdentifier'] = (string)IP::parse($peer['bgpPeerIdentifier'], true);
// display overlib graphs
$graph_array = array();
$graph_array['type'] = 'bgp_updates';
$graph_array['id'] = $peer['bgpPeer_id'];
$graph_array['to'] = $config['time']['now'];
$graph_array['from'] = $config['time']['day'];
$graph_array['height'] = '110';
$graph_array['width'] = $width;
// Peer Address
$graph_array_zoom = $graph_array;
$graph_array_zoom['height'] = '150';
$graph_array_zoom['width'] = '500';
$overlib_link = "device/device=".$peer['device_id']."/tab=routing/proto=bgp/";
$link_array = $graph_array;
$link_array['page'] = 'graphs';
unset($link_array['height'], $link_array['width'], $link_array['legend']);
$link = generate_url($link_array);
$peeraddresslink = "".overlib_link($link, $peer['bgpPeerIdentifier'], generate_graph_tag($graph_array_zoom), null)."";
echo '
';
echo '
'.$peeraddresslink.' '.$peername." |
$peer_type |
".(isset($peer['afi']) ? $peer['afi'] : '').' |
AS'.$peer['bgpPeerRemoteAs'].' '.$peer['astext']." |
".$peer['bgpPeerAdminStatus']." ".$peer['bgpPeerState'].' |
'.formatUptime($peer['bgpPeerFsmEstablishedTime'])."
Updates ".$peer['bgpPeerInUpdates']."
".$peer['bgpPeerOutUpdates'].' |
';
unset($invalid);
switch ($vars['view']) {
case 'prefixes_ipv4unicast':
case 'prefixes_ipv4multicast':
case 'prefixes_ipv4vpn':
case 'prefixes_ipv6unicast':
case 'prefixes_ipv6multicast':
list(,$afisafi) = explode('_', $vars['view']);
if (isset($peer['afisafi'][$afisafi])) {
$peer['graph'] = 1;
}
// FIXME no break??
case 'updates':
$graph_array['type'] = 'bgp_'.$vars['view'];
$graph_array['id'] = $peer['bgpPeer_id'];
}
switch ($vars['view']) {
case 'macaccounting_bits':
case 'macaccounting_pkts':
$acc = dbFetchRow('SELECT * FROM `ipv4_mac` AS I, `mac_accounting` AS M, `ports` AS P, `devices` AS D WHERE I.ipv4_address = ? AND M.mac = I.mac_address AND P.port_id = M.port_id AND D.device_id = P.device_id', array($peer['bgpPeerIdentifier']));
$database = rrd_name($device['hostname'], array('cip', $acc['ifIndex'], $acc['mac']));
if (is_array($acc) && is_file($database)) {
$peer['graph'] = 1;
$graph_array['id'] = $acc['ma_id'];
$graph_array['type'] = $vars['view'];
}
}
if ($vars['view'] == 'updates') {
$peer['graph'] = 1;
}
if ($peer['graph']) {
$graph_array['height'] = '100';
$graph_array['width'] = '216';
$graph_array['to'] = $config['time']['now'];
echo '| ';
include 'includes/print-graphrow.inc.php';
echo ' |
';
}
$i++;
unset($valid_afi_safi);
}//end foreach
?>