Passed
Push — master ( 4f9e3a...139be2 )
by Alexander
23:24
created

XmlConvertible::fromXml()   A

Complexity

Conditions 2
Paths 2

Size

Total Lines 7
Code Lines 3

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 3
CRAP Score 2

Importance

Changes 2
Bugs 1 Features 0
Metric Value
eloc 3
c 2
b 1
f 0
dl 0
loc 7
ccs 3
cts 3
cp 1
rs 10
cc 2
nc 2
nop 2
crap 2
1
<?php
2
3
namespace Horat1us;
4
5
use Horat1us\Services\XmlDifferenceService;
6
use Horat1us\Services\XmlEqualityService;
7
use Horat1us\Services\XmlExportService;
8
use Horat1us\Services\XmlIntersectionService;
9
use Horat1us\Services\XmlParserService;
10
11
/**
12
 * Class XmlConvertible
13
 * @package Horat1us
14
 *
15
 * @mixin XmlConvertibleInterface
16
 */
17
trait XmlConvertible
18
{
19
    /**
20
     * @var XmlConvertibleInterface[]|\DOMNode[]|\DOMElement[]|null
21
     */
22
    public ?array $xmlChildren = null;
23
24
    /**
25
     * Name of xml element (class name will be used by default)
26
     *
27
     * @var string
28
     */
29
    public $xmlElementName;
30
31
    /**
32
     * @param XmlConvertibleInterface $xml
33
     * @return XmlConvertible|XmlConvertibleInterface|null
34
     */
35
    public function xmlIntersect(
36 4
        XmlConvertibleInterface $xml
37
    ) {
38
        $service = new XmlIntersectionService($this, $xml);
0 ignored issues
show
Bug introduced by
$this of type Horat1us\XmlConvertible is incompatible with the type Horat1us\XmlConvertibleInterface expected by parameter $source of Horat1us\Services\XmlInt...nService::__construct(). ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-type  annotation

38
        $service = new XmlIntersectionService(/** @scrutinizer ignore-type */ $this, $xml);
Loading history...
39
        return $service->intersect();
40 4
    }
41 4
42
    /**
43
     * @param XmlConvertibleInterface $xml
44
     * @return XmlConvertibleInterface|XmlConvertible|null
45
     */
46
    public function xmlDiff(XmlConvertibleInterface $xml)
47
    {
48 4
        $service = new XmlDifferenceService($this, $xml);
0 ignored issues
show
Bug introduced by
$this of type Horat1us\XmlConvertible is incompatible with the type Horat1us\XmlConvertibleInterface expected by parameter $source of Horat1us\Services\XmlDif...eService::__construct(). ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-type  annotation

48
        $service = new XmlDifferenceService(/** @scrutinizer ignore-type */ $this, $xml);
Loading history...
49
        return $service->difference();
50 4
    }
51 4
52
    /**
53
     * Converts object to XML and compares it with given
54
     *
55
     * @param XmlConvertibleInterface $xml
56
     * @return bool
57
     */
58
    public function xmlEqual(XmlConvertibleInterface $xml): bool
59
    {
60 3
        $service = new XmlEqualityService($this, $xml);
0 ignored issues
show
Bug introduced by
$this of type Horat1us\XmlConvertible is incompatible with the type Horat1us\XmlConvertibleInterface|null expected by parameter $first of Horat1us\Services\XmlEqu...yService::__construct(). ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-type  annotation

60
        $service = new XmlEqualityService(/** @scrutinizer ignore-type */ $this, $xml);
Loading history...
61
        return $service->compare();
62 3
    }
63 3
64
    /**
65
     * @param \DOMDocument|\DOMElement $document
66
     * @param array $aliases
67
     * @return XmlConvertibleInterface
68
     */
69
    public static function fromXml($document, array $aliases = [])
70
    {
71 12
        /** @var \DOMElement $document */
72
        if (!in_array(get_called_class(), $aliases)) {
73
            $aliases[(new \ReflectionClass(get_called_class()))->getShortName()] = get_called_class();
74 12
        }
75 7
        return (new XmlParserService($document, $aliases))->convert();
76
    }
77 12
78
    /**
79
     * @param \DOMDocument|null $document
80
     * @return \DOMElement
81
     */
82
    public function toXml(?\DOMDocument $document = null): \DOMElement
83
    {
84 14
        $service = new XmlExportService($this, $document);
0 ignored issues
show
Bug introduced by
$this of type Horat1us\XmlConvertible is incompatible with the type Horat1us\XmlConvertibleInterface expected by parameter $object of Horat1us\Services\XmlExportService::__construct(). ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-type  annotation

84
        $service = new XmlExportService(/** @scrutinizer ignore-type */ $this, $document);
Loading history...
85
        return $service->export();
86 14
    }
87 14
88
    /**
89
     * Name of xml element (class name will be used by default)
90
     *
91
     * @return string
92
     */
93
    public function getXmlElementName(): string
94
    {
95 23
        return $this->xmlElementName ?? (new \ReflectionClass(get_called_class()))->getShortName();
96
    }
97 23
98
    /**
99
     * Settings name of xml element
100
     *
101
     * @param string $name
102
     * @return static
103
     */
104
    public function setXmlElementName(?string $name = null)
105
    {
106 1
        $this->xmlElementName = $name;
107
        return $this;
108 1
    }
109 1
110
    /**
111
     * @return XmlConvertibleInterface[]|\DOMNode[]|\DOMElement[]|null
112
     */
113
    public function getXmlChildren()
114
    {
115 23
        return $this->xmlChildren;
116
    }
117 23
118
    /**
119
     * @param XmlConvertibleInterface[]|\DOMNode[]|\DOMElement[]|null $xmlChildren
120
     * @return static
121
     */
122
    public function setXmlChildren(?array $xmlChildren = null)
123
    {
124 14
        $this->xmlChildren = $xmlChildren ?: null;
125
        return $this;
126 14
    }
127 14
128
    /**
129
     * Getting array of property names which will be used as attributes in created XML
130
     *
131
     * @param array|null $properties
132
     * @return array|string[]
133
     */
134
    public function getXmlProperties(?array $properties = null): array
135
    {
136 23
        $properties = $properties
137
            ?? array_map(
138 23
                function (\ReflectionProperty $property) {
139
                    return $property->getName();
140 18
                },
141 23
                (new \ReflectionClass(get_called_class()))
142
                    ->getProperties(\ReflectionProperty::IS_PUBLIC),
143
            );
144
145 23
146 23
        return array_filter($properties, function (string $property) {
147
            return !in_array($property, ['xmlChildren', 'xmlElementName']);
148
        });
149
    }
150
151
    public function getXmlProperty(string $property)
152
    {
153
        if (!in_array($property, $this->getXmlProperties())) {
154 18
            return;
155 5
        }
156 18
        return $this->{$property};
157 18
    }
158
159
    /**
160
     * Cloning all children by default
161
     */
162
    public function __clone()
163
    {
164
        $this->xmlChildren = array_map(function ($xmlChild) {
165
            return clone $xmlChild;
166
        }, $this->xmlChildren ?? []) ?: null;
167
    }
168
}
169