![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/mautic.corals.io/vendor/symfony/doctrine-bridge/Middleware/Debug/DBAL3/ |
<?php /* * This file is part of the Symfony package. * * (c) Fabien Potencier <[email protected]> * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Bridge\Doctrine\Middleware\Debug\DBAL3; use Doctrine\DBAL\Driver\Connection as ConnectionInterface; use Doctrine\DBAL\Driver\Middleware\AbstractConnectionMiddleware; use Doctrine\DBAL\Driver\Result; use Doctrine\DBAL\Driver\Statement as StatementInterface; use Symfony\Bridge\Doctrine\Middleware\Debug\DebugDataHolder; use Symfony\Bridge\Doctrine\Middleware\Debug\Query; use Symfony\Component\Stopwatch\Stopwatch; /** * @author Laurent VOULLEMIER <[email protected]> * * @internal */ final class Connection extends AbstractConnectionMiddleware { /** @var int */ private $nestingLevel = 0; private $debugDataHolder; private $stopwatch; private $connectionName; public function __construct( ConnectionInterface $connection, DebugDataHolder $debugDataHolder, ?Stopwatch $stopwatch, string $connectionName ) { $this->connectionName = $connectionName; $this->stopwatch = $stopwatch; $this->debugDataHolder = $debugDataHolder; parent::__construct($connection); } public function prepare(string $sql): StatementInterface { return new Statement( parent::prepare($sql), $this->debugDataHolder, $this->connectionName, $sql, $this->stopwatch, ); } public function query(string $sql): Result { $this->debugDataHolder->addQuery($this->connectionName, $query = new Query($sql)); if ($this->stopwatch) { $this->stopwatch->start('doctrine', 'doctrine'); } $query->start(); try { return parent::query($sql); } finally { $query->stop(); if ($this->stopwatch) { $this->stopwatch->stop('doctrine'); } } } public function exec(string $sql): int { $this->debugDataHolder->addQuery($this->connectionName, $query = new Query($sql)); if ($this->stopwatch) { $this->stopwatch->start('doctrine', 'doctrine'); } $query->start(); try { return parent::exec($sql); } finally { $query->stop(); if ($this->stopwatch) { $this->stopwatch->stop('doctrine'); } } } public function beginTransaction(): bool { $query = null; if (1 === ++$this->nestingLevel) { $this->debugDataHolder->addQuery($this->connectionName, $query = new Query('"START TRANSACTION"')); } if ($this->stopwatch) { $this->stopwatch->start('doctrine', 'doctrine'); } if ($query) { $query->start(); } try { return parent::beginTransaction(); } finally { if ($query) { $query->stop(); } if ($this->stopwatch) { $this->stopwatch->stop('doctrine'); } } } public function commit(): bool { $query = null; if (1 === $this->nestingLevel--) { $this->debugDataHolder->addQuery($this->connectionName, $query = new Query('"COMMIT"')); } if ($this->stopwatch) { $this->stopwatch->start('doctrine', 'doctrine'); } if ($query) { $query->start(); } try { return parent::commit(); } finally { if ($query) { $query->stop(); } if ($this->stopwatch) { $this->stopwatch->stop('doctrine'); } } } public function rollBack(): bool { $query = null; if (1 === $this->nestingLevel--) { $this->debugDataHolder->addQuery($this->connectionName, $query = new Query('"ROLLBACK"')); } if ($this->stopwatch) { $this->stopwatch->start('doctrine', 'doctrine'); } if ($query) { $query->start(); } try { return parent::rollBack(); } finally { if ($query) { $query->stop(); } if ($this->stopwatch) { $this->stopwatch->stop('doctrine'); } } } }