Skip to main content

create_accounts

Create one or more Accounts.

Event

The account to create. See Account for constraints.

Result

Results are listed in this section in order of descending precedence — that is, if more than one error is applicable to the account being created, only the result listed first is returned.

ok

The account was successfully created; it did not previously exist.

Note that ok is generated by the client implementation; the network protocol does not include a result when the account was successfully created.

linked_event_failed

The account was not created. One or more of the accounts in the linked chain is invalid, so the whole chain failed.

linked_event_chain_open

The account was not created. The Account.flags.linked flag was set on the last event in the batch, which is not legal. (flags.linked indicates that the chain continues to the next operation).

imported_event_expected

The account was not created. The Account.flags.imported was set on the first account of the batch, but not all accounts in the batch. Batches cannot mix imported accounts with non-imported accounts.

imported_event_not_expected

The account was not created. The Account.flags.imported was expected to not be set, as it's not allowed to mix accounts with different imported flag in the same batch. The first account determines the entire operation.

timestamp_must_be_zero

This result only applies when Account.flags.imported is not set.

The account was not created. The Account.timestamp is nonzero, but must be zero. The cluster is responsible for setting this field.

The Account.timestamp can only be assigned when creating accounts with Account.flags.imported set.

imported_event_timestamp_out_of_range

This result only applies when Account.flags.imported is set.

The account was not created. The Account.timestamp is out of range, but must be a user-defined timestamp greater than 0 and less than 2^63.

imported_event_timestamp_must_not_advance

This result only applies when Account.flags.imported is set.

The account was not created. The user-defined Account.timestamp is greater than the current cluster time, but it must be a past timestamp.

reserved_field

The account was not created. Account.reserved is nonzero, but must be zero.

reserved_flag

The account was not created. Account.flags.reserved is nonzero, but must be zero.

id_must_not_be_zero

The account was not created. Account.id is zero, which is a reserved value.

id_must_not_be_int_max

The account was not created. Account.id is 2^128 - 1, which is a reserved value.

flags_are_mutually_exclusive

The account was not created. An account cannot be created with the specified combination of Account.flags.

The following flags are mutually exclusive:

debits_pending_must_be_zero

The account was not created. Account.debits_pending is nonzero, but must be zero.

An account's debits and credits are only modified by transfers.

debits_posted_must_be_zero

The account was not created. Account.debits_posted is nonzero, but must be zero.

An account's debits and credits are only modified by transfers.

credits_pending_must_be_zero

The account was not created. Account.credits_pending is nonzero, but must be zero.

An account's debits and credits are only modified by transfers.

credits_posted_must_be_zero

The account was not created. Account.credits_posted is nonzero, but must be zero.

An account's debits and credits are only modified by transfers.

ledger_must_not_be_zero

The account was not created. Account.ledger is zero, but must be nonzero.

code_must_not_be_zero

The account was not created. Account.code is zero, but must be nonzero.

exists_with_different_flags

An account with the same id already exists, but with different flags.

exists_with_different_user_data_128

An account with the same id already exists, but with different user_data_128.

exists_with_different_user_data_64

An account with the same id already exists, but with different user_data_64.

exists_with_different_user_data_32

An account with the same id already exists, but with different user_data_32.

exists_with_different_ledger

An account with the same id already exists, but with different ledger.

exists_with_different_code

An account with the same id already exists, but with different code.

exists

An account with the same id already exists.

With the possible exception of the following fields, the existing account is identical to the account in the request:

  • timestamp
  • debits_pending
  • debits_posted
  • credits_pending
  • credits_posted

To correctly recover from application crashes, many applications should handle exists exactly as ok.

imported_event_timestamp_must_not_regress

This result only applies when Account.flags.imported is set.

The account was not created. The user-defined Account.timestamp regressed, but it must be greater than the last timestamp assigned to any Account in the cluster and cannot be equal to the timestamp of any existing Transfer.

Client libraries

For language-specific docs see:

Internals

If you're curious and want to learn more, you can find the source code for creating an account in src/state_machine.zig. Search for fn create_account( and fn execute(.