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

DevLogger   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 20
Duplicated Lines 0 %

Coupling/Cohesion

Components 0
Dependencies 3

Importance

Changes 0
Metric Value
wmc 3
lcom 0
cbo 3
dl 0
loc 20
rs 10
c 0
b 0
f 0

2 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 4 1
A __invoke() 0 7 2
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