1 | <?php |
||
2 | |||
3 | declare(strict_types=1); |
||
4 | |||
5 | namespace WyriHaximus\Monolog\FormattedPsrHandler; |
||
6 | |||
7 | use Monolog\Handler\AbstractProcessingHandler; |
||
8 | use Monolog\Level; |
||
9 | use Monolog\LogRecord; |
||
10 | use Psr\Log\LoggerInterface; |
||
11 | |||
12 | use function strtolower; |
||
13 | 2 | use function WyriHaximus\PSR3\formatValue; |
|
14 | |||
15 | 2 | final class FormattedPsrHandler extends AbstractProcessingHandler |
|
16 | { |
||
17 | 2 | /** @phpstan-ignore-next-line */ |
|
18 | 2 | public function __construct(protected LoggerInterface $logger, int|string|Level $level = Level::Debug, bool $bubble = true) |
|
19 | { |
||
20 | /** @psalm-suppress ArgumentTypeCoercion */ |
||
21 | parent::__construct($level, $bubble); |
||
22 | } |
||
23 | 2 | ||
24 | protected function write(LogRecord $record): void |
||
25 | 2 | { |
|
26 | /** @psalm-suppress InvalidArgument */ |
||
27 | if (! $this->isHandling($record)) { |
||
28 | // @codeCoverageIgnoreStart |
||
29 | 2 | return; // This is tested in FormattedPsrHandlerTest::notHandled but not picked up by PHPUnit as covered |
|
30 | 2 | ||
31 | 2 | // @codeCoverageIgnoreEnd |
|
32 | 2 | } |
|
33 | |||
34 | 2 | $this->logger->log( |
|
35 | strtolower($record->level->name), |
||
0 ignored issues
–
show
Bug
introduced
by
Loading history...
|
|||
36 | formatValue($record->formatted ?? $record->message), |
||
37 | $record->context, |
||
38 | ); |
||
39 | } |
||
40 | } |
||
41 |