pub struct GenericKeygenBuilder<'a, E: Curve, M, L: SecurityLevel, D: Digest> { /* private fields */ }Expand description
Key generation entry point with choice for threshold or non-threshold variant
Implementations§
Source§impl<'a, E, L, D> GenericKeygenBuilder<'a, E, NonThreshold, L, D>where
E: Curve,
L: SecurityLevel,
D: Digest + Clone + 'static,
impl<'a, E, L, D> GenericKeygenBuilder<'a, E, NonThreshold, L, D>where
E: Curve,
L: SecurityLevel,
D: Digest + Clone + 'static,
Sourcepub fn new(eid: ExecutionId<'a>, i: u16, n: u16) -> Self
pub fn new(eid: ExecutionId<'a>, i: u16, n: u16) -> Self
Constructs KeygenBuilder
Takes local party index $i$ and number of parties $n$
Source§impl<'a, E, L, D, M> GenericKeygenBuilder<'a, E, M, L, D>where
E: Curve,
L: SecurityLevel,
D: Digest + Clone + 'static,
impl<'a, E, L, D, M> GenericKeygenBuilder<'a, E, M, L, D>where
E: Curve,
L: SecurityLevel,
D: Digest + Clone + 'static,
Sourcepub fn set_threshold(
self,
t: u16,
) -> GenericKeygenBuilder<'a, E, WithThreshold, L, D>
pub fn set_threshold( self, t: u16, ) -> GenericKeygenBuilder<'a, E, WithThreshold, L, D>
Specifies to generate key shares for a threshold scheme
Sourcepub fn set_digest<D2>(self) -> GenericKeygenBuilder<'a, E, M, L, D2>where
D2: Digest + Clone + 'static,
pub fn set_digest<D2>(self) -> GenericKeygenBuilder<'a, E, M, L, D2>where
D2: Digest + Clone + 'static,
Specifies another hash function to use
Sourcepub fn set_security_level<L2>(self) -> GenericKeygenBuilder<'a, E, M, L2, D>where
L2: SecurityLevel,
pub fn set_security_level<L2>(self) -> GenericKeygenBuilder<'a, E, M, L2, D>where
L2: SecurityLevel,
Specifies security level
Sourcepub fn set_progress_tracer(self, tracer: &'a mut dyn Tracer) -> Self
pub fn set_progress_tracer(self, tracer: &'a mut dyn Tracer) -> Self
Sets a tracer that tracks progress of protocol execution
Sourcepub fn enforce_reliable_broadcast(self, enforce: bool) -> Self
pub fn enforce_reliable_broadcast(self, enforce: bool) -> Self
Ensures reliability of broadcast channel by adding one extra communication round
CGGMP24 protocol requires message in the first round to be sent over reliable broadcast channel. We ensure reliability of the broadcast channel by introducing extra communication round (at cost of additional latency). You may disable it, for instance, if your transport layer is reliable by construction (e.g. you use blockchain for communications).
Default: true.
Source§impl<'a, E, L, D> GenericKeygenBuilder<'a, E, NonThreshold, L, D>where
E: Curve,
L: SecurityLevel,
D: Digest + Clone + 'static,
impl<'a, E, L, D> GenericKeygenBuilder<'a, E, NonThreshold, L, D>where
E: Curve,
L: SecurityLevel,
D: Digest + Clone + 'static,
Sourcepub async fn start<R, M>(
self,
rng: &mut R,
party: M,
) -> Result<CoreKeyShare<E>, KeygenError>
pub async fn start<R, M>( self, rng: &mut R, party: M, ) -> Result<CoreKeyShare<E>, KeygenError>
Starts key generation
Sourcepub fn into_state_machine<R>(
self,
rng: &'a mut R,
) -> impl StateMachine<Output = Result<CoreKeyShare<E>, KeygenError>, Msg = Msg<E, L, D>> + 'a
pub fn into_state_machine<R>( self, rng: &'a mut R, ) -> impl StateMachine<Output = Result<CoreKeyShare<E>, KeygenError>, Msg = Msg<E, L, D>> + 'a
Returns a state machine that can be used to carry out the key generation protocol
See [round_based::state_machine] for details on how that can be done.
Source§impl<'a, E, L, D> GenericKeygenBuilder<'a, E, WithThreshold, L, D>where
E: Curve,
L: SecurityLevel,
D: Digest + Clone + 'static,
impl<'a, E, L, D> GenericKeygenBuilder<'a, E, WithThreshold, L, D>where
E: Curve,
L: SecurityLevel,
D: Digest + Clone + 'static,
Sourcepub async fn start<R, M>(
self,
rng: &mut R,
party: M,
) -> Result<CoreKeyShare<E>, KeygenError>
pub async fn start<R, M>( self, rng: &mut R, party: M, ) -> Result<CoreKeyShare<E>, KeygenError>
Starts threshold key generation
Sourcepub fn into_state_machine<R>(
self,
rng: &'a mut R,
) -> impl StateMachine<Output = Result<CoreKeyShare<E>, KeygenError>, Msg = Msg<E, L, D>> + 'a
pub fn into_state_machine<R>( self, rng: &'a mut R, ) -> impl StateMachine<Output = Result<CoreKeyShare<E>, KeygenError>, Msg = Msg<E, L, D>> + 'a
Returns a state machine that can be used to carry out the key generation protocol
See [round_based::state_machine] for details on how that can be done.
Auto Trait Implementations§
impl<'a, E, M, L, D> Freeze for GenericKeygenBuilder<'a, E, M, L, D>where
M: Freeze,
impl<'a, E, M, L, D> !RefUnwindSafe for GenericKeygenBuilder<'a, E, M, L, D>
impl<'a, E, M, L, D> Send for GenericKeygenBuilder<'a, E, M, L, D>
impl<'a, E, M, L, D> Sync for GenericKeygenBuilder<'a, E, M, L, D>
impl<'a, E, M, L, D> Unpin for GenericKeygenBuilder<'a, E, M, L, D>
impl<'a, E, M, L, D> UnsafeUnpin for GenericKeygenBuilder<'a, E, M, L, D>where
M: UnsafeUnpin,
impl<'a, E, M, L, D> !UnwindSafe for GenericKeygenBuilder<'a, E, M, L, 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
§impl<T> Conv for T
impl<T> Conv for T
§impl<T> FmtForward for T
impl<T> FmtForward for T
§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self to use its Binary implementation when Debug-formatted.§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self to use its Display implementation when
Debug-formatted.§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self to use its LowerExp implementation when
Debug-formatted.§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self to use its LowerHex implementation when
Debug-formatted.§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self to use its Octal implementation when Debug-formatted.§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self to use its Pointer implementation when
Debug-formatted.§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self to use its UpperExp implementation when
Debug-formatted.§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self to use its UpperHex implementation when
Debug-formatted.§fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
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>
§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read more§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read more§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self, then passes self.as_ref() into the pipe function.§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self, then passes self.as_mut() into the pipe
function.§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self, then passes self.deref() into the pipe function.§impl<T> Tap for T
impl<T> Tap for T
§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B> of a value. Read more§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B> of a value. Read more§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R> view of a value. Read more§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R> view of a value. Read more§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target of a value. Read more§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target of a value. Read more§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap() only in debug builds, and is erased in release builds.§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut() only in debug builds, and is erased in release
builds.§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow() only in debug builds, and is erased in release
builds.§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut() only in debug builds, and is erased in release
builds.§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref() only in debug builds, and is erased in release
builds.§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut() only in debug builds, and is erased in release
builds.§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref() only in debug builds, and is erased in release
builds.