Struct ConfidentialTransferMint

Source
#[repr(C)]
pub struct ConfidentialTransferMint { pub authority: OptionalNonZeroPubkey, pub auto_approve_new_accounts: PodBool, pub auditor_encryption_pubkey: OptionalNonZeroEncryptionPubkey, pub withdraw_withheld_authority_encryption_pubkey: OptionalNonZeroEncryptionPubkey, pub withheld_amount: EncryptedWithheldAmount, }
Expand description

Confidential transfer mint configuration

Fields§

§authority: OptionalNonZeroPubkey

Authority to modify the ConfidentialTransferMint configuration and to approve new accounts (if auto_approve_new_accounts is true)

The legacy Token Multisig account is not supported as the authority

§auto_approve_new_accounts: PodBool

Indicate if newly configured accounts must be approved by the authority before they may be used by the user.

  • If true, no approval is required and new accounts may be used immediately
  • If false, the authority must approve newly configured accounts (see ConfidentialTransferInstruction::ConfigureAccount)
§auditor_encryption_pubkey: OptionalNonZeroEncryptionPubkey

Authority to decode any transfer amount in a confidential transafer.

§withdraw_withheld_authority_encryption_pubkey: OptionalNonZeroEncryptionPubkey

Authority to withraw withheld fees that are associated with accounts. It must be set to None if the mint is not extended for fees.

Note that the withdraw withheld authority has the ability to decode any withheld fee amount that are associated with accounts. When combined with the fee parameters, the withheld fee amounts can reveal information about transfer amounts.

  • If not None, transfers must include ElGamal cyphertext of the transfer fee with this public key. If this is the case, but the base mint is not extended for fees, then any transfer will fail.
  • If None, transfer fee is disabled. If this is the case, but the base mint is extended for fees, then any transfer will fail.
§withheld_amount: EncryptedWithheldAmount

Withheld transfer fee confidential tokens that have been moved to the mint for withdrawal. This will always be zero if fees are never enabled.

Trait Implementations§

Source§

impl Clone for ConfidentialTransferMint

Source§

fn clone(&self) -> ConfidentialTransferMint

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for ConfidentialTransferMint

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for ConfidentialTransferMint

Source§

fn default() -> ConfidentialTransferMint

Returns the “default value” for a type. Read more
Source§

impl Extension for ConfidentialTransferMint

Source§

const TYPE: ExtensionType = ExtensionType::ConfidentialTransferMint

Associated extension type enum, checked at the start of TLV entries
Source§

impl PartialEq for ConfidentialTransferMint

Source§

fn eq(&self, other: &ConfidentialTransferMint) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Zeroable for ConfidentialTransferMint

Source§

fn zeroed() -> Self

Source§

impl Copy for ConfidentialTransferMint

Source§

impl Pod for ConfidentialTransferMint

Source§

impl StructuralPartialEq for ConfidentialTransferMint

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> AbiExample for T

Source§

default fn example() -> T

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CheckedBitPattern for T
where T: AnyBitPattern,

Source§

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

If this function returns true, then it must be valid to reinterpret bits as &Self.
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> AnyBitPattern for T
where T: Pod,

Source§

impl<T> NoUninit for T
where T: Pod,