pub struct ParticipantExchangingSecrets<G: Group> { /* private fields */ }
Expand description

Participant state during the third and final stage of the committed Pedersen’s distributed key generation.

During this stage, participants exchange secret shares corresponding to the polynomials exchanged on the previous stage. The exchange happens using secure peer-to-peer channels established between pairs of participants.

Implementations§

source§

impl<G: Group> ParticipantExchangingSecrets<G>

source

pub fn params(&self) -> &Params

Returns params of this threshold ElGamal encryption scheme.

source

pub fn index(&self) -> usize

Returns 0-based index of this participant.

source

pub fn secret_share_for_participant( &self, participant_index: usize ) -> SecretKey<G>

Returns the secret share for a participant with the specified participant_index.

source

pub fn missing_shares(&self) -> impl Iterator<Item = usize> + '_

Returns indices of parties whose secret shares were not provided.

source

pub fn insert_secret_share( &mut self, participant_index: usize, secret_share: SecretKey<G> ) -> Result<(), Error>

Inserts a secret share from participant with index participant_index and checks that the share is valid.

Errors

Returns an error if provided secret share doesn’t correspond to the participant’s public polynomial collected on the previous step of the DKG protocol.

Panics

Panics if participant_index is out of bounds.

source

pub fn complete(self) -> Result<ActiveParticipant<G>, Error>

Completes the distributed key generation protocol returning an ActiveParticipant.

Errors

Returns error if secret shares from some parties were not provided, or if the PublicKeySet cannot be created from participants’ keys.

Panics

Panics if shares from any participants are missing. If this is not known statically, check with Self::missing_shares() before calling this method.

Trait Implementations§

source§

impl<G: Clone + Group> Clone for ParticipantExchangingSecrets<G>

source§

fn clone(&self) -> ParticipantExchangingSecrets<G>

Returns a copy 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<G: Debug + Group> Debug for ParticipantExchangingSecrets<G>

source§

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

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

impl<'de, G: Group> Deserialize<'de> for ParticipantExchangingSecrets<G>

source§

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

Deserialize this value from the given Serde deserializer. Read more
source§

impl<G: Group> Serialize for ParticipantExchangingSecrets<G>

source§

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

Serialize this value into the given Serde serializer. Read more

Auto Trait Implementations§

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

source§

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

Mutably borrows from an owned value. 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 Twhere 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

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for Twhere T: Clone,

§

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 Twhere U: Into<T>,

§

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 Twhere U: TryFrom<T>,

§

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.
§

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

§

fn vzip(self) -> V

source§

impl<T> DeserializeOwned for Twhere T: for<'de> Deserialize<'de>,