use crate::types::NodeId;
#[derive(Debug, thiserror::Error)]
pub enum ConsensusError {
#[error("invalid raft config: {0}")]
Config(#[from] openraft::ConfigError),
#[error("raft fatal error: {0}")]
Fatal(String),
#[error("raft write error: {0}")]
Write(String),
#[error("raft init error: {0}")]
Init(String),
#[error("membership change error: {0}")]
Membership(String),
#[error("network error: {0}")]
Network(String),
#[error("storage error: {0}")]
Storage(#[from] openraft::StorageError<NodeId>),
#[error("serialization error: {0}")]
Serialization(String),
#[error("not leader (leader is {leader:?})")]
NotLeader {
leader: Option<NodeId>,
},
#[cfg(feature = "redb-store")]
#[error("redb error: {0}")]
Redb(String),
}
pub type Result<T> = std::result::Result<T, ConsensusError>;