Skip to main content

commonware_storage/qmdb/sync/
mod.rs

1//! Shared sync types and functionality for authenticated databases.
2
3use crate::qmdb::sync::engine::Config;
4use commonware_codec::Encode;
5
6pub mod engine;
7pub(crate) use engine::Engine;
8
9mod error;
10pub use error::{EngineError, Error};
11
12mod gaps;
13mod journal;
14
15pub(crate) use journal::Journal;
16
17mod database;
18pub(crate) use database::{Config as DatabaseConfig, Database};
19
20pub mod resolver;
21pub(crate) use resolver::{FetchResult, Resolver};
22
23mod target;
24pub use target::Target;
25
26mod requests;
27
28/// Create/open a database and sync it to a target state
29pub async fn sync<DB, R>(config: Config<DB, R>) -> Result<DB, Error<R::Error, DB::Digest>>
30where
31    DB: Database,
32    DB::Op: Encode,
33    R: resolver::Resolver<Op = DB::Op, Digest = DB::Digest>,
34{
35    Engine::new(config).await?.sync().await
36}