zlayer_consensus/
error.rs1use crate::types::NodeId;
4
5#[derive(Debug, thiserror::Error)]
7pub enum ConsensusError {
8 #[error("invalid raft config: {0}")]
10 Config(#[from] openraft::ConfigError),
11
12 #[error("raft fatal error: {0}")]
14 Fatal(String),
15
16 #[error("raft write error: {0}")]
18 Write(String),
19
20 #[error("raft init error: {0}")]
22 Init(String),
23
24 #[error("membership change error: {0}")]
26 Membership(String),
27
28 #[error("network error: {0}")]
30 Network(String),
31
32 #[error("storage error: {0}")]
34 Storage(#[from] openraft::StorageError<NodeId>),
35
36 #[error("serialization error: {0}")]
38 Serialization(String),
39
40 #[error("not leader (leader is {leader:?})")]
42 NotLeader {
43 leader: Option<NodeId>,
45 },
46
47 #[cfg(feature = "redb-store")]
49 #[error("redb error: {0}")]
50 Redb(String),
51}
52
53pub type Result<T> = std::result::Result<T, ConsensusError>;