use crate::relaycell::hs::pow::ProofOfWorkType;
use tor_bytes::{EncodeResult, Reader, Result, Writeable, Writer};
use tor_hscrypto::pow::v1::{Effort, Nonce, SeedHead, SolutionByteArray};
#[derive(derive_more::Constructor, amplify::Getters, Debug, Clone, PartialEq)]
pub struct ProofOfWorkV1 {
#[getter(as_ref)]
nonce: Nonce,
#[getter(as_copy)]
effort: Effort,
#[getter(as_copy)]
seed_head: SeedHead,
#[getter(as_ref)]
solution: SolutionByteArray,
}
impl ProofOfWorkV1 {
pub(super) fn try_take_body_from(scheme: u8, b: &mut Reader<'_>) -> Result<Option<Self>> {
if scheme == ProofOfWorkType::V1.get() {
Ok(Some(Self {
nonce: b.extract()?,
effort: b.extract()?,
seed_head: b.extract()?,
solution: b.extract()?,
}))
} else {
Ok(None)
}
}
pub(super) fn write_onto<B: Writer + ?Sized>(&self, b: &mut B) -> EncodeResult<()> {
b.write_u8(ProofOfWorkType::V1.get());
self.nonce.write_onto(b)?;
self.effort.write_onto(b)?;
self.seed_head.write_onto(b)?;
self.solution.write_onto(b)?;
Ok(())
}
}