pub enum SystemInstruction {
Show 13 variants CreateAccount { lamports: u64, space: u64, owner: Pubkey, }, Assign { owner: Pubkey, }, Transfer { lamports: u64, }, CreateAccountWithSeed { base: Pubkey, seed: String, lamports: u64, space: u64, owner: Pubkey, }, AdvanceNonceAccount, WithdrawNonceAccount(u64), InitializeNonceAccount(Pubkey), AuthorizeNonceAccount(Pubkey), Allocate { space: u64, }, AllocateWithSeed { base: Pubkey, seed: String, space: u64, owner: Pubkey, }, AssignWithSeed { base: Pubkey, seed: String, owner: Pubkey, }, TransferWithSeed { lamports: u64, from_seed: String, from_owner: Pubkey, }, UpgradeNonceAccount,
}

Variants

CreateAccount

Fields

lamports: u64

Number of lamports to transfer to the new account

space: u64

Number of bytes of memory to allocate

owner: Pubkey

Address of program that will own the new account

Create a new account

Account references

  1. [WRITE, SIGNER] Funding account
  2. [WRITE, SIGNER] New account

Assign

Fields

owner: Pubkey

Owner program account

Assign account to a program

Account references

  1. [WRITE, SIGNER] Assigned account public key

Transfer

Fields

lamports: u64

Transfer lamports

Account references

  1. [WRITE, SIGNER] Funding account
  2. [WRITE] Recipient account

CreateAccountWithSeed

Fields

base: Pubkey

Base public key

seed: String

String of ASCII chars, no longer than Pubkey::MAX_SEED_LEN

lamports: u64

Number of lamports to transfer to the new account

space: u64

Number of bytes of memory to allocate

owner: Pubkey

Owner program account address

Create a new account at an address derived from a base pubkey and a seed

Account references

  1. [WRITE, SIGNER] Funding account
  2. [WRITE] Created account
  3. [SIGNER] (optional) Base account; the account matching the base Pubkey below must be provided as a signer, but may be the same as the funding account and provided as account 0

AdvanceNonceAccount

Consumes a stored nonce, replacing it with a successor

Account references

  1. [WRITE] Nonce account
  2. [] RecentBlockhashes sysvar
  3. [SIGNER] Nonce authority

WithdrawNonceAccount(u64)

Withdraw funds from a nonce account

Account references

  1. [WRITE] Nonce account
  2. [WRITE] Recipient account
  3. [] RecentBlockhashes sysvar
  4. [] Rent sysvar
  5. [SIGNER] Nonce authority

The u64 parameter is the lamports to withdraw, which must leave the account balance above the rent exempt reserve or at zero.

InitializeNonceAccount(Pubkey)

Drive state of Uninitialized nonce account to Initialized, setting the nonce value

Account references

  1. [WRITE] Nonce account
  2. [] RecentBlockhashes sysvar
  3. [] Rent sysvar

The Pubkey parameter specifies the entity authorized to execute nonce instruction on the account

No signatures are required to execute this instruction, enabling derived nonce account addresses

AuthorizeNonceAccount(Pubkey)

Change the entity authorized to execute nonce instructions on the account

Account references

  1. [WRITE] Nonce account
  2. [SIGNER] Nonce authority

The Pubkey parameter identifies the entity to authorize

Allocate

Fields

space: u64

Number of bytes of memory to allocate

Allocate space in a (possibly new) account without funding

Account references

  1. [WRITE, SIGNER] New account

AllocateWithSeed

Fields

base: Pubkey

Base public key

seed: String

String of ASCII chars, no longer than pubkey::MAX_SEED_LEN

space: u64

Number of bytes of memory to allocate

owner: Pubkey

Owner program account

Allocate space for and assign an account at an address derived from a base public key and a seed

Account references

  1. [WRITE] Allocated account
  2. [SIGNER] Base account

AssignWithSeed

Fields

base: Pubkey

Base public key

seed: String

String of ASCII chars, no longer than pubkey::MAX_SEED_LEN

owner: Pubkey

Owner program account

Assign account to a program based on a seed

Account references

  1. [WRITE] Assigned account
  2. [SIGNER] Base account

TransferWithSeed

Fields

lamports: u64

Amount to transfer

from_seed: String

Seed to use to derive the funding account address

from_owner: Pubkey

Owner to use to derive the funding account address

Transfer lamports from a derived address

Account references

  1. [WRITE] Funding account
  2. [SIGNER] Base for funding account
  3. [WRITE] Recipient account

UpgradeNonceAccount

One-time idempotent upgrade of legacy nonce versions in order to bump them out of chain blockhash domain.

Account references

  1. [WRITE] Nonce account

Trait Implementations

Returns a copy of the value. Read more
Performs copy-assignment from source. Read more
Formats the value using the given formatter. Read more
Deserialize this value from the given Serde deserializer. Read more
This method tests for self and other values to be equal, and is used by ==. Read more
This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason. Read more
Serialize this value into the given Serde serializer. Read more

Auto Trait Implementations

Blanket Implementations

Gets the TypeId of self. Read more
Immutably borrows from an owned value. Read more
Mutably borrows from an owned value. Read more

Returns the argument unchanged.

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

The alignment of pointer.
The type for initializers.
Initializes a with the given initializer. Read more
Dereferences the given pointer. Read more
Mutably dereferences the given pointer. Read more
Drops the object pointed to by the given pointer. Read more
Should always be Self
The resulting type after obtaining ownership.
Creates owned data from borrowed data, usually by cloning. Read more
Uses borrowed data to replace owned data, usually by cloning. Read more
The type returned in the event of a conversion error.
Performs the conversion.
The type returned in the event of a conversion error.
Performs the conversion.