@aztec/pxe 0.0.1-commit.64b6bbb → 0.0.1-commit.69c59a8b3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dest/bin/check_oracle_version.js +4 -4
- package/dest/block_synchronizer/block_synchronizer.d.ts +1 -1
- package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -1
- package/dest/block_synchronizer/block_synchronizer.js +6 -0
- package/dest/config/index.d.ts +2 -2
- package/dest/config/index.d.ts.map +1 -1
- package/dest/config/index.js +8 -15
- package/dest/config/package_info.js +1 -1
- package/dest/contract_function_simulator/contract_function_simulator.d.ts +17 -7
- package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
- package/dest/contract_function_simulator/contract_function_simulator.js +145 -48
- package/dest/contract_function_simulator/ephemeral_array_service.d.ts +28 -0
- package/dest/contract_function_simulator/ephemeral_array_service.d.ts.map +1 -0
- package/dest/contract_function_simulator/ephemeral_array_service.js +78 -0
- package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts +7 -7
- package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts.map +1 -1
- package/dest/contract_function_simulator/execution_tagging_index_cache.js +19 -11
- package/dest/contract_function_simulator/index.d.ts +2 -1
- package/dest/contract_function_simulator/index.d.ts.map +1 -1
- package/dest/contract_function_simulator/index.js +1 -0
- package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts +4 -6
- package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts.map +1 -1
- package/dest/contract_function_simulator/noir-structs/event_validation_request.js +8 -10
- package/dest/contract_function_simulator/noir-structs/log_retrieval_request.d.ts +1 -1
- package/dest/contract_function_simulator/noir-structs/log_retrieval_request.js +1 -1
- package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts +2 -2
- package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts.map +1 -1
- package/dest/contract_function_simulator/noir-structs/log_retrieval_response.js +2 -4
- package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +4 -7
- package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts.map +1 -1
- package/dest/contract_function_simulator/noir-structs/note_validation_request.js +6 -11
- package/dest/contract_function_simulator/oracle/interfaces.d.ts +61 -45
- package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.d.ts +9 -0
- package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.d.ts.map +1 -0
- package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.js +47 -0
- package/dest/contract_function_simulator/oracle/oracle.d.ts +75 -44
- package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/oracle.js +281 -96
- package/dest/contract_function_simulator/oracle/private_execution.js +5 -3
- package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +23 -48
- package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/private_execution_oracle.js +51 -73
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +92 -56
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +275 -106
- package/dest/contract_function_simulator/pick_notes.d.ts +1 -1
- package/dest/contract_function_simulator/pick_notes.d.ts.map +1 -1
- package/dest/contract_function_simulator/pick_notes.js +14 -3
- package/dest/contract_function_simulator/proxied_contract_data_source.d.ts +1 -1
- package/dest/contract_function_simulator/proxied_contract_data_source.d.ts.map +1 -1
- package/dest/contract_function_simulator/proxied_contract_data_source.js +3 -0
- package/dest/contract_logging.d.ts +27 -0
- package/dest/contract_logging.d.ts.map +1 -0
- package/dest/contract_logging.js +38 -0
- package/dest/contract_sync/contract_sync_service.d.ts +7 -4
- package/dest/contract_sync/contract_sync_service.d.ts.map +1 -1
- package/dest/contract_sync/contract_sync_service.js +69 -35
- package/dest/contract_sync/helpers.d.ts +2 -2
- package/dest/contract_sync/helpers.d.ts.map +1 -1
- package/dest/contract_sync/helpers.js +9 -4
- package/dest/debug/pxe_debug_utils.d.ts +4 -3
- package/dest/debug/pxe_debug_utils.d.ts.map +1 -1
- package/dest/debug/pxe_debug_utils.js +4 -4
- package/dest/entrypoints/client/bundle/index.d.ts +3 -1
- package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
- package/dest/entrypoints/client/bundle/index.js +2 -0
- package/dest/entrypoints/client/bundle/utils.d.ts +2 -2
- package/dest/entrypoints/client/bundle/utils.d.ts.map +1 -1
- package/dest/entrypoints/client/bundle/utils.js +2 -2
- package/dest/entrypoints/client/lazy/index.d.ts +3 -1
- package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
- package/dest/entrypoints/client/lazy/index.js +2 -0
- package/dest/entrypoints/client/lazy/utils.d.ts +2 -2
- package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
- package/dest/entrypoints/client/lazy/utils.js +2 -2
- package/dest/entrypoints/pxe_creation_options.d.ts +3 -1
- package/dest/entrypoints/pxe_creation_options.d.ts.map +1 -1
- package/dest/entrypoints/pxe_creation_options.js +3 -1
- package/dest/entrypoints/server/index.d.ts +3 -2
- package/dest/entrypoints/server/index.d.ts.map +1 -1
- package/dest/entrypoints/server/index.js +2 -1
- package/dest/entrypoints/server/utils.d.ts +2 -2
- package/dest/entrypoints/server/utils.d.ts.map +1 -1
- package/dest/entrypoints/server/utils.js +2 -2
- package/dest/events/event_service.d.ts +3 -2
- package/dest/events/event_service.d.ts.map +1 -1
- package/dest/events/event_service.js +16 -4
- package/dest/events/private_event_filter_validator.d.ts +3 -2
- package/dest/events/private_event_filter_validator.d.ts.map +1 -1
- package/dest/events/private_event_filter_validator.js +15 -0
- package/dest/logs/log_service.d.ts +7 -7
- package/dest/logs/log_service.d.ts.map +1 -1
- package/dest/logs/log_service.js +33 -48
- package/dest/messages/message_context_service.d.ts +17 -0
- package/dest/messages/message_context_service.d.ts.map +1 -0
- package/dest/messages/message_context_service.js +36 -0
- package/dest/notes/note_service.d.ts +4 -4
- package/dest/notes/note_service.d.ts.map +1 -1
- package/dest/notes/note_service.js +17 -7
- package/dest/notes_filter.d.ts +24 -0
- package/dest/notes_filter.d.ts.map +1 -0
- package/dest/notes_filter.js +4 -0
- package/dest/oracle_version.d.ts +4 -3
- package/dest/oracle_version.d.ts.map +1 -1
- package/dest/oracle_version.js +20 -10
- package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts +4 -0
- package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts.map +1 -0
- package/dest/private_kernel/hints/{compute_tx_include_by_timestamp.js → compute_tx_expiration_timestamp.js} +12 -12
- package/dest/private_kernel/hints/index.d.ts +1 -1
- package/dest/private_kernel/hints/index.js +1 -1
- package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts +4 -3
- package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts.map +1 -1
- package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.js +129 -68
- package/dest/private_kernel/hints/test_utils.d.ts +122 -0
- package/dest/private_kernel/hints/test_utils.d.ts.map +1 -0
- package/dest/private_kernel/hints/test_utils.js +203 -0
- package/dest/private_kernel/private_kernel_execution_prover.d.ts +1 -1
- package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
- package/dest/private_kernel/private_kernel_execution_prover.js +18 -13
- package/dest/private_kernel/private_kernel_oracle.d.ts +6 -2
- package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
- package/dest/private_kernel/private_kernel_oracle.js +7 -3
- package/dest/pxe.d.ts +23 -15
- package/dest/pxe.d.ts.map +1 -1
- package/dest/pxe.js +87 -54
- package/dest/storage/anchor_block_store/anchor_block_store.js +1 -1
- package/dest/storage/capsule_store/capsule_service.d.ts +21 -0
- package/dest/storage/capsule_store/capsule_service.d.ts.map +1 -0
- package/dest/storage/capsule_store/capsule_service.js +50 -0
- package/dest/storage/capsule_store/capsule_store.d.ts +9 -9
- package/dest/storage/capsule_store/capsule_store.d.ts.map +1 -1
- package/dest/storage/capsule_store/capsule_store.js +36 -28
- package/dest/storage/capsule_store/index.d.ts +2 -1
- package/dest/storage/capsule_store/index.d.ts.map +1 -1
- package/dest/storage/capsule_store/index.js +1 -0
- package/dest/storage/contract_store/contract_store.d.ts +42 -15
- package/dest/storage/contract_store/contract_store.d.ts.map +1 -1
- package/dest/storage/contract_store/contract_store.js +143 -65
- package/dest/storage/metadata.d.ts +1 -1
- package/dest/storage/metadata.js +1 -1
- package/dest/storage/note_store/note_store.d.ts +3 -3
- package/dest/storage/note_store/note_store.d.ts.map +1 -1
- package/dest/storage/note_store/note_store.js +3 -4
- package/dest/storage/private_event_store/stored_private_event.js +1 -1
- package/dest/storage/tagging_store/recipient_tagging_store.d.ts +6 -6
- package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -1
- package/dest/storage/tagging_store/sender_tagging_store.d.ts +29 -28
- package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -1
- package/dest/storage/tagging_store/sender_tagging_store.js +141 -115
- package/dest/tagging/get_all_logs_by_tags.d.ts +1 -1
- package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -1
- package/dest/tagging/get_all_logs_by_tags.js +17 -3
- package/dest/tagging/index.d.ts +3 -3
- package/dest/tagging/index.d.ts.map +1 -1
- package/dest/tagging/index.js +1 -1
- package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +4 -5
- package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts.map +1 -1
- package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.js +7 -21
- package/dest/tagging/recipient_sync/utils/find_highest_indexes.js +2 -2
- package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +6 -7
- package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts.map +1 -1
- package/dest/tagging/recipient_sync/utils/load_logs_for_range.js +12 -11
- package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +4 -8
- package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -1
- package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +13 -7
- package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +4 -3
- package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts.map +1 -1
- package/dest/tagging/sender_sync/utils/get_status_change_of_pending.js +20 -10
- package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +5 -7
- package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts.map +1 -1
- package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.js +36 -24
- package/package.json +16 -16
- package/src/bin/check_oracle_version.ts +4 -4
- package/src/block_synchronizer/block_synchronizer.ts +6 -0
- package/src/config/index.ts +3 -9
- package/src/config/package_info.ts +1 -1
- package/src/contract_function_simulator/contract_function_simulator.ts +261 -67
- package/src/contract_function_simulator/ephemeral_array_service.ts +110 -0
- package/src/contract_function_simulator/execution_tagging_index_cache.ts +19 -14
- package/src/contract_function_simulator/index.ts +1 -0
- package/src/contract_function_simulator/noir-structs/event_validation_request.ts +9 -9
- package/src/contract_function_simulator/noir-structs/log_retrieval_request.ts +1 -1
- package/src/contract_function_simulator/noir-structs/log_retrieval_response.ts +2 -5
- package/src/contract_function_simulator/noir-structs/note_validation_request.ts +4 -10
- package/src/contract_function_simulator/oracle/interfaces.ts +82 -54
- package/src/contract_function_simulator/oracle/legacy_oracle_mappings.ts +104 -0
- package/src/contract_function_simulator/oracle/oracle.ts +363 -139
- package/src/contract_function_simulator/oracle/private_execution.ts +4 -4
- package/src/contract_function_simulator/oracle/private_execution_oracle.ts +58 -91
- package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +455 -143
- package/src/contract_function_simulator/pick_notes.ts +14 -3
- package/src/contract_function_simulator/proxied_contract_data_source.ts +8 -1
- package/src/contract_logging.ts +52 -0
- package/src/contract_sync/contract_sync_service.ts +102 -55
- package/src/contract_sync/helpers.ts +8 -3
- package/src/debug/pxe_debug_utils.ts +10 -8
- package/src/entrypoints/client/bundle/index.ts +2 -0
- package/src/entrypoints/client/bundle/utils.ts +2 -3
- package/src/entrypoints/client/lazy/index.ts +2 -0
- package/src/entrypoints/client/lazy/utils.ts +2 -3
- package/src/entrypoints/pxe_creation_options.ts +7 -0
- package/src/entrypoints/server/index.ts +2 -1
- package/src/entrypoints/server/utils.ts +2 -3
- package/src/events/event_service.ts +17 -4
- package/src/events/private_event_filter_validator.ts +21 -1
- package/src/logs/log_service.ts +63 -91
- package/src/messages/message_context_service.ts +44 -0
- package/src/notes/note_service.ts +19 -8
- package/src/notes_filter.ts +24 -0
- package/src/oracle_version.ts +20 -10
- package/src/private_kernel/hints/{compute_tx_include_by_timestamp.ts → compute_tx_expiration_timestamp.ts} +13 -13
- package/src/private_kernel/hints/index.ts +1 -1
- package/src/private_kernel/hints/private_kernel_reset_private_inputs_builder.ts +164 -117
- package/src/private_kernel/hints/test_utils.ts +325 -0
- package/src/private_kernel/private_kernel_execution_prover.ts +18 -16
- package/src/private_kernel/private_kernel_oracle.ts +7 -7
- package/src/pxe.ts +129 -72
- package/src/storage/anchor_block_store/anchor_block_store.ts +1 -1
- package/src/storage/capsule_store/capsule_service.ts +90 -0
- package/src/storage/capsule_store/capsule_store.ts +44 -26
- package/src/storage/capsule_store/index.ts +1 -0
- package/src/storage/contract_store/contract_store.ts +177 -76
- package/src/storage/metadata.ts +1 -1
- package/src/storage/note_store/note_store.ts +5 -5
- package/src/storage/private_event_store/stored_private_event.ts +1 -1
- package/src/storage/tagging_store/recipient_tagging_store.ts +9 -5
- package/src/storage/tagging_store/sender_tagging_store.ts +185 -138
- package/src/tagging/get_all_logs_by_tags.ts +28 -4
- package/src/tagging/index.ts +2 -2
- package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +9 -24
- package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +2 -2
- package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +10 -15
- package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +23 -10
- package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +26 -11
- package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +27 -26
- package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts +0 -4
- package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts.map +0 -1
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
2
2
|
import { type Logger, createLogger } from '@aztec/foundation/log';
|
|
3
3
|
import type { AztecAsyncKVStore, AztecAsyncMap } from '@aztec/kv-store';
|
|
4
|
-
import
|
|
4
|
+
import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
5
5
|
|
|
6
6
|
import type { StagedStore } from '../../job_coordinator/job_coordinator.js';
|
|
7
7
|
|
|
@@ -10,11 +10,12 @@ export class CapsuleStore implements StagedStore {
|
|
|
10
10
|
|
|
11
11
|
#store: AztecAsyncKVStore;
|
|
12
12
|
|
|
13
|
-
// Arbitrary data stored by contracts. Key is computed as `${contractAddress}:${key}
|
|
13
|
+
// Arbitrary data stored by contracts. Key is computed as `${contractAddress}:${scope}:${key}`, using the zero
|
|
14
|
+
// address for the global scope.
|
|
14
15
|
#capsules: AztecAsyncMap<string, Buffer>;
|
|
15
16
|
|
|
16
|
-
// jobId => `${contractAddress}:${key}` => capsule data
|
|
17
|
-
// when `#stagedCapsules.get('some-job-id').get('${some-contract-address
|
|
17
|
+
// jobId => `${contractAddress}:${scope}:${key}` => capsule data
|
|
18
|
+
// when `#stagedCapsules.get('some-job-id').get('${some-contract-address}:${some-scope}:${some-key}') === null`,
|
|
18
19
|
// it signals that the capsule was deleted during the job, so it needs to be deleted on commit
|
|
19
20
|
#stagedCapsules: Map<string, Map<string, Buffer | null>>;
|
|
20
21
|
|
|
@@ -134,8 +135,8 @@ export class CapsuleStore implements StagedStore {
|
|
|
134
135
|
* to public contract storage in that it's indexed by the contract address and storage slot but instead of the global
|
|
135
136
|
* network state it's backed by local PXE db.
|
|
136
137
|
*/
|
|
137
|
-
|
|
138
|
-
const dbSlotKey = dbSlotToKey(contractAddress, slot);
|
|
138
|
+
setCapsule(contractAddress: AztecAddress, slot: Fr, capsule: Fr[], jobId: string, scope: AztecAddress) {
|
|
139
|
+
const dbSlotKey = dbSlotToKey(contractAddress, slot, scope);
|
|
139
140
|
|
|
140
141
|
// A store overrides any pre-existing data on the slot
|
|
141
142
|
this.#setOnStage(jobId, dbSlotKey, Buffer.concat(capsule.map(value => value.toBuffer())));
|
|
@@ -147,8 +148,18 @@ export class CapsuleStore implements StagedStore {
|
|
|
147
148
|
* @param slot - The slot in the database to read.
|
|
148
149
|
* @returns The stored data or `null` if no data is stored under the slot.
|
|
149
150
|
*/
|
|
150
|
-
|
|
151
|
-
|
|
151
|
+
getCapsule(contractAddress: AztecAddress, slot: Fr, jobId: string, scope: AztecAddress): Promise<Fr[] | null> {
|
|
152
|
+
return this.#store.transactionAsync(() => this.#getCapsuleInternal(contractAddress, slot, jobId, scope));
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
/** Same as getCapsule but without its own transaction, for use inside an existing transactionAsync. */
|
|
156
|
+
async #getCapsuleInternal(
|
|
157
|
+
contractAddress: AztecAddress,
|
|
158
|
+
slot: Fr,
|
|
159
|
+
jobId: string,
|
|
160
|
+
scope: AztecAddress,
|
|
161
|
+
): Promise<Fr[] | null> {
|
|
162
|
+
const dataBuffer = await this.#getFromStage(jobId, dbSlotToKey(contractAddress, slot, scope));
|
|
152
163
|
if (!dataBuffer) {
|
|
153
164
|
this.logger.trace(`Data not found for contract ${contractAddress.toString()} and slot ${slot.toString()}`);
|
|
154
165
|
return null;
|
|
@@ -165,9 +176,9 @@ export class CapsuleStore implements StagedStore {
|
|
|
165
176
|
* @param contractAddress - The contract address under which the data is scoped.
|
|
166
177
|
* @param slot - The slot in the database to delete.
|
|
167
178
|
*/
|
|
168
|
-
deleteCapsule(contractAddress: AztecAddress, slot: Fr, jobId: string) {
|
|
179
|
+
deleteCapsule(contractAddress: AztecAddress, slot: Fr, jobId: string, scope: AztecAddress) {
|
|
169
180
|
// When we commit this, we will interpret null as a deletion, so we'll propagate the delete to the KV store
|
|
170
|
-
this.#deleteOnStage(jobId, dbSlotToKey(contractAddress, slot));
|
|
181
|
+
this.#deleteOnStage(jobId, dbSlotToKey(contractAddress, slot, scope));
|
|
171
182
|
}
|
|
172
183
|
|
|
173
184
|
/**
|
|
@@ -187,6 +198,7 @@ export class CapsuleStore implements StagedStore {
|
|
|
187
198
|
dstSlot: Fr,
|
|
188
199
|
numEntries: number,
|
|
189
200
|
jobId: string,
|
|
201
|
+
scope: AztecAddress,
|
|
190
202
|
): Promise<void> {
|
|
191
203
|
// This transactional context gives us "copy atomicity":
|
|
192
204
|
// there shouldn't be concurrent writes to what's being copied here.
|
|
@@ -203,8 +215,8 @@ export class CapsuleStore implements StagedStore {
|
|
|
203
215
|
}
|
|
204
216
|
|
|
205
217
|
for (const i of indexes) {
|
|
206
|
-
const currentSrcSlot = dbSlotToKey(contractAddress, srcSlot.add(new Fr(i)));
|
|
207
|
-
const currentDstSlot = dbSlotToKey(contractAddress, dstSlot.add(new Fr(i)));
|
|
218
|
+
const currentSrcSlot = dbSlotToKey(contractAddress, srcSlot.add(new Fr(i)), scope);
|
|
219
|
+
const currentDstSlot = dbSlotToKey(contractAddress, dstSlot.add(new Fr(i)), scope);
|
|
208
220
|
|
|
209
221
|
const toCopy = await this.#getFromStage(jobId, currentSrcSlot);
|
|
210
222
|
if (!toCopy) {
|
|
@@ -224,7 +236,13 @@ export class CapsuleStore implements StagedStore {
|
|
|
224
236
|
* @param baseSlot - The slot where the array length is stored
|
|
225
237
|
* @param content - Array of capsule data to append
|
|
226
238
|
*/
|
|
227
|
-
appendToCapsuleArray(
|
|
239
|
+
appendToCapsuleArray(
|
|
240
|
+
contractAddress: AztecAddress,
|
|
241
|
+
baseSlot: Fr,
|
|
242
|
+
content: Fr[][],
|
|
243
|
+
jobId: string,
|
|
244
|
+
scope: AztecAddress,
|
|
245
|
+
): Promise<void> {
|
|
228
246
|
// We wrap this in a transaction to serialize concurrent calls from Promise.all.
|
|
229
247
|
// Without this, concurrent appends to the same array could race: both read length=0,
|
|
230
248
|
// both write at the same slots, one overwrites the other.
|
|
@@ -232,22 +250,22 @@ export class CapsuleStore implements StagedStore {
|
|
|
232
250
|
// and not using a transaction here would heavily impact performance.
|
|
233
251
|
return this.#store.transactionAsync(async () => {
|
|
234
252
|
// Load current length, defaulting to 0 if not found
|
|
235
|
-
const lengthData = await this
|
|
253
|
+
const lengthData = await this.#getCapsuleInternal(contractAddress, baseSlot, jobId, scope);
|
|
236
254
|
const currentLength = lengthData ? lengthData[0].toNumber() : 0;
|
|
237
255
|
|
|
238
256
|
// Store each capsule at consecutive slots after baseSlot + 1 + currentLength
|
|
239
257
|
for (let i = 0; i < content.length; i++) {
|
|
240
258
|
const nextSlot = arraySlot(baseSlot, currentLength + i);
|
|
241
|
-
this.
|
|
259
|
+
this.setCapsule(contractAddress, nextSlot, content[i], jobId, scope);
|
|
242
260
|
}
|
|
243
261
|
|
|
244
262
|
// Update length to include all new capsules
|
|
245
263
|
const newLength = currentLength + content.length;
|
|
246
|
-
this.
|
|
264
|
+
this.setCapsule(contractAddress, baseSlot, [new Fr(newLength)], jobId, scope);
|
|
247
265
|
});
|
|
248
266
|
}
|
|
249
267
|
|
|
250
|
-
readCapsuleArray(contractAddress: AztecAddress, baseSlot: Fr, jobId: string): Promise<Fr[][]> {
|
|
268
|
+
readCapsuleArray(contractAddress: AztecAddress, baseSlot: Fr, jobId: string, scope: AztecAddress): Promise<Fr[][]> {
|
|
251
269
|
// I'm leaving this transactional context here though because I'm assuming this
|
|
252
270
|
// gives us "read array atomicity": there shouldn't be concurrent writes to what's being copied
|
|
253
271
|
// here.
|
|
@@ -255,14 +273,14 @@ export class CapsuleStore implements StagedStore {
|
|
|
255
273
|
// of jobs: different calls running concurrently on the same contract may cause trouble.
|
|
256
274
|
return this.#store.transactionAsync(async () => {
|
|
257
275
|
// Load length, defaulting to 0 if not found
|
|
258
|
-
const maybeLength = await this
|
|
276
|
+
const maybeLength = await this.#getCapsuleInternal(contractAddress, baseSlot, jobId, scope);
|
|
259
277
|
const length = maybeLength ? maybeLength[0].toBigInt() : 0n;
|
|
260
278
|
|
|
261
279
|
const values: Fr[][] = [];
|
|
262
280
|
|
|
263
281
|
// Read each capsule at consecutive slots after baseSlot
|
|
264
282
|
for (let i = 0; i < length; i++) {
|
|
265
|
-
const currentValue = await this
|
|
283
|
+
const currentValue = await this.#getCapsuleInternal(contractAddress, arraySlot(baseSlot, i), jobId, scope);
|
|
266
284
|
if (currentValue == undefined) {
|
|
267
285
|
throw new Error(
|
|
268
286
|
`Expected non-empty value at capsule array in base slot ${baseSlot} at index ${i} for contract ${contractAddress}`,
|
|
@@ -276,7 +294,7 @@ export class CapsuleStore implements StagedStore {
|
|
|
276
294
|
});
|
|
277
295
|
}
|
|
278
296
|
|
|
279
|
-
setCapsuleArray(contractAddress: AztecAddress, baseSlot: Fr, content: Fr[][], jobId: string) {
|
|
297
|
+
setCapsuleArray(contractAddress: AztecAddress, baseSlot: Fr, content: Fr[][], jobId: string, scope: AztecAddress) {
|
|
280
298
|
// This transactional context in theory isn't so critical now because we aren't
|
|
281
299
|
// writing to DB so if there's exceptions midway and it blows up, no visible impact
|
|
282
300
|
// to persistent storage will happen.
|
|
@@ -287,27 +305,27 @@ export class CapsuleStore implements StagedStore {
|
|
|
287
305
|
// of jobs: different calls running concurrently on the same contract may cause trouble.
|
|
288
306
|
return this.#store.transactionAsync(async () => {
|
|
289
307
|
// Load current length, defaulting to 0 if not found
|
|
290
|
-
const maybeLength = await this
|
|
308
|
+
const maybeLength = await this.#getCapsuleInternal(contractAddress, baseSlot, jobId, scope);
|
|
291
309
|
const originalLength = maybeLength ? maybeLength[0].toNumber() : 0;
|
|
292
310
|
|
|
293
311
|
// Set the new length
|
|
294
|
-
this.
|
|
312
|
+
this.setCapsule(contractAddress, baseSlot, [new Fr(content.length)], jobId, scope);
|
|
295
313
|
|
|
296
314
|
// Store the new content, possibly overwriting existing values
|
|
297
315
|
for (let i = 0; i < content.length; i++) {
|
|
298
|
-
this.
|
|
316
|
+
this.setCapsule(contractAddress, arraySlot(baseSlot, i), content[i], jobId, scope);
|
|
299
317
|
}
|
|
300
318
|
|
|
301
319
|
// Clear any stragglers
|
|
302
320
|
for (let i = content.length; i < originalLength; i++) {
|
|
303
|
-
this.deleteCapsule(contractAddress, arraySlot(baseSlot, i), jobId);
|
|
321
|
+
this.deleteCapsule(contractAddress, arraySlot(baseSlot, i), jobId, scope);
|
|
304
322
|
}
|
|
305
323
|
});
|
|
306
324
|
}
|
|
307
325
|
}
|
|
308
326
|
|
|
309
|
-
function dbSlotToKey(contractAddress: AztecAddress, slot: Fr): string {
|
|
310
|
-
return
|
|
327
|
+
function dbSlotToKey(contractAddress: AztecAddress, slot: Fr, scope: AztecAddress): string {
|
|
328
|
+
return [contractAddress.toString(), scope.toString(), slot.toString()].join(':');
|
|
311
329
|
}
|
|
312
330
|
|
|
313
331
|
function arraySlot(baseSlot: Fr, index: number) {
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import type { FUNCTION_TREE_HEIGHT } from '@aztec/constants';
|
|
2
|
-
import
|
|
2
|
+
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
3
3
|
import { toArray } from '@aztec/foundation/iterable';
|
|
4
|
+
import { BufferReader, numToUInt8, serializeToBuffer } from '@aztec/foundation/serialize';
|
|
4
5
|
import type { MembershipWitness } from '@aztec/foundation/trees';
|
|
5
6
|
import type { AztecAsyncKVStore, AztecAsyncMap } from '@aztec/kv-store';
|
|
6
7
|
import {
|
|
@@ -19,7 +20,8 @@ import {
|
|
|
19
20
|
} from '@aztec/stdlib/abi';
|
|
20
21
|
import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
21
22
|
import {
|
|
22
|
-
type
|
|
23
|
+
type ContractClassIdPreimage,
|
|
24
|
+
type ContractClassWithId,
|
|
23
25
|
type ContractInstanceWithAddress,
|
|
24
26
|
SerializableContractInstance,
|
|
25
27
|
getContractClassFromArtifact,
|
|
@@ -27,6 +29,68 @@ import {
|
|
|
27
29
|
|
|
28
30
|
import { PrivateFunctionsTree } from './private_functions_tree.js';
|
|
29
31
|
|
|
32
|
+
const VERSION = 1 as const;
|
|
33
|
+
|
|
34
|
+
/**
|
|
35
|
+
* All contract class data except the large packedBytecode.
|
|
36
|
+
* The expensive data from the ContractClass is precomputed and stored in this format to avoid redundant hashing.
|
|
37
|
+
* Since we have to store the artifacts anyway, the final ContractClass is reconstructed by combining this data
|
|
38
|
+
* with the packedBytecode obtained from the former. That way we can have quick class lookups without wasted storage.
|
|
39
|
+
*/
|
|
40
|
+
export class SerializableContractClassData {
|
|
41
|
+
public readonly version = VERSION;
|
|
42
|
+
public readonly id: Fr;
|
|
43
|
+
public readonly artifactHash: Fr;
|
|
44
|
+
public readonly privateFunctionsRoot: Fr;
|
|
45
|
+
public readonly publicBytecodeCommitment: Fr;
|
|
46
|
+
public readonly privateFunctions: { selector: FunctionSelector; vkHash: Fr }[];
|
|
47
|
+
|
|
48
|
+
constructor(
|
|
49
|
+
data: ContractClassIdPreimage & {
|
|
50
|
+
id: Fr;
|
|
51
|
+
privateFunctions: { selector: FunctionSelector; vkHash: Fr }[];
|
|
52
|
+
},
|
|
53
|
+
) {
|
|
54
|
+
this.id = data.id;
|
|
55
|
+
this.artifactHash = data.artifactHash;
|
|
56
|
+
this.privateFunctionsRoot = data.privateFunctionsRoot;
|
|
57
|
+
this.publicBytecodeCommitment = data.publicBytecodeCommitment;
|
|
58
|
+
this.privateFunctions = data.privateFunctions;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
toBuffer(): Buffer {
|
|
62
|
+
return serializeToBuffer(
|
|
63
|
+
numToUInt8(this.version),
|
|
64
|
+
this.id,
|
|
65
|
+
this.artifactHash,
|
|
66
|
+
this.privateFunctionsRoot,
|
|
67
|
+
this.publicBytecodeCommitment,
|
|
68
|
+
this.privateFunctions.length,
|
|
69
|
+
...this.privateFunctions.map(fn => serializeToBuffer(fn.selector, fn.vkHash)),
|
|
70
|
+
);
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
static fromBuffer(bufferOrReader: Buffer | BufferReader): SerializableContractClassData {
|
|
74
|
+
const reader = BufferReader.asReader(bufferOrReader);
|
|
75
|
+
const version = reader.readUInt8();
|
|
76
|
+
if (version !== VERSION) {
|
|
77
|
+
throw new Error(`Unexpected contract class data version ${version}`);
|
|
78
|
+
}
|
|
79
|
+
return new SerializableContractClassData({
|
|
80
|
+
id: reader.readObject(Fr),
|
|
81
|
+
artifactHash: reader.readObject(Fr),
|
|
82
|
+
privateFunctionsRoot: reader.readObject(Fr),
|
|
83
|
+
publicBytecodeCommitment: reader.readObject(Fr),
|
|
84
|
+
privateFunctions: reader.readVector({
|
|
85
|
+
fromBuffer: (r: BufferReader) => ({
|
|
86
|
+
selector: r.readObject(FunctionSelector),
|
|
87
|
+
vkHash: r.readObject(Fr),
|
|
88
|
+
}),
|
|
89
|
+
}),
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
|
|
30
94
|
/**
|
|
31
95
|
* ContractStore serves as a data manager and retriever for Aztec.nr contracts.
|
|
32
96
|
* It provides methods to obtain contract addresses, function ABI, bytecode, and membership witnesses
|
|
@@ -39,76 +103,95 @@ export class ContractStore {
|
|
|
39
103
|
// TODO: Update it to be LRU cache so that it doesn't keep all the data all the time.
|
|
40
104
|
#privateFunctionTrees: Map<string, PrivateFunctionsTree> = new Map();
|
|
41
105
|
|
|
42
|
-
/**
|
|
106
|
+
/**
|
|
107
|
+
* In-memory cache of deserialized ContractArtifact objects, keyed by class id string.
|
|
108
|
+
* Avoids repeated LMDB reads + JSON.parse + Zod validation on every oracle call.
|
|
109
|
+
* Artifacts are large but immutable after registration — safe to cache for the lifetime of the store.
|
|
110
|
+
*/
|
|
111
|
+
// TODO: Update it to be LRU cache so that it doesn't keep all the data all the time.
|
|
112
|
+
#contractArtifactCache: Map<string, ContractArtifact> = new Map();
|
|
113
|
+
|
|
114
|
+
/** Map from contract address to contract class id (avoids KV round-trip on hot path). */
|
|
43
115
|
#contractClassIdMap: Map<string, Fr> = new Map();
|
|
44
116
|
|
|
45
117
|
#store: AztecAsyncKVStore;
|
|
46
118
|
#contractArtifacts: AztecAsyncMap<string, Buffer>;
|
|
119
|
+
#contractClassData: AztecAsyncMap<string, Buffer>;
|
|
47
120
|
#contractInstances: AztecAsyncMap<string, Buffer>;
|
|
48
121
|
|
|
49
122
|
constructor(store: AztecAsyncKVStore) {
|
|
50
123
|
this.#store = store;
|
|
51
124
|
this.#contractArtifacts = store.openMap('contract_artifacts');
|
|
125
|
+
this.#contractClassData = store.openMap('contract_classes');
|
|
52
126
|
this.#contractInstances = store.openMap('contracts_instances');
|
|
53
127
|
}
|
|
54
128
|
|
|
55
129
|
// Setters
|
|
56
130
|
|
|
57
|
-
|
|
58
|
-
|
|
131
|
+
/**
|
|
132
|
+
* Registers a new contract artifact and its corresponding class data.
|
|
133
|
+
* IMPORTANT: This method does not verify that the provided artifact matches the class data or that the class id matches the artifact.
|
|
134
|
+
* It is the caller's responsibility to ensure the consistency and correctness of the provided data.
|
|
135
|
+
* This is done to avoid redundant, expensive contract class computations
|
|
136
|
+
*/
|
|
137
|
+
public async addContractArtifact(
|
|
138
|
+
contract: ContractArtifact,
|
|
139
|
+
contractClassWithIdAndPreimage?: ContractClassWithId & ContractClassIdPreimage,
|
|
140
|
+
): Promise<Fr> {
|
|
141
|
+
const contractClass = contractClassWithIdAndPreimage ?? (await getContractClassFromArtifact(contract));
|
|
142
|
+
const key = contractClass.id.toString();
|
|
143
|
+
|
|
144
|
+
if (this.#contractArtifactCache.has(key)) {
|
|
145
|
+
return contractClass.id;
|
|
146
|
+
}
|
|
147
|
+
|
|
59
148
|
const privateFunctions = contract.functions.filter(
|
|
60
149
|
functionArtifact => functionArtifact.functionType === FunctionType.PRIVATE,
|
|
61
150
|
);
|
|
62
|
-
|
|
63
151
|
const privateSelectors = await Promise.all(
|
|
64
|
-
privateFunctions.map(async
|
|
65
|
-
(
|
|
66
|
-
await FunctionSelector.fromNameAndParameters(privateFunctionArtifact.name, privateFunctionArtifact.parameters)
|
|
67
|
-
).toString(),
|
|
152
|
+
privateFunctions.map(async fn =>
|
|
153
|
+
(await FunctionSelector.fromNameAndParameters(fn.name, fn.parameters)).toString(),
|
|
68
154
|
),
|
|
69
155
|
);
|
|
70
|
-
|
|
71
156
|
if (privateSelectors.length !== new Set(privateSelectors).size) {
|
|
72
157
|
throw new Error('Repeated function selectors of private functions');
|
|
73
158
|
}
|
|
74
159
|
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
)
|
|
160
|
+
this.#contractArtifactCache.set(key, contract);
|
|
161
|
+
|
|
162
|
+
await this.#store.transactionAsync(async () => {
|
|
163
|
+
await this.#contractArtifacts.set(key, contractArtifactToBuffer(contract));
|
|
164
|
+
await this.#contractClassData.set(key, new SerializableContractClassData(contractClass).toBuffer());
|
|
165
|
+
});
|
|
166
|
+
|
|
167
|
+
return contractClass.id;
|
|
78
168
|
}
|
|
79
169
|
|
|
80
170
|
async addContractInstance(contract: ContractInstanceWithAddress): Promise<void> {
|
|
81
|
-
this.#
|
|
171
|
+
await this.#store.transactionAsync(async () => {
|
|
172
|
+
await this.#contractInstances.set(
|
|
173
|
+
contract.address.toString(),
|
|
174
|
+
new SerializableContractInstance(contract).toBuffer(),
|
|
175
|
+
);
|
|
176
|
+
});
|
|
82
177
|
|
|
83
|
-
|
|
84
|
-
contract.address.toString(),
|
|
85
|
-
new SerializableContractInstance(contract).toBuffer(),
|
|
86
|
-
);
|
|
178
|
+
this.#contractClassIdMap.set(contract.address.toString(), contract.currentContractClassId);
|
|
87
179
|
}
|
|
88
180
|
|
|
89
181
|
// Private getters
|
|
90
182
|
|
|
91
183
|
async #getContractClassId(contractAddress: AztecAddress): Promise<Fr | undefined> {
|
|
92
|
-
|
|
184
|
+
const key = contractAddress.toString();
|
|
185
|
+
if (!this.#contractClassIdMap.has(key)) {
|
|
93
186
|
const instance = await this.getContractInstance(contractAddress);
|
|
94
187
|
if (!instance) {
|
|
95
188
|
return;
|
|
96
189
|
}
|
|
97
|
-
this.#contractClassIdMap.set(
|
|
190
|
+
this.#contractClassIdMap.set(key, instance.currentContractClassId);
|
|
98
191
|
}
|
|
99
|
-
return this.#contractClassIdMap.get(
|
|
192
|
+
return this.#contractClassIdMap.get(key);
|
|
100
193
|
}
|
|
101
194
|
|
|
102
|
-
/**
|
|
103
|
-
* Retrieve or create a ContractTree instance based on the provided class id.
|
|
104
|
-
* If an existing tree with the same class id is found in the cache, it will be returned.
|
|
105
|
-
* Otherwise, a new ContractTree instance will be created using the contract data from the database
|
|
106
|
-
* and added to the cache before returning.
|
|
107
|
-
*
|
|
108
|
-
* @param classId - The class id of the contract for which the ContractTree is required.
|
|
109
|
-
* @returns A ContractTree instance associated with the specified contract address.
|
|
110
|
-
* @throws An Error if the contract is not found in the ContractDatabase.
|
|
111
|
-
*/
|
|
112
195
|
async #getPrivateFunctionTreeForClassId(classId: Fr): Promise<PrivateFunctionsTree | undefined> {
|
|
113
196
|
if (!this.#privateFunctionTrees.has(classId.toString())) {
|
|
114
197
|
const artifact = await this.getContractArtifact(classId);
|
|
@@ -121,9 +204,9 @@ export class ContractStore {
|
|
|
121
204
|
return this.#privateFunctionTrees.get(classId.toString())!;
|
|
122
205
|
}
|
|
123
206
|
|
|
124
|
-
async #
|
|
125
|
-
const
|
|
126
|
-
return
|
|
207
|
+
async #getArtifactByAddress(contractAddress: AztecAddress): Promise<ContractArtifact | undefined> {
|
|
208
|
+
const classId = await this.#getContractClassId(contractAddress);
|
|
209
|
+
return classId && this.getContractArtifact(classId);
|
|
127
210
|
}
|
|
128
211
|
|
|
129
212
|
// Public getters
|
|
@@ -135,7 +218,7 @@ export class ContractStore {
|
|
|
135
218
|
});
|
|
136
219
|
}
|
|
137
220
|
|
|
138
|
-
/** Returns a contract instance for a given address.
|
|
221
|
+
/** Returns a contract instance for a given address. */
|
|
139
222
|
public getContractInstance(contractAddress: AztecAddress): Promise<ContractInstanceWithAddress | undefined> {
|
|
140
223
|
return this.#store.transactionAsync(async () => {
|
|
141
224
|
const contract = await this.#contractInstances.getAsync(contractAddress.toString());
|
|
@@ -143,18 +226,39 @@ export class ContractStore {
|
|
|
143
226
|
});
|
|
144
227
|
}
|
|
145
228
|
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
229
|
+
/** Returns the raw contract artifact for a given class id. */
|
|
230
|
+
public async getContractArtifact(contractClassId: Fr): Promise<ContractArtifact | undefined> {
|
|
231
|
+
const key = contractClassId.toString();
|
|
232
|
+
const cached = this.#contractArtifactCache.get(key);
|
|
233
|
+
if (cached) {
|
|
234
|
+
return cached;
|
|
235
|
+
}
|
|
236
|
+
const artifact = await this.#store.transactionAsync(async () => {
|
|
237
|
+
const buf = await this.#contractArtifacts.getAsync(key);
|
|
238
|
+
return buf && contractArtifactFromBuffer(buf);
|
|
151
239
|
});
|
|
240
|
+
if (artifact) {
|
|
241
|
+
this.#contractArtifactCache.set(key, artifact);
|
|
242
|
+
}
|
|
243
|
+
return artifact;
|
|
152
244
|
}
|
|
153
245
|
|
|
154
|
-
/** Returns a contract class for a given class id.
|
|
155
|
-
public async
|
|
246
|
+
/** Returns a contract class for a given class id. */
|
|
247
|
+
public async getContractClassWithPreimage(
|
|
248
|
+
contractClassId: Fr,
|
|
249
|
+
): Promise<(ContractClassWithId & ContractClassIdPreimage) | undefined> {
|
|
250
|
+
const key = contractClassId.toString();
|
|
251
|
+
const buf = await this.#store.transactionAsync(() => this.#contractClassData.getAsync(key));
|
|
252
|
+
if (!buf) {
|
|
253
|
+
return undefined;
|
|
254
|
+
}
|
|
255
|
+
const classData = SerializableContractClassData.fromBuffer(buf);
|
|
156
256
|
const artifact = await this.getContractArtifact(contractClassId);
|
|
157
|
-
|
|
257
|
+
if (!artifact) {
|
|
258
|
+
return undefined;
|
|
259
|
+
}
|
|
260
|
+
const packedBytecode = artifact.functions.find(f => f.name === 'public_dispatch')?.bytecode ?? Buffer.alloc(0);
|
|
261
|
+
return { ...classData, packedBytecode };
|
|
158
262
|
}
|
|
159
263
|
|
|
160
264
|
public async getContract(
|
|
@@ -173,8 +277,6 @@ export class ContractStore {
|
|
|
173
277
|
|
|
174
278
|
/**
|
|
175
279
|
* Retrieves the artifact of a specified function within a given contract.
|
|
176
|
-
* The function is identified by its selector, which is a unique code generated from the function's signature.
|
|
177
|
-
* Throws an error if the contract address or function selector are invalid or not found.
|
|
178
280
|
*
|
|
179
281
|
* @param contractAddress - The AztecAddress representing the contract containing the function.
|
|
180
282
|
* @param selector - The function selector.
|
|
@@ -184,9 +286,12 @@ export class ContractStore {
|
|
|
184
286
|
contractAddress: AztecAddress,
|
|
185
287
|
selector: FunctionSelector,
|
|
186
288
|
): Promise<FunctionArtifactWithContractName | undefined> {
|
|
187
|
-
const artifact = await this.#
|
|
188
|
-
|
|
189
|
-
|
|
289
|
+
const artifact = await this.#getArtifactByAddress(contractAddress);
|
|
290
|
+
if (!artifact) {
|
|
291
|
+
return undefined;
|
|
292
|
+
}
|
|
293
|
+
const fn = await this.#findFunctionArtifactBySelector(artifact, selector);
|
|
294
|
+
return fn && { ...fn, contractName: artifact.name };
|
|
190
295
|
}
|
|
191
296
|
|
|
192
297
|
public async getFunctionArtifactWithDebugMetadata(
|
|
@@ -207,50 +312,48 @@ export class ContractStore {
|
|
|
207
312
|
public async getPublicFunctionArtifact(
|
|
208
313
|
contractAddress: AztecAddress,
|
|
209
314
|
): Promise<FunctionArtifactWithContractName | undefined> {
|
|
210
|
-
const artifact = await this.#
|
|
211
|
-
const
|
|
212
|
-
return
|
|
315
|
+
const artifact = await this.#getArtifactByAddress(contractAddress);
|
|
316
|
+
const fn = artifact && artifact.functions.find(f => f.functionType === FunctionType.PUBLIC);
|
|
317
|
+
return fn && { ...fn, contractName: artifact.name };
|
|
213
318
|
}
|
|
214
319
|
|
|
215
320
|
public async getFunctionAbi(
|
|
216
321
|
contractAddress: AztecAddress,
|
|
217
322
|
selector: FunctionSelector,
|
|
218
323
|
): Promise<FunctionAbi | undefined> {
|
|
219
|
-
const artifact = await this.#
|
|
324
|
+
const artifact = await this.#getArtifactByAddress(contractAddress);
|
|
220
325
|
return artifact && (await this.#findFunctionAbiBySelector(artifact, selector));
|
|
221
326
|
}
|
|
222
327
|
|
|
223
328
|
/**
|
|
224
329
|
* Retrieves the debug metadata of a specified function within a given contract.
|
|
225
|
-
* The function is identified by its selector, which is a unique code generated from the function's signature.
|
|
226
|
-
* Returns undefined if the debug metadata for the given function is not found.
|
|
227
|
-
* Throws if the contract has not been added to the database.
|
|
228
330
|
*
|
|
229
331
|
* @param contractAddress - The AztecAddress representing the contract containing the function.
|
|
230
332
|
* @param selector - The function selector.
|
|
231
|
-
* @returns The corresponding function's
|
|
333
|
+
* @returns The corresponding function's debug metadata, or undefined.
|
|
232
334
|
*/
|
|
233
335
|
public async getFunctionDebugMetadata(
|
|
234
336
|
contractAddress: AztecAddress,
|
|
235
337
|
selector: FunctionSelector,
|
|
236
338
|
): Promise<FunctionDebugMetadata | undefined> {
|
|
237
|
-
const artifact = await this.#
|
|
238
|
-
|
|
239
|
-
|
|
339
|
+
const artifact = await this.#getArtifactByAddress(contractAddress);
|
|
340
|
+
if (!artifact) {
|
|
341
|
+
return undefined;
|
|
342
|
+
}
|
|
343
|
+
const fn = await this.#findFunctionArtifactBySelector(artifact, selector);
|
|
344
|
+
return fn && getFunctionDebugMetadata(artifact, fn);
|
|
240
345
|
}
|
|
241
346
|
|
|
242
347
|
public async getPublicFunctionDebugMetadata(
|
|
243
348
|
contractAddress: AztecAddress,
|
|
244
349
|
): Promise<FunctionDebugMetadata | undefined> {
|
|
245
|
-
const artifact = await this.#
|
|
246
|
-
const
|
|
247
|
-
return
|
|
350
|
+
const artifact = await this.#getArtifactByAddress(contractAddress);
|
|
351
|
+
const fn = artifact && artifact.functions.find(f => f.functionType === FunctionType.PUBLIC);
|
|
352
|
+
return fn && getFunctionDebugMetadata(artifact, fn);
|
|
248
353
|
}
|
|
249
354
|
|
|
250
355
|
/**
|
|
251
356
|
* Retrieve the function membership witness for the given contract class and function selector.
|
|
252
|
-
* The function membership witness represents a proof that the function belongs to the specified contract.
|
|
253
|
-
* Throws an error if the contract address or function selector is unknown.
|
|
254
357
|
*
|
|
255
358
|
* @param contractClassId - The id of the class.
|
|
256
359
|
* @param selector - The function selector.
|
|
@@ -265,23 +368,21 @@ export class ContractStore {
|
|
|
265
368
|
}
|
|
266
369
|
|
|
267
370
|
public async getDebugContractName(contractAddress: AztecAddress) {
|
|
268
|
-
const artifact = await this.#
|
|
371
|
+
const artifact = await this.#getArtifactByAddress(contractAddress);
|
|
269
372
|
return artifact?.name;
|
|
270
373
|
}
|
|
271
374
|
|
|
272
375
|
public async getDebugFunctionName(contractAddress: AztecAddress, selector: FunctionSelector) {
|
|
273
|
-
const artifact = await this.#
|
|
274
|
-
const
|
|
275
|
-
return `${artifact?.name ?? contractAddress}:${
|
|
376
|
+
const artifact = await this.#getArtifactByAddress(contractAddress);
|
|
377
|
+
const fn = artifact && (await this.#findFunctionAbiBySelector(artifact, selector));
|
|
378
|
+
return `${artifact?.name ?? contractAddress}:${fn?.name ?? selector}`;
|
|
276
379
|
}
|
|
277
380
|
|
|
278
381
|
async #findFunctionArtifactBySelector(
|
|
279
382
|
artifact: ContractArtifact,
|
|
280
383
|
selector: FunctionSelector,
|
|
281
384
|
): Promise<FunctionArtifact | undefined> {
|
|
282
|
-
const
|
|
283
|
-
for (let i = 0; i < functions.length; i++) {
|
|
284
|
-
const fn = functions[i];
|
|
385
|
+
for (const fn of artifact.functions) {
|
|
285
386
|
const fnSelector = await FunctionSelector.fromNameAndParameters(fn.name, fn.parameters);
|
|
286
387
|
if (fnSelector.equals(selector)) {
|
|
287
388
|
return fn;
|
|
@@ -293,9 +394,7 @@ export class ContractStore {
|
|
|
293
394
|
artifact: ContractArtifact,
|
|
294
395
|
selector: FunctionSelector,
|
|
295
396
|
): Promise<FunctionAbi | undefined> {
|
|
296
|
-
const
|
|
297
|
-
for (let i = 0; i < functions.length; i++) {
|
|
298
|
-
const fn = functions[i];
|
|
397
|
+
for (const fn of [...artifact.functions, ...(artifact.nonDispatchPublicFunctions ?? [])]) {
|
|
299
398
|
const fnSelector = await FunctionSelector.fromNameAndParameters(fn.name, fn.parameters);
|
|
300
399
|
if (fnSelector.equals(selector)) {
|
|
301
400
|
return fn;
|
|
@@ -316,10 +415,12 @@ export class ContractStore {
|
|
|
316
415
|
throw new Error(`Unknown function ${functionName} in contract ${contract.name}.`);
|
|
317
416
|
}
|
|
318
417
|
|
|
418
|
+
const selector = await FunctionSelector.fromNameAndParameters(functionDao.name, functionDao.parameters);
|
|
419
|
+
|
|
319
420
|
return FunctionCall.from({
|
|
320
421
|
name: functionDao.name,
|
|
321
422
|
to,
|
|
322
|
-
selector
|
|
423
|
+
selector,
|
|
323
424
|
type: functionDao.functionType,
|
|
324
425
|
hideMsgSender: false,
|
|
325
426
|
isStatic: functionDao.isStatic,
|
package/src/storage/metadata.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export const PXE_DATA_SCHEMA_VERSION =
|
|
1
|
+
export const PXE_DATA_SCHEMA_VERSION = 5;
|
|
@@ -3,9 +3,10 @@ import type { Fr } from '@aztec/foundation/schemas';
|
|
|
3
3
|
import type { AztecAsyncKVStore, AztecAsyncMap, AztecAsyncMultiMap } from '@aztec/kv-store';
|
|
4
4
|
import type { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
5
5
|
import type { DataInBlock } from '@aztec/stdlib/block';
|
|
6
|
-
import { NoteDao, NoteStatus
|
|
6
|
+
import { NoteDao, NoteStatus } from '@aztec/stdlib/note';
|
|
7
7
|
|
|
8
8
|
import type { StagedStore } from '../../job_coordinator/job_coordinator.js';
|
|
9
|
+
import type { NotesFilter } from '../../notes_filter.js';
|
|
9
10
|
import { StoredNote } from './stored_note.js';
|
|
10
11
|
|
|
11
12
|
/**
|
|
@@ -103,11 +104,10 @@ export class NoteStore implements StagedStore {
|
|
|
103
104
|
* @params jobId - the job context to read from.
|
|
104
105
|
* @returns Filtered and deduplicated notes (a note might be present in multiple scopes - we ensure it is only
|
|
105
106
|
* returned once if this is the case)
|
|
106
|
-
* @throws If filtering by an empty scopes array. Scopes have to be set to undefined or to a non-empty array.
|
|
107
107
|
*/
|
|
108
108
|
getNotes(filter: NotesFilter, jobId: string): Promise<NoteDao[]> {
|
|
109
|
-
if (filter.scopes
|
|
110
|
-
return Promise.
|
|
109
|
+
if (filter.scopes.length === 0) {
|
|
110
|
+
return Promise.resolve([]);
|
|
111
111
|
}
|
|
112
112
|
|
|
113
113
|
return this.#store.transactionAsync(async () => {
|
|
@@ -180,7 +180,7 @@ export class NoteStore implements StagedStore {
|
|
|
180
180
|
continue;
|
|
181
181
|
}
|
|
182
182
|
|
|
183
|
-
if (
|
|
183
|
+
if (note.scopes.intersection(new Set(filter.scopes.map(s => s.toString()))).size === 0) {
|
|
184
184
|
continue;
|
|
185
185
|
}
|
|
186
186
|
|