!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/cluster-webmin/   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:     refresh.cgi (4.08 KB)      -rwxr-xr-x
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
#!/usr/bin/perl
# refresh.cgi
# Reload the list of modules from all managed hosts

require './cluster-webmin-lib.pl';
&ReadParse();
&ui_print_header(undef, $text{'refresh_title'}, "");
$| = 1;

# Setup error handler for down hosts
sub ref_error
{
$ref_error_msg = join("", @_);
}
&remote_error_setup(\&ref_error);

# Work out which hosts
@hosts = &list_webmin_hosts();
@servers = &list_servers();
if (defined($in{'id'})) {
        @hosts = grep { $_->{'id'} == $in{'id'} } @hosts;
    local ($s) = grep { $_->{'id'} == $hosts[0]->{'id'} } @servers;
        print "<b>",&text('refresh_header5', undef,
              &server_name($s)),"</b><p>\n";
        }
else {
    @hosts = &create_on_parse("refresh_header");
        #print "<b>$text{'refresh_header'}</b><p>\n";
        }
$p = 0;
foreach $h (@hosts) {
    local ($s) = grep { $_->{'id'} == $h->{'id'} } @servers;

    local ($rh = "READ$p", $wh = "WRITE$p");
    pipe($rh, $wh);
    if (!fork()) {
        close($rh);
        if ($s) {
            # Refresh the list
            &remote_foreign_require($s->{'host'}, "webmin",
                        "webmin-lib.pl");
            if ($ref_error_msg) {
                # Host is down ..
                print $wh &serialise_variable($ref_error_msg);
                exit;
                }
            &remote_foreign_require($s->{'host'}, "acl",
                        "acl-lib.pl");
            local $gconfig = &remote_foreign_config($s->{'host'},
                                undef);
            foreach $g ('os_type', 'os_version',
                    'real_os_type', 'real_os_version') {
                $h->{$g} = $gconfig->{$g};
                }
            $h->{'version'} = &remote_foreign_call($s->{'host'},
                        "webmin", "get_webmin_version");

            # Refresh modules and themes
            local @old = map { $_->{'dir'} } ( @{$h->{'modules'}},
                               @{$h->{'themes'}} );
            undef($h->{'modules'});
            local @mods = &remote_foreign_call($s->{'host'},
                    "webmin", "get_all_module_infos", 1);
            @mods = grep { !$_->{'clone'} } @mods;
            local @themes = &remote_foreign_call($s->{'host'},
                     "webmin", "list_themes");
            local @added;
            foreach $m (@mods, @themes) {
                $idx = &indexof($m->{'dir'}, @old);
                if ($idx < 0) {
                    push(@added, $m->{'dir'});
                    }
                else {
                    splice(@old, $idx, 1);
                    }
                }
            $h->{'modules'} = \@mods;
            $h->{'themes'} = \@themes;

            # Refresh users and groups
            local @users = &remote_foreign_call($s->{'host'},
                    "acl", "list_users");
            local $ud = scalar(@users) - scalar(@{$h->{'users'}});
            $h->{'users'} = \@users;
            local @groups = &remote_foreign_call($s->{'host'},
                    "acl", "list_groups");
            local $gd = scalar(@groups) - scalar(@{$h->{'groups'}});
            $h->{'groups'} = \@groups;

            &save_webmin_host($h);
            $rv = [ \@added, \@old, $ud, $gd ];
            }
        else {
            # remove from managed list
            &delete_webmin_host($h);
            $rv = undef;
            }
        print $wh &serialise_variable($rv);
        close($wh);
        exit;
        }
    close($wh);
    $p++;
    }

# Read back results
$p = 0;
foreach $h (@hosts) {
    local ($s) = grep { $_->{'id'} == $h->{'id'} } @servers;
    local $d = &server_name($s);
    local $rh = "READ$p";
    local $line = <$rh>;
    local $rv = &unserialise_variable($line);
    close($rh);

    if ($rv && ref($rv)) {
        @added = @{$rv->[0]};
        @old = @{$rv->[1]};
        if (@added && @old) {
            print &text('refresh_1', $d,
                    join(" ", @added),join(" ", @old)),"\n";
            }
        elsif (@added) {
            print &text('refresh_2', $d,
                    join(" ", @added)),"\n";
            }
        elsif (@old) {
            print &text('refresh_3', $d, join(" ", @old)),"\n";
            }
        else {
            print &text('refresh_4', $d),"\n";
            }
        if ($rv->[2] > 0) {
            print &text('refresh_u1', $rv->[2]),"\n";
            }
        elsif ($rv->[2] < 0) {
            print &text('refresh_u2', -$rv->[2]),"\n";
            }
        if ($rv->[3] > 0) {
            print &text('refresh_g1', $rv->[3]),"\n";
            }
        elsif ($rv->[3] < 0) {
            print &text('refresh_g2', -$rv->[3]),"\n";
            }
        print "<br>\n";
        }
    elsif ($rv) {
        print &text('refresh_failed', $d, $rv),"<br>\n";
        }
    else {
        print &text('refresh_del', $h->{'id'}),"<br>\n";
        }

    $p++;
    }

print "<p><b>$text{'refresh_done'}</b><p>\n";

&remote_finished();
if (defined($in{'id'})) {
        &ui_print_footer("edit_host.cgi?id=$in{'id'}", $text{'host_return'},
                         "", $text{'index_return'});
        }
else {
        &ui_print_footer("", $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.0091 ]--