nodedb-raft 0.0.1

Raft consensus engine for NodeDB — leader election, log replication, and snapshots
Documentation
use thiserror::Error;

pub type Result<T> = std::result::Result<T, RaftError>;

#[derive(Debug, Error)]
pub enum RaftError {
    #[error("not leader (leader hint: {leader_hint:?})")]
    NotLeader { leader_hint: Option<u64> },

    #[error("log compacted: requested index {requested}, first available {first_available}")]
    LogCompacted {
        requested: u64,
        first_available: u64,
    },

    #[error("proposal rejected: {reason}")]
    ProposalRejected { reason: String },

    #[error("group {group_id} not found on this node")]
    GroupNotFound { group_id: u64 },

    #[error("transport error: {detail}")]
    Transport { detail: String },

    #[error("storage error: {detail}")]
    Storage { detail: String },

    #[error("serialization error: {detail}")]
    Serialization { detail: String },

    #[error("shutdown in progress")]
    Shutdown,
}