#[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 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 (seeConfidentialTransferInstruction::ConfigureAccount
)
auditor_encryption_pubkey: OptionalNonZeroEncryptionPubkey
Authority to decode any transfer amount in a confidential transafer.
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
impl Clone for ConfidentialTransferMint
source§fn clone(&self) -> ConfidentialTransferMint
fn clone(&self) -> ConfidentialTransferMint
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for ConfidentialTransferMint
impl Debug for ConfidentialTransferMint
source§impl Default for ConfidentialTransferMint
impl Default for ConfidentialTransferMint
source§fn default() -> ConfidentialTransferMint
fn default() -> ConfidentialTransferMint
source§impl Extension for ConfidentialTransferMint
impl Extension for ConfidentialTransferMint
source§const TYPE: ExtensionType = ExtensionType::ConfidentialTransferMint
const TYPE: ExtensionType = ExtensionType::ConfidentialTransferMint
source§impl PartialEq<ConfidentialTransferMint> for ConfidentialTransferMint
impl PartialEq<ConfidentialTransferMint> for ConfidentialTransferMint
source§fn eq(&self, other: &ConfidentialTransferMint) -> bool
fn eq(&self, other: &ConfidentialTransferMint) -> bool
self
and other
values to be equal, and is used
by ==
.impl Copy for ConfidentialTransferMint
impl Pod for ConfidentialTransferMint
impl StructuralPartialEq for ConfidentialTransferMint
Auto Trait Implementations§
impl RefUnwindSafe for ConfidentialTransferMint
impl Send for ConfidentialTransferMint
impl Sync for ConfidentialTransferMint
impl Unpin for ConfidentialTransferMint
impl UnwindSafe for ConfidentialTransferMint
Blanket Implementations§
source§impl<T> CheckedBitPattern for Twhere
T: AnyBitPattern,
impl<T> CheckedBitPattern for Twhere T: AnyBitPattern,
§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
bits
as &Self
.