mirror of
https://github.com/Respect/Validation.git
synced 2026-03-17 15:50:03 +01:00
That helps organize the code better, making it easier to spot the core rule. It also helps not allow the Factory to load those rules, as the new namespace is not registered in it. Note that the "AbstractAge", "AbstractRelated", and "AbstractRule" were not moved. I want to do that only when I refactor them. After I moved classes, I realized that "Comparison" and "FilteredString" had no tests. I created the tests, and while I did that, I spotted two bugs: * The "Equals" rule was failing when comparing non-scalar wth scalar values; * The "Equals" and "Identical" rules were not working correctly because "Comparison" was converting their values. I fixed those bugs in this commit. Signed-off-by: Henrique Moody <henriquemoody@gmail.com>
38 lines
803 B
PHP
38 lines
803 B
PHP
<?php
|
|
|
|
/*
|
|
* Copyright (c) Alexandre Gomes Gaigalas <alganet@gmail.com>
|
|
* SPDX-License-Identifier: MIT
|
|
*/
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace Respect\Validation\Rules;
|
|
|
|
use Psr\Http\Message\StreamInterface;
|
|
use Respect\Validation\Message\Template;
|
|
use Respect\Validation\Rules\Core\Simple;
|
|
use SplFileInfo;
|
|
|
|
use function is_readable;
|
|
use function is_string;
|
|
|
|
#[Template(
|
|
'{{name}} must be readable',
|
|
'{{name}} must not be readable',
|
|
)]
|
|
final class Readable extends Simple
|
|
{
|
|
public function validate(mixed $input): bool
|
|
{
|
|
if ($input instanceof SplFileInfo) {
|
|
return $input->isReadable();
|
|
}
|
|
|
|
if ($input instanceof StreamInterface) {
|
|
return $input->isReadable();
|
|
}
|
|
|
|
return is_string($input) && is_readable($input);
|
|
}
|
|
}
|