!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/proftpd/   drwxr-xr-x
Free 53.79 GB of 127.8 GB (42.09%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     manual_save.cgi (3.14 KB)      -rwxr-xr-x
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
#!/usr/bin/perl
# manual_save.cgi
# Save manually entered directives

require './proftpd-lib.pl';
&ReadParseMime();
if ($in{'global'}) {
    $conf = &get_config();
    $global = &find_directive_struct("Global", $conf);
    $conf = $global->{'members'};
    if (defined($in{'limit'})) {
        # limit within the global section
        if ($in{'idx'}) {
            $d = $conf->[$in{'idx'}];
            $l = $d->{'members'}->[$in{'limit'}];
            }
        else {
            $l = $conf->[$in{'limit'}];
            }
        $file = $l->{'file'};
        $return = "limit_index.cgi";
        $start = $l->{'line'}+1; $end = $l->{'eline'}-1;
        }
    else {
        # directory in the global section
        $d = $conf->[$in{'idx'}];
        $file = $d->{'file'};
        $return = "dir_index.cgi";
        $start = $d->{'line'}+1; $end = $d->{'eline'}-1;
        $logtype = 'dir';
        $logname = $d->{'value'};
        }
    }
elsif (defined($in{'virt'})) {
    if (defined($in{'limit'})) {
        # limit, maybe within a directory
        ($conf, $v) = &get_virtual_config($in{'virt'});
        if ($in{'anon'}) {
            $anon = &find_directive_struct("Anonymous", $conf);
            $conf = $anon->{'members'};
            }
        if ($in{'idx'} ne '') {
            $conf = $conf->[$in{'idx'}]->{'members'};
            }
        $l = $conf->[$in{'limit'}];
        $file = $l->{'file'};
        $return = "limit_index.cgi";
        $start = $l->{'line'}+1; $end = $l->{'eline'}-1;
        $logtype = 'limit';
        $logname = $l->{'value'};
        }
    elsif (defined($in{'idx'})) {
        # directory within virtual server
        ($vconf, $v) = &get_virtual_config($in{'virt'});
        if ($in{'anon'}) {
            $anon = &find_directive_struct("Anonymous", $vconf);
            $vconf = $anon->{'members'};
            }
        $d = $vconf->[$in{'idx'}];
        $file = $d->{'file'};
        $return = "dir_index.cgi";
        $start = $d->{'line'}+1; $end = $d->{'eline'}-1;
        $logtype = 'dir';
        $logname = "$v->{'value'}:$d->{'words'}->[0]";
        }
    else {
        # virtual server
        ($conf, $v) = &get_virtual_config($in{'virt'});
        $return = "virt_index.cgi";
        $file = $v->{'file'};
        $start = $v->{'line'}+1; $end = $v->{'eline'}-1;
        $logtype = 'virt'; $logname = $v->{'words'}->[0];
        }
    }
else {
    if (defined($in{'limit'})) {
        # files within .htaccess file
        $hconf = &get_ftpaccess_config($in{'file'});
        $l = $hconf->[$in{'limit'}];
        $file = $in{'file'};
        $return = "limit_index.cgi";
        $start = $l->{'line'}+1; $end = $l->{'eline'}-1;
        $logtype = 'limit';
        $logname = $l->{'value'};
        }
    else {
        # .htaccess file
        $file = $in{'file'};
        $return = "ftpaccess_index.cgi";
        $logtype = 'ftpaccess'; $logname = $in{'file'};
        }
    }

&lock_file($file);
&lock_file($file);
$temp = &transname();
system("cp ".quotemeta($file)." $temp");
$in{'directives'} =~ s/\r//g;
$in{'directives'} =~ s/\s+$//;
@dirs = split(/\n/, $in{'directives'});
$lref = &read_file_lines($file);
if (!defined($start)) {
    $start = 0;
    $end = @$lref - 1;
    }
splice(@$lref, $start, $end-$start+1, @dirs);
&flush_file_lines();
if ($config{'test_manual'}) {
    $err = &test_config();
    if ($err) {
        system("mv $temp ".quotemeta($file));
        &error(&text('manual_etest', "<pre>$err</pre>"));
        }
    }
unlink($temp);
&unlock_file($file);
&webmin_log($logtype, "manual", $logname, \%in);

foreach $h ('virt', 'idx', 'file', 'limit', 'anon', 'global') {
    push(@args, "$h=$in{$h}") if (defined($in{$h}));
    }
&redirect("$return?".join("&", @args));


:: 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.0145 ]--