diff --git a/library/ZFDebug/Controller/Plugin/Debug/Plugin/Database.php b/library/ZFDebug/Controller/Plugin/Debug/Plugin/Database.php index 5ad1e86..8b8bf01 100644 --- a/library/ZFDebug/Controller/Plugin/Debug/Plugin/Database.php +++ b/library/ZFDebug/Controller/Plugin/Debug/Plugin/Database.php @@ -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 ' @@ -141,7 +142,7 @@ public function getProfile() if ($profiles = $adapter->getProfiler()->getQueryProfiles()) { $adapter->getProfiler()->setEnabled(false); if (1 < count($this->_db)) { - $html .= '

Adapter '.$name.'

'; + $queries .= '

Adapter '.$name.'

'; } $queries .=''; foreach ($profiles as $profile) { diff --git a/library/ZFDebug/Controller/Plugin/Debug/Plugin/Doctrine2.php b/library/ZFDebug/Controller/Plugin/Debug/Plugin/Doctrine2.php new file mode 100644 index 0000000..ecf1321 --- /dev/null +++ b/library/ZFDebug/Controller/Plugin/Debug/Plugin/Doctrine2.php @@ -0,0 +1,163 @@ +_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 = '

Doctrine2 queries - Doctrine2 (Common v' . Doctrine\Common\Version::VERSION . + ' | DBAL v' . Doctrine\DBAL\Version::VERSION . + ' | ORM v' . Doctrine\ORM\Version::VERSION . + ')

'; + + foreach ($this->_em as $name => $em) { + $html .= '

EntityManager ' . $name . '

'; + 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 = '
'; + foreach($logger->queries as $query) { + + $queries .= "\n\n\n\n"; + } + $queries .= "
\n" + . sprintf('%0.2f', round($query['executionMS']*1000, 2)) + . "ms"; + $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 .= "
\n"; + return $queries; + } + + /** + * Add quotes to query params + * @param mixed $value + * @param mixed $key + * @return void + */ + protected function _addQuotes(&$value, $key) + { + $value = "'" . $value . "'"; + } + +} \ No newline at end of file