diff options
| author | Jan-Hendrik Willms <tleilax+github@gmail.com> | 2023-12-07 14:04:18 +0100 |
|---|---|---|
| committer | Jan-Hendrik Willms <tleilax+studip@gmail.com> | 2024-10-30 12:40:05 +0000 |
| commit | 288f22cd7f789e6408c4fc8dcfac19627d0ff01b (patch) | |
| tree | f38fd112175dd78dd3833036e97b4f7e42ff6f85 /lib/classes/JsonApi/Schemas/ResourceSchema.php | |
| parent | 363c78feaae65f3dfaba40b39463e2f1156048d4 (diff) | |
initial commit, re #2799tic-2799
Diffstat (limited to 'lib/classes/JsonApi/Schemas/ResourceSchema.php')
| -rw-r--r-- | lib/classes/JsonApi/Schemas/ResourceSchema.php | 89 |
1 files changed, 89 insertions, 0 deletions
diff --git a/lib/classes/JsonApi/Schemas/ResourceSchema.php b/lib/classes/JsonApi/Schemas/ResourceSchema.php new file mode 100644 index 0000000..bcf89db --- /dev/null +++ b/lib/classes/JsonApi/Schemas/ResourceSchema.php @@ -0,0 +1,89 @@ +<?php +namespace JsonApi\Schemas; + +use Neomerx\JsonApi\Contracts\Schema\BaseLinkInterface; +use Neomerx\JsonApi\Contracts\Schema\ContextInterface; +use Resource; + +final class ResourceSchema extends SchemaProvider +{ + const TYPE = 'resources'; + + const REL_CATEGORY = 'category'; + + /** + * @param Resource $resource + */ + public function getId($resource): ?string + { + return $resource->id; + } + + /** + * @param Resource $resource + */ + public function getAttributes($resource, ContextInterface $context): iterable + { + return [ + 'level' => (int) $resource->level, + 'name' => (string) $resource->name, + 'description' => (string) $resource->description, + 'requestable' => (bool) $resource->requestable, + 'lockable' => (bool) $resource->lockable, + 'sort_position' => (int) $resource->sort_position, + + 'mkdate' => date('c', $resource->mkdate), + 'chdate' => date('c', $resource->chdate), + ]; + } + + /** + * @param Resource $resource + */ + public function hasResourceMeta($resource): bool + { + return true; + } + + /** + * @param Resource $resource + */ + public function getResourceMeta($resource) + { + return [ + 'class' => $resource->class_name, + ]; + } + + /** + * @param Resource $resource + */ + public function getRelationships($resource, ContextInterface $context): iterable + { + if ($context->getPosition()->getLevel() > 0) { + return []; + }; + + $relationships = []; + + $relationships = $this->getCategoryRelationship( + $relationships, + $resource, + $this->shouldInclude($context, self::REL_CATEGORY) + ); + + return $relationships; + } + + private function getCategoryRelationship(array $relationships, $resource, bool $shouldInclude) + { + $relationships[self::REL_CATEGORY] = [ + self::RELATIONSHIP_LINKS => [ + BaseLinkInterface::RELATED => $this->getRelationshipRelatedLink($resource, self::REL_CATEGORY), + ], + self::RELATIONSHIP_DATA => $shouldInclude ? $resource->category : \ResourceCategory::build(['id' => $resource->category_id]), + ]; + + return $relationships; + } +} |
