Здарова всем! Подскажите, плиз, где лучше размещать логику приложения в

симфонии? Логика по типу: кастомная авторизация и прочее. В сервисах подойдёт?

26 ответов

23 просмотра

На первое время да. Главное не забывать про SOLID. Особенно про последнюю букву.

Даня- Автор вопроса
Даня
Что значит на первое время?

Всё от сложности проекта зависит. Мб тебе и этого станет вполне достаточно. Но если нет, то на горизонте DDD и вот это вот всё.

Даня- Автор вопроса
Nikolay Deriglazov
Всё от сложности проекта зависит. Мб тебе и этого ...

Редактирование, Удаление, Создание - чего-то Регистрация, Авторизация, Восстановление пароля

Даня- Автор вопроса

Смотри как у меня было в своём фрейме: В папке app -> Services Я создавал папку с функционалом, например Track и в этой папке я создал уже сервисы: AddTrackService, AddSubtitlesService и т.д., но из-за того что я не сделал реализацию кастомных окружений тесты написать под апи не могу и пришлось на симфони переезжать и сейчас нужно будет переписать более 30к кода и вот сейчас думаю как это будет лучше сделать, чтоб потом не делать большой рефакторинг

Даня
Смотри как у меня было в своём фрейме: В папке app...

В целом у вас норм, если вы понимаете, что это у вас это сервисы приложения (есть сервисы домена, а есть приложения). На 100 сообщений выше было общение про разделение на контексты и юзкейсы (ваши сервисы) в них . Один из вариантов - вот такой https://github.com/ElisDN/demo-project-manager/tree/master/manager

Даня
Папка Service ?

Название спорное, потому что могут потом возникнуть проблемы, как называть и какую папку выделить под сервисы домена, или какие то другие сервисы (аплоадеры например, обработчики картинок)

Даня- Автор вопроса
Павел Г.
Название спорное, потому что могут потом возникнут...

https://github.com/codememory1/music-service у меня сделано сейчас так, т.е., общие сервисы я выношу в ./ а под другое создаю папки в сервисе

Даня
https://github.com/codememory1/music-service у мен...

Пример выше скинул, как пишут некоторые на симфони, сравнивайте :)

Даня
https://github.com/codememory1/music-service у мен...

В первом же попавшемся мне конструкторе вижу высокий каплинг. Вы же говорили, что знаете что означает D в контексте абривеатуры SOLID?

Даня- Автор вопроса
Nikolay Deriglazov
screenshot В первом же попавшемся мне конструкторе вижу высок...

Этот пакет был сделан на скорую руку, чтоб иметь возможность разделить логику от контроллеров

Nikolay Deriglazov
screenshot В первом же попавшемся мне конструкторе вижу высок...

Человек на обмазался везде интерфейсами, все, плохлой проект, SOLID упал?

Nikolay Deriglazov
screenshot Как ты на это напишешь юнит-тест?

Я не буду писать юнит на юзкейс

Даня- Автор вопроса
Nikolay Deriglazov
screenshot Как ты на это напишешь юнит-тест?

А то, что там repository в конструкторе инициализируются, что тут плохого? Мне его в методе инициализировать, а потом делать по 100 параметров ?

Даня
А то, что там repository в конструкторе инициализи...

В том, что этот сервис - такой же юнит как и любой другой класс системы. И он должен быть тестируемым. Если он тестируем обычным юнит-тестом - то у него нет высокого каплинга.

Даня- Автор вопроса
Nikolay Deriglazov
В том, что этот сервис - такой же юнит как и любой...

Ммм… Интересно, а зачем писать тест на api маршрут, а потом писать на сервис, который вызывается в маршруте, который уже протестирован ?

Nikolay Deriglazov
В том, что этот сервис - такой же юнит как и любой...

Любой класс можно протестить юнтом, вопрос лишь от боли в моках и сложности логики. Причем тут каплинг? Если был бы интерфейс, что бы это дало в тесте?

Павел Г.
Любой класс можно протестить юнтом, вопрос лишь от...

Я еще понимаю, языки где дне нельзя сделать мок без интерфейса. У нас то можно

Nikolay Deriglazov
screenshot Как ты на это напишешь юнит-тест?

findById() по любому в абстрактном лежит, а не в вашем

Даня- Автор вопроса
Даня
Верно

Это уже нужно смотреть пакет codememory/orm

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

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

Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
сделал сайт, прикрутил в боте сайт, и виджет логина. как автоматически логинить пользователя в аккаунт(телеграм), при входе с бота?
Александра Чернивецкая
5
Объясните, пожалуйста, почему компилятор ругается на использование в условии неинициализированной переменной: int x; Task.Run(async () => { x = await somefunc(); }).Wait...
Александр
5
Ребят, подскажите, пожалуйста, почему в префиксе к ассетам, которые генерируются через фильтр | theme в шаблоне, стал вдруг появляться index.php? Вот так выглядит ссылка на а...
Виталий
1
Всем привет. Ребята, подскажите, пожалуйста. у ботов есть ограничение на отправку сообщений - 30 сообщений в секунду, эти ограничения накладываются на все сообщения? или на со...
Artem Stormageddon
4
Блин, ребята, сори за тупые вопросы. А можно ли как-то открыть вебапку по нажатию на кнопку в меню(которое появляется слева, команды)?
Artem Stormageddon
3
а плаксы из-под питона умеют только в комфортных условиях что-то выдавить из себя?)
Lencore
9
Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
13
Это может быть все-таки не флудвейт? у меня ботфазер принимает изменения и отображает даже что они изменились, на видео видно что он прислал якобы уже измененное описание, н...
OVERLINK
13
Коллеги, может знает кто, можно ли цвет бейджа счётчика в BackendMenu менять без бубнов?
Alex Blaze
3
Карта сайта