pacifica-rs 1.0.0

rust implementation of PacificA: Replication in Log-Based Distributed Storage Systems
use thiserror::Error;
use crate::error::{CorruptedLogEntryError, NotFoundLogEntry, PacificaError};
use crate::{TypeConfig};
use crate::storage::StorageError;

#[derive(Debug, Error)]
pub enum LogManagerError
{
    #[error("LogManger has been shutdown")]
    Shutdown,
    /// not found LogEntry at log_index
    #[error(transparent)]
    NotFound(#[from] NotFoundLogEntry),
    /// Corrupted LogEntry with inconsistent checksum if log_entry_checksum_enable is true
    #[error(transparent)]
    CorruptedLogEntry(#[from] CorruptedLogEntryError),
    #[error(transparent)]
    StorageError(#[from] StorageError),
}


impl LogManagerError
{

    pub(crate) fn not_found(log_index: usize) -> Self {
        LogManagerError::NotFound(NotFoundLogEntry::new(log_index))
    }

    pub(crate) fn corrupted_log_entry(expect: u64, actual: u64) -> Self {
        LogManagerError::CorruptedLogEntry(CorruptedLogEntryError::new(expect, actual))
    }



}

impl<C> From<LogManagerError> for PacificaError<C>
where
    C: TypeConfig,
{
    fn from(value: LogManagerError) -> Self {
        match value {
            LogManagerError::Shutdown => PacificaError::Shutdown,
            LogManagerError::CorruptedLogEntry(e) => PacificaError::CorruptedLogEntryError(e),
            LogManagerError::NotFound(e) => PacificaError::NotFoundLogEntryError(e),
            LogManagerError::StorageError(e) => PacificaError::StorageError(e),
        }
    }
}