!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)

/var/www/html/mis/system/database/drivers/mysql/   drwxr-xr-x
Free 50.9 GB of 127.8 GB (39.82%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     mysql_forge.php (6.26 KB)      -rwxr-xr-x
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php  if ( ! defined('BASEPATH')) exit('No direct script access allowed');
/**
 * CodeIgniter
 *
 * An open source application development framework for PHP 5.1.6 or newer
 *
 * @package        CodeIgniter
 * @author        ExpressionEngine Dev Team
 * @copyright    Copyright (c) 2008 - 2011, EllisLab, Inc.
 * @license        http://codeigniter.com/user_guide/license.html
 * @link        http://codeigniter.com
 * @since        Version 1.0
 * @filesource
 */

// ------------------------------------------------------------------------

/**
 * MySQL Forge Class
 *
 * @category    Database
 * @author        ExpressionEngine Dev Team
 * @link        http://codeigniter.com/user_guide/database/
 */
class CI_DB_mysql_forge extends CI_DB_forge {

    
/**
     * Create database
     *
     * @access    private
     * @param    string    the database name
     * @return    bool
     */
    
function _create_database($name)
    {
        return 
"CREATE DATABASE ".$name;
    }

    
// --------------------------------------------------------------------

    /**
     * Drop database
     *
     * @access    private
     * @param    string    the database name
     * @return    bool
     */
    
function _drop_database($name)
    {
        return 
"DROP DATABASE ".$name;
    }

    
// --------------------------------------------------------------------

    /**
     * Process Fields
     *
     * @access    private
     * @param    mixed    the fields
     * @return    string
     */
    
function _process_fields($fields)
    {
        
$current_field_count 0;
        
$sql '';

        foreach (
$fields as $field=>$attributes)
        {
            
// Numeric field names aren't allowed in databases, so if the key is
            // numeric, we know it was assigned by PHP and the developer manually
            // entered the field information, so we'll simply add it to the list
            
if (is_numeric($field))
            {
                
$sql .= "\n\t$attributes";
            }
            else
            {
                
$attributes array_change_key_case($attributesCASE_UPPER);

                
$sql .= "\n\t".$this->db->_protect_identifiers($field);

                if (
array_key_exists('NAME'$attributes))
                {
                    
$sql .= ' '.$this->db->_protect_identifiers($attributes['NAME']).' ';
                }

                if (
array_key_exists('TYPE'$attributes))
                {
                    
$sql .=  ' '.$attributes['TYPE'];

                    if (
array_key_exists('CONSTRAINT'$attributes))
                    {
                        switch (
$attributes['TYPE'])
                        {
                            case 
'decimal':
                            case 
'float':
                            case 
'numeric':
                                
$sql .= '('.implode(','$attributes['CONSTRAINT']).')';
                            break;

                            case 
'enum':
                            case 
'set':
                                
$sql .= '("'.implode('","'$attributes['CONSTRAINT']).'")';
                            break;

                            default:
                                
$sql .= '('.$attributes['CONSTRAINT'].')';
                        }
                    }
                }

                if (
array_key_exists('UNSIGNED'$attributes) && $attributes['UNSIGNED'] === TRUE)
                {
                    
$sql .= ' UNSIGNED';
                }

                if (
array_key_exists('DEFAULT'$attributes))
                {
                    
$sql .= ' DEFAULT \''.$attributes['DEFAULT'].'\'';
                }

                if (
array_key_exists('NULL'$attributes))
                {
                    
$sql .= ($attributes['NULL'] === TRUE) ? ' NULL' ' NOT NULL';
                }

                if (
array_key_exists('AUTO_INCREMENT'$attributes) && $attributes['AUTO_INCREMENT'] === TRUE)
                {
                    
$sql .= ' AUTO_INCREMENT';
                }
            }

            
// don't add a comma on the end of the last field
            
if (++$current_field_count count($fields))
            {
                
$sql .= ',';
            }
        }

        return 
$sql;
    }

    
// --------------------------------------------------------------------

    /**
     * Create Table
     *
     * @access    private
     * @param    string    the table name
     * @param    mixed    the fields
     * @param    mixed    primary key(s)
     * @param    mixed    key(s)
     * @param    boolean    should 'IF NOT EXISTS' be added to the SQL
     * @return    bool
     */
    
function _create_table($table$fields$primary_keys$keys$if_not_exists)
    {
        
$sql 'CREATE TABLE ';

        if (
$if_not_exists === TRUE)
        {
            
$sql .= 'IF NOT EXISTS ';
        }

        
$sql .= $this->db->_escape_identifiers($table)." (";

        
$sql .= $this->_process_fields($fields);

        if (
count($primary_keys) > 0)
        {
            
$key_name $this->db->_protect_identifiers(implode('_'$primary_keys));
            
$primary_keys $this->db->_protect_identifiers($primary_keys);
            
$sql .= ",\n\tPRIMARY KEY ".$key_name." (" implode(', '$primary_keys) . ")";
        }

        if (
is_array($keys) && count($keys) > 0)
        {
            foreach (
$keys as $key)
            {
                if (
is_array($key))
                {
                    
$key_name $this->db->_protect_identifiers(implode('_'$key));
                    
$key $this->db->_protect_identifiers($key);
                }
                else
                {
                    
$key_name $this->db->_protect_identifiers($key);
                    
$key = array($key_name);
                }

                
$sql .= ",\n\tKEY {$key_name} (" implode(', '$key) . ")";
            }
        }

        
$sql .= "\n) DEFAULT CHARACTER SET {$this->db->char_set} COLLATE {$this->db->dbcollat};";

        return 
$sql;
    }

    
// --------------------------------------------------------------------

    /**
     * Drop Table
     *
     * @access    private
     * @return    string
     */
    
function _drop_table($table)
    {
        return 
"DROP TABLE IF EXISTS ".$this->db->_escape_identifiers($table);
    }

    
// --------------------------------------------------------------------

    /**
     * Alter table query
     *
     * Generates a platform-specific query so that a table can be altered
     * Called by add_column(), drop_column(), and column_alter(),
     *
     * @access    private
     * @param    string    the ALTER type (ADD, DROP, CHANGE)
     * @param    string    the column name
     * @param    array    fields
     * @param    string    the field after which we should add the new field
     * @return    object
     */
    
function _alter_table($alter_type$table$fields$after_field '')
    {
        
$sql 'ALTER TABLE '.$this->db->_protect_identifiers($table)." $alter_type ";

        
// DROP has everything it needs now.
        
if ($alter_type == 'DROP')
        {
            return 
$sql.$this->db->_protect_identifiers($fields);
        }

        
$sql .= $this->_process_fields($fields);

        if (
$after_field != '')
        {
            
$sql .= ' AFTER ' $this->db->_protect_identifiers($after_field);
        }

        return 
$sql;
    }

    
// --------------------------------------------------------------------

    /**
     * Rename a table
     *
     * Generates a platform-specific query so that a table can be renamed
     *
     * @access    private
     * @param    string    the old table name
     * @param    string    the new table name
     * @return    string
     */
    
function _rename_table($table_name$new_table_name)
    {
        
$sql 'ALTER TABLE '.$this->db->_protect_identifiers($table_name)." RENAME TO ".$this->db->_protect_identifiers($new_table_name);
        return 
$sql;
    }

}

/* End of file mysql_forge.php */
/* Location: ./system/database/drivers/mysql/mysql_forge.php */

:: 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 ::
 
[ ok ]

:: Make Dir ::
 
[ ok ]
:: Make File ::
 
[ ok ]

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