pub struct ProofStore<F: Family, D> { /* private fields */ }Expand description
A store derived from a Proof that can be used to generate proofs over any sub-range of the original range.
Implementations§
Source§impl<F: Family, D: Digest> ProofStore<F, D>
impl<F: Family, D: Digest> ProofStore<F, D>
Sourcepub fn new<H, E>(
hasher: &H,
proof: &Proof<F, D>,
elements: &[E],
start_loc: Location<F>,
root: &D,
) -> Result<Self, Error<F>>
pub fn new<H, E>( hasher: &H, proof: &Proof<F, D>, elements: &[E], start_loc: Location<F>, root: &D, ) -> Result<Self, Error<F>>
Create a ProofStore from a Proof of inclusion of the provided range of elements from
the structure with root root. The resulting store can be used to generate range proofs
over any sub-range of the original range. Returns an error if the proof is invalid or could
not be verified against the given root.
The fold prefix accumulator from the proof is stored internally so that sub-range proofs with different fold prefix boundaries can be generated without requiring individual peak digests.
Sourcepub fn range_proof<H: Hasher<F, Digest = D>>(
&self,
hasher: &H,
range: Range<Location<F>>,
) -> Result<Proof<F, D>, Error<F>>
pub fn range_proof<H: Hasher<F, Digest = D>>( &self, hasher: &H, range: Range<Location<F>>, ) -> Result<Proof<F, D>, Error<F>>
Return a range proof for the nodes corresponding to the given location range.
The sub-range’s fold prefix accumulator is derived from the stored fold accumulator (covering the original proof’s fold prefix peaks) plus any additional peaks that are individually available in the store (original range peaks now preceding the sub-range).
Sourcepub fn multi_proof(
&self,
locations: &[Location<F>],
peaks: &[(Position<F>, D)],
) -> Result<Proof<F, D>, Error<F>>
pub fn multi_proof( &self, locations: &[Location<F>], peaks: &[(Position<F>, D)], ) -> Result<Proof<F, D>, Error<F>>
Return a multi proof for the elements corresponding to the given locations.
Since multi-proofs require individual node digests (not fold accumulators), callers must supply any peak digests that fall in the fold prefix of the original proof. These are the peaks entirely before the original range’s start location. If the original range started at location 0, no peaks are needed.
Auto Trait Implementations§
impl<F, D> Freeze for ProofStore<F, D>where
D: Freeze,
impl<F, D> RefUnwindSafe for ProofStore<F, D>where
D: RefUnwindSafe,
F: RefUnwindSafe,
impl<F, D> Send for ProofStore<F, D>where
D: Send,
impl<F, D> Sync for ProofStore<F, D>where
D: Sync,
impl<F, D> Unpin for ProofStore<F, D>
impl<F, D> UnsafeUnpin for ProofStore<F, D>where
D: UnsafeUnpin,
impl<F, D> UnwindSafe for ProofStore<F, D>where
D: UnwindSafe,
F: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> FutureExt for T
impl<T> FutureExt for T
Source§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
Source§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more