Struct scicrypt::cryptosystems::integer_el_gamal::IntegerElGamal
source · [−]pub struct IntegerElGamal { /* private fields */ }
Expand description
Multiplicatively homomorphic ElGamal over a safe prime group where the generator is 4.
As an example we compute the product between 4 and 6 using ElGamal’s homomorphic property.
let mut rng = GeneralRng::new(OsRng);
let el_gamal = IntegerElGamal::setup(&Default::default());
let (public_key, secret_key) = el_gamal.generate_keys(&mut rng);
let ciphertext_1 = public_key.encrypt(&Integer::from(4), &mut rng);
let ciphertext_2 = public_key.encrypt(&Integer::from(6), &mut rng);
println!("[4] * [6] = [{}]", secret_key.decrypt(&(ciphertext_1 * ciphertext_2)));
// Prints: "[4] * [6] = [24]".
Trait Implementations
sourceimpl AsymmetricCryptosystem for IntegerElGamal
impl AsymmetricCryptosystem for IntegerElGamal
sourcefn setup(security_param: &BitsOfSecurity) -> IntegerElGamal
fn setup(security_param: &BitsOfSecurity) -> IntegerElGamal
Uses previously randomly generated safe primes as the modulus for pre-set modulus sizes.
sourcefn generate_keys<R>(
&self,
rng: &mut GeneralRng<R>
) -> (IntegerElGamalPK, IntegerElGamalSK) where
R: SecureRng,
fn generate_keys<R>(
&self,
rng: &mut GeneralRng<R>
) -> (IntegerElGamalPK, IntegerElGamalSK) where
R: SecureRng,
Generates a fresh ElGamal keypair.
let el_gamal = IntegerElGamal::setup(&Default::default());
let (public_key, secret_key) = el_gamal.generate_keys(&mut rng);
type PublicKey = IntegerElGamalPK
type PublicKey = IntegerElGamalPK
The public key, used for encrypting plaintexts.
type SecretKey = IntegerElGamalSK
type SecretKey = IntegerElGamalSK
The secret key, used for decrypting ciphertexts.
sourceimpl Clone for IntegerElGamal
impl Clone for IntegerElGamal
sourcefn clone(&self) -> IntegerElGamal
fn clone(&self) -> IntegerElGamal
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
Auto Trait Implementations
impl RefUnwindSafe for IntegerElGamal
impl Send for IntegerElGamal
impl Sync for IntegerElGamal
impl Unpin for IntegerElGamal
impl UnwindSafe for IntegerElGamal
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
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 Dst where
Src: CheckedCast<Dst>,
impl<Src, Dst> CheckedCastFrom<Src> for Dst where
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 Dst where
Src: OverflowingCast<Dst>,
impl<Src, Dst> OverflowingCastFrom<Src> for Dst where
Src: OverflowingCast<Dst>,
sourcefn overflowing_cast_from(src: Src) -> (Dst, bool)
fn overflowing_cast_from(src: Src) -> (Dst, bool)
OverflowingCasts the value.
sourceimpl<T> SaturatingAs for T
impl<T> SaturatingAs for T
sourcefn saturating_as<Dst>(self) -> Dst where
T: SaturatingCast<Dst>,
fn saturating_as<Dst>(self) -> Dst where
T: SaturatingCast<Dst>,
Casts the value.
sourceimpl<Src, Dst> SaturatingCastFrom<Src> for Dst where
Src: SaturatingCast<Dst>,
impl<Src, Dst> SaturatingCastFrom<Src> for Dst where
Src: SaturatingCast<Dst>,
sourcefn saturating_cast_from(src: Src) -> Dst
fn saturating_cast_from(src: Src) -> Dst
Casts the value.
sourceimpl<T> ToOwned for T where
T: Clone,
impl<T> ToOwned for T where
T: Clone,
type Owned = T
type Owned = T
The resulting type after obtaining ownership.
sourcefn clone_into(&self, target: &mut T)
fn clone_into(&self, target: &mut T)
toowned_clone_into
)Uses borrowed data to replace owned data, usually by cloning. Read more
sourceimpl<T> UnwrappedAs for T
impl<T> UnwrappedAs for T
sourcefn unwrapped_as<Dst>(self) -> Dst where
T: UnwrappedCast<Dst>,
fn unwrapped_as<Dst>(self) -> Dst where
T: UnwrappedCast<Dst>,
Casts the value.
sourceimpl<Src, Dst> UnwrappedCastFrom<Src> for Dst where
Src: UnwrappedCast<Dst>,
impl<Src, Dst> UnwrappedCastFrom<Src> for Dst where
Src: UnwrappedCast<Dst>,
sourcefn unwrapped_cast_from(src: Src) -> Dst
fn unwrapped_cast_from(src: Src) -> Dst
UnwrappedCasts the value.
sourceimpl<T> WrappingAs for T
impl<T> WrappingAs for T
sourcefn wrapping_as<Dst>(self) -> Dst where
T: WrappingCast<Dst>,
fn wrapping_as<Dst>(self) -> Dst where
T: WrappingCast<Dst>,
Casts the value.
sourceimpl<Src, Dst> WrappingCastFrom<Src> for Dst where
Src: WrappingCast<Dst>,
impl<Src, Dst> WrappingCastFrom<Src> for Dst where
Src: WrappingCast<Dst>,
sourcefn wrapping_cast_from(src: Src) -> Dst
fn wrapping_cast_from(src: Src) -> Dst
WrappingCasts the value.