#[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<ConfidentialTransferMint> for ConfidentialTransferMint

source§

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

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

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

This method 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§

§

impl<T> AbiExample for T

§

default fn example() -> T

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

const: unstable · source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

const: unstable · source§

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

Mutably borrows from an owned value. Read more
source§

impl<T> CheckedBitPattern for Twhere T: AnyBitPattern,

§

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> From<T> for T

const: unstable · source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

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

const: unstable · 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.

§

impl<T> Pointable for T

§

const ALIGN: usize = mem::align_of::<T>()

The alignment of pointer.
§

type Init = T

The type for initializers.
§

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

Initializes a with the given initializer. Read more
§

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

Dereferences the given pointer. Read more
§

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

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

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

impl<T> Same<T> for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for Twhere T: Clone,

§

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 Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
const: unstable · source§

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

Performs the conversion.
source§

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

§

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

The type returned in the event of a conversion error.
const: unstable · source§

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

Performs the conversion.
§

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

§

fn vzip(self) -> V

source§

impl<T> AnyBitPattern for Twhere T: Pod,

source§

impl<T> NoUninit for Twhere T: Pod,