Test Failed
Push — master ( 5bd0ed...9eafef )
by Esteban De La Fuente
08:45
created

FakeReceptorProvider::retrieve()   A

Complexity

Conditions 3
Paths 2

Size

Total Lines 22
Code Lines 12

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 3
eloc 12
c 1
b 0
f 0
nc 2
nop 1
dl 0
loc 22
rs 9.8666
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\Package\Billing\Component\TradingParties\Service;
26
27
use Derafu\Lib\Core\Helper\Hydrator;
28
use libredte\lib\Core\Package\Billing\Component\TradingParties\Contract\ReceptorFactoryInterface;
29
use libredte\lib\Core\Package\Billing\Component\TradingParties\Contract\ReceptorInterface;
30
use libredte\lib\Core\Package\Billing\Component\TradingParties\Contract\ReceptorProviderInterface;
31
32
/**
33
 * Proveedor falso de datos de un receptor para pruebas.
34
 *
35
 * La aplicación que use LibreDTE debe implementar este servicio para resolver
36
 * los datos que falten de un receptor al emitir un documento.
37
 */
38
class FakeReceptorProvider implements ReceptorProviderInterface
39
{
40
    /**
41
     * Constructor del servicio y sus dependencias.
42
     *
43
     * @param ReceptorFactoryInterface $receptorFactory
44
     */
45
    public function __construct(
46
        private ReceptorFactoryInterface $receptorFactory
47
    ) {
48
    }
49
50
    /**
51
     * {@inheritDoc}
52
     */
53
    public function retrieve(int|string|ReceptorInterface $receptor): ReceptorInterface
54
    {
55
        // Si se pasó el RUT se crea una instancia del receptor usando la
56
        // factory.
57
        if (is_int($receptor) || is_string($receptor)) {
58
            $receptor = $this->receptorFactory->create(['rut' => $receptor]);
59
        }
60
61
        // El emisor se estandariza como SII.
62
        $receptor = Hydrator::hydrate($receptor, [
63
            'rut' => 60803000,
64
            'dv' => 'K',
65
            'razon_social' => 'Servicio de Impuestos Internos',
66
            'giro' => 'Gobierno',
67
            'telefono' => '+56 2 32525575',
68
            'email' => '[email protected]',
69
            'direccion' => 'Alonso Ovalle 680',
70
            'comuna' => 'Santiago',
71
        ]);
72
73
        // Se entrega la instancia del receptor.
74
        return $receptor;
75
    }
76
}
77