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

TelemetryProcessor::__invoke()   A

Complexity

Conditions 3
Paths 4

Size

Total Lines 16
Code Lines 8

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 8
CRAP Score 3.0123

Importance

Changes 4
Bugs 0 Features 0
Metric Value
eloc 8
c 4
b 0
f 0
dl 0
loc 16
ccs 8
cts 9
cp 0.8889
rs 10
cc 3
nc 4
nop 1
crap 3.0123
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