@aztec/txe 0.0.1-commit.f2ce05ee → 0.0.1-commit.f504929

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 (40) hide show
  1. package/dest/index.d.ts +1 -1
  2. package/dest/index.d.ts.map +1 -1
  3. package/dest/index.js +88 -54
  4. package/dest/oracle/interfaces.d.ts +29 -28
  5. package/dest/oracle/interfaces.d.ts.map +1 -1
  6. package/dest/oracle/txe_oracle_public_context.d.ts +13 -13
  7. package/dest/oracle/txe_oracle_public_context.d.ts.map +1 -1
  8. package/dest/oracle/txe_oracle_public_context.js +12 -12
  9. package/dest/oracle/txe_oracle_top_level_context.d.ts +22 -23
  10. package/dest/oracle/txe_oracle_top_level_context.d.ts.map +1 -1
  11. package/dest/oracle/txe_oracle_top_level_context.js +104 -52
  12. package/dest/rpc_translator.d.ts +82 -82
  13. package/dest/rpc_translator.d.ts.map +1 -1
  14. package/dest/rpc_translator.js +241 -148
  15. package/dest/state_machine/dummy_p2p_client.d.ts +14 -11
  16. package/dest/state_machine/dummy_p2p_client.d.ts.map +1 -1
  17. package/dest/state_machine/dummy_p2p_client.js +23 -14
  18. package/dest/state_machine/index.d.ts +1 -1
  19. package/dest/state_machine/index.d.ts.map +1 -1
  20. package/dest/state_machine/index.js +1 -1
  21. package/dest/txe_session.d.ts +9 -6
  22. package/dest/txe_session.d.ts.map +1 -1
  23. package/dest/txe_session.js +77 -21
  24. package/dest/util/txe_public_contract_data_source.d.ts +2 -3
  25. package/dest/util/txe_public_contract_data_source.d.ts.map +1 -1
  26. package/dest/util/txe_public_contract_data_source.js +5 -22
  27. package/package.json +15 -15
  28. package/src/index.ts +89 -52
  29. package/src/oracle/interfaces.ts +32 -31
  30. package/src/oracle/txe_oracle_public_context.ts +12 -12
  31. package/src/oracle/txe_oracle_top_level_context.ts +107 -91
  32. package/src/rpc_translator.ts +254 -156
  33. package/src/state_machine/dummy_p2p_client.ts +33 -20
  34. package/src/state_machine/index.ts +1 -0
  35. package/src/txe_session.ts +80 -71
  36. package/src/util/txe_public_contract_data_source.ts +10 -36
  37. package/dest/util/txe_contract_store.d.ts +0 -12
  38. package/dest/util/txe_contract_store.d.ts.map +0 -1
  39. package/dest/util/txe_contract_store.js +0 -22
  40. package/src/util/txe_contract_store.ts +0 -36
