Completed
Push — log-level ( 45be4f...1ddb1b )
by Akihito
03:47
created

DevLogger::__construct()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 4

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 4
rs 10
c 0
b 0
f 0
cc 1
nc 1
nop 1
1
<?php
2
3
declare(strict_types=1);
4
5
namespace BEAR\Resource;
6
7
use Psr\Log\LoggerInterface as PsrLoggerInterface;
8
use Psr\Log\LogLevel;
9
use function sprintf;
10
11
final class DevLogger implements LoggerInterface
12
{
13
    /**
14
     * @var PsrLoggerInterface
15
     */
16
    private $logger;
17
18
    public function __construct(PsrLoggerInterface $logger)
19
    {
20
        $this->logger = $logger;
21
    }
22
23
    public function __invoke(ResourceObject $ro) : void
24
    {
25
        $unsafeMethod = ['post', 'put', 'patch', 'delete'];
26
        $level = in_array($ro->uri->method, $unsafeMethod, true) ? LogLevel::INFO : LogLevel::DEBUG;
27
        $this->logger->log($level, sprintf('request: %s %s', $ro->uri->method, (string) $ro->uri));
28
        $this->logger->log($level, sprintf('response: %s %s', $ro->code, (string) $ro));
29
    }
30
}
31