There are many micro-frameworks that rely on magic methods. We don't. In this document we're gonna explore the Respect\Validation API without fluent interfaces or magic methods. We'll use a traditional dependency injection approach.
use Respect\Validation\Validator as v;
$usernameValidator = v::alnum()->noWhitespace()->length(1,15);
$usernameValidator->validate('alganet'); //true
If you var_dump($usernameValidator)
, you'll see a composite of objects with
Respect\Validation\Rules\Alnum
, Respect\Validation\Rules\NoWhitespace
and
Respect\Validation\Rules\Length
. There is a specific object for each rule, and
the chain only builds the structure. You can build it by yourself:
use Respect\Validation\Rules;
$usernameValidator = new Rules\AllOf(
new Rules\Alnum(),
new Rules\NoWhitespace(),
new Rules\Length(1, 15)
);
$usernameValidator->validate('alganet'); //true
This is still a very lean API. You can use it in any dependency injection container or test it in the way you want. Nesting is still possible:
use Respect\Validation\Rules;
$usernameValidator = new Rules\AllOf(
new Rules\Alnum(),
new Rules\NoWhitespace(),
new Rules\Length(1, 15)
);
$userValidator = new Rules\Key('name', $usernameValidator);
$userValidator->validate(['name' => 'alganet']); //true
The Respect\Validation chain is an internal DSL. It acts in the creational realm of objects (where Abstract Factories and Builders live), and it's only job is to make rule construction terse and fluent.
Is
v
inv::something
a class name?
No! The class is Respect\Validation\Validator
, we suggest v
as a very short alias.
Is
v::something()
a static call?
Yes. Just like the default DateTime::createFromFormat()
or
Doctrine\ORM\Tools\Setup::createAnnotationMetadataConfiguration()
. It builds
something complex and returns for you.
I really don't like static calls, can I avoid it?
Yes. Just use $validator = new Validator();
each time you want a new validator,
and continue from there.
Do you have a static method for each rule?
No. We use __callStatic()
.
Magic methods are slow! Why do you use them?
They're optional. If you use the new
interface, they won't be called.
(still, do some benchmarks, you'd be surprised with our implementation).