NamespaceProof

Enum NamespaceProof 

Source
pub enum NamespaceProof<M: MerkleHash, const NS_ID_SIZE: usize> {
    AbsenceProof {
        proof: Proof<M>,
        ignore_max_ns: bool,
        leaf: Option<NamespacedHash<NS_ID_SIZE>>,
    },
    PresenceProof {
        proof: Proof<M>,
        ignore_max_ns: bool,
    },
}
Expand description

A proof of some statement about a namespaced merkle tree.

This proof may prove the presence of some set of leaves, or the absence of a particular namespace

Variants§

§

AbsenceProof

A proof that some item is absent from the tree

Fields

§proof: Proof<M>

The range proof against the inner merkle tree

§ignore_max_ns: bool

Whether to treat the maximum possible namespace as a special marker value and ignore it in computing namespace ranges

§leaf: Option<NamespacedHash<NS_ID_SIZE>>

A leaf that is present in the tree, if the namespace being proven absent falls within the namespace range covered by the root.

§

PresenceProof

A proof that some item is included in the tree

Fields

§proof: Proof<M>

The range proof against the inner merkle tree

§ignore_max_ns: bool

Whether to treat the maximum possible namespace as a special marker value and ignore it in computing namespace ranges

Implementations§

Source§

impl<M, const NS_ID_SIZE: usize> NamespaceProof<M, NS_ID_SIZE>
where M: NamespaceMerkleHasher<NS_ID_SIZE, Output = NamespacedHash<NS_ID_SIZE>>,

Source

pub fn verify_complete_namespace( &self, root: &NamespacedHash<NS_ID_SIZE>, raw_leaves: &[impl AsRef<[u8]>], namespace: NamespaceId<NS_ID_SIZE>, ) -> Result<(), RangeProofError>

Verify that the provided raw leaves are a complete namespace. This may be a proof of presence or absence.

Source

pub fn verify_range( &self, root: &NamespacedHash<NS_ID_SIZE>, raw_leaves: &[impl AsRef<[u8]>], leaf_namespace: NamespaceId<NS_ID_SIZE>, ) -> Result<(), RangeProofError>

Verify a that the provided raw leaves are a (1) present and (2) form a contiguous subset of some namespace

Source

pub fn narrow_range<L: AsRef<[u8]>>( &self, left_extra_raw_leaves: &[L], right_extra_raw_leaves: &[L], leaf_namespace: NamespaceId<NS_ID_SIZE>, ) -> Result<Self, RangeProofError>

Narrows the proof range: uses an existing proof to create a new proof for a subrange of the original proof’s range

§Arguments
  • left_extra_raw_leaves: The data for the leaves that will narrow the range from the left side (i.e. all the leaves from the left edge of the currently proven range, to the left edge of the new desired shrunk range)
  • right_extra_raw_leaves: Analogously, data for all the leaves between the right edge of the desired shrunken range, and the right edge of the current proof’s range
Source

pub fn convert_to_absence_proof(&mut self, leaf: NamespacedHash<NS_ID_SIZE>)

Convert a proof of the presence of some leaf to the proof of the absence of another leaf

Source

pub fn siblings(&self) -> &[NamespacedHash<NS_ID_SIZE>]

Returns the siblings provided as part of the proof

Source

pub fn start_idx(&self) -> u32

Returns the index of the first leaf in the proof

Source

pub fn end_idx(&self) -> u32

Returns the index after the last leaf in the proof

Source

pub fn leftmost_right_sibling(&self) -> Option<&NamespacedHash<NS_ID_SIZE>>

Returns the leftmost node to the right of the proven range, if one exists

Source

pub fn rightmost_left_sibling(&self) -> Option<&NamespacedHash<NS_ID_SIZE>>

Returns the rightmost node to the left of the proven range, if one exists

Source

pub fn is_of_absence(&self) -> bool

Returns true if the proof is an absence proof

Source

pub fn is_of_presence(&self) -> bool

Returns true if the proof is a presence proof

Trait Implementations§

Source§

impl<M: Clone + MerkleHash, const NS_ID_SIZE: usize> Clone for NamespaceProof<M, NS_ID_SIZE>

Source§

fn clone(&self) -> NamespaceProof<M, NS_ID_SIZE>

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<M: Debug + MerkleHash, const NS_ID_SIZE: usize> Debug for NamespaceProof<M, NS_ID_SIZE>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<M: PartialEq + MerkleHash, const NS_ID_SIZE: usize> PartialEq for NamespaceProof<M, NS_ID_SIZE>

Source§

fn eq(&self, other: &NamespaceProof<M, NS_ID_SIZE>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<M: MerkleHash, const NS_ID_SIZE: usize> StructuralPartialEq for NamespaceProof<M, NS_ID_SIZE>

Auto Trait Implementations§

§

impl<M, const NS_ID_SIZE: usize> Freeze for NamespaceProof<M, NS_ID_SIZE>

§

impl<M, const NS_ID_SIZE: usize> RefUnwindSafe for NamespaceProof<M, NS_ID_SIZE>

§

impl<M, const NS_ID_SIZE: usize> Send for NamespaceProof<M, NS_ID_SIZE>
where <M as MerkleHash>::Output: Send,

§

impl<M, const NS_ID_SIZE: usize> Sync for NamespaceProof<M, NS_ID_SIZE>
where <M as MerkleHash>::Output: Sync,

§

impl<M, const NS_ID_SIZE: usize> Unpin for NamespaceProof<M, NS_ID_SIZE>
where <M as MerkleHash>::Output: Unpin,

§

impl<M, const NS_ID_SIZE: usize> UnwindSafe for NamespaceProof<M, NS_ID_SIZE>
where <M as MerkleHash>::Output: UnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.