addType('id', 'integer'); $this->addType('shared', 'integer'); $this->addType('archived', 'boolean'); $this->addType('deletedAt', 'integer'); $this->addType('lastModified', 'integer'); $this->addRelation('labels'); $this->addRelation('acl'); $this->addRelation('shared'); $this->addRelation('users'); $this->addRelation('activeSessions'); $this->addRelation('permissions'); $this->addRelation('stacks'); $this->addRelation('settings'); $this->addResolvable('owner'); $this->shared = -1; } public function jsonSerialize(): array { $json = parent::jsonSerialize(); if ($this->shared === -1) { unset($json['shared']); } // FIXME: Ideally the API responses should follow the internal data structure and return null if the labels/acls have not been fetched from the db // however this would be a breaking change for consumers of the API $json['acl'] = $this->acl ?? []; $json['labels'] = $this->labels ?? []; return $json; } /** * @param Label[] $labels */ public function setLabels($labels) { $this->labels = $labels; } /** * @param Acl[] $acl */ public function setAcl($acl) { $this->acl = $acl; } public function getETag() { return md5((string)$this->getLastModified()); } /** @returns Acl[]|null */ public function getAcl(): ?array { return $this->acl; } /** @returns Label[]|null */ public function getLabels(): ?array { return $this->labels; } }