Test Failed
Push — master ( 8dc6a9...a5e9ad )
by Esteban De La Fuente
06:42
created

AduanaMoneda   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 29
Duplicated Lines 0 %

Test Coverage

Coverage 0%

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 6
c 1
b 0
f 0
dl 0
loc 29
ccs 0
cts 7
cp 0
rs 10
wmc 3

2 Methods

Rating   Name   Duplication   Size   Complexity  
A getMoneda() 0 9 2
A getCodigoISO() 0 3 1
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\Document\Entity;
26
27
use Derafu\Lib\Core\Package\Prime\Component\Entity\Entity\Entity;
28
29
/**
30
 * Entidad de una moneda de aduana (documentos de exportación).
31
 */
32
class AduanaMoneda extends Entity
33
{
34
    /**
35
     * Entrega el código ISO 4217 asociado a la moneda.
36
     *
37
     * @return string
38
     */
39
    public function getCodigoISO(): string
40
    {
41
        return $this->getAttribute('codigo_iso');
42
    }
43
44
    /**
45
     * Obtiene la instancia de la moneda asociada a la moneda de aduaba.
46
     *
47
     * Si la moneda no fue encontrada en las monedas soportadas se devolverá la
48
     * moneda ISO 4217 XXX.
49
     *
50
     * @return Moneda
51
     */
52
    public function getMoneda(): Moneda
53
    {
54
        $moneda = Moneda::tryFrom($this->getCodigoISO());
55
56
        if ($moneda !== null) {
57
            return $moneda;
58
        }
59
60
        return Moneda::XXX;
61
    }
62
}
63