mirror of
https://github.com/Respect/Validation.git
synced 2026-03-16 15:25:45 +01:00
There's no reason not to make this method public. It will actually be easier for users to test their rules when they extend this class if this method is public.
45 lines
953 B
PHP
45 lines
953 B
PHP
<?php
|
|
|
|
/*
|
|
* Copyright (c) Alexandre Gomes Gaigalas <alganet@gmail.com>
|
|
* SPDX-License-Identifier: MIT
|
|
*/
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace Respect\Validation\Rules;
|
|
|
|
use Attribute;
|
|
use Respect\Validation\Message\Template;
|
|
use Respect\Validation\Rules\Core\Simple;
|
|
|
|
use function ceil;
|
|
use function is_numeric;
|
|
use function sqrt;
|
|
|
|
#[Attribute(Attribute::TARGET_PROPERTY | Attribute::IS_REPEATABLE)]
|
|
#[Template(
|
|
'{{name}} must be a prime number',
|
|
'{{name}} must not be a prime number',
|
|
)]
|
|
final class PrimeNumber extends Simple
|
|
{
|
|
public function isValid(mixed $input): bool
|
|
{
|
|
if (!is_numeric($input) || $input <= 1) {
|
|
return false;
|
|
}
|
|
|
|
if ($input != 2 && ($input % 2) == 0) {
|
|
return false;
|
|
}
|
|
|
|
for ($i = 3; $i <= ceil(sqrt((float) $input)); $i += 2) {
|
|
if ($input % $i == 0) {
|
|
return false;
|
|
}
|
|
}
|
|
|
|
return true;
|
|
}
|
|
}
|