в его пакете или он должен внутри себя делать маппинг на какие-то бизнесовые сущности?
Ну у меня происходит маппинг
Т.е. у тебя модели слоя репозитория снаружи недоступны?
Не совсем понял, но модельки из дб никуда не гуляют — да
я всегда маплю на сущности из домена. Задача всех этих слоев - держать энтропию подальше от моего чистенькой классной бизнес-логики
Понял. Я просто обычно их маппинг на модели бизнес-логики делаю в сервисном слое
Но ведь появляется обратная зависимость слоя репозитория от слоя бизнес-логики
Просто в моём понимании ничего из infra не должно попасть в application; а уж тем более в domain. Ну соответственно если посмотреть импорты domain полностью самодостаточен в рамках своих границ, application юзает только домен и себя.
Т.е. смысл в том, чтобы слой бизнес-логики ничего ен импортировал из других слоёв? Просто направление импорта получается странным. Слой API импортирует модели из слоя бизнес-логики. А слой репозиторий, который находится ниже слоя бизнес-логики тоже импортирует модели из него
направленность таково domain(бизнес логика) -> application(распределительный пункт) -> infra(детали реализации и подобные темы) -> pres(взаимодействие с внешним миром)
А где тут слой работы с БД?
Смотрите, смысл в том, чтобы у вас бизнес-логика была написана максимально понятно и четко, и не знала ничего о внешнем мире. То есть в ней не должно быть ошметков от апи внешних сервисов, каких-то хттп-статусов, все типы должны быть максимально идиоматичны вашему приложению. Это значит, что всякие несоответствия и конвертации надо убирать максимально далеко от БЛ, то есть на слое транспорта/хранения
Это я всё понимаю - так и делаю. Вопрос именно в том, где правильно делать маппинг моделей слоя хранения на модели бизнес-логики. Я делаю в слое бизнес-логики, чтобы сохранить направление импорта. Но выглядит так, что может правильнее это делать в слое хранения. Но тогда направление импорта теряется, т.к. слой хранения будет импортировать модели слоя бизнес-логики
зачем слою бизнес-логики знать, что у вас в бд к примеру ююид хранится не юидом, а строкой?
У меня он не знает. Я такие модели объявляю прямо в методах слоя хранения, и маплю их там же на модели, возвращаемые наружу слоем хранения
ничего странного. Чистая архитектура
Обсуждают сегодня