pub enum ScriptCall {
Show 33 variants
    AddCurrencyToAccount {
        currency: TypeTag,
    },
    AddRecoveryRotationCapability {
        recovery_address: AccountAddress,
    },
    AddValidatorAndReconfigure {
        sliding_nonce: u64,
        validator_name: Vec<u8>,
        validator_address: AccountAddress,
    },
    Burn {
        token: TypeTag,
        sliding_nonce: u64,
        preburn_address: AccountAddress,
    },
    BurnTxnFees {
        coin_type: TypeTag,
    },
    CancelBurn {
        token: TypeTag,
        preburn_address: AccountAddress,
    },
    CreateChildVaspAccount {
        coin_type: TypeTag,
        child_address: AccountAddress,
        auth_key_prefix: Vec<u8>,
        add_all_currencies: bool,
        child_initial_balance: u64,
    },
    CreateDesignatedDealer {
        currency: TypeTag,
        sliding_nonce: u64,
        addr: AccountAddress,
        auth_key_prefix: Vec<u8>,
        human_name: Vec<u8>,
        add_all_currencies: bool,
    },
    CreateParentVaspAccount {
        coin_type: TypeTag,
        sliding_nonce: u64,
        new_account_address: AccountAddress,
        auth_key_prefix: Vec<u8>,
        human_name: Vec<u8>,
        add_all_currencies: bool,
    },
    CreateRecoveryAddress {},
    CreateValidatorAccount {
        sliding_nonce: u64,
        new_account_address: AccountAddress,
        auth_key_prefix: Vec<u8>,
        human_name: Vec<u8>,
    },
    CreateValidatorOperatorAccount {
        sliding_nonce: u64,
        new_account_address: AccountAddress,
        auth_key_prefix: Vec<u8>,
        human_name: Vec<u8>,
    },
    FreezeAccount {
        sliding_nonce: u64,
        to_freeze_account: AccountAddress,
    },
    PeerToPeerWithMetadata {
        currency: TypeTag,
        payee: AccountAddress,
        amount: u64,
        metadata: Vec<u8>,
        metadata_signature: Vec<u8>,
    },
    Preburn {
        token: TypeTag,
        amount: u64,
    },
    PublishSharedEd25519PublicKey {
        public_key: Vec<u8>,
    },
    RegisterValidatorConfig {
        validator_account: AccountAddress,
        consensus_pubkey: Vec<u8>,
        validator_network_addresses: Vec<u8>,
        fullnode_network_addresses: Vec<u8>,
    },
    RemoveValidatorAndReconfigure {
        sliding_nonce: u64,
        validator_name: Vec<u8>,
        validator_address: AccountAddress,
    },
    RotateAuthenticationKey {
        new_key: Vec<u8>,
    },
    RotateAuthenticationKeyWithNonce {
        sliding_nonce: u64,
        new_key: Vec<u8>,
    },
    RotateAuthenticationKeyWithNonceAdmin {
        sliding_nonce: u64,
        new_key: Vec<u8>,
    },
    RotateAuthenticationKeyWithRecoveryAddress {
        recovery_address: AccountAddress,
        to_recover: AccountAddress,
        new_key: Vec<u8>,
    },
    RotateDualAttestationInfo {
        new_url: Vec<u8>,
        new_key: Vec<u8>,
    },
    RotateSharedEd25519PublicKey {
        public_key: Vec<u8>,
    },
    SetValidatorConfigAndReconfigure {
        validator_account: AccountAddress,
        consensus_pubkey: Vec<u8>,
        validator_network_addresses: Vec<u8>,
        fullnode_network_addresses: Vec<u8>,
    },
    SetValidatorOperator {
        operator_name: Vec<u8>,
        operator_account: AccountAddress,
    },
    SetValidatorOperatorWithNonceAdmin {
        sliding_nonce: u64,
        operator_name: Vec<u8>,
        operator_account: AccountAddress,
    },
    TieredMint {
        coin_type: TypeTag,
        sliding_nonce: u64,
        designated_dealer_address: AccountAddress,
        mint_amount: u64,
        tier_index: u64,
    },
    UnfreezeAccount {
        sliding_nonce: u64,
        to_unfreeze_account: AccountAddress,
    },
    UpdateDiemVersion {
        sliding_nonce: u64,
        major: u64,
    },
    UpdateDualAttestationLimit {
        sliding_nonce: u64,
        new_micro_xdx_limit: u64,
    },
    UpdateExchangeRate {
        currency: TypeTag,
        sliding_nonce: u64,
        new_exchange_rate_numerator: u64,
        new_exchange_rate_denominator: u64,
    },
    UpdateMintingAbility {
        currency: TypeTag,
        allow_minting: bool,
    },
}Expand description
Structured representation of a call into a known Move script.
impl ScriptCall {
    pub fn encode(self) -> Script { .. }
    pub fn decode(&Script) -> Option<ScriptCall> { .. }
}Variants§
AddCurrencyToAccount
Fields
currency: TypeTagSummary
Adds a zero Currency balance to the sending account. This will enable account to
send, receive, and hold Diem::Diem<Currency> coins. This transaction can be
successfully sent by any account that is allowed to hold balances
(e.g., VASP, Designated Dealer).
Technical Description
After the successful execution of this transaction the sending account will have a
DiemAccount::Balance<Currency> resource with zero balance published under it. Only
accounts that can hold balances can send this transaction, the sending account cannot
already have a DiemAccount::Balance<Currency> published under it.
Parameters
| Name | Type | Description | 
|---|---|---|
| Currency | Type | The Move type for the Currencybeing added to the sending account of the transaction.Currencymust be an already-registered currency on-chain. | 
| account | &signer | The signer of the sending account of the transaction. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::NOT_PUBLISHED | Diem::ECURRENCY_INFO | The Currencyis not a registered currency on-chain. | 
| Errors::INVALID_ARGUMENT | DiemAccount::EROLE_CANT_STORE_BALANCE | The sending account’s role does not permit balances. | 
| Errors::ALREADY_PUBLISHED | DiemAccount::EADD_EXISTING_CURRENCY | A balance for Currencyis already published under the sendingaccount. | 
Related Scripts
- Script::create_child_vasp_account
- Script::create_parent_vasp_account
- Script::peer_to_peer_with_metadata
AddRecoveryRotationCapability
Fields
recovery_address: AccountAddressSummary
Stores the sending accounts ability to rotate its authentication key with a designated recovery account. Both the sending and recovery accounts need to belong to the same VASP and both be VASP accounts. After this transaction both the sending account and the specified recovery account can rotate the sender account’s authentication key.
Technical Description
Adds the DiemAccount::KeyRotationCapability for the sending account
(to_recover_account) to the RecoveryAddress::RecoveryAddress resource under
recovery_address. After this transaction has been executed successfully the account at
recovery_address and the to_recover_account may rotate the authentication key of
to_recover_account (the sender of this transaction).
The sending account of this transaction (to_recover_account) must not have previously given away its unique key
rotation capability, and must be a VASP account. The account at recovery_address
must also be a VASP account belonging to the same VASP as the to_recover_account.
Additionally the account at recovery_address must have already initialized itself as
a recovery account address using the Script::create_recovery_address transaction script.
The sending account’s (to_recover_account) key rotation capability is
removed in this transaction and stored in the RecoveryAddress::RecoveryAddress
resource stored under the account at recovery_address.
Parameters
| Name | Type | Description | 
|---|---|---|
| to_recover_account | &signer | The signer reference of the sending account of this transaction. | 
| recovery_address | address | The account address where the to_recover_account’sDiemAccount::KeyRotationCapabilitywill be stored. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::INVALID_STATE | DiemAccount::EKEY_ROTATION_CAPABILITY_ALREADY_EXTRACTED | to_recover_accounthas already delegated/extracted itsDiemAccount::KeyRotationCapability. | 
| Errors::NOT_PUBLISHED | RecoveryAddress::ERECOVERY_ADDRESS | recovery_addressdoes not have aRecoveryAddressresource published under it. | 
| Errors::INVALID_ARGUMENT | RecoveryAddress::EINVALID_KEY_ROTATION_DELEGATION | to_recover_accountandrecovery_addressdo not belong to the same VASP. | 
| Errors::LIMIT_EXCEEDED |  RecoveryAddress::EMAX_KEYS_REGISTERED | RecoveryAddress::MAX_REGISTERED_KEYShave already been registered with thisrecovery_address. | 
Related Scripts
- Script::create_recovery_address
- Script::rotate_authentication_key_with_recovery_address
AddValidatorAndReconfigure
Summary
Adds a validator account to the validator set, and triggers a reconfiguration of the system to admit the account to the validator set for the system. This transaction can only be successfully called by the Diem Root account.
Technical Description
This script adds the account at validator_address to the validator set.
This transaction emits a DiemConfig::NewEpochEvent event and triggers a
reconfiguration. Once the reconfiguration triggered by this script’s
execution has been performed, the account at the validator_address is
considered to be a validator in the network.
This transaction script will fail if the validator_address address is already in the validator set
or does not have a ValidatorConfig::ValidatorConfig resource already published under it.
Parameters
| Name | Type | Description | 
|---|---|---|
| dr_account | &signer | The signer reference of the sending account of this transaction. Must be the Diem Root signer. | 
| sliding_nonce | u64 | The sliding_nonce(see:SlidingNonce) to be used for this transaction. | 
| validator_name | vector<u8> | ASCII-encoded human name for the validator. Must match the human name in the ValidatorConfig::ValidatorConfigfor the validator. | 
| validator_address | address | The validator account address to be added to the validator set. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::NOT_PUBLISHED | SlidingNonce::ESLIDING_NONCE | A SlidingNonceresource is not published underdr_account. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_OLD | The sliding_nonceis too old and it’s impossible to determine if it’s duplicated or not. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_NEW | The sliding_nonceis too far in the future. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_ALREADY_RECORDED | The sliding_noncehas been previously recorded. | 
| Errors::REQUIRES_ADDRESS | CoreAddresses::EDIEM_ROOT | The sending account is not the Diem Root account. | 
| Errors::REQUIRES_ROLE | Roles::EDIEM_ROOT | The sending account is not the Diem Root account. | 
| 0 | 0 | The provided validator_namedoes not match the already-recorded human name for the validator. | 
| Errors::INVALID_ARGUMENT | DiemSystem::EINVALID_PROSPECTIVE_VALIDATOR | The validator to be added does not have a ValidatorConfig::ValidatorConfigresource published under it, or itsconfigfield is empty. | 
| Errors::INVALID_ARGUMENT | DiemSystem::EALREADY_A_VALIDATOR | The validator_addressaccount is already a registered validator. | 
| Errors::INVALID_STATE | DiemConfig::EINVALID_BLOCK_TIME | An invalid time value was encountered in reconfiguration. Unlikely to occur. | 
Related Scripts
- Script::create_validator_account
- Script::create_validator_operator_account
- Script::register_validator_config
- Script::remove_validator_and_reconfigure
- Script::set_validator_operator
- Script::set_validator_operator_with_nonce_admin
- Script::set_validator_config_and_reconfigure
Burn
Summary
Burns all coins held in the preburn resource at the specified preburn address and removes them from the system. The sending account must be the Treasury Compliance account. The account that holds the preburn resource will normally be a Designated Dealer, but there are no enforced requirements that it be one.
Technical Description
This transaction permanently destroys all the coins of Token type
stored in the Diem::Preburn<Token> resource published under the
preburn_address account address.
This transaction will only succeed if the sending account has a
Diem::BurnCapability<Token>, and a Diem::Preburn<Token> resource
exists under preburn_address, with a non-zero to_burn field. After the successful execution
of this transaction the total_value field in the
Diem::CurrencyInfo<Token> resource published under 0xA550C18 will be
decremented by the value of the to_burn field of the preburn resource
under preburn_address immediately before this transaction, and the
to_burn field of the preburn resource will have a zero value.
Events
The successful execution of this transaction will emit a Diem::BurnEvent on the event handle
held in the Diem::CurrencyInfo<Token> resource’s burn_events published under
0xA550C18.
Parameters
| Name | Type | Description | 
|---|---|---|
| Token | Type | The Move type for the Tokencurrency being burned.Tokenmust be an already-registered currency on-chain. | 
| tc_account | &signer | The signer reference of the sending account of this transaction, must have a burn capability for Tokenpublished under it. | 
| sliding_nonce | u64 | The sliding_nonce(see:SlidingNonce) to be used for this transaction. | 
| preburn_address | address | The address where the coins to-be-burned are currently held. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::NOT_PUBLISHED | SlidingNonce::ESLIDING_NONCE | A SlidingNonceresource is not published underaccount. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_OLD | The sliding_nonceis too old and it’s impossible to determine if it’s duplicated or not. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_NEW | The sliding_nonceis too far in the future. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_ALREADY_RECORDED | The sliding_noncehas been previously recorded. | 
| Errors::REQUIRES_CAPABILITY | Diem::EBURN_CAPABILITY | The sending accountdoes not have aDiem::BurnCapability<Token>published under it. | 
| Errors::NOT_PUBLISHED | Diem::EPREBURN | The account at preburn_addressdoes not have aDiem::Preburn<Token>resource published under it. | 
| Errors::INVALID_STATE | Diem::EPREBURN_EMPTY | The Diem::Preburn<Token>resource is empty (has a value of 0). | 
| Errors::NOT_PUBLISHED | Diem::ECURRENCY_INFO | The specified Tokenis not a registered currency on-chain. | 
Related Scripts
- Script::burn_txn_fees
- Script::cancel_burn
- Script::preburn
BurnTxnFees
Fields
coin_type: TypeTagSummary
Burns the transaction fees collected in the CoinType currency so that the
Diem association may reclaim the backing coins off-chain. May only be sent
by the Treasury Compliance account.
Technical Description
Burns the transaction fees collected in CoinType so that the
association may reclaim the backing coins. Once this transaction has executed
successfully all transaction fees that will have been collected in
CoinType since the last time this script was called with that specific
currency. Both balance and preburn fields in the
TransactionFee::TransactionFee<CoinType> resource published under the 0xB1E55ED
account address will have a value of 0 after the successful execution of this script.
Events
The successful execution of this transaction will emit a Diem::BurnEvent on the event handle
held in the Diem::CurrencyInfo<CoinType> resource’s burn_events published under
0xA550C18.
Parameters
| Name | Type | Description | 
|---|---|---|
| CoinType | Type | The Move type for the CoinTypebeing added to the sending account of the transaction.CoinTypemust be an already-registered currency on-chain. | 
| tc_account | &signer | The signer reference of the sending account of this transaction. Must be the Treasury Compliance account. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::REQUIRES_ADDRESS | CoreAddresses::ETREASURY_COMPLIANCE | The sending account is not the Treasury Compliance account. | 
| Errors::NOT_PUBLISHED | TransactionFee::ETRANSACTION_FEE | CoinTypeis not an accepted transaction fee currency. | 
| Errors::INVALID_ARGUMENT | Diem::ECOIN | The collected fees in CoinTypeare zero. | 
Related Scripts
- Script::burn
- Script::cancel_burn
CancelBurn
Summary
Cancels and returns all coins held in the preburn area under
preburn_address and returns the funds to the preburn_address’s balance.
Can only be successfully sent by an account with Treasury Compliance role.
Technical Description
Cancels and returns all coins held in the Diem::Preburn<Token> resource under the preburn_address and
return the funds to the preburn_address account’s DiemAccount::Balance<Token>.
The transaction must be sent by an account with a Diem::BurnCapability<Token>
resource published under it. The account at preburn_address must have a
Diem::Preburn<Token> resource published under it, and its value must be nonzero. The transaction removes
the entire balance held in the Diem::Preburn<Token> resource, and returns it back to the account’s
DiemAccount::Balance<Token> under preburn_address. Due to this, the account at
preburn_address must already have a balance in the Token currency published
before this script is called otherwise the transaction will fail.
Events
The successful execution of this transaction will emit:
- A Diem::CancelBurnEventon the event handle held in theDiem::CurrencyInfo<Token>resource’sburn_eventspublished under0xA550C18.
- A DiemAccount::ReceivedPaymentEventon thepreburn_address’sDiemAccount::DiemAccountreceived_eventsevent handle with both thepayerandpayeebeingpreburn_address.
Parameters
| Name | Type | Description | 
|---|---|---|
| Token | Type | The Move type for the Tokencurrenty that burning is being cancelled for.Tokenmust be an already-registered currency on-chain. | 
| account | &signer | The signer reference of the sending account of this transaction, must have a burn capability for Tokenpublished under it. | 
| preburn_address | address | The address where the coins to-be-burned are currently held. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::REQUIRES_CAPABILITY | Diem::EBURN_CAPABILITY | The sending accountdoes not have aDiem::BurnCapability<Token>published under it. | 
| Errors::NOT_PUBLISHED | Diem::EPREBURN | The account at preburn_addressdoes not have aDiem::Preburn<Token>resource published under it. | 
| Errors::NOT_PUBLISHED | Diem::ECURRENCY_INFO | The specified Tokenis not a registered currency on-chain. | 
| Errors::INVALID_ARGUMENT | DiemAccount::ECOIN_DEPOSIT_IS_ZERO | The value held in the preburn resource was zero. | 
| Errors::INVALID_ARGUMENT | DiemAccount::EPAYEE_CANT_ACCEPT_CURRENCY_TYPE | The account at preburn_addressdoesn’t have a balance resource forToken. | 
| Errors::LIMIT_EXCEEDED | DiemAccount::EDEPOSIT_EXCEEDS_LIMITS | The depositing of the funds held in the prebun area would exceed the account’s account limits. | 
| Errors::INVALID_STATE | DualAttestation::EPAYEE_COMPLIANCE_KEY_NOT_SET | The accountdoes not have a compliance key set on it but dual attestion checking was performed. | 
Related Scripts
- Script::burn_txn_fees
- Script::burn
- Script::preburn
CreateChildVaspAccount
Summary
Creates a Child VASP account with its parent being the sending account of the transaction. The sender of the transaction must be a Parent VASP account.
Technical Description
Creates a ChildVASP account for the sender parent_vasp at child_address with a balance of
child_initial_balance in CoinType and an initial authentication key of
auth_key_prefix | child_address.
If add_all_currencies is true, the child address will have a zero balance in all available
currencies in the system.
The new account will be a child account of the transaction sender, which must be a Parent VASP account. The child account will be recorded against the limit of child accounts of the creating Parent VASP account.
Events
Successful execution with a child_initial_balance greater than zero will emit:
- A DiemAccount::SentPaymentEventwith thepayerfield being the Parent VASP’s address, and payee field beingchild_address. This is emitted on the Parent VASP’sDiemAccount::DiemAccountsent_eventshandle.
- A DiemAccount::ReceivedPaymentEventwith thepayerfield being the Parent VASP’s address, and payee field beingchild_address. This is emitted on the new Child VASPS’sDiemAccount::DiemAccountreceived_eventshandle.
Parameters
| Name | Type | Description | 
|---|---|---|
| CoinType | Type | The Move type for the CoinTypethat the child account should be created with.CoinTypemust be an already-registered currency on-chain. | 
| parent_vasp | &signer | The signer reference of the sending account. Must be a Parent VASP account. | 
| child_address | address | Address of the to-be-created Child VASP account. | 
| auth_key_prefix | vector<u8> | The authentication key prefix that will be used initially for the newly created account. | 
| add_all_currencies | bool | Whether to publish balance resources for all known currencies when the account is created. | 
| child_initial_balance | u64 | The initial balance in CoinTypeto give the child account when it’s created. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::INVALID_ARGUMENT | DiemAccount::EMALFORMED_AUTHENTICATION_KEY | The auth_key_prefixwas not of length 32. | 
| Errors::REQUIRES_ROLE | Roles::EPARENT_VASP | The sending account wasn’t a Parent VASP account. | 
| Errors::ALREADY_PUBLISHED | Roles::EROLE_ID | The child_addressaddress is already taken. | 
| Errors::LIMIT_EXCEEDED | VASP::ETOO_MANY_CHILDREN | The sending account has reached the maximum number of allowed child accounts. | 
| Errors::NOT_PUBLISHED | Diem::ECURRENCY_INFO | The CoinTypeis not a registered currency on-chain. | 
| Errors::INVALID_STATE | DiemAccount::EWITHDRAWAL_CAPABILITY_ALREADY_EXTRACTED | The withdrawal capability for the sending account has already been extracted. | 
| Errors::NOT_PUBLISHED | DiemAccount::EPAYER_DOESNT_HOLD_CURRENCY | The sending account doesn’t have a balance in CoinType. | 
| Errors::LIMIT_EXCEEDED | DiemAccount::EINSUFFICIENT_BALANCE | The sending account doesn’t have at least child_initial_balanceofCoinTypebalance. | 
| Errors::INVALID_ARGUMENT | DiemAccount::ECANNOT_CREATE_AT_VM_RESERVED | The child_addressis the reserved address 0x0. | 
Related Scripts
- Script::create_parent_vasp_account
- Script::add_currency_to_account
- Script::rotate_authentication_key
- Script::add_recovery_rotation_capability
- Script::create_recovery_address
CreateDesignatedDealer
Summary
Creates a Designated Dealer account with the provided information, and initializes it with default mint tiers. The transaction can only be sent by the Treasury Compliance account.
Technical Description
Creates an account with the Designated Dealer role at addr with authentication key
auth_key_prefix | addr and a 0 balance of type Currency. If add_all_currencies is true,
0 balances for all available currencies in the system will also be added. This can only be
invoked by an account with the TreasuryCompliance role.
At the time of creation the account is also initialized with default mint tiers of (500_000, 5000_000, 50_000_000, 500_000_000), and preburn areas for each currency that is added to the account.
Parameters
| Name | Type | Description | 
|---|---|---|
| Currency | Type | The Move type for the Currencythat the Designated Dealer should be initialized with.Currencymust be an already-registered currency on-chain. | 
| tc_account | &signer | The signer reference of the sending account of this transaction. Must be the Treasury Compliance account. | 
| sliding_nonce | u64 | The sliding_nonce(see:SlidingNonce) to be used for this transaction. | 
| addr | address | Address of the to-be-created Designated Dealer account. | 
| auth_key_prefix | vector<u8> | The authentication key prefix that will be used initially for the newly created account. | 
| human_name | vector<u8> | ASCII-encoded human name for the Designated Dealer. | 
| add_all_currencies | bool | Whether to publish preburn, balance, and tier info resources for all known (SCS) currencies or just Currencywhen the account is created. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::NOT_PUBLISHED | SlidingNonce::ESLIDING_NONCE | A SlidingNonceresource is not published undertc_account. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_OLD | The sliding_nonceis too old and it’s impossible to determine if it’s duplicated or not. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_NEW | The sliding_nonceis too far in the future. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_ALREADY_RECORDED | The sliding_noncehas been previously recorded. | 
| Errors::REQUIRES_ADDRESS | CoreAddresses::ETREASURY_COMPLIANCE | The sending account is not the Treasury Compliance account. | 
| Errors::REQUIRES_ROLE | Roles::ETREASURY_COMPLIANCE | The sending account is not the Treasury Compliance account. | 
| Errors::NOT_PUBLISHED | Diem::ECURRENCY_INFO | The Currencyis not a registered currency on-chain. | 
| Errors::ALREADY_PUBLISHED | Roles::EROLE_ID | The addraddress is already taken. | 
Related Scripts
- Script::tiered_mint
- Script::peer_to_peer_with_metadata
- Script::rotate_dual_attestation_info
CreateParentVaspAccount
Summary
Creates a Parent VASP account with the specified human name. Must be called by the Treasury Compliance account.
Technical Description
Creates an account with the Parent VASP role at address with authentication key
auth_key_prefix | new_account_address and a 0 balance of type CoinType. If
add_all_currencies is true, 0 balances for all available currencies in the system will
also be added. This can only be invoked by an TreasuryCompliance account.
sliding_nonce is a unique nonce for operation, see SlidingNonce for details.
Parameters
| Name | Type | Description | 
|---|---|---|
| CoinType | Type | The Move type for the CoinTypecurrency that the Parent VASP account should be initialized with.CoinTypemust be an already-registered currency on-chain. | 
| tc_account | &signer | The signer reference of the sending account of this transaction. Must be the Treasury Compliance account. | 
| sliding_nonce | u64 | The sliding_nonce(see:SlidingNonce) to be used for this transaction. | 
| new_account_address | address | Address of the to-be-created Parent VASP account. | 
| auth_key_prefix | vector<u8> | The authentication key prefix that will be used initially for the newly created account. | 
| human_name | vector<u8> | ASCII-encoded human name for the Parent VASP. | 
| add_all_currencies | bool | Whether to publish balance resources for all known currencies when the account is created. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::NOT_PUBLISHED | SlidingNonce::ESLIDING_NONCE | A SlidingNonceresource is not published undertc_account. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_OLD | The sliding_nonceis too old and it’s impossible to determine if it’s duplicated or not. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_NEW | The sliding_nonceis too far in the future. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_ALREADY_RECORDED | The sliding_noncehas been previously recorded. | 
| Errors::REQUIRES_ADDRESS | CoreAddresses::ETREASURY_COMPLIANCE | The sending account is not the Treasury Compliance account. | 
| Errors::REQUIRES_ROLE | Roles::ETREASURY_COMPLIANCE | The sending account is not the Treasury Compliance account. | 
| Errors::NOT_PUBLISHED | Diem::ECURRENCY_INFO | The CoinTypeis not a registered currency on-chain. | 
| Errors::ALREADY_PUBLISHED | Roles::EROLE_ID | The new_account_addressaddress is already taken. | 
Related Scripts
- Script::create_child_vasp_account
- Script::add_currency_to_account
- Script::rotate_authentication_key
- Script::add_recovery_rotation_capability
- Script::create_recovery_address
- Script::rotate_dual_attestation_info
CreateRecoveryAddress
Fields
Summary
Initializes the sending account as a recovery address that may be used by the VASP that it belongs to. The sending account must be a VASP account. Multiple recovery addresses can exist for a single VASP, but accounts in each must be disjoint.
Technical Description
Publishes a RecoveryAddress::RecoveryAddress resource under account. It then
extracts the DiemAccount::KeyRotationCapability for account and adds
it to the resource. After the successful execution of this transaction
other accounts may add their key rotation to this resource so that account
may be used as a recovery account for those accounts.
Parameters
| Name | Type | Description | 
|---|---|---|
| account | &signer | The signer of the sending account of the transaction. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::INVALID_STATE | DiemAccount::EKEY_ROTATION_CAPABILITY_ALREADY_EXTRACTED | accounthas already delegated/extracted itsDiemAccount::KeyRotationCapability. | 
| Errors::INVALID_ARGUMENT | RecoveryAddress::ENOT_A_VASP | accountis not a VASP account. | 
| Errors::INVALID_ARGUMENT | RecoveryAddress::EKEY_ROTATION_DEPENDENCY_CYCLE | A key rotation recovery cycle would be created by adding account’s key rotation capability. | 
| Errors::ALREADY_PUBLISHED | RecoveryAddress::ERECOVERY_ADDRESS | A RecoveryAddress::RecoveryAddressresource has already been published underaccount. | 
Related Scripts
- Script::add_recovery_rotation_capability
- Script::rotate_authentication_key_with_recovery_address
CreateValidatorAccount
Fields
new_account_address: AccountAddressSummary
Creates a Validator account. This transaction can only be sent by the Diem Root account.
Technical Description
Creates an account with a Validator role at new_account_address, with authentication key
auth_key_prefix | new_account_address. It publishes a
ValidatorConfig::ValidatorConfig resource with empty config, and
operator_account fields. The human_name field of the
ValidatorConfig::ValidatorConfig is set to the passed in human_name.
This script does not add the validator to the validator set or the system,
but only creates the account.
Parameters
| Name | Type | Description | 
|---|---|---|
| dr_account | &signer | The signer reference of the sending account of this transaction. Must be the Diem Root signer. | 
| sliding_nonce | u64 | The sliding_nonce(see:SlidingNonce) to be used for this transaction. | 
| new_account_address | address | Address of the to-be-created Validator account. | 
| auth_key_prefix | vector<u8> | The authentication key prefix that will be used initially for the newly created account. | 
| human_name | vector<u8> | ASCII-encoded human name for the validator. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::NOT_PUBLISHED | SlidingNonce::ESLIDING_NONCE | A SlidingNonceresource is not published underdr_account. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_OLD | The sliding_nonceis too old and it’s impossible to determine if it’s duplicated or not. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_NEW | The sliding_nonceis too far in the future. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_ALREADY_RECORDED | The sliding_noncehas been previously recorded. | 
| Errors::REQUIRES_ADDRESS | CoreAddresses::EDIEM_ROOT | The sending account is not the Diem Root account. | 
| Errors::REQUIRES_ROLE | Roles::EDIEM_ROOT | The sending account is not the Diem Root account. | 
| Errors::ALREADY_PUBLISHED | Roles::EROLE_ID | The new_account_addressaddress is already taken. | 
Related Scripts
- Script::add_validator_and_reconfigure
- Script::create_validator_operator_account
- Script::register_validator_config
- Script::remove_validator_and_reconfigure
- Script::set_validator_operator
- Script::set_validator_operator_with_nonce_admin
- Script::set_validator_config_and_reconfigure
CreateValidatorOperatorAccount
Fields
new_account_address: AccountAddressSummary
Creates a Validator Operator account. This transaction can only be sent by the Diem Root account.
Technical Description
Creates an account with a Validator Operator role at new_account_address, with authentication key
auth_key_prefix | new_account_address. It publishes a
ValidatorOperatorConfig::ValidatorOperatorConfig resource with the specified human_name.
This script does not assign the validator operator to any validator accounts but only creates the account.
Parameters
| Name | Type | Description | 
|---|---|---|
| dr_account | &signer | The signer reference of the sending account of this transaction. Must be the Diem Root signer. | 
| sliding_nonce | u64 | The sliding_nonce(see:SlidingNonce) to be used for this transaction. | 
| new_account_address | address | Address of the to-be-created Validator account. | 
| auth_key_prefix | vector<u8> | The authentication key prefix that will be used initially for the newly created account. | 
| human_name | vector<u8> | ASCII-encoded human name for the validator. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::NOT_PUBLISHED | SlidingNonce::ESLIDING_NONCE | A SlidingNonceresource is not published underdr_account. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_OLD | The sliding_nonceis too old and it’s impossible to determine if it’s duplicated or not. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_NEW | The sliding_nonceis too far in the future. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_ALREADY_RECORDED | The sliding_noncehas been previously recorded. | 
| Errors::REQUIRES_ADDRESS | CoreAddresses::EDIEM_ROOT | The sending account is not the Diem Root account. | 
| Errors::REQUIRES_ROLE | Roles::EDIEM_ROOT | The sending account is not the Diem Root account. | 
| Errors::ALREADY_PUBLISHED | Roles::EROLE_ID | The new_account_addressaddress is already taken. | 
Related Scripts
- Script::create_validator_account
- Script::add_validator_and_reconfigure
- Script::register_validator_config
- Script::remove_validator_and_reconfigure
- Script::set_validator_operator
- Script::set_validator_operator_with_nonce_admin
- Script::set_validator_config_and_reconfigure
FreezeAccount
Summary
Freezes the account at address. The sending account of this transaction
must be the Treasury Compliance account. The account being frozen cannot be
the Diem Root or Treasury Compliance account. After the successful
execution of this transaction no transactions may be sent from the frozen
account, and the frozen account may not send or receive coins.
Technical Description
Sets the AccountFreezing::FreezingBit to true and emits a
AccountFreezing::FreezeAccountEvent. The transaction sender must be the
Treasury Compliance account, but the account at to_freeze_account must
not be either 0xA550C18 (the Diem Root address), or 0xB1E55ED (the
Treasury Compliance address). Note that this is a per-account property
e.g., freezing a Parent VASP will not effect the status any of its child
accounts and vice versa.
Events
Successful execution of this transaction will emit a AccountFreezing::FreezeAccountEvent on
the freeze_event_handle held in the AccountFreezing::FreezeEventsHolder resource published
under 0xA550C18 with the frozen_address being the to_freeze_account.
Parameters
| Name | Type | Description | 
|---|---|---|
| tc_account | &signer | The signer reference of the sending account of this transaction. Must be the Treasury Compliance account. | 
| sliding_nonce | u64 | The sliding_nonce(see:SlidingNonce) to be used for this transaction. | 
| to_freeze_account | address | The account address to be frozen. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::NOT_PUBLISHED | SlidingNonce::ESLIDING_NONCE | A SlidingNonceresource is not published undertc_account. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_OLD | The sliding_nonceis too old and it’s impossible to determine if it’s duplicated or not. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_NEW | The sliding_nonceis too far in the future. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_ALREADY_RECORDED | The sliding_noncehas been previously recorded. | 
| Errors::REQUIRES_ADDRESS | CoreAddresses::ETREASURY_COMPLIANCE | The sending account is not the Treasury Compliance account. | 
| Errors::REQUIRES_ROLE | Roles::ETREASURY_COMPLIANCE | The sending account is not the Treasury Compliance account. | 
| Errors::INVALID_ARGUMENT | AccountFreezing::ECANNOT_FREEZE_TC | to_freeze_accountwas the Treasury Compliance account (0xB1E55ED). | 
| Errors::INVALID_ARGUMENT | AccountFreezing::ECANNOT_FREEZE_DIEM_ROOT | to_freeze_accountwas the Diem Root account (0xA550C18). | 
Related Scripts
- Script::unfreeze_account
PeerToPeerWithMetadata
Summary
Transfers a given number of coins in a specified currency from one account to another. Transfers over a specified amount defined on-chain that are between two different VASPs, or other accounts that have opted-in will be subject to on-chain checks to ensure the receiver has agreed to receive the coins. This transaction can be sent by any account that can hold a balance, and to any account that can hold a balance. Both accounts must hold balances in the currency being transacted.
Technical Description
Transfers amount coins of type Currency from payer to payee with (optional) associated
metadata and an (optional) metadata_signature on the message
metadata | Signer::address_of(payer) | amount | DualAttestation::DOMAIN_SEPARATOR.
The metadata and metadata_signature parameters are only required if amount >=
DualAttestation::get_cur_microdiem_limit XDX and payer and payee are distinct VASPs.
However, a transaction sender can opt in to dual attestation even when it is not required
(e.g., a DesignatedDealer -> VASP payment) by providing a non-empty metadata_signature.
Standardized metadata BCS format can be found in diem_types::transaction::metadata::Metadata.
Events
Successful execution of this script emits two events:
- A DiemAccount::SentPaymentEventonpayer’sDiemAccount::DiemAccountsent_eventshandle; and
- A DiemAccount::ReceivedPaymentEventonpayee’sDiemAccount::DiemAccountreceived_eventshandle.
Parameters
| Name | Type | Description | 
|---|---|---|
| Currency | Type | The Move type for the Currencybeing sent in this transaction.Currencymust be an already-registered currency on-chain. | 
| payer | &signer | The signer reference of the sending account that coins are being transferred from. | 
| payee | address | The address of the account the coins are being transferred to. | 
| metadata | vector<u8> | Optional metadata about this payment. | 
| metadata_signature | vector<u8> | Optional signature over metadataand payment information. See | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::NOT_PUBLISHED | DiemAccount::EPAYER_DOESNT_HOLD_CURRENCY | payerdoesn’t hold a balance inCurrency. | 
| Errors::LIMIT_EXCEEDED | DiemAccount::EINSUFFICIENT_BALANCE | amountis greater thanpayer’s balance inCurrency. | 
| Errors::INVALID_ARGUMENT | DiemAccount::ECOIN_DEPOSIT_IS_ZERO | amountis zero. | 
| Errors::NOT_PUBLISHED | DiemAccount::EPAYEE_DOES_NOT_EXIST | No account exists at the payeeaddress. | 
| Errors::INVALID_ARGUMENT | DiemAccount::EPAYEE_CANT_ACCEPT_CURRENCY_TYPE | An account exists at payee, but it does not accept payments inCurrency. | 
| Errors::INVALID_STATE | AccountFreezing::EACCOUNT_FROZEN | The payeeaccount is frozen. | 
| Errors::INVALID_ARGUMENT | DualAttestation::EMALFORMED_METADATA_SIGNATURE | metadata_signatureis not 64 bytes. | 
| Errors::INVALID_ARGUMENT | DualAttestation::EINVALID_METADATA_SIGNATURE | metadata_signaturedoes not verify on the against thepayee'sDualAttestation::Credentialcompliance_public_keypublic key. | 
| Errors::LIMIT_EXCEEDED | DiemAccount::EWITHDRAWAL_EXCEEDS_LIMITS | payerhas exceeded its daily withdrawal limits for the backing coins of XDX. | 
| Errors::LIMIT_EXCEEDED | DiemAccount::EDEPOSIT_EXCEEDS_LIMITS | payeehas exceeded its daily deposit limits for XDX. | 
Related Scripts
- Script::create_child_vasp_account
- Script::create_parent_vasp_account
- Script::add_currency_to_account
Preburn
Summary
Moves a specified number of coins in a given currency from the account’s balance to its preburn area after which the coins may be burned. This transaction may be sent by any account that holds a balance and preburn area in the specified currency.
Technical Description
Moves the specified amount of coins in Token currency from the sending account’s
DiemAccount::Balance<Token> to the Diem::Preburn<Token> published under the same
account. account must have both of these resources published under it at the start of this
transaction in order for it to execute successfully.
Events
Successful execution of this script emits two events:
- DiemAccount::SentPaymentEventon- account’s- DiemAccount::DiemAccount- sent_eventshandle with the- payeeand- payerfields being- account’s address; and
- A Diem::PreburnEventwithToken’s currency code on theDiem::CurrencyInfo<Token’spreburn_eventshandle forTokenand withpreburn_addressset toaccount’s address.
Parameters
| Name | Type | Description | 
|---|---|---|
| Token | Type | The Move type for the Tokencurrency being moved to the preburn area.Tokenmust be an already-registered currency on-chain. | 
| account | &signer | The signer reference of the sending account. | 
| amount | u64 | The amount in Tokento be moved to the preburn area. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::NOT_PUBLISHED | Diem::ECURRENCY_INFO | The Tokenis not a registered currency on-chain. | 
| Errors::INVALID_STATE | DiemAccount::EWITHDRAWAL_CAPABILITY_ALREADY_EXTRACTED | The withdrawal capability for accounthas already been extracted. | 
| Errors::LIMIT_EXCEEDED | DiemAccount::EINSUFFICIENT_BALANCE | amountis greater thanpayer’s balance inToken. | 
| Errors::NOT_PUBLISHED | DiemAccount::EPAYER_DOESNT_HOLD_CURRENCY | accountdoesn’t hold a balance inToken. | 
| Errors::NOT_PUBLISHED | Diem::EPREBURN | accountdoesn’t have aDiem::Preburn<Token>resource published under it. | 
| Errors::INVALID_STATE | Diem::EPREBURN_OCCUPIED | The valuefield in theDiem::Preburn<Token>resource under the sender is non-zero. | 
| Errors::NOT_PUBLISHED | Roles::EROLE_ID | The accountdid not have a role assigned to it. | 
| Errors::REQUIRES_ROLE | Roles::EDESIGNATED_DEALER | The accountdid not have the role of DesignatedDealer. | 
Related Scripts
- Script::cancel_burn
- Script::burn
- Script::burn_txn_fees
Summary
Rotates the authentication key of the sending account to the newly-specified public key and publishes a new shared authentication key under the sender’s account. Any account can send this transaction.
Technical Description
Rotates the authentication key of the sending account to public_key,
and publishes a SharedEd25519PublicKey::SharedEd25519PublicKey resource
containing the 32-byte ed25519 public_key and the DiemAccount::KeyRotationCapability for
account under account.
Parameters
| Name | Type | Description | 
|---|---|---|
| account | &signer | The signer reference of the sending account of the transaction. | 
| public_key | vector<u8> | 32-byte Ed25519 public key for account’ authentication key to be rotated to and stored. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::INVALID_STATE | DiemAccount::EKEY_ROTATION_CAPABILITY_ALREADY_EXTRACTED | accounthas already delegated/extracted itsDiemAccount::KeyRotationCapabilityresource. | 
| Errors::ALREADY_PUBLISHED | SharedEd25519PublicKey::ESHARED_KEY | The SharedEd25519PublicKey::SharedEd25519PublicKeyresource is already published underaccount. | 
| Errors::INVALID_ARGUMENT | SharedEd25519PublicKey::EMALFORMED_PUBLIC_KEY | public_keyis an invalid ed25519 public key. | 
Related Scripts
- Script::rotate_shared_ed25519_public_key
RegisterValidatorConfig
Fields
validator_account: AccountAddressSummary
Updates a validator’s configuration. This does not reconfigure the system and will not update the configuration in the validator set that is seen by other validators in the network. Can only be successfully sent by a Validator Operator account that is already registered with a validator.
Technical Description
This updates the fields with corresponding names held in the ValidatorConfig::ValidatorConfig
config resource held under validator_account. It does not emit a DiemConfig::NewEpochEvent
so the copy of this config held in the validator set will not be updated, and the changes are
only “locally” under the validator_account account address.
Parameters
| Name | Type | Description | 
|---|---|---|
| validator_operator_account | &signer | Signer reference of the sending account. Must be the registered validator operator for the validator at validator_address. | 
| validator_account | address | The address of the validator’s ValidatorConfig::ValidatorConfigresource being updated. | 
| consensus_pubkey | vector<u8> | New Ed25519 public key to be used in the updated ValidatorConfig::ValidatorConfig. | 
| validator_network_addresses | vector<u8> | New set of validator_network_addressesto be used in the updatedValidatorConfig::ValidatorConfig. | 
| fullnode_network_addresses | vector<u8> | New set of fullnode_network_addressesto be used in the updatedValidatorConfig::ValidatorConfig. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::NOT_PUBLISHED | ValidatorConfig::EVALIDATOR_CONFIG | validator_addressdoes not have aValidatorConfig::ValidatorConfigresource published under it. | 
| Errors::INVALID_ARGUMENT | ValidatorConfig::EINVALID_TRANSACTION_SENDER | validator_operator_accountis not the registered operator for the validator atvalidator_address. | 
| Errors::INVALID_ARGUMENT | ValidatorConfig::EINVALID_CONSENSUS_KEY | consensus_pubkeyis not a valid ed25519 public key. | 
Related Scripts
- Script::create_validator_account
- Script::create_validator_operator_account
- Script::add_validator_and_reconfigure
- Script::remove_validator_and_reconfigure
- Script::set_validator_operator
- Script::set_validator_operator_with_nonce_admin
- Script::set_validator_config_and_reconfigure
RemoveValidatorAndReconfigure
Summary
This script removes a validator account from the validator set, and triggers a reconfiguration of the system to remove the validator from the system. This transaction can only be successfully called by the Diem Root account.
Technical Description
This script removes the account at validator_address from the validator set. This transaction
emits a DiemConfig::NewEpochEvent event. Once the reconfiguration triggered by this event
has been performed, the account at validator_address is no longer considered to be a
validator in the network. This transaction will fail if the validator at validator_address
is not in the validator set.
Parameters
| Name | Type | Description | 
|---|---|---|
| dr_account | &signer | The signer reference of the sending account of this transaction. Must be the Diem Root signer. | 
| sliding_nonce | u64 | The sliding_nonce(see:SlidingNonce) to be used for this transaction. | 
| validator_name | vector<u8> | ASCII-encoded human name for the validator. Must match the human name in the ValidatorConfig::ValidatorConfigfor the validator. | 
| validator_address | address | The validator account address to be removed from the validator set. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::NOT_PUBLISHED | SlidingNonce::ESLIDING_NONCE | A SlidingNonceresource is not published underdr_account. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_OLD | The sliding_nonceis too old and it’s impossible to determine if it’s duplicated or not. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_NEW | The sliding_nonceis too far in the future. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_ALREADY_RECORDED | The sliding_noncehas been previously recorded. | 
| Errors::NOT_PUBLISHED | SlidingNonce::ESLIDING_NONCE | The sending account is not the Diem Root account or Treasury Compliance account | 
| 0 | 0 | The provided validator_namedoes not match the already-recorded human name for the validator. | 
| Errors::INVALID_ARGUMENT | DiemSystem::ENOT_AN_ACTIVE_VALIDATOR | The validator to be removed is not in the validator set. | 
| Errors::REQUIRES_ADDRESS | CoreAddresses::EDIEM_ROOT | The sending account is not the Diem Root account. | 
| Errors::REQUIRES_ROLE | Roles::EDIEM_ROOT | The sending account is not the Diem Root account. | 
| Errors::INVALID_STATE | DiemConfig::EINVALID_BLOCK_TIME | An invalid time value was encountered in reconfiguration. Unlikely to occur. | 
Related Scripts
- Script::create_validator_account
- Script::create_validator_operator_account
- Script::register_validator_config
- Script::add_validator_and_reconfigure
- Script::set_validator_operator
- Script::set_validator_operator_with_nonce_admin
- Script::set_validator_config_and_reconfigure
RotateAuthenticationKey
Summary
Rotates the transaction sender’s authentication key to the supplied new authentication key. May be sent by any account.
Technical Description
Rotate the account’s DiemAccount::DiemAccount authentication_key field to new_key.
new_key must be a valid ed25519 public key, and account must not have previously delegated
its DiemAccount::KeyRotationCapability.
Parameters
| Name | Type | Description | 
|---|---|---|
| account | &signer | Signer reference of the sending account of the transaction. | 
| new_key | vector<u8> | New ed25519 public key to be used for account. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::INVALID_STATE | DiemAccount::EKEY_ROTATION_CAPABILITY_ALREADY_EXTRACTED | accounthas already delegated/extracted itsDiemAccount::KeyRotationCapability. | 
| Errors::INVALID_ARGUMENT | DiemAccount::EMALFORMED_AUTHENTICATION_KEY | new_keywas an invalid length. | 
Related Scripts
- Script::rotate_authentication_key_with_nonce
- Script::rotate_authentication_key_with_nonce_admin
- Script::rotate_authentication_key_with_recovery_address
RotateAuthenticationKeyWithNonce
Summary
Rotates the sender’s authentication key to the supplied new authentication key. May be sent by any account that has a sliding nonce resource published under it (usually this is Treasury Compliance or Diem Root accounts).
Technical Description
Rotates the account’s DiemAccount::DiemAccount authentication_key field to new_key.
new_key must be a valid ed25519 public key, and account must not have previously delegated
its DiemAccount::KeyRotationCapability.
Parameters
| Name | Type | Description | 
|---|---|---|
| account | &signer | Signer reference of the sending account of the transaction. | 
| sliding_nonce | u64 | The sliding_nonce(see:SlidingNonce) to be used for this transaction. | 
| new_key | vector<u8> | New ed25519 public key to be used for account. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::NOT_PUBLISHED | SlidingNonce::ESLIDING_NONCE | A SlidingNonceresource is not published underaccount. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_OLD | The sliding_nonceis too old and it’s impossible to determine if it’s duplicated or not. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_NEW | The sliding_nonceis too far in the future. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_ALREADY_RECORDED | The sliding_noncehas been previously recorded. | 
| Errors::INVALID_STATE | DiemAccount::EKEY_ROTATION_CAPABILITY_ALREADY_EXTRACTED | accounthas already delegated/extracted itsDiemAccount::KeyRotationCapability. | 
| Errors::INVALID_ARGUMENT | DiemAccount::EMALFORMED_AUTHENTICATION_KEY | new_keywas an invalid length. | 
Related Scripts
- Script::rotate_authentication_key
- Script::rotate_authentication_key_with_nonce_admin
- Script::rotate_authentication_key_with_recovery_address
RotateAuthenticationKeyWithNonceAdmin
Summary
Rotates the specified account’s authentication key to the supplied new authentication key. May only be sent by the Diem Root account as a write set transaction.
Technical Description
Rotate the account’s DiemAccount::DiemAccount authentication_key field to new_key.
new_key must be a valid ed25519 public key, and account must not have previously delegated
its DiemAccount::KeyRotationCapability.
Parameters
| Name | Type | Description | 
|---|---|---|
| dr_account | &signer | The signer reference of the sending account of the write set transaction. May only be the Diem Root signer. | 
| account | &signer | Signer reference of account specified in the execute_asfield of the write set transaction. | 
| sliding_nonce | u64 | The sliding_nonce(see:SlidingNonce) to be used for this transaction for Diem Root. | 
| new_key | vector<u8> | New ed25519 public key to be used for account. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::NOT_PUBLISHED | SlidingNonce::ESLIDING_NONCE | A SlidingNonceresource is not published underdr_account. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_OLD | The sliding_nonceindr_accountis too old and it’s impossible to determine if it’s duplicated or not. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_NEW | The sliding_nonceindr_accountis too far in the future. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_ALREADY_RECORDED | The sliding_noncein dr_accounthas been previously recorded. | 
| Errors::INVALID_STATE | DiemAccount::EKEY_ROTATION_CAPABILITY_ALREADY_EXTRACTED | accounthas already delegated/extracted itsDiemAccount::KeyRotationCapability. | 
| Errors::INVALID_ARGUMENT | DiemAccount::EMALFORMED_AUTHENTICATION_KEY | new_keywas an invalid length. | 
Related Scripts
- Script::rotate_authentication_key
- Script::rotate_authentication_key_with_nonce
- Script::rotate_authentication_key_with_recovery_address
RotateAuthenticationKeyWithRecoveryAddress
Summary
Rotates the authentication key of a specified account that is part of a recovery address to a
new authentication key. Only used for accounts that are part of a recovery address (see
Script::add_recovery_rotation_capability for account restrictions).
Technical Description
Rotates the authentication key of the to_recover account to new_key using the
DiemAccount::KeyRotationCapability stored in the RecoveryAddress::RecoveryAddress resource
published under recovery_address. This transaction can be sent either by the to_recover
account, or by the account where the RecoveryAddress::RecoveryAddress resource is published
that contains to_recover’s DiemAccount::KeyRotationCapability.
Parameters
| Name | Type | Description | 
|---|---|---|
| account | &signer | Signer reference of the sending account of the transaction. | 
| recovery_address | address | Address where RecoveryAddress::RecoveryAddressthat holdsto_recover’sDiemAccount::KeyRotationCapabilityis published. | 
| to_recover | address | The address of the account whose authentication key will be updated. | 
| new_key | vector<u8> | New ed25519 public key to be used for the account at the to_recoveraddress. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::NOT_PUBLISHED | RecoveryAddress::ERECOVERY_ADDRESS | recovery_addressdoes not have aRecoveryAddress::RecoveryAddressresource published under it. | 
| Errors::INVALID_ARGUMENT | RecoveryAddress::ECANNOT_ROTATE_KEY | The address of accountis notrecovery_addressorto_recover. | 
| Errors::INVALID_ARGUMENT | RecoveryAddress::EACCOUNT_NOT_RECOVERABLE | to_recover’sDiemAccount::KeyRotationCapabilityis not in theRecoveryAddress::RecoveryAddressresource published underrecovery_address. | 
| Errors::INVALID_ARGUMENT | DiemAccount::EMALFORMED_AUTHENTICATION_KEY | new_keywas an invalid length. | 
Related Scripts
- Script::rotate_authentication_key
- Script::rotate_authentication_key_with_nonce
- Script::rotate_authentication_key_with_nonce_admin
RotateDualAttestationInfo
Summary
Updates the url used for off-chain communication, and the public key used to verify dual attestation on-chain. Transaction can be sent by any account that has dual attestation information published under it. In practice the only such accounts are Designated Dealers and Parent VASPs.
Technical Description
Updates the base_url and compliance_public_key fields of the DualAttestation::Credential
resource published under account. The new_key must be a valid ed25519 public key.
Events
Successful execution of this transaction emits two events:
- A DualAttestation::ComplianceKeyRotationEventcontaining the new compliance public key, and the blockchain time at which the key was updated emitted on theDualAttestation::Credentialcompliance_key_rotation_eventshandle published underaccount; and
- A DualAttestation::BaseUrlRotationEventcontaining the new base url to be used for off-chain communication, and the blockchain time at which the url was updated emitted on theDualAttestation::Credentialbase_url_rotation_eventshandle published underaccount.
Parameters
| Name | Type | Description | 
|---|---|---|
| account | &signer | Signer reference of the sending account of the transaction. | 
| new_url | vector<u8> | ASCII-encoded url to be used for off-chain communication with account. | 
| new_key | vector<u8> | New ed25519 public key to be used for on-chain dual attestation checking. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::NOT_PUBLISHED | DualAttestation::ECREDENTIAL | A DualAttestation::Credentialresource is not published underaccount. | 
| Errors::INVALID_ARGUMENT | DualAttestation::EINVALID_PUBLIC_KEY | new_keyis not a valid ed25519 public key. | 
Related Scripts
- Script::create_parent_vasp_account
- Script::create_designated_dealer
- Script::rotate_dual_attestation_info
Summary
Rotates the authentication key in a SharedEd25519PublicKey. This transaction can be sent by
any account that has previously published a shared ed25519 public key using
Script::publish_shared_ed25519_public_key.
Technical Description
This first rotates the public key stored in account’s
SharedEd25519PublicKey::SharedEd25519PublicKey resource to public_key, after which it
rotates the authentication key using the capability stored in account’s
SharedEd25519PublicKey::SharedEd25519PublicKey to a new value derived from public_key
Parameters
| Name | Type | Description | 
|---|---|---|
| account | &signer | The signer reference of the sending account of the transaction. | 
| public_key | vector<u8> | 32-byte Ed25519 public key. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::NOT_PUBLISHED | SharedEd25519PublicKey::ESHARED_KEY | A SharedEd25519PublicKey::SharedEd25519PublicKeyresource is not published underaccount. | 
| Errors::INVALID_ARGUMENT | SharedEd25519PublicKey::EMALFORMED_PUBLIC_KEY | public_keyis an invalid ed25519 public key. | 
Related Scripts
- Script::publish_shared_ed25519_public_key
SetValidatorConfigAndReconfigure
Fields
validator_account: AccountAddressSummary
Updates a validator’s configuration, and triggers a reconfiguration of the system to update the validator set with this new validator configuration. Can only be successfully sent by a Validator Operator account that is already registered with a validator.
Technical Description
This updates the fields with corresponding names held in the ValidatorConfig::ValidatorConfig
config resource held under validator_account. It then emits a DiemConfig::NewEpochEvent to
trigger a reconfiguration of the system.  This reconfiguration will update the validator set
on-chain with the updated ValidatorConfig::ValidatorConfig.
Parameters
| Name | Type | Description | 
|---|---|---|
| validator_operator_account | &signer | Signer reference of the sending account. Must be the registered validator operator for the validator at validator_address. | 
| validator_account | address | The address of the validator’s ValidatorConfig::ValidatorConfigresource being updated. | 
| consensus_pubkey | vector<u8> | New Ed25519 public key to be used in the updated ValidatorConfig::ValidatorConfig. | 
| validator_network_addresses | vector<u8> | New set of validator_network_addressesto be used in the updatedValidatorConfig::ValidatorConfig. | 
| fullnode_network_addresses | vector<u8> | New set of fullnode_network_addressesto be used in the updatedValidatorConfig::ValidatorConfig. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::NOT_PUBLISHED | ValidatorConfig::EVALIDATOR_CONFIG | validator_addressdoes not have aValidatorConfig::ValidatorConfigresource published under it. | 
| Errors::REQUIRES_ROLE | Roles::EVALIDATOR_OPERATOR | validator_operator_accountdoes not have a Validator Operator role. | 
| Errors::INVALID_ARGUMENT | ValidatorConfig::EINVALID_TRANSACTION_SENDER | validator_operator_accountis not the registered operator for the validator atvalidator_address. | 
| Errors::INVALID_ARGUMENT | ValidatorConfig::EINVALID_CONSENSUS_KEY | consensus_pubkeyis not a valid ed25519 public key. | 
| Errors::INVALID_STATE | DiemConfig::EINVALID_BLOCK_TIME | An invalid time value was encountered in reconfiguration. Unlikely to occur. | 
Related Scripts
- Script::create_validator_account
- Script::create_validator_operator_account
- Script::add_validator_and_reconfigure
- Script::remove_validator_and_reconfigure
- Script::set_validator_operator
- Script::set_validator_operator_with_nonce_admin
- Script::register_validator_config
SetValidatorOperator
Summary
Sets the validator operator for a validator in the validator’s configuration resource “locally” and does not reconfigure the system. Changes from this transaction will not picked up by the system until a reconfiguration of the system is triggered. May only be sent by an account with Validator role.
Technical Description
Sets the account at operator_account address and with the specified human_name as an
operator for the sending validator account. The account at operator_account address must have
a Validator Operator role and have a ValidatorOperatorConfig::ValidatorOperatorConfig
resource published under it. The sending account must be a Validator and have a
ValidatorConfig::ValidatorConfig resource published under it. This script does not emit a
DiemConfig::NewEpochEvent and no reconfiguration of the system is initiated by this script.
Parameters
| Name | Type | Description | 
|---|---|---|
| account | &signer | The signer reference of the sending account of the transaction. | 
| operator_name | vector<u8> | Validator operator’s human name. | 
| operator_account | address | Address of the validator operator account to be added as the accountvalidator’s operator. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::NOT_PUBLISHED | ValidatorOperatorConfig::EVALIDATOR_OPERATOR_CONFIG | The ValidatorOperatorConfig::ValidatorOperatorConfigresource is not published underoperator_account. | 
| 0 | 0 | The human_namefield of theValidatorOperatorConfig::ValidatorOperatorConfigresource underoperator_accountdoes not match the providedhuman_name. | 
| Errors::REQUIRES_ROLE | Roles::EVALIDATOR | accountdoes not have a Validator account role. | 
| Errors::INVALID_ARGUMENT | ValidatorConfig::ENOT_A_VALIDATOR_OPERATOR | The account at operator_accountdoes not have aValidatorOperatorConfig::ValidatorOperatorConfigresource. | 
| Errors::NOT_PUBLISHED | ValidatorConfig::EVALIDATOR_CONFIG | A ValidatorConfig::ValidatorConfigis not published underaccount. | 
Related Scripts
- Script::create_validator_account
- Script::create_validator_operator_account
- Script::register_validator_config
- Script::remove_validator_and_reconfigure
- Script::add_validator_and_reconfigure
- Script::set_validator_operator_with_nonce_admin
- Script::set_validator_config_and_reconfigure
SetValidatorOperatorWithNonceAdmin
Summary
Sets the validator operator for a validator in the validator’s configuration resource “locally” and does not reconfigure the system. Changes from this transaction will not picked up by the system until a reconfiguration of the system is triggered. May only be sent by the Diem Root account as a write set transaction.
Technical Description
Sets the account at operator_account address and with the specified human_name as an
operator for the validator account. The account at operator_account address must have a
Validator Operator role and have a ValidatorOperatorConfig::ValidatorOperatorConfig resource
published under it. The account represented by the account signer must be a Validator and
have a ValidatorConfig::ValidatorConfig resource published under it. No reconfiguration of
the system is initiated by this script.
Parameters
| Name | Type | Description | 
|---|---|---|
| dr_account | &signer | The signer reference of the sending account of the write set transaction. May only be the Diem Root signer. | 
| account | &signer | Signer reference of account specified in the execute_asfield of the write set transaction. | 
| sliding_nonce | u64 | The sliding_nonce(see:SlidingNonce) to be used for this transaction for Diem Root. | 
| operator_name | vector<u8> | Validator operator’s human name. | 
| operator_account | address | Address of the validator operator account to be added as the accountvalidator’s operator. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::NOT_PUBLISHED | SlidingNonce::ESLIDING_NONCE | A SlidingNonceresource is not published underdr_account. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_OLD | The sliding_nonceindr_accountis too old and it’s impossible to determine if it’s duplicated or not. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_NEW | The sliding_nonceindr_accountis too far in the future. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_ALREADY_RECORDED | The sliding_noncein dr_accounthas been previously recorded. | 
| Errors::NOT_PUBLISHED | SlidingNonce::ESLIDING_NONCE | The sending account is not the Diem Root account or Treasury Compliance account | 
| Errors::NOT_PUBLISHED | ValidatorOperatorConfig::EVALIDATOR_OPERATOR_CONFIG | The ValidatorOperatorConfig::ValidatorOperatorConfigresource is not published underoperator_account. | 
| 0 | 0 | The human_namefield of theValidatorOperatorConfig::ValidatorOperatorConfigresource underoperator_accountdoes not match the providedhuman_name. | 
| Errors::REQUIRES_ROLE | Roles::EVALIDATOR | accountdoes not have a Validator account role. | 
| Errors::INVALID_ARGUMENT | ValidatorConfig::ENOT_A_VALIDATOR_OPERATOR | The account at operator_accountdoes not have aValidatorOperatorConfig::ValidatorOperatorConfigresource. | 
| Errors::NOT_PUBLISHED | ValidatorConfig::EVALIDATOR_CONFIG | A ValidatorConfig::ValidatorConfigis not published underaccount. | 
Related Scripts
- Script::create_validator_account
- Script::create_validator_operator_account
- Script::register_validator_config
- Script::remove_validator_and_reconfigure
- Script::add_validator_and_reconfigure
- Script::set_validator_operator
- Script::set_validator_config_and_reconfigure
TieredMint
Summary
Mints a specified number of coins in a currency to a Designated Dealer. The sending account must be the Treasury Compliance account, and coins can only be minted to a Designated Dealer account.
Technical Description
Mints mint_amount of coins in the CoinType currency to Designated Dealer account at
designated_dealer_address. The tier_index parameter specifies which tier should be used to
check verify the off-chain approval policy, and is based in part on the on-chain tier values
for the specific Designated Dealer, and the number of CoinType coins that have been minted to
the dealer over the past 24 hours. Every Designated Dealer has 4 tiers for each currency that
they support. The sending tc_account must be the Treasury Compliance account, and the
receiver an authorized Designated Dealer account.
Events
Successful execution of the transaction will emit two events:
- A Diem::MintEventwith the amount and currency code minted is emitted on themint_event_handlein the storedDiem::CurrencyInfo<CoinType>resource stored under0xA550C18; and
- A DesignatedDealer::ReceivedMintEventwith the amount, currency code, and Designated Dealer’s address is emitted on themint_event_handlein the storedDesignatedDealer::Dealerresource published under thedesignated_dealer_address.
Parameters
| Name | Type | Description | 
|---|---|---|
| CoinType | Type | The Move type for the CoinTypebeing minted.CoinTypemust be an already-registered currency on-chain. | 
| tc_account | &signer | The signer reference of the sending account of this transaction. Must be the Treasury Compliance account. | 
| sliding_nonce | u64 | The sliding_nonce(see:SlidingNonce) to be used for this transaction. | 
| designated_dealer_address | address | The address of the Designated Dealer account being minted to. | 
| mint_amount | u64 | The number of coins to be minted. | 
| tier_index | u64 | The mint tier index to use for the Designated Dealer account. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::NOT_PUBLISHED | SlidingNonce::ESLIDING_NONCE | A SlidingNonceresource is not published undertc_account. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_OLD | The sliding_nonceis too old and it’s impossible to determine if it’s duplicated or not. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_NEW | The sliding_nonceis too far in the future. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_ALREADY_RECORDED | The sliding_noncehas been previously recorded. | 
| Errors::REQUIRES_ADDRESS | CoreAddresses::ETREASURY_COMPLIANCE | tc_accountis not the Treasury Compliance account. | 
| Errors::REQUIRES_ROLE | Roles::ETREASURY_COMPLIANCE | tc_accountis not the Treasury Compliance account. | 
| Errors::INVALID_ARGUMENT | DesignatedDealer::EINVALID_MINT_AMOUNT | mint_amountis zero. | 
| Errors::NOT_PUBLISHED | DesignatedDealer::EDEALER | DesignatedDealer::DealerorDesignatedDealer::TierInfo<CoinType>resource does not exist atdesignated_dealer_address. | 
| Errors::INVALID_ARGUMENT | DesignatedDealer::EINVALID_TIER_INDEX | The tier_indexis out of bounds. | 
| Errors::INVALID_ARGUMENT | DesignatedDealer::EINVALID_AMOUNT_FOR_TIER | mint_amountexceeds the maximum allowed amount fortier_index. | 
| Errors::REQUIRES_CAPABILITY | Diem::EMINT_CAPABILITY | tc_accountdoes not have aDiem::MintCapability<CoinType>resource published under it. | 
| Errors::INVALID_STATE | Diem::EMINTING_NOT_ALLOWED | Minting is not currently allowed for CoinTypecoins. | 
| Errors::LIMIT_EXCEEDED | DiemAccount::EDEPOSIT_EXCEEDS_LIMITS | The depositing of the funds would exceed the account’s account limits. | 
Related Scripts
- Script::create_designated_dealer
- Script::peer_to_peer_with_metadata
- Script::rotate_dual_attestation_info
UnfreezeAccount
Summary
Unfreezes the account at address. The sending account of this transaction must be the
Treasury Compliance account. After the successful execution of this transaction transactions
may be sent from the previously frozen account, and coins may be sent and received.
Technical Description
Sets the AccountFreezing::FreezingBit to false and emits a
AccountFreezing::UnFreezeAccountEvent. The transaction sender must be the Treasury Compliance
account. Note that this is a per-account property so unfreezing a Parent VASP will not effect
the status any of its child accounts and vice versa.
Events
Successful execution of this script will emit a AccountFreezing::UnFreezeAccountEvent with
the unfrozen_address set the to_unfreeze_account’s address.
Parameters
| Name | Type | Description | 
|---|---|---|
| tc_account | &signer | The signer reference of the sending account of this transaction. Must be the Treasury Compliance account. | 
| sliding_nonce | u64 | The sliding_nonce(see:SlidingNonce) to be used for this transaction. | 
| to_unfreeze_account | address | The account address to be frozen. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::NOT_PUBLISHED | SlidingNonce::ESLIDING_NONCE | A SlidingNonceresource is not published underaccount. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_OLD | The sliding_nonceis too old and it’s impossible to determine if it’s duplicated or not. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_NEW | The sliding_nonceis too far in the future. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_ALREADY_RECORDED | The sliding_noncehas been previously recorded. | 
| Errors::REQUIRES_ADDRESS | CoreAddresses::ETREASURY_COMPLIANCE | The sending account is not the Treasury Compliance account. | 
Related Scripts
- Script::freeze_account
UpdateDiemVersion
Summary
Updates the Diem major version that is stored on-chain and is used by the VM. This transaction can only be sent from the Diem Root account.
Technical Description
Updates the DiemVersion on-chain config and emits a DiemConfig::NewEpochEvent to trigger
a reconfiguration of the system. The major version that is passed in must be strictly greater
than the current major version held on-chain. The VM reads this information and can use it to
preserve backwards compatibility with previous major versions of the VM.
Parameters
| Name | Type | Description | 
|---|---|---|
| account | &signer | Signer reference of the sending account. Must be the Diem Root account. | 
| sliding_nonce | u64 | The sliding_nonce(see:SlidingNonce) to be used for this transaction. | 
| major | u64 | The majorversion of the VM to be used from this transaction on. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::NOT_PUBLISHED | SlidingNonce::ESLIDING_NONCE | A SlidingNonceresource is not published underaccount. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_OLD | The sliding_nonceis too old and it’s impossible to determine if it’s duplicated or not. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_NEW | The sliding_nonceis too far in the future. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_ALREADY_RECORDED | The sliding_noncehas been previously recorded. | 
| Errors::REQUIRES_ADDRESS | CoreAddresses::EDIEM_ROOT | accountis not the Diem Root account. | 
| Errors::INVALID_ARGUMENT | DiemVersion::EINVALID_MAJOR_VERSION_NUMBER | majoris less-than or equal to the current major version stored on-chain. | 
UpdateDualAttestationLimit
Summary
Update the dual attestation limit on-chain. Defined in terms of micro-XDX. The transaction can only be sent by the Treasury Compliance account. After this transaction all inter-VASP payments over this limit must be checked for dual attestation.
Technical Description
Updates the micro_xdx_limit field of the DualAttestation::Limit resource published under
0xA550C18. The amount is set in micro-XDX.
Parameters
| Name | Type | Description | 
|---|---|---|
| tc_account | &signer | The signer reference of the sending account of this transaction. Must be the Treasury Compliance account. | 
| sliding_nonce | u64 | The sliding_nonce(see:SlidingNonce) to be used for this transaction. | 
| new_micro_xdx_limit | u64 | The new dual attestation limit to be used on-chain. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::NOT_PUBLISHED | SlidingNonce::ESLIDING_NONCE | A SlidingNonceresource is not published undertc_account. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_OLD | The sliding_nonceis too old and it’s impossible to determine if it’s duplicated or not. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_NEW | The sliding_nonceis too far in the future. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_ALREADY_RECORDED | The sliding_noncehas been previously recorded. | 
| Errors::REQUIRES_ADDRESS | CoreAddresses::ETREASURY_COMPLIANCE | tc_accountis not the Treasury Compliance account. | 
Related Scripts
- Script::update_exchange_rate
- Script::update_minting_ability
UpdateExchangeRate
Fields
currency: TypeTagSummary
Update the rough on-chain exchange rate between a specified currency and XDX (as a conversion to micro-XDX). The transaction can only be sent by the Treasury Compliance account. After this transaction the updated exchange rate will be used for normalization of gas prices, and for dual attestation checking.
Technical Description
Updates the on-chain exchange rate from the given Currency to micro-XDX.  The exchange rate
is given by new_exchange_rate_numerator/new_exchange_rate_denominator.
Parameters
| Name | Type | Description | 
|---|---|---|
| Currency | Type | The Move type for the Currencywhose exchange rate is being updated.Currencymust be an already-registered currency on-chain. | 
| tc_account | &signer | The signer reference of the sending account of this transaction. Must be the Treasury Compliance account. | 
| sliding_nonce | u64 | The sliding_nonce(see:SlidingNonce) to be used for the transaction. | 
| new_exchange_rate_numerator | u64 | The numerator for the new to micro-XDX exchange rate for Currency. | 
| new_exchange_rate_denominator | u64 | The denominator for the new to micro-XDX exchange rate for Currency. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::NOT_PUBLISHED | SlidingNonce::ESLIDING_NONCE | A SlidingNonceresource is not published undertc_account. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_OLD | The sliding_nonceis too old and it’s impossible to determine if it’s duplicated or not. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_TOO_NEW | The sliding_nonceis too far in the future. | 
| Errors::INVALID_ARGUMENT | SlidingNonce::ENONCE_ALREADY_RECORDED | The sliding_noncehas been previously recorded. | 
| Errors::REQUIRES_ADDRESS | CoreAddresses::ETREASURY_COMPLIANCE | tc_accountis not the Treasury Compliance account. | 
| Errors::REQUIRES_ROLE | Roles::ETREASURY_COMPLIANCE | tc_accountis not the Treasury Compliance account. | 
| Errors::INVALID_ARGUMENT | FixedPoint32::EDENOMINATOR | new_exchange_rate_denominatoris zero. | 
| Errors::INVALID_ARGUMENT | FixedPoint32::ERATIO_OUT_OF_RANGE | The quotient is unrepresentable as a FixedPoint32. | 
| Errors::LIMIT_EXCEEDED | FixedPoint32::ERATIO_OUT_OF_RANGE | The quotient is unrepresentable as a FixedPoint32. | 
Related Scripts
- Script::update_dual_attestation_limit
- Script::update_minting_ability
UpdateMintingAbility
Summary
Script to allow or disallow minting of new coins in a specified currency. This transaction can only be sent by the Treasury Compliance account. Turning minting off for a currency will have no effect on coins already in circulation, and coins may still be removed from the system.
Technical Description
This transaction sets the can_mint field of the Diem::CurrencyInfo<Currency> resource
published under 0xA550C18 to the value of allow_minting. Minting of coins if allowed if
this field is set to true and minting of new coins in Currency is disallowed otherwise.
This transaction needs to be sent by the Treasury Compliance account.
Parameters
| Name | Type | Description | 
|---|---|---|
| Currency | Type | The Move type for the Currencywhose minting ability is being updated.Currencymust be an already-registered currency on-chain. | 
| account | &signer | Signer reference of the sending account. Must be the Diem Root account. | 
| allow_minting | bool | Whether to allow minting of new coins in Currency. | 
Common Abort Conditions
| Error Category | Error Reason | Description | 
|---|---|---|
| Errors::REQUIRES_ADDRESS | CoreAddresses::ETREASURY_COMPLIANCE | tc_accountis not the Treasury Compliance account. | 
| Errors::NOT_PUBLISHED | Diem::ECURRENCY_INFO | Currencyis not a registered currency on-chain. | 
Related Scripts
- Script::update_dual_attestation_limit
- Script::update_exchange_rate
Implementations§
source§impl ScriptCall
 
