State Transition#

State Transition Overview#

State transitions are the means for submitting data that creates, updates, or deletes platform data and results in a change to a new state. Each one must contain:

Fees#

State transition fees are paid via the credits established when an identity is created. Credits are created at a rate of 1000 credits/satoshi. Fees for actions vary based on parameters related to storage and computational effort that are defined in rs-dpp.

Size#

State transitions are limited to a maximum size of 20 KB.

Common Fields#

The list of common fields used by multiple state transitions is defined in rs-dpp. All state transitions include the following fields:

Field

Type

Size

Description

$version

unsigned integer

16 bits

The state transition format version (FeatureVersion). Currently 0 for most transitions, 1 for Batch. This is not the global platform protocol version, which is negotiated separately.

type

unsigned integer

8 bits

State transition type discriminator (defined in rs-dpp). See State Transition Types for the full list.

userFeeIncrease

unsigned integer

16 bits

Extra fee to prioritize processing if the mempool is full. Typically set to zero.

signature

array of bytes

65 bytes

Signature of state transition data

Note

The masternode vote transition does not include the userFeeIncrease field.

Additionally, all state transitions except the identity create and topup state transitions include:

Field

Type

Size

Description

signaturePublicKeyId

unsigned integer

32 bits

The id of the identity public key that signed the state transition (=> 0)

State Transition Types#

Dash Platform Protocol defines the following state transition types. Most are documented in detail on the protocol reference page for the feature they operate on. Batch and Masternode Vote do not have a dedicated feature page; their formats are documented inline below.

Type

Name

Documented in

0

Data Contract Create

Data Contract Create

1

Batch

Batch (below)

2

Identity Create

Identity Create

3

Identity TopUp

Identity TopUp

4

Data Contract Update

Data Contract Update

5

Identity Update

Identity Update

6

Identity Credit Withdrawal

Identity Credit Withdrawal

7

Identity Credit Transfer

Identity Credit Transfer

8

Masternode Vote

Masternode Vote (below)

9

Identity Credit Transfer to Addresses

Identity Credit Transfer to Addresses

10

Identity Create from Addresses

Identity Create from Addresses

11

Identity TopUp from Addresses

Identity TopUp from Addresses

12

Address Funds Transfer

Address Funds Transfer

13

Address Funding from Asset Lock

Address Funding from Asset Lock

14

Address Credit Withdrawal

Address Credit Withdrawal

15

Shield

Shield

16

Shielded Transfer

Shielded Transfer

17

Unshield

Unshield

18

Shield from Asset Lock

Shield from Asset Lock

19

Shielded Withdrawal

Shielded Withdrawal

Batch#

Field

Type

Size

Description

ownerId

array of bytes

32 bytes

Identity submitting the document(s) or token action(s)

transitions

array of transition objects

Varies

A batch of document or token actions (currently limited to 1 object per batch)

More detailed information about the transitions array can be found in the document section. See the implementation in rs-dpp.

Masternode Vote#

Field

Type

Size

Description

proTxHash

array of bytes

32 bytes

An identifier based on a masternode or evonode’s provider registration transaction hash

voterIdentityId

array of bytes

32 bytes

The voter’s Identity ID. This will be a masternode identity based on the protx hash.

vote

Vote

Varies

Vote information

nonce

unsigned integer

64 bits

Identity nonce for this transition to prevent replay attacks

See the implementation in rs-dpp.

State Transition Signing#

State transitions must be cryptographically signed to prove that an authorized party submitted them. There are three ways to sign state transitions, with the difference being the source of the private key used for signing. The following table specifies which signing method is used by each state transition type:

Signing Method

State Transitions

Identity

Batch, Contract create, Contract update, Identity update, Identity credit transfer, Identity credit transfer to addresses, Identity credit withdrawal, Masternode vote

Asset lock

Identity create, Identity topup, Address funding from asset lock*, Shield from asset lock**

Address witness

Identity create from addresses, Identity topup from addresses, Address funds transfer, Address credit withdrawal, Address funding from asset lock*, Shield**

Shielded (Orchard)

Shield**, Shielded transfer, Unshield, Shield from asset lock**, Shielded withdrawal

* Address funding from asset lock requires both an asset lock signature and address witnesses (input_witnesses).

** Shielded transitions are always authorized by Orchard bundle signatures (per-action spendAuthSig plus the transition-level bindingSignature). Shield additionally carries address witnesses for its transparent address inputs; Shield from asset lock additionally carries an asset-lock ECDSA signature.

Note

