blob: 4221b5fcfc1e61e3da8078cee4ac66206225bcec (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
|
#!/usr/bin/perl
# Module: vyatta-gateway-static_route-check.pl
#
# **** License ****
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License version 2 as
# published by the Free Software Foundation.
#
# This program is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
# General Public License for more details.
#
# A copy of the GNU General Public License is available as
# `/usr/share/common-licenses/GPL' in the Debian GNU/Linux distribution
# or on the World Wide Web at `http://www.gnu.org/copyleft/gpl.html'.
# You can also obtain it by writing to the Free Software Foundation,
# Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
# MA 02110-1301, USA.
#
# This code was originally developed by Vyatta, Inc.
# Portions created by Vyatta are Copyright (C) 2008 Vyatta, Inc.
# All Rights Reserved.
#
# Author: Mohit Mehta
# Date: June 2008
# Description: Script to check if any one of the 'static route' is
# equivalent to the 'system gateway-address' if yes, then
# don't remove route from routing table unless both are
# unset
# **** End License ****
use strict;
use warnings;
use lib "/opt/vyatta/share/perl5/";
use Vyatta::Config;
sub findStaticDefaultRoute {
my ( $cfg ) = @_;
if ($cfg->exists('protocols static')) {
my @routes = $cfg->listNodes("protocols static route");
if (@routes > 0) {
foreach my $route (@routes) {
if ($route eq '0.0.0.0/0') {
return 1;
}
}
}
}
return 0;
}
if ( ( $#ARGV == 1 ) && ( $ARGV[0] eq '0.0.0.0/0' ) ) {
# check when deleting static-route
my $vcCHECK_GATEWAY = new Vyatta::Config();
$vcCHECK_GATEWAY->setLevel('system');
if ( $vcCHECK_GATEWAY->exists('.') ) {
my $gateway_ip = $vcCHECK_GATEWAY->returnValue('gateway-address');
if ( defined($gateway_ip) && $gateway_ip eq $ARGV[1] ) {
exit 1;
}
}
} elsif ( $#ARGV == 0 ) {
if ($ARGV[0] eq 'warn') {
my $config = new Vyatta::Config();
my $haveGatewayAddress = $config->exists("system gateway-address");
my $haveStaticDefaultRoute = findStaticDefaultRoute($config);
if ($haveGatewayAddress && $haveStaticDefaultRoute) {
print "Warning:\n";
print "Both 'system gateway-address' and 'protocols static route 0.0.0.0/0'\n";
print "are configured. This configuration is not recommended.\n";
}
} else {
# check when deleting gateway-address
my $vcCHECK_STATIC_ROUTE = new Vyatta::Config();
$vcCHECK_STATIC_ROUTE->setLevel('protocols static');
if ( $vcCHECK_STATIC_ROUTE->exists('.') ) {
my @routes = $vcCHECK_STATIC_ROUTE->listNodes("route");
if ( @routes > 0 ) {
foreach my $route (@routes) {
if ( $route eq '0.0.0.0/0' ) {
my @next_hops =
$vcCHECK_STATIC_ROUTE->listNodes("route $route next-hop");
foreach my $next_hop (@next_hops) {
if ( $next_hop eq $ARGV[0] ) {
exit 1;
}
}
}
}
}
}
}
}
exit 0;
|