Struct diem_types::validator_verifier::ValidatorVerifier[][src]

pub struct ValidatorVerifier { /* fields omitted */ }
Expand description

Supports validation of signatures for known authors with individual voting powers. This struct can be used for all signature verification operations including block and network signature verification, respectively.

Implementations

impl ValidatorVerifier[src]

pub fn new(
    address_to_validator_info: BTreeMap<AccountAddress, ValidatorConsensusInfo>
) -> Self
[src]

Initialize with a map of account address to validator info and set quorum size to default (2f + 1) or zero if address_to_validator_info is empty.

pub fn new_single(author: AccountAddress, public_key: Ed25519PublicKey) -> Self[src]

Helper method to initialize with a single author and public key with quorum voting power 1.

pub fn verify<T: Serialize + CryptoHash>(
    &self,
    author: AccountAddress,
    message: &T,
    signature: &Ed25519Signature
) -> Result<(), VerifyError>
[src]

Verify the correctness of a signature of a message by a known author.

pub fn verify_aggregated_struct_signature<T: CryptoHash + Serialize>(
    &self,
    message: &T,
    aggregated_signature: &BTreeMap<AccountAddress, Ed25519Signature>
) -> Result<(), VerifyError>
[src]

This function will successfully return when at least quorum_size signatures of known authors are successfully verified. Also, an aggregated signature is considered invalid if any of the attached signatures is invalid or it does not correspond to a known author. The latter is to prevent malicious users from adding arbitrary content to the signature payload that would go unnoticed.

pub fn batch_verify_aggregated_signatures<T: CryptoHash + Serialize>(
    &self,
    message: &T,
    aggregated_signature: &BTreeMap<AccountAddress, Ed25519Signature>
) -> Result<(), VerifyError>
[src]

This function will try batch signature verification and falls back to normal iterated verification if batching fails.

pub fn check_voting_power<'a>(
    &self,
    authors: impl Iterator<Item = &'a AccountAddress>
) -> Result<(), VerifyError>
[src]

Ensure there is at least quorum_voting_power in the provided signatures and there are only known authors. According to the threshold verification policy, invalid public keys are not allowed.

pub fn get_public_key(
    &self,
    author: &AccountAddress
) -> Option<Ed25519PublicKey>
[src]

Returns the public key for this address.

pub fn get_voting_power(&self, author: &AccountAddress) -> Option<u64>[src]

Returns the voting power for this address.

pub fn get_ordered_account_addresses_iter(
    &self
) -> impl Iterator<Item = AccountAddress> + '_
[src]

Returns an ordered list of account addresses as an Iterator.

pub fn len(&self) -> usize[src]

Returns the number of authors to be validated.

pub fn is_empty(&self) -> bool[src]

Is there at least one author?

pub fn quorum_voting_power(&self) -> u64[src]

Returns quorum voting power.

Trait Implementations

impl Clone for ValidatorVerifier[src]

fn clone(&self) -> ValidatorVerifier[src]

Returns a copy of the value. Read more

fn clone_from(&mut self, source: &Self)1.0.0[src]

Performs copy-assignment from source. Read more

impl Debug for ValidatorVerifier[src]

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

Formats the value using the given formatter. Read more

impl<'de> Deserialize<'de> for ValidatorVerifier[src]

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error> where
    __D: Deserializer<'de>, 
[src]

Deserialize this value from the given Serde deserializer. Read more

impl Display for ValidatorVerifier[src]

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

Formats the value using the given formatter. Read more

impl From<&'_ ValidatorSet> for ValidatorVerifier[src]

fn from(validator_set: &ValidatorSet) -> Self[src]

Performs the conversion.

impl PartialEq<ValidatorVerifier> for ValidatorVerifier[src]

fn eq(&self, other: &ValidatorVerifier) -> bool[src]

This method tests for self and other values to be equal, and is used by ==. Read more

fn ne(&self, other: &ValidatorVerifier) -> bool[src]

This method tests for !=.

impl Serialize for ValidatorVerifier[src]

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error> where
    __S: Serializer
[src]

Serialize this value into the given Serde serializer. Read more

impl Eq for ValidatorVerifier[src]

impl StructuralEq for ValidatorVerifier[src]

impl StructuralPartialEq for ValidatorVerifier[src]

Auto Trait Implementations

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

pub fn type_id(&self) -> TypeId[src]

Gets the TypeId of self. Read more

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

pub fn borrow(&self) -> &T[src]

Immutably borrows from an owned value. Read more

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

pub fn borrow_mut(&mut self) -> &mut T[src]

Mutably borrows from an owned value. Read more

impl<T> From<T> for T[src]

pub fn from(t: T) -> T[src]

Performs the conversion.

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

pub fn into(self) -> U[src]

Performs the conversion.

impl<T> Same<T> for T

type Output = T

Should always be Self

impl<T> TestOnlyHash for T where
    T: Serialize + ?Sized
[src]

pub fn test_only_hash(&self) -> HashValue[src]

Generates a hash used only for tests.

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

pub fn to_owned(&self) -> T[src]

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

pub fn clone_into(&self, target: &mut T)[src]

🔬 This is a nightly-only experimental API. (toowned_clone_into)

recently added

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

impl<T> ToString for T where
    T: Display + ?Sized
[src]

pub default fn to_string(&self) -> String[src]

Converts the given value to a String. Read more

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

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

Performs the conversion.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

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

The type returned in the event of a conversion error.

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

Performs the conversion.

impl<V, T> VZip<V> for T where
    V: MultiLane<T>, 

pub fn vzip(self) -> V

impl<T> DeserializeOwned for T where
    T: for<'de> Deserialize<'de>, 
[src]