1 | <?php |
||||||
2 | |||||||
3 | declare(strict_types=1); |
||||||
4 | |||||||
5 | namespace VGirol\JsonApiStructure\Concern; |
||||||
6 | |||||||
7 | use VGirol\JsonApiStructure\Messages; |
||||||
8 | |||||||
9 | /** |
||||||
10 | * Validations relating to the arrays |
||||||
11 | */ |
||||||
12 | trait ValidateArrays |
||||||
13 | { |
||||||
14 | /** |
||||||
15 | * Check if an array is an array of objects. |
||||||
16 | * |
||||||
17 | * @param array $json |
||||||
18 | * |
||||||
19 | * @return bool |
||||||
20 | */ |
||||||
21 | 183 | public function isArrayOfObjects($json): bool |
|||||
22 | { |
||||||
23 | 183 | $this->isValidArgument(1, 'array', $json); |
|||||
0 ignored issues
–
show
Bug
introduced
by
![]() |
|||||||
24 | |||||||
25 | 180 | if (\count($json) == 0) { |
|||||
26 | 3 | return true; |
|||||
27 | } |
||||||
28 | |||||||
29 | 177 | return !$this->arrayIsAssociative($json); |
|||||
30 | } |
||||||
31 | |||||||
32 | /** |
||||||
33 | * Validate that an array is an array of objects. |
||||||
34 | * |
||||||
35 | * @param array $json |
||||||
36 | * @param string|null $message An optional message to explain why the test failed |
||||||
37 | * @param mixed $code |
||||||
38 | * |
||||||
39 | * @return void |
||||||
40 | * @throws \VGirol\JsonApiStructure\Exception\ValidationException |
||||||
41 | */ |
||||||
42 | 54 | public function mustBeArrayOfObjects($json, ?string $message = '', $code = 403): void |
|||||
43 | { |
||||||
44 | 54 | if (!$this->isArrayOfObjects($json)) { |
|||||
45 | 21 | $this->throw($message ?: Messages::MUST_BE_ARRAY_OF_OBJECTS, $code); |
|||||
0 ignored issues
–
show
It seems like
throw() must be provided by classes using this trait. How about adding it as abstract method to this trait?
(
Ignorable by Annotation
)
If this is a false-positive, you can also ignore this issue in your code via the
![]() |
|||||||
46 | } |
||||||
47 | 33 | } |
|||||
48 | |||||||
49 | /** |
||||||
50 | * Check if an array is not an array of objects. |
||||||
51 | * |
||||||
52 | * @param array $json |
||||||
53 | * |
||||||
54 | * @return bool |
||||||
55 | */ |
||||||
56 | 186 | public function isNotArrayOfObjects($json): bool |
|||||
57 | { |
||||||
58 | 186 | $this->isValidArgument(1, 'array', $json); |
|||||
59 | |||||||
60 | 180 | if (\count($json) == 0) { |
|||||
61 | 3 | return true; |
|||||
62 | } |
||||||
63 | |||||||
64 | 177 | return $this->arrayIsAssociative($json); |
|||||
65 | } |
||||||
66 | |||||||
67 | /** |
||||||
68 | * Validate that an array is not an array of objects. |
||||||
69 | * |
||||||
70 | * @param array $json |
||||||
71 | * @param string $message An optional message to explain why the test failed |
||||||
72 | * @param mixed $code |
||||||
73 | * |
||||||
74 | * @return void |
||||||
75 | * @throws \VGirol\JsonApiStructure\Exception\ValidationException |
||||||
76 | */ |
||||||
77 | 174 | public function mustNotBeArrayOfObjects($json, string $message = '', $code = 403): void |
|||||
78 | { |
||||||
79 | 174 | if (!$this->isNotArrayOfObjects($json)) { |
|||||
80 | 21 | $this->throw($message ?: Messages::MUST_NOT_BE_ARRAY_OF_OBJECTS, $code); |
|||||
81 | } |
||||||
82 | 150 | } |
|||||
83 | |||||||
84 | /** |
||||||
85 | * Checks if the given array is an associative array. |
||||||
86 | * |
||||||
87 | * @param array $arr |
||||||
88 | * |
||||||
89 | * @return boolean |
||||||
90 | */ |
||||||
91 | 285 | private function arrayIsAssociative(array $arr): bool |
|||||
92 | { |
||||||
93 | 285 | return (\array_keys($arr) !== \range(0, \count($arr) - 1)); |
|||||
94 | } |
||||||
95 | } |
||||||
96 |