1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

//! A module for everything needed to be a "sync client" - ie, a device which
//! can perform a full sync of any number of collections, including managing
//! the server state.
//!
//! In general, the client is responsible for all communication with the sync server,
//! including ensuring the state is correct, and encrypting/decrypting all records
//! to and from the server. However, the actual syncing of the collections is
//! delegated to an external [crate::engine](Sync Engine).
//!
//! One exception is that the "sync client" owns one sync engine - the
//! [crate::clients_engine], which is managed internally.
mod coll_state;
mod coll_update;
mod collection_keys;
mod request;
mod state;
mod status;
mod storage_client;
mod sync;
mod sync_multiple;
mod token;
mod util;

pub(crate) use coll_state::{CollState, LocalCollStateMachine};
pub(crate) use coll_update::{fetch_incoming, CollectionUpdate};
pub(crate) use collection_keys::CollectionKeys;
pub(crate) use request::InfoConfiguration;
pub(crate) use state::GlobalState;
pub use status::{ServiceStatus, SyncResult};
pub use storage_client::{
    SetupStorageClient, Sync15ClientResponse, Sync15StorageClient, Sync15StorageClientInit,
};
pub use sync_multiple::{
    sync_multiple, sync_multiple_with_command_processor, MemoryCachedState, SyncRequestInfo,
};