array( 'Variables' => null, 'Time' => null, 'Memory' => null), 'image_path' => null ); /** * Standard plugins * * @var array */ public static $standardPlugins = array( 'Cache', 'Html', 'Database', 'Exception', 'File', 'Memory', 'Registry', 'Time', 'Variables', 'Log' ); /** * Debug Bar Version Number * for internal use only * * @var string */ protected $_version = '1.6'; /** * Creates a new instance of the Debug Bar * * @param array|Zend_Config $options * @throws Zend_Controller_Exception * @return void */ protected $_closingBracket = null; public function __construct($options = null) { if (isset($options)) { if ($options instanceof Zend_Config) { $options = $options->toArray(); } /* * Verify that adapter parameters are in an array. */ if (!is_array($options)) { throw new Zend_Exception('Debug parameters must be in an array or a Zend_Config object'); } $this->setOptions($options); } /** * Creating ZF Version Tab always shown */ $version = new ZFDebug_Controller_Plugin_Debug_Plugin_Text(); $version->setPanel($this->_getVersionPanel()) ->setTab($this->_getVersionTab()) ->setIdentifier('copyright') ->setIconData(''); // ->setIconData(''); $this->registerPlugin($version); /** * Creating the log tab */ $logger = new ZFDebug_Controller_Plugin_Debug_Plugin_Log(); $this->registerPlugin($logger); $logger->mark('Startup - ZFDebug construct()', true); /** * Loading already defined plugins */ $this->_loadPlugins(); } /** * Get the ZFDebug logger * * @return Zend_Log */ public function getLogger() { return $this->getPlugin('Log')->logger(); } /** * Sets options of the Debug Bar * * @param array $options * @return ZFDebug_Controller_Plugin_Debug */ public function setOptions(array $options = array()) { if (isset($options['image_path'])) { $this->_options['image_path'] = $options['image_path']; } if (isset($options['plugins'])) { $this->_options['plugins'] = $options['plugins']; } return $this; } /** * Register a new plugin in the Debug Bar * * @param ZFDebug_Controller_Plugin_Debug_Plugin_Interface * @return ZFDebug_Controller_Plugin_Debug */ public function registerPlugin(ZFDebug_Controller_Plugin_Debug_Plugin_Interface $plugin) { $this->_plugins[$plugin->getIdentifier()] = $plugin; return $this; } /** * Unregister a plugin in the Debug Bar * * @param string $plugin * @return ZFDebug_Controller_Plugin_Debug */ public function unregisterPlugin($plugin) { if (false !== strpos($plugin, '_')) { foreach ($this->_plugins as $key => $_plugin) { if ($plugin == get_class($_plugin)) { unset($this->_plugins[$key]); } } } else { $plugin = strtolower($plugin); if (isset($this->_plugins[$plugin])) { unset($this->_plugins[$plugin]); } } return $this; } /** * Get a registered plugin in the Debug Bar * * @param string $identifier * @return ZFDebug_Controller_Plugin_Debug_Plugin_Interface */ public function getPlugin($identifier) { $identifier = strtolower($identifier); if (isset($this->_plugins[$identifier])) { return $this->_plugins[$identifier]; } return false; } /** * Defined by Zend_Controller_Plugin_Abstract */ public function dispatchLoopShutdown() { if ($this->getRequest()->isXmlHttpRequest()) { return; } $disable = Zend_Controller_Front::getInstance()->getRequest()->getParam('ZFDEBUG_DISABLE'); if (isset($disable)) { return; } $html = ''; $html .= "
\n"; $html .= "\t   \n"; /** * Creating panel content for all registered plugins */ foreach ($this->_plugins as $plugin) { $tab = $plugin->getTab(); if ($tab == '') { continue; } if (null !== $this->_options['image_path'] && file_exists($this->_options['image_path'] .'/'. $plugin->getIdentifier() .'.png')) { $pluginIcon = $this->_options['image_path'] .'/'. $plugin->getIdentifier() .'.png'; } else { $pluginIcon = $plugin->getIconData(); } /* @var $plugin ZFDebug_Controller_Plugin_Debug_Plugin_Interface */ $showPanel = ($plugin->getPanel() == '') ? 'log' : $plugin->getIdentifier(); $html .= "\t".'' . "\n"; if ($pluginIcon) { $html .= "\t\t".'' 
                       . $plugin->getIdentifier() . ' ' . "\n"; } $html .= $tab . "\n"; } $html .= '' . "\n" . round(memory_get_peak_usage()/1024) . 'K in ' . round((microtime(true)-$_SERVER['REQUEST_TIME'])*1000) . 'ms' . '' . "\n"; $html .= "
