Passed
Push — master ( ae3156...6fb22a )
by Esteban De La Fuente
03:24
created

Entity::getAttribute()   A

Complexity

Conditions 2
Paths 2

Size

Total Lines 11
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 11
ccs 0
cts 8
cp 0
crap 6
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\Entity\Entity;
26
27
use LogicException;
28
29
/**
30
 * Clase genérica para el manejo de entidades de repositorios.
31
 *
32
 * Esta clase es útil cuando no se desea crear explícitamente cada clase de cada
33
 * entidad. Sin embargo, es desaconsejado su uso y se recomienda crear clases
34
 * para cada entidad que se requiera.
35
 */
36
class Entity
37
{
38
    /**
39
     * Atributos de la entidad.
40
     *
41
     * @var array
42
     */
43
    private array $attributes = [];
44
45
    /**
46
     * Asignar un atributo a la entidad.
47
     *
48
     * @param string $name
49
     * @param int|float|string|bool|null $value
50
     * @return static
51
     */
52
    public function setAttribute(string $name, int|float|string|bool|null $value): static
53
    {
54
        $this->attributes[$name] = $value;
55
56
        return $this;
57
    }
58
59
    /**
60
     * Obtener un atributo de la entidad.
61
     *
62
     * @param string $name
63
     * @return int|float|string|bool|null
64
     */
65
    public function getAttribute(string $name): int|float|string|bool|null
66
    {
67
        if (!$this->hasAttribute($name)) {
68
            throw new LogicException(sprintf(
69
                'No existe el atributo %s en la entidad %s.',
70
                $name,
71
                static::class
72
            ));
73
        }
74
75
        return $this->attributes[$name];
76
    }
77
78
    /**
79
     * Permite saber si existe o no un atributo definido para la entidad.
80
     *
81
     * @return bool
82
     */
83
    public function hasAttribute(string $name): bool
84
    {
85
        return array_key_exists($name, $this->attributes);
86
    }
87
88
    /**
89
     * Método mágico para obtener los atributos como si estuviesen definidos.
90
     *
91
     * @param string $name
92
     * @return int|float|string|bool|null
93
     */
94
    public function __get(string $name): int|float|string|bool|null
95
    {
96
        return $this->getAttribute($name);
97
    }
98
}
99