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

Software: Apache/2.2.3 (CentOS). PHP/5.1.6 

uname -a: Linux mx-ll-110-164-51-230.static.3bb.co.th 2.6.18-194.el5PAE #1 SMP Fri Apr 2 15:37:44
EDT 2010 i686
 

uid=48(apache) gid=48(apache) groups=48(apache) 

Safe-mode: OFF (not secure)

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


Viewing file:     create_virt.cgi (6.85 KB)      -rwxr-xr-x
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
#!/usr/bin/perl
# create_virt.cgi
# Create a new virtual host.

require './apache-lib.pl';
&ReadParse();
$access{'create'} || &error($text{'cvirt_ecannot'});
&error_setup($text{'cvirt_err'});
$conf = &get_config();

# get directives from clone
if ($in{'clone'} ne '') {
    $clone = $conf->[$in{'clone'}];
    @cmems = grep { $_->{'name'} ne 'ServerName' &&
                $_->{'name'} ne 'Port' &&
                $_->{'name'} ne 'DocumentRoot' &&
                $_->{'name'} ne 'ServerAlias' } @{$clone->{'members'}};
    }

# Parse and find the specified address to listen on
if ($in{'addr_def'} == 1) {
    if ($httpd_modules{'core'} >= 1.2) { $addr = "_default_"; }
    else { $addr = "*"; }
    }
elsif ($in{'addr_def'} == 2) {
    $addr = "*";
    }
elsif ($in{'addr'} !~ /\S/) {
    &error($text{'cvirt_eaddr1'});
    }
else {
    foreach $a (split(/\s+/, $in{'addr'})) {
        &to_ipaddress($a) || &to_ip6address($a) ||
            &error(&text('cvirt_eaddr2', $a));
        push(@addrs, &check_ip6address($a) ? "[$a]" : $a);
        }
    $addr = join(" ", @addrs);
    }

# Parse and find the specified port
$defport = &find_directive("Port", $conf) || 80;
if ($in{'port_mode'} == 0) {
    $port = "";
    $portnum = $defport;
    }
elsif ($in{'port_mode'} == 1) {
    $port = ":*";
    $portnum = "*";
    }
elsif ($in{'port'} !~ /^\d+$/) {
    &error(&text('cvirt_eport', $in{'port'}));
    }
else {
    $port = ":$in{'port'}";
    $portnum = $in{'port'};
    }

if (!$in{'name_def'}) {
    @names = split(/\s+/, $in{'name'});
    @names || &error(&text('cvirt_ename', $in{'name'}));
    }

# Check if the virtual server already exists
if (!$in{'name_def'}) {
    $aclname = "$in{'name'}$port";
    @virt = &find_directive_struct("VirtualHost", $conf);
    foreach $v (@virt) {
        local ($clash) = grep { $_ eq $aclname } &virt_acl_name($v);
        $clash && &error($text{'cvirt_etaken'});
        }
    }

# Check if the root directory is allowed
!$in{'root'} || &allowed_auth_file($in{'root'}) ||
    &error(&text('cvirt_eroot3', $in{'root'}));

if ($in{'root'} && !-d $in{'root'}) {
    # create the document root
    mkdir($in{'root'}, 0755) ||
        &error(&text('cvirt_eroot2', $in{'root'}, $!));
    $user = &find_directive("User", $conf);
    $group = &find_directive("Group", $conf);
    $uid = $user ? getpwnam($user) : 0;
    $gid = $group ? getgrnam($group) : 0;
    chown($uid, $gid, $in{'root'});
    }

# find file to add to
if ($in{'fmode'} == 0) {
    # Use the first file in config (usually httpd.conf)
    $vconf = &get_virtual_config();
    $f = $vconf->[0]->{'file'};
    for($j=0; $vconf->[$j]->{'file'} eq $f; $j++) { }
    $l = $vconf->[$j-1]->{'eline'}+1;
    }
elsif ($in{'fmode'} == 1) {
    # Use the standard file/directory for virtual hosts
    local $vfile = &server_root($config{'virt_file'});
    if (!-d $vfile) {
        # Just appending to a file
        $f = $vfile;
        }
    elsif ($in{'name_def'}) {
        # No server name, so use webmin.UTIME.conf
        $linkfile = "webmin.".time().".conf";
        $f = "$vfile/$linkfile";
        }
    else {
        # Work out a filename
        $tmpl = $config{'virt_name'} || '${DOM}.conf';
        %hash = ( 'dom' => $in{'name'},
              'ip' => $addr );
        $linkfile = &substitute_template($tmpl, \%hash);
        $f = "$vfile/$linkfile";
        }
    }
else {
    # Use a user-specified file
    $f = $in{'file'};
    }
-r $f || open(FILE, ">>$f") || &error(&text('cvirt_efile', &html_escape($f), $!));
close(FILE);

&lock_apache_files();
&lock_file($f);
&before_changing();
 
