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

Software: Apache/2.0.54 (Fedora). PHP/5.0.4 

uname -a: Linux mina-info.me 2.6.17-1.2142_FC4smp #1 SMP Tue Jul 11 22:57:02 EDT 2006 i686 

uid=48(apache) gid=48(apache) groups=48(apache)
context=system_u:system_r:httpd_sys_script_t
 

Safe-mode: OFF (not secure)

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


Viewing file:     edit_user.cgi (12.74 KB)      -rwxr-xr-x
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
#!/usr/bin/perl
# edit_user.cgi
# Edit a new or existing webmin user

use strict;
use warnings;
require './acl-lib.pl';
our (%in, %text, %config, %access, $config_directory, $base_remote_user);
&foreign_require("webmin", "webmin-lib.pl");

&ReadParse();
my ($u, %user);
if ($in{'user'}) {
    # Editing an existing user
    &can_edit_user($in{'user'}) || &error($text{'edit_euser'});
    &ui_print_header(undef, $text{'edit_title'}, "");
    $u = &get_user($in{'user'});
    $u || &error($text{'edit_egone'});
    %user = %$u;
    }
else {
    # Creating a new user
    $access{'create'} || &error($text{'edit_ecreate'});
    &ui_print_header(undef, $text{'edit_title2'}, "");
    if ($in{'clone'}) {
        # Initial settings come from clone
        $u = &get_user($in{'clone'});
        %user = %$u;
        delete($user{'name'});
        }
    else {
        %user = ( );
        }
    }
my $me = &get_user($base_remote_user);

# Give up if readonly
if ($user{'readonly'} && !$in{'readwrite'}) {
    my %minfo = &get_module_info($user{'readonly'});
    print &text('edit_readonly', $minfo{'desc'},
            "edit_user.cgi?user=$in{'user'}&readwrite=1"),"<p>\n";
    &ui_print_footer("", $text{'index_return'});
    exit;
    }

print &ui_form_start("save_user.cgi", "post");
if ($in{'user'}) {
    print &ui_hidden("old", $user{'name'});
    print &ui_hidden("oldpass", $user{'pass'});
    }
if ($in{'clone'}) {
    print &ui_hidden("clone", $in{'clone'});
    }
print &ui_hidden_table_start($text{'edit_rights'}, "width=100%", 2, "rights",
                 1, [ "width=30%" ]);

# Username
print &ui_table_row($text{'edit_user'},
    $access{'rename'} || !$in{'user'} ?
        &ui_textbox("name", $user{'name'}, 30,
                0, undef, "autocomplete=off") : $user{'name'});

# Source user for clone
if ($in{'clone'}) {
    print &ui_table_row($text{'edit_cloneof'}, "<tt>$in{'clone'}</tt>");
    }

# Find and show parent group
my @glist = &list_groups();
my @mcan = $access{'gassign'} eq '*' ?
        ( ( map { $_->{'name'} } @glist ), '_none' ) :
        split(/\s+/, $access{'gassign'});
my %gcan = map { $_, 1 } @mcan;
my $memg;
if (@glist && %gcan) {
    my @opts = ( );
    if ($gcan{'_none'}) {
        push(@opts, [ undef, "&lt;$text{'edit_none'}&gt;" ]);
        }
    foreach my $g (@glist) {
        if (&indexof($user{'name'}, @{$g->{'members'}}) >= 0 ||
            $in{'clone'} &&
             &indexof($in{'clone'}, @{$g->{'members'}}) >= 0) {
            $memg = $g;
            }
        next if (!$gcan{$g->{'name'}} && $memg ne $g);
        push(@opts, [ $g->{'name'} ]);
        }
    print &ui_table_row($text{'edit_group'},
        &ui_select("group", $memg->{'name'}, \@opts));
    }

# Show password type menu and current password
my $passmode = !$in{'user'} ? 0 :
           $user{'pass'} eq 'x' ? 3 :
           $user{'sync'} ? 2 :
           $user{'pass'} eq 'e' ? 5 :
           $user{'pass'} eq '*LK*' ? 4 : 1;
my %miniserv;
&get_miniserv_config(\%miniserv);
my @opts = ( [ 0, "$text{'edit_set'} .." ] );
if ($in{'user'}) {
    push(@opts, [ 1, $text{'edit_dont'} ]);
    }
push(@opts, [ 3, $text{'edit_unix'} ]);
if ($user{'sync'}) {
    push(@opts, [ 2, $text{'edit_same'} ]);
    }
