Passed
Push — master ( dcb61c...e80a85 )
by butschster
05:46 queued 18s
created

TelemetryProcessor::__construct()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 0

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 1
CRAP Score 1

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 0
dl 0
loc 3
rs 10
c 1
b 0
f 0
ccs 1
cts 1
cp 1
cc 1
nc 1
nop 1
crap 1
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Spiral\Telemetry\Monolog;
6
7
use Monolog\LogRecord;
8
use Monolog\Processor\ProcessorInterface;
9
use Psr\Container\ContainerInterface;
10
use Spiral\Telemetry\TracerInterface;
11
12
final class TelemetryProcessor implements ProcessorInterface
13
{
14 2
    public function __construct(
15
        private readonly ContainerInterface $container
16
    ) {
17 2
    }
18
19 2
    public function __invoke(LogRecord|array $record): array
20
    {
21 2
        if ($record instanceof LogRecord) {
0 ignored issues
show
introduced by
$record is never a sub-type of Monolog\LogRecord.
Loading history...
22
            $record = $record->toArray();
23
        }
24
25 2
        $tracer = $this->container->get(TracerInterface::class);
26 2
        \assert($tracer instanceof TracerInterface);
27
28 2
        $context = $tracer->getContext();
29
30 2
        if (!empty($context)) {
31 1
            $record['extra']['telemetry'] = $context;
32
        }
33
34 2
        return $record;
35
    }
36
}
37