структура User например чтобы ее создать у меня есть как водится функция-конструктор NewUser(args) которая создает User с различными проверками типа допустимость логина, почты, длина и сложность пароля и так далее. Тут все ясно. Вопрос вот в чем, если мне нужно создать ту же структуру но из БД то есть априори все поля уже естественно проверенные как поступать принято? Делать что-то типа NewUserFromDB? То есть получаем разные конструкторы/фабрики для создания сущности. Спасибо !
1. "априори" данные в БД непроверенные. Проверки в БД могут расходиться с проверками в коде из-за изменений и много чего ещё 2. Из пункта №1 следует, что конструктор сущности должен быть один, который проверяет все инварианты. Поверх него могут быть другие фабрики, в том числе репозиторий, который общается с БД и методами возвращает объекты типа User. То есть, в репо будет фабрика, которая маппит данные из БД в данные для конструктора NewUser
Добрый день, спасибо за ответ. Не совсем понятно как могт быть данные не проверенные в БД если при регистрации все данные проверяются. Теоритически конечно что-то может быть попрочено но это достаточно редкая ситуация, а проверки при получении из бд не пустая ли будет работа которая тратит ресурсы? Или я не понял Вас... Прошу прощения если глупый вопрос, только осваиваюсь ...
конструктор де факто не знает откуда к пришли данные. Сегодня они проверенные из базы, а завтра пришел чел и напилил кривой импорт или ручками "исправил" данные в бд
Это редкая ситуация — верно. Возможно, она не возникнет в проекте никогда. Но она бывает и от этого никто не защищён. Размер проекта, время его жизни и количество разработчиков прямопропорционально влияют на этот шанс. Проверка — не пустая трата ресурсов. Тем более, что мы экономим? Сто наносекунд?
Обсуждают сегодня