if ($miniserv{'extauth'}) {
    push(@opts, [ 5, $text{'edit_extauth'} ]);
    }
push(@opts, [ 4, $text{'edit_lock'} ]);
my ($lockbox, $tempbox) = ("", "");
if ($passmode == 1) {
    $lockbox = &ui_checkbox("lock", 1, $text{'edit_templock'},
                           $user{'pass'} =~ /^\!/ ? 1 : 0);
    }
if ($passmode != 3 && $passmode != 4) {
    $tempbox = &ui_checkbox("temp", 1, $text{'edit_temppass'},
                $user{'temppass'});
    }
my $expmsg = "";
if ($user{'lastchange'} && $miniserv{'pass_maxdays'}) {
    my $daysold = int((time() - $user{'lastchange'})/(24*60*60));
    if ($miniserv{'pass_lockdays'} &&
        $daysold > $miniserv{'pass_lockdays'}) {
        $expmsg = "<br>"."<font color=#ff0000>".
              &text('edit_passlocked', $daysold)."</font>";
        }
    elsif ($daysold > $miniserv{'pass_maxdays'}) {
        $expmsg = "<br>"."<font color=#ffaa00>".
              &text('edit_passmax', $daysold)."</font>";
        }
    elsif ($daysold) {
        $expmsg = "<br>".&text('edit_passold', $daysold);
        }
    else {
        $expmsg = "<br>".$text{'edit_passtoday'};
        }
    }
my $js = "onChange='form.pass.disabled = value != 0;'";
print &ui_table_row($text{'edit_pass'},
    &ui_select("pass_def", $passmode, \@opts, 1, 0, 0, 0, $js)." ".
    &ui_password("pass", undef, 25, $passmode != 0, undef,
             "autocomplete=off").
    ($lockbox || $tempbox ? "<br>" : "").$lockbox.$tempbox.$expmsg);

# Real name
print &ui_table_row($text{'edit_real'},
    &ui_textbox("real", $user{'real'}, 60));

# Storage type
if ($in{'user'}) {
    print &ui_table_row($text{'edit_proto'},
        $text{'edit_proto_'.($user{'proto'} || '')});
    }

print &ui_hidden_table_end("rights");

# Start of UI options section
my $showui = $access{'chcert'} || $access{'lang'} ||
         $access{'cats'} || $access{'theme'};
if ($showui) {
    print &ui_hidden_table_start($text{'edit_ui'}, "width=100%", 2, "ui",
                     0, [ "width=30%" ]);
    }

if ($access{'chcert'}) {
    # SSL certificate name
    print &ui_table_row($text{'edit_cert'},
        &ui_opt_textbox("cert", $user{'cert'}, 50, $text{'edit_none'}));
    }

if ($access{'lang'}) {
    # Current language
    print &ui_table_row($text{'edit_lang'},
        &ui_radio("lang_def", $user{'lang'} ? 0 : 1,
          [ [ 1, $text{'default'} ],
            [ 0, &ui_select("lang", $user{'lang'},
                [ map { [ $_->{'lang'}, $_->{'desc'}." (".
                    uc($_->{'lang'}).")" ] }
                  &list_languages() ]) ]
          ]));
    }

if ($access{'cats'}) {
    # Show categorized modules?
    print &ui_table_row($text{'edit_notabs'},
        &ui_radio("notabs", $user{'notabs'} || 0,
              [ [ 1, $text{'yes'} ],
                [ 2, $text{'no'} ],
                [ 0, $text{'default'} ] ]));
    }

my @all = &webmin::list_themes();
my @themes = grep { !$_->{'overlay'} } @all;
my @overlays = grep { $_->{'overlay'} } @all;

if ($access{'theme'}) {
    # Current theme
    my @topts = ( );
    push(@topts, [ "", $text{'edit_themedef'} ]);
    foreach my $t (@themes) {
        push(@topts, [ $t->{'dir'}, $t->{'desc'} ]);
        }
    print &ui_table_row($text{'edit_theme'},
        &ui_radio("theme_def", defined($user{'theme'}) ? 0 : 1,
          [ [ 1, $text{'edit_themeglobal'} ],
            [ 0, &ui_select("theme", $user{'theme'}, \@topts) ] ]));
    }

if ($access{'theme'} && @overlays) {
    # Overlay theme, if any
    print &ui_table_row($text{'edit_overlay'},
        &ui_radio("overlay_def", defined($user{'overlay'}) ? 0 : 1,
          [ [ 1, $text{'edit_overlayglobal'} ],
            [ 0, &ui_select("overlay", $user{'overlay'},
               [ map { [ $_->{'dir'}, $_->{'desc'} ] } @overlays ]
                    ) ] ]));
    }

