данных, прежде всего, обращаются к API удалённого сервиса для их извлечения. Если произошла какая-то ошибка, то идёт попытка извлечения данных из локальной БД, в этом случае, конечно, также может возникнуть ошибка в выполнении запроса. Мне хотелось бы, чтобы репозиторий мог, например, в случае ошибки запроса к API сервиса и при успехе запроса к БД, выдавать локальные данные и причину неудачи запроса к API. Основной вопрос в том, как лучше всего организовать результирующие данные в этом случае? Есть, конечно, идея реализовать sealed interface и три его реализации: RemoteData, LocalData и Failure. Однако, насколько я знаю, слой домена и слой представления не должны знать откуда именно пришли данные.
У себя использую подход, когда из репозитория торчит наружу observable источник с данными, который возвращает последние полученные данные от сервера. Отдельно есть методы load, loadIfNecessary которые возвращают Result<Unit>. Таким образом можно отобразить, что там есть сейчас в кэше, дёрнуть метод load и отдельно отработать ошибку, если требуется.
Обсуждают сегодня