# freebsd-lib.pl # Networking functions for FreeBSD # active_interfaces() # Returns a list of currently ifconfig'd interfaces sub active_interfaces { local(@rv, @lines, $l); &open_execute_command(IFC, "ifconfig -A", 1, 1); while(<IFC>) { s/\r|\n//g; if (/^\S+:/) { push(@lines, $_); } else { $lines[$#lines] .= $_; } } close(IFC); foreach $l (@lines) { local %ifc; $l =~ /^([^:\s]+):/; $ifc{'name'} = $ifc{'fullname'} = $1; if ($l =~ /^(\S+):(\d+):\s/) { $ifc{'virtual'} = $2; } if ($l =~ s/inet\s+(\S+)\s+netmask\s+(\S+)\s+broadcast\s+(\S+)//) { $ifc{'address'} = $1; $ifc{'netmask'} = &parse_hex($2); $ifc{'broadcast'} = $3; } elsif ($l =~ s/inet\s+(\S+)\s+netmask\s+(\S+)//) { $ifc{'address'} = $1; $ifc{'netmask'} = &parse_hex($2); } else { next; } if ($l =~ /ether\s+(\S+)/) { $ifc{'ether'} = $1; } if ($l =~ /mtu\s+(\S+)/) { $ifc{'mtu'} = $1; } $ifc{'up'}++ if ($l =~ /\<UP/); $ifc{'edit'} = &iface_type($ifc{'name'}) =~ /ethernet|loopback/i; $ifc{'index'} = scalar(@rv); if ($ifc{'ether'}) { $ifc{'ether'} = join(":", map { sprintf "%2.2d", $_ } split(/:/, $ifc{'ether'})); } push(@rv, \%ifc); # Add aliases as virtual interfaces local $v = 0; while($l =~ s/inet\s+(\S+)\s+netmask\s+(\S+)\s+broadcast\s+(\S+)//) { local %vifc = %ifc; $vifc{'address'} = $1; $vifc{'netmask'} = &parse_hex($2); $vifc{'broadcast'} = $3; $vifc{'up'} = 1; $vifc{'edit'} = $ifc{'edit'}; $vifc{'virtual'} = $v++; $vifc{'fullname'} = $vifc{'name'}.':'.$vifc{'virtual'}; $vifc{'index'} = scalar(@rv); push(@rv, \%vifc); } } return @rv; } # activate_interface(&details) # Create or modify an interface sub activate_interface { local %act; map { $act{$_->{'fullname'}} = $_ } &active_interfaces(); local $old = $act{$_[0]->{'fullname'}}; $act{$_[0]->{'fullname'}} = $_[0]; &interface_sync(\%act, $_[0]->{'name'}); } # deactivate_interface(&details) # Deactivate an interface sub deactivate_interface { local %act; local @act = &active_interfaces(); if ($_[0]->{'virtual'} eq '') { @act = grep { $_->{'name'} ne $_[0]->{'name'} } @act; } else { @act = grep { $_->{'fullname'} ne $_[0]->{'fullname'} } @act; } map { $act{$_->{'fullname'}} = $_ } @act; &interface_sync(\%act, $_[0]->{'name'}); } # interface_sync(interfaces, name) sub interface_sync { my ($act, $name) = @_; while(&backquote_command("ifconfig ".quotemeta($name)) =~ /\s+inet\s+/) { &system_logged("ifconfig ".quotemeta($name)." delete >/dev/null 2>&1"); } foreach $a (sort { $a->{'fullname'} cmp $b->{'fullname'} } grep { $_->{'name'} eq $_[1] } values(%{$_[0]})) { my $cmd = "ifconfig ".quotemeta($a->{'name'}); if ($a->{'virtual'} ne '') { $cmd .= " alias $a->{'address'}"; } else { $cmd .= " $a->{'address'}"; } if ($a->{'netmask'}) { $cmd .= " netmask $a->{'netmask'}"; } if ($a->{'broadcast'}) { $cmd .= " broadcast $a->{'broadcast'}"; } if ($a->{'mtu'}) { $cmd .= " mtu $a->{'mtu'}"; } my $out = &backquote_logged("$cmd 2>&1"); if ($? && $out !~ /file exists/i) { &error($out); } if ($a->{'virtual'} eq '') { if ($a->{'up'}) { $out = &backquote_command( "ifconfig ".quotemeta($a->{'name'})." up 2>&1"); } else { $out = &backquote_logged( "ifconfig ".quotemeta($a->{'name'})." down 2>&1"); } &error($out) if ($?); } } } # boot_interfaces() # Returns a list of interfaces brought up at boot time sub boot_interfaces { local @rv; local @if_list = split(" ", &backquote_command("echo -n /etc/hostname.*[!~]")); if ( $if_list[0] eq "/etc/hostname.*[!~]" ) { return @rv; } foreach $r (@if_list) { local $if; local $alias_cnt = 0; ($if = $r) =~ s/\/etc\/hostname\.//; &open_readfile( IF_FILE, $r) or die "Could not open: $r"; while(<IF_FILE>) { local %ifc; if( ! /^inet .*|^dhcp/ ) { next; } if( /^dhcp/ ) { %ifc = ( 'name' => $if, 'fullname' => $if, 'dhcp' => 1 ); } elsif( /alias/ ) { $_ =~ s/alias//; # Virtual interface %ifc = ( 'name' => $if, 'virtual' => $alias_cnt, 'fullname' => "$if:$alias_cnt" ); $alias_cnt++; } else { # Non-virtual interface %ifc = ( 'name' => $if, 'fullname' => $if ); } @_ = split; $ifc{'address'} = $_[1] if( $_[1] ne 'NONE' ); $ifc{'netmask'} = $_[2] if( $_[2] ne 'NONE' ); $ifc{'broadcast'} = $_[3] if( $_[3] ne 'NONE' ); $ifc{'up'} = 1; $ifc{'edit'} = 1; $ifc{'index'} = scalar(@rv); $ifc{'file'} = $r; push(@rv, \%ifc); } close( IF_FILE ); } return @rv; } # save_interface(&details) # Create or update a boot-time interface sub save_interface { local ($str, $lines, $found = 0); local $if = $_[0]->{'name'}; local $alias_nr = $_[0]->{'virtual'}; &lock_file("/etc/hostname.$if"); if ( $_[0]->{'dhcp'} ){ &open_tempfile( IF_FILE, ">/etc/hostname.".$if ); &print_tempfile(IF_FILE, "dhcp\n"); &close_tempfile( IF_FILE ); &unlock_file("/etc/hostname.$if"); return; } if ( $alias_nr eq '' ) { $str = "inet "; $alias_nr = 0; } else { $str = "inet alias "; $alias_nr += 1; } $str .= $_[0]->{'address'}; $str .= " $_[0]->{'netmask'}" if ($_[0]->{'netmask'}); $str .= " $_[0]->{'broadcast'}" if ($_[0]->{'broadcast'}); $_ = &backquote_command("echo -n /etc/hostname.*"); if( /hostname.$if/ ) { $lines = &read_file_lines( "/etc/hostname.".$if ); foreach $l (@$lines) { $_ = $l; if( ! /^inet |^dhcp/ ) { next; } if( $alias_nr == 0 ) { $l = $str; $found = 1; last; } if( ! /alias/ ) { next; } if( $alias_nr == 1 ) { $l = $str; $found = 1; last; } $alias_nr--; } if( $found == 0 ) { push @$lines, ($str); } &flush_file_lines(); } else { &open_tempfile( IF_FILE, ">/etc/hostname.".$if ); &print_tempfile(IF_FILE, $str, "\n"); &close_tempfile( IF_FILE ); } &unlock_file("/etc/hostname.$if"); } # delete_interface(&details) # Delete a boot-time interface sub delete_interface { local ($cnt = 0, $lines, $found = 0); local $if = $_[0]->{'name'}; local $addr = $_[0]->{'address'}; $_ = &backquote_command("echo -n /etc/hostname.*"); &lock_file("/etc/hostname.$if"); if( /hostname.$if/ ) { $lines = &read_file_lines( "/etc/hostname.".$if ); foreach $l (@$lines) { $_ = $l; $cnt++; if ( /^\#/ ) { next; } $found++; if( ! /^inet / ) { next; } if( /$addr/ ) { splice @$lines, $cnt-1, 1; } } &flush_file_lines(); # check if we deleted the only entry in the file # if so delete the file (otherwise dhcp will be used for the interface) if( $found == 1 ) { &unlink_logged("/etc/hostname.".$if); } } &unlock_file("/etc/hostname.$if"); } # iface_type(name) # Returns a human-readable interface type name sub iface_type { return $_[0] =~ /^tun/ ? "Loopback tunnel" : $_[0] =~ /^sl/ ? "SLIP" : $_[0] =~ /^ppp/ ? "PPP" : $_[0] =~ /^lo/ ? "Loopback" : $_[0] =~ /^ar/ ? "Arnet" : $_[0] =~ /^(aue|cue|kue)/ ? "USB ethernet" : $_[0] =~ /^(sk|ti|wx)/ ? "Gigabit ethernet" : $_[0] =~ /^(al|ax|be|mx|qe|qec|rl|sf|sis|ste|tx|wb)/ ? "Fast ethernet" : $_[0] =~ /^(ae|cs|dc|de|ec|ed|eg|el|en|ep|es|ex|fxp|hme|ie|il|ix|iy|le|mc|ne|np|qn|sm|sn|tl|vr|vx|we|xe|xl|ze|zp)/ ? "Ethernet" : $text{'ifcs_unknown'}; } # iface_hardware(name) # Does some interface have an editable hardware address sub iface_hardware { return 0; } # can_edit(what) # Can some boot-time interface parameter be edited? sub can_edit { return $_[0] =~ /netmask|broadcast|dhcp/; } sub can_broadcast_def { return 0; } # valid_boot_address(address) # Is some address valid for a bootup interface sub valid_boot_address { return &check_ipaddress($_[0]); } # get_dns_config() # Returns a hashtable containing keys nameserver, domain, search & order sub get_dns_config { local $dns; &open_readfile(RESOLV, "/etc/resolv.conf"); while(<RESOLV>) { s/\r|\n//g; s/#.*$//g; if (/nameserver\s+(.*)/) { push(@{$dns->{'nameserver'}}, split(/\s+/, $1)); } elsif (/search\s+(.*)/) { $dns->{'domain'} = [ split(/\s+/, $1) ]; } elsif (/lookup\s+(.*)/) { $dns->{'order'} = [ split(/\s+/, $1) ]; } } close(RESOLV); $dns->{'files'} = [ "/etc/resolv.conf" ]; return $dns; } # save_dns_config(&config) # Writes out the resolv.conf file sub save_dns_config { &lock_file("/etc/resolv.conf"); &open_readfile(RESOLV, "/etc/resolv.conf"); local @resolv = <RESOLV>; close(RESOLV); &open_tempfile(RESOLV, ">/etc/resolv.conf"); foreach (@{$_[0]->{'nameserver'}}) { &print_tempfile(RESOLV, "nameserver $_\n"); } if ($_[0]->{'domain'}) { &print_tempfile(RESOLV, "search ",join(" ", @{$_[0]->{'domain'}}),"\n"); } foreach (@resolv) { &print_tempfile(RESOLV, $_) if (!/^\s*(nameserver|search|lookup)\s+/); } &print_tempfile(RESOLV, "lookup "); foreach (@{$_[0]->{'order'}}) { &print_tempfile(RESOLV, $_," "); } &print_tempfile(RESOLV, "\n"); &close_tempfile(RESOLV); &unlock_file("/etc/resolv.conf"); } $max_dns_servers = 3; # order_input(&dns) # Returns HTML for selecting the name resolution order sub order_input { return &common_order_input("order", $_[0]->{'order'}, [ [ "file", "Hosts" ], [ "bind", "DNS" ], [ "yp", "NIS" ] ]); } # parse_order(&dns) # Parses the form created by order_input() sub parse_order { local($i, @order); for($i=0; defined($in{"order_$i"}); $i++) { push(@order, $in{"order_$i"}) if ($in{"order_$i"}); } $_[0]->{'order'} = \@order; } # get_hostname() sub get_hostname { local $hn = &read_file_contents("/etc/myname"); $hn =~ s/\r|\n//g; if ($hn) { return $hn; } return &get_system_hostname(); } # save_hostname(name) sub save_hostname { my ($hostname) = @_; &system_logged("hostname ".quotemeta($hostname)." >/dev/null 2>&1"); &open_lock_tempfile(MYNAME, ">/etc/myname"); &print_tempfile(MYNAME, $hostname,"\n"); &close_tempfile(MYNAME); undef(@main::get_system_hostname); # clear cache } sub set_line { local ($l, $lines, $found = 0); local $pat = $_[1]; local $news = $_[2]; $lines = read_file_lines($_[0]); foreach $l (@$lines) { $_ = $l; if( /$pat/ ) { $found = 1; $l = $news; } } if( ! $found ) { push @$lines, ($news); } &flush_file_lines(); } sub read_routing { $defr = ''; &open_readfile(DEFR, "/etc/mygate"); while(<DEFR>) { $defr .= $_; } close(DEFR); local %sysctl; read_file("/etc/sysctl.conf", \%sysctl); $gw = "$sysctl{'net.inet.ip.forwarding'}"; $gw =~ s/\s*\#.*//; $gw = "0" if( $gw eq '' ); local %rc; read_file("/etc/rc.conf",\%rc); $rd = $rc{'routed_flags'}; $rd =~ s/\s*\#.*//; $rd = "NO" if( $rd eq '' ); } sub routing_config_files { return ( "/etc/mygate", "/etc/sysctl.conf", "/etc/rc.conf" ); } sub routing_input { &read_routing; # Default router print &ui_table_row($text{'routes_default'}, &ui_opt_textbox("defr", $defr eq 'NO' ? '' : $defr, 20, $text{'routes_none'})); # Act as router? print &ui_table_row($text{'routes_forward'}, &ui_radio("gw", $gw || 0, [ [ 1, $text{'yes'} ], [ 0, $text{'no'} ] ])); # Run route discovery print &ui_table_row($text{'routes_routed'}, &ui_radio("rd", $rd || '-q', [ [ '-q', $text{'yes'} ], [ 'NO', $text{'no'} ] ])); } sub parse_routing { $in{'defr_def'} || &check_ipaddress($in{'defr'}) || &error(&text('routes_edefault', &html_escape($in{'defr'}))); &read_routing; &lock_file("/etc/mygate"); if ( $in{'defr_def'} && -f "/etc/mygate" ) { &unlink_file("/etc/mygate"); } else { if( $in{'defr'} ne $defr ) { &open_tempfile(MYGATE, ">/etc/mygate"); &print_tempfile(MYGATE, $in{'defr'},"\n"); &close_tempfile(MYDATE); } } &unlock_file("/etc/mygate"); if( $in{'gw'} ne $gw ) { &set_line( "/etc/sysctl.conf", "^net.inet.ip.forwarding", "net.inet.ip.forwarding=$in{'gw'}" ); } if( $in{'rd'} ne $rd ) { &set_line( "/etc/rc.conf", "^routed_flags", "routed_flags=$in{'rd'}" ); } } # supports_address6([&iface]) # Returns 1 if managing IPv6 interfaces is supported sub supports_address6 { local ($iface) = @_; return 0; } 1;
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
images | Folder | 0755 |
|
|
lang | Folder | 0755 |
|
|
CHANGELOG | File | 5.55 KB | 0644 |
|
acl_security.pl | File | 3.08 KB | 0755 |
|
apply.cgi | File | 184 B | 0755 |
|
backup_config.pl | File | 1005 B | 0755 |
|
cgi_args.pl | File | 752 B | 0755 |
|
cobalt-linux-lib.pl | File | 32.85 KB | 0755 |
|
coherent-linux-lib.pl | File | 32.85 KB | 0755 |
|
config | File | 48 B | 0644 |
|
config-ALL-linux | File | 48 B | 0644 |
|
config-cygwin | File | 82 B | 0644 |
|
config-freebsd | File | 48 B | 0644 |
|
config-macos | File | 48 B | 0644 |
|
config-netbsd | File | 48 B | 0644 |
|
config-openbsd | File | 48 B | 0644 |
|
config-solaris | File | 79 B | 0644 |
|
config-syno-linux | File | 48 B | 0644 |
|
config-unixware | File | 48 B | 0644 |
|
config-windows | File | 78 B | 0644 |
|
config.info | File | 193 B | 0644 |
|
config.info.ca | File | 241 B | 0644 |
|
config.info.cs | File | 205 B | 0644 |
|
config.info.de | File | 219 B | 0644 |
|
config.info.es | File | 175 B | 0644 |
|
config.info.fa | File | 255 B | 0644 |
|
config.info.fr | File | 246 B | 0644 |
|
config.info.hu | File | 0 B | 0644 |
|
config.info.ja | File | 68 B | 0644 |
|
config.info.nl | File | 197 B | 0644 |
|
config.info.no | File | 208 B | 0644 |
|
config.info.pl | File | 240 B | 0644 |
|
config.info.pt_BR | File | 229 B | 0644 |
|
config.info.ru | File | 361 B | 0644 |
|
config.info.sk | File | 225 B | 0644 |
|
config.info.sv | File | 42 B | 0644 |
|
config.info.tr | File | 65 B | 0644 |
|
config.info.uk | File | 87 B | 0644 |
|
config.info.zh | File | 43 B | 0644 |
|
config.info.zh_TW | File | 44 B | 0644 |
|
create_route.cgi | File | 1004 B | 0755 |
|
cygwin-lib.pl | File | 11.28 KB | 0755 |
|
debian-linux-lib.pl | File | 33.58 KB | 0755 |
|
defaultacl | File | 114 B | 0644 |
|
delete_aifcs.cgi | File | 537 B | 0755 |
|
delete_bifcs.cgi | File | 1.44 KB | 0755 |
|
delete_hosts.cgi | File | 523 B | 0755 |
|
delete_ipnodes.cgi | File | 542 B | 0755 |
|
delete_routes.cgi | File | 458 B | 0755 |
|
edit_aifc.cgi | File | 5.09 KB | 0755 |
|
edit_bifc.cgi | File | 10.42 KB | 0755 |
|
edit_host.cgi | File | 1.13 KB | 0755 |
|
edit_ipnode.cgi | File | 1.04 KB | 0755 |
|
edit_range.cgi | File | 1.34 KB | 0755 |
|
freebsd-lib.pl | File | 19.22 KB | 0755 |
|
gentoo-linux-lib.pl | File | 8.47 KB | 0755 |
|
index.cgi | File | 1.25 KB | 0755 |
|
interface_chooser.cgi | File | 3.8 KB | 0755 |
|
linux-lib.pl | File | 27.58 KB | 0755 |
|
list_dns.cgi | File | 2.3 KB | 0755 |
|
list_hosts.cgi | File | 1.36 KB | 0755 |
|
list_ifcs.cgi | File | 7.96 KB | 0755 |
|
list_ipnodes.cgi | File | 1.07 KB | 0755 |
|
list_routes.cgi | File | 3.38 KB | 0755 |
|
log_parser.pl | File | 1.24 KB | 0755 |
|
macos-lib.pl | File | 11.57 KB | 0755 |
|
mandrake-linux-lib.pl | File | 32.85 KB | 0755 |
|
mod_aifc.cgi | File | 720 B | 0755 |
|
module.info | File | 485 B | 0644 |
|
module.info.af | File | 0 B | 0644 |
|
module.info.af.auto | File | 123 B | 0644 |
|
module.info.ar | File | 0 B | 0644 |
|
module.info.ar.auto | File | 170 B | 0644 |
|
module.info.be | File | 0 B | 0644 |
|
module.info.be.auto | File | 226 B | 0644 |
|
module.info.bg | File | 0 B | 0644 |
|
module.info.bg.auto | File | 261 B | 0644 |
|
module.info.ca | File | 127 B | 0644 |
|
module.info.ca.auto | File | 25 B | 0644 |
|
module.info.cs | File | 27 B | 0644 |
|
module.info.cs.auto | File | 111 B | 0644 |
|
module.info.da | File | 0 B | 0644 |
|
module.info.da.auto | File | 129 B | 0644 |
|
module.info.de | File | 121 B | 0644 |
|
module.info.de.auto | File | 19 B | 0644 |
|
module.info.el | File | 0 B | 0644 |
|
module.info.el.auto | File | 229 B | 0644 |
|
module.info.es | File | 30 B | 0644 |
|
module.info.es.auto | File | 116 B | 0644 |
|
module.info.eu | File | 0 B | 0644 |
|
module.info.eu.auto | File | 142 B | 0644 |
|
module.info.fa | File | 0 B | 0644 |
|
module.info.fa.auto | File | 194 B | 0644 |
|
module.info.fi | File | 0 B | 0644 |
|
module.info.fi.auto | File | 145 B | 0644 |
|
module.info.fr | File | 30 B | 0644 |
|
module.info.fr.auto | File | 128 B | 0644 |
|
module.info.he | File | 0 B | 0644 |
|
module.info.he.auto | File | 161 B | 0644 |
|
module.info.hr | File | 0 B | 0644 |
|
module.info.hr.auto | File | 148 B | 0644 |
|
module.info.hu | File | 34 B | 0644 |
|
module.info.hu.auto | File | 148 B | 0644 |
|
module.info.it | File | 28 B | 0644 |
|
module.info.it.auto | File | 112 B | 0644 |
|
module.info.ja | File | 33 B | 0644 |
|
module.info.ja.auto | File | 153 B | 0644 |
|
module.info.ko | File | 28 B | 0644 |
|
module.info.ko.auto | File | 105 B | 0644 |
|
module.info.lt | File | 0 B | 0644 |
|
module.info.lt.auto | File | 157 B | 0644 |
|
module.info.lv | File | 0 B | 0644 |
|
module.info.lv.auto | File | 157 B | 0644 |
|
module.info.ms | File | 136 B | 0644 |
|
module.info.ms.auto | File | 18 B | 0644 |
|
module.info.mt | File | 0 B | 0644 |
|
module.info.mt.auto | File | 144 B | 0644 |
|
module.info.nl | File | 29 B | 0644 |
|
module.info.nl.auto | File | 105 B | 0644 |
|
module.info.no | File | 31 B | 0644 |
|
module.info.no.auto | File | 99 B | 0644 |
|
module.info.pl | File | 122 B | 0644 |
|
module.info.pl.auto | File | 19 B | 0644 |
|
module.info.pt | File | 31 B | 0644 |
|
module.info.pt.auto | File | 125 B | 0644 |
|
module.info.pt_BR | File | 34 B | 0644 |
|
module.info.pt_BR.auto | File | 131 B | 0644 |
|
module.info.ro | File | 0 B | 0644 |
|
module.info.ro.auto | File | 143 B | 0644 |
|
module.info.ru | File | 36 B | 0644 |
|
module.info.ru.auto | File | 167 B | 0644 |
|
module.info.sk | File | 28 B | 0644 |
|
module.info.sk.auto | File | 113 B | 0644 |
|
module.info.sl | File | 0 B | 0644 |
|
module.info.sl.auto | File | 140 B | 0644 |
|
module.info.sv | File | 31 B | 0644 |
|
module.info.sv.auto | File | 103 B | 0644 |
|
module.info.th | File | 0 B | 0644 |
|
module.info.th.auto | File | 327 B | 0644 |
|
module.info.tr | File | 30 B | 0644 |
|
module.info.tr.auto | File | 130 B | 0644 |
|
module.info.uk | File | 0 B | 0644 |
|
module.info.uk.auto | File | 223 B | 0644 |
|
module.info.ur | File | 0 B | 0644 |
|
module.info.ur.auto | File | 210 B | 0644 |
|
module.info.vi | File | 0 B | 0644 |
|
module.info.vi.auto | File | 170 B | 0644 |
|
module.info.zh | File | 21 B | 0644 |
|
module.info.zh.auto | File | 90 B | 0644 |
|
module.info.zh_TW | File | 24 B | 0644 |
|
module.info.zh_TW.auto | File | 96 B | 0644 |
|
msc-linux-lib.pl | File | 32.85 KB | 0755 |
|
net-lib.pl | File | 12 KB | 0755 |
|
netbsd-lib.pl | File | 19.22 KB | 0755 |
|
netplan-lib.pl | File | 21.01 KB | 0644 |
|
open-linux-lib.pl | File | 7.2 KB | 0755 |
|
openbsd-lib.pl | File | 12.6 KB | 0755 |
|
openmamba-linux-lib.pl | File | 32.85 KB | 0755 |
|
pardus-linux-lib.pl | File | 32.85 KB | 0755 |
|
rbac-mapping | File | 180 B | 0644 |
|
rc.inet1 | File | 1.95 KB | 0644 |
|
redhat-linux-lib.pl | File | 32.85 KB | 0755 |
|
save_aifc.cgi | File | 5.78 KB | 0755 |
|
save_bifc.cgi | File | 10.12 KB | 0755 |
|
save_dns.cgi | File | 3.65 KB | 0755 |
|
save_host.cgi | File | 1.18 KB | 0755 |
|
save_ipnode.cgi | File | 1.26 KB | 0755 |
|
save_range.cgi | File | 1.42 KB | 0755 |
|
save_routes.cgi | File | 283 B | 0755 |
|
slackware-linux-9.1-ALL-lib.pl | File | 7.85 KB | 0755 |
|
slackware-linux-lib.pl | File | 6.71 KB | 0755 |
|
solaris-lib.pl | File | 20.79 KB | 0755 |
|
suse-linux-8.0-lib.pl | File | 7.31 KB | 0755 |
|
suse-linux-8.2-lib.pl | File | 7.31 KB | 0755 |
|
suse-linux-9.0-lib.pl | File | 8.74 KB | 0755 |
|
suse-linux-9.1-lib.pl | File | 8.74 KB | 0755 |
|
suse-linux-9.2-ALL-lib.pl | File | 11.23 KB | 0755 |
|
suse-linux-lib.pl | File | 9.08 KB | 0755 |
|
system_info.pl | File | 2.42 KB | 0644 |
|
trustix-linux-lib.pl | File | 32.85 KB | 0755 |
|
turbo-linux-lib.pl | File | 32.85 KB | 0755 |
|
united-linux-lib.pl | File | 7.31 KB | 0755 |
|
unixware-lib.pl | File | 9.9 KB | 0755 |
|
windows-lib.pl | File | 11.28 KB | 0755 |
|