if ($showui) {
    print &ui_hidden_table_end("ui");
    }

# Start of security options section
my $showsecurity = $access{'logouttime'} || $access{'ips'} ||
           $access{'minsize'} ||
           &supports_rbac() && $access{'mode'} == 0 || $access{'times'};
if ($showsecurity) {
    print &ui_hidden_table_start($text{'edit_security'}, "width=100%", 2,
                     "security", 0, [ "width=30%" ]);
    }

if ($access{'logouttime'}) {
    # Show logout time
    print &ui_table_row($text{'edit_logout'},
        &ui_opt_textbox("logouttime", $user{'logouttime'}, 5,
                      $text{'default'})." ".$text{'edit_mins'});
    }

if ($access{'minsize'}) {
    # Show minimum password length, for just this user
    print &ui_table_row($text{'edit_minsize'},
        &ui_opt_textbox("minsize", $user{'minsize'}, 5,
                      $text{'default'})." ".$text{'edit_chars'});
    }

if ($access{'nochange'} && $miniserv{'pass_maxdays'}) {
    # Opt out of forced password change, for this user
    print &ui_table_row($text{'edit_nochange'},
        &ui_radio("nochange", $user{'nochange'},
            [ [ 0, $text{'yes'} ], [ 1, $text{'no'} ] ]));
    }

if ($access{'ips'}) {
    # Allowed IP addresses
    print &ui_table_row(&hlink("<b>$text{'edit_ips'}</b>", "ips"),
        &ui_radio("ipmode", $user{'allow'} ? 1 :
                    $user{'deny'} ? 2 : 0,
              [ [ 0, $text{'edit_all'}."<br>" ],
                [ 1, $text{'edit_allow'}."<br>" ],
                [ 2, $text{'edit_deny'}."<br>" ] ]).
        &ui_textarea("ips",
            join("\n", split(/\s+/, $user{'allow'} ||
                        $user{'deny'} || "")),
            4, 30));
    }

if (&supports_rbac() && $access{'mode'} == 0) {
    # Deny access to modules not managed by RBAC?
    print &ui_table_row($text{'edit_rbacdeny'},
        &ui_radio("rbacdeny", $user{'rbacdeny'} ? 1 : 0,
              [ [ 0, $text{'edit_rbacdeny0'} ],
                [ 1, $text{'edit_rbacdeny1'} ] ]));
    }

if ($access{'times'}) {
    # Show allowed days of the week
    my %days = map { $_, 1 } split(/,/, $user{'days'} || '');
    my $daysels = "";
    for(my $i=0; $i<7; $i++) {
        $daysels .= &ui_checkbox("days", $i, $text{'day_'.$i},
                     $days{$i});
        }
    print &ui_table_row($text{'edit_days'},
        &ui_radio("days_def", !defined($user{'days'}) || $user{'days'} eq '' ? 1 : 0,
              [ [ 1, $text{'edit_alldays'} ],
                [ 0, $text{'edit_seldays'} ] ])."<br>".
        $daysels);

    # Show allow hour/minute range
    my ($hf, $mf) = split(/\./, $user{'hoursfrom'} || '');
    my ($ht, $mt) = split(/\./, $user{'hoursto'} || '');
    print &ui_table_row($text{'edit_hours'},
        &ui_radio("hours_def", !defined($hf) || $hf eq '' ? 1 : 0,
            [ [ 1, $text{'edit_allhours'} ],
                [ 0, &text('edit_selhours',
                &ui_textbox("hours_hfrom", $hf, 2),
                &ui_textbox("hours_mfrom", $mf, 2),
                &ui_textbox("hours_hto", $ht, 2),
                &ui_textbox("hours_mto", $mt, 2)) ] ]));
    }

# Two-factor details
if ($user{'twofactor_provider'}) {
    my ($prov) = grep { $_->[0] eq $user{'twofactor_provider'} }
               &webmin::list_twofactor_providers();
    print &ui_table_row($text{'edit_twofactor'},
        &text('edit_twofactorprov', "<i>$prov->[1]</i>",
              "<tt>$user{'twofactor_id'}</tt>")."<br>\n".
        &ui_checkbox('cancel', 1, $text{'edit_twofactorcancel'}, 0));
    }
elsif ($miniserv{'twofactor_provider'}) {
    print &ui_table_row($text{'edit_twofactor'},
        $text{'edit_twofactornone'}." ".
        &ui_submit($text{'edit_twofactoradd'}, "twofactor"));
    }

