summaryrefslogtreecommitdiff
path: root/vendor/doctrine/dbal/src/Logging/Connection.php
blob: 9c220dea19d36dc75fbe57772d0bef5a33acf0de (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
<?php

declare(strict_types=1);

namespace Doctrine\DBAL\Logging;

use Doctrine\DBAL\Driver\Connection as ConnectionInterface;
use Doctrine\DBAL\Driver\Middleware\AbstractConnectionMiddleware;
use Doctrine\DBAL\Driver\Result;
use Doctrine\DBAL\Driver\Statement as DriverStatement;
use Psr\Log\LoggerInterface;

final class Connection extends AbstractConnectionMiddleware
{
    /** @internal This connection can be only instantiated by its driver. */
    public function __construct(ConnectionInterface $connection, private readonly LoggerInterface $logger)
    {
        parent::__construct($connection);
    }

    public function __destruct()
    {
        $this->logger->info('Disconnecting');
    }

    public function prepare(string $sql): DriverStatement
    {
        return new Statement(
            parent::prepare($sql),
            $this->logger,
            $sql,
        );
    }

    public function query(string $sql): Result
    {
        $this->logger->debug('Executing query: {sql}', ['sql' => $sql]);

        return parent::query($sql);
    }

    public function exec(string $sql): int|string
    {
        $this->logger->debug('Executing statement: {sql}', ['sql' => $sql]);

        return parent::exec($sql);
    }

    public function beginTransaction(): void
    {
        $this->logger->debug('Beginning transaction');

        parent::beginTransaction();
    }

    public function commit(): void
    {
        $this->logger->debug('Committing transaction');

        parent::commit();
    }

    public function rollBack(): void
    {
        $this->logger->debug('Rolling back transaction');

        parent::rollBack();
    }
}