485 lines
20 KiB
PHP
485 lines
20 KiB
PHP
<?php
|
|
/**
|
|
* ZFDebug Zend Additions
|
|
*
|
|
* @category ZFDebug
|
|
* @package ZFDebug_Controller
|
|
* @subpackage Plugins
|
|
* @copyright Copyright (c) 2008-2009 ZF Debug Bar Team (http://code.google.com/p/zfdebug)
|
|
* @license http://code.google.com/p/zfdebug/wiki/License New BSD License
|
|
* @version $Id$
|
|
*/
|
|
|
|
/**
|
|
* @see Zend_Controller_Exception
|
|
*/
|
|
require_once 'Zend/Controller/Exception.php';
|
|
|
|
/**
|
|
* @see Zend_Version
|
|
*/
|
|
require_once 'Zend/Version.php';
|
|
|
|
/**
|
|
* @see ZFDebug_Controller_Plugin_Debug_Plugin_Text
|
|
*/
|
|
require_once 'ZFDebug/Controller/Plugin/Debug/Plugin/Text.php';
|
|
|
|
/**
|
|
* @category ZFDebug
|
|
* @package ZFDebug_Controller
|
|
* @subpackage Plugins
|
|
* @copyright Copyright (c) 2008-2009 ZF Debug Bar Team (http://code.google.com/p/zfdebug)
|
|
* @license http://code.google.com/p/zfdebug/wiki/License New BSD License
|
|
*/
|
|
class ZFDebug_Controller_Plugin_Debug extends Zend_Controller_Plugin_Abstract
|
|
{
|
|
/**
|
|
* Contains registered plugins
|
|
*
|
|
* @var array
|
|
*/
|
|
protected $_plugins = array();
|
|
|
|
/**
|
|
* Contains options to change Debug Bar behavior
|
|
*/
|
|
protected $_options = array(
|
|
'plugins' => array(
|
|
'Variables' => null,
|
|
'Time' => null,
|
|
'Memory' => null),
|
|
'z-index' => 255,
|
|
'jquery_path' => 'http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js',
|
|
'image_path' => null
|
|
);
|
|
|
|
/**
|
|
* Standard plugins
|
|
*
|
|
* @var array
|
|
*/
|
|
public static $standardPlugins = array('Cache', 'Html', 'Database', 'Exception', 'File', 'Memory', 'Registry', 'Time', 'Variables');
|
|
|
|
/**
|
|
* Debug Bar Version Number
|
|
* for internal use only
|
|
*
|
|
* @var string
|
|
*/
|
|
protected $_version = '1.5.4';
|
|
|
|
/**
|
|
* 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('');
|
|
$this->registerPlugin($version);
|
|
|
|
/**
|
|
* Loading aready defined plugins
|
|
*/
|
|
$this->_loadPlugins();
|
|
}
|
|
|
|
/**
|
|
* Sets options of the Debug Bar
|
|
*
|
|
* @param array $options
|
|
* @return ZFDebug_Controller_Plugin_Debug
|
|
*/
|
|
public function setOptions(array $options = array())
|
|
{
|
|
if (isset($options['jquery_path'])) {
|
|
$this->_options['jquery_path'] = $options['jquery_path'];
|
|
}
|
|
|
|
if (isset($options['z-index'])) {
|
|
$this->_options['z-index'] = $options['z-index'];
|
|
}
|
|
|
|
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 = '';
|
|
|
|
/**
|
|
* Creating menu tab for all registered plugins
|
|
*/
|
|
foreach ($this->_plugins as $plugin)
|
|
{
|
|
$panel = $plugin->getPanel();
|
|
if ($panel == '') {
|
|
continue;
|
|
}
|
|
|
|
/* @var $plugin ZFDebug_Controller_Plugin_Debug_Plugin_Interface */
|
|
$html .= '<div id="ZFDebug_' . $plugin->getIdentifier()
|
|
. '" class="ZFDebug_panel">' . $panel . '</div>';
|
|
}
|
|
|
|
$html .= '<div id="ZFDebug_info">';
|
|
|
|
/**
|
|
* 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')) {
|
|
$plugin_icon = $this->_options['image_path'] .'/'. $plugin->getIdentifier() .'.png';
|
|
} else {
|
|
$plugin_icon = $plugin->getIconData();
|
|
}
|
|
|
|
/* @var $plugin ZFDebug_Controller_Plugin_Debug_Plugin_Interface */
|
|
$html .= '<span class="ZFDebug_span clickable" onclick="ZFDebugPanel(\'ZFDebug_' . $plugin->getIdentifier() . '\');">';
|
|
$html .= '<img src="' . $plugin_icon . '" style="vertical-align:middle" alt="' . $plugin->getIdentifier() . '" title="' . $plugin->getIdentifier() . '"'. $this->getClosingBracket() .' ';
|
|
$html .= $tab . '</span>';
|
|
}
|
|
|
|
$html .= '<span class="ZFDebug_span ZFDebug_last clickable" id="ZFDebug_toggler" onclick="ZFDebugSlideBar()">«</span>';
|
|
|
|
$html .= '</div>';
|
|
$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 ' ' . Zend_Version::VERSION . '/'.phpversion();
|
|
}
|
|
|
|
/**
|
|
* Returns version panel
|
|
*
|
|
* @return string
|
|
*/
|
|
protected function _getVersionPanel()
|
|
{
|
|
$panel = '<h4>ZFDebug v'.$this->_version.'</h4>' .
|
|
'<p>©2008-2009 <a href="http://jokke.dk">Joakim Nygård</a> & <a href="http://www.bangal.de">Andreas Pankratz</a></p>' .
|
|
'<p>The project is hosted at <a href="http://code.google.com/p/zfdebug/">http://zfdebug.googlecode.com</a> and released under the BSD License' . $this->getLinebreak() .
|
|
'Includes images from the <a href="http://www.famfamfam.com/lab/icons/silk/">Silk Icon set</a> by Mark James</p>'.
|
|
'<p>Disable ZFDebug temporarily by sending ZFDEBUG_DISABLE as a GET/POST parameter</p>';
|
|
// $panel .= '<h4>Zend Framework '.Zend_Version::VERSION.' / PHP '.phpversion().' with extensions:</h4>';
|
|
// $extensions = get_loaded_extensions();
|
|
// natcasesort($extensions);
|
|
// $panel .= implode('<br>', $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;
|
|
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'] : 0;
|
|
|
|
return ('
|
|
<style type="text/css" media="screen">
|
|
#ZFDebug_debug { font: 11px/1.4em Lucida Grande, Lucida Sans Unicode, sans-serif; position:fixed; bottom:5px; left:5px; color:#000; z-index: ' . $this->_options['z-index'] . ';}
|
|
#ZFDebug_debug ol {margin:10px 0px; padding:0 25px}
|
|
#ZFDebug_debug li {margin:0 0 10px 0;}
|
|
#ZFDebug_debug .clickable {cursor:pointer}
|
|
#ZFDebug_toggler { font-weight:bold; background:#BFBFBF; }
|
|
.ZFDebug_span { border: 1px solid #999; border-right:0px; background:#DFDFDF; padding: 5px 5px; }
|
|
.ZFDebug_last { border: 1px solid #999; }
|
|
.ZFDebug_panel { text-align:left; position:absolute;bottom:21px;width:800px; max-height:400px; overflow:auto; display:none; background:#E8E8E8; padding:5px; border: 1px solid #999; }
|
|
.ZFDebug_panel .pre {font: 11px/1.4em Monaco, Lucida Console, monospace; margin:0 0 0 22px}
|
|
#ZFDebug_exception { border:1px solid #CD0A0A;display: block; }
|
|
</style>
|
|
<script type="text/javascript">
|
|
if (typeof jQuery == "undefined") {
|
|
var scriptObj = document.createElement("script");
|
|
scriptObj.src = "'.$this->_options['jquery_path'].'";
|
|
scriptObj.type = "text/javascript";
|
|
var head=document.getElementsByTagName("head")[0];
|
|
head.insertBefore(scriptObj,head.firstChild);
|
|
jQuery.noConflict();
|
|
}
|
|
|
|
var ZFDebugLoad = window.onload;
|
|
window.onload = function(){
|
|
if (ZFDebugLoad) {
|
|
ZFDebugLoad();
|
|
}
|
|
ZFDebugCollapsed();
|
|
};
|
|
|
|
function ZFDebugCollapsed() {
|
|
if ('.$collapsed.' == 1) {
|
|
ZFDebugPanel();
|
|
jQuery("#ZFDebug_toggler").html("»");
|
|
return jQuery("#ZFDebug_debug").css("left", "-"+parseInt(jQuery("#ZFDebug_debug").outerWidth()-jQuery("#ZFDebug_toggler").outerWidth()+1)+"px");
|
|
}
|
|
}
|
|
|
|
function ZFDebugPanel(name) {
|
|
jQuery(".ZFDebug_panel").each(function(i){
|
|
if(jQuery(this).css("display") == "block") {
|
|
jQuery(this).slideUp();
|
|
} else {
|
|
if (jQuery(this).attr("id") == name)
|
|
jQuery(this).slideDown();
|
|
else
|
|
jQuery(this).slideUp();
|
|
}
|
|
});
|
|
}
|
|
|
|
function ZFDebugSlideBar() {
|
|
if (jQuery("#ZFDebug_debug").position().left > 0) {
|
|
document.cookie = "ZFDebugCollapsed=1;expires=;path=/";
|
|
ZFDebugPanel();
|
|
jQuery("#ZFDebug_toggler").html("»");
|
|
return jQuery("#ZFDebug_debug").animate({left:"-"+parseInt(jQuery("#ZFDebug_debug").outerWidth()-jQuery("#ZFDebug_toggler").outerWidth()+1)+"px"}, "normal", "swing");
|
|
} else {
|
|
document.cookie = "ZFDebugCollapsed=0;expires=;path=/";
|
|
jQuery("#ZFDebug_toggler").html("«");
|
|
return jQuery("#ZFDebug_debug").animate({left:"5px"}, "normal", "swing");
|
|
}
|
|
}
|
|
|
|
function ZFDebugToggleElement(name, whenHidden, whenVisible){
|
|
if(jQuery(name).css("display")=="none"){
|
|
jQuery(whenVisible).show();
|
|
jQuery(whenHidden).hide();
|
|
} else {
|
|
jQuery(whenVisible).hide();
|
|
jQuery(whenHidden).show();
|
|
}
|
|
jQuery(name).slideToggle();
|
|
}
|
|
</script>');
|
|
}
|
|
|
|
/**
|
|
* Appends Debug Bar html output to the original page
|
|
*
|
|
* @param string $html
|
|
* @return void
|
|
*/
|
|
protected function _output($html)
|
|
{
|
|
$response = $this->getResponse();
|
|
$response->setBody(preg_replace('/(<\/head>)/i', $this->_headerOutput() . '$1', $response->getBody()));
|
|
$response->setBody(str_ireplace('</body>', '<div id="ZFDebug_debug">'.$html.'</div></body>', $response->getBody()));
|
|
}
|
|
|
|
public function getLinebreak()
|
|
{
|
|
return '<br'.$this->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;
|
|
}
|
|
} |