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

E:\xampp\xampp\php\PEAR\Zend\Loader\   drwxrwxrwx
Free 780.09 MB of 239.26 GB (0.32%)
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:     PluginLoader.php (14.49 KB)      -rw-rw-rw-
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
/**
 * Zend Framework
 *
 * LICENSE
 *
 * This source file is subject to the new BSD license that is bundled
 * with this package in the file LICENSE.txt.
 * It is also available through the world-wide-web at this URL:
 * http://framework.zend.com/license/new-bsd
 * If you did not receive a copy of the license and are unable to
 * obtain it through the world-wide-web, please send an email
 * to license@zend.com so we can send you a copy immediately.
 *
 * @category   Zend
 * @package    Zend_Loader
 * @subpackage PluginLoader
 * @copyright  Copyright (c) 2005-2009 Zend Technologies USA Inc. (http://www.zend.com)
 * @license    http://framework.zend.com/license/new-bsd     New BSD License
 * @version    $Id: PluginLoader.php 18951 2009-11-12 16:26:19Z alexander $
 */

/** Zend_Loader_PluginLoader_Interface */
require_once 'Zend/Loader/PluginLoader/Interface.php';

/** Zend_Loader */
require_once 'Zend/Loader.php';

/**
 * Generic plugin class loader
 *
 * @category   Zend
 * @package    Zend_Loader
 * @subpackage PluginLoader
 * @copyright  Copyright (c) 2005-2009 Zend Technologies USA Inc. (http://www.zend.com)
 * @license    http://framework.zend.com/license/new-bsd     New BSD License
 */
