Lifecycle of a Transaction
ZK Compression transactions are fully compatible with Solana's Transaction and Versioned Transaction formats. There are three key nuances in building transactions with compressed accounts as compared to regular accounts:
Instructions must specify the list of all compressed accounts being read or written to. To read or write to a compressed account, the instruction must send the current account state on-chain and prove its validity
Each unique state tree that gets read or written to (via any compressed account) needs to be specified as per Solana's regular on-chain account access lists
To read any compressed account state on-chain, the client must send a validity proof alongside the instruction data to the chain. Depending on your program logic, the validity proof can prove A) the validity of all specified read accounts and B) the non-existence of a specified PDA within the compressed address space, e.g., for creating a new compressed PDA account
We can express a transaction more generally as:
(state, validityProof) -> state transition -> state'
Here's what this looks like when updating a single compressed PDA account:
In this example, we assume that the client previously created said compressed account and thereafter fetched its compressed account info from an RPC node
The custom Solana program executing the state transition Data -> Data' should require its client to pack the instructions efficiently. In the above scenario, the total data that's sent to the chain is: address (same)
, owner program (same)
, data
, data'-data
, validity proof
The compressed account after its update looks like this:
On-chain Protocol Execution
To write compressed state, a custom caller program must invoke the Light System Program via CPI. The system program then does the following:
Runs relevant checks (sum check, etc.)
Nullifies the "old" leaf of the compressed account that is being written to
Appends the new compressed account hash to the state tree and advances the tree's state root
Emits the new "raw" compressed account state onto the Solana ledger
An RPC node then parses the transaction and compressed state and provides the read state to clients via the ZK Compression RPC API
Last updated