diff options
author | Stephen Hemminger <stephen.hemminger@vyatta.com> | 2009-03-31 07:40:32 -0700 |
---|---|---|
committer | Stephen Hemminger <stephen.hemminger@vyatta.com> | 2009-03-31 07:40:32 -0700 |
commit | 5cd9cf8567446f92a4b9f0e8fbe7d11aaf46fa12 (patch) | |
tree | e1b1d3dc6323a5ac07b37e6b9b3e49a02d28f6f4 | |
parent | 58c647a42ad8a75308d80c1952a2d7692ed1826b (diff) | |
parent | 3720b90870a67e3920f6a03b6b8d68c84988a2c5 (diff) | |
download | vyatta-cfg-quagga-5cd9cf8567446f92a4b9f0e8fbe7d11aaf46fa12.tar.gz vyatta-cfg-quagga-5cd9cf8567446f92a4b9f0e8fbe7d11aaf46fa12.zip |
Merge branch 'jenner' of 192.168.100.1:git/vyatta-cfg-quagga into jenner
-rwxr-xr-x | scripts/bgp/vyatta-bgp.pl | 25 |
1 files changed, 10 insertions, 15 deletions
diff --git a/scripts/bgp/vyatta-bgp.pl b/scripts/bgp/vyatta-bgp.pl index f6ae9e72..4bc27c53 100755 --- a/scripts/bgp/vyatta-bgp.pl +++ b/scripts/bgp/vyatta-bgp.pl @@ -18,10 +18,10 @@ GetOptions( "check-if-peer-group" => \$checkifpeergroup, ); -check_peer_name($peername) if ($peername); -check_for_peer_groups( $pg, $as ) if ($checkpeergroups); -check_as( ( $pg ? $pg : -1 ), $neighbor, $as ) if ($checkas); -check_if_peer_group($pg) if ($checkifpeergroup); +check_peer_name($peername) if ($peername); +check_for_peer_groups( $pg, $as ) if ($checkpeergroups); +check_as( $pg, $neighbor, $as ) if ($checkas); +check_if_peer_group($pg) if ($checkifpeergroup); exit 0; @@ -85,30 +85,25 @@ sub check_for_peer_groups { # make sure nodes are either in a peer group of have # a remote AS assigned to them. sub check_as { - my $pg = shift; - my $neighbor = shift; + my ($pg,$neighbor, $as) = @_; + die "Neighbor not defined" unless $neighbor; - my $as = shift; + die "neighbor must be address" unless is_ip_v4_or_v6($neighbor); die "AS not defined\n" unless $as; - my $config = new Vyatta::Config; - my $pgtest = $neighbor; # if this is peer-group then short circuit this - return unless is_ip_v4_or_v6($pg); - + my $config = new Vyatta::Config; $config->setLevel("protocols bgp $as neighbor $neighbor"); my $remoteas = $config->returnValue("remote-as"); - return if defined $remoteas; - return if ( $pg > 0 ); + return if $pg; my $peergroup = $config->returnValue("peer-group"); - my $peergroupas = $config->returnValue(" .. $peergroup remote-as"); - die "protocols bgp $as neighbor $neighbor: must define a remote-as or peer-group\n" unless $peergroup; + my $peergroupas = $config->returnValue(" .. $peergroup remote-as"); die "protocols bgp $as neighbor $neighbor: must define a remote-as in neighbor or peer-group $peergroup\n" unless $peergroupas; } |