The Symfony Validator component includes some advanced constraints such as Callback (to implement custom validation rules), Sequentially (to apply a set of rules in order and interrupt them at any point), Compound (to create a set of reusable constraints), etc.
In Symfony 6.2 we're adding another advanced constraint to that list: When
,
which allows to implement conditional validations.
Consider a Discount
class with two properties:
// src/Model/Discount.php
namespace App\Model;
class Discount
{
private ?string $type;
private ?int $value;
// ...
}
To validate the object contents, you need to apply these rules:
- If
type
ispercent
, thenvalue
must be less than or equal100
; - If
type
isabsolute
, thenvalue
can be any value; - In all cases, the
value
must be greater than 0.
The new When
constraint defines tow main options called expression
and
constraints
. These constraints are only enforced when the result of evaluating
the expression is true
. You can use it as follows to validate that the
value
is less than 100
only if the discount type
is percent
:
use Symfony\Component\Validator\Constraints as Assert;
// ...
class Discount
{
#[Assert\GreaterThan(0)]
#[Assert\When(
expression: 'this.type == "percent"',
constraints: [
new Assert\LessThanOrEqual(100, message: 'The value should be between 1 and 100!')
],
)]
private ?int $value;
// ...
}
The condition passed to the expression
option must use the Symfony
ExpressionLanguage syntax. Inside the expression you can use the this
variable to refer to the object being validated and value
to refer to the
property being valuated (this is only available if you apply the When
constraint to properties).
Finally, you can combine When
with other advanced constraints such as Callback
to define complex conditional validations:
use Symfony\Component\Validator\Constraints as Assert;
use Symfony\Component\Validator\Context\ExecutionContextInterface;
class Discount
{
#[Assert\When(
expression: 'value == "percent"',
constraints: [new Assert\Callback('doComplexValidation')],
)]
private ?string $type;
// ...
}
<hr style="margin-bottom: 5px" />
<div style="font-size: 90%">
<a href="https://symfony.com/sponsor">Sponsor</a> the Symfony project.
</div>
Autentifică-te pentru a adăuga comentarii
Alte posturi din acest grup

Symfony 6.4.24 has just been released. Read the Symfony upgrade guide to learn more about upgrading Symfony and use the SymfonyInsight upgrade reports to detect the code you will need to change in you

Symfony 7.2.9 has just been released. Read the Symfony upgrade guide to learn more about upgrading Symfony and use the SymfonyInsight upgrade reports to detect the code you will need to change in your

Symfony 7.3.2 has just been released. Read the Symfony upgrade guide to learn more about upgrading Symfony and use the SymfonyInsight upgrade reports to detect the code you will need to change in your

This week, development focused on the upcoming Symfony 7.4 and 8.0 releases. We added new features such as the ObjectMapperAwareInterface, improved value transformers in JsonStreamer, and enabled load

Symfony is turning 20 and we’re throwing a party you won’t want to miss! 🥳
Join us for an unforgettable evening of drinks, music, and great company at the Kanarie Club in Amsterdam!
This year

This week, the upcoming Symfony 7.4 version improved the Serializer component by adding more prefix support to the accessor, added more code to make the JsonPath component RFC compliant, and added sup

This week, Symfony unveiled the Symfony AI initiative, a set of components and bundles designed to bring powerful AI capabilities directly into your PHP applications. In addition, we published travel