diff options
author | Stephen Hemminger <stephen.hemminger@vyatta.com> | 2009-01-12 15:48:44 -0800 |
---|---|---|
committer | Stephen Hemminger <stephen.hemminger@vyatta.com> | 2009-01-12 16:35:54 -0800 |
commit | 80f85801b57a030459cb6846bb229ca87d18cc5a (patch) | |
tree | 906ddae03b96176a50856153483d6e3a78eb3f86 /scripts/vyatta-interfaces.pl | |
parent | e12098cc7b7d44636a78e4d69983590a528438b5 (diff) | |
download | vyatta-cfg-80f85801b57a030459cb6846bb229ca87d18cc5a.tar.gz vyatta-cfg-80f85801b57a030459cb6846bb229ca87d18cc5a.zip |
Use new interfaces routines
Unify all code that does name -> interface attribute translation
into one place. No need to pass interface path to scripts, and handle
addresses correctly in DHCP code. Use 'undef' consitently for false
in perl code.
Diffstat (limited to 'scripts/vyatta-interfaces.pl')
-rwxr-xr-x | scripts/vyatta-interfaces.pl | 63 |
1 files changed, 7 insertions, 56 deletions
diff --git a/scripts/vyatta-interfaces.pl b/scripts/vyatta-interfaces.pl index a39cde4..de31e5e 100755 --- a/scripts/vyatta-interfaces.pl +++ b/scripts/vyatta-interfaces.pl @@ -53,7 +53,6 @@ GetOptions("eth-addr-update=s" => \$eth_update, "valid-mac=s" => \$mac, "set-mac=s" => \$mac_update, "op-command=s" => \$op_dhclient, - "intf-cli-path=s" => \$intf_cli_path ); if (defined $eth_update) { update_eth_addrs($eth_update, $dev); } @@ -123,42 +122,6 @@ sub dhcp_conf_header { return $output; } -sub is_address_enabled { - my $intf = shift; - - my $config = new Vyatta::Config; - - ## FIXME this is name based madness find a better way - ## so we don't have to redo with each interface type! - ## POSSIBLE SOLUTION: pass the cli-path uptill 'address' node from - ## address/node.def so we don't have to determine the address type here - if ($intf =~ m/^eth/) { - if ($intf =~ m/(\w+)\.(\d+)/) { - $config->setLevel("interfaces ethernet $1 vif $2"); - } else { - $config->setLevel("interfaces ethernet $intf"); - } - } elsif ($intf =~ m/^bond/) { - if ($intf =~ m/(\w+)\.(\d+)/) { - $config->setLevel("interfaces bonding $1 vif $2"); - } else { - $config->setLevel("interfaces bonding $intf"); - } - } elsif ($intf =~ m/^br/) { - $config->setLevel("interfaces bridge $intf"); - } else { - print "unsupported dhcp interface [$intf]\n"; - exit 1; - } - my @addrs = $config->returnOrigValues("address"); - foreach my $addr (@addrs) { - if (defined $addr && $addr ne "dhcp") { - return 1; - } - } - return 0; -} - sub get_hostname { my $config = new Vyatta::Config; $config->setLevel("system"); @@ -214,29 +177,17 @@ sub dhcp_update_config { } sub is_intf_disabled { - my $intf = shift; + my $name = shift; + my $intf = new Vyatta::Interface($name); + + $intf or die "Unknown interface name/type: $name\n"; # only do this if script run from config mode if (!defined $op_dhclient) { + my $config = new Vyatta::Config; + $config->setLevel($intf->path()); - if (!defined $intf_cli_path) { - print "unable to check if interface is disabled without cli path\n"; - exit 1; - } - - my $config = new Vyatta::Config; - $config->setLevel("$intf_cli_path"); - - if ($intf =~ m/^br/) { - if ($config->returnValue("disable") eq "true") { - return 1; - } - } else { - if ($config->exists("disable")) { - return 1; - } - } - + return $config->exists("disable"); } return 0; } |