print &ui_hidden_table_end("security");

# Work out which modules can be selected
@mcan = $access{'mode'} == 1 ? @{$me->{'modules'}} :
    $access{'mode'} == 2 ? split(/\s+/, $access{'mods'}) :
                   &list_modules();
my (%mcan, %has);
map { $mcan{$_}++ } @mcan;
map { $has{$_}++ } @{$user{'modules'}};

# Start of modules section
my @groups = &list_groups();
print &ui_hidden_table_start(@groups ? $text{'edit_modsg'} : $text{'edit_mods'},
                 "width=100%", 2, "mods");

# Show available modules, under categories
my @mlist = grep { $access{'others'} || $has{$_->{'dir'}} ||
           $mcan{$_->{'dir'}} } &list_module_infos();
my @links = ( &select_all_link("mod", 0, $text{'edit_selall'}),
          &select_invert_link("mod", 0, $text{'edit_invert'}) );
my @cats = &unique(map { $_->{'category'} || '' } @mlist);
my %catnames;
&read_file("$config_directory/webmin.catnames", \%catnames);
my $grids = "";
foreach my $c (sort { $b cmp $a } @cats) {
    my @cmlist = grep { ($_->{'category'} || '') eq $c } @mlist;
    $grids .= "<b>".($catnames{$c} ||
             $text{'category_'.$c} || '')."</b><br>\n";
    my @grid = ( );
    my $sw = 0;
    foreach my $m (@cmlist) {
        my $md = $m->{'dir'};
        my $fromgroup = $memg &&
                &indexof($md, @{$memg->{'modules'}}) >= 0;
        if ($mcan{$md} && $fromgroup) {
            # Module comes from group
            push(@grid, (sprintf "<img src=images/%s.gif> %s\n",
                                $has{$md} ? 'tick' : 'empty', $m->{'desc'}).
                ($has{$md} ? &ui_hidden("mod", $md) : ""));
            }
        elsif ($mcan{$md}) {
            my $label;
            if ($access{'acl'} && $in{'user'}) {
                # Show link for editing ACL
                $label = ui_link("edit_acl.cgi?" .
                     "mod=" . urlize($m->{'dir'}) .
                     "&user=". urlize($in{'user'}),
                     $m->{'desc'})  . "\n";
                }
            else {
                # No privileges to edit ACL
                $label = $m->{'desc'};
                }
            push(@grid, &ui_checkbox("mod", $md, $label,$has{$md}));
            }
        else {
            push(@grid, (sprintf "<img src=images/%s.gif> %s\n",
                $has{$md} ? 'tick' : 'empty', $m->{'desc'}));
            }
        }
    $grids .= &ui_grid_table(\@grid, 2, 100, [ "width=50%", "width=50%" ]);
    }

print &ui_table_row(undef, &ui_links_row(\@links).
                           $grids.
                           &ui_links_row(\@links), 2);
print &ui_hidden_table_end("mods");

# Add global ACL section, but only if not set from the group
my $groupglobal = $memg && -r "$config_directory/$memg->{'name'}.acl";
if ($access{'acl'} && !$groupglobal && $in{'user'}) {
    print &ui_hidden_table_start($text{'edit_global'}, "width=100%", 2,
                     "global", 0, [ "width=30%" ]);
    my %uaccess;
    %uaccess = &get_module_acl($in{'user'}, "", 1);
    print &ui_hidden("acl_security_form", 1);
    &foreign_require("", "acl_security.pl");
    &foreign_call("", "acl_security_form", \%uaccess);
    print &ui_hidden_table_end("global");
    }

# Generate form end buttons
my @buts = ( );
push(@buts, [ undef, $in{'user'} ? $text{'save'} : $text{'create'} ]);
if ($in{'user'}) {
    if ($access{'create'}) {
        push(@buts, [ "but_clone", $text{'edit_clone'} ]);
        }
    if (&foreign_available("webminlog")) {
        push(@buts, [ "but_log", $text{'edit_log'} ]);
        }
    if ($access{'switch'} && $main::session_id) {
        push(@buts, [ "but_switch", $text{'edit_switch'} ]);
        }
    if ($access{'delete'}) {
        push(@buts, [ "but_delete", $text{'delete'} ]);
        }
    }
print &ui_form_end(\@buts);

&ui_print_footer("", $text{'index_return'});


:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

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

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

--[ c99shell v. 1.0 pre-release build #16 powered by Captain Crunch Security Team | http://ccteam.ru | Generation time: 0.0041 ]--