@aztec/pxe 0.0.1-commit.c80b6263 → 0.0.1-commit.cd76b27

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.
Files changed (156) hide show
  1. package/dest/access_scopes.d.ts +9 -0
  2. package/dest/access_scopes.d.ts.map +1 -0
  3. package/dest/access_scopes.js +6 -0
  4. package/dest/block_synchronizer/block_synchronizer.d.ts +4 -2
  5. package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -1
  6. package/dest/block_synchronizer/block_synchronizer.js +7 -1
  7. package/dest/config/package_info.js +1 -1
  8. package/dest/contract_function_simulator/contract_function_simulator.d.ts +54 -30
  9. package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
  10. package/dest/contract_function_simulator/contract_function_simulator.js +172 -68
  11. package/dest/contract_function_simulator/noir-structs/event_validation_request.js +1 -1
  12. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +2 -2
  13. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts.map +1 -1
  14. package/dest/contract_function_simulator/noir-structs/note_validation_request.js +1 -1
  15. package/dest/contract_function_simulator/oracle/interfaces.d.ts +9 -9
  16. package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
  17. package/dest/contract_function_simulator/oracle/oracle.d.ts +5 -5
  18. package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
  19. package/dest/contract_function_simulator/oracle/oracle.js +32 -20
  20. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +36 -36
  21. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
  22. package/dest/contract_function_simulator/oracle/private_execution_oracle.js +74 -21
  23. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +48 -24
  24. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
  25. package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +85 -61
  26. package/dest/contract_sync/contract_sync_service.d.ts +43 -0
  27. package/dest/contract_sync/contract_sync_service.d.ts.map +1 -0
  28. package/dest/contract_sync/contract_sync_service.js +97 -0
  29. package/dest/contract_sync/helpers.d.ts +29 -0
  30. package/dest/contract_sync/helpers.d.ts.map +1 -0
  31. package/dest/contract_sync/{index.js → helpers.js} +13 -12
  32. package/dest/debug/pxe_debug_utils.d.ts +14 -10
  33. package/dest/debug/pxe_debug_utils.d.ts.map +1 -1
  34. package/dest/debug/pxe_debug_utils.js +16 -15
  35. package/dest/entrypoints/client/bundle/index.d.ts +3 -1
  36. package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
  37. package/dest/entrypoints/client/bundle/index.js +2 -0
  38. package/dest/entrypoints/client/bundle/utils.d.ts +1 -1
  39. package/dest/entrypoints/client/bundle/utils.d.ts.map +1 -1
  40. package/dest/entrypoints/client/bundle/utils.js +11 -2
  41. package/dest/entrypoints/client/lazy/index.d.ts +3 -1
  42. package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
  43. package/dest/entrypoints/client/lazy/index.js +2 -0
  44. package/dest/entrypoints/client/lazy/utils.d.ts +1 -1
  45. package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
  46. package/dest/entrypoints/client/lazy/utils.js +11 -2
  47. package/dest/entrypoints/server/index.d.ts +4 -2
  48. package/dest/entrypoints/server/index.d.ts.map +1 -1
  49. package/dest/entrypoints/server/index.js +3 -1
  50. package/dest/entrypoints/server/utils.js +9 -1
  51. package/dest/events/event_service.d.ts +4 -5
  52. package/dest/events/event_service.d.ts.map +1 -1
  53. package/dest/events/event_service.js +5 -6
  54. package/dest/logs/log_service.d.ts +6 -5
  55. package/dest/logs/log_service.d.ts.map +1 -1
  56. package/dest/logs/log_service.js +14 -24
  57. package/dest/notes/note_service.d.ts +7 -7
  58. package/dest/notes/note_service.d.ts.map +1 -1
  59. package/dest/notes/note_service.js +9 -9
  60. package/dest/notes_filter.d.ts +25 -0
  61. package/dest/notes_filter.d.ts.map +1 -0
  62. package/dest/notes_filter.js +4 -0
  63. package/dest/oracle_version.d.ts +3 -3
  64. package/dest/oracle_version.d.ts.map +1 -1
  65. package/dest/oracle_version.js +2 -2
  66. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts +4 -0
  67. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts.map +1 -0
  68. package/dest/private_kernel/hints/{compute_tx_include_by_timestamp.js → compute_tx_expiration_timestamp.js} +12 -12
  69. package/dest/private_kernel/hints/index.d.ts +1 -1
  70. package/dest/private_kernel/hints/index.js +1 -1
  71. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.js +4 -4
  72. package/dest/private_kernel/private_kernel_execution_prover.js +6 -6
  73. package/dest/pxe.d.ts +69 -23
  74. package/dest/pxe.d.ts.map +1 -1
  75. package/dest/pxe.js +78 -50
  76. package/dest/storage/address_store/address_store.d.ts +1 -1
  77. package/dest/storage/address_store/address_store.d.ts.map +1 -1
  78. package/dest/storage/address_store/address_store.js +12 -11
  79. package/dest/storage/anchor_block_store/anchor_block_store.d.ts +9 -1
  80. package/dest/storage/anchor_block_store/anchor_block_store.d.ts.map +1 -1
  81. package/dest/storage/anchor_block_store/anchor_block_store.js +8 -1
  82. package/dest/storage/capsule_store/capsule_store.js +6 -8
  83. package/dest/storage/contract_store/contract_store.d.ts +1 -1
  84. package/dest/storage/contract_store/contract_store.d.ts.map +1 -1
  85. package/dest/storage/contract_store/contract_store.js +27 -18
  86. package/dest/storage/metadata.d.ts +1 -1
  87. package/dest/storage/metadata.js +1 -1
  88. package/dest/storage/note_store/note_store.d.ts +13 -3
  89. package/dest/storage/note_store/note_store.d.ts.map +1 -1
  90. package/dest/storage/note_store/note_store.js +147 -107
  91. package/dest/storage/private_event_store/private_event_store.d.ts +1 -1
  92. package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -1
  93. package/dest/storage/private_event_store/private_event_store.js +84 -61
  94. package/dest/storage/private_event_store/stored_private_event.js +1 -1
  95. package/dest/storage/tagging_store/recipient_tagging_store.d.ts +1 -1
  96. package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -1
  97. package/dest/storage/tagging_store/recipient_tagging_store.js +31 -19
  98. package/dest/storage/tagging_store/sender_address_book_store.d.ts +1 -1
  99. package/dest/storage/tagging_store/sender_address_book_store.d.ts.map +1 -1
  100. package/dest/storage/tagging_store/sender_address_book_store.js +20 -14
  101. package/dest/storage/tagging_store/sender_tagging_store.d.ts +1 -1
  102. package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -1
  103. package/dest/storage/tagging_store/sender_tagging_store.js +183 -113
  104. package/dest/tagging/get_all_logs_by_tags.d.ts +1 -1
  105. package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -1
  106. package/dest/tagging/get_all_logs_by_tags.js +17 -3
  107. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.js +4 -4
  108. package/dest/tagging/recipient_sync/utils/find_highest_indexes.js +2 -2
  109. package/package.json +25 -16
  110. package/src/access_scopes.ts +9 -0
  111. package/src/block_synchronizer/block_synchronizer.ts +6 -0
  112. package/src/config/package_info.ts +1 -1
  113. package/src/contract_function_simulator/contract_function_simulator.ts +321 -125
  114. package/src/contract_function_simulator/noir-structs/event_validation_request.ts +1 -1
  115. package/src/contract_function_simulator/noir-structs/note_validation_request.ts +1 -1
  116. package/src/contract_function_simulator/oracle/interfaces.ts +10 -10
  117. package/src/contract_function_simulator/oracle/oracle.ts +35 -18
  118. package/src/contract_function_simulator/oracle/private_execution_oracle.ts +97 -101
  119. package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +129 -63
  120. package/src/contract_sync/contract_sync_service.ts +152 -0
  121. package/src/contract_sync/{index.ts → helpers.ts} +21 -21
  122. package/src/debug/pxe_debug_utils.ts +48 -18
  123. package/src/entrypoints/client/bundle/index.ts +2 -0
  124. package/src/entrypoints/client/bundle/utils.ts +12 -2
  125. package/src/entrypoints/client/lazy/index.ts +2 -0
  126. package/src/entrypoints/client/lazy/utils.ts +12 -2
  127. package/src/entrypoints/server/index.ts +3 -1
  128. package/src/entrypoints/server/utils.ts +7 -7
  129. package/src/events/event_service.ts +4 -6
  130. package/src/logs/log_service.ts +14 -29
  131. package/src/notes/note_service.ts +9 -10
  132. package/src/notes_filter.ts +26 -0
  133. package/src/oracle_version.ts +2 -2
  134. package/src/private_kernel/hints/{compute_tx_include_by_timestamp.ts → compute_tx_expiration_timestamp.ts} +13 -13
  135. package/src/private_kernel/hints/index.ts +1 -1
  136. package/src/private_kernel/hints/private_kernel_reset_private_inputs_builder.ts +7 -7
  137. package/src/private_kernel/private_kernel_execution_prover.ts +6 -6
  138. package/src/pxe.ts +161 -98
  139. package/src/storage/address_store/address_store.ts +15 -15
  140. package/src/storage/anchor_block_store/anchor_block_store.ts +8 -0
  141. package/src/storage/capsule_store/capsule_store.ts +8 -8
  142. package/src/storage/contract_store/contract_store.ts +26 -15
  143. package/src/storage/metadata.ts +1 -1
  144. package/src/storage/note_store/note_store.ts +169 -132
  145. package/src/storage/private_event_store/private_event_store.ts +102 -81
  146. package/src/storage/private_event_store/stored_private_event.ts +1 -1
  147. package/src/storage/tagging_store/recipient_tagging_store.ts +31 -21
  148. package/src/storage/tagging_store/sender_address_book_store.ts +20 -14
  149. package/src/storage/tagging_store/sender_tagging_store.ts +210 -126
  150. package/src/tagging/get_all_logs_by_tags.ts +28 -4
  151. package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +4 -4
  152. package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +2 -2
  153. package/dest/contract_sync/index.d.ts +0 -23
  154. package/dest/contract_sync/index.d.ts.map +0 -1
  155. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts +0 -4
  156. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts.map +0 -1
