%PDF- %PDF-
Direktori : /www/varak.net/nextcloud.varak.net/apps/related_resources/lib/Tools/Traits/ |
Current File : //www/varak.net/nextcloud.varak.net/apps/related_resources/lib/Tools/Traits/TDeserialize.php |
<?php declare(strict_types=1); /** * SPDX-FileCopyrightText: 2022 Nextcloud GmbH and Nextcloud contributors * SPDX-License-Identifier: AGPL-3.0-or-later */ namespace OCA\RelatedResources\Tools\Traits; use Exception; use JsonSerializable; use OCA\RelatedResources\Tools\Exceptions\InvalidItemException; use OCA\RelatedResources\Tools\IDeserializable; use ReflectionClass; trait TDeserialize { /** * @param JsonSerializable $model * * @return array */ public function serialize(JsonSerializable $model): array { return json_decode(json_encode($model), true); } /** * @param array $data * * @return array */ public function serializeArray(array $data): array { return json_decode(json_encode($data), true); } /** * @param array $data * @param string $class * * @return IDeserializable * @throws InvalidItemException */ public function deserialize(array $data, string $class): IDeserializable { try { $test = new ReflectionClass($class); } catch (\ReflectionException $e) { throw new InvalidItemException('cannot ReflectionClass ' . $class); } if (!in_array(IDeserializable::class, $test->getInterfaceNames())) { throw new InvalidItemException($class . ' does not implement IDeserializable'); } /** @var IDeserializable $item */ $item = new $class; $item->import($data); return $item; } /** * force deserialize without checking for implementation of IDeserializable. * quickest solution to deserialize model from other apps. * * @param string $json * @param string $class * * @return array */ public function forceDeserializeArrayFromJson(string $json, string $class): array { $data = json_decode($json, true); if (!is_array($data)) { return []; } $arr = []; foreach ($data as $entry) { try { $item = new $class; $arr[] = $item->import($entry); } catch (Exception $e) { } } return $arr; } /** * @param string $json * @param string $class * * @return IDeserializable[] */ public function deserializeArrayFromJson(string $json, string $class): array { $data = json_decode($json, true); if (!is_array($data)) { return []; } return $this->deserializeArray($data, $class); } /** * @param array $data * @param string $class * * @return array */ public function deserializeArray(array $data, string $class): array { $arr = []; foreach ($data as $entry) { try { $arr[] = $this->deserialize($entry, $class); } catch (InvalidItemException $e) { } } return $arr; } /** * @param string $json * @param string $class * * @return IDeserializable * @throws InvalidItemException */ public function deserializeJson(string $json, string $class): IDeserializable { $data = json_decode($json, true); return $this->deserialize($data, $class); } }