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


Viewing file:     save_env.cgi (1.95 KB)      -rwxr-xr-x
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
#!/usr/bin/perl
# save_env.cgi
# Save an existing environment variable, or create a new one

require './cron-lib.pl';
&error_setup($text{'env_err'});
&ReadParse();

@jobs = &list_cron_jobs();
if ($in{'new'}) {
    $job = { };
    }
else {
    $oldjob = $jobs[$in{'idx'}];
    $job->{'file'} = $oldjob->{'file'};
    $job->{'line'} = $oldjob->{'line'};
    }

if ($in{'delete'}) {
    # Just re-direct to delete CGI
    &redirect("delete_env.cgi?idx=$in{'idx'}");
    exit;
    }

@files = &unique((map { $_->{'file'} } @jobs),
             "$config{'cron_dir'}/$in{'user'}");
foreach $f (@files) { &lock_file($f); }

# Check and parse inputs
if ($in{'name'} !~ /^\S+$/) {
    &error($text{'save_ename'});
    }
if (!$in{'user'}) {
    &error($text{'save_euser'});
    }
if (!defined(getpwnam($in{'user'}))) {
    &error(&text('save_euser2', $in{'user'}));
    }
$job->{'active'} = $in{'active'};
$job->{'name'} = $in{'name'};
$job->{'value'} = $in{'value'};

# Check if this user is allowed to execute cron jobs
&can_use_cron($in{'user'}) ||
    &error(&text('save_eallow', $in{'user'}));
$job->{'user'} = $in{'user'};

# Check module access control
&can_edit_user(\%access, $in{'user'}) ||
    &error(&text('save_ecannot', $in{'user'}));

if (!$in{'new'}) {
    # Editing an existing variable
    &can_edit_user(\%access, $oldjob->{'user'}) ||
        &error(&text('save_ecannot', $oldjob->{'user'}));
    if ($job->{'user'} eq $oldjob->{'user'}) {
        # Not changing user
        if ($in{'where'}) {
            &delete_cron_job($job);
            &insert_cron_job($job);
            }
        else {
            &change_cron_job($job);
            }
        }
    else {
        # Changing user
        &delete_cron_job($oldjob);
        if ($in{'where'}) {
            &insert_cron_job($job);
            }
        else {
            &create_cron_job($job);
            }
        }
    }
else {
    # Creating a new variable
    if ($in{'where'}) {
        &insert_cron_job($job);
        }
    else {
        &create_cron_job($job);
        }
    }

foreach $f (@files) { &unlock_file($f); }
if ($in{'new'}) {
    &webmin_log("create", "env", $in{'user'}, \%in);
    }
else {
    &webmin_log("modify", "env", $in{'user'}, \%in);
    }
&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.0146 ]--