#[repr(C)]pub struct WithdrawProof {
pub commitment: PedersenCommitment,
pub equality_proof: CiphertextCommitmentEqualityProof,
pub range_proof: RangeProofU64,
}
Expand description
The withdraw proof.
It contains a ciphertext-commitment equality proof and a 64-bit range proof.
Fields§
§commitment: PedersenCommitment
New Pedersen commitment
equality_proof: CiphertextCommitmentEqualityProof
Associated equality proof
range_proof: RangeProofU64
Associated range proof
Implementations§
source§impl WithdrawProof
impl WithdrawProof
pub fn new( keypair: &ElGamalKeypair, final_balance: u64, final_ciphertext: &ElGamalCiphertext, transcript: &mut Transcript, ) -> Result<Self, ProofGenerationError>
pub fn verify( &self, pubkey: &ElGamalPubkey, final_ciphertext: &ElGamalCiphertext, transcript: &mut Transcript, ) -> Result<(), ProofVerificationError>
Trait Implementations§
source§impl Clone for WithdrawProof
impl Clone for WithdrawProof
source§fn clone(&self) -> WithdrawProof
fn clone(&self) -> WithdrawProof
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 moreimpl Copy for WithdrawProof
impl Pod for WithdrawProof
Auto Trait Implementations§
impl Freeze for WithdrawProof
impl RefUnwindSafe for WithdrawProof
impl Send for WithdrawProof
impl Sync for WithdrawProof
impl Unpin for WithdrawProof
impl UnwindSafe for WithdrawProof
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
Mutably borrows from an owned value. Read more
source§impl<T> CheckedBitPattern for Twhere
T: AnyBitPattern,
impl<T> CheckedBitPattern for Twhere
T: AnyBitPattern,
source§type Bits = T
type Bits = T
Self
must have the same layout as the specified Bits
except for
the possible invalid bit patterns being checked during
is_valid_bit_pattern
.source§fn is_valid_bit_pattern(_bits: &T) -> bool
fn is_valid_bit_pattern(_bits: &T) -> bool
If this function returns true, then it must be valid to reinterpret
bits
as &Self
.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<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