use config::ConfigError;
use thiserror::Error as ThisError;
pub type Result<T> = std::result::Result<T, Error>;
#[derive(Debug, ThisError)]
pub enum Error {
#[error("Raft error: cause:`{0}`")]
RaftError(#[from] crate::raft::Error),
#[error("Raft storage error: cause:`{0}`")]
RaftStorageError(#[from] crate::raft::StorageError),
#[error("Error joining the cluster")]
JoinError,
#[error("Request rejected, cause: `{0}`")]
Rejected(String),
#[error("Invalid config error. cause: `{0}`")]
ConfigInvalid(String),
#[error("Request timeout")]
Timeout,
#[error("gRPC error: `{0}`")]
Grpc(#[from] tonic::transport::Error),
#[error("Error calling remote procedure: `{0}`")]
RemoteCall(#[from] tonic::Status),
#[error("IO error: {0}")]
Io(#[from] tokio::io::Error),
#[error("Storage error: `{0}`")]
Database(#[from] heed::Error),
#[error("Unexpected error")]
Other(#[source] Box<dyn std::error::Error + Sync + Send + 'static>),
#[error("Unknown error")]
Unknown,
#[error("Shut down by Ctrl+C signal")]
CtrlC,
#[error("RaftNode LocalRequestMsg Receive error: {0}")]
RecvError(#[from] tokio::sync::oneshot::error::RecvError),
#[error("Encoding error")]
EncodingError(String),
#[error("Decoding error")]
DecodingError(String),
#[error("Config file format invalid")]
ConfigFileParsingError(#[from] ConfigError),
}
#[derive(Debug, ThisError)]
pub enum SendMessageError {
#[error("Failed to connect to node. {0}")]
ConnectionError(String),
#[error("Node {0} not found from the peers")]
PeerNotFound(String),
#[error("Failed to send message. {0}")]
TransmissionError(String),
}
impl From<prost::DecodeError> for Error {
fn from(e: prost::DecodeError) -> Self {
Self::Other(Box::new(e))
}
}
impl From<bincode::Error> for Error {
fn from(e: bincode::Error) -> Self {
Self::Other(e)
}
}