mosaik 0.3.13

A Rust runtime for building self-organizing, leaderless distributed systems.
Documentation
pub use backoff;
use {
	crate::primitives::BackoffFactory,
	backoff::{ExponentialBackoffBuilder, backoff::Backoff},
	core::{fmt::Debug, time::Duration},
	derive_builder::Builder,
	std::sync::Arc,
};

/// Configuration options for the streams subsystem.
#[derive(Builder, Clone)]
#[builder(pattern = "owned", setter(prefix = "with"), derive(Clone))]
#[builder_struct_attr(doc(hidden))]
pub struct Config {
	/// The backoff policy for retrying stream subscription connections on
	/// recoverable failures. This is the default policy used by consumers
	/// unless overridden per-consumer via the consumer builder. The default
	/// is an exponential backoff with a maximum elapsed time of 5 minutes.
	#[builder(
		setter(custom),
		default = "Arc::new(|| Box::new(ExponentialBackoffBuilder::default() \
		           .with_max_elapsed_time(Some(Duration::from_secs(300))) \
		           .build()))"
	)]
	pub backoff: BackoffFactory,
}

impl Config {
	/// Creates a new config builder with default values.
	pub fn builder() -> ConfigBuilder {
		ConfigBuilder::default()
	}
}

impl ConfigBuilder {
	/// Sets a backoff policy for stream connection retries.
	#[must_use]
	pub fn with_backoff<B: Backoff + Clone + Send + Sync + 'static>(
		mut self,
		backoff: B,
	) -> Self {
		self.backoff = Some(Arc::new(move || Box::new(backoff.clone())));
		self
	}
}

impl core::fmt::Debug for Config {
	fn fmt(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result {
		f.debug_struct("Config")
			.field("backoff", &"<backoff factory>")
			.finish()
	}
}

impl core::fmt::Debug for ConfigBuilder {
	fn fmt(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result {
		f.debug_struct("Config")
			.field("backoff", &"<backoff factory>")
			.finish()
	}
}