class Zend_Loader_PluginLoader implements Zend_Loader_PluginLoader_Interface
{
    
/**
     * Class map cache file
     * @var string
     */
    
protected static $_includeFileCache;

    
/**
     * Instance loaded plugin paths
     *
     * @var array
     */
    
protected $_loadedPluginPaths = array();

    
/**
     * Instance loaded plugins
     *
     * @var array
     */
    
protected $_loadedPlugins = array();

    
/**
     * Instance registry property
     *
     * @var array
     */
    
protected $_prefixToPaths = array();

    
/**
     * Statically loaded plugin path mappings
     *
     * @var array
     */
    
protected static $_staticLoadedPluginPaths = array();

    
/**
     * Statically loaded plugins
     *
     * @var array
     */
    
protected static $_staticLoadedPlugins = array();

    
/**
     * Static registry property
     *
     * @var array
     */
    
protected static $_staticPrefixToPaths = array();

    
/**
     * Whether to use a statically named registry for loading plugins
     *
     * @var string|null
     */
    
protected $_useStaticRegistry null;

    
/**
     * Constructor
     *
     * @param array $prefixToPaths
     * @param string $staticRegistryName OPTIONAL
     */
    
public function __construct(Array $prefixToPaths = array(), $staticRegistryName null)
    {
        if (
is_string($staticRegistryName) && !empty($staticRegistryName)) {
            
$this->_useStaticRegistry $staticRegistryName;
            if(!isset(
self::$_staticPrefixToPaths[$staticRegistryName])) {
                
self::$_staticPrefixToPaths[$staticRegistryName] = array();
            }
            if(!isset(
self::$_staticLoadedPlugins[$staticRegistryName])) {
                
self::$_staticLoadedPlugins[$staticRegistryName] = array();
            }
        }

        foreach (
$prefixToPaths as $prefix => $path) {
            
$this->addPrefixPath($prefix$path);
        }
    }

    
/**
     * Format prefix for internal use
     *
     * @param  string $prefix
     * @return string
     */
    
protected function _formatPrefix($prefix)
    {
        if(
$prefix == "") {
            return 
$prefix;
        }
        return 
rtrim($prefix'_') . '_';
    }

    
/**
     * Add prefixed paths to the registry of paths
     *
     * @param string $prefix
     * @param string $path
     * @return Zend_Loader_PluginLoader
     */
    
public function addPrefixPath($prefix$path)
    {
        if (!
is_string($prefix) || !is_string($path)) {
            require_once 
'Zend/Loader/PluginLoader/Exception.php';
            throw new 
Zend_Loader_PluginLoader_Exception('Zend_Loader_PluginLoader::addPrefixPath() method only takes strings for prefix and path.');
        }

        
$prefix $this->_formatPrefix($prefix);
        
$path   rtrim($path'/\\') . '/';

        if (
$this->_useStaticRegistry) {
            
self::$_staticPrefixToPaths[$this->_useStaticRegistry][$prefix][] = $path;
        } else {
            if (!isset(
$this->_prefixToPaths[$prefix])) {
                
$this->_prefixToPaths[$prefix] = array();
            }
            if (!
in_array($path$this->_prefixToPaths[$prefix])) {
                
$this->_prefixToPaths[$prefix][] = $path;
            }
        }
        return 
$this;
    }

    
/**
     * Get path stack
     *
     * @param  string $prefix
     * @return false|array False if prefix does not exist, array otherwise
     */
    
public function getPaths($prefix null)
    {
        if ((
null !== $prefix) && is_string($prefix)) {
            
$prefix $this->_formatPrefix($prefix);
            if (
$this->_useStaticRegistry) {
                if (isset(
self::$_staticPrefixToPaths[$this->_useStaticRegistry][$prefix])) {
                    return 
self::$_staticPrefixToPaths[$this->_useStaticRegistry][$prefix];
                }

                return 
false;
            }

            if (isset(
$this->_prefixToPaths[$prefix])) {
                return 
$this->_prefixToPaths[$prefix];
            }

            return 
false;
        }

        if (
$this->_useStaticRegistry) {
            return 
self::$_staticPrefixToPaths[$this->_useStaticRegistry];
        }

        return 
$this->_prefixToPaths;
    }

    
/**
     * Clear path stack
     *
     * @param  string $prefix
     * @return bool False only if $prefix does not exist
     */
    
public function clearPaths($prefix null)
    {
        if ((
null !== $prefix) && is_string($prefix)) {
            
$prefix $this->_formatPrefix($prefix);
            if (
$this->_useStaticRegistry) {
                if (isset(
self::$_staticPrefixToPaths[$this->_useStaticRegistry][$prefix])) {
                    unset(
self::$_staticPrefixToPaths[$this->_useStaticRegistry][$prefix]);
                    return 
true;
                }

                return 
false;
            }

            if (isset(
$this->_prefixToPaths[$prefix])) {
                unset(
$this->_prefixToPaths[$prefix]);
                return 
true;
            }

            return 
false;
        }

        if (
$this->_useStaticRegistry) {
            
self::$_staticPrefixToPaths[$this->_useStaticRegistry] = array();
        } else {
            
$this->_prefixToPaths = array();
        }

        return 
true;
    }

    
/**
     * Remove a prefix (or prefixed-path) from the registry
     *
     * @param string $prefix
     * @param string $path OPTIONAL
     * @return Zend_Loader_PluginLoader
     */
    
public function removePrefixPath($prefix$path null)
    {
        
$prefix $this->_formatPrefix($prefix);
        if (
$this->_useStaticRegistry) {
            
$registry =& self::$_staticPrefixToPaths[$this->_useStaticRegistry];
        } else {
            
$registry =& $this->_prefixToPaths;
        }

        if (!isset(
$registry[$prefix])) {
            require_once 
'Zend/Loader/PluginLoader/Exception.php';
            throw new 
Zend_Loader_PluginLoader_Exception('Prefix ' $prefix ' was not found in the PluginLoader.');
        }

        if (
$path != null) {
            
$pos array_search($path$registry[$prefix]);
            if (
$pos === null) {
                require_once 
'Zend/Loader/PluginLoader/Exception.php';
                throw new 
Zend_Loader_PluginLoader_Exception('Prefix ' $prefix ' / Path ' $path ' was not found in the PluginLoader.');
            }
            unset(
$registry[$prefix][$pos]);
        } else {
            unset(
$registry[$prefix]);
        }

        return 
$this;
    }

    
/**
     * Normalize plugin name
     *
     * @param  string $name
     * @return string
     */
    
protected function _formatName($name)
    {
        return 
ucfirst((string) $name);
    }

    
/**
     * Whether or not a Plugin by a specific name is loaded
     *
     * @param string $name
     * @return Zend_Loader_PluginLoader
     */
    
public function isLoaded($name)
    {
        
$name $this->_formatName($name);
        if (
$this->_useStaticRegistry) {
            return isset(
self::$_staticLoadedPlugins[$this->_useStaticRegistry][$name]);
        }

        return isset(
$this->_loadedPlugins[$name]);
    }

    
/**
     * Return full class name for a named plugin
     *
     * @param string $name
     * @return string|false False if class not found, class name otherwise
     */
    
public function getClassName($name)
    {
        
$name $this->_formatName($name);
        if (
$this->_useStaticRegistry
            
&& isset(self::$_staticLoadedPlugins[$this->_useStaticRegistry][$name])
        ) {
            return 
self::$_staticLoadedPlugins[$this->_useStaticRegistry][$name];
        } elseif (isset(
$this->_loadedPlugins[$name])) {
            return 
$this->_loadedPlugins[$name];
        }

        return 
false;
    }

    
/**
     * Get path to plugin class
     *
     * @param  mixed $name
     * @return string|false False if not found
     */
    
public function getClassPath($name)
    {
        
$name $this->_formatName($name);
        if (
$this->_useStaticRegistry
            
&& !empty(self::$_staticLoadedPluginPaths[$this->_useStaticRegistry][$name])
        ) {
            return 
self::$_staticLoadedPluginPaths[$this->_useStaticRegistry][$name];
        } elseif (!empty(
$this->_loadedPluginPaths[$name])) {
            return 
$this->_loadedPluginPaths[$name];
        }

        if (
$this->isLoaded($name)) {
            
$class $this->getClassName($name);
            
$r     = new ReflectionClass($class);
            
$path  $r->getFileName();
            if (
$this->_useStaticRegistry) {
                
self::$_staticLoadedPluginPaths[$this->_useStaticRegistry][$name] = $path;
            } else {
                
$this->_loadedPluginPaths[$name] = $path;
            }
            return 
$path;
        }

        return 
false;
    }

    
/**
     * Load a plugin via the name provided
     *
     * @param  string $name
     * @param  bool $throwExceptions Whether or not to throw exceptions if the
     * class is not resolved
     * @return string|false Class name of loaded class; false if $throwExceptions
     * if false and no class found
     * @throws Zend_Loader_Exception if class not found
     */
    
public function load($name$throwExceptions true)
    {
        
$name $this->_formatName($name);
        if (
$this->isLoaded($name)) {
            return 
$this->getClassName($name);
        }

        if (
$this->_useStaticRegistry) {
            
$registry self::$_staticPrefixToPaths[$this->_useStaticRegistry];
        } else {
            
$registry $this->_prefixToPaths;
        }

        
$registry  array_reverse($registrytrue);
        
$found     false;
        
$classFile str_replace('_'DIRECTORY_SEPARATOR$name) . '.php';
        
$incFile   self::getIncludeFileCache();
        foreach (
$registry as $prefix => $paths) {
            
$className $prefix $name;

            if (
class_exists($classNamefalse)) {
                
$found true;
                break;
            }

            
$paths     array_reverse($pathstrue);

            foreach (
$paths as $path) {
                
$loadFile $path $classFile;
                if (
Zend_Loader::isReadable($loadFile)) {
                    include_once 
$loadFile;
                    if (
class_exists($classNamefalse)) {
                        if (
null !== $incFile) {
                            
self::_appendIncFile($loadFile);
                        }
                        
$found true;
                        break 
2;
                    }
                }
            }
        }

        if (!
$found) {
            if (!
$throwExceptions) {
                return 
false;
            }

            
$message "Plugin by name '$name' was not found in the registry; used paths:";
            foreach (
$registry as $prefix => $paths) {
                
$message .= "\n$prefix: " implode(PATH_SEPARATOR$paths);
            }
            require_once 
'Zend/Loader/PluginLoader/Exception.php';
            throw new 
Zend_Loader_PluginLoader_Exception($message);
       }

        if (
$this->_useStaticRegistry) {
            
self::$_staticLoadedPlugins[$this->_useStaticRegistry][$name]     = $className;
            
self::$_staticLoadedPluginPaths[$this->_useStaticRegistry][$name] = (isset($loadFile) ? $loadFile '');
        } else {
            
$this->_loadedPlugins[$name]     = $className;
            
$this->_loadedPluginPaths[$name] = (isset($loadFile) ? $loadFile '');
        }
        return 
$className;
    }

    
/**
     * Set path to class file cache
     *
     * Specify a path to a file that will add include_once statements for each
     * plugin class loaded. This is an opt-in feature for performance purposes.
     *
     * @param  string $file
     * @return void
     * @throws Zend_Loader_PluginLoader_Exception if file is not writeable or path does not exist
     */
    
public static function setIncludeFileCache($file)
    {
        if (
null === $file) {
            
self::$_includeFileCache null;
            return;
        }

        if (!
file_exists($file) && !file_exists(dirname($file))) {
            require_once 
'Zend/Loader/PluginLoader/Exception.php';
            throw new 
Zend_Loader_PluginLoader_Exception('Specified file does not exist and/or directory does not exist (' $file ')');
        }
        if (
file_exists($file) && !is_writable($file)) {
            require_once 
'Zend/Loader/PluginLoader/Exception.php';
            throw new 
Zend_Loader_PluginLoader_Exception('Specified file is not writeable (' $file ')');
        }
        if (!
file_exists($file) && file_exists(dirname($file)) && !is_writable(dirname($file))) {
            require_once 
'Zend/Loader/PluginLoader/Exception.php';
            throw new 
Zend_Loader_PluginLoader_Exception('Specified file is not writeable (' $file ')');
        }

        
self::$_includeFileCache $file;
    }

    
/**
     * Retrieve class file cache path
     *
     * @return string|null
     */
    
public static function getIncludeFileCache()
    {
        return 
self::$_includeFileCache;
    }

    
/**
     * Append an include_once statement to the class file cache
     *
     * @param  string $incFile
     * @return void
     */
    
protected static function _appendIncFile($incFile)
    {
        if (!
file_exists(self::$_includeFileCache)) {
            
$file '<?php';
        } else {
            
$file file_get_contents(self::$_includeFileCache);
        }
        if (!
strstr($file$incFile)) {
            
$file .= "\ninclude_once '$incFile';";
            
file_put_contents(self::$_includeFileCache$file);
        }
    }
}

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