Уроки по Android Clean Architecture, слой DATA на практике

แชร์
ฝัง
  • เผยแพร่เมื่อ 19 ม.ค. 2025

ความคิดเห็น • 146

  • @TimofeyKovalenko
    @TimofeyKovalenko  3 ปีที่แล้ว +7

    СОДЕРЖАНИЕ:
    00:00:00 - что такое слой DATA
    00:00:33 - кратко про предыдущий урок
    00:03:17 - диаграмма Clean Architecture
    00:05:09 - паттерн Repository на практике
    00:09:19 - правильная связь Domain c Data
    00:22:09 - пишем внутрянку для Repository
    00:33:18 - кратко о том, что мы сделали в уроке
    00:35:17 - подводим итоги и ставим лайки :)
    На канале также есть и другие уроки по Android Clean Architecture.

  • @f.uckeng
    @f.uckeng 2 ปีที่แล้ว +20

    боже храни тебя Всевышний за то, что ты умеешь так грамотно подходить к материалу и подавать его!

  • @KirillAndreevich-c9w
    @KirillAndreevich-c9w 3 ปีที่แล้ว +8

    Оуууууу еееее! Ну наконец-то дядю Боба кто-то доходчиво объясняет в ютубе!!! Жду модульность, тесты, маппинг, асинхронщину и MVVM :D

    • @kafychannel
      @kafychannel 3 ปีที่แล้ว

      Чел, поддерживаю, очень этого жду, не хочешь списаться в телеге, может быть пообщаемся об андроиде, если будет интересно, пиши - @kostiggig

    • @KirillAndreevich-c9w
      @KirillAndreevich-c9w 3 ปีที่แล้ว

      @bitmap Да, Боб Мартин. У него помимо "Clean code" есть статьи по архитектуре, собственно откуда все эти слои и пошли а также его книга "Clean architecture". Также есть адаптированный вариант для андроида у Фернандо Седжаса.

  • @sergomachine8927
    @sergomachine8927 4 หลายเดือนก่อน +1

    🔥🔥🔥 какая же это сложная тема и как все становится понятно после твоих роликов, долгих лет жизни, святой ты человек❤

  • @АлександрТюрин-ы1и
    @АлександрТюрин-ы1и 3 ปีที่แล้ว +9

    Тимофей, как обычно, Ваши видео просто супер. Для начинающих разработчиков Clean Architecture одна из самых тяжёлых и непонятных тем. Жду продолжения. Удачи!

  • @sergeyorlovskiy3537
    @sergeyorlovskiy3537 3 ปีที่แล้ว +1

    Супер объяснение! Все ваши видео в захлеб смотрю, до этого сколько не смотрел по чистой архитектуре, ничего не понятно было - с вашей помощью со всем разобрался!

  • @oleg12395
    @oleg12395 2 ปีที่แล้ว +3

    Большое спасибо ! С интерфейсом и двумя репозиториями, от души !!! Очень ценный материал !

  • @AndrewMatusevich
    @AndrewMatusevich ปีที่แล้ว

    Как глоток свежего воздуха. Честно. Спасибо!

  • @artlinestudio6735
    @artlinestudio6735 7 หลายเดือนก่อน

    Тимофей, уважаемый Тимофей. Огромное вам спасибо. Вы великолепный преподаватель! Потрясающе интересные уроки. Желаю вам и вашим родным, крепкого здоровья и настоящего счастья!

  • @antonfcss
    @antonfcss 2 ปีที่แล้ว +1

    Спасибо большое за ваша видео, очень помогает! В начинаниях в Android Development

  • @beckaksel8783
    @beckaksel8783 ปีที่แล้ว +1

    Спасибо большое за такое понятное объяснение!)

  • @mraleks4474
    @mraleks4474 ปีที่แล้ว

    автора приятно слушать. последовательный курс будет отличным практическим дополнение к печатной литературе по теме. спасибо

  • @dervanowsky
    @dervanowsky 3 ปีที่แล้ว +1

    Очень классно разжевано! Продолжайте еще!

  • @b.shpanchuk
    @b.shpanchuk 3 ปีที่แล้ว +2

    Уроки просто супер!!! Лайк и ждем продолжение :)

  • @azatsabirov863
    @azatsabirov863 3 ปีที่แล้ว +2

    Спасибо. Лучшего ресурса по архитектуре я еще не встречал

    • @neuralnetwork2811
      @neuralnetwork2811 2 ปีที่แล้ว

      +++ Плюсую. Все остальные видео которые я смотрел по архитектуре андроид приложений, там просто авторы говорили "Бла-бла-бла, тут короче Domain в Domain-е хранится вот это и там короче кроме Domain есть Presentation и Data. Конец". А в видеоуроках от Тимофея, именно создаешь вместе с автором, приложения используя Clean Architect на практике и после уроков откладывается в голове, что, как работает и что вообще такое Clean Architect

  • @denissavast
    @denissavast ปีที่แล้ว

    Отличнейший материал ! Благодарю

  • @КонстантинЪЪЪ
    @КонстантинЪЪЪ 2 ปีที่แล้ว +3

    мало лайков, поднажмите! это одно из лучших описаний чистой архитектуры :)

  • @Revakovskyi
    @Revakovskyi 2 ปีที่แล้ว +1

    Ну очень круто!!!! Тимофей, спасибо вам за шикарные и очень понятные для новичка уроки!!!

  • @javist1318
    @javist1318 2 ปีที่แล้ว

    Очень доходчиво объясняете , диаграммы сильно помогают, очень рад что попал на этот канал

  • @kraduschiisyatigrinc3207
    @kraduschiisyatigrinc3207 3 ปีที่แล้ว

    Лайк! Хотим больше разных видео! У вас талант объяснять.

  • @PavelStr-x5w
    @PavelStr-x5w 9 หลายเดือนก่อน

    Большое спасибо за подробное объяснение!!!

  • @Onitsura12
    @Onitsura12 2 ปีที่แล้ว

    Господи, хочу сказать спасибо за такой подробный разбор, огромное спасибо) лайк подписку оставил)

  • @spyro2008
    @spyro2008 10 หลายเดือนก่อน

    Спасибо Вам огромное! Вы лучший!

  • @isagamach1
    @isagamach1 ปีที่แล้ว

    Спасибо за объяснение! Давно хотел узнать, как грамотно сделать архитектуру приложения. А то чем больше оно растет, тем больше беспорядка :D

  • @UZEXCEL
    @UZEXCEL ปีที่แล้ว

    Спасибо, отличная подача материала.

  • @komronbekm4450
    @komronbekm4450 2 ปีที่แล้ว +1

    Искал в ютубе видосы другого Тимофея, и нашёл вас. Но рад этому, у вас всё тут так классно объясняется, спасибо вам!

  • @stasleonov5196
    @stasleonov5196 2 ปีที่แล้ว

    Очень, очень большое спасибо. Прям всё разжевано до мелочей. Большое спасибо

  • @alexrr7087
    @alexrr7087 2 ปีที่แล้ว +1

    16:55 сделайте пожалуйста видео с примером несколько реализаций

    • @TimofeyKovalenko
      @TimofeyKovalenko  2 ปีที่แล้ว +1

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

  • @МарияСтороженко-с1х
    @МарияСтороженко-с1х ปีที่แล้ว

    Это божественно, спасибо)

  • @ПавелРепин-м3г
    @ПавелРепин-м3г 2 ปีที่แล้ว

    Бесподобные примеры и объяснения. От души благодарю!

  • @эмильискаков-в9с
    @эмильискаков-в9с 3 ปีที่แล้ว +1

    Ваши уроки просто замечательные, пожайлуйста продолжайте радовать нас=)

  • @OCEH6
    @OCEH6 2 ปีที่แล้ว

    Огромное спасибо за урок. В моменте с объяснением элвис оператора 28:10 используется строка с firstName и параметр DEFAULT_NAME который создан для lastName. (Лично мне понятно, но тем кто видит ?: первый раз может показаться что-то искаженное =)
    Извиняюсь если уже подсвечивали ранее или если это избыточный комментарий. В любом случае урок потрясающий!

  • @mikhaillazarev5378
    @mikhaillazarev5378 2 ปีที่แล้ว

    Большое спасибо за информацию, все очень доступно и по полочкам, безумно благодарен.

  • @kafychannel
    @kafychannel 3 ปีที่แล้ว +5

    Продолжайте пожалуйста делать видео по clean architecture with Android, очень полезные видео

    • @TimofeyKovalenko
      @TimofeyKovalenko  3 ปีที่แล้ว +1

      спасибо, приятно что видео помогают вам. Конечно буду продолжать ).

  • @sovrinfo
    @sovrinfo 3 ปีที่แล้ว

    Спасибо за видео.Коммент в поддержку!

  • @Стас-с4ю5т
    @Стас-с4ю5т 3 ปีที่แล้ว +2

    И хотелось бы увидеть как правильно реализовать синхронизацию данных между web api (или firebase) и room)))

  • @lirjarmuhametova8516
    @lirjarmuhametova8516 2 ปีที่แล้ว

    Это оказывается так легко и просто 🤗👍 спасибо большое за отличные материал. Продолжаю обучение

  • @sonerrika
    @sonerrika 2 ปีที่แล้ว

    Очень понравилась серия видео, доходчиво и наглядно! Одно только смутило, если слой domain ни про кого не знает, почему от него идут стрелки зависимостей? Разве не другое направление у них должно быть, от data и presentation к domain.

  • @luckydevil1601
    @luckydevil1601 2 ปีที่แล้ว

    Очень здорово! Спасибо большое! Жаль, что Вы перестали выпускать видео..((

  • @samuilzhumakhanov6056
    @samuilzhumakhanov6056 3 ปีที่แล้ว

    Все подробно и понятно, благодарю!

  • @saosao29744
    @saosao29744 3 ปีที่แล้ว +1

    Отличный видеоурок и вообще курс, понятно и интересно, большое спасибо!😀

  • @yauheniprakapenka8095
    @yauheniprakapenka8095 3 ปีที่แล้ว

    Спасибо за видео и грамотную подачу

  • @armangukasian
    @armangukasian 2 ปีที่แล้ว +3

    класс, спасибо вам большое!) Лайк и подписка однозначно!)
    Скажите, а планируются уроки по таким темам как ретрофит, корутины, рум? Думаю очень полезным был бы ролик с практикой на каком-то маленьком демо-проекте, но где бы сочетался такой стек ?)

    • @TimofeyKovalenko
      @TimofeyKovalenko  2 ปีที่แล้ว +1

      Да, эти темы тоже будут.

  • @Serjoo88
    @Serjoo88 2 ปีที่แล้ว

    Тимофей, это блестящий урок!

  • @КахарманБалтабаев-б2о
    @КахарманБалтабаев-б2о 3 ปีที่แล้ว

    Шикарные уроки!!!

  • @Mecenatt
    @Mecenatt 2 ปีที่แล้ว

    ставлю лайк . Надеюсь автор не забьет на канал .

  • @CaptainBuldog
    @CaptainBuldog ปีที่แล้ว

    До просмотра этого видео в голове была каша. Разложил по полочкам. Огромное спасибо!

  • @dordzhiev
    @dordzhiev ปีที่แล้ว

    А пример со связью можно? Интересно узнать про вложенность объектов.

  • @islammagomedov3700
    @islammagomedov3700 3 ปีที่แล้ว +4

    Спасибо за урок, все очень доходчиво и понятно ! По твоим видео понял суть чистой архитектуры на практике
    У меня вопрос: Нужно ли помешать логику в отдельный usecase если usecase не взаимодействует с датой через интерфейс, а возвращает некий объект описанный в слое domen ?
    Было бы отлично если бы уроки по чистой архитектуры выходили и дальше, которые затрагивали бы и другие примеры которые очень часто встречаются на практике например: использование mvvm, recyclerView, взаимодействие с бэком в чистой архитектуре.
    Также не совсем по теме, нигде не смог найти внятное объяснение и пример использования DI (Dagger 2) в MVVM (Передача зависимостей во ViewModel + зависимости с контекстом)
    P.S спасибо еще раз, прошел собес -_-

    • @TimofeyKovalenko
      @TimofeyKovalenko  3 ปีที่แล้ว +3

      Спасибо за отзыв! Конечно буду продолжать, еще много планов на новые видео по архитектуре.
      По поводу помещения логики в usecase, нет таких правил что бы usecase обязательно зависел от даты, в домен выносится вся логика, даже та которая просто что-то делает но не общается в data слоем.

  • @grigorechebac2247
    @grigorechebac2247 2 ปีที่แล้ว

    Thank you for this very nice video. It helped me. I think that it is one from better explanation

  • @muhammadkurbonov4779
    @muhammadkurbonov4779 7 หลายเดือนก่อน

    Спасибо большое

  • @Mecenatt
    @Mecenatt 2 ปีที่แล้ว

    подскажите с контекстом в jetpack compose . Все работает без by lazy . Правильно ли делать так:
    val context = LocalContext.current

  • @roustamdev
    @roustamdev 2 ปีที่แล้ว

    Супер

  • @valentinkulagin515
    @valentinkulagin515 ปีที่แล้ว

    господи, спасибо ВАМ за эти шикарные и понятные, составленные на русском (а не девелоперском) языке объяснения. Мне кажется, что по вашим урокам можно аутиста клин архитектуре научить

  • @МагомедРашидов-э3д
    @МагомедРашидов-э3д 3 ปีที่แล้ว

    БОМБАА

  • @juneuniversum
    @juneuniversum 3 ปีที่แล้ว +1

    Юзкейсы позволяют переиспользовать логику работы с репозиториями в UI слое. Т.е. когда у вас вызовы репозиториев - это например сложные цепочки и используются в разных местах.
    Это мне кажется первая причина, почему не используются репозитории в UI.

    • @TimofeyKovalenko
      @TimofeyKovalenko  2 ปีที่แล้ว +1

      Да, совершенно верно.

  • @ArtemSamoshkin
    @ArtemSamoshkin ปีที่แล้ว

    Все здорово! Спасибо!
    Помогите, плз, понять, почему на схеме Presentation знает про Data напрямую? В коде данного видео Activity знает только про UseCases. Разве в клин архитектуре можно "обходить" домен слой?

    • @TimofeyKovalenko
      @TimofeyKovalenko  ปีที่แล้ว +1

      Да, presentation сам по себе не должен иметь доступ к data, только к use cases. Но, presentation в нашем случае находится внутри модуля app, а app занимается конфигурированием приложения и должен знать о всех, поэтому технически доступ к data возможен. Что бы избежать можно вынести presentation в отдельный модуль, а лучше разделять его на feature модули, про них планирую рассказать.

  • @looee4462
    @looee4462 ปีที่แล้ว

    Спасибо больше за видео, очень интересно и понятно рассказана тема!
    Подскажите пожалуйста, что означает фраза "это класс, который делает корут операции" по отношению к репозиторию? Что такое корут операции?

    • @TimofeyKovalenko
      @TimofeyKovalenko  ปีที่แล้ว

      Возможно корутину имел ввиду. Напишите в каком конкретно месте такое говорил.

  • @readmeandanswer8142
    @readmeandanswer8142 3 ปีที่แล้ว +1

    Здравствуйте, очень хотелось бы получить объяснение касательно presentation слоя. В видео вы сказали что presentation слой может знать и об domain и о data.
    Тогда как все мои знакомые это отвергли и сказали что напрямую presentation слой не должен знать о data.
    Так как на этом видео можно писать только в случае ну крайне быстрой и ленивой реализации, в очень простой бизнес логике.
    Presentation работает только через domain с data и друг о друге они знать не должны.
    Можно только подцепить даггерчкий элемент, но не более того, так как в видео делать - все сказали что нельзя, это нарушает принцип инверсии зависимости.

    • @TimofeyKovalenko
      @TimofeyKovalenko  3 ปีที่แล้ว +5

      Во первых я в видео много раз говорю, что я даю вам фундаментальные принципы, на основе которых, вы уже дальше развиваете свой проект. Если бы я давал сложный пример сходу со всем функционалом, то мало кто разобрался бы с этим. Мои видео все же делаются для моих студентов, которые только начинают изучать программирование.
      Во вторых: "презентейшен" слой не знает о "дата", это правда, но "app" знает, так как этот модуль является точкой входа в приложение и нам просто больше негде инициализировать все зависимости: "домен" и "дата". И, "app" внутри себя содержит "presentation", соответственно "presentation", технически имеет доступ к этим зависимостям, но логически мы используем только домен.
      Решается это путем разделения "app" и "презентейшен" на разные модули, либо использование фича модулей.
      Так же посмотрите видео, где разбирается DI, тогда станет понятно.

  • @konstantinmezler5238
    @konstantinmezler5238 2 หลายเดือนก่อน

    Спасибо

  • @Arman_127
    @Arman_127 2 ปีที่แล้ว

    Спасибо мне это очень помогло

  • @robertto921
    @robertto921 2 ปีที่แล้ว

    27:01 Если всё равно ставите элвиса, тогда делайте дефолтовое значение в параметрах null и не надо будет два раза указывать дефолтное значение.

  • @ШамсуддинИсабекуулу
    @ШамсуддинИсабекуулу 2 ปีที่แล้ว

    Здравствуйте Тимофей, хотел спросить, GetUserNameUseCase и SaveUserNameUseCase принимают объект интерфейса UserRepository, но в MainActivity вы передали объект UserRepositoryImpl

    • @TimofeyKovalenko
      @TimofeyKovalenko  2 ปีที่แล้ว

      Да, все верно. Полиморфизм ;)

  • @AkramAzizmurodov
    @AkramAzizmurodov 3 ปีที่แล้ว

    Здравствуйте. Спасибо за видео и труда.
    У меня есть вопрос по поводу applicationContext. Сначала вы запустили программу. Там написал, что applicationContext on a null object reference. А когда вы писали by lazy он работал. Это означает, что applicationContext создаётся внутри функции onCreate?

    • @TimofeyKovalenko
      @TimofeyKovalenko  3 ปีที่แล้ว +1

      Да, с этой активити стартует приложение и applicationContext просто еще не успел создаться.

  • @ВТАНКЕ-с2б
    @ВТАНКЕ-с2б 2 ปีที่แล้ว

    Тимофей здравствуйте, вот вы говорите что в data не может быть никакой логики, у меня тогда вопрос может ли репозиторий управлять источником данных, а конкретно может ли быть там логика выбора источника данных в зависимости например от наличия интернет подключения? Или например из UseCase дергаем список фильмов а репозиторий решает какой из методов апи дернуть для получения списка фильмов, например если их несколько но есть условия их получения?

    • @TimofeyKovalenko
      @TimofeyKovalenko  2 ปีที่แล้ว +1

      Может, так как смысл data это как раз таки и работа с данными. Но тут сильно зависит от ваших потребностей в бизнес логике, можно и так и так делать.

  • @kafychannel
    @kafychannel 3 ปีที่แล้ว +2

    Тимофей, замечательное объяснение, вы случайно не читали статью на медиум по этой теме?

    • @TimofeyKovalenko
      @TimofeyKovalenko  3 ปีที่แล้ว +1

      :), очень много читал, особенно когда только начинал заниматься программированием. Сейчас уже меньше, опыт уже значительно выше чем большинство статей.

  • @alexkoty5877
    @alexkoty5877 3 ปีที่แล้ว

    Очень круто!
    А скажи пожалуйста, вот у нас в домене есть модели и есть юзкейсы которые их берут на вход или выход. Нужно ли использовать для них интерфейсы или это избыточно?
    Спасибо

    • @TimofeyKovalenko
      @TimofeyKovalenko  3 ปีที่แล้ว

      Избыточно.
      Но тут на вкус и цвет, кто как делает. Лично я считаю, что стоит делать только если это реально решает, какую-то проблему. Делать просто для красоты или потому, что так написано в умной книжке нет никакого смысла.

  • @kiparisov1480
    @kiparisov1480 ปีที่แล้ว

    Может ли репозиторий хранить в себе методы генерации данных, например генерация вопроса generateQuestion, реализацию этого метода из репозитория я добавляю в RepositoryImpl в data слое и генерирую вопрос на основе числа, которое ввел пользователь, будет ли это ошибкой? Возможно в GenerateQuestionUseCase даже не нужно передавать репозиторий, а можно сразу написать генерацию вопроса, это же вроде как бизнес логика, не требующая доступ к БД.

    • @TimofeyKovalenko
      @TimofeyKovalenko  ปีที่แล้ว

      Эти вопросы ведь генерируются из какого-то списка? Откуда они берутся? Соответственно данные, на основе которых происходит генерация, где-то хранятся. Я бы в репозитории это делал.

    • @kiparisov1480
      @kiparisov1480 ปีที่แล้ว

      @@TimofeyKovalenko эти вопросы генерируется во время работы приложения на основе данных, которые подает пользователь прямо во время работы приложения, затем выводятся на экран, после перезапуска забываются и генерируется снова

    • @TimofeyKovalenko
      @TimofeyKovalenko  ปีที่แล้ว

      Репозиторий хорошее место тогда.

  • @abuiman5251
    @abuiman5251 2 ปีที่แล้ว

    👍🏻👍🏻👍🏻

  • @garifzyanovrr
    @garifzyanovrr 2 ปีที่แล้ว

    Тимофей привет!
    Есть ли у тебя сейчас возможность взять на обучение?
    Оставил на твоем сайте заявку, но без ответа.

    • @TimofeyKovalenko
      @TimofeyKovalenko  2 ปีที่แล้ว +1

      Привет! Все заявки есть, но не все еще обработал. В этом году обучение не проводиться, есть планы на начало следующего года.

    • @garifzyanovrr
      @garifzyanovrr 2 ปีที่แล้ว

      @@TimofeyKovalenko отлично жду!
      Благодарю за видео, просто💣

    • @TimofeyKovalenko
      @TimofeyKovalenko  2 ปีที่แล้ว

      Всем кого смог найти в мессенджерах отметил, если вам не ответил, то наверно у вас номер телефона скрыт от поиска оп нему. В этом случае оставьте ваш ник в телеграме.

    • @garifzyanovrr
      @garifzyanovrr 2 ปีที่แล้ว

      @@TimofeyKovalenko Тимофей, спасибо, уже добавили в чат ждунов😄

  • @Стас-с4ю5т
    @Стас-с4ю5т 3 ปีที่แล้ว

    Спасибо за доходчивый разбор данной темы, в ру сегменте я такого еще не встречал. Вопрос у меня возник такой, пишу приложение в котом есть большое количество фоновой работы, WorkManager который запускает foreground сервисы, в каком из слоев будет правильно размещать подобный функционал? Мне вот кажется, что нужно выносить в совершенно отдельный модуль или в presentaition , но интересно мнение профессионала.

    • @TimofeyKovalenko
      @TimofeyKovalenko  3 ปีที่แล้ว +1

      Если WorkManager используется только для синхронизации данных, то без проблем можно положить его в data слой. Data ведь как раз и предназначен для работы с данными. Выносить в отдельный модуль я бы не стал, только если необходимо сделать универсальную реализацию, которая будет использовать в нескольких проектах.
      А вообще тема синхронизации данных очень обширная, тут много нюансов. Думаю про эту тему тоже сделаю отдельную серию видео.

  • @rikirahi
    @rikirahi 2 ปีที่แล้ว

    Тимофей привет!
    У меня такой вопрос:
    Как прогнать LiveData через domain, если в этом слое нельзя импортировать данную библиотеку?
    Просто у меня есть usecase: getMoviesFromApiUseCase. В app и в data я сохраняю всё и использую в виде LiveData, но сделать прогон через usecase в domain слое я не могу. Как поступить, если сохранять Clean Architecture?

    • @TimofeyKovalenko
      @TimofeyKovalenko  2 ปีที่แล้ว +1

      Никак). Либо смириться с тем, что у тебя в domain будет подключен LiveData. Если используешь корутины, то советую поменять LiveData на Flow.

  • @МаратНазмутдинов-ы5н
    @МаратНазмутдинов-ы5н 2 ปีที่แล้ว

    Спасибо, очень интересно. Но вот урок с MVVM бы очень хорошо, чтобы было понятнее. И что делать, если UserRepositoryImpl данные берет из сети. У Вас он хардкодом

    • @TimofeyKovalenko
      @TimofeyKovalenko  2 ปีที่แล้ว +2

      Если у вас сеть, то вы просто будите дергать http запросы оттуда, или сделаете дополнительно какой-то класс для запросов, по принципу стораджей. А хардкодом, потому что это слишком простой пример, что бы показать еще и работу с сетью. Полноценный пример позже будем делать.

  • @scorkSH
    @scorkSH 10 หลายเดือนก่อน

    я вот или понял или нет) не могу понять)....... я так понял, это все "фокусы", посути, все даные храняться в одной компосибл функции (хмл не знаю, юзаю компос), я долго пытался понять, как даные куда передаються, но в этоге пришол к мнению, что не чего не куда не передаеться, а храниться тут:
    val userRepository = UserRepositoryImpl(context = LocalContext.current )
    val usecaseGetName = UserCaseGETname(userRepository)
    val useCaseSaveName = UseCaseSaveName(userRepository)
    я прав?

  • @speedrages
    @speedrages ปีที่แล้ว

    И благодарю

  • @ДмитрийЛунин-ю5ц
    @ДмитрийЛунин-ю5ц 2 ปีที่แล้ว

    спасибо

  • @LockedIp
    @LockedIp 3 ปีที่แล้ว

    Можно ли использовать flow в domain модуле?

    • @TimofeyKovalenko
      @TimofeyKovalenko  3 ปีที่แล้ว +2

      Конечно, корутины, как и RX - глобальные либы, которые пронизывают все слои.

  • @sasharobson
    @sasharobson ปีที่แล้ว

    Тимофей, при использовании UseCases, может ли репозиторий иметь методы обновления данных в репозитории, например поход в локалку, проверка наличия данных и в случае их отсутствия поход на удаленный источник, с сохранением полученных данных в локалке? Или все таки репозиторий должен строго иметь тупые методы сохранения и извлечения данных, а вся логика походов в источники данных уже в UseCases?

    • @TimofeyKovalenko
      @TimofeyKovalenko  ปีที่แล้ว

      То, что вы описали, как раз и является тупыми методами репозитория). То есть это ответственность репозитория откуда и как брать данные. Но в зависимости от ситуации, иногда этим управляют и из UseCase

    • @sasharobson
      @sasharobson ปีที่แล้ว

      @@TimofeyKovalenko спасибо за ответ Тимофей!

  • @ДмитрийБогданов-и5б
    @ДмитрийБогданов-и5б 3 ปีที่แล้ว

    Отличное видео! Однако возник вопрос каким образом можно реализовать получение данных из различных источников? Например, мне в проекте нужно получить свежие данные с API, но если это не получилось необходимо отобразить данные из локального хранилища. На сколько я понял, в репозитории я должен создать два метода, например getUserFromAPI в котором происходит получение данных с API и getUserFromDb в котором происходит получение данных из Db. А саму логику с
    if(getUserFromAPI == null){
    getUserFromDb
    }
    я должен реализовать в Use Case. Поправьте пожалуйста если что-то не так.

    • @TimofeyKovalenko
      @TimofeyKovalenko  3 ปีที่แล้ว +1

      UseCase такое не должен делать, это логика получения данных. Тут все очень просто, в репозитории у вас должно быть 2 storage (api и локальная база), и дальше уже в зависимости от задач делаете логику того из какого источника брать данные. Обычно вы дергаете API и если ошибка или данных нет, то идете в локальную базу, либо сначала проверяете локальную базу и если нет данных, то идете в api.
      "getUserFromAPI" - такие методы делать нельзя, так как UseCase не стоит знать конкретику реализации и откуда пришли данные. Дергая метод в репе нам просто нужны данные, все равно откуда они.

  • @ilgarm4370
    @ilgarm4370 3 ปีที่แล้ว

    Не понял, репозиторий только для для получения и сохранения данных? А отправка данных это не в репозитории?

    • @TimofeyKovalenko
      @TimofeyKovalenko  3 ปีที่แล้ว

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

  • @Nidvoraich
    @Nidvoraich ปีที่แล้ว

    Очень сильно бьёт по глазкам смена тёмной темы студии на белый лист дровио(
    Может, в дровио тоже можно тему потемнее выбрать?)

    • @TimofeyKovalenko
      @TimofeyKovalenko  ปีที่แล้ว

      Возможно есть темная тема, посмотрю.

  • @developerdeveloper4816
    @developerdeveloper4816 3 ปีที่แล้ว +1

    Please show mvvm + clean architecture with Koin

    • @TimofeyKovalenko
      @TimofeyKovalenko  3 ปีที่แล้ว

      Sure, it is plan for next videos

    • @developerdeveloper4816
      @developerdeveloper4816 3 ปีที่แล้ว

      @@TimofeyKovalenko okey and please a case with onTextInputlayout validations how to implement in mvvm and clean architecture because it is tricky

    • @developerdeveloper4816
      @developerdeveloper4816 3 ปีที่แล้ว

      @@TimofeyKovalenko Thank you sir

  • @videoss6258
    @videoss6258 2 ปีที่แล้ว

    Спасибо за урок! Но не очень понятно зачем выносить константы из класса, это сделано осмысленно или для удобства чтения? (25 минута)

    • @TimofeyKovalenko
      @TimofeyKovalenko  2 ปีที่แล้ว

      Потому что это котлин, в классе особо вариантов и нет что бы сделать константу.

  • @deo5686
    @deo5686 2 ปีที่แล้ว

    Правильно ли я понял, что репозиторий выступает неким юзеркейсом для получения данных. В нем нет конкретного процесса получения но есть логика "условий" почему, откуда и зачем. Конкретное решение получения данных должно быть в сторедже. Вопрос, как определить абстракцию для репозитория, ведь он может раздутая до многих десятков функций. И когда надо создавать другие репозитории и надо ли. Спасибо большое.

    • @TimofeyKovalenko
      @TimofeyKovalenko  2 ปีที่แล้ว +1

      Получение данных можно сделать как в репозитории, так и в сторадже, все зависит от того насколько у вас большое приложение. По поводу определения абстракции, как правило репозиторий делает CRUD операции с конкретной моделью. Например, у вас есть модель User, значит у вас будет UserRepository, который делает различные манипуляции с User. Или например для процесса авторизации у вас может быть AuthRepository с методами login, register, forgot password и logout. Один репозиторий под конкретную задачу.

    • @deo5686
      @deo5686 2 ปีที่แล้ว

      @@TimofeyKovalenko Спасибо большое

  • @k.barabass
    @k.barabass 2 ปีที่แล้ว

    С чего вдруг presentation может знать о data слое? У вас тем самым образуются горизонтальные связи. Presentation может знать в лучшем случае о интерфейсе репозитория который лежит в domain слое.
    Так же у вас почему-то в domain слое логика синхронизации данных - когда вы сначала получаете данные, проверяете изменились ли они и если нет, то ничего не сохраняете. Это не бизнес логика, чтобы она была в domain слое. Логично будет вынести ее в репозиторий, и там уже настраивать политики синхронизации. В domain слое должна быть бизнес логика и только.

  • @jarjaju9524
    @jarjaju9524 ปีที่แล้ว

    Сначала подумал какой смысл от модуля data, если данные (models) хранятся не в нем а в domain. А потом снял ручник и вспомнил что models это не данные а типы данных.
    Получается что domain предоставляет логику взаимодействия модулю data с другими модулями, то есть domain, не зная о других, говорит как им взаимодействовать.
    Presentation показывает что-то, используя логику предоставляемую domain.
    Data отдает и получает данные, используя логику предоставляемую domain.
    Так или не так?

  • @RenatGaniev-1
    @RenatGaniev-1 2 ปีที่แล้ว

    Странно что модели на уровне domain, вроде как они должны быть на уровне data

    • @TimofeyKovalenko
      @TimofeyKovalenko  2 ปีที่แล้ว +1

      Ничего странного, есть модели на уровне domain и есть модели на уровне data, это разные вещи.

    • @RenatGaniev-1
      @RenatGaniev-1 2 ปีที่แล้ว

      @@TimofeyKovalenko ну да, просто на уровне data я привык что это entities . Но сути не мешает :) я посмотрел потом след. Видео понял что ты имел ввиду.

  • @ljlj
    @ljlj 2 ปีที่แล้ว

    почему все слои в одном модуле, а не в отдельных?

    • @kavelquu
      @kavelquu 2 ปีที่แล้ว

      Думаю, автор не захотел усложнять начало, чтобы не отпугнуть и не запутать начинающих
      p.s одно из следующих видео как раз посвящено разделению слоев на модули

  • @РоманМаринов-ъ3ь
    @РоманМаринов-ъ3ь 2 ปีที่แล้ว

    неплохо было бы на гит выкладывать, очень долго переписывать код, жесть. Мне проще сразу смотреть и тыкать чего и откуда.

    • @TimofeyKovalenko
      @TimofeyKovalenko  2 ปีที่แล้ว

      Так в этом же и смысл), пока пишешь, набиваешь руку и становится все понятнее. Вообще не представляю даже, как можно научиться просто посмотрев ролик без написания кода.

  • @oscargil80
    @oscargil80 6 วันที่ผ่านมา

    English o Español Please

  • @MxMayers
    @MxMayers 3 ปีที่แล้ว

    как тут поставить 200 лайков 🤔

  • @Jktu3000
    @Jktu3000 10 หลายเดือนก่อน

    Тимофей добрый день.
    override fun saveName(saveParam:SaveUserNameParam):Boolean{
    Log.d("MyLog", "Save Param - ${saveParam.name}")
    sharedPreferences.edit().putString(KEY_FIRST_NAME, saveParam.name).apply()
    Log.d("MyLog", "Saved - ${sharedPreferences.getString("KEY_FIRST_NAME", "")?:""}")
    return true
    }
    В первом логе name отображается, но при вызове второго лога getString ничего не отображает.
    Попробовал реализовать тоже самое в новом проекте, но только, просто в активити, все работает.
    Подскажите, пожалуйста, в чем может быть проблема?