Horat1us /
php-xml-convertible
| 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
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
$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
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
$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
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
$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
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 |