* * 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\Middleware\AbstractStatementMiddleware; use Doctrine\DBAL\Driver\Result as ResultInterface; use Doctrine\DBAL\Driver\Statement as StatementInterface; use Doctrine\DBAL\ParameterType; use Symfony\Bridge\Doctrine\Middleware\Debug\DebugDataHolder; use Symfony\Bridge\Doctrine\Middleware\Debug\Query; use Symfony\Component\Stopwatch\Stopwatch; /** * @author Laurent VOULLEMIER * * @internal */ final class Statement extends AbstractStatementMiddleware { private readonly Query $query; public function __construct( StatementInterface $statement, private readonly DebugDataHolder $debugDataHolder, private readonly string $connectionName, string $sql, private readonly ?Stopwatch $stopwatch = null, ) { $this->query = new Query($sql); parent::__construct($statement); } public function bindParam($param, &$variable, $type = ParameterType::STRING, $length = null): bool { $this->query->setParam($param, $variable, $type); return parent::bindParam($param, $variable, $type, ...\array_slice(\func_get_args(), 3)); } public function bindValue($param, $value, $type = ParameterType::STRING): bool { $this->query->setValue($param, $value, $type); return parent::bindValue($param, $value, $type); } public function execute($params = null): ResultInterface { if (null !== $params) { $this->query->setValues($params); } // clone to prevent variables by reference to change $this->debugDataHolder->addQuery($this->connectionName, $query = clone $this->query); $this->stopwatch?->start('doctrine', 'doctrine'); $query->start(); try { return parent::execute($params); } finally { $query->stop(); $this->stopwatch?->stop('doctrine'); } } }