vendor/symfony/src/Symfony/Bridge/Doctrine/Logger/DbalLogger.php
changeset 0 7f95f8617b0b
equal deleted inserted replaced
-1:000000000000 0:7f95f8617b0b
       
     1 <?php
       
     2 
       
     3 /*
       
     4  * This file is part of the Symfony package.
       
     5  *
       
     6  * (c) Fabien Potencier <fabien@symfony.com>
       
     7  *
       
     8  * For the full copyright and license information, please view the LICENSE
       
     9  * file that was distributed with this source code.
       
    10  */
       
    11 
       
    12 namespace Symfony\Bridge\Doctrine\Logger;
       
    13 
       
    14 use Symfony\Component\HttpKernel\Log\LoggerInterface;
       
    15 use Doctrine\DBAL\Logging\DebugStack;
       
    16 
       
    17 /**
       
    18  * DbalLogger.
       
    19  *
       
    20  * @author Fabien Potencier <fabien@symfony.com>
       
    21  */
       
    22 class DbalLogger extends DebugStack
       
    23 {
       
    24     protected $logger;
       
    25 
       
    26     /**
       
    27      * Constructor.
       
    28      *
       
    29      * @param LoggerInterface $logger A LoggerInterface instance
       
    30      */
       
    31     public function __construct(LoggerInterface $logger = null)
       
    32     {
       
    33         $this->logger = $logger;
       
    34     }
       
    35 
       
    36     /**
       
    37      * {@inheritdoc}
       
    38      */
       
    39     public function startQuery($sql, array $params = null, array $types = null)
       
    40     {
       
    41         parent::startQuery($sql, $params, $types);
       
    42 
       
    43         if (null !== $this->logger) {
       
    44             $this->log($sql.' ('.json_encode($params).')');
       
    45         }
       
    46     }
       
    47 
       
    48     /**
       
    49      * Logs a message.
       
    50      *
       
    51      * @param string $message A message to log
       
    52      */
       
    53     public function log($message)
       
    54     {
       
    55         $this->logger->debug($message);
       
    56     }
       
    57 }