@aztec/pxe 0.0.1-commit.d1f2d6c → 0.0.1-commit.d20b825a7
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 +5 -5
- package/dest/block_synchronizer/block_synchronizer.d.ts +10 -4
- package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -1
- package/dest/block_synchronizer/block_synchronizer.js +30 -6
- 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 +63 -31
- package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
- package/dest/contract_function_simulator/contract_function_simulator.js +206 -77
- 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 +5 -7
- 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 +9 -11
- 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 +5 -8
- 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 +7 -12
- package/dest/contract_function_simulator/oracle/interfaces.d.ts +62 -46
- 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 +310 -113
- package/dest/contract_function_simulator/oracle/private_execution.d.ts +3 -22
- package/dest/contract_function_simulator/oracle/private_execution.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/private_execution.js +5 -49
- package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +60 -84
- package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/private_execution_oracle.js +125 -98
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +128 -70
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +330 -143
- 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 +20 -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 +44 -0
- package/dest/contract_sync/contract_sync_service.d.ts.map +1 -0
- package/dest/contract_sync/contract_sync_service.js +116 -0
- package/dest/contract_sync/helpers.d.ts +28 -0
- package/dest/contract_sync/helpers.d.ts.map +1 -0
- package/dest/contract_sync/helpers.js +60 -0
- package/dest/debug/pxe_debug_utils.d.ts +24 -10
- package/dest/debug/pxe_debug_utils.d.ts.map +1 -1
- package/dest/debug/pxe_debug_utils.js +28 -18
- 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 +23 -9
- 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 +3 -3
- package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
- package/dest/entrypoints/client/lazy/utils.js +24 -10
- package/dest/entrypoints/pxe_creation_options.d.ts +5 -2
- 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 +4 -2
- package/dest/entrypoints/server/index.d.ts.map +1 -1
- package/dest/entrypoints/server/index.js +3 -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 +30 -11
- package/dest/events/event_service.d.ts +6 -6
- package/dest/events/event_service.d.ts.map +1 -1
- package/dest/events/event_service.js +31 -11
- 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/job_coordinator/job_coordinator.d.ts +3 -2
- package/dest/job_coordinator/job_coordinator.d.ts.map +1 -1
- package/dest/job_coordinator/job_coordinator.js +3 -2
- package/dest/logs/log_service.d.ts +10 -9
- package/dest/logs/log_service.d.ts.map +1 -1
- package/dest/logs/log_service.js +41 -62
- 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 +7 -8
- package/dest/notes/note_service.d.ts.map +1 -1
- package/dest/notes/note_service.js +23 -15
- 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 +3 -2
- package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
- package/dest/private_kernel/private_kernel_execution_prover.js +20 -15
- package/dest/private_kernel/private_kernel_oracle.d.ts +10 -6
- package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
- package/dest/private_kernel/private_kernel_oracle.js +19 -18
- package/dest/pxe.d.ts +85 -24
- package/dest/pxe.d.ts.map +1 -1
- package/dest/pxe.js +169 -87
- package/dest/storage/address_store/address_store.d.ts +1 -1
- package/dest/storage/address_store/address_store.d.ts.map +1 -1
- package/dest/storage/address_store/address_store.js +12 -11
- package/dest/storage/anchor_block_store/anchor_block_store.d.ts +9 -1
- package/dest/storage/anchor_block_store/anchor_block_store.d.ts.map +1 -1
- package/dest/storage/anchor_block_store/anchor_block_store.js +9 -2
- 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 +42 -36
- 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 -16
- package/dest/storage/contract_store/contract_store.d.ts.map +1 -1
- package/dest/storage/contract_store/contract_store.js +160 -85
- package/dest/storage/metadata.d.ts +1 -1
- package/dest/storage/metadata.js +1 -1
- package/dest/storage/note_store/note_store.d.ts +14 -4
- package/dest/storage/note_store/note_store.d.ts.map +1 -1
- package/dest/storage/note_store/note_store.js +149 -109
- package/dest/storage/private_event_store/private_event_store.d.ts +1 -1
- package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -1
- package/dest/storage/private_event_store/private_event_store.js +87 -61
- package/dest/storage/private_event_store/stored_private_event.d.ts +4 -4
- package/dest/storage/private_event_store/stored_private_event.d.ts.map +1 -1
- package/dest/storage/private_event_store/stored_private_event.js +2 -2
- 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/recipient_tagging_store.js +31 -19
- package/dest/storage/tagging_store/sender_address_book_store.d.ts +1 -1
- package/dest/storage/tagging_store/sender_address_book_store.d.ts.map +1 -1
- package/dest/storage/tagging_store/sender_address_book_store.js +20 -14
- 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 +233 -137
- package/dest/tagging/get_all_logs_by_tags.d.ts +4 -4
- 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 +5 -6
- 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 +8 -22
- package/dest/tagging/recipient_sync/utils/find_highest_indexes.js +2 -2
- package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +7 -8
- 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 +5 -9
- 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 +6 -8
- 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 +25 -16
- package/src/bin/check_oracle_version.ts +5 -4
- package/src/block_synchronizer/block_synchronizer.ts +45 -21
- package/src/config/index.ts +3 -9
- package/src/config/package_info.ts +1 -1
- package/src/contract_function_simulator/contract_function_simulator.ts +366 -136
- 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 +10 -10
- 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 +5 -11
- package/src/contract_function_simulator/oracle/interfaces.ts +90 -62
- package/src/contract_function_simulator/oracle/legacy_oracle_mappings.ts +104 -0
- package/src/contract_function_simulator/oracle/oracle.ts +391 -150
- package/src/contract_function_simulator/oracle/private_execution.ts +5 -83
- package/src/contract_function_simulator/oracle/private_execution_oracle.ts +160 -193
- package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +552 -179
- package/src/contract_function_simulator/pick_notes.ts +22 -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 +176 -0
- package/src/contract_sync/helpers.ts +98 -0
- package/src/debug/pxe_debug_utils.ts +63 -19
- package/src/entrypoints/client/bundle/index.ts +2 -0
- package/src/entrypoints/client/bundle/utils.ts +18 -18
- package/src/entrypoints/client/lazy/index.ts +2 -0
- package/src/entrypoints/client/lazy/utils.ts +19 -18
- package/src/entrypoints/pxe_creation_options.ts +9 -1
- package/src/entrypoints/server/index.ts +3 -1
- package/src/entrypoints/server/utils.ts +24 -29
- package/src/events/event_service.ts +35 -12
- package/src/events/private_event_filter_validator.ts +21 -1
- package/src/job_coordinator/job_coordinator.ts +4 -3
- package/src/logs/log_service.ts +77 -106
- package/src/messages/message_context_service.ts +44 -0
- package/src/notes/note_service.ts +25 -17
- 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 +24 -19
- package/src/private_kernel/private_kernel_oracle.ts +21 -21
- package/src/pxe.ts +318 -144
- package/src/storage/address_store/address_store.ts +15 -15
- package/src/storage/anchor_block_store/anchor_block_store.ts +9 -1
- package/src/storage/capsule_store/capsule_service.ts +90 -0
- package/src/storage/capsule_store/capsule_store.ts +52 -34
- package/src/storage/capsule_store/index.ts +1 -0
- package/src/storage/contract_store/contract_store.ts +193 -101
- package/src/storage/metadata.ts +1 -1
- package/src/storage/note_store/note_store.ts +168 -134
- package/src/storage/private_event_store/private_event_store.ts +106 -81
- package/src/storage/private_event_store/stored_private_event.ts +3 -3
- package/src/storage/tagging_store/recipient_tagging_store.ts +38 -24
- package/src/storage/tagging_store/sender_address_book_store.ts +20 -14
- package/src/storage/tagging_store/sender_tagging_store.ts +287 -156
- package/src/tagging/get_all_logs_by_tags.ts +31 -7
- package/src/tagging/index.ts +2 -2
- package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +14 -27
- package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +2 -2
- package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +12 -17
- package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +25 -12
- 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 +30 -29
- 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,9 +1,9 @@
|
|
|
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
|
-
import { isProtocolContract } from '@aztec/protocol-contracts';
|
|
7
7
|
import {
|
|
8
8
|
type ContractArtifact,
|
|
9
9
|
type FunctionAbi,
|
|
@@ -20,7 +20,8 @@ import {
|
|
|
20
20
|
} from '@aztec/stdlib/abi';
|
|
21
21
|
import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
22
22
|
import {
|
|
23
|
-
type
|
|
23
|
+
type ContractClassIdPreimage,
|
|
24
|
+
type ContractClassWithId,
|
|
24
25
|
type ContractInstanceWithAddress,
|
|
25
26
|
SerializableContractInstance,
|
|
26
27
|
getContractClassFromArtifact,
|
|
@@ -28,6 +29,68 @@ import {
|
|
|
28
29
|
|
|
29
30
|
import { PrivateFunctionsTree } from './private_functions_tree.js';
|
|
30
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
|
+
|
|
31
94
|
/**
|
|
32
95
|
* ContractStore serves as a data manager and retriever for Aztec.nr contracts.
|
|
33
96
|
* It provides methods to obtain contract addresses, function ABI, bytecode, and membership witnesses
|
|
@@ -40,71 +103,95 @@ export class ContractStore {
|
|
|
40
103
|
// TODO: Update it to be LRU cache so that it doesn't keep all the data all the time.
|
|
41
104
|
#privateFunctionTrees: Map<string, PrivateFunctionsTree> = new Map();
|
|
42
105
|
|
|
43
|
-
/**
|
|
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). */
|
|
44
115
|
#contractClassIdMap: Map<string, Fr> = new Map();
|
|
45
116
|
|
|
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) {
|
|
123
|
+
this.#store = store;
|
|
50
124
|
this.#contractArtifacts = store.openMap('contract_artifacts');
|
|
125
|
+
this.#contractClassData = store.openMap('contract_classes');
|
|
51
126
|
this.#contractInstances = store.openMap('contracts_instances');
|
|
52
127
|
}
|
|
53
128
|
|
|
54
129
|
// Setters
|
|
55
130
|
|
|
56
|
-
|
|
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
|
+
|
|
57
148
|
const privateFunctions = contract.functions.filter(
|
|
58
149
|
functionArtifact => functionArtifact.functionType === FunctionType.PRIVATE,
|
|
59
150
|
);
|
|
60
|
-
|
|
61
151
|
const privateSelectors = await Promise.all(
|
|
62
|
-
privateFunctions.map(async
|
|
63
|
-
(
|
|
64
|
-
await FunctionSelector.fromNameAndParameters(privateFunctionArtifact.name, privateFunctionArtifact.parameters)
|
|
65
|
-
).toString(),
|
|
152
|
+
privateFunctions.map(async fn =>
|
|
153
|
+
(await FunctionSelector.fromNameAndParameters(fn.name, fn.parameters)).toString(),
|
|
66
154
|
),
|
|
67
155
|
);
|
|
68
|
-
|
|
69
156
|
if (privateSelectors.length !== new Set(privateSelectors).size) {
|
|
70
157
|
throw new Error('Repeated function selectors of private functions');
|
|
71
158
|
}
|
|
72
159
|
|
|
73
|
-
|
|
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;
|
|
74
168
|
}
|
|
75
169
|
|
|
76
170
|
async addContractInstance(contract: ContractInstanceWithAddress): Promise<void> {
|
|
77
|
-
this.#
|
|
171
|
+
await this.#store.transactionAsync(async () => {
|
|
172
|
+
await this.#contractInstances.set(
|
|
173
|
+
contract.address.toString(),
|
|
174
|
+
new SerializableContractInstance(contract).toBuffer(),
|
|
175
|
+
);
|
|
176
|
+
});
|
|
78
177
|
|
|
79
|
-
|
|
80
|
-
contract.address.toString(),
|
|
81
|
-
new SerializableContractInstance(contract).toBuffer(),
|
|
82
|
-
);
|
|
178
|
+
this.#contractClassIdMap.set(contract.address.toString(), contract.currentContractClassId);
|
|
83
179
|
}
|
|
84
180
|
|
|
85
181
|
// Private getters
|
|
86
182
|
|
|
87
183
|
async #getContractClassId(contractAddress: AztecAddress): Promise<Fr | undefined> {
|
|
88
|
-
|
|
184
|
+
const key = contractAddress.toString();
|
|
185
|
+
if (!this.#contractClassIdMap.has(key)) {
|
|
89
186
|
const instance = await this.getContractInstance(contractAddress);
|
|
90
187
|
if (!instance) {
|
|
91
188
|
return;
|
|
92
189
|
}
|
|
93
|
-
this.#contractClassIdMap.set(
|
|
190
|
+
this.#contractClassIdMap.set(key, instance.currentContractClassId);
|
|
94
191
|
}
|
|
95
|
-
return this.#contractClassIdMap.get(
|
|
192
|
+
return this.#contractClassIdMap.get(key);
|
|
96
193
|
}
|
|
97
194
|
|
|
98
|
-
/**
|
|
99
|
-
* Retrieve or create a ContractTree instance based on the provided class id.
|
|
100
|
-
* If an existing tree with the same class id is found in the cache, it will be returned.
|
|
101
|
-
* Otherwise, a new ContractTree instance will be created using the contract data from the database
|
|
102
|
-
* and added to the cache before returning.
|
|
103
|
-
*
|
|
104
|
-
* @param classId - The class id of the contract for which the ContractTree is required.
|
|
105
|
-
* @returns A ContractTree instance associated with the specified contract address.
|
|
106
|
-
* @throws An Error if the contract is not found in the ContractDatabase.
|
|
107
|
-
*/
|
|
108
195
|
async #getPrivateFunctionTreeForClassId(classId: Fr): Promise<PrivateFunctionsTree | undefined> {
|
|
109
196
|
if (!this.#privateFunctionTrees.has(classId.toString())) {
|
|
110
197
|
const artifact = await this.getContractArtifact(classId);
|
|
@@ -117,34 +204,61 @@ export class ContractStore {
|
|
|
117
204
|
return this.#privateFunctionTrees.get(classId.toString())!;
|
|
118
205
|
}
|
|
119
206
|
|
|
120
|
-
async #
|
|
121
|
-
const
|
|
122
|
-
return
|
|
207
|
+
async #getArtifactByAddress(contractAddress: AztecAddress): Promise<ContractArtifact | undefined> {
|
|
208
|
+
const classId = await this.#getContractClassId(contractAddress);
|
|
209
|
+
return classId && this.getContractArtifact(classId);
|
|
123
210
|
}
|
|
124
211
|
|
|
125
212
|
// Public getters
|
|
126
213
|
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
214
|
+
getContractsAddresses(): Promise<AztecAddress[]> {
|
|
215
|
+
return this.#store.transactionAsync(async () => {
|
|
216
|
+
const keys = await toArray(this.#contractInstances.keysAsync());
|
|
217
|
+
return keys.map(AztecAddress.fromString);
|
|
218
|
+
});
|
|
130
219
|
}
|
|
131
220
|
|
|
132
|
-
/** Returns a contract instance for a given address.
|
|
133
|
-
public
|
|
134
|
-
|
|
135
|
-
|
|
221
|
+
/** Returns a contract instance for a given address. */
|
|
222
|
+
public getContractInstance(contractAddress: AztecAddress): Promise<ContractInstanceWithAddress | undefined> {
|
|
223
|
+
return this.#store.transactionAsync(async () => {
|
|
224
|
+
const contract = await this.#contractInstances.getAsync(contractAddress.toString());
|
|
225
|
+
return contract && SerializableContractInstance.fromBuffer(contract).withAddress(contractAddress);
|
|
226
|
+
});
|
|
136
227
|
}
|
|
137
228
|
|
|
229
|
+
/** Returns the raw contract artifact for a given class id. */
|
|
138
230
|
public async getContractArtifact(contractClassId: Fr): Promise<ContractArtifact | undefined> {
|
|
139
|
-
const
|
|
140
|
-
|
|
141
|
-
|
|
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);
|
|
239
|
+
});
|
|
240
|
+
if (artifact) {
|
|
241
|
+
this.#contractArtifactCache.set(key, artifact);
|
|
242
|
+
}
|
|
243
|
+
return artifact;
|
|
142
244
|
}
|
|
143
245
|
|
|
144
|
-
/** Returns a contract class for a given class id.
|
|
145
|
-
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);
|
|
146
256
|
const artifact = await this.getContractArtifact(contractClassId);
|
|
147
|
-
|
|
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 };
|
|
148
262
|
}
|
|
149
263
|
|
|
150
264
|
public async getContract(
|
|
@@ -163,8 +277,6 @@ export class ContractStore {
|
|
|
163
277
|
|
|
164
278
|
/**
|
|
165
279
|
* Retrieves the artifact of a specified function within a given contract.
|
|
166
|
-
* The function is identified by its selector, which is a unique code generated from the function's signature.
|
|
167
|
-
* Throws an error if the contract address or function selector are invalid or not found.
|
|
168
280
|
*
|
|
169
281
|
* @param contractAddress - The AztecAddress representing the contract containing the function.
|
|
170
282
|
* @param selector - The function selector.
|
|
@@ -174,9 +286,12 @@ export class ContractStore {
|
|
|
174
286
|
contractAddress: AztecAddress,
|
|
175
287
|
selector: FunctionSelector,
|
|
176
288
|
): Promise<FunctionArtifactWithContractName | undefined> {
|
|
177
|
-
const artifact = await this.#
|
|
178
|
-
|
|
179
|
-
|
|
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 };
|
|
180
295
|
}
|
|
181
296
|
|
|
182
297
|
public async getFunctionArtifactWithDebugMetadata(
|
|
@@ -197,50 +312,48 @@ export class ContractStore {
|
|
|
197
312
|
public async getPublicFunctionArtifact(
|
|
198
313
|
contractAddress: AztecAddress,
|
|
199
314
|
): Promise<FunctionArtifactWithContractName | undefined> {
|
|
200
|
-
const artifact = await this.#
|
|
201
|
-
const
|
|
202
|
-
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 };
|
|
203
318
|
}
|
|
204
319
|
|
|
205
320
|
public async getFunctionAbi(
|
|
206
321
|
contractAddress: AztecAddress,
|
|
207
322
|
selector: FunctionSelector,
|
|
208
323
|
): Promise<FunctionAbi | undefined> {
|
|
209
|
-
const artifact = await this.#
|
|
324
|
+
const artifact = await this.#getArtifactByAddress(contractAddress);
|
|
210
325
|
return artifact && (await this.#findFunctionAbiBySelector(artifact, selector));
|
|
211
326
|
}
|
|
212
327
|
|
|
213
328
|
/**
|
|
214
329
|
* Retrieves the debug metadata of a specified function within a given contract.
|
|
215
|
-
* The function is identified by its selector, which is a unique code generated from the function's signature.
|
|
216
|
-
* Returns undefined if the debug metadata for the given function is not found.
|
|
217
|
-
* Throws if the contract has not been added to the database.
|
|
218
330
|
*
|
|
219
331
|
* @param contractAddress - The AztecAddress representing the contract containing the function.
|
|
220
332
|
* @param selector - The function selector.
|
|
221
|
-
* @returns The corresponding function's
|
|
333
|
+
* @returns The corresponding function's debug metadata, or undefined.
|
|
222
334
|
*/
|
|
223
335
|
public async getFunctionDebugMetadata(
|
|
224
336
|
contractAddress: AztecAddress,
|
|
225
337
|
selector: FunctionSelector,
|
|
226
338
|
): Promise<FunctionDebugMetadata | undefined> {
|
|
227
|
-
const artifact = await this.#
|
|
228
|
-
|
|
229
|
-
|
|
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);
|
|
230
345
|
}
|
|
231
346
|
|
|
232
347
|
public async getPublicFunctionDebugMetadata(
|
|
233
348
|
contractAddress: AztecAddress,
|
|
234
349
|
): Promise<FunctionDebugMetadata | undefined> {
|
|
235
|
-
const artifact = await this.#
|
|
236
|
-
const
|
|
237
|
-
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);
|
|
238
353
|
}
|
|
239
354
|
|
|
240
355
|
/**
|
|
241
356
|
* Retrieve the function membership witness for the given contract class and function selector.
|
|
242
|
-
* The function membership witness represents a proof that the function belongs to the specified contract.
|
|
243
|
-
* Throws an error if the contract address or function selector is unknown.
|
|
244
357
|
*
|
|
245
358
|
* @param contractClassId - The id of the class.
|
|
246
359
|
* @param selector - The function selector.
|
|
@@ -255,23 +368,21 @@ export class ContractStore {
|
|
|
255
368
|
}
|
|
256
369
|
|
|
257
370
|
public async getDebugContractName(contractAddress: AztecAddress) {
|
|
258
|
-
const artifact = await this.#
|
|
371
|
+
const artifact = await this.#getArtifactByAddress(contractAddress);
|
|
259
372
|
return artifact?.name;
|
|
260
373
|
}
|
|
261
374
|
|
|
262
375
|
public async getDebugFunctionName(contractAddress: AztecAddress, selector: FunctionSelector) {
|
|
263
|
-
const artifact = await this.#
|
|
264
|
-
const
|
|
265
|
-
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}`;
|
|
266
379
|
}
|
|
267
380
|
|
|
268
381
|
async #findFunctionArtifactBySelector(
|
|
269
382
|
artifact: ContractArtifact,
|
|
270
383
|
selector: FunctionSelector,
|
|
271
384
|
): Promise<FunctionArtifact | undefined> {
|
|
272
|
-
const
|
|
273
|
-
for (let i = 0; i < functions.length; i++) {
|
|
274
|
-
const fn = functions[i];
|
|
385
|
+
for (const fn of artifact.functions) {
|
|
275
386
|
const fnSelector = await FunctionSelector.fromNameAndParameters(fn.name, fn.parameters);
|
|
276
387
|
if (fnSelector.equals(selector)) {
|
|
277
388
|
return fn;
|
|
@@ -283,9 +394,7 @@ export class ContractStore {
|
|
|
283
394
|
artifact: ContractArtifact,
|
|
284
395
|
selector: FunctionSelector,
|
|
285
396
|
): Promise<FunctionAbi | undefined> {
|
|
286
|
-
const
|
|
287
|
-
for (let i = 0; i < functions.length; i++) {
|
|
288
|
-
const fn = functions[i];
|
|
397
|
+
for (const fn of [...artifact.functions, ...(artifact.nonDispatchPublicFunctions ?? [])]) {
|
|
289
398
|
const fnSelector = await FunctionSelector.fromNameAndParameters(fn.name, fn.parameters);
|
|
290
399
|
if (fnSelector.equals(selector)) {
|
|
291
400
|
return fn;
|
|
@@ -306,34 +415,17 @@ export class ContractStore {
|
|
|
306
415
|
throw new Error(`Unknown function ${functionName} in contract ${contract.name}.`);
|
|
307
416
|
}
|
|
308
417
|
|
|
309
|
-
|
|
418
|
+
const selector = await FunctionSelector.fromNameAndParameters(functionDao.name, functionDao.parameters);
|
|
419
|
+
|
|
420
|
+
return FunctionCall.from({
|
|
310
421
|
name: functionDao.name,
|
|
311
|
-
args: encodeArguments(functionDao, args),
|
|
312
|
-
selector: await FunctionSelector.fromNameAndParameters(functionDao.name, functionDao.parameters),
|
|
313
|
-
type: functionDao.functionType,
|
|
314
422
|
to,
|
|
423
|
+
selector,
|
|
424
|
+
type: functionDao.functionType,
|
|
315
425
|
hideMsgSender: false,
|
|
316
426
|
isStatic: functionDao.isStatic,
|
|
427
|
+
args: encodeArguments(functionDao, args),
|
|
317
428
|
returnTypes: functionDao.returnTypes,
|
|
318
|
-
};
|
|
319
|
-
}
|
|
320
|
-
|
|
321
|
-
// Synchronize target contract data
|
|
322
|
-
public async syncPrivateState(
|
|
323
|
-
contractAddress: AztecAddress,
|
|
324
|
-
functionToInvokeAfterSync: FunctionSelector | null,
|
|
325
|
-
utilityExecutor: (privateSyncCall: FunctionCall) => Promise<any>,
|
|
326
|
-
) {
|
|
327
|
-
// Protocol contracts don't have private state to sync
|
|
328
|
-
if (!isProtocolContract(contractAddress)) {
|
|
329
|
-
const syncPrivateStateFunctionCall = await this.getFunctionCall('sync_private_state', [], contractAddress);
|
|
330
|
-
if (functionToInvokeAfterSync && functionToInvokeAfterSync.equals(syncPrivateStateFunctionCall.selector)) {
|
|
331
|
-
throw new Error(
|
|
332
|
-
'Forbidden `sync_private_state` invocation. `sync_private_state` can only be invoked by PXE, manual execution can lead to inconsistencies.',
|
|
333
|
-
);
|
|
334
|
-
}
|
|
335
|
-
|
|
336
|
-
return utilityExecutor(syncPrivateStateFunctionCall);
|
|
337
|
-
}
|
|
429
|
+
});
|
|
338
430
|
}
|
|
339
431
|
}
|
package/src/storage/metadata.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export const PXE_DATA_SCHEMA_VERSION =
|
|
1
|
+
export const PXE_DATA_SCHEMA_VERSION = 5;
|