@@ -5,7 +5,7 @@ import { AztecAddress } from '@aztec/stdlib/aztec-address';
5
5
  import { TxHash } from '@aztec/stdlib/tx';
6
6
 
7
7
  // TODO(#14617): should we compute this from constants? This value is aztec-nr specific.
8
- const MAX_EVENT_SERIALIZED_LEN = 12;
8
+ const MAX_EVENT_SERIALIZED_LEN = 11;
9
9
 
10
10
  /**
11
11
  * Intermediate struct used to perform batch event validation by PXE. The `utilityValidateAndStoreEnqueuedNotesAndEvents` oracle
@@ -4,7 +4,7 @@ import { AztecAddress } from '@aztec/stdlib/aztec-address';
4
4
  import { TxHash } from '@aztec/stdlib/tx';
5
5
 
6
6
  // TODO(#14617): should we compute this from constants? This value is aztec-nr specific.
7
- export const MAX_NOTE_PACKED_LEN = 10;
7
+ export const MAX_NOTE_PACKED_LEN = 9;
8
8
 
9
9
  /**
10
10
  * Intermediate struct used to perform batch note validation by PXE. The `utilityValidateAndStoreEnqueuedNotesAndEvents` oracle
@@ -54,7 +54,7 @@ export interface IMiscOracle {
54
54
 
55
55
  utilityGetRandomField(): Fr;
56
56
  utilityAssertCompatibleOracleVersion(version: number): void;
57
- utilityDebugLog(level: number, message: string, fields: Fr[]): void;
57
+ utilityLog(level: number, message: string, fields: Fr[]): Promise<void>;
58
58
  }
59
59
 
60
60
  /**
@@ -68,24 +68,24 @@ export interface IUtilityExecutionOracle {
68
68
  utilityGetKeyValidationRequest(pkMHash: Fr): Promise<KeyValidationRequest>;
69
69
  utilityGetContractInstance(address: AztecAddress): Promise<ContractInstance>;
70
70
  utilityGetNoteHashMembershipWitness(
71
- blockHash: BlockHash,
72
- leafValue: Fr,
71
+ anchorBlockHash: BlockHash,
72
+ noteHash: Fr,
73
73
  ): Promise<MembershipWitness<typeof NOTE_HASH_TREE_HEIGHT> | undefined>;
74
- utilityGetArchiveMembershipWitness(
74
+ utilityGetBlockHashMembershipWitness(
75
+ anchorBlockHash: BlockHash,
75
76
  blockHash: BlockHash,
76
- leafValue: Fr,
77
77
  ): Promise<MembershipWitness<typeof ARCHIVE_HEIGHT> | undefined>;
78
78
  utilityGetNullifierMembershipWitness(
79
- blockHash: BlockHash,
79
+ anchorBlockHash: BlockHash,
80
80
  nullifier: Fr,
81
81
  ): Promise<NullifierMembershipWitness | undefined>;
82
- utilityGetPublicDataWitness(blockHash: BlockHash, leafSlot: Fr): Promise<PublicDataWitness | undefined>;
82
+ utilityGetPublicDataWitness(anchorBlockHash: BlockHash, leafSlot: Fr): Promise<PublicDataWitness | undefined>;
83
83
  utilityGetLowNullifierMembershipWitness(
84
- blockHash: BlockHash,
84
+ anchorBlockHash: BlockHash,
85
85
  nullifier: Fr,
86
86
  ): Promise<NullifierMembershipWitness | undefined>;
87
87
  utilityGetBlockHeader(blockNumber: BlockNumber): Promise<BlockHeader | undefined>;
88
- utilityGetPublicKeysAndPartialAddress(account: AztecAddress): Promise<CompleteAddress>;
88
+ utilityTryGetPublicKeysAndPartialAddress(account: AztecAddress): Promise<CompleteAddress | undefined>;
89
89
  utilityGetAuthWitness(messageHash: Fr): Promise<Fr[] | undefined>;
90
90
  utilityGetNotes(
91
91
  owner: AztecAddress | undefined,
@@ -111,7 +111,7 @@ export interface IUtilityExecutionOracle {
111
111
  secret: Fr,
112
112
  ): Promise<MessageLoadOracleInputs<typeof L1_TO_L2_MSG_TREE_HEIGHT>>;
113
113
  utilityStorageRead(
114
- blockHash: BlockHash,
114
+ anchorBlockHash: BlockHash,
115
115
  contractAddress: AztecAddress,
116
116
  startStorageSlot: Fr,
117
117
  numberOfElements: number,
@@ -138,29 +138,39 @@ export class Oracle {
138
138
  }
139
139
 
140
140
  async utilityGetNoteHashMembershipWitness(
141
- [blockHash]: ACVMField[],
142
- [leafValue]: ACVMField[],
141
+ [anchorBlockHash]: ACVMField[],
142
+ [noteHash]: ACVMField[],
143
143
  ): Promise<(ACVMField | ACVMField[])[]> {
144
- const parsedBlockHash = BlockHash.fromString(blockHash);
145
- const parsedLeafValue = Fr.fromString(leafValue);
144
+ const parsedAnchorBlockHash = BlockHash.fromString(anchorBlockHash);
145
+ const parsedNoteHash = Fr.fromString(noteHash);
146
146
 
147
- const witness = await this.handlerAsUtility().utilityGetNoteHashMembershipWitness(parsedBlockHash, parsedLeafValue);
147
+ const witness = await this.handlerAsUtility().utilityGetNoteHashMembershipWitness(
148
+ parsedAnchorBlockHash,
149
+ parsedNoteHash,
150
+ );
148
151
  if (!witness) {
149
- throw new Error(`Leaf ${leafValue} not found in the note hash tree at block hash ${parsedBlockHash.toString()}.`);
152
+ throw new Error(
153
+ `Note hash ${noteHash} not found in the note hash tree at anchor block hash ${parsedAnchorBlockHash.toString()}.`,
154
+ );
150
155
  }
151
156
  return witness.toNoirRepresentation();
152
157
  }
153
158
 
154
- async utilityGetArchiveMembershipWitness(
159
+ async utilityGetBlockHashMembershipWitness(
160
+ [anchorBlockHash]: ACVMField[],
155
161
  [blockHash]: ACVMField[],
156
- [leafValue]: ACVMField[],
157
162
  ): Promise<(ACVMField | ACVMField[])[]> {
163
+ const parsedAnchorBlockHash = BlockHash.fromString(anchorBlockHash);
158
164
  const parsedBlockHash = BlockHash.fromString(blockHash);
159
- const parsedLeafValue = Fr.fromString(leafValue);
160
165
 
161
- const witness = await this.handlerAsUtility().utilityGetArchiveMembershipWitness(parsedBlockHash, parsedLeafValue);
166
+ const witness = await this.handlerAsUtility().utilityGetBlockHashMembershipWitness(
167
+ parsedAnchorBlockHash,
168
+ parsedBlockHash,
169
+ );
162
170
  if (!witness) {
163
- throw new Error(`Leaf ${leafValue} not found in the archive tree at block hash ${parsedBlockHash.toString()}.`);
171
+ throw new Error(
172
+ `Block hash ${parsedBlockHash.toString()} not found in the archive tree at anchor block ${parsedAnchorBlockHash.toString()}.`,
173
+ );
164
174
  }
165
175
  return witness.toNoirRepresentation();
166
176
  }
@@ -238,12 +248,19 @@ export class Oracle {
238
248
  return [witness.map(toACVMField)];
239
249
  }
240
250
 
241
- async utilityGetPublicKeysAndPartialAddress([address]: ACVMField[]): Promise<ACVMField[][]> {
251
+ async utilityTryGetPublicKeysAndPartialAddress([address]: ACVMField[]): Promise<(ACVMField | ACVMField[])[]> {
242
252
  const parsedAddress = AztecAddress.fromField(Fr.fromString(address));
243
- const { publicKeys, partialAddress } =
244
- await this.handlerAsUtility().utilityGetPublicKeysAndPartialAddress(parsedAddress);
253
+ const result = await this.handlerAsUtility().utilityTryGetPublicKeysAndPartialAddress(parsedAddress);
245
254
 
246
- return [[...publicKeys.toFields(), partialAddress].map(toACVMField)];
255
+ // We are going to return a Noir Option struct to represent the possibility of null values. Options are a struct
256
+ // with two fields: `some` (a boolean) and `value` (a field array in this case).
257
+ if (result === undefined) {
258
+ // No data was found so we set `some` to 0 and pad `value` with zeros get the correct return size.
259
+ return [toACVMField(0), Array(13).fill(toACVMField(0))];
260
+ } else {
261
+ // Data was found so we set `some` to 1 and return it along with `value`.
262
+ return [toACVMField(1), [...result.publicKeys.toFields(), result.partialAddress].map(toACVMField)];
263
+ }
247
264
  }
248
265
 
249
266
  async utilityGetNotes(
@@ -400,7 +417,7 @@ export class Oracle {
400
417
  return Promise.resolve([]);
401
418
  }
402
419
 
403
- utilityDebugLog(
420
+ async utilityLog(
404
421
  level: ACVMField[],
405
422
  message: ACVMField[],
406
423
  _ignoredFieldsSize: ACVMField[],
@@ -409,8 +426,8 @@ export class Oracle {
409
426
  const levelFr = Fr.fromString(level[0]);
410
427
  const messageStr = message.map(acvmField => String.fromCharCode(Fr.fromString(acvmField).toNumber())).join('');
411
428
  const fieldsFr = fields.map(Fr.fromString);
412
- this.handlerAsMisc().utilityDebugLog(levelFr.toNumber(), messageStr, fieldsFr);
413
- return Promise.resolve([]);
429
+ await this.handlerAsMisc().utilityLog(levelFr.toNumber(), messageStr, fieldsFr);
430
+ return [];
414
431
  }
415
432
 
416
433
  // This function's name is directly hardcoded in `circuit_recorder.ts`. Don't forget to update it there if you
@@ -2,7 +2,6 @@ import { MAX_FR_CALLDATA_TO_ALL_ENQUEUED_CALLS, PRIVATE_CONTEXT_INPUTS_LENGTH }
2
2
  import { Fr } from '@aztec/foundation/curves/bn254';
3
3
  import { createLogger } from '@aztec/foundation/log';
4
4
  import { Timer } from '@aztec/foundation/timer';
5
- import type { KeyStore } from '@aztec/key-store';
6
5
  import { type CircuitSimulator, toACVMWitness } from '@aztec/simulator/client';
7
6
  import {
8
7
  type FunctionAbi,
@@ -12,34 +11,23 @@ import {
12
11
  type NoteSelector,
13
12
  countArgumentsSize,
14
13
  } from '@aztec/stdlib/abi';
15
- import type { AuthWitness } from '@aztec/stdlib/auth-witness';
16
14
  import { AztecAddress } from '@aztec/stdlib/aztec-address';
17
15
  import { siloNullifier } from '@aztec/stdlib/hash';
18
- import type { AztecNode } from '@aztec/stdlib/interfaces/client';
19
16
  import { PrivateContextInputs } from '@aztec/stdlib/kernel';
20
17
  import { type ContractClassLog, DirectionalAppTaggingSecret, type PreTag } from '@aztec/stdlib/logs';
21
18
  import { Tag } from '@aztec/stdlib/logs';
22
19
  import { Note, type NoteStatus } from '@aztec/stdlib/note';
23
20
  import {
24
- type BlockHeader,
25
21
  CallContext,
26
- Capsule,
27
22
  CountedContractClassLog,
28
23
  NoteAndSlot,
29
24
  PrivateCallExecutionResult,
30
25
  type TxContext,
31
26
  } from '@aztec/stdlib/tx';
32
27
 
33
- import { ensureContractSynced } from '../../contract_sync/index.js';
28
+ import type { AccessScopes } from '../../access_scopes.js';
29
+ import type { ContractSyncService } from '../../contract_sync/contract_sync_service.js';
34
30
  import { NoteService } from '../../notes/note_service.js';
35
- import type { AddressStore } from '../../storage/address_store/address_store.js';
36
- import type { AnchorBlockStore } from '../../storage/anchor_block_store/anchor_block_store.js';
37
- import type { CapsuleStore } from '../../storage/capsule_store/capsule_store.js';
38
- import type { ContractStore } from '../../storage/contract_store/contract_store.js';
39
- import type { NoteStore } from '../../storage/note_store/note_store.js';
40
- import type { PrivateEventStore } from '../../storage/private_event_store/private_event_store.js';
41
- import type { RecipientTaggingStore } from '../../storage/tagging_store/recipient_tagging_store.js';
42
- import type { SenderAddressBookStore } from '../../storage/tagging_store/sender_address_book_store.js';
43
31
  import type { SenderTaggingStore } from '../../storage/tagging_store/sender_tagging_store.js';
44
32
  import { syncSenderTaggingIndexes } from '../../tagging/index.js';
45
33
  import type { ExecutionNoteCache } from '../execution_note_cache.js';
@@ -48,7 +36,25 @@ import type { HashedValuesCache } from '../hashed_values_cache.js';
48
36
  import { pickNotes } from '../pick_notes.js';
49
37
  import type { IPrivateExecutionOracle, NoteData } from './interfaces.js';
50
38
  import { executePrivateFunction } from './private_execution.js';
51
- import { UtilityExecutionOracle } from './utility_execution_oracle.js';
39
+ import { UtilityExecutionOracle, type UtilityExecutionOracleArgs } from './utility_execution_oracle.js';
40
+
41
+ /** Args for PrivateExecutionOracle constructor. */
42
+ export type PrivateExecutionOracleArgs = Omit<UtilityExecutionOracleArgs, 'contractAddress'> & {
43
+ argsHash: Fr;
44
+ txContext: TxContext;
45
+ callContext: CallContext;
46
+ /** Needed to trigger contract synchronization before nested calls */
47
+ utilityExecutor: (call: FunctionCall, scopes: AccessScopes) => Promise<void>;
48
+ executionCache: HashedValuesCache;
49
+ noteCache: ExecutionNoteCache;
50
+ taggingIndexCache: ExecutionTaggingIndexCache;
51
+ senderTaggingStore: SenderTaggingStore;
52
+ contractSyncService: ContractSyncService;
53
+ totalPublicCalldataCount?: number;
54
+ sideEffectCounter?: number;
55
+ senderForTags?: AztecAddress;
56
+ simulator?: CircuitSimulator;
57
+ };
52
58
 