impl ScriptCall
sourcepub fn decode(script: &Script) -> Option<ScriptCall>
 
pub fn decode(script: &Script) -> Option<ScriptCall>
Try to recognize a Diem Script and convert it into a structured object ScriptCall.
Trait Implementations§
source§impl Arbitrary for ScriptCall
 
impl Arbitrary for ScriptCall
§type Parameters = ()
 
type Parameters = ()
arbitrary_with accepts for configuration
of the generated Strategy. Parameters must implement Default.§type Strategy = TupleUnion<((u32, Arc<Map<<TypeTag as Arbitrary>::Strategy, fn(_: TypeTag) -> ScriptCall>>), (u32, Arc<Map<<AccountAddress as Arbitrary>::Strategy, fn(_: AccountAddress) -> ScriptCall>>), (u32, Arc<Map<(<u64 as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy), fn(_: (u64, Vec<u8, Global>, AccountAddress)) -> ScriptCall>>), (u32, Arc<Map<(<TypeTag as Arbitrary>::Strategy, <u64 as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy), fn(_: (TypeTag, u64, AccountAddress)) -> ScriptCall>>), (u32, Arc<Map<<TypeTag as Arbitrary>::Strategy, fn(_: TypeTag) -> ScriptCall>>), (u32, Arc<Map<(<TypeTag as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy), fn(_: (TypeTag, AccountAddress)) -> ScriptCall>>), (u32, Arc<Map<(<TypeTag as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <bool as Arbitrary>::Strategy, <u64 as Arbitrary>::Strategy), fn(_: (TypeTag, AccountAddress, Vec<u8, Global>, bool, u64)) -> ScriptCall>>), (u32, Arc<Map<(<TypeTag as Arbitrary>::Strategy, <u64 as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <bool as Arbitrary>::Strategy), fn(_: (TypeTag, u64, AccountAddress, Vec<u8, Global>, Vec<u8, Global>, bool)) -> ScriptCall>>), (u32, Arc<Map<(<TypeTag as Arbitrary>::Strategy, <u64 as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <bool as Arbitrary>::Strategy), fn(_: (TypeTag, u64, AccountAddress, Vec<u8, Global>, Vec<u8, Global>, bool)) -> ScriptCall>>), (u32, Arc<TupleUnion<((u32, Arc<fn() -> ScriptCall>), (u32, Arc<Map<(<u64 as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy), fn(_: (u64, AccountAddress, Vec<u8, Global>, Vec<u8, Global>)) -> ScriptCall>>), (u32, Arc<Map<(<u64 as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy), fn(_: (u64, AccountAddress, Vec<u8, Global>, Vec<u8, Global>)) -> ScriptCall>>), (u32, Arc<Map<(<u64 as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy), fn(_: (u64, AccountAddress)) -> ScriptCall>>), (u32, Arc<Map<(<TypeTag as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy, <u64 as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy), fn(_: (TypeTag, AccountAddress, u64, Vec<u8, Global>, Vec<u8, Global>)) -> ScriptCall>>), (u32, Arc<Map<(<TypeTag as Arbitrary>::Strategy, <u64 as Arbitrary>::Strategy), fn(_: (TypeTag, u64)) -> ScriptCall>>), (u32, Arc<Map<<Vec<u8, Global> as Arbitrary>::Strategy, fn(_: Vec<u8, Global>) -> ScriptCall>>), (u32, Arc<Map<(<AccountAddress as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy), fn(_: (AccountAddress, Vec<u8, Global>, Vec<u8, Global>, Vec<u8, Global>)) -> ScriptCall>>), (u32, Arc<Map<(<u64 as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy), fn(_: (u64, Vec<u8, Global>, AccountAddress)) -> ScriptCall>>), (u32, Arc<TupleUnion<((u32, Arc<Map<<Vec<u8, Global> as Arbitrary>::Strategy, fn(_: Vec<u8, Global>) -> ScriptCall>>), (u32, Arc<Map<(<u64 as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy), fn(_: (u64, Vec<u8, Global>)) -> ScriptCall>>), (u32, Arc<Map<(<u64 as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy), fn(_: (u64, Vec<u8, Global>)) -> ScriptCall>>), (u32, Arc<Map<(<AccountAddress as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy), fn(_: (AccountAddress, AccountAddress, Vec<u8, Global>)) -> ScriptCall>>), (u32, Arc<Map<(<Vec<u8, Global> as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy), fn(_: (Vec<u8, Global>, Vec<u8, Global>)) -> ScriptCall>>), (u32, Arc<Map<<Vec<u8, Global> as Arbitrary>::Strategy, fn(_: Vec<u8, Global>) -> ScriptCall>>), (u32, Arc<Map<(<AccountAddress as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy), fn(_: (AccountAddress, Vec<u8, Global>, Vec<u8, Global>, Vec<u8, Global>)) -> ScriptCall>>), (u32, Arc<Map<(<Vec<u8, Global> as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy), fn(_: (Vec<u8, Global>, AccountAddress)) -> ScriptCall>>), (u32, Arc<Map<(<u64 as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy), fn(_: (u64, Vec<u8, Global>, AccountAddress)) -> ScriptCall>>), (u32, Arc<TupleUnion<((u32, Arc<Map<(<TypeTag as Arbitrary>::Strategy, <u64 as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy, <u64 as Arbitrary>::Strategy, <u64 as Arbitrary>::Strategy), fn(_: (TypeTag, u64, AccountAddress, u64, u64)) -> ScriptCall>>), (u32, Arc<Map<(<u64 as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy), fn(_: (u64, AccountAddress)) -> ScriptCall>>), (u32, Arc<Map<(<u64 as Arbitrary>::Strategy, <u64 as Arbitrary>::Strategy), fn(_: (u64, u64)) -> ScriptCall>>), (u32, Arc<Map<(<u64 as Arbitrary>::Strategy, <u64 as Arbitrary>::Strategy), fn(_: (u64, u64)) -> ScriptCall>>), (u32, Arc<Map<(<TypeTag as Arbitrary>::Strategy, <u64 as Arbitrary>::Strategy, <u64 as Arbitrary>::Strategy, <u64 as Arbitrary>::Strategy), fn(_: (TypeTag, u64, u64, u64)) -> ScriptCall>>), (u32, Arc<Map<(<TypeTag as Arbitrary>::Strategy, <bool as Arbitrary>::Strategy), fn(_: (TypeTag, bool)) -> ScriptCall>>))>>))>>))>>))>
 
