Skip to content

Commit

Permalink
Feat: Adding multiple from version 0.33
Browse files Browse the repository at this point in the history
  • Loading branch information
byawitz committed Jul 19, 2024
1 parent c27a91d commit f355e93
Showing 1 changed file with 115 additions and 0 deletions.
115 changes: 115 additions & 0 deletions src/Http/Validator/Multiple.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,115 @@
<?php

namespace Utopia\Http\Validator;

use Utopia\Http\Validator;

/**
* Multiple
*
* Multiple validator is a container of multiple validations each acting as a rule.
*
* @package Utopia\Validator
*/
class Multiple extends Validator
{
/**
* @var Validator[]
*/
protected $rules = [];

protected $type = self::TYPE_MIXED;

/**
* Constructor
*
* Multiple constructor can get any number of arguments containing Validator instances using PHP func_get_args function.
*
* Example:
*
* $multiple = new Multiple([$validator1, $validator2]);
* $multiple = new Multiple([$validator1, $validator2, $validator3], self::TYPE_STRING);
*/
public function __construct(array $rules, ?string $type = self::TYPE_MIXED)
{
foreach ($rules as $rule) {
$this->addRule($rule);
}

$this->type = $type;
}
/**
* Add rule
*
* Add a new rule to the end of the rules containing array
*
* @param Validator $rule
* @return $this
*/
public function addRule(Validator $rule)
{
$this->rules[] = $rule;

return $this;
}

/**
* Get Description
*
* Returns validator description
*
* @return string
*/
public function getDescription(): string
{
$description = '';
foreach ($this->rules as $key => $rule) {
$description .= ++$key . '. ' . $rule->getDescription() . " \n";
}

return $description;
}

/**
* Is valid
*
* Validation will pass when all rules are valid if only one of the rules is invalid validation will fail.
*
* @param mixed $value
* @return bool
*/
public function isValid(mixed $value): bool
{
foreach ($this->rules as $rule) { /* @var $rule Validator */
if (false === $rule->isValid($value)) {
return false;
}
}

return true;
}

/**
* Get Type
*
* Returns validator type.
*
* @return string
*/
public function getType(): string
{
return $this->type;
}

/**
* Is array
*
* Function will return true if object is array.
*
* @return bool
*/
public function isArray(): bool
{
return true;
}
}

0 comments on commit f355e93

Please sign in to comment.