Files
2025-10-08 11:39:17 -04:00

55 lines
1.7 KiB
PHP

<?php
/*
* This file is part of the Symfony package.
*
* (c) Fabien Potencier <fabien@symfony.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Symfony\Component\Validator\Constraints;
use Symfony\Component\Validator\Attribute\HasNamedArguments;
use Symfony\Component\Validator\Constraint;
use Symfony\Component\Validator\Exception\ConstraintDefinitionException;
/**
* Validates an object that needs to be traversed.
*
* @author Bernhard Schussek <bschussek@gmail.com>
*/
#[\Attribute(\Attribute::TARGET_CLASS)]
class Traverse extends Constraint
{
public bool $traverse = true;
/**
* @param bool|array<string,mixed>|null $traverse Whether to traverse the given object or not (defaults to true). Pass an associative array to configure the constraint's options (e.g. payload).
*/
#[HasNamedArguments]
public function __construct(bool|array|null $traverse = null, mixed $payload = null)
{
if (\is_array($traverse) && \array_key_exists('groups', $traverse)) {
throw new ConstraintDefinitionException(\sprintf('The option "groups" is not supported by the constraint "%s".', __CLASS__));
}
if (\is_array($traverse)) {
trigger_deprecation('symfony/validator', '7.3', 'Passing an array of options to configure the "%s" constraint is deprecated, use named arguments instead.', static::class);
}
parent::__construct($traverse, null, $payload);
}
public function getDefaultOption(): ?string
{
return 'traverse';
}
public function getTargets(): string|array
{
return self::CLASS_CONSTRAINT;
}
}