53
59
  /**
54
60
  * The execution oracle for the private part of a transaction.
@@ -70,58 +76,39 @@ export class PrivateExecutionOracle extends UtilityExecutionOracle implements IP
70
76
  private offchainEffects: { data: Fr[] }[] = [];
71
77
  private nestedExecutionResults: PrivateCallExecutionResult[] = [];
72
78
 
73
- constructor(
74
- private readonly argsHash: Fr,
75
- private readonly txContext: TxContext,
76
- private readonly callContext: CallContext,
77
- /** Header of a block whose state is used during private execution (not the block the transaction is included in). */
78
- protected override readonly anchorBlockHeader: BlockHeader,
79
- /** Needed to trigger contract synchronization before nested calls */
80
- private readonly utilityExecutor: (call: FunctionCall) => Promise<void>,
81
- /** List of transient auth witnesses to be used during this simulation */
82
- authWitnesses: AuthWitness[],
83
- capsules: Capsule[],
84
- private readonly executionCache: HashedValuesCache,
85
- private readonly noteCache: ExecutionNoteCache,
86
- private readonly taggingIndexCache: ExecutionTaggingIndexCache,
87
- contractStore: ContractStore,
88
- noteStore: NoteStore,
89
- keyStore: KeyStore,
90
- addressStore: AddressStore,
91
- aztecNode: AztecNode,
92
- anchorBlockStore: AnchorBlockStore,
93
- private readonly senderTaggingStore: SenderTaggingStore,
94
- recipientTaggingStore: RecipientTaggingStore,
95
- senderAddressBookStore: SenderAddressBookStore,
96
- capsuleStore: CapsuleStore,
97
- privateEventStore: PrivateEventStore,
98
- jobId: string,
99
- private totalPublicCalldataCount: number = 0,
100
- protected sideEffectCounter: number = 0,
101
- log = createLogger('simulator:client_execution_context'),
102
- scopes?: AztecAddress[],
103
- private senderForTags?: AztecAddress,
104
- private simulator?: CircuitSimulator,
105
- ) {
106
- super(
107
- callContext.contractAddress,
108
- authWitnesses,
109
- capsules,
110
- anchorBlockHeader,
111
- contractStore,
112
- noteStore,
113
- keyStore,
114
- addressStore,
115
- aztecNode,
116
- anchorBlockStore,
117
- recipientTaggingStore,
118
- senderAddressBookStore,
119
- capsuleStore,
120
- privateEventStore,
121
- jobId,
122
- log,
123
- scopes,
124
- );
79
+ private readonly argsHash: Fr;
80
+ private readonly txContext: TxContext;
81
+ private readonly callContext: CallContext;
82
+ private readonly utilityExecutor: (call: FunctionCall, scopes: AccessScopes) => Promise<void>;
83
+ private readonly executionCache: HashedValuesCache;
84
+ private readonly noteCache: ExecutionNoteCache;
85
+ private readonly taggingIndexCache: ExecutionTaggingIndexCache;
86
+ private readonly senderTaggingStore: SenderTaggingStore;
87
+ private readonly contractSyncService: ContractSyncService;
88
+ private totalPublicCalldataCount: number;
89
+ protected sideEffectCounter: number;
90
+ private senderForTags?: AztecAddress;
91
+ private readonly simulator?: CircuitSimulator;
92
+
93
+ constructor(args: PrivateExecutionOracleArgs) {
94
+ super({
95
+ ...args,
96
+ contractAddress: args.callContext.contractAddress,
97
+ log: args.log ?? createLogger('simulator:client_execution_context'),
98
+ });
99
+ this.argsHash = args.argsHash;
100
+ this.txContext = args.txContext;
101
+ this.callContext = args.callContext;
102
+ this.utilityExecutor = args.utilityExecutor;
103
+ this.executionCache = args.executionCache;
104
+ this.noteCache = args.noteCache;
105
+ this.taggingIndexCache = args.taggingIndexCache;
106
+ this.senderTaggingStore = args.senderTaggingStore;
107
+ this.contractSyncService = args.contractSyncService;
108
+ this.totalPublicCalldataCount = args.totalPublicCalldataCount ?? 0;
109
+ this.sideEffectCounter = args.sideEffectCounter ?? 0;
110
+ this.senderForTags = args.senderForTags;
111
+ this.simulator = args.simulator;
125
112
  }
126
113
 
127
114
  public getPrivateContextInputs(): PrivateContextInputs {
@@ -245,7 +232,7 @@ export class PrivateExecutionOracle extends UtilityExecutionOracle implements IP
245
232
  sender: AztecAddress,
246
233
  recipient: AztecAddress,
247
234
  ) {
248
- const senderCompleteAddress = await this.getCompleteAddress(sender);
235
+ const senderCompleteAddress = await this.getCompleteAddressOrFail(sender);
249
236
  const senderIvsk = await this.keyStore.getMasterIncomingViewingSecretKey(sender);
250
237
  return DirectionalAppTaggingSecret.compute(
251
238
  senderCompleteAddress,
@@ -364,7 +351,7 @@ export class PrivateExecutionOracle extends UtilityExecutionOracle implements IP
364
351
 
365
352
  const pendingNullifiers = this.noteCache.getNullifiers(this.callContext.contractAddress);
366
353
 
367
- const noteService = new NoteService(this.noteStore, this.aztecNode, this.anchorBlockStore, this.jobId);
354
+ const noteService = new NoteService(this.noteStore, this.aztecNode, this.anchorBlockHeader, this.jobId);
368
355
  const dbNotes = await noteService.getNotes(
369
356
  this.callContext.contractAddress,
370
357
  owner,
@@ -540,13 +527,22 @@ export class PrivateExecutionOracle extends UtilityExecutionOracle implements IP
540
527
 
541
528
  isStaticCall = isStaticCall || this.callContext.isStaticCall;
542
529
 
543
- await ensureContractSynced(
530
+ // When scopes are set and the target contract is a registered account (has keys in the keyStore),
531
+ // expand scopes to include it so nested private calls can sync and read the contract's own notes.
532
+ // We only expand for registered accounts because the log service needs the recipient's keys to derive
533
+ // tagging secrets, which are only available for registered accounts.
534
+ const expandedScopes =
535
+ this.scopes !== 'ALL_SCOPES' && (await this.keyStore.hasAccount(targetContractAddress))
536
+ ? [...this.scopes, targetContractAddress]
537
+ : this.scopes;
538
+
539
+ await this.contractSyncService.ensureContractSynced(
544
540
  targetContractAddress,
545
541
  functionSelector,
546
542
  this.utilityExecutor,
547
- this.aztecNode,
548
- this.contractStore,
549
543
  this.anchorBlockHeader,
544
+ this.jobId,
545
+ expandedScopes,
550
546
  );
551
547
 
552
548
  const targetArtifact = await this.contractStore.getFunctionArtifactWithDebugMetadata(
@@ -558,41 +554,41 @@ export class PrivateExecutionOracle extends UtilityExecutionOracle implements IP
558
554
 
559
555
  const derivedCallContext = await this.deriveCallContext(targetContractAddress, targetArtifact, isStaticCall);
560
556
 
561
- const privateExecutionOracle = new PrivateExecutionOracle(
557
+ const privateExecutionOracle = new PrivateExecutionOracle({
562
558
  argsHash,
563
- derivedTxContext,
564
- derivedCallContext,
565
- this.anchorBlockHeader,
566
- this.utilityExecutor,
567
- this.authWitnesses,
568
- this.capsules,
569
- this.executionCache,
570
- this.noteCache,
571
- this.taggingIndexCache,
572
- this.contractStore,
573
- this.noteStore,
574
- this.keyStore,
575
- this.addressStore,
576
- this.aztecNode,
577
- this.anchorBlockStore,
578
- this.senderTaggingStore,
579
- this.recipientTaggingStore,
580
- this.senderAddressBookStore,
581
- this.capsuleStore,
582
- this.privateEventStore,
583
- this.jobId,
584
- this.totalPublicCalldataCount,
559
+ txContext: derivedTxContext,
560
+ callContext: derivedCallContext,
561
+ anchorBlockHeader: this.anchorBlockHeader,
562
+ utilityExecutor: this.utilityExecutor,
563
+ authWitnesses: this.authWitnesses,
564
+ capsules: this.capsules,
565
+ executionCache: this.executionCache,
566
+ noteCache: this.noteCache,
567
+ taggingIndexCache: this.taggingIndexCache,
568
+ contractStore: this.contractStore,
569
+ noteStore: this.noteStore,
570
+ keyStore: this.keyStore,
571
+ addressStore: this.addressStore,
572
+ aztecNode: this.aztecNode,
573
+ senderTaggingStore: this.senderTaggingStore,
574
+ recipientTaggingStore: this.recipientTaggingStore,
575
+ senderAddressBookStore: this.senderAddressBookStore,
576
+ capsuleStore: this.capsuleStore,
577
+ privateEventStore: this.privateEventStore,
578
+ contractSyncService: this.contractSyncService,
579
+ jobId: this.jobId,
580
+ totalPublicCalldataCount: this.totalPublicCalldataCount,
585
581
  sideEffectCounter,
586
- this.log,
587
- this.scopes,
588
- this.senderForTags,
589
- this.simulator,
590
- );
582
+ log: this.log,
583
+ scopes: expandedScopes,
584
+ senderForTags: this.senderForTags,
585
+ simulator: this.simulator!,
586
+ });
591
587
 
592
588
  const setupTime = simulatorSetupTimer.ms();
593
589
 
594
590
  const childExecutionResult = await executePrivateFunction(
595
- this.simulator,
591
+ this.simulator!,
596
592
  privateExecutionOracle,
597
593
  targetArtifact,
598
594
  targetContractAddress,