Passed
Pull Request — master (#19)
by Rustam
02:40
created

LogTarget   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 25
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 2
Bugs 1 Features 0
Metric Value
eloc 7
dl 0
loc 25
ccs 7
cts 7
cp 1
rs 10
c 2
b 1
f 0
wmc 3

2 Methods

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