RendererWorker::render()   A
last analyzed

Complexity

Conditions 2
Paths 2

Size

Total Lines 17
Code Lines 10

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 5
CRAP Score 2.5

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 2
eloc 10
c 1
b 0
f 0
nc 2
nop 2
dl 0
loc 17
ccs 5
cts 10
cp 0.5
crap 2.5
rs 9.9332
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\Template\Worker;
26
27
use Derafu\Lib\Core\Foundation\Abstract\AbstractWorker;
28
use Derafu\Lib\Core\Package\Prime\Component\Template\Contract\RendererStrategyInterface;
29
use Derafu\Lib\Core\Package\Prime\Component\Template\Contract\RendererWorkerInterface;
30
use Derafu\Lib\Core\Package\Prime\Component\Template\Exception\TemplateException;
31
use Throwable;
32
33
/**
34
 * Worker de renderización de plantillas.
35
 *
36
 * Permite renderizar plantillas utilizando estrategias según el formato.
37
 * Por ejemplo puede renderizar HTML mediante Twig o un PDF usando HTML.
38
 */
39
class RendererWorker extends AbstractWorker implements RendererWorkerInterface
40
{
41
    /**
42
     * Formato por defecto que se debe utilizar.
43
     *
44
     * @var string
45
     */
46
    private string $defaultFormat = 'html';
47
48
    /**
49
     * {@inheritDoc}
50
     */
51 2
    public function render(string $template, array $data = []): string
52
    {
53
        // Formato en el que se renderizará la plantilla.
54 2
        $format = $data['options']['format'] ?? $this->defaultFormat;
55
56
        // Buscar estrategia según el formato.
57 2
        $strategy = $this->getStrategy($format);
58 2
        assert($strategy instanceof RendererStrategyInterface);
59
60
        // Renderizar utilizando la estrategia.
61
        try {
62 2
            return $strategy->render($template, $data);
63
        } catch (Throwable $e) {
64
            throw new TemplateException(sprintf(
65
                'Ocurrió un problema al renderizar la plantilla %s: %s',
66
                $template,
67
                $e->getMessage()
68
            ));
69
        }
70
    }
71
}
72