diff options
author | Stephen Hemminger <stephen.hemminger@vyatta.com> | 2010-11-30 14:00:30 -0800 |
---|---|---|
committer | Stephen Hemminger <stephen.hemminger@vyatta.com> | 2010-11-30 14:00:30 -0800 |
commit | faae20c0404f7ffc1c7ee0241d451f754e684c59 (patch) | |
tree | f67adfea46f1050e5bbd687a0d71ac33fca93e18 /scripts/vyatta-interfaces.pl | |
parent | 6dae0ea064866ed0fc4a09da716601435c2f318b (diff) | |
download | vyatta-cfg-quagga-faae20c0404f7ffc1c7ee0241d451f754e684c59.tar.gz vyatta-cfg-quagga-faae20c0404f7ffc1c7ee0241d451f754e684c59.zip |
Remove old code for address insertion/deletion/validation
Interface addresses are now checked with other code.
Diffstat (limited to 'scripts/vyatta-interfaces.pl')
-rwxr-xr-x | scripts/vyatta-interfaces.pl | 186 |
1 files changed, 2 insertions, 184 deletions
diff --git a/scripts/vyatta-interfaces.pl b/scripts/vyatta-interfaces.pl index cf74a7d8..11b5c8c5 100755 --- a/scripts/vyatta-interfaces.pl +++ b/scripts/vyatta-interfaces.pl @@ -39,9 +39,7 @@ use Vyatta::Interface; use Getopt::Long; use POSIX; -use NetAddr::IP; use Fcntl; -use Socket; use strict; use warnings; @@ -49,7 +47,7 @@ use warnings; my $dhcp_daemon = '/sbin/dhclient'; my $ETHTOOL = '/sbin/ethtool'; -my ($eth_update, $eth_delete, $addr_set, $dev, $mac, $mac_update); +my ($dev, $mac, $mac_update); my %skip_interface; my ($check_name, $show_names, $vif_name, $warn_name); my ($check_up, $dhcp_command, $allowed_speed); @@ -60,9 +58,6 @@ sub usage { Usage: $0 --dev=<interface> --check=<type> $0 --dev=<interface> --warn $0 --dev=<interface> --valid-mac=<aa:aa:aa:aa:aa:aa> - $0 --dev=<interface> --eth-addr-update=<aa:aa:aa:aa:aa:aa> - $0 --dev=<interface> --eth-addr-delete=<aa:aa:aa:aa:aa:aa> - $0 --dev=<interface> --valid-addr-set={<a.b.c.d>|dhcp} $0 --dev=<interface> --valid-addr-commit={addr1 addr2 ...} $0 --dev=<interface> --speed-duplex=speed,duplex $0 --dev=<interface> --check-speed=speed,duplex @@ -73,11 +68,7 @@ EOF exit 1; } -GetOptions("eth-addr-update=s" => \$eth_update, - "eth-addr-delete=s" => \$eth_delete, - "valid-addr=s" => \$addr_set, - "valid-addr-set=s" => \$addr_set, - "valid-addr-commit=s{,}" => \@addr_commit, +GetOptions("valid-addr-commit=s{,}" => \@addr_commit, "dev=s" => \$dev, "valid-mac=s" => \$mac, "set-mac=s" => \$mac_update, @@ -93,9 +84,6 @@ GetOptions("eth-addr-update=s" => \$eth_update, "allowed-speed" => \$allowed_speed, ) or usage(); -update_eth_addrs($eth_update, $dev) if ($eth_update); -delete_eth_addrs($eth_delete, $dev) if ($eth_delete); -is_valid_addr_set($addr_set, $dev) if ($addr_set); is_valid_addr_commit($dev, @addr_commit) if (@addr_commit); is_valid_mac($mac, $dev) if ($mac); update_mac($mac_update, $dev) if ($mac_update); @@ -119,18 +107,6 @@ sub is_ipv4 { return index($_[0],':') < 0; } -sub is_ip_duplicate { - my ($intf, $ip) = @_; - - # get a map of all ipv4 and ipv6 addresses - my %ipaddrs_hash = map { $_ => 1 } getIP(); - - return unless($ipaddrs_hash{$ip}); - - # allow dup if it's the same interface - return !is_ip_configured($intf, $ip); -} - sub is_up { my $name = shift; my $intf = new Vyatta::Interface($name); @@ -252,65 +228,6 @@ sub stop_dhclient { or warn "stop $dhcp_daemon failed: $?\n"; } -sub update_eth_addrs { - my ($addr, $intf) = @_; - - if ($addr eq "dhcp") { - touch("/var/lib/dhcp3/$intf"); - run_dhclient($intf); - return; - } - my $version = is_ip_v4_or_v6($addr); - die "Unknown address not IPV4 or IPV6" unless $version; - - if (is_ip_configured($intf, $addr)) { - # - # treat this as informational, don't fail - # - print "Address $addr already configured on $intf\n"; - exit 0; - } - - if ($version == 4) { - exec (qw(ip addr add),$addr,qw(broadcast + dev), $intf) - or die "ip addr command failed: $!"; - } - if ($version == 6) { - exec (qw(ip -6 addr add), $addr, 'dev', $intf) - or die "ip addr command failed: $!"; - } - die "Error: Invalid address/prefix [$addr] for interface $intf\n"; -} - -sub delete_eth_addrs { - my ($addr, $intf) = @_; - - if ($addr eq "dhcp") { - stop_dhclient($intf); - unlink("/var/lib/dhcp3/dhclient_$intf\_lease"); - unlink("/var/lib/dhcp3/$intf"); - unlink("/var/run/vyatta/dhclient/dhclient_release_$intf"); - unlink("/var/lib/dhcp3/dhclient_$intf\.conf"); - exit 0; - } - my $version = is_ip_v4_or_v6($addr); - if ($version == 6) { - exec 'ip', '-6', 'addr', 'del', $addr, 'dev', $intf - or die "Could not exec ip?"; - } - - ($version == 4) or die "Bad ip version"; - - if (is_ip_configured($intf, $addr)) { - # Link is up, so just delete address - # Zebra is watching for netlink events and will handle it - exec 'ip', 'addr', 'del', $addr, 'dev', $intf - or die "Could not exec ip?"; - } - - exit 0; -} - sub update_mac { my ($mac, $intf) = @_; @@ -351,105 +268,6 @@ sub is_valid_mac { exit 0; } -# Validate an address parameter at the time the user enters it via -# a "set" command. This validates the parameter for syntax only. -# It does not validate it in combination with other parameters. -# Valid values are: "dhcp", <ipv4-address>/<prefix-len>, or -# <ipv6-address>/<prefix-len> -# -sub is_valid_addr_set { - my ($addr_net, $intf) = @_; - - if ($addr_net eq "dhcp") { - die "Error: can't use dhcp client on loopback interface\n" - if ($intf eq "lo"); - - exit 0; - } - - if ($addr_net eq "dhcpv6") { - die "Error: can't use dhcpv6 client on loopback interface\n" - if ($intf eq "lo"); - - exit 0; - } - - my ($addr, $net); - if ($addr_net =~ m/^([0-9a-fA-F\.\:]+)\/(\d+)$/) { - $addr = $1; - $net = $2; - } else { - exit 1; - } - - my $version = is_ip_v4_or_v6($addr_net); - if (!defined $version) { - exit 1; - } - - my $ip = NetAddr::IP->new($addr_net); - my $network = $ip->network(); - my $bcast = $ip->broadcast(); - - if ($ip->version == 4) { - # Check for illegal IPv4 addresses. - # - # RFC3021 allows for a mask of /31. In this case both addresses - # are treated host addresses. And /32 is also a legal mask. - # - if (($ip->masklen() != 31) && ($ip->masklen() != 32)) { - die "Can not assign network address as the IP address\n" - if ($ip->addr() eq $network->addr()); - - die "Can not assign broadcast address as the IP address\n" - if ($ip->addr() eq $bcast->addr()); - } - } - - if ($ip->version == 6) { - # Check for illegal IPv6 addreseses. - # - my $multicast_range = NetAddr::IP->new("FF00::/8"); - if ($ip->within($multicast_range)) { - die "Can not assign address within IPv6 multicast range\n"; - } - - my $linklocal_range = NetAddr::IP->new("FE80::/10"); - if ($ip->within($linklocal_range)) { - die "Can not assign address within IPv6 link local range\n"; - } - - if ($ip->contains($multicast_range)) { - die "Can not assign address containing IPv6 multicast range\n"; - } - - if ($ip->contains($linklocal_range)) { - die "Can not assign address containing IPv6 link local range\n"; - } - - my $unspecified_addr = NetAddr::IP->new("::/128"); - if ($ip == $unspecified_addr ) { - die "Can not assign IPv6 Unspecified address\n"; - } - } - - die "Error: duplicate address/prefix [$addr_net]\n" - if (is_ip_duplicate($intf, $addr_net)); - - if ($version == 4) { - if ($net > 0 && $net <= 32) { - exit 0; - } - } - if ($version == 6) { - if ($net > 1 && $net <= 128) { - exit 0; - } - } - - exit 1; -} - # Validate the set of address values configured on an interface at commit # Check that full set of address address values are consistent. # 1. Interface may not be part of bridge or bonding group |