178 lines
3.8 KiB
PHP
178 lines
3.8 KiB
PHP
<?php
|
|
|
|
/*
|
|
* This file is part of the Symfony package.
|
|
*
|
|
* (c) Fabien Potencier <fabien@symfony.com>
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
|
|
namespace Propel\Bundle\PropelBundle\Logger;
|
|
|
|
use Psr\Log\LoggerInterface;
|
|
use Symfony\Component\Stopwatch\Stopwatch;
|
|
|
|
/**
|
|
* PropelLogger.
|
|
*
|
|
* @author Fabien Potencier <fabien.potencier@symfony-project.com>
|
|
* @author William Durand <william.durand1@gmail.com>
|
|
*/
|
|
class PropelLogger implements \BasicLogger
|
|
{
|
|
/**
|
|
* @var LoggerInterface
|
|
*/
|
|
protected $logger;
|
|
|
|
/**
|
|
* @var array
|
|
*/
|
|
protected $queries = array();
|
|
|
|
/**
|
|
* @var Stopwatch
|
|
*/
|
|
protected $stopwatch;
|
|
|
|
/**
|
|
* @var bool
|
|
*/
|
|
private $isPrepared = false;
|
|
|
|
/**
|
|
* Constructor.
|
|
*
|
|
* @param LoggerInterface $logger A LoggerInterface instance
|
|
* @param Stopwatch $stopwatch A Stopwatch instance
|
|
*/
|
|
public function __construct(LoggerInterface $logger = null, Stopwatch $stopwatch = null)
|
|
{
|
|
$this->logger = $logger;
|
|
$this->stopwatch = $stopwatch;
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function alert($message)
|
|
{
|
|
$this->log($message, 'alert');
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function crit($message)
|
|
{
|
|
$this->log($message, 'crit');
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function err($message)
|
|
{
|
|
$this->log($message, 'err');
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function warning($message)
|
|
{
|
|
$this->log($message, 'warning');
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function notice($message)
|
|
{
|
|
$this->log($message, 'notice');
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function info($message)
|
|
{
|
|
$this->log($message, 'info');
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function debug($message)
|
|
{
|
|
$add = true;
|
|
|
|
if (null !== $this->stopwatch) {
|
|
$trace = debug_backtrace();
|
|
$method = $trace[2]['args'][2];
|
|
|
|
$watch = 'Propel Query '.(count($this->queries) + 1);
|
|
if ('PropelPDO::prepare' === $method) {
|
|
$this->isPrepared = true;
|
|
$this->stopwatch->start($watch, 'propel');
|
|
|
|
$add = false;
|
|
} elseif ($this->isPrepared) {
|
|
$this->isPrepared = false;
|
|
$this->stopwatch->stop($watch);
|
|
}
|
|
}
|
|
|
|
if ($add) {
|
|
$this->queries[] = $message;
|
|
$this->log($message, 'debug');
|
|
}
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function log($message, $severity = null)
|
|
{
|
|
if (null !== $this->logger) {
|
|
$message = is_string($message) ? $message : var_export($message, true);
|
|
|
|
switch ($severity) {
|
|
case 'alert':
|
|
$this->logger->alert($message);
|
|
break;
|
|
case 'crit':
|
|
$this->logger->critical($message);
|
|
break;
|
|
case 'err':
|
|
$this->logger->error($message);
|
|
break;
|
|
case 'warning':
|
|
$this->logger->warning($message);
|
|
break;
|
|
case 'notice':
|
|
$this->logger->notice($message);
|
|
break;
|
|
case 'info':
|
|
$this->logger->info($message);
|
|
break;
|
|
case 'debug':
|
|
default:
|
|
$this->logger->debug($message);
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns queries.
|
|
*
|
|
* @return array Queries
|
|
*/
|
|
public function getQueries()
|
|
{
|
|
return $this->queries;
|
|
}
|
|
}
|