Processor::__invoke()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 24
Code Lines 14

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 16
CRAP Score 1

Importance

Changes 0
Metric Value
cc 1
eloc 14
c 0
b 0
f 0
nc 1
nop 1
dl 0
loc 24
ccs 16
cts 16
cp 1
crap 1
rs 9.7998
1
<?php
2
3
declare(strict_types=1);
4
5
/**
6
 * Derafu: Biblioteca PHP (Núcleo).
7
 * Copyright (C) Derafu <https://www.derafu.org>
8
 *
9
 * Este programa es software libre: usted puede redistribuirlo y/o modificarlo
10
 * bajo los términos de la Licencia Pública General Affero de GNU publicada por
11
 * la Fundación para el Software Libre, ya sea la versión 3 de la Licencia, o
12
 * (a su elección) cualquier versión posterior de la misma.
13
 *
14
 * Este programa se distribuye con la esperanza de que sea útil, pero SIN
15
 * GARANTÍA ALGUNA; ni siquiera la garantía implícita MERCANTIL o de APTITUD
16
 * PARA UN PROPÓSITO DETERMINADO. Consulte los detalles de la Licencia Pública
17
 * General Affero de GNU para obtener una información más detallada.
18
 *
19
 * Debería haber recibido una copia de la Licencia Pública General Affero de GNU
20
 * junto a este programa.
21
 *
22
 * En caso contrario, consulte <http://www.gnu.org/licenses/agpl.html>.
23
 */
24
25
namespace Derafu\Lib\Core\Package\Prime\Component\Log\Worker;
26
27
use Derafu\Lib\Core\Package\Prime\Component\Log\Entity\Log;
28
use Monolog\LogRecord as MonologLogRecord;
29
30
/**
31
 * Procesador del registro de la bitácora.
32
 */
33
class Processor
34
{
35
    /**
36
     * Procesador del registro de la bitácora.
37
     *
38
     * @param MonologLogRecord $logRecord Registro original de monolog.
39
     * @return Log Registro convertido de la biblioteca.
40
     */
41 38
    public function __invoke(MonologLogRecord $logRecord): Log
42
    {
43
        // Extraer caller si existe.
44 38
        $context = $logRecord->context;
45 38
        $caller = $context['__caller'] ?? null;
46 38
        unset($context['__caller']);
47
48
        // Crear instancia de LogRecord.
49 38
        $log = new Log(
50 38
            datetime: $logRecord->datetime,
51 38
            channel: $logRecord->channel,
52 38
            level: $logRecord->level,
53 38
            message: $logRecord->message,
54 38
            context: $context,
55 38
            extra: $logRecord->extra,
56 38
            formatted: $logRecord->formatted
57 38
        );
58
59
        // Asignar datos adicionales del registro de la bitácora.
60 38
        $log->code = $context['code'] ?? $logRecord->level->value;
61 38
        $log->caller = $caller;
62
63
        // Entregar el registro de la bitácora personalizado.
64 38
        return $log;
65
    }
66
}
67