aranya_runtime/lib.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
//! The Aranya runtime.
//!
//! # Overview
//!
//! The runtime crate is the starting point for integrating with Aranya.
//!
//! The runtime provides a higher level interface to:
//! 1. An [`Engine`] responsible for enforcing a [`Policy`] on graph [`Command`]s.
//! 2. A [`StorageProvider`] responsible for providing a storage mechanism for graph commands.
//! 3. A [`sync`] interface responsible for syncing graph state between peers.
//!
//! # Usage
//!
//! Refer to provided demo/quickstart code for an example of how to use the runtime crate.
//! The `quic_syncer.rs` module provides a good example of syncing via QUIC.
//!
//! # Example
//!
//! Start by initializing a client with desired [`Engine`] and [`StorageProvider`]
//! ```ignore
//! let client = ClientState::new(engine, storage)
//! ```
//!
//! Initialize graph for the client with:
//! ```ignore
//! client.new_graph(...)
//! ```
//!
//! Start listening for incoming sync requests with:
//! ```ignore
//! sync::run_syncer(...)
//! ```
//!
//! To initiate a sync with another peer, construct a [`SyncRequester`]
//! and send the sync request to the peer via the Aranya transport:
//! ```ignore
//! SyncRequester::new(...)
//! sync::sync(...)
//! ```
#![cfg_attr(docsrs, feature(doc_cfg))]
#![cfg_attr(not(any(test, doctest, feature = "std")), no_std)]
#![warn(clippy::arithmetic_side_effects)]
extern crate alloc;
mod client;
pub mod command;
pub mod engine;
pub mod metrics;
mod prior;
pub mod protocol;
pub mod storage;
pub mod sync;
pub mod testing;
pub mod vm_policy;
pub use crate::{
client::*, command::*, engine::*, prior::Prior, storage::*, sync::*, vm_policy::*,
};