Актуальность вариантов использования чистой архитектуры / уровень домена
В течение нескольких лет я читал статьи об Android Architecture и Clean Architecture.
В чистой архитектуре у нас обычно есть 3 уровня: Презентация (содержащая MVVM/MVP) - Домен (содержащий POJO и UseCases/Interactors) - Данные (содержащие реализацию репозиториев)
В проектах Android часто есть только 2 уровня: уровень представления, содержащий материалы MVVM, и уровень данных с репозиториями. Доступ к репозиториям осуществляется напрямую из ViewModel, а данные обрабатываются в ViewModel перед передачей их в View.
Итак, мой вопрос: какова цель UseCases / Interactors на Android? Они актуальны или могут быть полностью интегрированы в Android ViewModel?
1 ответ
Это зависит от того, как вы смотрите свое приложение для Android. Если приложение представляет собой чисто видовой слой, то нет, они не особо актуальны. Если вы используете его как нечто большее, чем слой представления, а вместо этого являетесь клиентским приложением, тогда вам лучше создать целое новое многоуровневое приложение, а не пропускать варианты использования и модели чистой архитектуры.
Когда это сделать, это чисто суждение. Для приложений, которые имеют только тривиальную логику и используются в основном в качестве механизма представления, со всей соответствующей серверной стороной бизнес-логики, тогда вы, вероятно, можете обойтись без модели представления. Многие приложения имеют столько же или больше сложностей на стороне клиента, чем на стороне сервера, и в этот момент вы захотите спроектировать их так, чтобы система масштабировалась и поддерживалась.
Если вы задаетесь вопросом, где находятся ваши UseCases, то вы, вероятно, перешли этот порог и должны разработать его как свое собственное приложение.