@aztec/pxe 0.0.1-commit.d431d1c → 0.0.1-commit.e310a4c8
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 +1 -1
- package/dest/block_synchronizer/block_synchronizer.d.ts +7 -5
- package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -1
- package/dest/block_synchronizer/block_synchronizer.js +56 -16
- package/dest/config/index.d.ts +3 -1
- package/dest/config/index.d.ts.map +1 -1
- package/dest/config/index.js +17 -0
- package/dest/contract_function_simulator/contract_function_simulator.d.ts +2 -4
- package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
- package/dest/contract_function_simulator/contract_function_simulator.js +8 -13
- package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts +1 -1
- package/dest/contract_function_simulator/noir-structs/event_validation_request.js +1 -1
- package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +1 -1
- package/dest/contract_function_simulator/noir-structs/note_validation_request.js +1 -1
- package/dest/contract_function_simulator/oracle/interfaces.d.ts +13 -10
- package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/oracle.d.ts +5 -3
- package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/oracle.js +28 -18
- package/dest/contract_function_simulator/oracle/private_execution.d.ts +2 -22
- package/dest/contract_function_simulator/oracle/private_execution.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/private_execution.js +0 -37
- package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +10 -3
- package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/private_execution_oracle.js +19 -8
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +29 -17
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
- package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +47 -45
- package/dest/contract_sync/index.d.ts +23 -0
- package/dest/contract_sync/index.d.ts.map +1 -0
- package/dest/contract_sync/index.js +54 -0
- package/dest/debug/pxe_debug_utils.d.ts +16 -6
- package/dest/debug/pxe_debug_utils.d.ts.map +1 -1
- package/dest/debug/pxe_debug_utils.js +20 -10
- package/dest/entrypoints/client/bundle/utils.d.ts +1 -1
- package/dest/entrypoints/client/bundle/utils.d.ts.map +1 -1
- package/dest/entrypoints/client/bundle/utils.js +12 -6
- 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 +13 -7
- package/dest/entrypoints/pxe_creation_options.d.ts +3 -2
- package/dest/entrypoints/pxe_creation_options.d.ts.map +1 -1
- package/dest/entrypoints/server/index.d.ts +2 -1
- package/dest/entrypoints/server/index.d.ts.map +1 -1
- package/dest/entrypoints/server/index.js +1 -0
- package/dest/entrypoints/server/utils.d.ts +1 -1
- package/dest/entrypoints/server/utils.d.ts.map +1 -1
- package/dest/entrypoints/server/utils.js +19 -8
- package/dest/events/event_service.d.ts +5 -6
- package/dest/events/event_service.d.ts.map +1 -1
- package/dest/events/event_service.js +6 -7
- 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 +5 -4
- package/dest/logs/log_service.d.ts.map +1 -1
- package/dest/logs/log_service.js +18 -15
- package/dest/notes/note_service.d.ts +6 -6
- package/dest/notes/note_service.d.ts.map +1 -1
- package/dest/notes/note_service.js +14 -14
- package/dest/oracle_version.d.ts +3 -3
- package/dest/oracle_version.d.ts.map +1 -1
- package/dest/oracle_version.js +4 -3
- 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 +2 -2
- package/dest/private_kernel/private_kernel_oracle.d.ts +3 -3
- package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
- package/dest/pxe.d.ts +1 -1
- package/dest/pxe.d.ts.map +1 -1
- package/dest/pxe.js +19 -15
- 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 +8 -1
- package/dest/storage/capsule_store/capsule_store.js +6 -8
- package/dest/storage/contract_store/contract_store.d.ts +1 -2
- package/dest/storage/contract_store/contract_store.d.ts.map +1 -1
- package/dest/storage/contract_store/contract_store.js +22 -25
- package/dest/storage/metadata.d.ts +1 -1
- package/dest/storage/metadata.js +1 -1
- package/dest/storage/note_store/note_store.d.ts +48 -50
- package/dest/storage/note_store/note_store.d.ts.map +1 -1
- package/dest/storage/note_store/note_store.js +276 -252
- package/dest/storage/note_store/stored_note.d.ts +16 -0
- package/dest/storage/note_store/stored_note.d.ts.map +1 -0
- package/dest/storage/note_store/stored_note.js +43 -0
- package/dest/storage/private_event_store/private_event_store.d.ts +17 -4
- package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -1
- package/dest/storage/private_event_store/private_event_store.js +198 -147
- package/dest/storage/private_event_store/stored_private_event.d.ts +23 -0
- package/dest/storage/private_event_store/stored_private_event.d.ts.map +1 -0
- package/dest/storage/private_event_store/stored_private_event.js +56 -0
- package/dest/storage/tagging_store/recipient_tagging_store.d.ts +1 -1
- 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 +1 -1
- package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -1
- package/dest/storage/tagging_store/sender_tagging_store.js +183 -113
- package/dest/tagging/get_all_logs_by_tags.d.ts +24 -0
- package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -0
- package/dest/tagging/get_all_logs_by_tags.js +46 -0
- package/dest/tagging/index.d.ts +2 -1
- package/dest/tagging/index.d.ts.map +1 -1
- package/dest/tagging/index.js +1 -0
- package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +3 -2
- 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 +2 -2
- package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +3 -2
- 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 +5 -2
- package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +3 -2
- package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -1
- package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +2 -2
- package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +1 -1
- 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 +5 -8
- package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +3 -2
- 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 +7 -4
- package/package.json +16 -16
- package/src/bin/check_oracle_version.ts +1 -0
- package/src/block_synchronizer/block_synchronizer.ts +70 -33
- package/src/config/index.ts +14 -0
- package/src/contract_function_simulator/contract_function_simulator.ts +7 -15
- package/src/contract_function_simulator/noir-structs/event_validation_request.ts +1 -1
- package/src/contract_function_simulator/noir-structs/note_validation_request.ts +1 -1
- package/src/contract_function_simulator/oracle/interfaces.ts +18 -9
- package/src/contract_function_simulator/oracle/oracle.ts +42 -19
- package/src/contract_function_simulator/oracle/private_execution.ts +1 -60
- package/src/contract_function_simulator/oracle/private_execution_oracle.ts +32 -10
- package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +67 -53
- package/src/contract_sync/index.ts +98 -0
- package/src/debug/pxe_debug_utils.ts +26 -11
- package/src/entrypoints/client/bundle/utils.ts +7 -14
- package/src/entrypoints/client/lazy/utils.ts +8 -14
- package/src/entrypoints/pxe_creation_options.ts +2 -1
- package/src/entrypoints/server/index.ts +1 -0
- package/src/entrypoints/server/utils.ts +15 -19
- package/src/events/event_service.ts +5 -7
- package/src/job_coordinator/job_coordinator.ts +4 -3
- package/src/logs/log_service.ts +29 -13
- package/src/notes/note_service.ts +21 -20
- package/src/oracle_version.ts +4 -3
- package/src/private_kernel/private_kernel_execution_prover.ts +6 -3
- package/src/private_kernel/private_kernel_oracle.ts +2 -2
- package/src/pxe.ts +48 -17
- package/src/storage/address_store/address_store.ts +15 -15
- package/src/storage/anchor_block_store/anchor_block_store.ts +8 -0
- package/src/storage/capsule_store/capsule_store.ts +8 -8
- package/src/storage/contract_store/contract_store.ts +22 -31
- package/src/storage/metadata.ts +1 -1
- package/src/storage/note_store/note_store.ts +314 -318
- package/src/storage/note_store/stored_note.ts +48 -0
- package/src/storage/private_event_store/private_event_store.ts +250 -190
- package/src/storage/private_event_store/stored_private_event.ts +73 -0
- package/src/storage/tagging_store/recipient_tagging_store.ts +31 -21
- package/src/storage/tagging_store/sender_address_book_store.ts +20 -14
- package/src/storage/tagging_store/sender_tagging_store.ts +210 -126
- package/src/tagging/get_all_logs_by_tags.ts +68 -0
- package/src/tagging/index.ts +1 -0
- package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +11 -1
- package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +7 -1
- package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +3 -1
- package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +5 -17
- package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +12 -3
- package/dest/tree_membership/tree_membership_service.d.ts +0 -50
- package/dest/tree_membership/tree_membership_service.d.ts.map +0 -1
- package/dest/tree_membership/tree_membership_service.js +0 -75
- package/src/tree_membership/tree_membership_service.ts +0 -97
|
@@ -1,18 +1,21 @@
|
|
|
1
|
+
import type { ARCHIVE_HEIGHT, NOTE_HASH_TREE_HEIGHT } from '@aztec/constants';
|
|
1
2
|
import type { BlockNumber } from '@aztec/foundation/branded-types';
|
|
2
3
|
import { Aes128 } from '@aztec/foundation/crypto/aes128';
|
|
3
4
|
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
4
5
|
import { Point } from '@aztec/foundation/curves/grumpkin';
|
|
5
6
|
import { LogLevels, applyStringFormatting, createLogger } from '@aztec/foundation/log';
|
|
7
|
+
import type { MembershipWitness } from '@aztec/foundation/trees';
|
|
6
8
|
import type { KeyStore } from '@aztec/key-store';
|
|
7
9
|
import type { AuthWitness } from '@aztec/stdlib/auth-witness';
|
|
8
10
|
import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
9
|
-
import {
|
|
11
|
+
import { BlockHash } from '@aztec/stdlib/block';
|
|
10
12
|
import type { CompleteAddress, ContractInstance } from '@aztec/stdlib/contract';
|
|
11
13
|
import { siloNullifier } from '@aztec/stdlib/hash';
|
|
12
14
|
import type { AztecNode } from '@aztec/stdlib/interfaces/server';
|
|
13
15
|
import type { KeyValidationRequest } from '@aztec/stdlib/kernel';
|
|
14
16
|
import { computeAddressSecret } from '@aztec/stdlib/keys';
|
|
15
17
|
import { deriveEcdhSharedSecret } from '@aztec/stdlib/logs';
|
|
18
|
+
import { getNonNullifiedL1ToL2MessageWitness } from '@aztec/stdlib/messaging';
|
|
16
19
|
import type { NoteStatus } from '@aztec/stdlib/note';
|
|
17
20
|
import { MerkleTreeId, type NullifierMembershipWitness, PublicDataWitness } from '@aztec/stdlib/trees';
|
|
18
21
|
import type { BlockHeader, Capsule } from '@aztec/stdlib/tx';
|
|
@@ -22,14 +25,12 @@ import { LogService } from '../../logs/log_service.js';
|
|
|
22
25
|
import { NoteService } from '../../notes/note_service.js';
|
|
23
26
|
import { ORACLE_VERSION } from '../../oracle_version.js';
|
|
24
27
|
import type { AddressStore } from '../../storage/address_store/address_store.js';
|
|
25
|
-
import type { AnchorBlockStore } from '../../storage/anchor_block_store/anchor_block_store.js';
|
|
26
28
|
import type { CapsuleStore } from '../../storage/capsule_store/capsule_store.js';
|
|
27
29
|
import type { ContractStore } from '../../storage/contract_store/contract_store.js';
|
|
28
30
|
import type { NoteStore } from '../../storage/note_store/note_store.js';
|
|
29
31
|
import type { PrivateEventStore } from '../../storage/private_event_store/private_event_store.js';
|
|
30
32
|
import type { RecipientTaggingStore } from '../../storage/tagging_store/recipient_tagging_store.js';
|
|
31
33
|
import type { SenderAddressBookStore } from '../../storage/tagging_store/sender_address_book_store.js';
|
|
32
|
-
import { TreeMembershipService } from '../../tree_membership/tree_membership_service.js';
|
|
33
34
|
import { EventValidationRequest } from '../noir-structs/event_validation_request.js';
|
|
34
35
|
import { LogRetrievalRequest } from '../noir-structs/log_retrieval_request.js';
|
|
35
36
|
import { LogRetrievalResponse } from '../noir-structs/log_retrieval_response.js';
|
|
@@ -59,7 +60,6 @@ export class UtilityExecutionOracle implements IMiscOracle, IUtilityExecutionOra
|
|
|
59
60
|
protected readonly keyStore: KeyStore,
|
|
60
61
|
protected readonly addressStore: AddressStore,
|
|
61
62
|
protected readonly aztecNode: AztecNode,
|
|
62
|
-
protected readonly anchorBlockStore: AnchorBlockStore,
|
|
63
63
|
protected readonly recipientTaggingStore: RecipientTaggingStore,
|
|
64
64
|
protected readonly senderAddressBookStore: SenderAddressBookStore,
|
|
65
65
|
protected readonly capsuleStore: CapsuleStore,
|
|
@@ -94,15 +94,35 @@ export class UtilityExecutionOracle implements IMiscOracle, IUtilityExecutionOra
|
|
|
94
94
|
}
|
|
95
95
|
|
|
96
96
|
/**
|
|
97
|
-
* Fetches the index and sibling path of a leaf at a given block from
|
|
98
|
-
* @param
|
|
99
|
-
*
|
|
100
|
-
* @param
|
|
101
|
-
* @returns The index and sibling path
|
|
97
|
+
* Fetches the index and sibling path of a leaf at a given block from the note hash tree.
|
|
98
|
+
* @param anchorBlockHash - The hash of a block that contains the note hash tree root in which to find the membership
|
|
99
|
+
* witness.
|
|
100
|
+
* @param noteHash - The note hash to find in the note hash tree.
|
|
101
|
+
* @returns The membership witness containing the leaf index and sibling path
|
|
102
102
|
*/
|
|
103
|
-
public
|
|
104
|
-
|
|
105
|
-
|
|
103
|
+
public utilityGetNoteHashMembershipWitness(
|
|
104
|
+
anchorBlockHash: BlockHash,
|
|
105
|
+
noteHash: Fr,
|
|
106
|
+
): Promise<MembershipWitness<typeof NOTE_HASH_TREE_HEIGHT> | undefined> {
|
|
107
|
+
return this.aztecNode.getNoteHashMembershipWitness(anchorBlockHash, noteHash);
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
/**
|
|
111
|
+
* Fetches the index and sibling path of a block hash in the archive tree.
|
|
112
|
+
*
|
|
113
|
+
* Block hashes are the leaves of the archive tree. Each time a new block is added to the chain,
|
|
114
|
+
* its block hash is appended as a new leaf to the archive tree.
|
|
115
|
+
*
|
|
116
|
+
* @param anchorBlockHash - The hash of a block that contains the archive tree root in which to find the membership
|
|
117
|
+
* witness.
|
|
118
|
+
* @param blockHash - The block hash to find in the archive tree.
|
|
119
|
+
* @returns The membership witness containing the leaf index and sibling path
|
|
120
|
+
*/
|
|
121
|
+
public utilityGetBlockHashMembershipWitness(
|
|
122
|
+
anchorBlockHash: BlockHash,
|
|
123
|
+
blockHash: BlockHash,
|
|
124
|
+
): Promise<MembershipWitness<typeof ARCHIVE_HEIGHT> | undefined> {
|
|
125
|
+
return this.aztecNode.getBlockHashMembershipWitness(anchorBlockHash, blockHash);
|
|
106
126
|
}
|
|
107
127
|
|
|
108
128
|
/**
|
|
@@ -111,11 +131,11 @@ export class UtilityExecutionOracle implements IMiscOracle, IUtilityExecutionOra
|
|
|
111
131
|
* @param nullifier - Nullifier we try to find witness for.
|
|
112
132
|
* @returns The nullifier membership witness (if found).
|
|
113
133
|
*/
|
|
114
|
-
public
|
|
115
|
-
blockHash:
|
|
134
|
+
public utilityGetNullifierMembershipWitness(
|
|
135
|
+
blockHash: BlockHash,
|
|
116
136
|
nullifier: Fr,
|
|
117
137
|
): Promise<NullifierMembershipWitness | undefined> {
|
|
118
|
-
return
|
|
138
|
+
return this.aztecNode.getNullifierMembershipWitness(blockHash, nullifier);
|
|
119
139
|
}
|
|
120
140
|
|
|
121
141
|
/**
|
|
@@ -127,12 +147,11 @@ export class UtilityExecutionOracle implements IMiscOracle, IUtilityExecutionOra
|
|
|
127
147
|
* list structure" of leaves and proving that a lower nullifier is pointing to a bigger next value than the nullifier
|
|
128
148
|
* we are trying to prove non-inclusion for.
|
|
129
149
|
*/
|
|
130
|
-
public
|
|
131
|
-
blockHash:
|
|
150
|
+
public utilityGetLowNullifierMembershipWitness(
|
|
151
|
+
blockHash: BlockHash,
|
|
132
152
|
nullifier: Fr,
|
|
133
153
|
): Promise<NullifierMembershipWitness | undefined> {
|
|
134
|
-
|
|
135
|
-
return await treeMembershipService.getLowNullifierMembershipWitness(blockHash, nullifier);
|
|
154
|
+
return this.aztecNode.getLowNullifierMembershipWitness(blockHash, nullifier);
|
|
136
155
|
}
|
|
137
156
|
|
|
138
157
|
/**
|
|
@@ -141,12 +160,8 @@ export class UtilityExecutionOracle implements IMiscOracle, IUtilityExecutionOra
|
|
|
141
160
|
* @param leafSlot - The slot of the public data tree to get the witness for.
|
|
142
161
|
* @returns - The witness
|
|
143
162
|
*/
|
|
144
|
-
public
|
|
145
|
-
blockHash
|
|
146
|
-
leafSlot: Fr,
|
|
147
|
-
): Promise<PublicDataWitness | undefined> {
|
|
148
|
-
const treeMembershipService = new TreeMembershipService(this.aztecNode);
|
|
149
|
-
return await treeMembershipService.getPublicDataWitness(blockHash, leafSlot);
|
|
163
|
+
public utilityGetPublicDataWitness(blockHash: BlockHash, leafSlot: Fr): Promise<PublicDataWitness | undefined> {
|
|
164
|
+
return this.aztecNode.getPublicDataWitness(blockHash, leafSlot);
|
|
150
165
|
}
|
|
151
166
|
|
|
152
167
|
/**
|
|
@@ -155,7 +170,7 @@ export class UtilityExecutionOracle implements IMiscOracle, IUtilityExecutionOra
|
|
|
155
170
|
* @returns Block extracted from a block with block number `blockNumber`.
|
|
156
171
|
*/
|
|
157
172
|
public async utilityGetBlockHeader(blockNumber: BlockNumber): Promise<BlockHeader | undefined> {
|
|
158
|
-
const anchorBlockNumber =
|
|
173
|
+
const anchorBlockNumber = this.anchorBlockHeader.getBlockNumber();
|
|
159
174
|
if (blockNumber > anchorBlockNumber) {
|
|
160
175
|
throw new Error(`Block number ${blockNumber} is higher than current block ${anchorBlockNumber}`);
|
|
161
176
|
}
|
|
@@ -251,7 +266,7 @@ export class UtilityExecutionOracle implements IMiscOracle, IUtilityExecutionOra
|
|
|
251
266
|
offset: number,
|
|
252
267
|
status: NoteStatus,
|
|
253
268
|
): Promise<NoteData[]> {
|
|
254
|
-
const noteService = new NoteService(this.noteStore, this.aztecNode, this.
|
|
269
|
+
const noteService = new NoteService(this.noteStore, this.aztecNode, this.anchorBlockHeader, this.jobId);
|
|
255
270
|
|
|
256
271
|
const dbNotes = await noteService.getNotes(this.contractAddress, owner, storageSlot, status, this.scopes);
|
|
257
272
|
return pickNotes<NoteData>(dbNotes, {
|
|
@@ -276,9 +291,8 @@ export class UtilityExecutionOracle implements IMiscOracle, IUtilityExecutionOra
|
|
|
276
291
|
*/
|
|
277
292
|
public async utilityCheckNullifierExists(innerNullifier: Fr) {
|
|
278
293
|
const nullifier = await siloNullifier(this.contractAddress, innerNullifier!);
|
|
279
|
-
const
|
|
280
|
-
|
|
281
|
-
return index !== undefined;
|
|
294
|
+
const [leafIndex] = await this.aztecNode.findLeavesIndexes('latest', MerkleTreeId.NULLIFIER_TREE, [nullifier]);
|
|
295
|
+
return leafIndex?.data !== undefined;
|
|
282
296
|
}
|
|
283
297
|
|
|
284
298
|
/**
|
|
@@ -290,14 +304,13 @@ export class UtilityExecutionOracle implements IMiscOracle, IUtilityExecutionOra
|
|
|
290
304
|
* @returns The l1 to l2 membership witness (index of message in the tree and sibling path).
|
|
291
305
|
*/
|
|
292
306
|
public async utilityGetL1ToL2MembershipWitness(contractAddress: AztecAddress, messageHash: Fr, secret: Fr) {
|
|
293
|
-
const
|
|
294
|
-
|
|
307
|
+
const [messageIndex, siblingPath] = await getNonNullifiedL1ToL2MessageWitness(
|
|
308
|
+
this.aztecNode,
|
|
295
309
|
contractAddress,
|
|
296
310
|
messageHash,
|
|
297
311
|
secret,
|
|
298
312
|
);
|
|
299
313
|
|
|
300
|
-
// Assuming messageIndex is what you intended to use for the index in MessageLoadOracleInputs
|
|
301
314
|
return new MessageLoadOracleInputs(messageIndex, siblingPath);
|
|
302
315
|
}
|
|
303
316
|
|
|
@@ -309,24 +322,23 @@ export class UtilityExecutionOracle implements IMiscOracle, IUtilityExecutionOra
|
|
|
309
322
|
* @param numberOfElements - Number of elements to read from the starting storage slot.
|
|
310
323
|
*/
|
|
311
324
|
public async utilityStorageRead(
|
|
312
|
-
blockHash:
|
|
325
|
+
blockHash: BlockHash,
|
|
313
326
|
contractAddress: AztecAddress,
|
|
314
327
|
startStorageSlot: Fr,
|
|
315
328
|
numberOfElements: number,
|
|
316
329
|
) {
|
|
317
|
-
const
|
|
330
|
+
const slots = Array(numberOfElements)
|
|
331
|
+
.fill(0)
|
|
332
|
+
.map((_, i) => new Fr(startStorageSlot.value + BigInt(i)));
|
|
318
333
|
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
334
|
+
const values = await Promise.all(
|
|
335
|
+
slots.map(storageSlot => this.aztecNode.getPublicStorageAt(blockHash, contractAddress, storageSlot)),
|
|
336
|
+
);
|
|
337
|
+
|
|
338
|
+
this.log.debug(
|
|
339
|
+
`Oracle storage read: slots=[${slots.map(slot => slot.toString()).join(', ')}] address=${contractAddress.toString()} values=[${values.join(', ')}]`,
|
|
340
|
+
);
|
|
324
341
|
|
|
325
|
-
this.log.debug(
|
|
326
|
-
`Oracle storage read: slot=${storageSlot.toString()} address-${contractAddress.toString()} value=${value}`,
|
|
327
|
-
);
|
|
328
|
-
values.push(value);
|
|
329
|
-
}
|
|
330
342
|
return values;
|
|
331
343
|
}
|
|
332
344
|
|
|
@@ -341,16 +353,17 @@ export class UtilityExecutionOracle implements IMiscOracle, IUtilityExecutionOra
|
|
|
341
353
|
public async utilityFetchTaggedLogs(pendingTaggedLogArrayBaseSlot: Fr) {
|
|
342
354
|
const logService = new LogService(
|
|
343
355
|
this.aztecNode,
|
|
344
|
-
this.
|
|
356
|
+
this.anchorBlockHeader,
|
|
345
357
|
this.keyStore,
|
|
346
358
|
this.capsuleStore,
|
|
347
359
|
this.recipientTaggingStore,
|
|
348
360
|
this.senderAddressBookStore,
|
|
349
361
|
this.addressStore,
|
|
350
362
|
this.jobId,
|
|
363
|
+
this.log.getBindings(),
|
|
351
364
|
);
|
|
352
365
|
|
|
353
|
-
const noteService = new NoteService(this.noteStore, this.aztecNode, this.
|
|
366
|
+
const noteService = new NoteService(this.noteStore, this.aztecNode, this.anchorBlockHeader, this.jobId);
|
|
354
367
|
|
|
355
368
|
// It is acceptable to run the following operations in parallel for several reasons:
|
|
356
369
|
// 1. syncTaggedLogs does not write to the note store — it only stores the pending tagged logs in a capsule array,
|
|
@@ -372,7 +385,7 @@ export class UtilityExecutionOracle implements IMiscOracle, IUtilityExecutionOra
|
|
|
372
385
|
* @param noteValidationRequestsArrayBaseSlot - The base slot of capsule array containing note validation requests.
|
|
373
386
|
* @param eventValidationRequestsArrayBaseSlot - The base slot of capsule array containing event validation requests.
|
|
374
387
|
*/
|
|
375
|
-
public async
|
|
388
|
+
public async utilityValidateAndStoreEnqueuedNotesAndEvents(
|
|
376
389
|
contractAddress: AztecAddress,
|
|
377
390
|
noteValidationRequestsArrayBaseSlot: Fr,
|
|
378
391
|
eventValidationRequestsArrayBaseSlot: Fr,
|
|
@@ -392,9 +405,9 @@ export class UtilityExecutionOracle implements IMiscOracle, IUtilityExecutionOra
|
|
|
392
405
|
await this.capsuleStore.readCapsuleArray(contractAddress, eventValidationRequestsArrayBaseSlot, this.jobId)
|
|
393
406
|
).map(EventValidationRequest.fromFields);
|
|
394
407
|
|
|
395
|
-
const noteService = new NoteService(this.noteStore, this.aztecNode, this.
|
|
408
|
+
const noteService = new NoteService(this.noteStore, this.aztecNode, this.anchorBlockHeader, this.jobId);
|
|
396
409
|
const noteStorePromises = noteValidationRequests.map(request =>
|
|
397
|
-
noteService.
|
|
410
|
+
noteService.validateAndStoreNote(
|
|
398
411
|
request.contractAddress,
|
|
399
412
|
request.owner,
|
|
400
413
|
request.storageSlot,
|
|
@@ -408,9 +421,9 @@ export class UtilityExecutionOracle implements IMiscOracle, IUtilityExecutionOra
|
|
|
408
421
|
),
|
|
409
422
|
);
|
|
410
423
|
|
|
411
|
-
const eventService = new EventService(this.
|
|
424
|
+
const eventService = new EventService(this.anchorBlockHeader, this.aztecNode, this.privateEventStore, this.jobId);
|
|
412
425
|
const eventStorePromises = eventValidationRequests.map(request =>
|
|
413
|
-
eventService.
|
|
426
|
+
eventService.validateAndStoreEvent(
|
|
414
427
|
request.contractAddress,
|
|
415
428
|
request.eventTypeId,
|
|
416
429
|
request.randomness,
|
|
@@ -446,13 +459,14 @@ export class UtilityExecutionOracle implements IMiscOracle, IUtilityExecutionOra
|
|
|
446
459
|
|
|
447
460
|
const logService = new LogService(
|
|
448
461
|
this.aztecNode,
|
|
449
|
-
this.
|
|
462
|
+
this.anchorBlockHeader,
|
|
450
463
|
this.keyStore,
|
|
451
464
|
this.capsuleStore,
|
|
452
465
|
this.recipientTaggingStore,
|
|
453
466
|
this.senderAddressBookStore,
|
|
454
467
|
this.addressStore,
|
|
455
468
|
this.jobId,
|
|
469
|
+
this.log.getBindings(),
|
|
456
470
|
);
|
|
457
471
|
|
|
458
472
|
const maybeLogRetrievalResponses = await logService.bulkRetrieveLogs(logRetrievalRequests);
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
import { ProtocolContractAddress, isProtocolContract } from '@aztec/protocol-contracts';
|
|
2
|
+
import type { FunctionCall, FunctionSelector } from '@aztec/stdlib/abi';
|
|
3
|
+
import type { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
4
|
+
import type { ContractInstance } from '@aztec/stdlib/contract';
|
|
5
|
+
import { DelayedPublicMutableValues, DelayedPublicMutableValuesWithHash } from '@aztec/stdlib/delayed-public-mutable';
|
|
6
|
+
import type { AztecNode } from '@aztec/stdlib/interfaces/client';
|
|
7
|
+
import type { BlockHeader } from '@aztec/stdlib/tx';
|
|
8
|
+
|
|
9
|
+
import type { ContractStore } from '../storage/contract_store/contract_store.js';
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* Read the current class id of a contract from the execution data provider or AztecNode. If not found, class id
|
|
13
|
+
* from the instance is used.
|
|
14
|
+
* @param contractAddress - The address of the contract to read the class id for.
|
|
15
|
+
* @param instance - The instance of the contract.
|
|
16
|
+
* @param aztecNode - The Aztec node to query for storage.
|
|
17
|
+
* @param header - The header of the block at which to load the DelayedPublicMutable storing the class id.
|
|
18
|
+
* @returns The current class id.
|
|
19
|
+
*/
|
|
20
|
+
export async function readCurrentClassId(
|
|
21
|
+
contractAddress: AztecAddress,
|
|
22
|
+
instance: ContractInstance,
|
|
23
|
+
aztecNode: AztecNode,
|
|
24
|
+
header: BlockHeader,
|
|
25
|
+
) {
|
|
26
|
+
const blockHash = await header.hash();
|
|
27
|
+
const timestamp = header.globalVariables.timestamp;
|
|
28
|
+
const { delayedPublicMutableSlot } = await DelayedPublicMutableValuesWithHash.getContractUpdateSlots(contractAddress);
|
|
29
|
+
const delayedPublicMutableValues = await DelayedPublicMutableValues.readFromTree(delayedPublicMutableSlot, slot =>
|
|
30
|
+
aztecNode.getPublicStorageAt(blockHash, ProtocolContractAddress.ContractInstanceRegistry, slot),
|
|
31
|
+
);
|
|
32
|
+
let currentClassId = delayedPublicMutableValues.svc.getCurrentAt(timestamp)[0];
|
|
33
|
+
if (currentClassId.isZero()) {
|
|
34
|
+
currentClassId = instance.originalContractClassId;
|
|
35
|
+
}
|
|
36
|
+
return currentClassId;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
export async function syncState(
|
|
40
|
+
contractAddress: AztecAddress,
|
|
41
|
+
contractStore: ContractStore,
|
|
42
|
+
functionToInvokeAfterSync: FunctionSelector | null,
|
|
43
|
+
utilityExecutor: (privateSyncCall: FunctionCall) => Promise<any>,
|
|
44
|
+
) {
|
|
45
|
+
// Protocol contracts don't have private state to sync
|
|
46
|
+
if (!isProtocolContract(contractAddress)) {
|
|
47
|
+
const syncStateFunctionCall = await contractStore.getFunctionCall('sync_state', [], contractAddress);
|
|
48
|
+
if (functionToInvokeAfterSync && functionToInvokeAfterSync.equals(syncStateFunctionCall.selector)) {
|
|
49
|
+
throw new Error(
|
|
50
|
+
'Forbidden `sync_state` invocation. `sync_state` can only be invoked by PXE, manual execution can lead to inconsistencies.',
|
|
51
|
+
);
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
return utilityExecutor(syncStateFunctionCall);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
/**
|
|
59
|
+
* Verify that the current class id of a contract obtained from AztecNode is the same as the one in contract data
|
|
60
|
+
* provider (i.e. PXE's own storage).
|
|
61
|
+
* @param header - The header of the block at which to verify the current class id.
|
|
62
|
+
*/
|
|
63
|
+
async function verifyCurrentClassId(
|
|
64
|
+
contractAddress: AztecAddress,
|
|
65
|
+
aztecNode: AztecNode,
|
|
66
|
+
contractStore: ContractStore,
|
|
67
|
+
header: BlockHeader,
|
|
68
|
+
) {
|
|
69
|
+
const instance = await contractStore.getContractInstance(contractAddress);
|
|
70
|
+
if (!instance) {
|
|
71
|
+
throw new Error(`No contract instance found for address ${contractAddress.toString()}`);
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
const currentClassId = await readCurrentClassId(contractAddress, instance, aztecNode, header);
|
|
75
|
+
if (!instance.currentContractClassId.equals(currentClassId)) {
|
|
76
|
+
throw new Error(
|
|
77
|
+
`Contract ${contractAddress} is outdated, current class id is ${currentClassId}, local class id is ${instance.currentContractClassId}`,
|
|
78
|
+
);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
/**
|
|
83
|
+
* Ensures the contract's private state is synchronized and that the PXE holds the current class artifact for
|
|
84
|
+
* the contract.
|
|
85
|
+
*/
|
|
86
|
+
export async function ensureContractSynced(
|
|
87
|
+
contractAddress: AztecAddress,
|
|
88
|
+
functionToInvokeAfterSync: FunctionSelector | null,
|
|
89
|
+
utilityExecutor: (call: FunctionCall) => Promise<any>,
|
|
90
|
+
aztecNode: AztecNode,
|
|
91
|
+
contractStore: ContractStore,
|
|
92
|
+
header: BlockHeader,
|
|
93
|
+
): Promise<void> {
|
|
94
|
+
await Promise.all([
|
|
95
|
+
syncState(contractAddress, contractStore, functionToInvokeAfterSync, utilityExecutor),
|
|
96
|
+
verifyCurrentClassId(contractAddress, aztecNode, contractStore, header),
|
|
97
|
+
]);
|
|
98
|
+
}
|
|
@@ -1,7 +1,11 @@
|
|
|
1
|
+
import { randomBytes } from '@aztec/foundation/crypto/random';
|
|
1
2
|
import type { NoteDao, NotesFilter } from '@aztec/stdlib/note';
|
|
3
|
+
import type { BlockHeader } from '@aztec/stdlib/tx';
|
|
2
4
|
|
|
5
|
+
import type { BlockSynchronizer } from '../block_synchronizer/block_synchronizer.js';
|
|
3
6
|
import type { PXE } from '../pxe.js';
|
|
4
7
|
import type { ContractStore } from '../storage/contract_store/contract_store.js';
|
|
8
|
+
import type { AnchorBlockStore } from '../storage/index.js';
|
|
5
9
|
import type { NoteStore } from '../storage/note_store/note_store.js';
|
|
6
10
|
|
|
7
11
|
/**
|
|
@@ -9,18 +13,20 @@ import type { NoteStore } from '../storage/note_store/note_store.js';
|
|
|
9
13
|
* No backwards compatibility or API stability should be expected. Use at your own risk.
|
|
10
14
|
*/
|
|
11
15
|
export class PXEDebugUtils {
|
|
12
|
-
#pxe
|
|
16
|
+
#pxe!: PXE;
|
|
17
|
+
#putJobInQueue!: <T>(job: (jobId: string) => Promise<T>) => Promise<T>;
|
|
13
18
|
|
|
14
19
|
constructor(
|
|
15
20
|
private contractStore: ContractStore,
|
|
16
21
|
private noteStore: NoteStore,
|
|
22
|
+
private blockStateSynchronizer: BlockSynchronizer,
|
|
23
|
+
private anchorBlockStore: AnchorBlockStore,
|
|
17
24
|
) {}
|
|
18
25
|
|
|
19
|
-
/**
|
|
20
|
-
|
|
21
|
-
*/
|
|
22
|
-
public setPXE(pxe: PXE) {
|
|
26
|
+
/** Not injected through constructor since they're are co-dependant */
|
|
27
|
+
public setPXE(pxe: PXE, putJobInQueue: <T>(job: (jobId: string) => Promise<T>) => Promise<T>) {
|
|
23
28
|
this.#pxe = pxe;
|
|
29
|
+
this.#putJobInQueue = putJobInQueue;
|
|
24
30
|
}
|
|
25
31
|
|
|
26
32
|
/**
|
|
@@ -35,14 +41,23 @@ export class PXEDebugUtils {
|
|
|
35
41
|
* @returns The requested notes.
|
|
36
42
|
*/
|
|
37
43
|
public async getNotes(filter: NotesFilter): Promise<NoteDao[]> {
|
|
38
|
-
if (!this.#pxe) {
|
|
39
|
-
throw new Error('Cannot getNotes because no PXE is set');
|
|
40
|
-
}
|
|
41
|
-
|
|
42
44
|
// We need to manually trigger private state sync to have a guarantee that all the notes are available.
|
|
43
|
-
const call = await this.contractStore.getFunctionCall('
|
|
45
|
+
const call = await this.contractStore.getFunctionCall('sync_state', [], filter.contractAddress);
|
|
44
46
|
await this.#pxe.simulateUtility(call);
|
|
45
47
|
|
|
46
|
-
return this.noteStore.getNotes(filter);
|
|
48
|
+
return this.noteStore.getNotes(filter, randomBytes(8).toString('hex'));
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
/** Returns the block header up to which the PXE has synced. */
|
|
52
|
+
public getSyncedBlockHeader(): Promise<BlockHeader> {
|
|
53
|
+
return this.anchorBlockStore.getBlockHeader();
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
/**
|
|
57
|
+
* Triggers a sync of the PXE with the node.
|
|
58
|
+
* Blocks until the sync is complete.
|
|
59
|
+
*/
|
|
60
|
+
public sync(): Promise<void> {
|
|
61
|
+
return this.#putJobInQueue(() => this.blockStateSynchronizer.sync());
|
|
47
62
|
}
|
|
48
63
|
}
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { BBPrivateKernelProver } from '@aztec/bb-prover/client';
|
|
2
2
|
import { BBBundlePrivateKernelProver } from '@aztec/bb-prover/client/bundle';
|
|
3
|
-
import { randomBytes } from '@aztec/foundation/crypto/random';
|
|
4
3
|
import { createLogger } from '@aztec/foundation/log';
|
|
5
4
|
import { createStore } from '@aztec/kv-store/indexeddb';
|
|
6
5
|
import { BundledProtocolContractsProvider } from '@aztec/protocol-contracts/providers/bundle';
|
|
@@ -9,6 +8,7 @@ import type { AztecNode } from '@aztec/stdlib/interfaces/client';
|
|
|
9
8
|
|
|
10
9
|
import type { PXEConfig } from '../../../config/index.js';
|
|
11
10
|
import { PXE } from '../../../pxe.js';
|
|
11
|
+
import { PXE_DATA_SCHEMA_VERSION } from '../../../storage/metadata.js';
|
|
12
12
|
import type { PXECreationOptions } from '../../pxe_creation_options.js';
|
|
13
13
|
|
|
14
14
|
/**
|
|
@@ -26,13 +26,7 @@ export async function createPXE(
|
|
|
26
26
|
config: PXEConfig,
|
|
27
27
|
options: PXECreationOptions = { loggers: {} },
|
|
28
28
|
) {
|
|
29
|
-
const
|
|
30
|
-
typeof options.useLogSuffix === 'boolean'
|
|
31
|
-
? options.useLogSuffix
|
|
32
|
-
? randomBytes(3).toString('hex')
|
|
33
|
-
: undefined
|
|
34
|
-
: options.useLogSuffix;
|
|
35
|
-
|
|
29
|
+
const actor = options.loggerActorLabel;
|
|
36
30
|
const loggers = options.loggers ?? {};
|
|
37
31
|
|
|
38
32
|
const l1Contracts = await aztecNode.getL1ContractAddresses();
|
|
@@ -41,14 +35,13 @@ export async function createPXE(
|
|
|
41
35
|
l1Contracts,
|
|
42
36
|
} as PXEConfig;
|
|
43
37
|
|
|
44
|
-
const storeLogger = loggers.store
|
|
38
|
+
const storeLogger = loggers.store ?? createLogger('pxe:data:idb', { actor });
|
|
45
39
|
|
|
46
|
-
const store =
|
|
40
|
+
const store =
|
|
41
|
+
options.store ?? (await createStore('pxe_data', configWithContracts, PXE_DATA_SCHEMA_VERSION, storeLogger));
|
|
47
42
|
|
|
48
43
|
const simulator = options.simulator ?? new WASMSimulator();
|
|
49
|
-
const proverLogger = loggers.prover
|
|
50
|
-
? loggers.prover
|
|
51
|
-
: createLogger('pxe:bb:wasm:bundle' + (logSuffix ? `:${logSuffix}` : ''));
|
|
44
|
+
const proverLogger = loggers.prover ?? createLogger('pxe:bb:wasm:bundle', { actor });
|
|
52
45
|
|
|
53
46
|
let prover;
|
|
54
47
|
if (options.proverOrOptions instanceof BBPrivateKernelProver) {
|
|
@@ -58,7 +51,7 @@ export async function createPXE(
|
|
|
58
51
|
}
|
|
59
52
|
const protocolContractsProvider = new BundledProtocolContractsProvider();
|
|
60
53
|
|
|
61
|
-
const pxeLogger = loggers.pxe
|
|
54
|
+
const pxeLogger = loggers.pxe ?? createLogger('pxe:service', { actor });
|
|
62
55
|
const pxe = await PXE.create(aztecNode, store, prover, simulator, protocolContractsProvider, config, pxeLogger);
|
|
63
56
|
return pxe;
|
|
64
57
|
}
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { BBPrivateKernelProver } from '@aztec/bb-prover/client';
|
|
2
2
|
import { BBLazyPrivateKernelProver } from '@aztec/bb-prover/client/lazy';
|
|
3
|
-
import { randomBytes } from '@aztec/foundation/crypto/random';
|
|
4
3
|
import { createLogger } from '@aztec/foundation/log';
|
|
5
4
|
import { createStore } from '@aztec/kv-store/indexeddb';
|
|
6
5
|
import { LazyProtocolContractsProvider } from '@aztec/protocol-contracts/providers/lazy';
|
|
@@ -9,6 +8,7 @@ import type { AztecNode } from '@aztec/stdlib/interfaces/client';
|
|
|
9
8
|
|
|
10
9
|
import type { PXEConfig } from '../../../config/index.js';
|
|
11
10
|
import { PXE } from '../../../pxe.js';
|
|
11
|
+
import { PXE_DATA_SCHEMA_VERSION } from '../../../storage/metadata.js';
|
|
12
12
|
import type { PXECreationOptions } from '../../pxe_creation_options.js';
|
|
13
13
|
|
|
14
14
|
/**
|
|
@@ -17,7 +17,7 @@ import type { PXECreationOptions } from '../../pxe_creation_options.js';
|
|
|
17
17
|
*
|
|
18
18
|
* @param aztecNode - The AztecNode instance to be used by the server.
|
|
19
19
|
* @param config - The PXE Config to use
|
|
20
|
-
* @param
|
|
20
|
+
* @param options - (Optional) Optional information for creating an PXE.
|
|
21
21
|
* @returns A Promise that resolves to the started PXE instance.
|
|
22
22
|
*/
|
|
23
23
|
export async function createPXE(
|
|
@@ -25,12 +25,7 @@ export async function createPXE(
|
|
|
25
25
|
config: PXEConfig,
|
|
26
26
|
options: PXECreationOptions = { loggers: {} },
|
|
27
27
|
) {
|
|
28
|
-
const
|
|
29
|
-
typeof options.useLogSuffix === 'boolean'
|
|
30
|
-
? options.useLogSuffix
|
|
31
|
-
? randomBytes(3).toString('hex')
|
|
32
|
-
: undefined
|
|
33
|
-
: options.useLogSuffix;
|
|
28
|
+
const actor = options.loggerActorLabel;
|
|
34
29
|
|
|
35
30
|
const l1Contracts = await aztecNode.getL1ContractAddresses();
|
|
36
31
|
const configWithContracts = {
|
|
@@ -40,14 +35,13 @@ export async function createPXE(
|
|
|
40
35
|
|
|
41
36
|
const loggers = options.loggers ?? {};
|
|
42
37
|
|
|
43
|
-
const storeLogger = loggers.store
|
|
38
|
+
const storeLogger = loggers.store ?? createLogger('pxe:data:idb', { actor });
|
|
44
39
|
|
|
45
|
-
const store =
|
|
40
|
+
const store =
|
|
41
|
+
options.store ?? (await createStore('pxe_data', configWithContracts, PXE_DATA_SCHEMA_VERSION, storeLogger));
|
|
46
42
|
|
|
47
43
|
const simulator = options.simulator ?? new WASMSimulator();
|
|
48
|
-
const proverLogger = loggers.prover
|
|
49
|
-
? loggers.prover
|
|
50
|
-
: createLogger('pxe:bb:wasm:bundle' + (logSuffix ? `:${logSuffix}` : ''));
|
|
44
|
+
const proverLogger = loggers.prover ?? createLogger('pxe:bb:wasm:bundle', { actor });
|
|
51
45
|
|
|
52
46
|
let prover;
|
|
53
47
|
if (options.proverOrOptions instanceof BBPrivateKernelProver) {
|
|
@@ -57,7 +51,7 @@ export async function createPXE(
|
|
|
57
51
|
}
|
|
58
52
|
const protocolContractsProvider = new LazyProtocolContractsProvider();
|
|
59
53
|
|
|
60
|
-
const pxeLogger = loggers.pxe
|
|
54
|
+
const pxeLogger = loggers.pxe ?? createLogger('pxe:service', { actor });
|
|
61
55
|
const pxe = await PXE.create(aztecNode, store, prover, simulator, protocolContractsProvider, config, pxeLogger);
|
|
62
56
|
return pxe;
|
|
63
57
|
}
|
|
@@ -6,7 +6,8 @@ import type { PrivateKernelProver } from '@aztec/stdlib/interfaces/client';
|
|
|
6
6
|
|
|
7
7
|
export type PXECreationOptions = {
|
|
8
8
|
loggers?: { store?: Logger; pxe?: Logger; prover?: Logger };
|
|
9
|
-
|
|
9
|
+
/** Actor label to include in log output (e.g., 'pxe-0', 'pxe-test'). */
|
|
10
|
+
loggerActorLabel?: string;
|
|
10
11
|
proverOrOptions?: PrivateKernelProver | BBPrivateKernelProverOptions;
|
|
11
12
|
store?: AztecAsyncKVStore;
|
|
12
13
|
simulator?: CircuitSimulator;
|
|
@@ -7,3 +7,4 @@ export { NoteService } from '../../notes/note_service.js';
|
|
|
7
7
|
export { ORACLE_VERSION } from '../../oracle_version.js';
|
|
8
8
|
export { type PXECreationOptions } from '../pxe_creation_options.js';
|
|
9
9
|
export { JobCoordinator } from '../../job_coordinator/job_coordinator.js';
|
|
10
|
+
export { syncState } from '../../contract_sync/index.js';
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { BBPrivateKernelProver } from '@aztec/bb-prover/client';
|
|
2
2
|
import { BBBundlePrivateKernelProver } from '@aztec/bb-prover/client/bundle';
|
|
3
|
-
import { randomBytes } from '@aztec/foundation/crypto/random';
|
|
4
3
|
import { createLogger } from '@aztec/foundation/log';
|
|
5
4
|
import { createStore } from '@aztec/kv-store/lmdb-v2';
|
|
6
5
|
import { BundledProtocolContractsProvider } from '@aztec/protocol-contracts/providers/bundle';
|
|
@@ -20,17 +19,13 @@ export async function createPXE(
|
|
|
20
19
|
config: PXEConfigWithoutDefaults,
|
|
21
20
|
options: PXECreationOptions = { loggers: {} },
|
|
22
21
|
) {
|
|
22
|
+
const actor = options.loggerActorLabel;
|
|
23
|
+
const recorderLogger = createLogger('simulator:acvm:recording', { actor });
|
|
23
24
|
const recorder = process.env.CIRCUIT_RECORD_DIR
|
|
24
|
-
? new FileCircuitRecorder(process.env.CIRCUIT_RECORD_DIR)
|
|
25
|
-
: new MemoryCircuitRecorder();
|
|
26
|
-
const
|
|
27
|
-
|
|
28
|
-
const logSuffix =
|
|
29
|
-
typeof options.useLogSuffix === 'boolean'
|
|
30
|
-
? options.useLogSuffix
|
|
31
|
-
? randomBytes(3).toString('hex')
|
|
32
|
-
: undefined
|
|
33
|
-
: options.useLogSuffix;
|
|
25
|
+
? new FileCircuitRecorder(process.env.CIRCUIT_RECORD_DIR, recorderLogger)
|
|
26
|
+
: new MemoryCircuitRecorder(recorderLogger);
|
|
27
|
+
const simulatorLogger = createLogger('wasm-simulator', { actor });
|
|
28
|
+
const simulator = new SimulatorRecorderWrapper(new WASMSimulator(simulatorLogger), recorder);
|
|
34
29
|
const loggers = options.loggers ?? {};
|
|
35
30
|
|
|
36
31
|
const { l1ChainId, l1ContractAddresses: l1Contracts, rollupVersion } = await aztecNode.getNodeInfo();
|
|
@@ -43,14 +38,15 @@ export async function createPXE(
|
|
|
43
38
|
};
|
|
44
39
|
|
|
45
40
|
if (!options.store) {
|
|
46
|
-
const storeLogger = loggers.store
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
41
|
+
const storeLogger = loggers.store ?? createLogger('pxe:data:lmdb', { actor });
|
|
42
|
+
options.store = await createStore(
|
|
43
|
+
'pxe_data',
|
|
44
|
+
PXE_DATA_SCHEMA_VERSION,
|
|
45
|
+
configWithContracts,
|
|
46
|
+
storeLogger.getBindings(),
|
|
47
|
+
);
|
|
50
48
|
}
|
|
51
|
-
const proverLogger = loggers.prover
|
|
52
|
-
? loggers.prover
|
|
53
|
-
: createLogger('pxe:bb:native' + (logSuffix ? `:${logSuffix}` : ''));
|
|
49
|
+
const proverLogger = loggers.prover ?? createLogger('pxe:bb:native', { actor });
|
|
54
50
|
|
|
55
51
|
let prover;
|
|
56
52
|
if (options.proverOrOptions instanceof BBPrivateKernelProver) {
|
|
@@ -61,7 +57,7 @@ export async function createPXE(
|
|
|
61
57
|
|
|
62
58
|
const protocolContractsProvider = new BundledProtocolContractsProvider();
|
|
63
59
|
|
|
64
|
-
const pxeLogger = loggers.pxe
|
|
60
|
+
const pxeLogger = loggers.pxe ?? createLogger('pxe:service', { actor });
|
|
65
61
|
const pxe = await PXE.create(
|
|
66
62
|
aztecNode,
|
|
67
63
|
options.store,
|