pacifica-rs 1.0.0

rust implementation of PacificA: Replication in Log-Based Distributed Storage Systems
use crate::{ReplicaId, TypeConfig};

pub struct ReplicaRecoverRequest<C>
where
    C: TypeConfig,
{
    pub term: usize,
    pub version: usize,
    pub recover_id: ReplicaId<C::NodeId>,
}

impl<C> ReplicaRecoverRequest<C>
where C:TypeConfig{
    pub fn new(term: usize, version: usize, recover_id: ReplicaId<C::NodeId>) -> ReplicaRecoverRequest<C> {
        ReplicaRecoverRequest {
            term,
            version,
            recover_id,
        }
    }
}

pub enum ReplicaRecoverResponse {
    Success,
    HigherTerm {
        term: usize,
    }


}

impl ReplicaRecoverResponse {

    pub fn success() -> ReplicaRecoverResponse {
        ReplicaRecoverResponse::Success
    }
    pub fn higher_term(term: usize) -> ReplicaRecoverResponse {
        ReplicaRecoverResponse::HigherTerm { term }
    }


}