Function diem_transaction_builder::stdlib::encode_create_validator_operator_account_script_function  
source · pub fn encode_create_validator_operator_account_script_function(
    sliding_nonce: u64,
    new_account_address: AccountAddress,
    auth_key_prefix: Vec<u8>,
    human_name: Vec<u8>
) -> TransactionPayloadExpand description
Summary
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.
Authentication key prefixes, and how to construct them from an ed25519 public key are described
here.
Events
Successful execution will emit:
- A DiemAccount::CreateAccountEventwith thecreatedfield beingnew_account_address, and therold_idfield beingRoles::VALIDATOR_OPERATOR_ROLE_ID. This is emitted on theDiemAccount::AccountOperationsCapabilitycreation_eventshandle.
Parameters
| Name | Type | Description | 
|---|---|---|
| dr_account | signer | The signer 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
- AccountCreationScripts::create_validator_account
- ValidatorAdministrationScripts::add_validator_and_reconfigure
- ValidatorAdministrationScripts::register_validator_config
- ValidatorAdministrationScripts::remove_validator_and_reconfigure
- ValidatorAdministrationScripts::set_validator_operator
- ValidatorAdministrationScripts::set_validator_operator_with_nonce_admin
- ValidatorAdministrationScripts::set_validator_config_and_reconfigure