!C99Shell v. 1.0 pre-release build #16!

Software: Apache/2.0.54 (Fedora). PHP/5.0.4 

uname -a: Linux mina-info.me 2.6.17-1.2142_FC4smp #1 SMP Tue Jul 11 22:57:02 EDT 2006 i686 

uid=48(apache) gid=48(apache) groups=48(apache)
context=system_u:system_r:httpd_sys_script_t
 

Safe-mode: OFF (not secure)

/usr/libexec/webmin/net/   drwxr-xr-x
Free 3.83 GB of 27.03 GB (14.17%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     netplan-lib.pl (14.5 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
# Networking functions for Ubuntu 17+, which uses Netplan by default
# XXX preserve other fields

$netplan_dir = "/etc/netplan";
$sysctl_config = "/etc/sysctl.conf";

do 'linux-lib.pl';

# boot_interfaces()
# Returns a list of all interfaces activated at boot time
sub boot_interfaces
{
my @rv;
foreach my $f (glob("$netplan_dir/*.yaml")) {
    my $yaml = &read_yaml_file($f);
    next if (!$yaml || !@$yaml);
    my ($network) = grep { $_->{'name'} eq 'network' } @$yaml;
    next if (!$network);
    my ($ens) = grep { $_->{'name'} eq 'ethernets' }
             @{$network->{'members'}};
    next if (!$ens);
    foreach my $e (@{$ens->{'members'}}) {
        my $cfg = { 'name' => $e->{'name'},
                'fullname' => $e->{'name'},
                'file' => $f,
                'line' => $e->{'line'},
                'eline' => $e->{'eline'},
                'edit' => 1,
                'up' => 1 };

        # Is DHCP enabled?
        my ($dhcp) = grep { $_->{'name'} eq 'dhcp4' }
                  @{$e->{'members'}};
        if (&is_true_value($dhcp)) {
            $cfg->{'dhcp'} = 1;
            }

        # Is optional at boot?
        my ($optional) = grep { $_->{'name'} eq 'optional' }
                      @{$e->{'members'}};
        if (&is_true_value($optional)) {
            $cfg->{'up'} = 0;
            }

        # IPv4 and v6 addresses
        my ($addresses) = grep { $_->{'name'} eq 'addresses' }
                       @{$e->{'members'}};
        my @addrs;
        my @addrs6;
        if ($addresses) {
            @addrs = grep { !&check_ip6address($_) }
                      @{$addresses->{'value'}};
            @addrs6 = grep { &check_ip6address($_) }
                       @{$addresses->{'value'}};
            my $a = shift(@addrs);
            ($cfg->{'address'}, $cfg->{'netmask'}) =
                &split_addr_netmask($a);
            }
        foreach my $a6 (@addrs6) {
            if ($a6 =~ /^(\S+)\/(\d+)$/) {
                push(@{$cfg->{'address6'}}, $1);
                push(@{$cfg->{'netmask6'}}, $2);
                }
            else {
                push(@{$cfg->{'address6'}}, $a6);
                push(@{$cfg->{'netmask6'}}, 64);
                }
            }

        # IPv4 and v4 gateways
        my ($gateway4) = grep { $_->{'name'} eq 'gateway4' }
                      @{$e->{'members'}};
        if ($gateway4) {
            $cfg->{'gateway'} = $gateway4->{'value'};
            }
        my ($gateway6) = grep { $_->{'name'} eq 'gateway6' }
                      @{$e->{'members'}};
        if ($gateway6) {
            $cfg->{'gateway6'} = $gateway6->{'value'};
            }
        $cfg->{'index'} = scalar(@rv);
        push(@rv, $cfg);

        # Nameservers (which are used to generate resolv.conf)
        my ($nameservers) = grep { $_->{'name'} eq 'nameservers' }
                                         @{$e->{'members'}};
        if ($nameservers) {
            my ($nsa) = grep { $_->{'name'} eq 'addresses' }
                     @{$nameservers->{'members'}};
            my ($search) = grep { $_->{'name'} eq 'search' }
                     @{$nameservers->{'members'}};
            if ($nsa) {
                $cfg->{'nameserver'} = $nsa->{'value'};
                }
            if ($search) {
                $cfg->{'search'} = $search->{'value'};
                }
            }

        # MAC address
        my ($macaddress) = grep { $_->{'name'} eq 'macaddress' }
                                         @{$e->{'members'}};
        if ($macaddress) {
            $cfg->{'ether'} = $macaddress->{'value'};
            }

        # Add IPv4 alias interfaces
        my $i = 0;
        foreach my $aa (@addrs) {
            my $acfg = { 'name' => $cfg->{'name'},
                     'virtual' => $i,
                     'fullname' => $cfg->{'name'}.":".$i,
                     'file' => $f,
                     'edit' => 1,
                     'up' => 1, };
            ($acfg->{'address'}, $acfg->{'netmask'}) =
                &split_addr_netmask($aa);
            $acfg->{'index'} = scalar(@rv);
            push(@rv, $acfg);
            $i++;
            }
        }
    }
return @rv;
}

# save_interface(&details, [&all-interfaces])
# Create or update a boot-time interface
sub save_interface
{
my ($iface, $boot) = @_;
$boot ||= [ &boot_interfaces() ];
if ($iface->{'virtual'} ne '') {
    # Find the parent config entry
    my ($parent) = grep { $_->{'fullname'} eq $iface->{'name'} } @$boot;
    $parent || &error("No interface named $iface->{'name'} exists");
    if (!$iface->{'file'}) {
        # Add to complete interface list
        push(@$boot, $iface);
        }
    else {
        # Update in complete list
        my ($oldiface) = grep { $_->{'fullname'} eq
                    $iface->{'fullname'} } @$boot;
        $oldiface || &error("No existing interface named $iface->{'fullname'} found");
        $boot->[$oldiface->{'index'}] = $iface;
        }
    &save_interface($parent, $boot);
    }
else {
    # Build interface config lines
    my $id = " " x 8;
    my @lines;
    push(@lines, $id.$iface->{'fullname'}.":");
    my @addrs;
    if (!$iface->{'up'}) {
        push(@lines, $id."    "."optional: true");
        }
    if ($iface->{'dhcp'}) {
        push(@lines, $id."    "."dhp4: true");
        }
    else {
        push(@addrs, $iface->{'address'}."/".
                 &mask_to_prefix($iface->{'netmask'}));
        }
    for(my $i=0; $i<@{$iface->{'address6'}}; $i++) {
        push(@addrs, $iface->{'address6'}->[$i]."/".
                 $iface->{'netmask6'}->[$i]);
        }
    foreach my $a (@$boot) {
        if ($a->{'virtual'} ne '' && $a->{'name'} eq $iface->{'name'}) {
            push(@addrs, $a->{'address'}."/".
                     &mask_to_prefix($a->{'netmask'}));
            }
        }
    if (@addrs) {
        push(@lines, $id."    "."addresses: [".join(",", @addrs)."]");
        }
    if ($iface->{'gateway'}) {
        push(@lines, $id."    "."gateway4: ".$iface->{'gateway'});
        }
    if ($iface->{'gateway6'}) {
        push(@lines, $id."    "."gateway6: ".$iface->{'gateway6'});
        }
    if ($iface->{'nameserver'}) {
        push(@lines, $id."    "."nameservers:");
        push(@lines, $id."        "."addresses: [".
                 join(",", @{$iface->{'nameserver'}})."]");
        if ($iface->{'search'}) {
            push(@lines, $id."        "."search: [".
                     join(",", @{$iface->{'search'}})."]");
            }
        }
    if ($iface->{'ether'}) {
        push(@lines, $id."    "."macaddress: ".$iface->{'ether'});
        }

    if ($iface->{'file'}) {
        # Replacing an existing interface
        my ($old) = grep { $_->{'fullname'} eq $iface->{'fullname'} } @$boot;
        $old || &error("No interface named $iface->{'fullname'} found");
        &lock_file($old->{'file'});
        my $lref = &read_file_lines($old->{'file'});
        splice(@$lref, $old->{'line'},
               $old->{'eline'} - $old->{'line'} + 1, @lines);
        &flush_file_lines($old->{'file'});
        &unlock_file($old->{'file'});
        }
    else {
        # Adding a new one (to it's own file)
        $iface->{'file'} = $netplan_dir."/".$iface->{'name'}.".yaml";
        @lines = ( "network:",
               "    ethernets:",
               @lines );
        &lock_file($iface->{'file'});
        my $lref = &read_file_lines($iface->{'file'});
        push(@$lref, @lines);
        &flush_file_lines($iface->{'file'});
        &unlock_file($iface->{'file'});
        }
    }
}

# delete_interface(&details)
# Remove a boot-time interface
sub delete_interface
{
my ($iface) = @_;
if ($iface->{'virtual'} ne '') {
    # Just remove the virtual address
    my $boot = [ &boot_interfaces() ];
    my ($parent) = grep { $_->{'fullname'} eq $iface->{'name'} } @$boot;
    $parent || &error("No interface named $iface->{'name'} exists");
    $boot = [ grep { $_->{'fullname'} ne $iface->{'fullname'} } @$boot ];
    &save_interface($parent, $boot);
    }
else {
    # Delete all the lines
    &lock_file($iface->{'file'});
    my $lref = &read_file_lines($iface->{'file'});
    splice(@$lref, $iface->{'line'},
           $iface->{'eline'} - $iface->{'line'} + 1);
    &flush_file_lines($iface->{'file'});
    &unlock_file($iface->{'file'});
    # XXX also delete file if empty?
    }
}

sub supports_bonding
{
return 0;    # XXX fix later
}

sub supports_vlans
{
return 0;    # XXX fix later
}

sub boot_iface_hardware
{
return $_[0] =~ /^(eth|em)/;
}

# supports_address6([&iface])
# Returns 1 if managing IPv6 interfaces is supported
sub supports_address6
{
local ($iface) = @_;
return !$iface || $iface->{'virtual'} eq '';
}

# Returns 1, as boot-time interfaces on Debian can exist without an IP (such as
# for bridging)
sub supports_no_address
{
return 1;
}

# Bridge interfaces can be created on debian
sub supports_bridges
{
return 0;    # XXX fix later
}

# can_edit(what)
# Can some boot-time interface parameter be edited?
sub can_edit
{
my ($f) = @_;
return $f ne "mtu";
}

# valid_boot_address(address)
# Is some address valid for a bootup interface
sub valid_boot_address
{
return &check_ipaddress_any($_[0]);
}

# get_hostname()
sub get_hostname
{
local $hn = &read_file_contents("/etc/hostname");
$hn =~ s/\r|\n//g;
if ($hn) {
    return $hn;
    }
return &get_system_hostname(1);
}

# save_hostname(name)
sub save_hostname
{
local (%conf, $f);
&system_logged("hostname $_[0] >/dev/null 2>&1");
foreach $f ("/etc/hostname", "/etc/HOSTNAME", "/etc/mailname") {
    if (-r $f) {
        &open_lock_tempfile(HOST, ">$f");
        &print_tempfile(HOST, $_[0],"\n");
        &close_tempfile(HOST);
        }
    }
undef(@main::get_system_hostname);      # clear cache
}

# get_domainname()
sub get_domainname
{
local $d;
&execute_command("domainname", undef, \$d, undef);
chop($d);
return $d;
}

# save_domainname(domain)
sub save_domainname
{
local %conf;
&execute_command("domainname ".quotemeta($_[0]));
}

sub routing_config_files
{
return ( $netplan_dir, $sysctl_config );
}

# routing_input()
# show default router and device
sub routing_input
{
my ($addr, $router) = &get_default_gateway();
my ($addr6, $router6) = &get_default_ipv6_gateway();
my @ifaces = grep { $_->{'virtual'} eq '' } &boot_interfaces();

# Show default gateway
print &ui_table_row($text{'routes_default'},
    &ui_radio("gateway_def", $addr ? 0 : 1,
          [ [ 1, $text{'routes_none'} ],
            [ 0, $text{'routes_gateway'}." ".
             &ui_textbox("gateway", $addr, 15)." ".
             &ui_select("gatewaydev", $router,
                [ map { $_->{'name'} } @ifaces ]) ] ]));

# Show default IPv6 gateway
print &ui_table_row($text{'routes_default6'},
    &ui_radio("gateway6_def", $addr6 ? 0 : 1,
          [ [ 1, $text{'routes_none'} ],
            [ 0, $text{'routes_gateway'}." ".
             &ui_textbox("gateway6", $addr6, 30)." ".
             &ui_select("gatewaydev6", $router6,
                [ map { $_->{'name'} } @ifaces ]) ] ]));

# Act as router?
local %sysctl;
&read_env_file($sysctl_config, \%sysctl);
print &ui_table_row($text{'routes_forward'},
    &ui_yesno_radio("forward",
            $sysctl{'net.ipv4.ip_forward'} ? 1 : 0));
}

# parse_routing()
# Save the form generated by routing_input
sub parse_routing
{
# Save IPv4 address
my ($dev, $gw);
if (!$in{'gateway_def'}) {
    &check_ipaddress($in{'gateway'}) ||
        &error(&text('routes_egateway', $in{'gateway'}));
    $gw = $in{'gateway'};
    $dev = $in{'gatewaydev'};
    }
&set_default_gateway($gw, $dev);

# Save IPv6 address
my ($dev6, $gw6);
if (!$in{'gateway6_def'}) {
    &check_ip6address($in{'gateway6'}) ||
        &error(&text('routes_egateway6', $in{'gateway6'}));
    $gw6 = $in{'gateway6'};
    $dev6 = $in{'gatewaydev6'};
    }
&set_default_ipv6_gateway($gw6, $dev6);

# Save routing flag
local %sysctl;
&lock_file($sysctl_config);
&read_env_file($sysctl_config, \%sysctl);
$sysctl{'net.ipv4.ip_forward'} = $in{'forward'};
&write_env_file($sysctl_config, \%sysctl);
&unlock_file($sysctl_config);
}

sub network_config_files
{
return ( "/etc/hostname", "/etc/HOSTNAME", "/etc/mailname" );
}

# apply_network()
# Apply the interface and routing settings
sub apply_network
{
&system_logged("(cd / ; netplan apply) >/dev/null 2>&1");
}

# get_default_gateway()
# Returns the default gateway IP (if one is set) and device (if set) boot time
# settings.
sub get_default_gateway
{
foreach my $iface (&boot_interfaces()) {
    if ($iface->{'gateway'}) {
        return ( $iface->{'gateway'}, $iface->{'fullname'} );
        }
    }
return ( );
}

# set_default_gateway([gateway, device])
# Sets the default gateway to the given IP accessible via the given device,
# in the boot time settings.
sub set_default_gateway
{
my ($gw, $dev) = @_;
foreach my $iface (&boot_interfaces()) {
    if ($iface->{'fullname'} eq $dev && $iface->{'gateway'} ne $gw) {
        # Need to add to this interface
        $iface->{'gateway'} = $gw;
        &save_interface($iface);
        }
    elsif ($iface->{'fullname'} ne $dev && $iface->{'gateway'}) {
        # Need to remove from this interface
        delete($iface->{'gateway'});
        &save_interface($iface);
        }
    }
}

# get_default_ipv6_gateway()
# Returns the default gateway IPv6 address (if one is set) and device (if set)
# boot time settings.
sub get_default_ipv6_gateway
{
foreach my $iface (&boot_interfaces()) {
    if ($iface->{'gateway6'}) {
        return ( $iface->{'gateway6'}, $iface->{'fullname'} );
        }
    }
return ( );
}

# set_default_ipv6_gateway([gateway, device])
# Sets the default IPv6 gateway to the given IP accessible via the given device,
# in the boot time settings.
sub set_default_ipv6_gateway
{
my ($gw, $dev) = @_;
foreach my $iface (&boot_interfaces()) {
    if ($iface->{'fullname'} eq $dev && $iface->{'gateway6'} ne $gw) {
        # Need to add to this interface
        $iface->{'gateway6'} = $gw;
        &save_interface($iface);
        }
    elsif ($iface->{'fullname'} ne $dev && $iface->{'gateway6'}) {
        # Need to remove from this interface
        delete($iface->{'gateway6'});
        &save_interface($iface);
        }
    }
}

# os_save_dns_config(&config)
# On Ubuntu 18+, DNS servers are stored in the Netplan config files
sub os_save_dns_config
{
my ($conf) = @_;
my @boot = &boot_interfaces();
my @fix = grep { $_->{'nameserver'} } @boot;
@fix = @boot if (!@fix);
foreach my $iface (@fix) {
    $iface->{'nameserver'} = $conf->{'nameserver'};
    $iface->{'search'} = $conf->{'domain'};
    &save_interface($iface);
    }
}

# read_yaml_file(file)
# Converts a YAML file into a nested hash ref
sub read_yaml_file
{
my ($file) = @_;
my $lref = &read_file_lines($file, 1);
my $lnum = 0;
my $rv = [ ];
my $parent = { 'members' => $rv,
           'indent' => -1 };
foreach my $origl (@$lref) {
    my $l = $origl;
    $l =~ s/#.*$//;
    if ($l =~ /^(\s*)(\S+):\s*(\S.*)/) {
        # Value line
        my $i = length($1);
        my $dir = { 'indent' => length($1),
                'name' => $2,
                'value' => $3,
                'line' => $lnum,
                'eline' => $lnum,
                'parent' => $parent,
              };
        if ($dir->{'value'} =~ /^\[(.*)\]$/) {
            $dir->{'value'} = [ split(/,/, $1) ];
            }
        while($i <= $parent->{'indent'}) {
            $parent = $parent->{'parent'};
            }
        push(@{$parent->{'members'}}, $dir);
        &set_parent_elines($parent, $lnum);
        }
    elsif ($l =~ /^(\s*)(\S+):\s*$/) {
        # Section header line
        my $i = length($1);
        my $dir = { 'indent' => length($1),
                'name' => $2,
                'members' => [ ],
                'line' => $lnum,
                'eline' => $lnum,
              };
        if ($i > $parent->{'indent'}) {
            # Start of a sub-section inside the current directive
            push(@{$parent->{'members'}}, $dir);
            $dir->{'parent'} = $parent;
            &set_parent_elines($parent, $lnum);
            $parent = $dir;
            }
        else {
            # Pop up a level (or more)
            while($i <= $parent->{'indent'}) {
                $parent = $parent->{'parent'};
                }
            }
        }
    $lnum++;
    }
return $rv;
}

# set_parent_elines(&conf, eline)
sub set_parent_elines
{
my ($c, $eline) = @_;
$c->{'eline'} = $eline;
&set_parent_elines($c->{'parent'}, $eline) if ($c->{'parent'});
}

# split_addr_netmask(addr-string)
# Splits a string like 1.2.3.4/24 into an address and netmask
sub split_addr_netmask
{
my ($a) = @_;
if ($a =~ /^([0-9\.]+)\/(\d+)$/) {
    return ($1, &prefix_to_mask($2));
    }
elsif ($a =~ /^([0-9\.]+)\/([0-9\.]+)$/) {
    return ($1, $2);
    }
else {
    return $a;
    }
}

sub is_true_value
{
my ($dir) = @_;
return $dir && $dir->{'value'} =~ /true|yes|1/i;
}

1;

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

:: Make Dir ::
 
[ Read-Only ]
:: Make File ::
 
[ Read-Only ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 1.0 pre-release build #16 powered by Captain Crunch Security Team | http://ccteam.ru | Generation time: 0.0043 ]--