pub mod cdc;
pub mod commit_policy;
pub mod commit_waiter;
pub mod lease;
pub mod logical;
pub mod primary;
pub mod quorum;
pub mod replica;
pub mod scheduler;
pub mod topology_advertiser;
pub use commit_policy::CommitPolicy;
pub use commit_waiter::{AwaitOutcome, CommitWaiter};
pub use lease::{LeaseError, LeaseStore, WriterLease};
pub use quorum::{QuorumConfig, QuorumCoordinator, QuorumError};
pub use topology_advertiser::{
LagConfig, TopologyAdvertiser, TopologyAuthGate, DEFAULT_REPLICA_TIMEOUT_MS,
TOPOLOGY_READ_CAPABILITY,
};
#[derive(Debug, Clone, PartialEq, Eq, Default)]
pub enum ReplicationRole {
#[default]
Standalone,
Primary,
Replica {
primary_addr: String,
},
}
#[derive(Debug, Clone)]
pub struct ReplicationConfig {
pub role: ReplicationRole,
pub poll_interval_ms: u64,
pub max_batch_size: usize,
pub region: String,
pub quorum: QuorumConfig,
}
impl ReplicationConfig {
pub fn standalone() -> Self {
Self {
role: ReplicationRole::Standalone,
poll_interval_ms: 100,
max_batch_size: 1000,
region: "local".to_string(),
quorum: QuorumConfig::async_commit(),
}
}
pub fn primary() -> Self {
Self {
role: ReplicationRole::Primary,
poll_interval_ms: 100,
max_batch_size: 1000,
region: "local".to_string(),
quorum: QuorumConfig::async_commit(),
}
}
pub fn replica(primary_addr: impl Into<String>) -> Self {
Self {
role: ReplicationRole::Replica {
primary_addr: primary_addr.into(),
},
poll_interval_ms: 100,
max_batch_size: 1000,
region: "local".to_string(),
quorum: QuorumConfig::async_commit(),
}
}
pub fn with_quorum(mut self, quorum: QuorumConfig) -> Self {
self.quorum = quorum;
self
}
pub fn with_region(mut self, region: impl Into<String>) -> Self {
self.region = region.into();
self
}
}