1 | <?php namespace Limoncello\Flute\Validation\JsonApi\Execution; |
||
30 | class JsonApiDataRulesSerializer extends RulesSerializer implements JsonApiDataRulesSerializerInterface |
||
31 | { |
||
32 | /** Serialized indexes key */ |
||
33 | protected const SERIALIZED_RULES = 0; |
||
34 | |||
35 | /** Serialized rules key */ |
||
36 | protected const SERIALIZED_BLOCKS = self::SERIALIZED_RULES + 1; |
||
37 | |||
38 | /** Index key */ |
||
39 | protected const ID_SERIALIZED = 0; |
||
40 | |||
41 | /** Index key */ |
||
42 | protected const TYPE_SERIALIZED = self::ID_SERIALIZED + 1; |
||
43 | |||
44 | /** Index key */ |
||
45 | protected const ATTRIBUTES_SERIALIZED = self::TYPE_SERIALIZED + 1; |
||
46 | |||
47 | /** Index key */ |
||
48 | protected const TO_ONE_SERIALIZED = self::ATTRIBUTES_SERIALIZED + 1; |
||
49 | |||
50 | /** Index key */ |
||
51 | protected const TO_MANY_SERIALIZED = self::TO_ONE_SERIALIZED + 1; |
||
52 | |||
53 | /** |
||
54 | * @var array |
||
55 | */ |
||
56 | private $serializedRules = []; |
||
57 | |||
58 | /** |
||
59 | * @param string $rulesClass |
||
60 | * |
||
61 | * @return self |
||
62 | */ |
||
63 | 28 | public function addRulesFromClass(string $rulesClass): JsonApiDataRulesSerializerInterface |
|
80 | |||
81 | /** |
||
82 | * @inheritdoc |
||
83 | */ |
||
84 | 40 | public function addDataRules( |
|
109 | |||
110 | /** |
||
111 | * @inheritdoc |
||
112 | * |
||
113 | * @SuppressWarnings(PHPMD.StaticAccess) |
||
114 | */ |
||
115 | 40 | public function getData(): array |
|
122 | |||
123 | /** |
||
124 | * @param string $rulesClass |
||
125 | * @param array $serializedData |
||
126 | * |
||
127 | * @return array |
||
128 | */ |
||
129 | 21 | public static function readRules(string $rulesClass, array $serializedData): array |
|
137 | |||
138 | /** |
||
139 | * @inheritdoc |
||
140 | */ |
||
141 | 21 | public static function hasRules(string $name, array $serializedData): bool |
|
148 | |||
149 | /** |
||
150 | * @param array $serializedData |
||
151 | * |
||
152 | * @return array |
||
153 | */ |
||
154 | 21 | public static function readBlocks(array $serializedData): array |
|
162 | |||
163 | /** |
||
164 | * @param array $serializedRules |
||
165 | * |
||
166 | * @return array |
||
167 | */ |
||
168 | 21 | public static function readIdRuleIndexes(array $serializedRules): array |
|
176 | |||
177 | /** |
||
178 | * @param array $serializedRules |
||
179 | * |
||
180 | * @return array |
||
181 | */ |
||
182 | 21 | public static function readTypeRuleIndexes(array $serializedRules): array |
|
190 | |||
191 | /** |
||
192 | * @param array $serializedRules |
||
193 | * |
||
194 | * @return array |
||
195 | */ |
||
196 | 21 | public static function readAttributeRulesIndexes(array $serializedRules): array |
|
204 | |||
205 | /** |
||
206 | * @param array $serializedRules |
||
207 | * |
||
208 | * @return array |
||
209 | */ |
||
210 | 21 | public static function readToOneRulesIndexes(array $serializedRules): array |
|
218 | |||
219 | /** |
||
220 | * @param array $serializedRules |
||
221 | * |
||
222 | * @return array |
||
223 | */ |
||
224 | 21 | public static function readToManyRulesIndexes(array $serializedRules): array |
|
232 | |||
233 | /** |
||
234 | * @param array $ruleIndexes |
||
235 | * |
||
236 | * @return int |
||
237 | */ |
||
238 | 14 | public static function readRuleIndex(array $ruleIndexes): int |
|
242 | |||
243 | /** |
||
244 | * @param array $ruleIndexes |
||
245 | * |
||
246 | * @return array |
||
247 | */ |
||
248 | 15 | public static function readRuleStartIndexes(array $ruleIndexes): array |
|
252 | |||
253 | /** |
||
254 | * @param array $ruleIndexes |
||
255 | * |
||
256 | * @return array |
||
257 | */ |
||
258 | 15 | public static function readRuleEndIndexes(array $ruleIndexes): array |
|
262 | |||
263 | /** |
||
264 | * @param array $arrayRuleIndexes |
||
265 | * |
||
266 | * @return array |
||
267 | */ |
||
268 | 21 | public static function readRulesIndexes(array $arrayRuleIndexes): array |
|
272 | |||
273 | /** |
||
274 | * @param array $arrayRuleIndexes |
||
275 | * |
||
276 | * @return array |
||
277 | */ |
||
278 | 21 | public static function readRulesStartIndexes(array $arrayRuleIndexes): array |
|
282 | |||
283 | /** |
||
284 | * @param array $arrayRuleIndexes |
||
285 | * |
||
286 | * @return array |
||
287 | */ |
||
288 | 21 | public static function readRulesEndIndexes(array $arrayRuleIndexes): array |
|
292 | |||
293 | /** |
||
294 | * @param int $index |
||
295 | * @param array $blocks |
||
296 | * |
||
297 | * @return bool |
||
298 | */ |
||
299 | 17 | public static function hasRule(int $index, array $blocks): bool |
|
305 | |||
306 | /** |
||
307 | * @param string $rulesClass |
||
308 | * |
||
309 | * @return bool |
||
310 | */ |
||
311 | 28 | private static function isRulesClass(string $rulesClass): bool |
|
317 | } |
||
318 |
Let’s assume you have a class which uses late-static binding:
}
The code above will run fine in your PHP runtime. However, if you now create a sub-class and call the
getSomeVariable()
on that sub-class, you will receive a runtime error:In the case above, it makes sense to update
SomeClass
to useself
instead: