2011-08-05 12:52:03 +00:00

571 lines
24 KiB
PHP
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<?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: Debug.php 153 2010-07-05 19:52:11Z gugakfugl $
*/
/**
* @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),
'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 .= "<div id='ZFDebug_info'>\n";
$html .= "\t<span class='ZFDebug_span' style='padding-right:0px;' onclick='ZFDebugPanel(ZFDebugCurrent);'>
<img style='vertical-align:middle;' src='".$this->_icon('close')."'>&nbsp;
</span>\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".'<span id="ZFDebugInfo_'.$plugin->getIdentifier()
. '" class="ZFDebug_span clickable" onclick="ZFDebugPanel(\'ZFDebug_'
. $showPanel . '\');">' . "\n";
if ($pluginIcon) {
$html .= "\t\t".'<img src="' . $pluginIcon . '" style="vertical-align:middle" alt="'
. $plugin->getIdentifier() . '" title="'
. $plugin->getIdentifier() . '"> ' . "\n";
}
$html .= $tab . "</span>\n";
}
$html .= '<span id="ZFDebugInfo_Request" class="ZFDebug_span">'
. "\n"
. round(memory_get_peak_usage()/1024) . 'K in '
. round((microtime(true)-$_SERVER['REQUEST_TIME'])*1000) . 'ms'
. '</span>' . "\n";
$html .= "</div>\n";
$html .= '<div id="ZFDebugResize"></div>';
/**
* 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" . '<div id="ZFDebug_' . $plugin->getIdentifier()
. '" class="ZFDebug_panel" name="ZFDebug_panel">' . "\n" . $panel . "\n</div>\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 '<strong>ZFDebug</strong>';
// return ' ' . Zend_Version::VERSION . '/'.phpversion();
}
/**
* Returns version panel
*
* @return string
*/
protected function _getVersionPanel()
{
$panel = "<h4>ZFDebug $this->_version Zend Framework "
. Zend_Version::VERSION . " on PHP " . phpversion() . "</h4>\n"
. "<p>©2008-2009 <a href='http://jokke.dk'>Joakim Nygård</a>" . $this->getLinebreak()
. "with contributions by <a href='http://www.bangal.de'>Andreas Pankratz</a> and others</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;
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 ('
<style type="text/css" media="screen">
html,body {height:100%}
#ZFDebug, #ZFDebug div, #ZFDebug span, #ZFDebug h1, #ZFDebug h2, #ZFDebug h3, #ZFDebug h4, #ZFDebug h5, #ZFDebug h6, #ZFDebug p, #ZFDebug blockquote, #ZFDebug pre, #ZFDebug a, #ZFDebug code, #ZFDebug em, #ZFDebug img, #ZFDebug strong, #ZFDebug dl, #ZFDebug dt, #ZFDebug dd, #ZFDebug ol, #ZFDebug ul, #ZFDebug li, #ZFDebug table, #ZFDebug tbody, #ZFDebug tfoot, #ZFDebug thead, #ZFDebug tr, #ZFDebug th, #ZFDebug td {
margin: 0;
padding: 0;
border: 0;
outline: 0;
font-size: 100%;
vertical-align: baseline;
background: transparent;
}
#ZFDebug_offset {height:'.$boxheight.'px}
#ZFDebug {height:'.$boxheight.'px; width:100%; background:#262626;
font: 12px/1.4em Lucida Grande, Lucida Sans Unicode, sans-serif;
position:fixed; bottom:0px; left:0px; color:#FFF; background:#000000;
z-index:2718281828459045;}
#ZFDebug p {margin:1em 0}
#ZFDebug a {color:#FFFFFF}
#ZFDebug tr {color:#FFFFFF;}
#ZFDebug td {vertical-align:top; padding-bottom:1em}
#ZFDebug ol {margin:1em 0 0 0; padding:0; list-style-position: inside;}
#ZFDebug li {margin:0;}
#ZFDebug .clickable {cursor:pointer}
#ZFDebug #ZFDebug_info {display:block; height:32px;
background:url() }
#ZFDebug #ZFDebugResize {cursor:row-resize; height:1px; border-top:1px solid #1a1a1a;border-bottom:1px solid #333333; }
#ZFDebug .ZFDebug_span {padding:0 15px; line-height:32px; display:block; float:left}
#ZFDebug .ZFDebug_panel {padding:0px 15px 15px 15px;
font: 11px/1.4em Menlo, Monaco, Lucida Console, monospace;
text-align:left; height:'.($boxheight-50).'px; overflow:auto; display:none; }
#ZFDebug h4 {font:bold 12px/1.4em Menlo, Monaco, Lucida Console, monospace; margin:1em 0;}
#ZFDebug .ZFDebug_active {background:#1a1a1a;}
#ZFDebug .ZFDebug_panel .pre {margin:0 0 0 22px}
#ZFDebug_exception { border:1px solid #CD0A0A;display: block; }
</style>
<script type="text/javascript">
var ZFDebugLoad = window.onload;
window.onload = function(){
if (ZFDebugLoad) {
ZFDebugLoad();
}
if ("'.$collapsed.'" != "") {
ZFDebugPanel("' . $collapsed . '");
}
window.zfdebugHeight = "'.(isset($_COOKIE['ZFDebugHeight']) ? $_COOKIE['ZFDebugHeight'] : '240').'";
document.onmousemove = function(e) {
var event = e || window.event;
window.zfdebugMouse = Math.max(40, Math.min(window.innerHeight, -1*(event.clientY-window.innerHeight-32)));
}
var ZFDebugResizeTimer = null;
document.getElementById("ZFDebugResize").onmousedown=function(e){
ZFDebugResize();
ZFDebugResizeTimer = setInterval("ZFDebugResize()",50);
return false;
}
document.onmouseup=function(e){
clearTimeout(ZFDebugResizeTimer);
}
};
function ZFDebugResize()
{
window.zfdebugHeight = window.zfdebugMouse;
document.cookie = "ZFDebugHeight="+window.zfdebugHeight+";expires=;path=/";
document.getElementById("ZFDebug").style.height = window.zfdebugHeight+"px";
document.getElementById("ZFDebug_offset").style.height = window.zfdebugHeight+"px";
var panels = document.getElementById("ZFDebug").children;
for (var i=0; i < document.getElementById("ZFDebug").childElementCount; i++) {
if (panels[i].className.indexOf("ZFDebug_panel") == -1)
continue;
panels[i].style.height = window.zfdebugHeight-50+"px";
}
}
var ZFDebugCurrent = null;
function ZFDebugPanel(name) {
if (ZFDebugCurrent == name) {
document.getElementById("ZFDebug").style.height = "32px";
document.getElementById("ZFDebug_offset").style.height = "32px";
ZFDebugCurrent = null;
document.cookie = "ZFDebugCollapsed=;expires=;path=/";
} else {
document.getElementById("ZFDebug").style.height = window.zfdebugHeight+"px";
document.getElementById("ZFDebug_offset").style.height = window.zfdebugHeight+"px";
ZFDebugCurrent = name;
document.cookie = "ZFDebugCollapsed="+name+";expires=;path=/";
}
var panels = document.getElementById("ZFDebug").children;
for (var i=0; i < document.getElementById("ZFDebug").childElementCount; i++) {
if (panels[i].className.indexOf("ZFDebug_panel") == -1)
continue;
if (ZFDebugCurrent && panels[i].id == name) {
document.getElementById("ZFDebugInfo_"+name.substring(8)).className += " ZFDebug_active";
panels[i].style.display = "block";
panels[i].style.height = (window.zfdebugHeight-50)+"px";
} else {
var element = document.getElementById("ZFDebugInfo_"+panels[i].id.substring(8));
element.className = element.className.replace("ZFDebug_active", "");
panels[i].style.display = "none";
}
}
}
</script>
');
}
/**
* Appends Debug Bar html output to the original page
*
* @param string $html
* @return void
*/
protected function _output($html)
{
$html = "<div id='ZFDebug_offset'></div>\n<div id='ZFDebug'>\n$html\n</div>\n</body>";
$response = $this->getResponse();
// $response->setBody(preg_replace('/(<\/head>)/i', $this->_headerOutput() . '$1', $response->getBody()));
$response->setBody(str_ireplace('</body>', $this->_headerOutput() . $html, $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;
}
}