Address-based state transitions (types 9-14) were introduced in Protocol Version 11. For detailed information on these transitions, see Address-Based State Transitions.

Signing with Asset Lock#

The identity create and topup state transition signatures are unique in that they must be signed by the private key used in the Core chain asset lock transaction funding the identity. The signing process consists of the following steps:

  1. Create a canonical, signable state transition encoded using Bincode.

    • Exclude the signature field and any other non-signable fields indicated in the table below.

  2. Calculate the double SHA-256 hash of the encoded signable state transition.

  3. Sign the computed hash using the private key associated with the asset lock transaction.

  4. Store the signature in the state transition’s signature field.

  5. For identity create only, sign any public keys as described in the signing public keys section.

  6. Finalize the state transition by re-encoding it with Bincode, including all previously excluded fields such as signature.

Signing with Identity#

Most state transitions must be signed by a private key associated with the identity creating the state transition. Each identity must have at least two keys: a primary key (security level 0) that is only used when signing identity update state transitions and an additional key (security level 2) that is used to sign all other state transitions.

The process to sign state transitions using an identity consists of the following steps:

  1. Create a canonical, signable state transition encoded using Bincode.

  2. Calculate the double SHA-256 hash of the encoded signable state transition.

  3. Sign the computed hash using the identity’s relevant private key.

  4. Store the signature in the state transition’s signature field

  5. For identity update only, sign any added public keys as described in the signing public keys section.

  6. Finalize the state transition by re-encoding it with Bincode, including all previously excluded fields such as signature.

Signing with Address Witness#

Address-based state transitions (types 10-12, 14) use address witnesses to prove ownership of Platform addresses. Unlike identity-signed transitions, these do not require an existing identity. Instead, each input address requires a corresponding witness containing cryptographic proof of address ownership.

Note

Identity credit transfer to addresses (type 9) is not signed with address witnesses — it uses identity signing because it requires an existing identity.

The process to sign state transitions using address witnesses consists of the following steps:

  1. Create a canonical, signable state transition encoded using Bincode.

    • Exclude the input_witnesses field and any other non-signable fields.

  2. Calculate the double SHA-256 hash of the encoded signable state transition.

  3. For each input address, create an appropriate witness:

    • P2PKH addresses: Create a recoverable ECDSA signature (65 bytes) using the private key that derives the address.

    • P2SH multisig addresses: Collect the required number of signatures and include the redeem script.

  4. Store witnesses in the state transition’s input_witnesses field in the same order as inputs.

  5. Finalize the state transition by re-encoding it with Bincode, including all previously excluded fields.

For detailed information on address witnesses and Platform addresses, see Address-Based State Transitions.

Signing public keys#

Public keys can be added to an identity by the identity create or identity update state transitions. Any new public keys must include a signature to prove that the associated private key is accessible. To sign new public keys:

  1. Get the double SHA-256 hash of the encoded signable state transition from step 2 of the signing with asset lock or signing with identity section.

  2. Sign each new public key:

    • Use the private key that derived the public key to sign the hash.

    • Store the result in the public key’s signature field.

Signing Shielded Transitions#

Shielded transitions are not signed by an identity public key or an address private key at the transition level — they do not include signature or signaturePublicKeyId fields. Authorization is carried instead by Orchard primitives attached to each action and to the bundle as a whole. Shield additionally carries address witnesses over its address inputs, and Shield from asset lock additionally carries an asset-lock ECDSA signature. Both input_witnesses (on Shield) and signature (on Shield from asset lock) are omitted from the bytes that feed the platform sighash.

See Shielded Transition Signing for the full signing model.

Non-signable Fields#

This table shows the fields that must be excluded when creating state transition signatures. All transitions exclude the signature field. Some transitions contain other fields that must be excluded also. Click the state transition name to see the rs-dpp implementation for additional context.

State transition

Signature

Signature public key ID

Identity ID

Identity public key signature(s)

Batch

Exclude

Exclude

N/A

N/A

Contract create

Exclude

Exclude

N/A

N/A

Contract update

Exclude

Exclude

N/A

N/A

Identity create

Exclude

N/A

Exclude

Exclude

Identity topup

Exclude

N/A

N/A

N/A

Identity update

Exclude

Exclude

N/A

Exclude for any keys being added by the state transition

Identity credit transfer

Exclude

Exclude

N/A

N/A

Identity credit withdrawal

Exclude

Exclude

N/A

N/A

Masternode vote

Exclude

Exclude

N/A

N/A

Note

The table above does not cover shielded transitions, which do not carry transition-level signature or signaturePublicKeyId fields. See Signing Shielded Transitions.