2021-04-08 08:39:23 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
namespace Appwrite\Utopia\Response\Model;
|
|
|
|
|
|
|
|
|
|
use Appwrite\Utopia\Response;
|
2022-01-17 16:25:20 +00:00
|
|
|
use Utopia\Database\Document as DatabaseDocument;
|
2021-04-08 08:39:23 +00:00
|
|
|
|
|
|
|
|
class Document extends Any
|
|
|
|
|
{
|
|
|
|
|
/**
|
|
|
|
|
* Get Name
|
2021-10-06 14:22:38 +00:00
|
|
|
*
|
2021-04-08 08:39:23 +00:00
|
|
|
* @return string
|
|
|
|
|
*/
|
|
|
|
|
public function getName(): string
|
|
|
|
|
{
|
|
|
|
|
return 'Document';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2021-12-15 10:19:29 +00:00
|
|
|
* Get Type
|
2021-10-06 14:22:38 +00:00
|
|
|
*
|
2021-04-08 08:39:23 +00:00
|
|
|
* @return string
|
|
|
|
|
*/
|
|
|
|
|
public function getType(): string
|
|
|
|
|
{
|
|
|
|
|
return Response::MODEL_DOCUMENT;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function __construct()
|
|
|
|
|
{
|
|
|
|
|
$this
|
|
|
|
|
->addRule('$id', [
|
|
|
|
|
'type' => self::TYPE_STRING,
|
|
|
|
|
'description' => 'Document ID.',
|
|
|
|
|
'default' => '',
|
|
|
|
|
'example' => '5e5ea5c16897e',
|
|
|
|
|
])
|
2022-09-12 21:58:23 +00:00
|
|
|
->addRule('$collectionId', [
|
2021-04-08 08:39:23 +00:00
|
|
|
'type' => self::TYPE_STRING,
|
|
|
|
|
'description' => 'Collection ID.',
|
|
|
|
|
'default' => '',
|
|
|
|
|
'example' => '5e5ea5c15117e',
|
|
|
|
|
])
|
2022-09-12 21:58:23 +00:00
|
|
|
->addRule('$databaseId', [
|
|
|
|
|
'type' => self::TYPE_STRING,
|
|
|
|
|
'description' => 'Database ID.',
|
|
|
|
|
'default' => '',
|
|
|
|
|
'example' => '5e5ea5c15117e',
|
|
|
|
|
])
|
2022-06-15 12:46:52 +00:00
|
|
|
->addRule('$createdAt', [
|
2022-07-04 09:55:11 +00:00
|
|
|
'type' => self::TYPE_DATETIME,
|
2022-09-04 21:26:16 +00:00
|
|
|
'description' => 'Document creation date in ISO 8601 format.',
|
2022-07-04 09:55:11 +00:00
|
|
|
'default' => '',
|
2022-08-14 10:27:07 +00:00
|
|
|
'example' => self::TYPE_DATETIME_EXAMPLE,
|
2022-06-15 12:46:52 +00:00
|
|
|
])
|
|
|
|
|
->addRule('$updatedAt', [
|
2022-07-04 09:55:11 +00:00
|
|
|
'type' => self::TYPE_DATETIME,
|
2022-09-04 21:26:16 +00:00
|
|
|
'description' => 'Document update date in ISO 8601 format.',
|
2022-07-04 09:55:11 +00:00
|
|
|
'default' => '',
|
2022-08-14 10:27:07 +00:00
|
|
|
'example' => self::TYPE_DATETIME_EXAMPLE,
|
2022-06-15 12:46:52 +00:00
|
|
|
])
|
2022-08-02 09:18:49 +00:00
|
|
|
->addRule('$permissions', [
|
2021-06-10 18:19:10 +00:00
|
|
|
'type' => self::TYPE_STRING,
|
2023-10-13 13:43:44 +00:00
|
|
|
'description' => 'Document permissions. [Learn more about permissions](https://appwrite.io/docs/permissions).',
|
2021-06-10 18:19:10 +00:00
|
|
|
'default' => '',
|
2022-08-14 10:33:36 +00:00
|
|
|
'example' => ['read("any")'],
|
2021-06-10 18:19:10 +00:00
|
|
|
'array' => true,
|
2022-09-12 21:58:23 +00:00
|
|
|
]);
|
2021-04-08 08:39:23 +00:00
|
|
|
}
|
2022-01-17 16:25:20 +00:00
|
|
|
|
|
|
|
|
public function filter(DatabaseDocument $document): DatabaseDocument
|
|
|
|
|
{
|
|
|
|
|
$document->removeAttribute('$internalId');
|
2022-09-12 21:58:23 +00:00
|
|
|
$document->removeAttribute('$collection'); // $collection is the internal collection ID
|
2022-01-17 16:25:20 +00:00
|
|
|
|
2023-03-25 04:11:19 +00:00
|
|
|
foreach ($document->getAttributes() as $attribute) {
|
2023-03-30 07:54:45 +00:00
|
|
|
if (\is_array($attribute)) {
|
|
|
|
|
foreach ($attribute as $subAttribute) {
|
|
|
|
|
if ($subAttribute instanceof DatabaseDocument) {
|
|
|
|
|
$this->filter($subAttribute);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
} elseif ($attribute instanceof DatabaseDocument) {
|
2023-03-25 04:11:19 +00:00
|
|
|
$this->filter($attribute);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2022-01-17 16:25:20 +00:00
|
|
|
return $document;
|
|
|
|
|
}
|
2021-04-08 08:39:23 +00:00
|
|
|
}
|