DevLogger   A
last analyzed

Complexity

Total Complexity 3

Size/Duplication

Total Lines 14
Duplicated Lines 0 %

Importance

Changes 0
Metric Value
eloc 5
dl 0
loc 14
rs 10
c 0
b 0
f 0
wmc 3

2 Methods

Rating   Name   Duplication   Size   Complexity  
A __invoke() 0 7 2
A __construct() 0 3 1
1
<?php
2
3
declare(strict_types=1);
4
5
namespace BEAR\Resource;
6
7
use Override;
8
use Psr\Log\LoggerInterface as PsrLoggerInterface;
9
use Psr\Log\LogLevel;
10
11
use function in_array;
12
use function sprintf;
13
14
final class DevLogger implements LoggerInterface
15
{
16
    public function __construct(
17
        private readonly PsrLoggerInterface $logger,
18
    ) {
19
    }
20
21
    #[Override]
22
    public function __invoke(ResourceObject $ro): void
23
    {
24
        $unsafeMethod = ['post', 'put', 'patch', 'delete'];
25
        $level = in_array($ro->uri->method, $unsafeMethod, true) ? LogLevel::INFO : LogLevel::DEBUG;
26
        $this->logger->log($level, sprintf('request: %s %s', $ro->uri->method, (string) $ro->uri));
27
        $this->logger->log($level, sprintf('response: %s %s', $ro->code, (string) $ro));
28
    }
29
}
30