хидратор гидрирует, валидатор потом валидирует. Зачем отдельный компонент под эту задачу?
1) Сохранение результата валидации в самом объекте. Это позволит делать такие штуки: public function myAction(MyModel $model) { if ($model->getValidationResult()->isValid()) { ... } else { ... } } То есть модель сама наполнится, сама отвалидируется, а дальше уже мы работаем с результатом. 2) Атрибут, который позволяет валидировать исходные значения до типизации и присвоения значения. Например, при проверке на обязательность поля мы можем выдать разный текст ошибки, когда значение вообще не передали и когда значение передали, но оно пустое.
Спасибо. Вот именно это и хотелось в итоге получить)
Сейчас работаем над этим как раз :)
Вопрос в продолжение. На основе такой модели (в аргументе контроллера) нам необходимо не только провалидировать, но и сгенерить АПИ-документацию. Для этого надо поточнее "разметить" типы свойств класса. Желательно чем-то более-менее универсальным/унифицированным. Что-то типа такого: class Person { public function __construct( #[Type(Array<int, string>)] public array $names; #[Type(Array<string, Person>)] public array $children; ) { } } Это чем-то похоже на атрибуты phpstan. PHPDOC использовать не хочется, лучше PHP-атрибуты. Искал в интернете, ничего путёвого не нашёл. Сергей, я так понимаю, вы тоже будете размечать свойства класса атрибутами, но вроде специфичные атрибуты гидратора/валидатора?
Наверняка уже есть что-то универсальное? Атрибуты или аннотации. Можно будет сделать класс, который будет выполнять приведение в соответствии с ними
https://symfony.com/doc/current/components/property_info.html - может помочь
поддежривает док-блоки вида array<array-key, Post>
Почему не хотите использовать phpDoc? По факту их придется навесить чтоб psalm/ide понимала код
Спасибо. Вижу, что phpDoc поддерживает. Но в идеале хотелось именно php-атрибуты. У них поддержка нативная, и скорость повыше. И что главное, там структура более строгая.
Обсуждают сегодня