This package allows configuring validators with a new configuration type.
This package provides the SettingsValidator
which uses the configuration type Validation
to resolve the validators
that should be applied to the value. It distinguishes between validators that are applied to the value itself and its
properties.
The SettingsValidator
has an option name
. If it is set, the name is used to resolve the validation configuration,
otherwise the type of the value is used, which is mainly useful for objects where the FQCN is used.
To resolve the validation configuration by name just use the option name
.
/**
* @Flow\Validate(type="DigiComp.SettingValidator:Settings", options={"name"="MyNamedValidator"})
* @var MyObject
*/
protected MyObject $myObject;
The SettingsValidator
will search for an entry inside the Validation.yaml
with that name.
MyNamedValidator:
...
To resolve the validation configuration by type just do not set the option name
.
/**
* @Flow\Validate(type="DigiComp.SettingValidator:Settings")
* @var MyObject
*/
protected MyObject $myObject;
The SettingsValidator
will search for an entry inside the Validation.yaml
with the FQCN of MyObject
.
My\Package\Domain\Model\MyObject:
...
self
contains a map of validators that are applied to the value itself. properties
contains a map with property
names of the value you would like to validate and each entry contains a map of validators that are applied to that
property.
MyNamedValidator:
self:
...
properties:
myProperty1:
...
myProperty2:
...
To configure a validator you use the type of the validator as key and the options as entries of that key. If the validator has no options or all the default values are used, set an empty map as options.
MyNamedValidator:
self:
'My.Package:SomeValidator':
myOption: "myOptionValue"
properties:
myProperty1:
'My.Package:SomeOtherValidator': {}
myProperty2:
'My.Package:SomeOtherValidator': {}
To disable a validator you need to set the options to null
.
MyNamedValidator:
self:
'My.Package:SomeValidator': ~
The SettingsValidator
can be used to reduce the number of @Flow\Validate
annotations and gives you the possibility
of overwriting existing validation configurations in other packages.
Old PHP code:
/**
* @Flow\Validate(type="My.Package:SomeValidator", options={"myOption"="myOptionValue"})
* @Flow\Validate(type="My.Package:SomeOtherValidator")
* @var MyObject
*/
protected MyObject $myObject;
New PHP code:
/**
* @Flow\Validate(type="DigiComp.SettingValidator:Settings", options={"name"="MyNamedValidator"})
* @var MyObject
*/
protected MyObject $myObject;
New validation configuration:
MyNamedValidator:
self:
'My.Package:SomeValidator':
myOption: "myOptionValue"
'My.Package:SomeOtherValidator': {}
Old PHP code:
/**
* @Flow\Validate(argumentName="myObject", type="My.Package:SomeValidator", options={"myOption"="myOptionValue"})
* @Flow\Validate(argumentName="myObject", type="My.Package:SomeOtherValidator")
* @param MyObject $myObject
*/
public function myAction(MyObject $myObject)
{
...
}
New PHP code:
/**
* @Flow\Validate(argumentName="myObject", type="DigiComp.SettingValidator:Settings", options={"name"="MyNamedValidator"})
* @param MyObject $myObject
*/
public function myAction(MyObject $myObject)
{
...
}
New validation configuration:
MyNamedValidator:
self:
'My.Package:SomeValidator':
myOption: "myOptionValue"
'My.Package:SomeOtherValidator': {}
You can use the SettingsValidator
inside the validator configuration to easily construct flexible structures.
MyNamedValidator:
properties:
myProperty1:
'DigiComp.SettingValidator:Settings':
name: "MyOtherNamedValidator"
MyOtherNamedValidator:
self:
'My.Package:SomeOtherValidator': {}
It can be useful to provide an empty validator in code that is used by many projects. By doing so you can make sure that a different validation is possible in any project.
/**
* @Flow\Validate(argumentName="myObject", type="DigiComp.SettingValidator:Settings", options={"name"="MyNamedValidator"})
* @param MyObject $myObject
*/
public function myAction(MyObject $myObject)
{
...
}
MyNamedValidator: {}