type Strategy = TupleUnion<((u32, Arc<Map<<TypeTag as Arbitrary>::Strategy, fn(_: TypeTag) -> ScriptCall>>), (u32, Arc<Map<<AccountAddress as Arbitrary>::Strategy, fn(_: AccountAddress) -> ScriptCall>>), (u32, Arc<Map<(<u64 as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy), fn(_: (u64, Vec<u8, Global>, AccountAddress)) -> ScriptCall>>), (u32, Arc<Map<(<TypeTag as Arbitrary>::Strategy, <u64 as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy), fn(_: (TypeTag, u64, AccountAddress)) -> ScriptCall>>), (u32, Arc<Map<<TypeTag as Arbitrary>::Strategy, fn(_: TypeTag) -> ScriptCall>>), (u32, Arc<Map<(<TypeTag as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy), fn(_: (TypeTag, AccountAddress)) -> ScriptCall>>), (u32, Arc<Map<(<TypeTag as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <bool as Arbitrary>::Strategy, <u64 as Arbitrary>::Strategy), fn(_: (TypeTag, AccountAddress, Vec<u8, Global>, bool, u64)) -> ScriptCall>>), (u32, Arc<Map<(<TypeTag as Arbitrary>::Strategy, <u64 as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <bool as Arbitrary>::Strategy), fn(_: (TypeTag, u64, AccountAddress, Vec<u8, Global>, Vec<u8, Global>, bool)) -> ScriptCall>>), (u32, Arc<Map<(<TypeTag as Arbitrary>::Strategy, <u64 as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <bool as Arbitrary>::Strategy), fn(_: (TypeTag, u64, AccountAddress, Vec<u8, Global>, Vec<u8, Global>, bool)) -> ScriptCall>>), (u32, Arc<TupleUnion<((u32, Arc<fn() -> ScriptCall>), (u32, Arc<Map<(<u64 as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy), fn(_: (u64, AccountAddress, Vec<u8, Global>, Vec<u8, Global>)) -> ScriptCall>>), (u32, Arc<Map<(<u64 as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy), fn(_: (u64, AccountAddress, Vec<u8, Global>, Vec<u8, Global>)) -> ScriptCall>>), (u32, Arc<Map<(<u64 as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy), fn(_: (u64, AccountAddress)) -> ScriptCall>>), (u32, Arc<Map<(<TypeTag as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy, <u64 as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy), fn(_: (TypeTag, AccountAddress, u64, Vec<u8, Global>, Vec<u8, Global>)) -> ScriptCall>>), (u32, Arc<Map<(<TypeTag as Arbitrary>::Strategy, <u64 as Arbitrary>::Strategy), fn(_: (TypeTag, u64)) -> ScriptCall>>), (u32, Arc<Map<<Vec<u8, Global> as Arbitrary>::Strategy, fn(_: Vec<u8, Global>) -> ScriptCall>>), (u32, Arc<Map<(<AccountAddress as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy), fn(_: (AccountAddress, Vec<u8, Global>, Vec<u8, Global>, Vec<u8, Global>)) -> ScriptCall>>), (u32, Arc<Map<(<u64 as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy), fn(_: (u64, Vec<u8, Global>, AccountAddress)) -> ScriptCall>>), (u32, Arc<TupleUnion<((u32, Arc<Map<<Vec<u8, Global> as Arbitrary>::Strategy, fn(_: Vec<u8, Global>) -> ScriptCall>>), (u32, Arc<Map<(<u64 as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy), fn(_: (u64, Vec<u8, Global>)) -> ScriptCall>>), (u32, Arc<Map<(<u64 as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy), fn(_: (u64, Vec<u8, Global>)) -> ScriptCall>>), (u32, Arc<Map<(<AccountAddress as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy), fn(_: (AccountAddress, AccountAddress, Vec<u8, Global>)) -> ScriptCall>>), (u32, Arc<Map<(<Vec<u8, Global> as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy), fn(_: (Vec<u8, Global>, Vec<u8, Global>)) -> ScriptCall>>), (u32, Arc<Map<<Vec<u8, Global> as Arbitrary>::Strategy, fn(_: Vec<u8, Global>) -> ScriptCall>>), (u32, Arc<Map<(<AccountAddress as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy), fn(_: (AccountAddress, Vec<u8, Global>, Vec<u8, Global>, Vec<u8, Global>)) -> ScriptCall>>), (u32, Arc<Map<(<Vec<u8, Global> as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy), fn(_: (Vec<u8, Global>, AccountAddress)) -> ScriptCall>>), (u32, Arc<Map<(<u64 as Arbitrary>::Strategy, <Vec<u8, Global> as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy), fn(_: (u64, Vec<u8, Global>, AccountAddress)) -> ScriptCall>>), (u32, Arc<TupleUnion<((u32, Arc<Map<(<TypeTag as Arbitrary>::Strategy, <u64 as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy, <u64 as Arbitrary>::Strategy, <u64 as Arbitrary>::Strategy), fn(_: (TypeTag, u64, AccountAddress, u64, u64)) -> ScriptCall>>), (u32, Arc<Map<(<u64 as Arbitrary>::Strategy, <AccountAddress as Arbitrary>::Strategy), fn(_: (u64, AccountAddress)) -> ScriptCall>>), (u32, Arc<Map<(<u64 as Arbitrary>::Strategy, <u64 as Arbitrary>::Strategy), fn(_: (u64, u64)) -> ScriptCall>>), (u32, Arc<Map<(<u64 as Arbitrary>::Strategy, <u64 as Arbitrary>::Strategy), fn(_: (u64, u64)) -> ScriptCall>>), (u32, Arc<Map<(<TypeTag as Arbitrary>::Strategy, <u64 as Arbitrary>::Strategy, <u64 as Arbitrary>::Strategy, <u64 as Arbitrary>::Strategy), fn(_: (TypeTag, u64, u64, u64)) -> ScriptCall>>), (u32, Arc<Map<(<TypeTag as Arbitrary>::Strategy, <bool as Arbitrary>::Strategy), fn(_: (TypeTag, bool)) -> ScriptCall>>))>>))>>))>>))>
Strategy used to generate values of type Self.source§fn arbitrary_with(_top: Self::Parameters) -> Self::Strategy
 
fn arbitrary_with(_top: Self::Parameters) -> Self::Strategy
source§impl Clone for ScriptCall
 
impl Clone for ScriptCall
source§fn clone(&self) -> ScriptCall
 
fn clone(&self) -> ScriptCall
1.0.0 · source§fn clone_from(&mut self, source: &Self)
 
fn clone_from(&mut self, source: &Self)
source. Read moresource§impl Debug for ScriptCall
 
impl Debug for ScriptCall
source§impl PartialEq<ScriptCall> for ScriptCall
 
impl PartialEq<ScriptCall> for ScriptCall
source§fn eq(&self, other: &ScriptCall) -> bool
 
fn eq(&self, other: &ScriptCall) -> bool
self and other values to be equal, and is used
by ==.source§impl PartialOrd<ScriptCall> for ScriptCall
 
impl PartialOrd<ScriptCall> for ScriptCall
source§fn partial_cmp(&self, other: &ScriptCall) -> Option<Ordering>
 
fn partial_cmp(&self, other: &ScriptCall) -> Option<Ordering>
1.0.0 · source§fn le(&self, other: &Rhs) -> bool
 
fn le(&self, other: &Rhs) -> bool
self and other) and is used by the <=
operator. Read more