@@ -36,7 +36,6 @@ export class TXEOracleTopLevelContext {
36
36
  senderAddressBookStore;
37
37
  capsuleStore;
38
38
  privateEventStore;
39
- jobId;
40
39
  nextBlockTimestamp;
41
40
  version;
42
41
  chainId;
@@ -44,7 +43,7 @@ export class TXEOracleTopLevelContext {
44
43
  isMisc;
45
44
  isTxe;
46
45
  logger;
47
- constructor(stateMachine, contractStore, noteStore, keyStore, addressStore, accountStore, senderTaggingStore, recipientTaggingStore, senderAddressBookStore, capsuleStore, privateEventStore, jobId, nextBlockTimestamp, version, chainId, authwits){
46
+ constructor(stateMachine, contractStore, noteStore, keyStore, addressStore, accountStore, senderTaggingStore, recipientTaggingStore, senderAddressBookStore, capsuleStore, privateEventStore, nextBlockTimestamp, version, chainId, authwits){
48
47
  this.stateMachine = stateMachine;
49
48
  this.contractStore = contractStore;
50
49
  this.noteStore = noteStore;
@@ -56,7 +55,6 @@ export class TXEOracleTopLevelContext {
56
55
  this.senderAddressBookStore = senderAddressBookStore;
57
56
  this.capsuleStore = capsuleStore;
58
57
  this.privateEventStore = privateEventStore;
59
- this.jobId = jobId;
60
58
  this.nextBlockTimestamp = nextBlockTimestamp;
61
59
  this.version = version;
62
60
  this.chainId = chainId;
@@ -66,20 +64,20 @@ export class TXEOracleTopLevelContext {
66
64
  this.logger = createLogger('txe:top_level_context');
67
65
  this.logger.debug('Entering Top Level Context');
68
66
  }
69
- utilityAssertCompatibleOracleVersion(version) {
67
+ assertCompatibleOracleVersion(version) {
70
68
  if (version !== ORACLE_VERSION) {
71
69
  throw new Error(`Incompatible oracle version. TXE is using version '${ORACLE_VERSION}', but got a request for '${version}'.`);
72
70
  }
73
71
  }
74
72
  // This is typically only invoked in private contexts, but it is convenient to also have it in top-level for testing
75
73
  // setup.
76
- utilityGetRandomField() {
74
+ getRandomField() {
77
75
  return Fr.random();
78
76
  }
79
77
  // We instruct users to debug contracts via this oracle, so it makes sense that they'd expect it to also work in tests
80
- utilityDebugLog(level, message, fields) {
78
+ log(level, message, fields) {
81
79
  if (!LogLevels[level]) {
82
- throw new Error(`Invalid debug log level: ${level}`);
80
+ throw new Error(`Invalid log level: ${level}`);
83
81
  }
84
82
  const levelName = LogLevels[level];
85
83
  this.logger[levelName](`${applyStringFormatting(message, fields)}`, {
@@ -87,19 +85,19 @@ export class TXEOracleTopLevelContext {
87
85
  });
88
86
  return Promise.resolve();
89
87
  }
90
- txeGetDefaultAddress() {
88
+ getDefaultAddress() {
91
89
  return DEFAULT_ADDRESS;
92
90
  }
93
- async txeGetNextBlockNumber() {
91
+ async getNextBlockNumber() {
94
92
  return BlockNumber(await this.getLastBlockNumber() + 1);
95
93
  }
96
- txeGetNextBlockTimestamp() {
94
+ getNextBlockTimestamp() {
97
95
  return Promise.resolve(this.nextBlockTimestamp);
98
96
  }
99
- async txeGetLastBlockTimestamp() {
97
+ async getLastBlockTimestamp() {
100
98
  return (await this.stateMachine.node.getBlockHeader('latest')).globalVariables.timestamp;
101
99
  }
102
- async txeGetLastTxEffects() {
100
+ async getLastTxEffects() {
103
101
  const latestBlockNumber = await this.stateMachine.archiver.getBlockNumber();
104
102
  const block = await this.stateMachine.archiver.getBlock(latestBlockNumber);
105
103
  if (block.body.txEffects.length != 1) {
@@ -113,7 +111,19 @@ export class TXEOracleTopLevelContext {
113
111
  nullifiers: txEffects.nullifiers
114
112
  };
115
113
  }
116
- async txeGetPrivateEvents(selector, contractAddress, scope) {
114
+ async syncContractNonOracleMethod(contractAddress, scope, jobId) {
115
+ if (contractAddress.equals(DEFAULT_ADDRESS)) {
116
+ this.logger.debug(`Skipping sync in getPrivateEvents because the events correspond to the default address.`);
117
+ return;
118
+ }
119
+ const blockHeader = await this.stateMachine.anchorBlockStore.getBlockHeader();
120
+ await this.stateMachine.contractSyncService.ensureContractSynced(contractAddress, null, async (call, execScopes)=>{
121
+ await this.executeUtilityCall(call, execScopes, jobId);
122
+ }, blockHeader, jobId, [
123
+ scope
124
+ ]);
125
+ }
126
+ async getPrivateEvents(selector, contractAddress, scope) {
117
127
  return (await this.privateEventStore.getPrivateEvents(selector, {
118
128
  contractAddress,
119
129
  scopes: [
@@ -123,17 +133,17 @@ export class TXEOracleTopLevelContext {
123
133
  toBlock: await this.getLastBlockNumber() + 1
124
134
  })).map((e)=>e.packedEvent);
125
135
  }
126
- async txeAdvanceBlocksBy(blocks) {
136
+ async advanceBlocksBy(blocks) {
127
137
  this.logger.debug(`time traveling ${blocks} blocks`);
128
138
  for(let i = 0; i < blocks; i++){
129
139
  await this.mineBlock();
130
140
  }
131
141
  }
132
- txeAdvanceTimestampBy(duration) {
142
+ advanceTimestampBy(duration) {
133
143
  this.logger.debug(`time traveling ${duration} seconds`);
134
144
  this.nextBlockTimestamp += duration;
135
145
  }
136
- async txeDeploy(artifact, instance, secret) {
146
+ async deploy(artifact, instance, secret) {
137
147
  // Emit deployment nullifier
138
148
  await this.mineBlock({
139
149
  nullifiers: [
@@ -141,25 +151,25 @@ export class TXEOracleTopLevelContext {
141
151
  ]
142
152
  });
143
153
  if (!secret.equals(Fr.ZERO)) {
144
- await this.txeAddAccount(artifact, instance, secret);
154
+ await this.addAccount(artifact, instance, secret);
145
155
  } else {
146
156
  await this.contractStore.addContractInstance(instance);
147
- await this.contractStore.addContractArtifact(instance.currentContractClassId, artifact);
157
+ await this.contractStore.addContractArtifact(artifact);
148
158
  this.logger.debug(`Deployed ${artifact.name} at ${instance.address}`);
149
159
  }
150
160
  }
151
- async txeAddAccount(artifact, instance, secret) {
161
+ async addAccount(artifact, instance, secret) {
152
162
  const partialAddress = await computePartialAddress(instance);
153
163
  this.logger.debug(`Deployed ${artifact.name} at ${instance.address}`);
154
164
  await this.contractStore.addContractInstance(instance);
155
- await this.contractStore.addContractArtifact(instance.currentContractClassId, artifact);
165
+ await this.contractStore.addContractArtifact(artifact);
156
166
  const completeAddress = await this.keyStore.addAccount(secret, partialAddress);
157
167
  await this.accountStore.setAccount(completeAddress.address, completeAddress);
158
168
  await this.addressStore.addCompleteAddress(completeAddress);
159
169
  this.logger.debug(`Created account ${completeAddress.address}`);
160
170
  return completeAddress;
161
171
  }
162
- async txeCreateAccount(secret) {
172
+ async createAccount(secret) {
163
173
  // This is a foot gun !
164
174
  const completeAddress = await this.keyStore.addAccount(secret, secret);
165
175
  await this.accountStore.setAccount(completeAddress.address, completeAddress);
@@ -167,7 +177,7 @@ export class TXEOracleTopLevelContext {
167
177
  this.logger.debug(`Created account ${completeAddress.address}`);
168
178
  return completeAddress;
169
179
  }
170
- async txeAddAuthWitness(address, messageHash) {
180
+ async addAuthWitness(address, messageHash) {
171
181
  const account = await this.accountStore.getAccount(address);
172
182
  const privateKey = await this.keyStore.getMasterSecretKey(account.publicKeys.masterIncomingViewingPublicKey);
173
183
  const schnorr = new Schnorr();
@@ -178,7 +188,7 @@ export class TXEOracleTopLevelContext {
178
188
  this.authwits.set(authWitness.requestHash.toString(), authWitness);
179
189
  }
180
190
  async mineBlock(options = {}) {
181
- const blockNumber = await this.txeGetNextBlockNumber();
191
+ const blockNumber = await this.getNextBlockNumber();
182
192
  const txEffect = TxEffect.empty();
183
193
  txEffect.nullifiers = [
184
194
  getSingleTxBlockRequestHash(blockNumber),
@@ -200,26 +210,25 @@ export class TXEOracleTopLevelContext {
200
210
  this.logger.info(`Created block ${blockNumber} with timestamp ${block.header.globalVariables.timestamp}`);
201
211
  await this.stateMachine.handleL2Block(block);
202
212
  }
203
- async txePrivateCallNewFlow(from, targetContractAddress = AztecAddress.zero(), functionSelector = FunctionSelector.empty(), args, argsHash = Fr.zero(), isStaticCall = false) {
213
+ async privateCallNewFlow(from, targetContractAddress = AztecAddress.zero(), functionSelector = FunctionSelector.empty(), args, argsHash = Fr.zero(), isStaticCall = false, jobId) {
204
214
  this.logger.verbose(`Executing external function ${await this.contractStore.getDebugFunctionName(targetContractAddress, functionSelector)}@${targetContractAddress} isStaticCall=${isStaticCall}`);
205
215
  const artifact = await this.contractStore.getFunctionArtifact(targetContractAddress, functionSelector);
206
216
  if (!artifact) {
207
217
  const message = functionSelector.equals(await FunctionSelector.fromSignature('verify_private_authwit(Field)')) ? 'Found no account contract artifact for a private authwit check - use `create_contract_account` instead of `create_light_account` for authwit support.' : 'Function Artifact does not exist';
208
218
  throw new Error(message);
209
219
  }
210
- // When `from` is the zero address (used when creating a new contract account for example),
211
- // we disable scope filtering by setting effectiveScopes to undefined. This allows these operations
212
- // to proceed without requiring keys registered for the zero address.
213
- const effectiveScopes = from.isZero() ? undefined : [
220
+ // When `from` is the zero address (e.g. when deploying a new account contract), we return an
221
+ // empty scope list which acts as deny-all: no notes are visible and no keys are accessible.
222
+ const effectiveScopes = from.isZero() ? [] : [
214
223
  from
215
224
  ];
216
225
  // Sync notes before executing private function to discover notes from previous transactions
217
- const utilityExecutor = async (call)=>{
218
- await this.executeUtilityCall(call, effectiveScopes);
226
+ const utilityExecutor = async (call, execScopes)=>{
227
+ await this.executeUtilityCall(call, execScopes, jobId);
219
228
  };
220
229
  const blockHeader = await this.stateMachine.anchorBlockStore.getBlockHeader();
221
- await this.stateMachine.contractSyncService.ensureContractSynced(targetContractAddress, functionSelector, utilityExecutor, blockHeader, this.jobId);
222
- const blockNumber = await this.txeGetNextBlockNumber();
230
+ await this.stateMachine.contractSyncService.ensureContractSynced(targetContractAddress, functionSelector, utilityExecutor, blockHeader, jobId, effectiveScopes);
231
+ const blockNumber = await this.getNextBlockNumber();
223
232
  const callContext = new CallContext(from, targetContractAddress, functionSelector, isStaticCall);
224
233
  const gasLimits = new Gas(DEFAULT_DA_GAS_LIMIT, DEFAULT_L2_GAS_LIMIT);
225
234
  const teardownGasLimits = new Gas(DEFAULT_TEARDOWN_DA_GAS_LIMIT, DEFAULT_TEARDOWN_L2_GAS_LIMIT);
@@ -234,12 +243,39 @@ export class TXEOracleTopLevelContext {
234
243
  await noteCache.setMinRevertibleSideEffectCounter(minRevertibleSideEffectCounter);
235
244
  const taggingIndexCache = new ExecutionTaggingIndexCache();
236
245
  const simulator = new WASMSimulator();
237
- const privateExecutionOracle = new PrivateExecutionOracle(argsHash, txContext, callContext, /** Header of a block whose state is used during private execution (not the block the transaction is included in). */ blockHeader, utilityExecutor, /** List of transient auth witnesses to be used during this simulation */ Array.from(this.authwits.values()), /** List of transient auth witnesses to be used during this simulation */ [], HashedValuesCache.create([
238
- new HashedValues(args, argsHash)
239
- ]), noteCache, taggingIndexCache, this.contractStore, this.noteStore, this.keyStore, this.addressStore, this.stateMachine.node, this.senderTaggingStore, this.recipientTaggingStore, this.senderAddressBookStore, this.capsuleStore, this.privateEventStore, this.stateMachine.contractSyncService, this.jobId, 0, minRevertibleSideEffectCounter, undefined, effectiveScopes, /**
240
- * In TXE, the typical transaction entrypoint is skipped, so we need to simulate the actions that such a
241
- * contract would perform, including setting senderForTags.
242
- */ from, simulator);
246
+ const privateExecutionOracle = new PrivateExecutionOracle({
247
+ argsHash,
248
+ txContext,
249
+ callContext,
250
+ anchorBlockHeader: blockHeader,
251
+ utilityExecutor,
252
+ authWitnesses: Array.from(this.authwits.values()),
253
+ capsules: [],
254
+ executionCache: HashedValuesCache.create([
255
+ new HashedValues(args, argsHash)
256
+ ]),
257
+ noteCache,
258
+ taggingIndexCache,
259
+ contractStore: this.contractStore,
260
+ noteStore: this.noteStore,
261
+ keyStore: this.keyStore,
262
+ addressStore: this.addressStore,
263
+ aztecNode: this.stateMachine.node,
264
+ senderTaggingStore: this.senderTaggingStore,
265
+ recipientTaggingStore: this.recipientTaggingStore,
266
+ senderAddressBookStore: this.senderAddressBookStore,
267
+ capsuleStore: this.capsuleStore,
268
+ privateEventStore: this.privateEventStore,
269
+ contractSyncService: this.stateMachine.contractSyncService,
270
+ jobId,
271
+ totalPublicCalldataCount: 0,
272
+ sideEffectCounter: minRevertibleSideEffectCounter,
273
+ scopes: effectiveScopes,
274
+ // In TXE, the typical transaction entrypoint is skipped, so we need to simulate the actions that such a
275
+ // contract would perform, including setting senderForTags.
276
+ senderForTags: from,
277
+ simulator
278
+ });
243
279
  // Note: This is a slight modification of simulator.run without any of the checks. Maybe we should modify simulator.run with a boolean value to skip checks.
244
280
  let result;
245
281
  let executionResult;
@@ -251,7 +287,7 @@ export class TXEOracleTopLevelContext {
251
287
  r.publicInputs.publicTeardownCallRequest
252
288
  ]));
253
289
  const publicFunctionsCalldata = await Promise.all(publicCallRequests.map(async (r)=>{
254
- const calldata = await privateExecutionOracle.privateLoadFromExecutionCache(r.calldataHash);
290
+ const calldata = await privateExecutionOracle.loadFromExecutionCache(r.calldataHash);
255
291
  return new HashedValues(calldata, r.calldataHash);
256
292
  }));
257
293
  noteCache.finish();
@@ -263,7 +299,7 @@ export class TXEOracleTopLevelContext {
263
299
  // According to the protocol rules, there must be at least one nullifier in the tx. The first nullifier is used as
264
300
  // the nonce generator for the note hashes.
265
301
  // We pass the non-zero minRevertibleSideEffectCounter to make sure the side effects are split correctly.
266
- const { publicInputs } = await generateSimulatedProvingResult(result, (addr, sel)=>this.contractStore.getDebugFunctionName(addr, sel), minRevertibleSideEffectCounter);
302
+ const { publicInputs } = await generateSimulatedProvingResult(result, (addr, sel)=>this.contractStore.getDebugFunctionName(addr, sel), this.stateMachine.node, minRevertibleSideEffectCounter);
267
303
  const globals = makeGlobalVariables();
268
304
  globals.blockNumber = blockNumber;
269
305
  globals.timestamp = this.nextBlockTimestamp;
@@ -331,9 +367,9 @@ export class TXEOracleTopLevelContext {
331
367
  await forkedWorldTrees.close();
332
368
  return executionResult.returnValues ?? [];
333
369
  }
334
- async txePublicCallNewFlow(from, targetContractAddress, calldata, isStaticCall) {
370
+ async publicCallNewFlow(from, targetContractAddress, calldata, isStaticCall) {
335
371
  this.logger.verbose(`Executing public function ${await this.contractStore.getDebugFunctionName(targetContractAddress, FunctionSelector.fromField(calldata[0]))}@${targetContractAddress} isStaticCall=${isStaticCall}`);
336
- const blockNumber = await this.txeGetNextBlockNumber();
372
+ const blockNumber = await this.getNextBlockNumber();
337
373
  const gasLimits = new Gas(DEFAULT_DA_GAS_LIMIT, DEFAULT_L2_GAS_LIMIT);
338
374
  const teardownGasLimits = new Gas(DEFAULT_TEARDOWN_DA_GAS_LIMIT, DEFAULT_TEARDOWN_L2_GAS_LIMIT);
339
375
  const gasSettings = new GasSettings(gasLimits, teardownGasLimits, GasFees.empty(), GasFees.empty());
@@ -372,7 +408,7 @@ export class TXEOracleTopLevelContext {
372
408
  revertibleAccumulatedData.publicCallRequests[0] = new PublicCallRequest(from, targetContractAddress, isStaticCall, calldataHash);
373
409
  const inputsForPublic = new PartialPrivateTailPublicInputsForPublic(nonRevertibleAccumulatedData, revertibleAccumulatedData, PublicCallRequest.empty());
374
410
  const constantData = new TxConstantData(anchorBlockHeader, txContext, Fr.zero(), Fr.zero());
375
- const txData = new PrivateKernelTailCircuitPublicInputs(constantData, /*gasUsed=*/ new Gas(0, 0), /*feePayer=*/ AztecAddress.zero(), /*includeByTimestamp=*/ 0n, inputsForPublic, undefined);
411
+ const txData = new PrivateKernelTailCircuitPublicInputs(constantData, /*gasUsed=*/ new Gas(0, 0), /*feePayer=*/ AztecAddress.zero(), /*expirationTimestamp=*/ 0n, inputsForPublic, undefined);
376
412
  const tx = await Tx.create({
377
413
  data: txData,
378
414
  chonkProof: ChonkProof.empty(),
@@ -425,16 +461,16 @@ export class TXEOracleTopLevelContext {
425
461
  await forkedWorldTrees.close();
426
462
  return returnValues ?? [];
427
463
  }
428
- async txeSimulateUtilityFunction(targetContractAddress, functionSelector, args) {
464
+ async executeUtilityFunction(targetContractAddress, functionSelector, args, jobId) {
429
465
  const artifact = await this.contractStore.getFunctionArtifact(targetContractAddress, functionSelector);
430
466
  if (!artifact) {
431
467
  throw new Error(`Cannot call ${functionSelector} as there is no artifact found at ${targetContractAddress}.`);
432
468
  }
433
469
  // Sync notes before executing utility function to discover notes from previous transactions
434
470
  const blockHeader = await this.stateMachine.anchorBlockStore.getBlockHeader();
435
- await this.stateMachine.contractSyncService.ensureContractSynced(targetContractAddress, functionSelector, async (call)=>{
436
- await this.executeUtilityCall(call);
437
- }, blockHeader, this.jobId);
471
+ await this.stateMachine.contractSyncService.ensureContractSynced(targetContractAddress, functionSelector, async (call, execScopes)=>{
472
+ await this.executeUtilityCall(call, execScopes, jobId);
473
+ }, blockHeader, jobId, 'ALL_SCOPES');
438
474
  const call = FunctionCall.from({
439
475
  name: artifact.name,
440
476
  to: targetContractAddress,
@@ -445,9 +481,9 @@ export class TXEOracleTopLevelContext {
445
481
  args,
446
482
  returnTypes: []
447
483
  });
448
- return this.executeUtilityCall(call);
484
+ return this.executeUtilityCall(call, 'ALL_SCOPES', jobId);
449
485
  }
450
- async executeUtilityCall(call, scopes) {
486
+ async executeUtilityCall(call, scopes, jobId) {
451
487
  const entryPointArtifact = await this.contractStore.getFunctionArtifactWithDebugMetadata(call.to, call.selector);
452
488
  if (entryPointArtifact.functionType !== FunctionType.UTILITY) {
453
489
  throw new Error(`Cannot run ${entryPointArtifact.functionType} function as utility`);
@@ -458,7 +494,23 @@ export class TXEOracleTopLevelContext {
458
494
  });
459
495
  try {
460
496
  const anchorBlockHeader = await this.stateMachine.anchorBlockStore.getBlockHeader();
461
- const oracle = new UtilityExecutionOracle(call.to, [], [], anchorBlockHeader, this.contractStore, this.noteStore, this.keyStore, this.addressStore, this.stateMachine.node, this.recipientTaggingStore, this.senderAddressBookStore, this.capsuleStore, this.privateEventStore, this.jobId, undefined, scopes);
497
+ const oracle = new UtilityExecutionOracle({
498
+ contractAddress: call.to,
499
+ authWitnesses: [],
500
+ capsules: [],
501
+ anchorBlockHeader,
502
+ contractStore: this.contractStore,
503
+ noteStore: this.noteStore,
504
+ keyStore: this.keyStore,
505
+ addressStore: this.addressStore,
506
+ aztecNode: this.stateMachine.node,
507
+ recipientTaggingStore: this.recipientTaggingStore,
508
+ senderAddressBookStore: this.senderAddressBookStore,
509
+ capsuleStore: this.capsuleStore,
510
+ privateEventStore: this.privateEventStore,
511
+ jobId,
512
+ scopes
513
+ });
462
514
  const acirExecutionResult = await new WASMSimulator().executeUserCircuit(toACVMWitness(0, call.args), entryPointArtifact, new Oracle(oracle).toACIRCallback()).catch((err)=>{
463
515
  err.message = resolveAssertionMessageFromError(err, entryPointArtifact);
464
516
  throw new ExecutionError(err.message, {
@@ -468,10 +520,10 @@ export class TXEOracleTopLevelContext {
468
520
  cause: err
469
521
  });
470
522
  });
471
- this.logger.verbose(`Utility simulation for ${call.to}.${call.selector} completed`);
523
+ this.logger.verbose(`Utility execution for ${call.to}.${call.selector} completed`);
472
524
  return witnessMapToFields(acirExecutionResult.returnWitness);
473
525
  } catch (err) {
474
- throw createSimulationError(err instanceof Error ? err : new Error('Unknown error during utility simulation'));
526
+ throw createSimulationError(err instanceof Error ? err : new Error('Unknown error during utility execution'));
475
527
  }
476
528
  }
477
529
  close() {