Ребят, привет! Может быть уже был у кого-то похожий опыт с оффлайн работой приложения.
Как можно сделать поддержку оффлайн работы приложения с архитектурной точки зрения? То есть, чтобы было не только кэширование данных с сервера, а можно было производить модификацию этих данных также как через обычные сетевые запросы, но сохранять это оффлайн. А в случае подключения к сети синхронизироваться с сервером.
Был следующий опыт.
1. В базе есть модель данных. Скажем "name, age"
2. пользователь меняет эти поля в оффлайн
3. делаешь отдельную таблицу, в которой лежит uid из других таблиц. Назовём её таблица операций.
4. При появлении интернета ловишь ресивером это, идёшь в свою таблицу операций, достаёшь из неё метаданные(uid, название таблицы, тип операции (CRUD), название полей для синхронизации)
5. А дальше синкай как хочешь: можешь объект создать и его в джейсон, можешь еще как.
6. Удаляешь операцию только если отработал запрос.
7. Не отработал - кидай ошибку в UI, делай retry X раз
Ну и да, разделяй и власвтвуй, в одном файле это делать не стоит