122 lines
3.9 KiB
PHP
122 lines
3.9 KiB
PHP
<?php
|
|
|
|
namespace Appwrite\Utopia\Response\Model;
|
|
|
|
use Appwrite\Utopia\Response;
|
|
use Appwrite\Utopia\Response\Model;
|
|
|
|
class Func extends Model
|
|
{
|
|
public function __construct()
|
|
{
|
|
$this
|
|
->addRule('$id', [
|
|
'type' => self::TYPE_STRING,
|
|
'description' => 'Function ID.',
|
|
'default' => '',
|
|
'example' => '5e5ea5c16897e',
|
|
])
|
|
->addRule('execute', [
|
|
'type' => Response::MODEL_FUNC_PERMISSIONS,
|
|
'description' => 'Function permissions.',
|
|
'default' => new \stdClass,
|
|
'example' => new \stdClass,
|
|
'array' => false,
|
|
])
|
|
->addRule('name', [
|
|
'type' => self::TYPE_STRING,
|
|
'description' => 'Function name.',
|
|
'default' => '',
|
|
'example' => 'My Function',
|
|
])
|
|
->addRule('dateCreated', [
|
|
'type' => self::TYPE_INTEGER,
|
|
'description' => 'Function creation date in Unix timestamp.',
|
|
'default' => 0,
|
|
'example' => 1592981250,
|
|
])
|
|
->addRule('dateUpdated', [
|
|
'type' => self::TYPE_INTEGER,
|
|
'description' => 'Function update date in Unix timestamp.',
|
|
'default' => 0,
|
|
'example' => 1592981257,
|
|
])
|
|
->addRule('status', [
|
|
'type' => self::TYPE_STRING,
|
|
'description' => 'Function status. Possible values: `disabled`, `enabled`',
|
|
'default' => '',
|
|
'example' => 'enabled',
|
|
])
|
|
->addRule('runtime', [
|
|
'type' => self::TYPE_STRING,
|
|
'description' => 'Function execution runtime.',
|
|
'default' => '',
|
|
'example' => 'python-3.8',
|
|
])
|
|
->addRule('tag', [
|
|
'type' => self::TYPE_STRING,
|
|
'description' => 'Function active tag ID.',
|
|
'default' => '',
|
|
'example' => '5e5ea5c16897e',
|
|
])
|
|
->addRule('vars', [
|
|
'type' => self::TYPE_JSON,
|
|
'description' => 'Function environment variables.',
|
|
'default' => new \stdClass,
|
|
'example' => ['key' => 'value'],
|
|
])
|
|
->addRule('events', [
|
|
'type' => self::TYPE_STRING,
|
|
'description' => 'Function trigger events.',
|
|
'default' => [],
|
|
'example' => 'account.create',
|
|
'array' => true,
|
|
])
|
|
->addRule('schedule', [
|
|
'type' => self::TYPE_STRING,
|
|
'description' => 'Function execution schedult in CRON format.',
|
|
'default' => '',
|
|
'example' => '5 4 * * *',
|
|
])
|
|
->addRule('scheduleNext', [
|
|
'type' => self::TYPE_INTEGER,
|
|
'description' => 'Function next scheduled execution date in Unix timestamp.',
|
|
'default' => 0,
|
|
'example' => 1592981292,
|
|
])
|
|
->addRule('schedulePrevious', [
|
|
'type' => self::TYPE_INTEGER,
|
|
'description' => 'Function next scheduled execution date in Unix timestamp.',
|
|
'default' => 0,
|
|
'example' => 1592981237,
|
|
])
|
|
->addRule('timeout', [
|
|
'type' => self::TYPE_INTEGER,
|
|
'description' => 'Function execution timeout in seconds.',
|
|
'default' => 15,
|
|
'example' => 1592981237,
|
|
])
|
|
;
|
|
}
|
|
|
|
/**
|
|
* Get Name
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getName():string
|
|
{
|
|
return 'Function';
|
|
}
|
|
|
|
/**
|
|
* Get Collection
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getType():string
|
|
{
|
|
return Response::MODEL_FUNCTION;
|
|
}
|
|
}
|