Skip to content

Sixth task#3

Open
Damirikys wants to merge 2 commits intomasterfrom
SixthTask
Open

Sixth task#3
Damirikys wants to merge 2 commits intomasterfrom
SixthTask

Conversation

@Damirikys
Copy link
Owner

P.S.: Синхронизация устроена следующим образом: (1) локальные записи (время редактирования которых позже, чем время редактирования удаленных записей) автоматически сохраняются на сервер. Поле extra используется для псевдо-уникальной идентификации устройства, с которого запись была отредактирована. Если при синхронизации с одного устройства обнаружится, что данные были изменены с другого устройства - пользователю будет дан выбор, какие изменения сохранить. Выбор будет дан также во всех остальных случаях, отличных от (1). Оффлайн режим поддерживается и реализован следующим механизмом: если при редактировании записи мы не можем сохранить изменения на сервере, то устанавливаем флаг о запланированной синхронизации. BroadcastSyncManager ловит события CONNECTIVITY_CHANGE и запускает синхронизацию при активном интернет соединении и установленном флаге. Сам процесс синхронизации реализован в SynchronizeService. Для работы с API сервера был написан небольшой клиент (папка data/network).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant