You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
408 lines
11 KiB
408 lines
11 KiB
<?php |
|
|
|
declare(strict_types=1); |
|
|
|
/** |
|
* This file is part of CodeIgniter 4 framework. |
|
* |
|
* (c) CodeIgniter Foundation <admin@codeigniter.com> |
|
* |
|
* For the full copyright and license information, please view |
|
* the LICENSE file that was distributed with this source code. |
|
*/ |
|
|
|
namespace CodeIgniter\Validation\StrictRules; |
|
|
|
use CodeIgniter\Validation\Rules as NonStrictRules; |
|
use Config\Database; |
|
|
|
/** |
|
* Validation Rules. |
|
* |
|
* @see \CodeIgniter\Validation\StrictRules\RulesTest |
|
*/ |
|
class Rules |
|
{ |
|
private NonStrictRules $nonStrictRules; |
|
|
|
public function __construct() |
|
{ |
|
$this->nonStrictRules = new NonStrictRules(); |
|
} |
|
|
|
/** |
|
* The value does not match another field in $data. |
|
* |
|
* @param array|bool|float|int|object|string|null $str |
|
* @param array $data Other field/value pairs |
|
*/ |
|
public function differs( |
|
$str, |
|
string $otherField, |
|
array $data, |
|
?string $error = null, |
|
?string $field = null |
|
): bool { |
|
if (strpos($otherField, '.') !== false) { |
|
return $str !== dot_array_search($otherField, $data); |
|
} |
|
|
|
if (! array_key_exists($field, $data)) { |
|
return false; |
|
} |
|
|
|
if (! array_key_exists($otherField, $data)) { |
|
return false; |
|
} |
|
|
|
return $str !== ($data[$otherField] ?? null); |
|
} |
|
|
|
/** |
|
* Equals the static value provided. |
|
* |
|
* @param array|bool|float|int|object|string|null $str |
|
*/ |
|
public function equals($str, string $val): bool |
|
{ |
|
return $this->nonStrictRules->equals($str, $val); |
|
} |
|
|
|
/** |
|
* Returns true if $str is $val characters long. |
|
* $val = "5" (one) | "5,8,12" (multiple values) |
|
* |
|
* @param array|bool|float|int|object|string|null $str |
|
*/ |
|
public function exact_length($str, string $val): bool |
|
{ |
|
if (is_int($str) || is_float($str)) { |
|
$str = (string) $str; |
|
} |
|
|
|
if (! is_string($str)) { |
|
return false; |
|
} |
|
|
|
return $this->nonStrictRules->exact_length($str, $val); |
|
} |
|
|
|
/** |
|
* Greater than |
|
* |
|
* @param array|bool|float|int|object|string|null $str expects int|string |
|
*/ |
|
public function greater_than($str, string $min): bool |
|
{ |
|
if (is_int($str) || is_float($str)) { |
|
$str = (string) $str; |
|
} |
|
|
|
if (! is_string($str)) { |
|
return false; |
|
} |
|
|
|
return $this->nonStrictRules->greater_than($str, $min); |
|
} |
|
|
|
/** |
|
* Equal to or Greater than |
|
* |
|
* @param array|bool|float|int|object|string|null $str expects int|string |
|
*/ |
|
public function greater_than_equal_to($str, string $min): bool |
|
{ |
|
if (is_int($str) || is_float($str)) { |
|
$str = (string) $str; |
|
} |
|
|
|
if (! is_string($str)) { |
|
return false; |
|
} |
|
|
|
return $this->nonStrictRules->greater_than_equal_to($str, $min); |
|
} |
|
|
|
/** |
|
* Checks the database to see if the given value exist. |
|
* Can ignore records by field/value to filter (currently |
|
* accept only one filter). |
|
* |
|
* Example: |
|
* is_not_unique[table.field,where_field,where_value] |
|
* is_not_unique[menu.id,active,1] |
|
* |
|
* @param array|bool|float|int|object|string|null $str |
|
*/ |
|
public function is_not_unique($str, string $field, array $data): bool |
|
{ |
|
if (is_object($str) || is_array($str)) { |
|
return false; |
|
} |
|
|
|
// Grab any data for exclusion of a single row. |
|
[$field, $whereField, $whereValue] = array_pad( |
|
explode(',', $field), |
|
3, |
|
null |
|
); |
|
|
|
// Break the table and field apart |
|
sscanf($field, '%[^.].%[^.]', $table, $field); |
|
|
|
$row = Database::connect($data['DBGroup'] ?? null) |
|
->table($table) |
|
->select('1') |
|
->where($field, $str) |
|
->limit(1); |
|
|
|
if ( |
|
$whereField !== null && $whereField !== '' |
|
&& $whereValue !== null && $whereValue !== '' |
|
&& ! preg_match('/^\{(\w+)\}$/', $whereValue) |
|
) { |
|
$row = $row->where($whereField, $whereValue); |
|
} |
|
|
|
return $row->get()->getRow() !== null; |
|
} |
|
|
|
/** |
|
* Value should be within an array of values |
|
* |
|
* @param array|bool|float|int|object|string|null $value |
|
*/ |
|
public function in_list($value, string $list): bool |
|
{ |
|
if (is_int($value) || is_float($value)) { |
|
$value = (string) $value; |
|
} |
|
|
|
if (! is_string($value)) { |
|
return false; |
|
} |
|
|
|
return $this->nonStrictRules->in_list($value, $list); |
|
} |
|
|
|
/** |
|
* Checks the database to see if the given value is unique. Can |
|
* ignore a single record by field/value to make it useful during |
|
* record updates. |
|
* |
|
* Example: |
|
* is_unique[table.field,ignore_field,ignore_value] |
|
* is_unique[users.email,id,5] |
|
* |
|
* @param array|bool|float|int|object|string|null $str |
|
*/ |
|
public function is_unique($str, string $field, array $data): bool |
|
{ |
|
if (is_object($str) || is_array($str)) { |
|
return false; |
|
} |
|
|
|
[$field, $ignoreField, $ignoreValue] = array_pad( |
|
explode(',', $field), |
|
3, |
|
null |
|
); |
|
|
|
sscanf($field, '%[^.].%[^.]', $table, $field); |
|
|
|
$row = Database::connect($data['DBGroup'] ?? null) |
|
->table($table) |
|
->select('1') |
|
->where($field, $str) |
|
->limit(1); |
|
|
|
if ( |
|
$ignoreField !== null && $ignoreField !== '' |
|
&& $ignoreValue !== null && $ignoreValue !== '' |
|
&& ! preg_match('/^\{(\w+)\}$/', $ignoreValue) |
|
) { |
|
$row = $row->where("{$ignoreField} !=", $ignoreValue); |
|
} |
|
|
|
return $row->get()->getRow() === null; |
|
} |
|
|
|
/** |
|
* Less than |
|
* |
|
* @param array|bool|float|int|object|string|null $str expects int|string |
|
*/ |
|
public function less_than($str, string $max): bool |
|
{ |
|
if (is_int($str) || is_float($str)) { |
|
$str = (string) $str; |
|
} |
|
|
|
if (! is_string($str)) { |
|
return false; |
|
} |
|
|
|
return $this->nonStrictRules->less_than($str, $max); |
|
} |
|
|
|
/** |
|
* Equal to or Less than |
|
* |
|
* @param array|bool|float|int|object|string|null $str expects int|string |
|
*/ |
|
public function less_than_equal_to($str, string $max): bool |
|
{ |
|
if (is_int($str) || is_float($str)) { |
|
$str = (string) $str; |
|
} |
|
|
|
if (! is_string($str)) { |
|
return false; |
|
} |
|
|
|
return $this->nonStrictRules->less_than_equal_to($str, $max); |
|
} |
|
|
|
/** |
|
* Matches the value of another field in $data. |
|
* |
|
* @param array|bool|float|int|object|string|null $str |
|
* @param array $data Other field/value pairs |
|
*/ |
|
public function matches( |
|
$str, |
|
string $otherField, |
|
array $data, |
|
?string $error = null, |
|
?string $field = null |
|
): bool { |
|
if (strpos($otherField, '.') !== false) { |
|
return $str === dot_array_search($otherField, $data); |
|
} |
|
|
|
if (! array_key_exists($field, $data)) { |
|
return false; |
|
} |
|
|
|
if (! array_key_exists($otherField, $data)) { |
|
return false; |
|
} |
|
|
|
return $str === ($data[$otherField] ?? null); |
|
} |
|
|
|
/** |
|
* Returns true if $str is $val or fewer characters in length. |
|
* |
|
* @param array|bool|float|int|object|string|null $str |
|
*/ |
|
public function max_length($str, string $val): bool |
|
{ |
|
if (is_int($str) || is_float($str) || null === $str) { |
|
$str = (string) $str; |
|
} |
|
|
|
if (! is_string($str)) { |
|
return false; |
|
} |
|
|
|
return $this->nonStrictRules->max_length($str, $val); |
|
} |
|
|
|
/** |
|
* Returns true if $str is at least $val length. |
|
* |
|
* @param array|bool|float|int|object|string|null $str |
|
*/ |
|
public function min_length($str, string $val): bool |
|
{ |
|
if (is_int($str) || is_float($str)) { |
|
$str = (string) $str; |
|
} |
|
|
|
if (! is_string($str)) { |
|
return false; |
|
} |
|
|
|
return $this->nonStrictRules->min_length($str, $val); |
|
} |
|
|
|
/** |
|
* Does not equal the static value provided. |
|
* |
|
* @param array|bool|float|int|object|string|null $str |
|
*/ |
|
public function not_equals($str, string $val): bool |
|
{ |
|
return $this->nonStrictRules->not_equals($str, $val); |
|
} |
|
|
|
/** |
|
* Value should not be within an array of values. |
|
* |
|
* @param array|bool|float|int|object|string|null $value |
|
*/ |
|
public function not_in_list($value, string $list): bool |
|
{ |
|
if (null === $value) { |
|
return true; |
|
} |
|
|
|
if (is_int($value) || is_float($value)) { |
|
$value = (string) $value; |
|
} |
|
|
|
if (! is_string($value)) { |
|
return false; |
|
} |
|
|
|
return $this->nonStrictRules->not_in_list($value, $list); |
|
} |
|
|
|
/** |
|
* @param array|bool|float|int|object|string|null $str |
|
*/ |
|
public function required($str = null): bool |
|
{ |
|
return $this->nonStrictRules->required($str); |
|
} |
|
|
|
/** |
|
* The field is required when any of the other required fields are present |
|
* in the data. |
|
* |
|
* Example (field is required when the password field is present): |
|
* |
|
* required_with[password] |
|
* |
|
* @param array|bool|float|int|object|string|null $str |
|
* @param string|null $fields List of fields that we should check if present |
|
* @param array $data Complete list of fields from the form |
|
*/ |
|
public function required_with($str = null, ?string $fields = null, array $data = []): bool |
|
{ |
|
return $this->nonStrictRules->required_with($str, $fields, $data); |
|
} |
|
|
|
/** |
|
* The field is required when all the other fields are present |
|
* in the data but not required. |
|
* |
|
* Example (field is required when the id or email field is missing): |
|
* |
|
* required_without[id,email] |
|
* |
|
* @param array|bool|float|int|object|string|null $str |
|
* @param string|null $otherFields The param fields of required_without[]. |
|
* @param string|null $field This rule param fields aren't present, this field is required. |
|
*/ |
|
public function required_without( |
|
$str = null, |
|
?string $otherFields = null, |
|
array $data = [], |
|
?string $error = null, |
|
?string $field = null |
|
): bool { |
|
return $this->nonStrictRules->required_without($str, $otherFields, $data, $error, $field); |
|
} |
|
}
|
|
|