pub struct ElGamalPubkey(/* private fields */);
Expand description
Public key for the ElGamal encryption scheme.
Implementations§
source§impl ElGamalPubkey
impl ElGamalPubkey
sourcepub fn new(secret: &ElGamalSecretKey) -> Self
pub fn new(secret: &ElGamalSecretKey) -> Self
Derives the ElGamalPubkey
that uniquely corresponds to an ElGamalSecretKey
.
pub fn get_point(&self) -> &RistrettoPoint
pub fn to_bytes(&self) -> [u8; 32]
pub fn from_bytes(bytes: &[u8]) -> Option<ElGamalPubkey>
sourcepub fn encrypt<T: Into<Scalar>>(&self, amount: T) -> ElGamalCiphertext
pub fn encrypt<T: Into<Scalar>>(&self, amount: T) -> ElGamalCiphertext
Encrypts an amount under the public key.
This function is randomized. It internally samples a scalar element using OsRng
.
sourcepub fn encrypt_with<T: Into<Scalar>>(
&self,
amount: T,
opening: &PedersenOpening,
) -> ElGamalCiphertext
pub fn encrypt_with<T: Into<Scalar>>( &self, amount: T, opening: &PedersenOpening, ) -> ElGamalCiphertext
Encrypts an amount under the public key and an input Pedersen opening.
sourcepub fn decrypt_handle(self, opening: &PedersenOpening) -> DecryptHandle
pub fn decrypt_handle(self, opening: &PedersenOpening) -> DecryptHandle
Generates a decryption handle for an ElGamal public key under a Pedersen opening.
Trait Implementations§
source§impl Clone for ElGamalPubkey
impl Clone for ElGamalPubkey
source§fn clone(&self) -> ElGamalPubkey
fn clone(&self) -> ElGamalPubkey
Returns a copy of the value. Read more
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moresource§impl Debug for ElGamalPubkey
impl Debug for ElGamalPubkey
source§impl Default for ElGamalPubkey
impl Default for ElGamalPubkey
source§fn default() -> ElGamalPubkey
fn default() -> ElGamalPubkey
Returns the “default value” for a type. Read more
source§impl<'de> Deserialize<'de> for ElGamalPubkey
impl<'de> Deserialize<'de> for ElGamalPubkey
source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
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 Display for ElGamalPubkey
impl Display for ElGamalPubkey
source§impl EncodableKey for ElGamalPubkey
impl EncodableKey for ElGamalPubkey
fn read<R: Read>(reader: &mut R) -> Result<Self, Box<dyn Error>>
fn write<W: Write>(&self, writer: &mut W) -> Result<String, Box<dyn Error>>
fn read_from_file<F>(path: F) -> Result<Self, Box<dyn Error>>
fn write_to_file<F>(&self, outfile: F) -> Result<String, Box<dyn Error>>
source§impl From<ElGamalPubkey> for ElGamalPubkey
impl From<ElGamalPubkey> for ElGamalPubkey
source§fn from(decoded_pubkey: ElGamalPubkey) -> Self
fn from(decoded_pubkey: ElGamalPubkey) -> Self
Converts to this type from the input type.
source§impl PartialEq for ElGamalPubkey
impl PartialEq for ElGamalPubkey
source§impl Serialize for ElGamalPubkey
impl Serialize for ElGamalPubkey
source§impl TryFrom<ElGamalPubkey> for ElGamalPubkey
impl TryFrom<ElGamalPubkey> for ElGamalPubkey
source§type Error = ElGamalError
type Error = ElGamalError
The type returned in the event of a conversion error.
source§impl Zeroize for ElGamalPubkey
impl Zeroize for ElGamalPubkey
impl Copy for ElGamalPubkey
impl Eq for ElGamalPubkey
impl StructuralPartialEq for ElGamalPubkey
Auto Trait Implementations§
impl Freeze for ElGamalPubkey
impl RefUnwindSafe for ElGamalPubkey
impl Send for ElGamalPubkey
impl Sync for ElGamalPubkey
impl Unpin for ElGamalPubkey
impl UnwindSafe for ElGamalPubkey
Blanket Implementations§
source§impl<T> AbiEnumVisitor for T
impl<T> AbiEnumVisitor for T
default fn visit_for_abi( &self, _digester: &mut AbiDigester, ) -> Result<AbiDigester, DigestError>
source§impl<T> AbiEnumVisitor for T
impl<T> AbiEnumVisitor for T
default fn visit_for_abi( &self, digester: &mut AbiDigester, ) -> Result<AbiDigester, DigestError>
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
Mutably borrows from an owned value. Read more
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit
)source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more