pub struct Notarize<V: Variant, D: Digest> {
pub proposal: Proposal<D>,
pub proposal_signature: PartialSignature<V>,
pub seed_signature: PartialSignature<V>,
}
Expand description
Notarize represents a validator’s vote to notarize a proposal. In threshold_simplex, it contains a partial signature on the proposal and a partial signature for the seed. The seed is used for leader election and as a source of randomness.
Fields§
§proposal: Proposal<D>
The proposal that is being notarized
proposal_signature: PartialSignature<V>
The validator’s partial signature on the proposal
seed_signature: PartialSignature<V>
The validator’s partial signature on the seed (for leader election/randomness)
Implementations§
Source§impl<V: Variant, D: Digest> Notarize<V, D>
impl<V: Variant, D: Digest> Notarize<V, D>
Sourcepub fn new(
proposal: Proposal<D>,
proposal_signature: PartialSignature<V>,
seed_signature: PartialSignature<V>,
) -> Self
pub fn new( proposal: Proposal<D>, proposal_signature: PartialSignature<V>, seed_signature: PartialSignature<V>, ) -> Self
Creates a new notarize with the given proposal and signatures.
Sourcepub fn verify(&self, namespace: &[u8], polynomial: &[V::Public]) -> bool
pub fn verify(&self, namespace: &[u8], polynomial: &[V::Public]) -> bool
Verifies the PartialSignatures on this Notarize.
This ensures that:
- The notarize signature is valid for the claimed proposal
- The seed signature is valid for the view
- Both signatures are from the same signer
Trait Implementations§
Source§impl<V: Variant, D: Digest> EncodeSize for Notarize<V, D>
impl<V: Variant, D: Digest> EncodeSize for Notarize<V, D>
Source§fn encode_size(&self) -> usize
fn encode_size(&self) -> usize
Returns the encoded size of this value (in bytes).
Source§impl<V: Variant, D: Digest> Read for Notarize<V, D>
impl<V: Variant, D: Digest> Read for Notarize<V, D>
impl<V: Eq + Variant, D: Eq + Digest> Eq for Notarize<V, D>
impl<V: Variant, D: Digest> StructuralPartialEq for Notarize<V, D>
Auto Trait Implementations§
impl<V, D> Freeze for Notarize<V, D>
impl<V, D> RefUnwindSafe for Notarize<V, D>
impl<V, D> Send for Notarize<V, D>
impl<V, D> Sync for Notarize<V, D>
impl<V, D> Unpin for Notarize<V, D>
impl<V, D> UnwindSafe for Notarize<V, D>
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
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Encode for Twhere
T: Write + EncodeSize,
impl<T> Encode for Twhere
T: Write + EncodeSize,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
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>
Converts
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>
Converts
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