pub struct SyncConfig {
pub direction: SyncDirection,
pub conflict_resolution: ConflictResolution,
pub batch_size: usize,
pub push_interval_ms: u64,
pub pull_interval_ms: u64,
pub retry: RetryConfig,
pub collectives: Option<Vec<CollectiveId>>,
pub sync_relations: bool,
pub sync_insights: bool,
}Available on crate feature
sync only.Expand description
Configuration for the sync protocol.
Controls direction, conflict resolution, batch sizes, polling intervals, and which collectives to sync.
§Example
use pulsedb::sync::config::{SyncConfig, SyncDirection};
let config = SyncConfig {
direction: SyncDirection::PushOnly,
batch_size: 200,
..Default::default()
};
assert!(config.validate().is_ok());Fields§
§direction: SyncDirectionDirection of sync data flow.
conflict_resolution: ConflictResolutionStrategy for resolving conflicts.
batch_size: usizeMaximum number of changes per sync batch.
Larger batches reduce round trips but increase memory usage. Default: 500
push_interval_ms: u64Interval between push cycles in milliseconds.
Default: 1000 (1 second)
pull_interval_ms: u64Interval between pull cycles in milliseconds.
Default: 1000 (1 second)
retry: RetryConfigRetry configuration for transient failures.
collectives: Option<Vec<CollectiveId>>Optional filter: only sync these collectives.
None means sync all collectives.
sync_relations: boolWhether to sync experience relations.
Default: true
sync_insights: boolWhether to sync derived insights.
Default: true
Implementations§
Source§impl SyncConfig
impl SyncConfig
Trait Implementations§
Source§impl Clone for SyncConfig
impl Clone for SyncConfig
Source§fn clone(&self) -> SyncConfig
fn clone(&self) -> SyncConfig
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for SyncConfig
impl Debug for SyncConfig
Source§impl Default for SyncConfig
impl Default for SyncConfig
Source§impl<'de> Deserialize<'de> for SyncConfig
impl<'de> Deserialize<'de> for SyncConfig
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Auto Trait Implementations§
impl Freeze for SyncConfig
impl RefUnwindSafe for SyncConfig
impl Send for SyncConfig
impl Sync for SyncConfig
impl Unpin for SyncConfig
impl UnsafeUnpin for SyncConfig
impl UnwindSafe for SyncConfig
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more