-
Notifications
You must be signed in to change notification settings - Fork 0
/
JsonXmlAdapter.php
77 lines (64 loc) · 1.59 KB
/
JsonXmlAdapter.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
<?php
namespace app\modules\api\components\adapters;
use SimpleXMLElement;
/**
* Class JsonXmlAdapter
*
* Данный класс выступает в виде вспомогательного инструмента
* при помощи которого можно привести к общему типу данных (array)
* входную строку xml|json
**/
class JsonXmlAdapter
{
private $type = 'json';
private $string;
/**
* JsonXmlAdapter constructor.
*
* @param string $rawString
*/
public function __construct(string $rawString)
{
$this->string = $rawString;
}
/**
* @return array
*/
public function getArray(): array
{
if ($obj = $this->xmlDecode()) {
$this->string = json_encode($obj);
}
return $this->jsonDecode();
}
/**
* @return SimpleXMLElement|null
*/
private function xmlDecode(): ?SimpleXMLElement
{
if (@simplexml_load_string($this->string)) {
$this->type = 'xml';
return new SimpleXMLElement($this->string);
}
return null;
}
/**
* @return array
*/
private function jsonDecode(): array
{
$array = json_decode($this->string, true);
if (json_last_error() == JSON_ERROR_NONE) {
return (isset($array['@attributes'])) ? $array['@attributes'] : $array;
}
$this->type = 'undefined';
return [];
}
/**
* @return string
*/
public function getConvertType(): string
{
return $this->type;
}
}