respect-validation/library/Rules/Decimal.php
Henrique Moody 7f66bcea10
Bump PHP support from 8.1 to 8.5
We want to release version 3.0 as fresh as possible, without having to
maintain backward compatibility with the previous versions. Because that
version will be on for some time, we decided it will be best to support
only PHP version 8.5 or higher.

Acked-by: Alexandre Gomes Gaigalas <alganet@gmail.com>
2025-12-18 19:03:38 +01:00

68 lines
1.6 KiB
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\Result;
use Respect\Validation\Rule;
use function is_numeric;
use function is_string;
use function number_format;
use function preg_replace;
use function var_export;
#[Attribute(Attribute::TARGET_PROPERTY | Attribute::IS_REPEATABLE)]
#[Template(
'{{name}} must have {{decimals}} decimals',
'{{name}} must not have {{decimals}} decimals',
)]
final readonly class Decimal implements Rule
{
public function __construct(
private int $decimals
) {
}
public function evaluate(mixed $input): Result
{
$parameters = ['decimals' => $this->decimals];
if (!is_numeric($input)) {
return Result::failed($input, $this, $parameters);
}
return new Result($this->isValidDecimal($input), $input, $this, $parameters);
}
private function isValidDecimal(mixed $input): bool
{
return $this->toFormattedString($input) === $this->toRawString($input);
}
private function toRawString(mixed $input): string
{
if (is_string($input)) {
return $input;
}
return var_export($input, true);
}
private function toFormattedString(mixed $input): string
{
$formatted = number_format((float) $input, $this->decimals, '.', '');
if (is_string($input)) {
return $formatted;
}
return preg_replace('/^(\d+\.\d)0*$/', '$1', $formatted) ?: '';
}
}