@aztec/pxe 0.0.1-commit.0c875d939 → 0.0.1-commit.10bd49492
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/config/index.d.ts +2 -2
- package/dest/config/index.d.ts.map +1 -1
- package/dest/config/index.js +1 -1
- package/dest/config/package_info.js +1 -1
- package/dest/contract_function_simulator/contract_function_simulator.d.ts +4 -1
- package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
- package/dest/contract_function_simulator/contract_function_simulator.js +16 -12
- 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 +2 -3
- 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 +5 -4
- package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts +1 -1
- 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 +1 -3
- package/dest/contract_function_simulator/noir-structs/message_tx_context.d.ts +16 -0
- package/dest/contract_function_simulator/noir-structs/message_tx_context.d.ts.map +1 -0
- package/dest/contract_function_simulator/noir-structs/message_tx_context.js +57 -0
- package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +2 -4
- 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 +3 -5
- package/dest/contract_function_simulator/oracle/interfaces.d.ts +49 -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 +52 -0
- package/dest/contract_function_simulator/oracle/oracle.d.ts +44 -44
- package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/oracle.js +141 -93
- package/dest/contract_function_simulator/oracle/private_execution.js +3 -3
- package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +23 -37
- package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/private_execution_oracle.js +41 -67
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +40 -34
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +83 -50
- package/dest/contract_logging.d.ts +22 -0
- package/dest/contract_logging.d.ts.map +1 -0
- package/dest/contract_logging.js +23 -0
- package/dest/debug/pxe_debug_utils.d.ts +2 -2
- 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 +2 -1
- package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
- package/dest/entrypoints/client/bundle/index.js +1 -0
- package/dest/entrypoints/client/lazy/index.d.ts +2 -1
- package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
- package/dest/entrypoints/client/lazy/index.js +1 -0
- package/dest/logs/log_service.d.ts +1 -1
- package/dest/logs/log_service.d.ts.map +1 -1
- package/dest/logs/log_service.js +4 -4
- 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/oracle_version.d.ts +2 -2
- package/dest/oracle_version.js +3 -3
- 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 +19 -11
- 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 +9 -7
- package/dest/pxe.d.ts.map +1 -1
- package/dest/pxe.js +49 -36
- 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 +140 -64
- package/dest/storage/metadata.d.ts +1 -1
- package/dest/storage/metadata.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 -7
- 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/config/index.ts +1 -1
- package/src/config/package_info.ts +1 -1
- package/src/contract_function_simulator/contract_function_simulator.ts +25 -21
- 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 +8 -5
- package/src/contract_function_simulator/noir-structs/log_retrieval_response.ts +1 -4
- package/src/contract_function_simulator/noir-structs/message_tx_context.ts +55 -0
- package/src/contract_function_simulator/noir-structs/note_validation_request.ts +3 -6
- package/src/contract_function_simulator/oracle/interfaces.ts +53 -54
- package/src/contract_function_simulator/oracle/legacy_oracle_mappings.ts +77 -0
- package/src/contract_function_simulator/oracle/oracle.ts +154 -137
- package/src/contract_function_simulator/oracle/private_execution.ts +3 -3
- package/src/contract_function_simulator/oracle/private_execution_oracle.ts +46 -83
- package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +117 -59
- package/src/contract_logging.ts +39 -0
- package/src/debug/pxe_debug_utils.ts +4 -4
- package/src/entrypoints/client/bundle/index.ts +1 -0
- package/src/entrypoints/client/lazy/index.ts +1 -0
- package/src/logs/log_service.ts +10 -5
- package/src/messages/message_context_service.ts +45 -0
- package/src/oracle_version.ts +3 -3
- 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 +19 -12
- package/src/private_kernel/private_kernel_oracle.ts +7 -7
- package/src/pxe.ts +53 -40
- package/src/storage/contract_store/contract_store.ts +170 -71
- package/src/storage/metadata.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 +7 -10
- 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
|
@@ -8,13 +8,15 @@ import type { KeyStore } from '@aztec/key-store';
|
|
|
8
8
|
import type { AuthWitness } from '@aztec/stdlib/auth-witness';
|
|
9
9
|
import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
10
10
|
import { BlockHash } from '@aztec/stdlib/block';
|
|
11
|
-
import type { CompleteAddress, ContractInstance } from '@aztec/stdlib/contract';
|
|
11
|
+
import type { CompleteAddress, ContractInstance, PartialAddress } from '@aztec/stdlib/contract';
|
|
12
12
|
import type { AztecNode } from '@aztec/stdlib/interfaces/server';
|
|
13
13
|
import type { KeyValidationRequest } from '@aztec/stdlib/kernel';
|
|
14
|
+
import { type PublicKeys } from '@aztec/stdlib/keys';
|
|
14
15
|
import type { NoteStatus } from '@aztec/stdlib/note';
|
|
15
16
|
import { type NullifierMembershipWitness, PublicDataWitness } from '@aztec/stdlib/trees';
|
|
16
17
|
import type { BlockHeader, Capsule } from '@aztec/stdlib/tx';
|
|
17
18
|
import type { AccessScopes } from '../../access_scopes.js';
|
|
19
|
+
import { MessageContextService } from '../../messages/message_context_service.js';
|
|
18
20
|
import type { AddressStore } from '../../storage/address_store/address_store.js';
|
|
19
21
|
import type { CapsuleStore } from '../../storage/capsule_store/capsule_store.js';
|
|
20
22
|
import type { ContractStore } from '../../storage/contract_store/contract_store.js';
|
|
@@ -41,6 +43,7 @@ export type UtilityExecutionOracleArgs = {
|
|
|
41
43
|
senderAddressBookStore: SenderAddressBookStore;
|
|
42
44
|
capsuleStore: CapsuleStore;
|
|
43
45
|
privateEventStore: PrivateEventStore;
|
|
46
|
+
messageContextService: MessageContextService;
|
|
44
47
|
jobId: string;
|
|
45
48
|
log?: ReturnType<typeof createLogger>;
|
|
46
49
|
scopes: AccessScopes;
|
|
@@ -66,13 +69,14 @@ export declare class UtilityExecutionOracle implements IMiscOracle, IUtilityExec
|
|
|
66
69
|
protected readonly senderAddressBookStore: SenderAddressBookStore;
|
|
67
70
|
protected readonly capsuleStore: CapsuleStore;
|
|
68
71
|
protected readonly privateEventStore: PrivateEventStore;
|
|
72
|
+
protected readonly messageContextService: MessageContextService;
|
|
69
73
|
protected readonly jobId: string;
|
|
70
|
-
protected
|
|
74
|
+
protected logger: ReturnType<typeof createLogger>;
|
|
71
75
|
protected readonly scopes: AccessScopes;
|
|
72
76
|
constructor(args: UtilityExecutionOracleArgs);
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
77
|
+
assertCompatibleOracleVersion(version: number): void;
|
|
78
|
+
getRandomField(): Fr;
|
|
79
|
+
getUtilityContext(): UtilityContext;
|
|
76
80
|
/**
|
|
77
81
|
* Retrieve keys associated with a specific master public key and app address.
|
|
78
82
|
* @param pkMHash - The master public key hash.
|
|
@@ -80,7 +84,7 @@ export declare class UtilityExecutionOracle implements IMiscOracle, IUtilityExec
|
|
|
80
84
|
* @throws If the keys are not registered in the key store.
|
|
81
85
|
* @throws If scopes are defined and the account is not in the scopes.
|
|
82
86
|
*/
|
|
83
|
-
|
|
87
|
+
getKeyValidationRequest(pkMHash: Fr): Promise<KeyValidationRequest>;
|
|
84
88
|
/**
|
|
85
89
|
* Fetches the index and sibling path of a leaf at a given block from the note hash tree.
|
|
86
90
|
* @param anchorBlockHash - The hash of a block that contains the note hash tree root in which to find the membership
|
|
@@ -88,7 +92,7 @@ export declare class UtilityExecutionOracle implements IMiscOracle, IUtilityExec
|
|
|
88
92
|
* @param noteHash - The note hash to find in the note hash tree.
|
|
89
93
|
* @returns The membership witness containing the leaf index and sibling path
|
|
90
94
|
*/
|
|
91
|
-
|
|
95
|
+
getNoteHashMembershipWitness(anchorBlockHash: BlockHash, noteHash: Fr): Promise<MembershipWitness<typeof NOTE_HASH_TREE_HEIGHT> | undefined>;
|
|
92
96
|
/**
|
|
93
97
|
* Fetches the index and sibling path of a block hash in the archive tree.
|
|
94
98
|
*
|
|
@@ -100,14 +104,14 @@ export declare class UtilityExecutionOracle implements IMiscOracle, IUtilityExec
|
|
|
100
104
|
* @param blockHash - The block hash to find in the archive tree.
|
|
101
105
|
* @returns The membership witness containing the leaf index and sibling path
|
|
102
106
|
*/
|
|
103
|
-
|
|
107
|
+
getBlockHashMembershipWitness(anchorBlockHash: BlockHash, blockHash: BlockHash): Promise<MembershipWitness<typeof ARCHIVE_HEIGHT> | undefined>;
|
|
104
108
|
/**
|
|
105
109
|
* Returns a nullifier membership witness for a given nullifier at a given block.
|
|
106
110
|
* @param blockHash - The block hash at which to get the index.
|
|
107
111
|
* @param nullifier - Nullifier we try to find witness for.
|
|
108
112
|
* @returns The nullifier membership witness (if found).
|
|
109
113
|
*/
|
|
110
|
-
|
|
114
|
+
getNullifierMembershipWitness(blockHash: BlockHash, nullifier: Fr): Promise<NullifierMembershipWitness | undefined>;
|
|
111
115
|
/**
|
|
112
116
|
* Returns a low nullifier membership witness for a given nullifier at a given block.
|
|
113
117
|
* @param blockHash - The block hash at which to get the index.
|
|
@@ -117,41 +121,43 @@ export declare class UtilityExecutionOracle implements IMiscOracle, IUtilityExec
|
|
|
117
121
|
* list structure" of leaves and proving that a lower nullifier is pointing to a bigger next value than the nullifier
|
|
118
122
|
* we are trying to prove non-inclusion for.
|
|
119
123
|
*/
|
|
120
|
-
|
|
124
|
+
getLowNullifierMembershipWitness(blockHash: BlockHash, nullifier: Fr): Promise<NullifierMembershipWitness | undefined>;
|
|
121
125
|
/**
|
|
122
126
|
* Returns a public data tree witness for a given leaf slot at a given block.
|
|
123
127
|
* @param blockHash - The block hash at which to get the index.
|
|
124
128
|
* @param leafSlot - The slot of the public data tree to get the witness for.
|
|
125
129
|
* @returns - The witness
|
|
126
130
|
*/
|
|
127
|
-
|
|
131
|
+
getPublicDataWitness(blockHash: BlockHash, leafSlot: Fr): Promise<PublicDataWitness | undefined>;
|
|
128
132
|
/**
|
|
129
133
|
* Fetches a block header of a given block.
|
|
130
134
|
* @param blockNumber - The number of a block of which to get the block header.
|
|
131
135
|
* @returns Block extracted from a block with block number `blockNumber`.
|
|
132
136
|
*/
|
|
133
|
-
|
|
137
|
+
getBlockHeader(blockNumber: BlockNumber): Promise<BlockHeader | undefined>;
|
|
134
138
|
/**
|
|
135
|
-
* Retrieve the
|
|
139
|
+
* Retrieve the public keys and partial address associated to a given address.
|
|
136
140
|
* @param account - The account address.
|
|
137
|
-
* @returns
|
|
141
|
+
* @returns The public keys and partial address, or `undefined` if the account is not registered.
|
|
138
142
|
*/
|
|
139
|
-
|
|
143
|
+
tryGetPublicKeysAndPartialAddress(account: AztecAddress): Promise<{
|
|
144
|
+
publicKeys: PublicKeys;
|
|
145
|
+
partialAddress: PartialAddress;
|
|
146
|
+
} | undefined>;
|
|
140
147
|
protected getCompleteAddressOrFail(account: AztecAddress): Promise<CompleteAddress>;
|
|
141
148
|
/**
|
|
142
149
|
* Returns a contract instance associated with an address or throws if not found.
|
|
143
150
|
* @param address - Address.
|
|
144
151
|
* @returns A contract instance.
|
|
145
152
|
*/
|
|
146
|
-
|
|
147
|
-
protected getContractInstance(address: AztecAddress): Promise<ContractInstance>;
|
|
153
|
+
getContractInstance(address: AztecAddress): Promise<ContractInstance>;
|
|
148
154
|
/**
|
|
149
155
|
* Returns an auth witness for the given message hash. Checks on the list of transient witnesses
|
|
150
156
|
* for this transaction first, and falls back to the local database if not found.
|
|
151
157
|
* @param messageHash - Hash of the message to authenticate.
|
|
152
158
|
* @returns Authentication witness for the requested message hash.
|
|
153
159
|
*/
|
|
154
|
-
|
|
160
|
+
getAuthWitness(messageHash: Fr): Promise<Fr[] | undefined>;
|
|
155
161
|
/**
|
|
156
162
|
* Gets some notes for a contract address and storage slot.
|
|
157
163
|
* Returns a flattened array containing filtered notes.
|
|
@@ -174,13 +180,13 @@ export declare class UtilityExecutionOracle implements IMiscOracle, IUtilityExec
|
|
|
174
180
|
* @param status - The status of notes to fetch.
|
|
175
181
|
* @returns Array of note data.
|
|
176
182
|
*/
|
|
177
|
-
|
|
183
|
+
getNotes(owner: AztecAddress | undefined, storageSlot: Fr, numSelects: number, selectByIndexes: number[], selectByOffsets: number[], selectByLengths: number[], selectValues: Fr[], selectComparators: number[], sortByIndexes: number[], sortByOffsets: number[], sortByLengths: number[], sortOrder: number[], limit: number, offset: number, status: NoteStatus): Promise<NoteData[]>;
|
|
178
184
|
/**
|
|
179
185
|
* Check if a nullifier exists in the nullifier tree.
|
|
180
186
|
* @param innerNullifier - The inner nullifier.
|
|
181
187
|
* @returns A boolean indicating whether the nullifier exists in the tree or not.
|
|
182
188
|
*/
|
|
183
|
-
|
|
189
|
+
checkNullifierExists(innerNullifier: Fr): Promise<boolean>;
|
|
184
190
|
/**
|
|
185
191
|
* Fetches a message from the executionStore, given its key.
|
|
186
192
|
* @param contractAddress - Address of a contract by which the message was emitted.
|
|
@@ -189,7 +195,7 @@ export declare class UtilityExecutionOracle implements IMiscOracle, IUtilityExec
|
|
|
189
195
|
* @dev Contract address and secret are only used to compute the nullifier to get non-nullified messages
|
|
190
196
|
* @returns The l1 to l2 membership witness (index of message in the tree and sibling path).
|
|
191
197
|
*/
|
|
192
|
-
|
|
198
|
+
getL1ToL2MembershipWitness(contractAddress: AztecAddress, messageHash: Fr, secret: Fr): Promise<MessageLoadOracleInputs<36>>;
|
|
193
199
|
/**
|
|
194
200
|
* Read the public storage data.
|
|
195
201
|
* @param blockHash - The block hash to read storage at.
|
|
@@ -197,9 +203,9 @@ export declare class UtilityExecutionOracle implements IMiscOracle, IUtilityExec
|
|
|
197
203
|
* @param startStorageSlot - The starting storage slot.
|
|
198
204
|
* @param numberOfElements - Number of elements to read from the starting storage slot.
|
|
199
205
|
*/
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
206
|
+
storageRead(blockHash: BlockHash, contractAddress: AztecAddress, startStorageSlot: Fr, numberOfElements: number): Promise<Fr[]>;
|
|
207
|
+
log(level: number, message: string, fields: Fr[]): Promise<void>;
|
|
208
|
+
fetchTaggedLogs(pendingTaggedLogArrayBaseSlot: Fr): Promise<void>;
|
|
203
209
|
/**
|
|
204
210
|
* Validates all note and event validation requests enqueued via `enqueue_note_for_validation` and
|
|
205
211
|
* `enqueue_event_for_validation`, inserting them into the note database and event store respectively, making them
|
|
@@ -210,20 +216,20 @@ export declare class UtilityExecutionOracle implements IMiscOracle, IUtilityExec
|
|
|
210
216
|
* @param noteValidationRequestsArrayBaseSlot - The base slot of capsule array containing note validation requests.
|
|
211
217
|
* @param eventValidationRequestsArrayBaseSlot - The base slot of capsule array containing event validation requests.
|
|
212
218
|
*/
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
219
|
+
validateAndStoreEnqueuedNotesAndEvents(contractAddress: AztecAddress, noteValidationRequestsArrayBaseSlot: Fr, eventValidationRequestsArrayBaseSlot: Fr, maxNotePackedLen: number, maxEventSerializedLen: number): Promise<void>;
|
|
220
|
+
bulkRetrieveLogs(contractAddress: AztecAddress, logRetrievalRequestsArrayBaseSlot: Fr, logRetrievalResponsesArrayBaseSlot: Fr): Promise<void>;
|
|
221
|
+
utilityResolveMessageContexts(contractAddress: AztecAddress, messageContextRequestsArrayBaseSlot: Fr, messageContextResponsesArrayBaseSlot: Fr): Promise<void>;
|
|
222
|
+
storeCapsule(contractAddress: AztecAddress, slot: Fr, capsule: Fr[]): Promise<void>;
|
|
223
|
+
loadCapsule(contractAddress: AztecAddress, slot: Fr): Promise<Fr[] | null>;
|
|
224
|
+
deleteCapsule(contractAddress: AztecAddress, slot: Fr): Promise<void>;
|
|
225
|
+
copyCapsule(contractAddress: AztecAddress, srcSlot: Fr, dstSlot: Fr, numEntries: number): Promise<void>;
|
|
226
|
+
aes128Decrypt(ciphertext: Buffer, iv: Buffer, symKey: Buffer): Promise<Buffer>;
|
|
220
227
|
/**
|
|
221
228
|
* Retrieves the shared secret for a given address and ephemeral public key.
|
|
222
229
|
* @param address - The address to get the secret for.
|
|
223
230
|
* @param ephPk - The ephemeral public key to get the secret for.
|
|
224
231
|
* @returns The secret for the given address.
|
|
225
232
|
*/
|
|
226
|
-
|
|
227
|
-
protected getSharedSecret(address: AztecAddress, ephPk: Point): Promise<Point>;
|
|
233
|
+
getSharedSecret(address: AztecAddress, ephPk: Point): Promise<Point>;
|
|
228
234
|
}
|
|
229
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
235
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbGl0eV9leGVjdXRpb25fb3JhY2xlLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29udHJhY3RfZnVuY3Rpb25fc2ltdWxhdG9yL29yYWNsZS91dGlsaXR5X2V4ZWN1dGlvbl9vcmFjbGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLEVBQUUsY0FBYyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDOUUsT0FBTyxLQUFLLEVBQUUsV0FBVyxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFFbkUsT0FBTyxFQUFFLEVBQUUsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQ3BELE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUMxRCxPQUFPLEVBQTBCLFlBQVksRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzdFLE9BQU8sS0FBSyxFQUFFLGlCQUFpQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDakUsT0FBTyxLQUFLLEVBQUUsUUFBUSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFFakQsT0FBTyxLQUFLLEVBQUUsV0FBVyxFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDOUQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQzNELE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUNoRCxPQUFPLEtBQUssRUFBRSxlQUFlLEVBQUUsZ0JBQWdCLEVBQUUsY0FBYyxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFFaEcsT0FBTyxLQUFLLEVBQUUsU0FBUyxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDakUsT0FBTyxLQUFLLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUNqRSxPQUFPLEVBQUUsS0FBSyxVQUFVLEVBQXdCLE1BQU0sb0JBQW9CLENBQUM7QUFHM0UsT0FBTyxLQUFLLEVBQUUsVUFBVSxFQUFFLE1B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
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utility_execution_oracle.d.ts","sourceRoot":"","sources":["../../../src/contract_function_simulator/oracle/utility_execution_oracle.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAC;AAC9E,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,iCAAiC,CAAC;AAEnE,OAAO,EAAE,EAAE,EAAE,MAAM,gCAAgC,CAAC;AACpD,OAAO,EAAE,KAAK,EAAE,MAAM,mCAAmC,CAAC;AAC1D,OAAO,
|
|
1
|
+
{"version":3,"file":"utility_execution_oracle.d.ts","sourceRoot":"","sources":["../../../src/contract_function_simulator/oracle/utility_execution_oracle.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,11 +1,13 @@
|
|
|
1
1
|
import { Aes128 } from '@aztec/foundation/crypto/aes128';
|
|
2
2
|
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
3
|
-
import { LogLevels,
|
|
3
|
+
import { LogLevels, createLogger } from '@aztec/foundation/log';
|
|
4
|
+
import { isProtocolContract } from '@aztec/protocol-contracts';
|
|
4
5
|
import { siloNullifier } from '@aztec/stdlib/hash';
|
|
5
6
|
import { computeAddressSecret } from '@aztec/stdlib/keys';
|
|
6
7
|
import { deriveEcdhSharedSecret } from '@aztec/stdlib/logs';
|
|
7
8
|
import { getNonNullifiedL1ToL2MessageWitness } from '@aztec/stdlib/messaging';
|
|
8
9
|
import { MerkleTreeId } from '@aztec/stdlib/trees';
|
|
10
|
+
import { createContractLogger, logContractMessage } from '../../contract_logging.js';
|
|
9
11
|
import { EventService } from '../../events/event_service.js';
|
|
10
12
|
import { LogService } from '../../logs/log_service.js';
|
|
11
13
|
import { NoteService } from '../../notes/note_service.js';
|
|
@@ -13,6 +15,7 @@ import { ORACLE_VERSION } from '../../oracle_version.js';
|
|
|
13
15
|
import { EventValidationRequest } from '../noir-structs/event_validation_request.js';
|
|
14
16
|
import { LogRetrievalRequest } from '../noir-structs/log_retrieval_request.js';
|
|
15
17
|
import { LogRetrievalResponse } from '../noir-structs/log_retrieval_response.js';
|
|
18
|
+
import { MessageTxContext } from '../noir-structs/message_tx_context.js';
|
|
16
19
|
import { NoteValidationRequest } from '../noir-structs/note_validation_request.js';
|
|
17
20
|
import { UtilityContext } from '../noir-structs/utility_context.js';
|
|
18
21
|
import { pickNotes } from '../pick_notes.js';
|
|
@@ -36,8 +39,9 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
|
|
|
36
39
|
senderAddressBookStore;
|
|
37
40
|
capsuleStore;
|
|
38
41
|
privateEventStore;
|
|
42
|
+
messageContextService;
|
|
39
43
|
jobId;
|
|
40
|
-
|
|
44
|
+
logger;
|
|
41
45
|
scopes;
|
|
42
46
|
constructor(args){
|
|
43
47
|
this.contractAddress = args.contractAddress;
|
|
@@ -53,19 +57,32 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
|
|
|
53
57
|
this.senderAddressBookStore = args.senderAddressBookStore;
|
|
54
58
|
this.capsuleStore = args.capsuleStore;
|
|
55
59
|
this.privateEventStore = args.privateEventStore;
|
|
60
|
+
this.messageContextService = args.messageContextService;
|
|
56
61
|
this.jobId = args.jobId;
|
|
57
|
-
this.
|
|
62
|
+
this.logger = args.log ?? createLogger('simulator:client_view_context');
|
|
58
63
|
this.scopes = args.scopes;
|
|
59
64
|
}
|
|
60
|
-
|
|
65
|
+
assertCompatibleOracleVersion(version) {
|
|
66
|
+
// TODO(F-416): Remove this hack on v5 when protocol contracts are redeployed.
|
|
67
|
+
// Protocol contracts/canonical contracts shipped with committed bytecode that cannot be changed. Assert they use
|
|
68
|
+
// the expected pinned version or the current one. We want to allow for both the pinned and the current versions
|
|
69
|
+
// because we want this code to work with both the pinned and unpinned version since some branches do not have the
|
|
70
|
+
// pinned contracts (like e.g. next)
|
|
71
|
+
const LEGACY_ORACLE_VERSION = 12;
|
|
72
|
+
if (isProtocolContract(this.contractAddress)) {
|
|
73
|
+
if (version !== LEGACY_ORACLE_VERSION && version !== ORACLE_VERSION) {
|
|
74
|
+
throw new Error(`Expected legacy oracle version ${LEGACY_ORACLE_VERSION} or current oracle version ${ORACLE_VERSION} for alpha payload contract at ${this.contractAddress}, got ${version}.`);
|
|
75
|
+
}
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
61
78
|
if (version !== ORACLE_VERSION) {
|
|
62
79
|
throw new Error(`Incompatible oracle version. Expected version ${ORACLE_VERSION}, got ${version}.`);
|
|
63
80
|
}
|
|
64
81
|
}
|
|
65
|
-
|
|
82
|
+
getRandomField() {
|
|
66
83
|
return Fr.random();
|
|
67
84
|
}
|
|
68
|
-
|
|
85
|
+
getUtilityContext() {
|
|
69
86
|
return new UtilityContext(this.anchorBlockHeader, this.contractAddress);
|
|
70
87
|
}
|
|
71
88
|
/**
|
|
@@ -74,7 +91,7 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
|
|
|
74
91
|
* @returns A Promise that resolves to nullifier keys.
|
|
75
92
|
* @throws If the keys are not registered in the key store.
|
|
76
93
|
* @throws If scopes are defined and the account is not in the scopes.
|
|
77
|
-
*/ async
|
|
94
|
+
*/ async getKeyValidationRequest(pkMHash) {
|
|
78
95
|
// If scopes are defined, check that the key belongs to an account in the scopes.
|
|
79
96
|
if (this.scopes !== 'ALL_SCOPES' && this.scopes.length > 0) {
|
|
80
97
|
let hasAccess = false;
|
|
@@ -95,7 +112,7 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
|
|
|
95
112
|
* witness.
|
|
96
113
|
* @param noteHash - The note hash to find in the note hash tree.
|
|
97
114
|
* @returns The membership witness containing the leaf index and sibling path
|
|
98
|
-
*/
|
|
115
|
+
*/ getNoteHashMembershipWitness(anchorBlockHash, noteHash) {
|
|
99
116
|
return this.aztecNode.getNoteHashMembershipWitness(anchorBlockHash, noteHash);
|
|
100
117
|
}
|
|
101
118
|
/**
|
|
@@ -108,7 +125,7 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
|
|
|
108
125
|
* witness.
|
|
109
126
|
* @param blockHash - The block hash to find in the archive tree.
|
|
110
127
|
* @returns The membership witness containing the leaf index and sibling path
|
|
111
|
-
*/
|
|
128
|
+
*/ getBlockHashMembershipWitness(anchorBlockHash, blockHash) {
|
|
112
129
|
return this.aztecNode.getBlockHashMembershipWitness(anchorBlockHash, blockHash);
|
|
113
130
|
}
|
|
114
131
|
/**
|
|
@@ -116,7 +133,7 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
|
|
|
116
133
|
* @param blockHash - The block hash at which to get the index.
|
|
117
134
|
* @param nullifier - Nullifier we try to find witness for.
|
|
118
135
|
* @returns The nullifier membership witness (if found).
|
|
119
|
-
*/
|
|
136
|
+
*/ getNullifierMembershipWitness(blockHash, nullifier) {
|
|
120
137
|
return this.aztecNode.getNullifierMembershipWitness(blockHash, nullifier);
|
|
121
138
|
}
|
|
122
139
|
/**
|
|
@@ -127,7 +144,7 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
|
|
|
127
144
|
* @remarks Low nullifier witness can be used to perform a nullifier non-inclusion proof by leveraging the "linked
|
|
128
145
|
* list structure" of leaves and proving that a lower nullifier is pointing to a bigger next value than the nullifier
|
|
129
146
|
* we are trying to prove non-inclusion for.
|
|
130
|
-
*/
|
|
147
|
+
*/ getLowNullifierMembershipWitness(blockHash, nullifier) {
|
|
131
148
|
return this.aztecNode.getLowNullifierMembershipWitness(blockHash, nullifier);
|
|
132
149
|
}
|
|
133
150
|
/**
|
|
@@ -135,14 +152,14 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
|
|
|
135
152
|
* @param blockHash - The block hash at which to get the index.
|
|
136
153
|
* @param leafSlot - The slot of the public data tree to get the witness for.
|
|
137
154
|
* @returns - The witness
|
|
138
|
-
*/
|
|
155
|
+
*/ getPublicDataWitness(blockHash, leafSlot) {
|
|
139
156
|
return this.aztecNode.getPublicDataWitness(blockHash, leafSlot);
|
|
140
157
|
}
|
|
141
158
|
/**
|
|
142
159
|
* Fetches a block header of a given block.
|
|
143
160
|
* @param blockNumber - The number of a block of which to get the block header.
|
|
144
161
|
* @returns Block extracted from a block with block number `blockNumber`.
|
|
145
|
-
*/ async
|
|
162
|
+
*/ async getBlockHeader(blockNumber) {
|
|
146
163
|
const anchorBlockNumber = this.anchorBlockHeader.getBlockNumber();
|
|
147
164
|
if (blockNumber > anchorBlockNumber) {
|
|
148
165
|
throw new Error(`Block number ${blockNumber} is higher than current block ${anchorBlockNumber}`);
|
|
@@ -151,11 +168,18 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
|
|
|
151
168
|
return block?.header;
|
|
152
169
|
}
|
|
153
170
|
/**
|
|
154
|
-
* Retrieve the
|
|
171
|
+
* Retrieve the public keys and partial address associated to a given address.
|
|
155
172
|
* @param account - The account address.
|
|
156
|
-
* @returns
|
|
157
|
-
*/
|
|
158
|
-
|
|
173
|
+
* @returns The public keys and partial address, or `undefined` if the account is not registered.
|
|
174
|
+
*/ async tryGetPublicKeysAndPartialAddress(account) {
|
|
175
|
+
const completeAddress = await this.addressStore.getCompleteAddress(account);
|
|
176
|
+
if (!completeAddress) {
|
|
177
|
+
return undefined;
|
|
178
|
+
}
|
|
179
|
+
return {
|
|
180
|
+
publicKeys: completeAddress.publicKeys,
|
|
181
|
+
partialAddress: completeAddress.partialAddress
|
|
182
|
+
};
|
|
159
183
|
}
|
|
160
184
|
async getCompleteAddressOrFail(account) {
|
|
161
185
|
const completeAddress = await this.addressStore.getCompleteAddress(account);
|
|
@@ -169,10 +193,7 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
|
|
|
169
193
|
* Returns a contract instance associated with an address or throws if not found.
|
|
170
194
|
* @param address - Address.
|
|
171
195
|
* @returns A contract instance.
|
|
172
|
-
*/
|
|
173
|
-
return this.getContractInstance(address);
|
|
174
|
-
}
|
|
175
|
-
async getContractInstance(address) {
|
|
196
|
+
*/ async getContractInstance(address) {
|
|
176
197
|
const instance = await this.contractStore.getContractInstance(address);
|
|
177
198
|
if (!instance) {
|
|
178
199
|
throw new Error(`No contract instance found for address ${address.toString()}`);
|
|
@@ -184,7 +205,7 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
|
|
|
184
205
|
* for this transaction first, and falls back to the local database if not found.
|
|
185
206
|
* @param messageHash - Hash of the message to authenticate.
|
|
186
207
|
* @returns Authentication witness for the requested message hash.
|
|
187
|
-
*/
|
|
208
|
+
*/ getAuthWitness(messageHash) {
|
|
188
209
|
return Promise.resolve(this.authWitnesses.find((w)=>w.requestHash.equals(messageHash))?.witness);
|
|
189
210
|
}
|
|
190
211
|
/**
|
|
@@ -208,7 +229,7 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
|
|
|
208
229
|
* @param offset - The starting index for pagination.
|
|
209
230
|
* @param status - The status of notes to fetch.
|
|
210
231
|
* @returns Array of note data.
|
|
211
|
-
*/ async
|
|
232
|
+
*/ async getNotes(owner, storageSlot, numSelects, selectByIndexes, selectByOffsets, selectByLengths, selectValues, selectComparators, sortByIndexes, sortByOffsets, sortByLengths, sortOrder, limit, offset, status) {
|
|
212
233
|
const noteService = new NoteService(this.noteStore, this.aztecNode, this.anchorBlockHeader, this.jobId);
|
|
213
234
|
const dbNotes = await noteService.getNotes(this.contractAddress, owner, storageSlot, status, this.scopes);
|
|
214
235
|
return pickNotes(dbNotes, {
|
|
@@ -237,7 +258,7 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
|
|
|
237
258
|
* Check if a nullifier exists in the nullifier tree.
|
|
238
259
|
* @param innerNullifier - The inner nullifier.
|
|
239
260
|
* @returns A boolean indicating whether the nullifier exists in the tree or not.
|
|
240
|
-
*/ async
|
|
261
|
+
*/ async checkNullifierExists(innerNullifier) {
|
|
241
262
|
const [nullifier, anchorBlockHash] = await Promise.all([
|
|
242
263
|
siloNullifier(this.contractAddress, innerNullifier),
|
|
243
264
|
this.anchorBlockHeader.hash()
|
|
@@ -254,7 +275,7 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
|
|
|
254
275
|
* @param secret - Secret used to compute a nullifier.
|
|
255
276
|
* @dev Contract address and secret are only used to compute the nullifier to get non-nullified messages
|
|
256
277
|
* @returns The l1 to l2 membership witness (index of message in the tree and sibling path).
|
|
257
|
-
*/ async
|
|
278
|
+
*/ async getL1ToL2MembershipWitness(contractAddress, messageHash, secret) {
|
|
258
279
|
const [messageIndex, siblingPath] = await getNonNullifiedL1ToL2MessageWitness(this.aztecNode, contractAddress, messageHash, secret);
|
|
259
280
|
return new MessageLoadOracleInputs(messageIndex, siblingPath);
|
|
260
281
|
}
|
|
@@ -264,37 +285,33 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
|
|
|
264
285
|
* @param contractAddress - The address to read storage from.
|
|
265
286
|
* @param startStorageSlot - The starting storage slot.
|
|
266
287
|
* @param numberOfElements - Number of elements to read from the starting storage slot.
|
|
267
|
-
*/ async
|
|
288
|
+
*/ async storageRead(blockHash, contractAddress, startStorageSlot, numberOfElements) {
|
|
268
289
|
const slots = Array(numberOfElements).fill(0).map((_, i)=>new Fr(startStorageSlot.value + BigInt(i)));
|
|
269
290
|
const values = await Promise.all(slots.map((storageSlot)=>this.aztecNode.getPublicStorageAt(blockHash, contractAddress, storageSlot)));
|
|
270
|
-
this.
|
|
291
|
+
this.logger.debug(`Oracle storage read: slots=[${slots.map((slot)=>slot.toString()).join(', ')}] address=${contractAddress.toString()} values=[${values.join(', ')}]`);
|
|
271
292
|
return values;
|
|
272
293
|
}
|
|
273
294
|
/**
|
|
274
295
|
* Returns a per-contract logger whose output is prefixed with `contract_log::<name>(<addrAbbrev>)`.
|
|
275
296
|
*/ async #getContractLogger() {
|
|
276
297
|
if (!this.contractLogger) {
|
|
277
|
-
const addrAbbrev = this.contractAddress.toString().slice(0, 10);
|
|
278
|
-
const name = await this.contractStore.getDebugContractName(this.contractAddress);
|
|
279
|
-
const module = name ? `contract_log::${name}(${addrAbbrev})` : `contract_log::${addrAbbrev}`;
|
|
280
298
|
// Purpose of instanceId is to distinguish logs from different instances of the same component. It makes sense
|
|
281
299
|
// to re-use jobId as instanceId here as executions of different PXE jobs are isolated.
|
|
282
|
-
this.contractLogger =
|
|
300
|
+
this.contractLogger = await createContractLogger(this.contractAddress, (addr)=>this.contractStore.getDebugContractName(addr), {
|
|
283
301
|
instanceId: this.jobId
|
|
284
302
|
});
|
|
285
303
|
}
|
|
286
304
|
return this.contractLogger;
|
|
287
305
|
}
|
|
288
|
-
async
|
|
306
|
+
async log(level, message, fields) {
|
|
289
307
|
if (!LogLevels[level]) {
|
|
290
308
|
throw new Error(`Invalid log level: ${level}`);
|
|
291
309
|
}
|
|
292
|
-
const levelName = LogLevels[level];
|
|
293
310
|
const logger = await this.#getContractLogger();
|
|
294
|
-
logger[
|
|
311
|
+
logContractMessage(logger, LogLevels[level], message, fields);
|
|
295
312
|
}
|
|
296
|
-
async
|
|
297
|
-
const logService = new LogService(this.aztecNode, this.anchorBlockHeader, this.keyStore, this.capsuleStore, this.recipientTaggingStore, this.senderAddressBookStore, this.addressStore, this.jobId, this.
|
|
313
|
+
async fetchTaggedLogs(pendingTaggedLogArrayBaseSlot) {
|
|
314
|
+
const logService = new LogService(this.aztecNode, this.anchorBlockHeader, this.keyStore, this.capsuleStore, this.recipientTaggingStore, this.senderAddressBookStore, this.addressStore, this.jobId, this.logger.getBindings());
|
|
298
315
|
await logService.fetchTaggedLogs(this.contractAddress, pendingTaggedLogArrayBaseSlot, this.scopes);
|
|
299
316
|
}
|
|
300
317
|
/**
|
|
@@ -306,15 +323,15 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
|
|
|
306
323
|
* @param contractAddress - The address of the contract that the logs are tagged for.
|
|
307
324
|
* @param noteValidationRequestsArrayBaseSlot - The base slot of capsule array containing note validation requests.
|
|
308
325
|
* @param eventValidationRequestsArrayBaseSlot - The base slot of capsule array containing event validation requests.
|
|
309
|
-
*/ async
|
|
326
|
+
*/ async validateAndStoreEnqueuedNotesAndEvents(contractAddress, noteValidationRequestsArrayBaseSlot, eventValidationRequestsArrayBaseSlot, maxNotePackedLen, maxEventSerializedLen) {
|
|
310
327
|
// TODO(#10727): allow other contracts to store notes
|
|
311
328
|
if (!this.contractAddress.equals(contractAddress)) {
|
|
312
329
|
throw new Error(`Got a note validation request from ${contractAddress}, expected ${this.contractAddress}`);
|
|
313
330
|
}
|
|
314
331
|
// We read all note and event validation requests and process them all concurrently. This makes the process much
|
|
315
332
|
// faster as we don't need to wait for the network round-trip.
|
|
316
|
-
const noteValidationRequests = (await this.capsuleStore.readCapsuleArray(contractAddress, noteValidationRequestsArrayBaseSlot, this.jobId)).map(NoteValidationRequest.fromFields);
|
|
317
|
-
const eventValidationRequests = (await this.capsuleStore.readCapsuleArray(contractAddress, eventValidationRequestsArrayBaseSlot, this.jobId)).map(EventValidationRequest.fromFields);
|
|
333
|
+
const noteValidationRequests = (await this.capsuleStore.readCapsuleArray(contractAddress, noteValidationRequestsArrayBaseSlot, this.jobId)).map((fields)=>NoteValidationRequest.fromFields(fields, maxNotePackedLen));
|
|
334
|
+
const eventValidationRequests = (await this.capsuleStore.readCapsuleArray(contractAddress, eventValidationRequestsArrayBaseSlot, this.jobId)).map((fields)=>EventValidationRequest.fromFields(fields, maxEventSerializedLen));
|
|
318
335
|
const noteService = new NoteService(this.noteStore, this.aztecNode, this.anchorBlockHeader, this.jobId);
|
|
319
336
|
const noteStorePromises = noteValidationRequests.map((request)=>noteService.validateAndStoreNote(request.contractAddress, request.owner, request.storageSlot, request.randomness, request.noteNonce, request.content, request.noteHash, request.nullifier, request.txHash, request.recipient));
|
|
320
337
|
const eventService = new EventService(this.anchorBlockHeader, this.aztecNode, this.privateEventStore, this.jobId);
|
|
@@ -327,7 +344,7 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
|
|
|
327
344
|
await this.capsuleStore.setCapsuleArray(contractAddress, noteValidationRequestsArrayBaseSlot, [], this.jobId);
|
|
328
345
|
await this.capsuleStore.setCapsuleArray(contractAddress, eventValidationRequestsArrayBaseSlot, [], this.jobId);
|
|
329
346
|
}
|
|
330
|
-
async
|
|
347
|
+
async bulkRetrieveLogs(contractAddress, logRetrievalRequestsArrayBaseSlot, logRetrievalResponsesArrayBaseSlot) {
|
|
331
348
|
// TODO(#10727): allow other contracts to process partial notes
|
|
332
349
|
if (!this.contractAddress.equals(contractAddress)) {
|
|
333
350
|
throw new Error(`Got a note validation request from ${contractAddress}, expected ${this.contractAddress}`);
|
|
@@ -335,14 +352,33 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
|
|
|
335
352
|
// We read all log retrieval requests and process them all concurrently. This makes the process much faster as we
|
|
336
353
|
// don't need to wait for the network round-trip.
|
|
337
354
|
const logRetrievalRequests = (await this.capsuleStore.readCapsuleArray(contractAddress, logRetrievalRequestsArrayBaseSlot, this.jobId)).map(LogRetrievalRequest.fromFields);
|
|
338
|
-
const logService = new LogService(this.aztecNode, this.anchorBlockHeader, this.keyStore, this.capsuleStore, this.recipientTaggingStore, this.senderAddressBookStore, this.addressStore, this.jobId, this.
|
|
355
|
+
const logService = new LogService(this.aztecNode, this.anchorBlockHeader, this.keyStore, this.capsuleStore, this.recipientTaggingStore, this.senderAddressBookStore, this.addressStore, this.jobId, this.logger.getBindings());
|
|
339
356
|
const maybeLogRetrievalResponses = await logService.bulkRetrieveLogs(logRetrievalRequests);
|
|
340
357
|
// Requests are cleared once we're done.
|
|
341
358
|
await this.capsuleStore.setCapsuleArray(contractAddress, logRetrievalRequestsArrayBaseSlot, [], this.jobId);
|
|
342
359
|
// The responses are stored as Option<LogRetrievalResponse> in a second CapsuleArray.
|
|
343
360
|
await this.capsuleStore.setCapsuleArray(contractAddress, logRetrievalResponsesArrayBaseSlot, maybeLogRetrievalResponses.map(LogRetrievalResponse.toSerializedOption), this.jobId);
|
|
344
361
|
}
|
|
345
|
-
|
|
362
|
+
async utilityResolveMessageContexts(contractAddress, messageContextRequestsArrayBaseSlot, messageContextResponsesArrayBaseSlot) {
|
|
363
|
+
try {
|
|
364
|
+
if (!this.contractAddress.equals(contractAddress)) {
|
|
365
|
+
throw new Error(`Got a message context request from ${contractAddress}, expected ${this.contractAddress}`);
|
|
366
|
+
}
|
|
367
|
+
const requestCapsules = await this.capsuleStore.readCapsuleArray(contractAddress, messageContextRequestsArrayBaseSlot, this.jobId);
|
|
368
|
+
const txHashes = requestCapsules.map((fields, i)=>{
|
|
369
|
+
if (fields.length !== 1) {
|
|
370
|
+
throw new Error(`Malformed message context request at index ${i}: expected 1 field (tx hash), got ${fields.length}`);
|
|
371
|
+
}
|
|
372
|
+
return fields[0];
|
|
373
|
+
});
|
|
374
|
+
const maybeMessageContexts = await this.messageContextService.resolveMessageContexts(txHashes, this.anchorBlockHeader.getBlockNumber());
|
|
375
|
+
// Leave response in response capsule array.
|
|
376
|
+
await this.capsuleStore.setCapsuleArray(contractAddress, messageContextResponsesArrayBaseSlot, maybeMessageContexts.map(MessageTxContext.toSerializedOption), this.jobId);
|
|
377
|
+
} finally{
|
|
378
|
+
await this.capsuleStore.setCapsuleArray(contractAddress, messageContextRequestsArrayBaseSlot, [], this.jobId);
|
|
379
|
+
}
|
|
380
|
+
}
|
|
381
|
+
storeCapsule(contractAddress, slot, capsule) {
|
|
346
382
|
if (!contractAddress.equals(this.contractAddress)) {
|
|
347
383
|
// TODO(#10727): instead of this check that this.contractAddress is allowed to access the external DB
|
|
348
384
|
throw new Error(`Contract ${contractAddress} is not allowed to access ${this.contractAddress}'s PXE DB`);
|
|
@@ -350,7 +386,7 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
|
|
|
350
386
|
this.capsuleStore.storeCapsule(this.contractAddress, slot, capsule, this.jobId);
|
|
351
387
|
return Promise.resolve();
|
|
352
388
|
}
|
|
353
|
-
async
|
|
389
|
+
async loadCapsule(contractAddress, slot) {
|
|
354
390
|
if (!contractAddress.equals(this.contractAddress)) {
|
|
355
391
|
// TODO(#10727): instead of this check that this.contractAddress is allowed to access the external DB
|
|
356
392
|
throw new Error(`Contract ${contractAddress} is not allowed to access ${this.contractAddress}'s PXE DB`);
|
|
@@ -358,7 +394,7 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
|
|
|
358
394
|
return(// TODO(#12425): On the following line, the pertinent capsule gets overshadowed by the transient one. Tackle this.
|
|
359
395
|
this.capsules.find((c)=>c.contractAddress.equals(contractAddress) && c.storageSlot.equals(slot))?.data ?? await this.capsuleStore.loadCapsule(this.contractAddress, slot, this.jobId));
|
|
360
396
|
}
|
|
361
|
-
|
|
397
|
+
deleteCapsule(contractAddress, slot) {
|
|
362
398
|
if (!contractAddress.equals(this.contractAddress)) {
|
|
363
399
|
// TODO(#10727): instead of this check that this.contractAddress is allowed to access the external DB
|
|
364
400
|
throw new Error(`Contract ${contractAddress} is not allowed to access ${this.contractAddress}'s PXE DB`);
|
|
@@ -366,7 +402,7 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
|
|
|
366
402
|
this.capsuleStore.deleteCapsule(this.contractAddress, slot, this.jobId);
|
|
367
403
|
return Promise.resolve();
|
|
368
404
|
}
|
|
369
|
-
|
|
405
|
+
copyCapsule(contractAddress, srcSlot, dstSlot, numEntries) {
|
|
370
406
|
if (!contractAddress.equals(this.contractAddress)) {
|
|
371
407
|
// TODO(#10727): instead of this check that this.contractAddress is allowed to access the external DB
|
|
372
408
|
throw new Error(`Contract ${contractAddress} is not allowed to access ${this.contractAddress}'s PXE DB`);
|
|
@@ -374,7 +410,7 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
|
|
|
374
410
|
return this.capsuleStore.copyCapsule(this.contractAddress, srcSlot, dstSlot, numEntries, this.jobId);
|
|
375
411
|
}
|
|
376
412
|
// TODO(#11849): consider replacing this oracle with a pure Noir implementation of aes decryption.
|
|
377
|
-
|
|
413
|
+
aes128Decrypt(ciphertext, iv, symKey) {
|
|
378
414
|
const aes128 = new Aes128();
|
|
379
415
|
return aes128.decryptBufferCBC(ciphertext, iv, symKey);
|
|
380
416
|
}
|
|
@@ -383,10 +419,7 @@ import { MessageLoadOracleInputs } from './message_load_oracle_inputs.js';
|
|
|
383
419
|
* @param address - The address to get the secret for.
|
|
384
420
|
* @param ephPk - The ephemeral public key to get the secret for.
|
|
385
421
|
* @returns The secret for the given address.
|
|
386
|
-
*/
|
|
387
|
-
return this.getSharedSecret(address, ephPk);
|
|
388
|
-
}
|
|
389
|
-
async getSharedSecret(address, ephPk) {
|
|
422
|
+
*/ async getSharedSecret(address, ephPk) {
|
|
390
423
|
// TODO(#12656): return an app-siloed secret
|
|
391
424
|
const recipientCompleteAddress = await this.getCompleteAddressOrFail(address);
|
|
392
425
|
const ivskM = await this.keyStore.getMasterSecretKey(recipientCompleteAddress.publicKeys.masterIncomingViewingPublicKey);
|