JournalHandler::__construct()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 2
CRAP Score 1

Importance

Changes 0
Metric Value
cc 1
eloc 1
c 0
b 0
f 0
nc 1
nop 1
dl 0
loc 3
ccs 2
cts 2
cp 1
crap 1
rs 10
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 Derafu\Lib\Core\Support\Store\Contract\JournalInterface;
29
use Monolog\Handler\AbstractProcessingHandler;
30
use Monolog\LogRecord as MonologLogRecord;
31
32
/**
33
 * Clase para manejar los mensajes de la bitácora.
34
 */
35
class JournalHandler extends AbstractProcessingHandler
36
{
37
    /**
38
     * Instancia del almacenamiento de los logs.
39
     *
40
     * @var JournalInterface
41
     */
42
    private JournalInterface $journal;
43
44
    /**
45
     * Constructor de la clase.
46
     */
47 38
    public function __construct(JournalInterface $journal)
48
    {
49 38
        $this->journal = $journal;
50
    }
51
52
    /**
53
     * Agrega un registro de la bitácora al almacenamiento.
54
     *
55
     * @param MonologLogRecord $logRecord
56
     */
57 38
    public function write(MonologLogRecord $logRecord): void
58
    {
59 38
        if (!($logRecord instanceof Log)) {
60
            $processor = new Processor();
61
            $logRecord = $processor($logRecord);
62
        }
63
64 38
        $this->journal->add($logRecord);
65
    }
66
}
67