Passed
Pull Request — master (#2)
by Wilmer
02:40
created

LogTarget   A

Complexity

Total Complexity 4

Size/Duplication

Total Lines 35
Duplicated Lines 0 %

Test Coverage

Coverage 77.78%

Importance

Changes 2
Bugs 1 Features 0
Metric Value
wmc 4
eloc 9
c 2
b 1
f 0
dl 0
loc 35
ccs 7
cts 9
cp 0.7778
rs 10

3 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 4 1
A export() 0 6 2
A getLogLevel() 0 3 1
1
<?php
2
declare(strict_types=1);
3
4
namespace Yiisoft\Profiler;
5
6
use Psr\Log\LogLevel;
7
use Psr\Log\LoggerInterface;
8
9
/**
10
 * LogTarget saves profiling messages as a log messages.
11
 *
12
 * Application configuration example:
13
 *
14
 * ```php
15
 * return [
16
 *     Yiisoft\Profiler\Profiler::class => [
17
 *         'targets' => [
18
 *             [
19
 *                 '__class' => Yiisoft\Profiler\LogTarget::class,
20
 *             ],
21
 *         ],
22
 *         // ...
23
 *     ],
24
 *     // ...
25
 * ];
26
 * ```
27
 */
28
class LogTarget extends Target
29
{
30
    /**
31
     * @var LoggerInterface logger to be used for message export.
32
     */
33
    private LoggerInterface $logger;
34
35
    /**
36
     * @var string log level to be used for messages export.
37
     */
38
    private ?string $logLevel = null;
39
40 1
    public function __construct(LoggerInterface $logger, ?string $logLevel = LogLevel::DEBUG)
41
    {
42 1
        $this->logger = $logger;
43 1
        $this->logLevel = $logLevel;
44
    }
45
46 1
    public function export(array $messages): void
47
    {
48 1
        foreach ($messages as $message) {
49 1
            $message['time'] = $message['beginTime'];
50
51 1
            $this->logger->log($this->logLevel, $message['token'], $message);
52
        }
53
    }
54
55
    /**
56
     * @return ?string logLevel
57
     *
58
     * {@see logLevel}
59
     */
60
    public function getLogLevel(): ?string
61
    {
62
        return $this->logLevel;
63
    }
64
}
65