Привет. Кто-нибудь может подсказатьк ак организовать бизнес логику в крупном

проекте? Пришел к тому что чего-то мне не хватает - не очень удобно становится.

Сейчас: контроллеры тонкие, вся логика лежит в сервисах, выбор данных через репозитории. В Entity только геттеры и сеттеры, и мунимум какой-то логики связаной непосредственно с сущностью.

В этом всем смущает один момент - сервисы стали какими-то очень громоздкими, умеющими во все. Я чую что это не очень нормально.

Например естьт сервис для работы с документами, я вызываю отдельные мтоды этого сервиса и каждый раз передаю экземпляр объекта в метод. И еще есть методы работающие с массивами объектов. Т.е. уже можно было бы завести пару классов рабюотающих с массивами данных обектов и с отдельными экзмеплярами данных объектов. Правильно я рассуждаю? На что еще можно обратить внимание?

1 ответов

6 просмотров

1. В крупном проекте важна декомпозиция и изоляция фич 2. Неправильное разбиение стэйта (границы сущностей) приводит к проблемам со связанносьтью и потерей той самой изоляции 3. Дробить *правильно* сложно и ты будешь ошибаться 4. Тесты - эт пиздец важно.

Похожие вопросы

Обсуждают сегодня

Можно ли загрузить скрипт py в бота чтобы он работал по нему? как это сделать?
huskadam #RCC Фанат? @hitlerpvp
13
'frakturBold' => ['𝖆', '𝖇', '𝖈', '𝖉', '𝖊', '𝖋', '𝖌', '𝖍', '𝖎', '𝖏', '𝖐', '𝖑', '𝖒', '𝖓', '𝖔', '𝖕', '𝖖', '𝖗', '𝖘', '𝖙', '𝖚', '𝖛', '𝖜', '𝖝', '𝖞', '𝖟', '𝕬', '𝕭', '𝕮', '𝕯'...
Roma
4
Ребят, а за скок можно впарить анон чат с апишкой и веб админкой ?
Eugene Неелов
15
Добрый день, не подскажите, если в OC-V3 поменять страндартную директорию /storage/ на /storage2/ - не будет сильно много проблем ?
Max Dubovsky
32
Всем привет! Напишите пожалуйста, кто мог бы оффлайн преподавать некоторые курсы по Odoo в Алматы в одном из ВУЗов? Мы сейчас вместе с Odoo запускаем университетскую программу...
Adil Dauletkhan
2
Ты просто гитлеровскую эстетику плохо понимаешь. Он же всё под Цезаря делал. А это как бы запрещённый приём в политике. Пиджаки они зачем все носят? Чтобы показать что они тип...
Ivan Kropotkin
4
Каким то образом можно определить ширину экрана пользователя перед загрузкой partial-а? Надо рассчитать ширину кадров слайдера для ресайза картинок для container-fluid.
Point 111
22
Добрый день, подскажите как правильно сделать filter в backend-e. Есть модель (товар) у который связь belongsToMany (компания), компаний > 4k, поэтому выборку типа ->all(); н...
Max Dubovsky
7
А как заставить поиск искать? Есть такая формочка <select class="form-control custom-select" name="brand_id" data-handler="onGetBrands"></select>
Денис Александрович
5
с помощью чего можно бота добавить как админа в чат? (условно в боте есть кнопка, нажатие на которую приводит тебя к выбору чата и выдаче прав боту)
ηє νєямσяє
5
Карта сайта