Using Capsules
Capsules are a per-contract non-volatile database.
It can be used for storing arbitrary data that can be retrieved later.
The data is stored locally in PXE and it is scoped per contract address, so external contracts cannot access it.
The capsule (data stored under a storage slot in the capsules database) persists until explicitly deleted with delete
.
The capsules module provides these main functions:
store<T, N>
- Stores arbitrary data at a slot, overwriting any existing dataload<T, N>
- Retrieves previously stored data from a slotdelete
- Deletes data at a slotcopy
- Efficiently copies contiguous entries between slots
1. Import capsules into your smart contract
Import the capsules module:
use dep::aztec::oracle::capsules;
Source code: noir-projects/noir-contracts/contracts/contract_class_registerer_contract/src/main.nr#L34-L36
2. Store and load data
You can store any type that implements Serialize
and Deserialize
:
let packed_public_bytecode: [Field; MAX_PACKED_PUBLIC_BYTECODE_SIZE_IN_FIELDS] = unsafe {
capsules::load(
context.this_address(),
REGISTERER_CONTRACT_BYTECODE_CAPSULE_SLOT,
)
.unwrap()
};
Source code: noir-projects/noir-contracts/contracts/contract_class_registerer_contract/src/main.nr#L47-L55
The data is stored per contract address and slot. When loading, you'll get back an Option<T>
- None
if no data exists at that slot.
3. Copying data
You can use copy
to move contiguous entries between slots without repeated loads and stores.
This supports overlapping source and destination regions.
Note that all values are scoped per contract address, so external contracts cannot access them.
4. Using CapsuleArray
The CapsuleArray<T>
type provides a dynamically sized array backed by capsules.
It handles the storage layout and management automatically.
The array stores its length at a base slot, with elements stored in consecutive slots after it.
Key functions:
at(contract_address, base_slot)
- Creates/connects to an array at the given base slotlen()
- Returns the number of elements in the arraypush(value)
- Appends a value to the end of the arrayget(index)
- Retrieves the value at the given indexremove(index)
- Removes an element, shifting subsequent elements to maintain contiguous storage