use common::coordinator::WriteError;
use common::{SequenceError, StorageError};
#[derive(Debug, Clone, PartialEq, Eq)]
pub enum Error {
Storage(String),
Encoding(String),
InvalidInput(String),
Internal(String),
}
impl std::error::Error for Error {}
impl std::fmt::Display for Error {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
match self {
Error::Storage(msg) => write!(f, "Storage error: {}", msg),
Error::Encoding(msg) => write!(f, "Encoding error: {}", msg),
Error::InvalidInput(msg) => write!(f, "Invalid input: {}", msg),
Error::Internal(msg) => write!(f, "Internal error: {}", msg),
}
}
}
impl From<StorageError> for Error {
fn from(err: StorageError) -> Self {
match err {
StorageError::Storage(msg) => Error::Storage(msg),
StorageError::Internal(msg) => Error::Internal(msg),
}
}
}
impl From<SequenceError> for Error {
fn from(err: SequenceError) -> Self {
match err {
SequenceError::Storage(storage_err) => Error::from(storage_err),
SequenceError::Deserialize(de_err) => Error::Encoding(de_err.message),
}
}
}
impl From<WriteError> for Error {
fn from(err: WriteError) -> Self {
match err {
WriteError::Backpressure(()) => Error::Internal("write queue full".into()),
WriteError::TimeoutError(()) => Error::Internal("write queue timeout".into()),
WriteError::Shutdown => Error::Internal("coordinator shut down".into()),
WriteError::ApplyError(_, msg) => Error::Internal(msg),
WriteError::FlushError(msg) => Error::Storage(msg),
WriteError::Internal(msg) => Error::Internal(msg),
}
}
}
impl From<&str> for Error {
fn from(msg: &str) -> Self {
Error::InvalidInput(msg.to_string())
}
}
pub type Result<T> = std::result::Result<T, Error>;
use crate::model::Record;
#[derive(Debug)]
pub enum AppendError {
QueueFull(Vec<Record>),
Timeout(Vec<Record>),
Shutdown,
InvalidRecord(String),
}
impl AppendError {
pub fn into_inner(self) -> Option<Vec<Record>> {
match self {
AppendError::QueueFull(records) => Some(records),
AppendError::Timeout(records) => Some(records),
AppendError::Shutdown => None,
AppendError::InvalidRecord(_) => None,
}
}
}
impl std::fmt::Display for AppendError {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
match self {
AppendError::QueueFull(_) => write!(f, "write queue full"),
AppendError::Timeout(_) => write!(f, "write queue timeout"),
AppendError::Shutdown => write!(f, "coordinator shut down"),
AppendError::InvalidRecord(msg) => write!(f, "invalid record: {}", msg),
}
}
}
impl std::error::Error for AppendError {}
impl From<AppendError> for Error {
fn from(err: AppendError) -> Self {
match err {
AppendError::QueueFull(_) => Error::Internal("write queue full".into()),
AppendError::Timeout(_) => Error::Internal("write queue timeout".into()),
AppendError::Shutdown => Error::Internal("coordinator shut down".into()),
AppendError::InvalidRecord(msg) => Error::Internal(msg),
}
}
}
pub type AppendResult<T> = std::result::Result<T, AppendError>;