Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Doctrine2 support #3

Open
wants to merge 3 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 2 additions & 1 deletion library/ZFDebug/Controller/Plugin/Debug/Plugin/Database.php
Original file line number Diff line number Diff line change
Expand Up @@ -101,6 +101,7 @@ public function getTab()
if (!$this->_db)
return 'No adapter';

$adapterInfo = array();
foreach ($this->_db as $adapter) {
$profiler = $adapter->getProfiler();
$adapterInfo[] = $profiler->getTotalNumQueries() . ' in '
Expand Down Expand Up @@ -141,7 +142,7 @@ public function getProfile()
if ($profiles = $adapter->getProfiler()->getQueryProfiles()) {
$adapter->getProfiler()->setEnabled(false);
if (1 < count($this->_db)) {
$html .= '<h4>Adapter '.$name.'</h4>';
$queries .= '<h4>Adapter '.$name.'</h4>';
}
$queries .='<table cellspacing="0" cellpadding="0" width="100%">';
foreach ($profiles as $profile) {
Expand Down
163 changes: 163 additions & 0 deletions library/ZFDebug/Controller/Plugin/Debug/Plugin/Doctrine2.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,163 @@
<?php
/**
* ZFDebug Zend Additions
*
* @category ZFDebug
* @package ZFDebug_Controller
* @subpackage Plugins
* @copyright Copyright (c) 2008-2011 ZF Debug Bar Team (http://code.google.com/p/zfdebug)
* @license http://code.google.com/p/zfdebug/wiki/License New BSD License
* @version $Id$
*/

/**
* @category ZFDebug
* @package ZFDebug_Controller
* @subpackage Plugins
* @copyright Copyright (c) 2008-2011 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_Plugin_Doctrine2
extends ZFDebug_Controller_Plugin_Debug_Plugin
implements ZFDebug_Controller_Plugin_Debug_Plugin_Interface
{

/**
* Contains plugin identifier name
*
* @var string
*/
protected $_identifier = 'doctrine2';

/**
* Contains entityManagers
* @var array
*/
protected $_em = array();

/**
* Create ZFDebug_Controller_Plugin_Debug_Plugin_Variables
*
* @param array $options
* @return void
*/
public function __construct(array $options = array())
{
if (isset($options['entityManagers'])) {
$this->_em = $options['entityManagers'];
}
}

/**
* Gets icon
* @return string
*/
public function getIconData()
{
return '';
}

/**
* Gets identifier for this plugin
*
* @return string
*/
public function getIdentifier()
{
return $this->_identifier;
}

/**
* Gets menu tab for the Debugbar
*
* @return string
*/
public function getTab()
{
if (!$this->_em)
return 'No entitymanagers available';
$adapterInfo = array();

foreach ($this->_em as $em) {
if ($logger = $em->getConnection()->getConfiguration()->getSqlLogger()) {
$totalTime = 0;
foreach($logger->queries as $query) {
$totalTime += $query['executionMS'];
}
$adapterInfo[] = count($logger->queries) . ' in ' . round($totalTime * 1000, 2) . ' ms';
}
}
$html = implode(' / ', $adapterInfo);

return $html;
}

/**
* Gets content panel for the Debug bar
*
* @return string
*/
public function getPanel()
{
if (!$this->_em)
return '';

$html = '<h4>Doctrine2 queries - Doctrine2 (Common v' . Doctrine\Common\Version::VERSION .
' | DBAL v' . Doctrine\DBAL\Version::VERSION .
' | ORM v' . Doctrine\ORM\Version::VERSION .
')</h4>';

foreach ($this->_em as $name => $em) {
$html .= '<h4>EntityManager ' . $name . '</h4>';
if ($logger = $em->getConnection()->getConfiguration()->getSqlLogger()) {
$html .= $this->getProfile($logger);
} else {
$html .= "No logger enabled!";
}
}

return $html;
}

/**
* Gets sql queries from the logger
* @param $logger
* @return string
*/
protected function getProfile($logger)
{
$queries = '<table cellspacing="0" cellpadding="0" width="100%">';
foreach($logger->queries as $query) {

$queries .= "<tr>\n<td style='text-align:right;padding-right:2em;' nowrap>\n"
. sprintf('%0.2f', round($query['executionMS']*1000, 2))
. "ms</td>\n<td>";
$params = array();
if(!empty($query['params'])) {
$params = $query['params'];
array_walk($params, array($this, '_addQuotes'));
}
$paramCount = count($params);
if ($paramCount) {
$queries .= htmlspecialchars(preg_replace(array_fill(0, $paramCount, '/\?/'), $params, $query['sql'], 1));
} else {
$queries .= htmlspecialchars($query['sql']);
}
$queries .= "</td>\n</tr>\n";
}
$queries .= "</table>\n";
return $queries;
}

/**
* Add quotes to query params
* @param mixed $value
* @param mixed $key
* @return void
*/
protected function _addQuotes(&$value, $key)
{
$value = "'" . $value . "'";
}

}