\n"; $html .= '
'; /** * Creating menu tab for all registered plugins */ $this->getPlugin('log')->mark('Shutdown', true); foreach ($this->_plugins as $plugin) { $panel = $plugin->getPanel(); if ($panel == '') { continue; } /* @var $plugin ZFDebug_Controller_Plugin_Debug_Plugin_Interface */ $html .= "\n" . '
' . "\n" . $panel . "\n
\n"; } $this->_output($html); } ### INTERNAL METHODS BELOW ### /** * Load plugins set in config option * * @return void; */ protected function _loadPlugins() { foreach ($this->_options['plugins'] as $plugin => $options) { if (is_numeric($plugin)) { # Plugin passed as array value instead of key $plugin = $options; $options = array(); } // Register an instance if (is_object($plugin) && in_array('ZFDebug_Controller_Plugin_Debug_Plugin_Interface', class_implements($plugin))) { $this->registerPlugin($plugin); continue; } if (!is_string($plugin)) { throw new Exception("Invalid plugin name", 1); } $plugin = ucfirst($plugin); // Register a classname if (in_array($plugin, ZFDebug_Controller_Plugin_Debug::$standardPlugins)) { // standard plugin $pluginClass = 'ZFDebug_Controller_Plugin_Debug_Plugin_' . $plugin; } else { // we use a custom plugin if (!preg_match('~^[\w]+$~D', $plugin)) { throw new Zend_Exception("ZFDebug: Invalid plugin name [$plugin]"); } $pluginClass = $plugin; } require_once str_replace('_', DIRECTORY_SEPARATOR, $pluginClass) . '.php'; $object = new $pluginClass($options); $this->registerPlugin($object); } } /** * Return version tab * * @return string */ protected function _getVersionTab() { return 'ZFDebug'; // return ' ' . Zend_Version::VERSION . '/'.phpversion(); } /** * Returns version panel * * @return string */ protected function _getVersionPanel() { $panel = "

ZFDebug $this->_version – Zend Framework " . Zend_Version::VERSION . " on PHP " . phpversion() . "

\n" . "

©2008-2009 Joakim Nygård" . $this->getLinebreak() . "with contributions by Andreas Pankratz and others

" . "

The project is hosted at http://zfdebug.googlecode.com" . " and released under the BSD License" . $this->getLinebreak() . "Includes images from the Silk Icon set by Mark James

" . "

Disable ZFDebug temporarily by sending ZFDEBUG_DISABLE as a GET/POST parameter

"; // $panel .= '

Zend Framework '.Zend_Version::VERSION.' / PHP '.phpversion().' with extensions:

'; // $extensions = get_loaded_extensions(); // natcasesort($extensions); // $panel .= implode('
', $extensions); return $panel; } /** * Returns path to the specific icon * * @return string */ protected function _icon($kind) { switch ($kind) { case 'database': if (null === $this->_options['image_path']) return ''; return $this->_options['image_path'] . '/database.png'; break; case 'exception': if (null === $this->_options['image_path']) return ''; return $this->_options['image_path'] . '/exception.png'; break; case 'error': if (null === $this->_options['image_path']) return ''; return $this->_options['image_path'] . '/error.png'; break; case 'close': return ''; break; default: if (null === $this->_options['image_path']) return ''; return $this->_options['image_path'] . '/unknown.png'; break; } } /** * Returns html header for the Debug Bar * * @return string */ protected function _headerOutput() { $collapsed = isset($_COOKIE['ZFDebugCollapsed']) ? $_COOKIE['ZFDebugCollapsed'] : ''; if ($collapsed) { $boxheight = isset($_COOKIE['ZFDebugHeight']) ? $_COOKIE['ZFDebugHeight'] : '240'; } else { $boxheight = '32'; } return (' '); } /** * Appends Debug Bar html output to the original page * * @param string $html * @return void */ protected function _output($html) { $html = "
\n
\n$html\n
\n"; $response = $this->getResponse(); // $response->setBody(preg_replace('/(<\/head>)/i', $this->_headerOutput() . '$1', $response->getBody())); $response->setBody(str_ireplace('', $this->_headerOutput() . $html, $response->getBody())); } public function getLinebreak() { return 'getClosingBracket(); } public function getClosingBracket() { if (!$this->_closingBracket) { if ($this->_isXhtml()) { $this->_closingBracket = ' />'; } else { $this->_closingBracket = '>'; } } return $this->_closingBracket; } protected function _isXhtml() { if ($view = Zend_Controller_Action_HelperBroker::getStaticHelper('viewRenderer')->view) { $doctype = $view->doctype(); return $doctype->isXhtml(); } return false; } }