8f14f5aa21
* database response model * database collection config * new database scopes * database service update * database execption codes * remove read write permission from database model * updating tests and fixing some bugs * server side tests are now passing * databases api * tests for database endpoint * composer update * fix error * formatting * formatting fixes * get database test * more updates to events and usage * more usage updates * fix delete type * fix test * delete database * more fixes * databaseId in attributes and indexes * more fixes * fix issues * fix index subquery * fix console scope and index query * updating tests as required * fix phpcs errors and warnings * updates to review suggestions * UI progress * ui updates and cleaning up * fix type * rework database events * update tests * update types * event generation fixed * events config updated * updating context to support multiple * realtime updates * fix ids * update context * validator updates * fix naming conflict * fix tests * fix lint errors * fix wprler and realtime tests * fix webhooks test * fix event validator and other tests * formatting fixes * removing leftover var_dumps * remove leftover comment * update usage params * usage metrics updates * update database usage * fix usage * specs update * updates to usage * fix UI and usage * fix lints * internal id fixes * fixes for internal Id * renaming services and related files * rename tests * rename doc link * rename readme * fix test name * tests: fixes for 0.15.x sync Co-authored-by: Torsten Dittmann <torsten.dittmann@googlemail.com>
145 lines
3.4 KiB
PHP
145 lines
3.4 KiB
PHP
<?php
|
|
|
|
namespace Appwrite\Event\Validator;
|
|
|
|
use Utopia\Config\Config;
|
|
use Utopia\Validator;
|
|
|
|
class Event extends Validator
|
|
{
|
|
/**
|
|
* Get Description.
|
|
*
|
|
* Returns validator description
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getDescription(): string
|
|
{
|
|
return 'Event is not valid.';
|
|
}
|
|
|
|
/**
|
|
* Is valid.
|
|
*
|
|
* @param mixed $value
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function isValid($value): bool
|
|
{
|
|
$events = Config::getParam('events', []);
|
|
$parts = \explode('.', $value);
|
|
$count = \count($parts);
|
|
|
|
if ($count < 2 || $count > 7) {
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Identify all sections of the pattern.
|
|
*/
|
|
$type = $parts[0] ?? false;
|
|
$resource = $parts[1] ?? false;
|
|
$hasSubResource = $count > 3 && ($events[$type]['$resource'] ?? false) && ($events[$type][$parts[2]]['$resource'] ?? false);
|
|
$hasSubSubResource = $count > 5 && $hasSubResource && ($events[$type][$parts[2]][$parts[4]]['$resource'] ?? false);
|
|
|
|
if (!$type || !$resource) {
|
|
return false;
|
|
}
|
|
|
|
if ($hasSubResource) {
|
|
$subType = $parts[2];
|
|
$subResource = $parts[3];
|
|
}
|
|
|
|
if ($hasSubSubResource) {
|
|
$subSubType = $parts[4];
|
|
$subSubResource = $parts[5];
|
|
if ($count === 8) {
|
|
$attribute = $parts[7];
|
|
}
|
|
}
|
|
|
|
if ($hasSubResource && !$hasSubSubResource) {
|
|
if ($count === 6) {
|
|
$attribute = $parts[5];
|
|
}
|
|
}
|
|
|
|
if (!$hasSubResource) {
|
|
if ($count === 4) {
|
|
$attribute = $parts[3];
|
|
}
|
|
}
|
|
|
|
$subSubType ??= false;
|
|
$subSubResource ??= false;
|
|
$subType ??= false;
|
|
$subResource ??= false;
|
|
$attribute ??= false;
|
|
|
|
$action = match (true) {
|
|
!$hasSubResource && $count > 2 => $parts[2],
|
|
$hasSubSubResource => $parts[6] ?? false,
|
|
$hasSubResource && $count > 4 => $parts[4],
|
|
default => false
|
|
};
|
|
|
|
if (!\array_key_exists($type, $events)) {
|
|
return false;
|
|
}
|
|
|
|
if ($subType) {
|
|
if ($action && !\array_key_exists($action, $events[$type][$subType])) {
|
|
return false;
|
|
}
|
|
if (!($subResource) || !\array_key_exists($subType, $events[$type])) {
|
|
return false;
|
|
}
|
|
} else {
|
|
if ($action && !\array_key_exists($action, $events[$type])) {
|
|
return false;
|
|
}
|
|
}
|
|
|
|
if ($attribute) {
|
|
if (($subType)) {
|
|
if (!\array_key_exists($attribute, $events[$type][$subType][$action])) {
|
|
return false;
|
|
}
|
|
} else {
|
|
if (!\array_key_exists($attribute, $events[$type][$action])) {
|
|
return false;
|
|
}
|
|
}
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Is array
|
|
*
|
|
* Function will return true if object is array.
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function isArray(): bool
|
|
{
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Get Type
|
|
*
|
|
* Returns validator type.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getType(): string
|
|
{
|
|
return self::TYPE_STRING;
|
|
}
|
|
}
|