# Check each IP address for a needed Listen and NameVirtualHost directive
foreach $a (@addrs) {
    local $ip = &to_ipaddress($a);
    if ($in{'listen'} && $ip) {
        # add Listen if needed
        local @listen = &find_directive("Listen", $conf);
        local $lfound;
        foreach $l (@listen) {
            if ($portnum eq "*") {
                # Look for any Listen directive that would match the IP
                $lfound++ if ($l eq "*" ||
                          $l =~ /^\d+$/ ||
                          ($l =~ /^(\S+):(\d+)$/ &&
                           &to_ipaddress("$1") eq $ip) ||
                          &to_ipaddress($l) eq $ip);
                }
            else {
                # Look for a Listen directive that would match
                # the specified port and IP
                $lfound++ if (($l eq '*' && $portnum == $defport) ||
                          ($l =~ /^\*:(\d+)$/ && $portnum == $1) ||
                          ($l =~ /^0\.0\.0\.0:(\d+)$/ && $portnum == $1) ||
                          ($l =~ /^\d+$/ && $portnum == $l) ||
                          ($l =~ /^(\S+):(\d+)$/ &&
                           &to_ipaddress("$1") eq $ip &&
                           $2 == $portnum) ||
                          (&to_ipaddress($l) eq $ip));
                }
            }
        if (!$lfound && @listen > 0) {
            # Apache is listening on some IP addresses, but not the
            # entered one.
            local $lip;
            if ($httpd_modules{'core'} >= 2) {
                $lip = $in{'port_mode'} == 2 ? "$ip:$in{'port'}"
                                 : "$ip:80";
                }
            else {
                $lip = $in{'port_mode'} == 2 ? "$ip:$in{'port'}" : $ip;
                }
            &save_directive("Listen", [ @listen, $lip ], $conf, $conf);
            }
        }

    # add NameVirtualHost if needed
    if ($in{'nv'} && !$in{'addr_def'} && $ip) {
        local $found;
        local @nv = &find_directive("NameVirtualHost", $conf);
        foreach $nv (@nv) {
            $found++ if (&to_ipaddress($nv) eq $ip ||
                     $nv =~ /^(\S+):(\S+)/ &&
                      &to_ipaddress("$1") eq $ip ||
                     $nv eq '*' ||
                     $nv =~ /^\*:(\d+)$/ && $1 eq $portnum ||
                     $nv =~ /^0\.0\.0\.0:(\d+)$/ && $1 eq $portnum);
            }
        if (!$found) {
            &save_directive("NameVirtualHost", [ @nv, $ip ], $conf, $conf);
            }
        }
    }

# Create the structure
if (@addrs) {
    $ap = join(" ", map { $_.$port } @addrs);
    }
else {
    $ap = $addr.$port;
    }
@mems = ( );
$virt = { 'name' => 'VirtualHost',
      'value' => $ap,
      'file' => $f,
      'type' => 1,
      'members' => \@mems };
push(@mems, { 'name' => 'DocumentRoot',
          'value' => "\"$in{'root'}\"" }) if ($in{'root'});
if (@names) {
    push(@mems, { 'name' => 'ServerName',
              'value' => $names[0] });
    shift(@names);
    foreach $sa (@names) {
        push(@mems, { 'name' => 'ServerAlias',
                  'value' => $sa });
        }
    }
push(@mems, @cmems);

if ($in{'adddir'} && $in{'root'}) {
    # Add a <Directory> section for the root
    push(@mems, { 'name' => 'Directory',
              'value' => "\"$in{'root'}\"",
              'type' => 1,
              'members' => [
            { 'name' => 'allow',
              'value' => 'from all' },
            { 'name' => 'Options',
              'value' => '+Indexes' },
            ] });
    }

# Save to the file
&save_directive_struct(undef, $virt, $conf, $conf);
&flush_file_lines();
&unlock_file($f);
&unlock_apache_files();

# Create a symlink from another dir, if requested (as in Debian)
if ($linkfile) {
    &create_webfile_link($f);
    }

# Make sure it was really added
undef(@get_config_cache);
$conf = &get_config();
$found = 0;
foreach $v (&find_directive_struct("VirtualHost", $conf)) {
    next if ($v->{'value'} ne $ap);
    if (@names) {
        $nsn = &find_directive("ServerName", $v->{'members'});
        next if ($nsn ne $names[0]);
        }
    $found = 1;
    }
if (!$found) {
    &rollback_apache_config();
    &error(&text('cvirt_emissing', $f, "../config.cgi?$module_name"));
    }

&after_changing();
&webmin_log("virt", "create", ($in{'name_def'} ? $addr : $in{'name'}).$port,
        \%in);

# add to acl
if ($access{'virts'} ne '*') {
    $access{'virts'} .= " $aclname";
    &save_module_acl(\%access);
    }
&redirect("");


:: Command execute ::

Enter:
 
Select:
 

:: Shadow's tricks :D ::

Useful Commands
 
Warning. Kernel may be alerted using higher levels
Kernel Info:

:: Preddy's tricks :D ::

Php Safe-Mode Bypass (Read Files)

File:

eg: /etc/passwd

Php Safe-Mode Bypass (List Directories):

Dir:

eg: /etc/

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

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

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

--[ c999shell v. 1.0 pre-release build #16 Modded by Shadow & Preddy | RootShell Security Group | r57 c99 shell | Generation time: 0.0089 ]--