Test Failed
Push — master ( e6f4b5...c3cccf )
by
unknown
15:56
created

TokenManager::getToken()   A

Complexity

Conditions 2
Paths 2

Size

Total Lines 20
Code Lines 6

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 6

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 2
eloc 6
c 1
b 0
f 0
nc 2
nop 1
dl 0
loc 20
ccs 0
cts 7
cp 0
crap 6
rs 10
1
<?php
2
3
declare(strict_types=1);
4
5
/**
6
 * LibreDTE: Biblioteca PHP (Núcleo).
7
 * Copyright (C) LibreDTE <https://www.libredte.cl>
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
20
 * GNU junto a este programa.
21
 *
22
 * En caso contrario, consulte <http://www.gnu.org/licenses/agpl.html>.
23
 */
24
25
namespace libredte\lib\Core\Sii\HttpClient;
26
27
use libredte\lib\Core\Signature\Certificate;
28
use Psr\SimpleCache\CacheInterface;
29
30
/**
31
 * Clase para gestionar las solicitudes de token para autenticación al SII.
32
 */
33
class TokenManager
34
{
35
    /**
36
     * Tiempo en segundos que el token es válido desde que se solicitó.
37
     *
38
     * @var int
39
     */
40
    private const TOKEN_TTL = 60;
41
42
    /**
43
     * Formato de la clave en caché para guardar el token asociado a un
44
     * certificado.
45
     *
46
     * Se utiliza un placeholder que se reemplazará con el ID del certificado.
47
     *
48
     * @var string
49
     */
50
    private const TOKEN_KEY = 'libredte_lib_sii_auth_token_%s';
51
52
    /**
53
     * Instancia con la implementación de la caché que se utilizará para el
54
     * almacenamiento de los tokens.
55
     *
56
     * @var CacheInterface
57
     */
58
    private CacheInterface $cache;
59
60
    /**
61
     * Cliente de la API SOAP del SII.
62
     *
63
     * @var WsdlConsumer
64
     */
65
    private WsdlConsumer $wsdlConsumer;
66
67
    /**
68
     * Constructor del TokenManager para inyectar la implementación de caché y
69
     * el cliente de los servicios web SOAP del SII para obtener un token.
70
     */
71
    public function __construct(
72
        CacheInterface $cache,
73
        WsdlConsumer $wsdlConsumer
74
    ) {
75
        $this->cache = $cache;
76
        $this->wsdlConsumer = $wsdlConsumer;
77
    }
78
79
    /**
80
     * Obtiene un token de autenticación asociado al certificado digital.
81
     *
82
     * El token se busca primero en la caché, si existe, se reutilizará, si no
83
     * existe se solicitará uno nuevo al SII.
84
     *
85
     * @param Certificate $certificate Certificado digital con el cual se desea
86
     * obtener un token de autenticación en el SII.
87
     * @return string El token asociado al certificado.
88
     * @throws SiiClientException Si hubo algún error al obtener el token.
89
     */
90
    public function getToken(Certificate $certificate): string
91
    {
92
        // Armar clave de la caché para el token asociado al certificado.
93
        $cacheKey = sprintf(self::TOKEN_KEY, $certificate->getID());
94
95
        // Verificar si hay un token en la caché y si no ha expirado.
96
        if ($this->cache->has($cacheKey)) {
97
            return $this->cache->get($cacheKey);
98
        }
99
100
        // Si no hay un token o está expirado, solicitar uno nuevo.
101
        // Esto falla con excepción que se deja pasara a quien haya llamado a
102
        // este método getToken().
103
        $newToken = $this->wsdlConsumer->getToken();
104
105
        // Si se logró obtener un token, se guarda en la caché.
106
        $this->cache->set($cacheKey, $newToken, self::TOKEN_TTL);
107
108
        // Entregar el nuevo token obtenido.
109
        return $newToken;
110
    }
111
}
112