Passed
Push — master ( 660904...4d7c06 )
by Esteban De La Fuente
03:42
created

Entity   A

Complexity

Total Complexity 6

Size/Duplication

Total Lines 60
Duplicated Lines 0 %

Test Coverage

Coverage 0%

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 13
dl 0
loc 60
ccs 0
cts 17
cp 0
rs 10
c 1
b 0
f 0
wmc 6

5 Methods

Rating   Name   Duplication   Size   Complexity  
A hasAttribute() 0 3 1
A __get() 0 3 1
A getAttribute() 0 11 2
A __toString() 0 3 1
A setAttribute() 0 5 1
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 Derafu\Lib\Core\Package\Prime\Component\Entity\Contract\EntityInterface;
28
use LogicException;
29
30
/**
31
 * Clase genérica para el manejo de entidades de repositorios.
32
 *
33
 * Esta clase es útil cuando no se desea crear explícitamente cada clase de cada
34
 * entidad. Sin embargo, es desaconsejado su uso y se recomienda crear clases
35
 * para cada entidad que se requiera.
36
 */
37
class Entity implements EntityInterface
38
{
39
    /**
40
     * Atributos de la entidad.
41
     *
42
     * @var array
43
     */
44
    private array $attributes = [];
45
46
    /**
47
     * {@inheritdoc}
48
     */
49
    public function __toString(): string
50
    {
51
        return static::class;
52
    }
53
54
    /**
55
     * {@inheritdoc}
56
     */
57
    public function setAttribute(string $name, int|float|string|bool|null $value): static
58
    {
59
        $this->attributes[$name] = $value;
60
61
        return $this;
62
    }
63
64
    /**
65
     * {@inheritdoc}
66
     */
67
    public function getAttribute(string $name): int|float|string|bool|null
68
    {
69
        if (!$this->hasAttribute($name)) {
70
            throw new LogicException(sprintf(
71
                'No existe el atributo %s en la entidad %s.',
72
                $name,
73
                static::class
74
            ));
75
        }
76
77
        return $this->attributes[$name];
78
    }
79
80
    /**
81
     * {@inheritdoc}
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