sync_manager/types.rs
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 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104
/* 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 https://mozilla.org/MPL/2.0/. */
use std::collections::HashMap;
use std::time::SystemTime;
use sync15::DeviceType;
#[derive(Debug)]
pub struct SyncParams {
// Why are we performing this sync?
pub reason: SyncReason,
// Which engines should we sync?
pub engines: SyncEngineSelection,
// Which engines should be enabled in the "account global" list (for
// example, if the UI was used to change an engine's state since the last
// sync).
pub enabled_changes: HashMap<String, bool>,
// Keys to encrypt/decrypt data from local database files. These are
// separate from the key we use to encrypt the sync payload as a whole.
pub local_encryption_keys: HashMap<String, String>,
// Authorization for the sync server
pub auth_info: SyncAuthInfo,
// An opaque string, as returned in the previous sync's SyncResult and
// persisted to disk, or null if no such state is available. This includes
// information such as the list of engines previously enabled, certain
// server timestamps and GUIDs etc. If this value isn't correctly persisted
// and round-tripped, each sync may look like a "first sync".
pub persisted_state: Option<String>,
// Information about the current device, such as its name, formfactor and
// FxA device ID.
pub device_settings: DeviceSettings,
}
#[derive(Debug)]
pub enum SyncReason {
Scheduled,
User,
PreSleep,
Startup,
EnabledChange,
Backgrounded,
}
#[derive(Debug)]
pub enum SyncEngineSelection {
All,
Some { engines: Vec<String> },
}
#[derive(Debug)]
pub struct SyncAuthInfo {
pub kid: String,
pub fxa_access_token: String,
pub sync_key: String,
pub tokenserver_url: String,
}
#[derive(Debug)]
pub struct DeviceSettings {
pub fxa_device_id: String,
pub name: String,
pub kind: DeviceType,
}
#[derive(Debug)]
pub struct SyncResult {
// Result from the sync server
pub status: ServiceStatus,
// Engines that synced successfully
pub successful: Vec<String>,
// Maps the names of engines that failed to sync to the reason why
pub failures: HashMap<String, String>,
// State that should be persisted to disk and supplied to the sync method
// on the next sync (See SyncParams.persisted_state).
pub persisted_state: String,
// The list of engines which are marked as "declined" (ie, disabled) on the
// sync server. The list of declined engines is global to the account
// rather than to the device. Apps should use this after every sync to
// update the local state (ie, to ensure that their Sync UI correctly
// reflects what engines are enabled and disabled), because these could
// change after every sync.
pub declined: Option<Vec<String>>,
// Earliest time that the next sync should happen at
pub next_sync_allowed_at: Option<SystemTime>,
// JSON string encoding a `SyncTelemetryPing` object
pub telemetry_json: Option<String>,
}
#[derive(Debug)]
pub enum ServiceStatus {
Ok,
NetworkError,
ServiceError,
AuthError,
BackedOff,
OtherError,
}
impl ServiceStatus {
pub fn is_ok(&self) -> bool {
matches!(self, ServiceStatus::Ok)
}
}