#[repr(u16)]
pub enum ExtensionType {
Show 24 variants Uninitialized = 0, TransferFeeConfig = 1, TransferFeeAmount = 2, MintCloseAuthority = 3, ConfidentialTransferMint = 4, ConfidentialTransferAccount = 5, DefaultAccountState = 6, ImmutableOwner = 7, MemoTransfer = 8, NonTransferable = 9, InterestBearingConfig = 10, CpiGuard = 11, PermanentDelegate = 12, NonTransferableAccount = 13, TransferHook = 14, TransferHookAccount = 15, ConfidentialTransferFeeConfig = 16, ConfidentialTransferFeeAmount = 17, MetadataPointer = 18, TokenMetadata = 19, GroupPointer = 20, TokenGroup = 21, GroupMemberPointer = 22, TokenGroupMember = 23,
}
Expand description

Extensions that can be applied to mints or accounts. Mint extensions must only be applied to mint accounts, and account extensions must only be applied to token holding accounts.

Variants§

§

Uninitialized = 0

Used as padding if the account size would otherwise be 355, same as a multisig

§

TransferFeeConfig = 1

Includes transfer fee rate info and accompanying authorities to withdraw and set the fee

§

TransferFeeAmount = 2

Includes withheld transfer fees

§

MintCloseAuthority = 3

Includes an optional mint close authority

§

ConfidentialTransferMint = 4

Auditor configuration for confidential transfers

§

ConfidentialTransferAccount = 5

State for confidential transfers

§

DefaultAccountState = 6

Specifies the default Account::state for new Accounts

§

ImmutableOwner = 7

Indicates that the Account owner authority cannot be changed

§

MemoTransfer = 8

Require inbound transfers to have memo

§

NonTransferable = 9

Indicates that the tokens from this mint can’t be transfered

§

InterestBearingConfig = 10

Tokens accrue interest over time,

§

CpiGuard = 11

Locks privileged token operations from happening via CPI

§

PermanentDelegate = 12

Includes an optional permanent delegate

§

NonTransferableAccount = 13

Indicates that the tokens in this account belong to a non-transferable mint

§

TransferHook = 14

Mint requires a CPI to a program implementing the “transfer hook” interface

§

TransferHookAccount = 15

Indicates that the tokens in this account belong to a mint with a transfer hook

§

ConfidentialTransferFeeConfig = 16

Includes encrypted withheld fees and the encryption public that they are encrypted under

§

ConfidentialTransferFeeAmount = 17

Includes confidential withheld transfer fees

§

MetadataPointer = 18

Mint contains a pointer to another account (or the same account) that holds metadata

§

TokenMetadata = 19

Mint contains token-metadata

§

GroupPointer = 20

Mint contains a pointer to another account (or the same account) that holds group configurations

§

TokenGroup = 21

Mint contains token group configurations

§

GroupMemberPointer = 22

Mint contains a pointer to another account (or the same account) that holds group member configurations

§

TokenGroupMember = 23

Mint contains token group member configurations

Implementations§

source§

impl ExtensionType

source

pub fn try_calculate_account_len<S: BaseState>( extension_types: &[Self] ) -> Result<usize, ProgramError>

Get the required account data length for the given ExtensionTypes

Fails if any of the extension types has a variable length

source

pub fn get_account_type(&self) -> AccountType

Get the associated account type

source

pub fn get_required_init_account_extensions( mint_extension_types: &[Self] ) -> Vec<Self>

Based on a set of AccountType::Mint ExtensionTypes, get the list of AccountType::Account ExtensionTypes required on InitializeAccount

source

pub fn check_for_invalid_mint_extension_combinations( mint_extension_types: &[Self] ) -> Result<(), TokenError>

Check for invalid combination of mint extensions

Trait Implementations§

source§

impl Clone for ExtensionType

source§

fn clone(&self) -> ExtensionType

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 ExtensionType

source§

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

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

impl From<ExtensionType> for [u8; 2]

source§

fn from(a: ExtensionType) -> Self

Converts to this type from the input type.
source§

impl From<ExtensionType> for u16

source§

fn from(enum_value: ExtensionType) -> Self

Converts to this type from the input type.
source§

impl PartialEq for ExtensionType

source§

fn eq(&self, other: &ExtensionType) -> 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 TryFrom<&[u8]> for ExtensionType

§

type Error = ProgramError

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

fn try_from(a: &[u8]) -> Result<Self, Self::Error>

Performs the conversion.
source§

impl TryFrom<u16> for ExtensionType

§

type Error = TryFromPrimitiveError<ExtensionType>

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

fn try_from(number: u16) -> Result<Self, TryFromPrimitiveError<Self>>

Performs the conversion.
source§

impl TryFromPrimitive for ExtensionType

§

type Primitive = u16

§

type Error = TryFromPrimitiveError<ExtensionType>

source§

const NAME: &'static str = "ExtensionType"

source§

fn try_from_primitive( number: Self::Primitive ) -> Result<Self, TryFromPrimitiveError<Self>>

source§

impl Copy for ExtensionType

source§

impl StructuralPartialEq for ExtensionType

Auto Trait Implementations§

Blanket Implementations§

§

impl<T> AbiExample for T

§

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> 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.

§

impl<T> Pointable for T

§

const ALIGN: usize = _

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

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for T
where 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 T
where U: Into<T>,

§

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>,

§

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

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

§

fn vzip(self) -> V