Passed
Push — master ( 1bc903...93f74b )
by Rustam
02:00
created

LogTarget::__construct()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 4
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 3
CRAP Score 1

Importance

Changes 0
Metric Value
cc 1
eloc 2
nc 1
nop 2
dl 0
loc 4
ccs 3
cts 3
cp 1
crap 1
rs 10
c 0
b 0
f 0
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Yiisoft\Profiler\Target;
6
7
use Psr\Log\LoggerInterface;
8
use Psr\Log\LogLevel;
9
use Yiisoft\Profiler\Message;
10
11
/**
12
 * LogTarget saves profiling messages as a log messages.
13
 *
14
 * Application configuration example:
15
 *
16
 * ```php
17
 * return [
18
 *     'yiisoft/profiler' => [
19
 *         'targets' => [
20
 *             Yiisoft\Profiler\LogTarget::class,
21
 *         ],
22
 *         // ...
23
 *     ],
24
 *     // ...
25
 * ];
26
 * ```
27
 */
28
final class LogTarget extends AbstractTarget
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;
39
40 3
    public function __construct(LoggerInterface $logger, ?string $logLevel = LogLevel::DEBUG)
41
    {
42 3
        $this->logger = $logger;
43 3
        $this->logLevel = $logLevel;
44 3
    }
45
46
    /**
47
     * @param Message[] $messages
48
     */
49 2
    public function export(array $messages): void
50
    {
51 2
        foreach ($messages as $message) {
52 2
            $this->logger->log($this->logLevel, $message->message(), $message->context());
53
        }
54 2
    }
55
}
56