1
0
قرینه از https://github.com/matomo-org/matomo.git synced 2025-08-21 22:47:43 +00:00
Files
matomo/core/Validators/BaseValidator.php
Michal Kleiner 9a3ef94df6 [Coding Style] Enable rule PSR12.Files.FileHeader + unify file headers (#22132)
* [Coding Style] Enable rule PSR12.Files.FileHeader

* Apply CS

* Replace Piwik with Matomo in file headers

* Unify file headers (position, no. of lines, https links)

* Rebuild dist files

* Apply CS

* Fix system test that relies on line numbers in a file that had the file header updated

---------

Co-authored-by: Stefan Giehl <stefan@matomo.org>
2024-04-20 20:50:47 +02:00

48 خطوط
1.4 KiB
PHP

<?php
/**
* Matomo - free/libre analytics platform
*
* @link https://matomo.org
* @license https://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
*/
namespace Piwik\Validators;
abstract class BaseValidator
{
/**
* The method to validate a value. If the value has not an expected format, an instance of
* {@link Piwik\Validators\Exception} should be thrown.
*
* @param $value
* @throws Exception
*/
abstract public function validate($value);
protected function isValueBare($value)
{
// we allow this value. if it is supposed to be not empty, please use NotEmpty validator on top
return $value === false || $value === null || $value === '';
}
/**
* Lets you easily check a value against multiple validators.
*
* @param string $name The name/description of the field you want to validate the value for.
* The name will be prefixed in case there is any error.
* @param mixed $value The value which needs to be tested
* @param BaseValidator[] $validators
*/
public static function check($name, $value, $validators)
{
foreach ($validators as $validator) {
try {
$validator->validate($value);
} catch (\Exception $e) {
throw new Exception(strip_tags($name) . ': ' . $e->getMessage(), $e->getCode());
}
}
}
}