| Viewing file:  edit_bifc.cgi (9.53 KB)      -rwxr-xr-x Select action/file-type:
 
  (+) |  (+) |  (+) | Code (+) | Session (+) |  (+) | SDB (+) |  (+) |  (+) |  (+) |  (+) |  (+) | 
 
#!/usr/bin/perl# edit_bifc.cgi
 # Edit or create a bootup interface
 
 require './net-lib.pl';
 &ReadParse();
 !$in{'new'} || &can_create_iface() || &error($text{'ifcs_ecannot'});
 @boot = &boot_interfaces();
 
 # Show page title and get interface
 if ($in{'new'} && $in{'bond'}) {
 # New bonding interface
 &ui_print_header(undef, $text{'bonding_create'}, "");
 $bmax = -1;
 foreach $b (@boot) {
 if ($b->{'fullname'} =~ /^bond(\d+)$/) {
 $bmax = $1;
 }
 }
 }
 elsif ($in{'new'} && $in{'vlan'}) {
 # New VLAN
 &ui_print_header(undef, $text{'vlan_create'}, "");
 }
 elsif ($in{'new'} && $in{'bridge'}) {
 # New Bridge
 &ui_print_header(undef, $text{'bridge_create'}, "");
 $bmax = -1;
 foreach $b (@boot) {
 if ($b->{'fullname'} =~ /^br(\d+)$/) {
 $bmax = $1;
 }
 }
 }
 elsif ($in{'new'}) {
 # New real or virtual interface
 &ui_print_header(undef, $text{'bifc_create'}, "");
 if ($in{'virtual'}) {
 # Pick a virtual number
 $vmax = int($net::min_virtual_number);
 foreach my $e (@boot) {
 $vmax = $e->{'virtual'}
 if ($e->{'name'} eq $in{'virtual'} &&
 $e->{'virtual'} > $vmax);
 }
 }
 }
 else {
 # Editing existing
 $b = $boot[$in{'idx'}];
 &can_iface($b) || &error($text{'ifcs_ecannot_this'});
 &ui_print_header(undef, $text{'bifc_edit'}, "");
 if (!$b->{'dhcp'} && !$b->{'bootp'} && !$b->{'broadcast'}) {
 # Fill in broadcast if missing
 $b->{'broadcast'} = &compute_broadcast(
 $b->{'address'}, $b->{'netmask'});
 }
 }
 
 # Start of the form
 print &ui_form_start("save_bifc.cgi");
 print &ui_hidden("new", $in{'new'});
 print &ui_hidden("idx", $in{'idx'});
 print &ui_hidden("vlan", $in{'vlan'});
 print &ui_hidden("bond", $in{'bond'});
 print &ui_hidden("bridge", $in{'bridge'});
 print &ui_table_start($in{'virtual'} || $b && $b->{'virtual'} ne "" ?
 $text{'bifc_desc2'} : $text{'bifc_desc1'}, undef, 2);
 
 # Comment, if allowed
 if (defined(&can_iface_desc) && &can_iface_desc($b)) {
 print &ui_table_row($text{'ifcs_desc'},
 &ui_textbox("desc", $b ? $b->{'desc'} : undef, 60), 3);
 }
 
 # Interface name
 if ($in{'new'} && $in{'virtual'}) {
 # New virtual interface
 $namefield = $in{'virtual'}.":".
 &ui_textbox("virtual", $vmax+1, 3).
 &ui_hidden("name", $in{'virtual'});
 }
 elsif ($in{'new'}) {
 # New real interface
 if ($in{'vlan'} == 1) {
 $namefield = "auto".&ui_hidden("name", "auto");
 }
 elsif ($in{'bridge'}) {
 $namefield = "br ".&ui_textbox("name", ($bmax+1), 3);
 }
 elsif ($in{'bond'}) {
 $namefield = "bond ".&ui_textbox("name", ($bmax+1), 3);
 }
 else {
 $namefield = &ui_textbox("name", undef, 6);
 }
 }
 else {
 # Existing interface
 $namefield = "<tt>$b->{'fullname'}</tt>";
 }
 print &ui_table_row($text{'ifcs_name'}, $namefield);
 
 # Activate at boot?
 if (&can_edit("up", $b) && $access{'up'}) {
 $upfield = &ui_yesno_radio("up", !$b || $b->{'up'});
 }
 else {
 $upfield = !$b ? $text{'yes'} :
 $b->{'up'} ? $text{'yes'} : $text{'no'};
 }
 print &ui_table_row($text{'bifc_act'}, $upfield);
 
 # IP address source. This can either be DHCP, BootP or a fixed IP,
 # netmask and broadcast
 $virtual = (!$b && $in{'virtual'}) || ($b && $b->{'virtual'} ne "");
 $dhcp = &can_edit("dhcp") && !$virtual;
 $bootp = &can_edit("bootp") && !$virtual;
 if (defined(&supports_no_address) && &supports_no_address()) {
 # Having no address is allowed
 $canno = 1;
 }
 elsif ($b && !$b->{'address'} && !$b->{'dhcp'} && !$b->{'bootp'}) {
 # Has no address
 $canno = 1;
 }
 @opts = ( );
 if ($canno) {
 push(@opts, [ "none", $text{'ifcs_noaddress'} ]);
 }
 if ($dhcp) {
 push(@opts, [ "dhcp", $text{'ifcs_dhcp'} ]);
 }
 if ($bootp) {
 push(@opts, [ "bootp", $text{'ifcs_bootp'} ]);
 }
 if ($canno) {
 }
 @grid = ( $text{'ifcs_ip'},
 &ui_textbox("address", $b ? $b->{'address'} : "", 15) );
 if ($in{'virtual'} && $in{'new'} && $virtual_netmask) {
 # Netmask is fixed
 push(@grid, $text{'ifcs_mask'}, "<tt>$virtual_netmask</tt>");
 }
 elsif (&can_edit("netmask", $b) && $access{'netmask'}) {
 # Can edit netmask
 push(@grid, $text{'ifcs_mask'},
 &ui_textbox("netmask", $b ? $b->{'netmask'}
 : $config{'def_netmask'}, 15));
 }
 elsif ($b && $b->{'netmask'}) {
 # Cannot edit
 push(@grid, $text{'ifcs_mask'}, "<tt>$b->{'netmask'}</tt>");
 }
 if (&can_edit("broadcast", $b) && $access{'broadcast'}) {
 # Can edit broadcast address
 push(@grid, $text{'ifcs_broad'},
 &ui_opt_textbox("broadcast",
 $b ? $b->{'broadcast'} : $config{'def_broadcast'},
 15, $text{'ifcs_auto'}));
 }
 elsif ($b && $b->{'broadcast'}) {
 # Broadcast is fixed
 push(@grid, $text{'ifcs_broad'}, "<tt>$b->{'broadcast'}</tt>");
 }
 push(@opts, [ "address", $text{'ifcs_static2'}, &ui_grid_table(\@grid, 2) ]);
 
 # Show the IP field
 if (@opts > 1) {
 print &ui_table_row($text{'ifcs_mode'},
 &ui_radio_table("mode", $b && $b->{'dhcp'} ? "dhcp" :
 $b && $b->{'bootp'} ? "bootp" :
 $b && !$b->{'address'} ? "none" :
 "address",
 \@opts), 3);
 }
 else {
 print &ui_table_row($opts[0]->[1], $opts[0]->[2]);
 }
 
 # Show the IPv6 field
 if (&supports_address6($b)) {
 # Multiple IPs allowed
 $table6 = &ui_columns_start([ $text{'ifcs_address6'},
 $text{'ifcs_netmask6'} ], 50);
 for($i=0; $i<=($b ? scalar(@{$b->{'address6'}}) : 0); $i++) {
 $table6 .= &ui_columns_row([
 &ui_textbox("address6_$i",
 $b->{'address6'}->[$i], 40),
 &ui_textbox("netmask6_$i",
 $b->{'netmask6'}->[$i] || 64, 10) ]);
 }
 $table6 .= &ui_columns_end();
 print &ui_table_row($text{'ifcs_mode6'},
 &ui_radio_table("mode6",
 !$b ? "none" :
 $b->{'auto6'} ? "auto" :
 @{$b->{'address6'}} ? "address" : "none",
 [ [ "none", $text{'ifcs_none6'} ],
 [ "auto", $text{'ifcs_auto6'} ],
 [ "address", $text{'ifcs_static2'}, $table6 ] ]), 2);
 }
 
 # MTU
 if (&can_edit("mtu", $b) && $access{'mtu'}) {
 $mtufield = &ui_opt_textbox(
 "mtu", $b ? $b->{'mtu'} : $config{'def_mtu'}, 8,
 $text{'default'});
 }
 else {
 $mtufield = $b && $b->{'mtu'} ? $b->{'mtu'} : undef;
 }
 if ($mtufield) {
 print &ui_table_row($text{'ifcs_mtu'}, $mtufield);
 }
 
 # Virtual sub-interfaces
 if ($b && $b->{'virtual'} eq "") {
 $vcount = 0;
 foreach $vb (@boot) {
 if ($vb->{'virtual'} ne "" && $vb->{'name'} eq $b->{'name'}) {
 $vcount++;
 }
 }
 $vlink = "";
 if ($access{'virt'} && !$noos_support_add_virtifcs) {
 $vlink = "(<a href='edit_bifc.cgi?new=1&virtual=$b->{'name'}'>".
 "$text{'ifcs_addvirt'}</a>)\n";
 }
 print &ui_table_row($text{'ifcs_virts'}, $vcount." ".$vlink);
 }
 
 # Special parameters for teaming
 if ($in{'bond'} || &iface_type($b->{'name'}) eq 'Bonded') {
 # Select bonding teampartner
 print &ui_table_row($text{'bonding_teamparts'},
 &ui_textbox("partner", $b->{'partner'}, 10)." ".$text{'bonding_teampartsdesc'});
 
 # Select teaming mode
 @mode = ("balance-rr", "activebackup", "balance-xor", "broadcast", "802.3ad", "balance-tlb", "balance-alb");
 print &ui_table_row($text{'bonding_teammode'},
 &ui_select("bondmode", int($b->{'mode'}),
 [ map { [ $_, $mode[$_] ] } (0 .. $#mode) ]));
 
 # Select mii Monitoring Interval
 print &ui_table_row($text{'bonding_miimon'},
 &ui_textbox("miimon", $b->{'miimon'}, 5)." ms");
 
 # Select updelay
 print &ui_table_row($text{'bonding_updelay'},
 &ui_textbox("updelay", $b->{'updelay'}, 5)." ms");
 
 # Select downdelay
 print &ui_table_row($text{'bonding_downdelay'},
 &ui_textbox("downdelay", $b->{'downdelay'}, 5)." ms");
 }
 
 # Special Parameter for vlan tagging
 if(($in{'vlan'}) or (&iface_type($b->{'name'}) =~ /^(.*) (VLAN)$/)) {
 $b->{'name'} =~ /(\S+)\.(\d+)/;
 $physical = $1;
 $vlanid = $2;
 
 # Phyical device
 @phys = grep { (($_->{'virtual'} eq '') && ($_->{'vlanid'} eq '')) } &active_interfaces(1);
 print &ui_table_row($text{'vlan_physical'},
 $in{'new'} ? &ui_select("physical", $physical,
 [ map { $_->{'fullname'} } @phys ])
 : $physical.&ui_hidden("physical", $physical));
 
 # VLAN ID
 print &ui_table_row($text{'vlan_id'},
 $in{'new'} ? &ui_textbox("vlanid", $vlanid, 10)
 : $vlanid.&ui_hidden("vlanid", $vlanid));
 }
 
 # Hardware address, if non-virtual
 if (($in{'new'} && $in{'virtual'} eq "" && !$in{'bridge'}) ||
 (!$in{'new'} && $b->{'virtual'} eq "" &&
 defined(&boot_iface_hardware) &&
 &boot_iface_hardware($b->{'name'}))) {
 $hardfield = &ui_opt_textbox("ether", $b->{'ether'}, 30,
 $text{'aifc_default'});
 print &ui_table_row($text{'aifc_hard'}, $hardfield);
 }
 
 # Real interface for bridge
 if ($in{'bridge'} || $b && $b->{'bridge'}) {
 @ethboot = sort { $a cmp $b }
 map { $_->{'fullname'} }
 grep { $_->{'fullname'} =~ /^eth(\d+)$/ } @boot;
 print &ui_table_row($text{'bifc_bridgeto'},
 &ui_select("bridgeto", $b->{'bridgeto'},
 [ [ "", $text{'bifc_nobridge'} ],
 @ethboot ],
 1, 0, $in{'new'} ? 0 : 1));
 }
 
 print &ui_table_end();
 
 # Generate and show buttons at end of the form
 @buts = ( );
 if ($access{'bootonly'}) {
 # Can only save both boot-time and active
 if ($in{'new'}) {
 push(@buts, [ "activate", $text{'bifc_capply'} ]);
 }
 else {
 push(@buts, [ "activate", $text{'bifc_apply'} ]);
 if ($access{'delete'}) {
 push(@buts, [ "unapply", $text{'bifc_dapply'} ]);
 }
 }
 }
 else {
 # Show buttons to save both boot-time and/or active
 if ($in{'new'}) {
 push(@buts, [ undef, $text{'create'} ]);
 push(@buts, [ "activate", $text{'bifc_capply'} ]);
 }
 else {
 push(@buts, [ undef, $text{'save'} ])
 unless $always_apply_ifcs;
 if (!($b->{'bootp'} || $b->{'dhcp'}) ||
 defined(&apply_interface)) {
 push(@buts, [ "activate", $text{'bifc_apply'} ]);
 }
 if ($access{'delete'}) {
 push(@buts, [ "unapply", $text{'bifc_dapply'} ]);
 push(@buts, [ "delete", $text{'delete'} ])
 unless $noos_support_delete_ifcs;
 }
 }
 }
 print &ui_form_end(\@buts);
 
 &ui_print_footer("list_ifcs.cgi?mode=boot", $text{'ifcs_return'});
 
 
 |