2022-04-04 18:30:07 +12:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Appwrite\Event\Validator;
|
|
|
|
|
2022-04-21 01:34:55 +12:00
|
|
|
use Utopia\Config\Config;
|
2022-04-04 18:30:07 +12:00
|
|
|
use Utopia\Validator;
|
|
|
|
|
|
|
|
class Event extends Validator
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Get Description.
|
|
|
|
*
|
|
|
|
* Returns validator description
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getDescription(): string
|
|
|
|
{
|
2022-04-19 04:21:45 +12:00
|
|
|
return 'Event is not valid.';
|
2022-04-04 18:30:07 +12:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Is valid.
|
|
|
|
*
|
|
|
|
* @param mixed $value
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function isValid($value): bool
|
|
|
|
{
|
2022-04-21 01:34:55 +12:00
|
|
|
$events = Config::getParam('events', []);
|
2022-04-04 18:30:07 +12:00
|
|
|
$parts = \explode('.', $value);
|
|
|
|
$count = \count($parts);
|
|
|
|
|
2022-06-22 22:51:49 +12:00
|
|
|
if ($count < 2 || $count > 7) {
|
2022-04-04 18:30:07 +12:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2022-04-19 04:21:45 +12:00
|
|
|
* Identify all sections of the pattern.
|
2022-04-04 18:30:07 +12:00
|
|
|
*/
|
|
|
|
$type = $parts[0] ?? false;
|
|
|
|
$resource = $parts[1] ?? false;
|
2022-04-21 01:34:55 +12:00
|
|
|
$hasSubResource = $count > 3 && ($events[$type]['$resource'] ?? false) && ($events[$type][$parts[2]]['$resource'] ?? false);
|
2022-06-22 22:51:49 +12:00
|
|
|
$hasSubSubResource = $count > 5 && $hasSubResource && ($events[$type][$parts[2]][$parts[4]]['$resource'] ?? false);
|
2022-04-04 18:30:07 +12:00
|
|
|
|
|
|
|
if (!$type || !$resource) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($hasSubResource) {
|
|
|
|
$subType = $parts[2];
|
|
|
|
$subResource = $parts[3];
|
2022-06-22 22:51:49 +12:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($hasSubSubResource) {
|
|
|
|
$subSubType = $parts[4];
|
|
|
|
$subSubResource = $parts[5];
|
|
|
|
if ($count === 8) {
|
|
|
|
$attribute = $parts[7];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($hasSubResource && !$hasSubSubResource) {
|
2022-04-04 18:30:07 +12:00
|
|
|
if ($count === 6) {
|
|
|
|
$attribute = $parts[5];
|
|
|
|
}
|
2022-06-22 22:51:49 +12:00
|
|
|
}
|
|
|
|
|
|
|
|
if (!$hasSubResource) {
|
2022-04-04 18:30:07 +12:00
|
|
|
if ($count === 4) {
|
|
|
|
$attribute = $parts[3];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-06-22 22:51:49 +12:00
|
|
|
$subSubType ??= false;
|
|
|
|
$subSubResource ??= false;
|
2022-04-04 18:30:07 +12:00
|
|
|
$subType ??= false;
|
|
|
|
$subResource ??= false;
|
|
|
|
$attribute ??= false;
|
2022-04-19 04:21:45 +12:00
|
|
|
|
2022-04-04 18:30:07 +12:00
|
|
|
$action = match (true) {
|
|
|
|
!$hasSubResource && $count > 2 => $parts[2],
|
2022-06-22 22:51:49 +12:00
|
|
|
$hasSubSubResource => $parts[6] ?? false,
|
2022-04-04 18:30:07 +12:00
|
|
|
$hasSubResource && $count > 4 => $parts[4],
|
|
|
|
default => false
|
|
|
|
};
|
|
|
|
|
2022-04-21 01:34:55 +12:00
|
|
|
if (!\array_key_exists($type, $events)) {
|
2022-04-04 18:30:07 +12:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2022-05-11 01:03:34 +12:00
|
|
|
if ($subType) {
|
2022-04-21 01:34:55 +12:00
|
|
|
if ($action && !\array_key_exists($action, $events[$type][$subType])) {
|
|
|
|
return false;
|
|
|
|
}
|
2022-05-11 01:03:34 +12:00
|
|
|
if (!($subResource) || !\array_key_exists($subType, $events[$type])) {
|
2022-04-21 01:34:55 +12:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if ($action && !\array_key_exists($action, $events[$type])) {
|
2022-04-04 18:30:07 +12:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-05-11 01:03:34 +12:00
|
|
|
if ($attribute) {
|
|
|
|
if (($subType)) {
|
2022-05-09 02:31:32 +12:00
|
|
|
if (!\array_key_exists($attribute, $events[$type][$subType][$action])) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if (!\array_key_exists($attribute, $events[$type][$action])) {
|
|
|
|
return false;
|
|
|
|
}
|
2022-04-04 18:30:07 +12:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
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;
|
|
|
|
}
|
|
|
|
}
|