pub struct NOfNIntegerElGamal { /* private fields */ }
Expand description
N-out-of-N Threshold ElGamal cryptosystem over integers: Extension of ElGamal that requires n out of n parties to successfully decrypt. For this scheme there exists an efficient distributed key generation protocol.
Trait Implementations
sourceimpl Clone for NOfNIntegerElGamal
impl Clone for NOfNIntegerElGamal
sourcefn clone(&self) -> NOfNIntegerElGamal
fn clone(&self) -> NOfNIntegerElGamal
Returns a copy of the value. Read more
1.0.0 · sourcefn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from source
. Read more
sourceimpl NOfNCryptosystem for NOfNIntegerElGamal
impl NOfNCryptosystem for NOfNIntegerElGamal
sourcefn setup(security_param: &BitsOfSecurity) -> NOfNIntegerElGamal
fn setup(security_param: &BitsOfSecurity) -> NOfNIntegerElGamal
Uses previously randomly generated safe primes as the modulus for pre-set modulus sizes.
type PublicKey = IntegerElGamalPK
type PublicKey = IntegerElGamalPK
The public key used to encrypt plaintexts.
type SecretKey = NOfNIntegerElGamalSK
type SecretKey = NOfNIntegerElGamalSK
The secret key used to partially decrypt ciphertexts.
sourcefn generate_keys<R>(
&self,
key_count_n: usize,
rng: &mut GeneralRng<R>
) -> (IntegerElGamalPK, Vec<NOfNIntegerElGamalSK, Global>)where
R: SecureRng,
fn generate_keys<R>(
&self,
key_count_n: usize,
rng: &mut GeneralRng<R>
) -> (IntegerElGamalPK, Vec<NOfNIntegerElGamalSK, Global>)where
R: SecureRng,
Generate a public key, and $n$ secret keys using a cryptographic RNG.
Auto Trait Implementations
impl RefUnwindSafe for NOfNIntegerElGamal
impl Send for NOfNIntegerElGamal
impl !Sync for NOfNIntegerElGamal
impl Unpin for NOfNIntegerElGamal
impl UnwindSafe for NOfNIntegerElGamal
Blanket Implementations
sourceimpl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> CheckedAs for T
impl<T> CheckedAs for T
sourcefn checked_as<Dst>(self) -> Option<Dst>where
T: CheckedCast<Dst>,
fn checked_as<Dst>(self) -> Option<Dst>where
T: CheckedCast<Dst>,
Casts the value.
sourceimpl<Src, Dst> CheckedCastFrom<Src> for Dstwhere
Src: CheckedCast<Dst>,
impl<Src, Dst> CheckedCastFrom<Src> for Dstwhere
Src: CheckedCast<Dst>,
sourcefn checked_cast_from(src: Src) -> Option<Dst>
fn checked_cast_from(src: Src) -> Option<Dst>
Casts the value.
sourceimpl<T> OverflowingAs for T
impl<T> OverflowingAs for T
sourcefn overflowing_as<Dst>(self) -> (Dst, bool)where
T: OverflowingCast<Dst>,
fn overflowing_as<Dst>(self) -> (Dst, bool)where
T: OverflowingCast<Dst>,
Casts the value.
sourceimpl<Src, Dst> OverflowingCastFrom<Src> for Dstwhere
Src: OverflowingCast<Dst>,
impl<Src, Dst> OverflowingCastFrom<Src> for Dstwhere
Src: OverflowingCast<Dst>,
sourcefn overflowing_cast_from(src: Src) -> (Dst, bool)
fn overflowing_cast_from(src: Src) -> (Dst, bool)
Casts the value.
sourceimpl<T> SaturatingAs for T
impl<T> SaturatingAs for T
sourcefn saturating_as<Dst>(self) -> Dstwhere
T: SaturatingCast<Dst>,
fn saturating_as<Dst>(self) -> Dstwhere
T: SaturatingCast<Dst>,
Casts the value.
sourceimpl<Src, Dst> SaturatingCastFrom<Src> for Dstwhere
Src: SaturatingCast<Dst>,
impl<Src, Dst> SaturatingCastFrom<Src> for Dstwhere
Src: SaturatingCast<Dst>,
sourcefn saturating_cast_from(src: Src) -> Dst
fn saturating_cast_from(src: Src) -> Dst
Casts the value.
sourceimpl<T> UnwrappedAs for T
impl<T> UnwrappedAs for T
sourcefn unwrapped_as<Dst>(self) -> Dstwhere
T: UnwrappedCast<Dst>,
fn unwrapped_as<Dst>(self) -> Dstwhere
T: UnwrappedCast<Dst>,
Casts the value.
sourceimpl<Src, Dst> UnwrappedCastFrom<Src> for Dstwhere
Src: UnwrappedCast<Dst>,
impl<Src, Dst> UnwrappedCastFrom<Src> for Dstwhere
Src: UnwrappedCast<Dst>,
sourcefn unwrapped_cast_from(src: Src) -> Dst
fn unwrapped_cast_from(src: Src) -> Dst
Casts the value.
sourceimpl<T> WrappingAs for T
impl<T> WrappingAs for T
sourcefn wrapping_as<Dst>(self) -> Dstwhere
T: WrappingCast<Dst>,
fn wrapping_as<Dst>(self) -> Dstwhere
T: WrappingCast<Dst>,
Casts the value.
sourceimpl<Src, Dst> WrappingCastFrom<Src> for Dstwhere
Src: WrappingCast<Dst>,
impl<Src, Dst> WrappingCastFrom<Src> for Dstwhere
Src: WrappingCast<Dst>,
sourcefn wrapping_cast_from(src: Src) -> Dst
fn wrapping_cast_from(src: Src) -> Dst
Casts the value.