@aztec/txe 0.0.1-commit.3e3d0c9cd → 0.0.1-commit.3f5453c7b

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 (39) hide show
  1. package/dest/oracle/txe_oracle_top_level_context.d.ts +10 -4
  2. package/dest/oracle/txe_oracle_top_level_context.d.ts.map +1 -1
  3. package/dest/oracle/txe_oracle_top_level_context.js +29 -16
  4. package/dest/rpc_translator.d.ts +55 -19
  5. package/dest/rpc_translator.d.ts.map +1 -1
  6. package/dest/rpc_translator.js +162 -39
  7. package/dest/state_machine/archiver.d.ts +1 -1
  8. package/dest/state_machine/archiver.d.ts.map +1 -1
  9. package/dest/state_machine/archiver.js +2 -1
  10. package/dest/state_machine/dummy_p2p_client.d.ts +3 -2
  11. package/dest/state_machine/dummy_p2p_client.d.ts.map +1 -1
  12. package/dest/state_machine/dummy_p2p_client.js +5 -2
  13. package/dest/state_machine/global_variable_builder.d.ts +9 -4
  14. package/dest/state_machine/global_variable_builder.d.ts.map +1 -1
  15. package/dest/state_machine/global_variable_builder.js +9 -3
  16. package/dest/state_machine/index.d.ts +1 -1
  17. package/dest/state_machine/index.d.ts.map +1 -1
  18. package/dest/state_machine/index.js +2 -2
  19. package/dest/state_machine/mock_epoch_cache.d.ts +18 -3
  20. package/dest/state_machine/mock_epoch_cache.d.ts.map +1 -1
  21. package/dest/state_machine/mock_epoch_cache.js +35 -2
  22. package/dest/txe_session.d.ts +4 -3
  23. package/dest/txe_session.d.ts.map +1 -1
  24. package/dest/txe_session.js +18 -12
  25. package/dest/util/encoding.d.ts +69 -1
  26. package/dest/util/encoding.d.ts.map +1 -1
  27. package/dest/util/txe_public_contract_data_source.d.ts +1 -1
  28. package/dest/util/txe_public_contract_data_source.d.ts.map +1 -1
  29. package/dest/util/txe_public_contract_data_source.js +1 -3
  30. package/package.json +15 -15
  31. package/src/oracle/txe_oracle_top_level_context.ts +40 -21
  32. package/src/rpc_translator.ts +192 -38
  33. package/src/state_machine/archiver.ts +1 -0
  34. package/src/state_machine/dummy_p2p_client.ts +6 -2
  35. package/src/state_machine/global_variable_builder.ts +18 -3
  36. package/src/state_machine/index.ts +3 -1
  37. package/src/state_machine/mock_epoch_cache.ts +46 -3
  38. package/src/txe_session.ts +20 -10
  39. package/src/util/txe_public_contract_data_source.ts +0 -2
@@ -13,7 +13,7 @@ import { getPackageVersion } from '@aztec/stdlib/update-checker';
13
13
 
14
14
  import { TXEArchiver } from './archiver.js';
15
15
  import { DummyP2P } from './dummy_p2p_client.js';
16
- import { TXEGlobalVariablesBuilder } from './global_variable_builder.js';
16
+ import { TXEFeeProvider, TXEGlobalVariablesBuilder } from './global_variable_builder.js';
17
17
  import { MockEpochCache } from './mock_epoch_cache.js';
18
18
  import { TXESynchronizer } from './synchronizer.js';
19
19
 
@@ -56,9 +56,11 @@ export class TXEStateMachine {
56
56
  VERSION,
57
57
  CHAIN_ID,
58
58
  new TXEGlobalVariablesBuilder(),
59
+ new TXEFeeProvider(),
59
60
  new MockEpochCache(),
60
61
  getPackageVersion() ?? '',
61
62
  new TestCircuitVerifier(),
63
+ new TestCircuitVerifier(),
62
64
  undefined,
63
65
  log,
64
66
  );
@@ -8,7 +8,7 @@ import { EmptyL1RollupConstants, type L1RollupConstants } from '@aztec/stdlib/ep
8
8
  * Since in TXE we don't validate transactions, mock suffices here.
9
9
  */
10
10
  export class MockEpochCache implements EpochCacheInterface {
11
- getCommittee(): Promise<EpochCommitteeInfo> {
11
+ getCommittee(_slot: SlotTag = 'now'): Promise<EpochCommitteeInfo> {
12
12
  return Promise.resolve({
13
13
  committee: undefined,
14
14
  seed: 0n,
@@ -17,6 +17,22 @@ export class MockEpochCache implements EpochCacheInterface {
17
17
  });
18
18
  }
19
19
 
20
+ getSlotNow(): SlotNumber {
21
+ return SlotNumber(0);
22
+ }
23
+
24
+ getTargetSlot(): SlotNumber {
25
+ return SlotNumber(0);
26
+ }
27
+
28
+ getEpochNow(): EpochNumber {
29
+ return EpochNumber.ZERO;
30
+ }
31
+
32
+ getTargetEpoch(): EpochNumber {
33
+ return EpochNumber.ZERO;
34
+ }
35
+
20
36
  getEpochAndSlotNow(): EpochAndSlot & { nowMs: bigint } {
21
37
  return {
22
38
  epoch: EpochNumber.ZERO,
@@ -26,15 +42,27 @@ export class MockEpochCache implements EpochCacheInterface {
26
42
  };
27
43
  }
28
44
 
29
- getEpochAndSlotInNextL1Slot(): EpochAndSlot & { now: bigint } {
45
+ getEpochAndSlotInNextL1Slot(): EpochAndSlot & { nowSeconds: bigint } {
30
46
  return {
31
47
  epoch: EpochNumber.ZERO,
32
48
  slot: SlotNumber(0),
33
49
  ts: 0n,
34
- now: 0n,
50
+ nowSeconds: 0n,
35
51
  };
36
52
  }
37
53
 
54
+ getTargetEpochAndSlotInNextL1Slot(): EpochAndSlot & { nowSeconds: bigint } {
55
+ return this.getEpochAndSlotInNextL1Slot();
56
+ }
57
+
58
+ isProposerPipeliningEnabled(): boolean {
59
+ return false;
60
+ }
61
+
62
+ pipeliningOffset(): number {
63
+ return 0;
64
+ }
65
+
38
66
  getProposerIndexEncoding(_epoch: EpochNumber, _slot: SlotNumber, _seed: bigint): `0x${string}` {
39
67
  return '0x00';
40
68
  }
@@ -50,6 +78,13 @@ export class MockEpochCache implements EpochCacheInterface {
50
78
  };
51
79
  }
52
80
 
81
+ getTargetAndNextSlot(): { targetSlot: SlotNumber; nextSlot: SlotNumber } {
82
+ return {
83
+ targetSlot: SlotNumber(0),
84
+ nextSlot: SlotNumber(0),
85
+ };
86
+ }
87
+
53
88
  getProposerAttesterAddressInSlot(_slot: SlotNumber): Promise<EthAddress | undefined> {
54
89
  return Promise.resolve(undefined);
55
90
  }
@@ -66,6 +101,14 @@ export class MockEpochCache implements EpochCacheInterface {
66
101
  return Promise.resolve([]);
67
102
  }
68
103
 
104
+ isEscapeHatchOpen(_epoch: EpochNumber): Promise<boolean> {
105
+ return Promise.resolve(false);
106
+ }
107
+
108
+ isEscapeHatchOpenAtSlot(_slot: SlotTag): Promise<boolean> {
109
+ return Promise.resolve(false);
110
+ }
111
+
69
112
  getL1Constants(): L1RollupConstants {
70
113
  return EmptyL1RollupConstants;
71
114
  }
@@ -3,12 +3,13 @@ import { Fr } from '@aztec/foundation/curves/bn254';
3
3
  import { type Logger, createLogger } from '@aztec/foundation/log';
4
4
  import { KeyStore } from '@aztec/key-store';
5
5
  import { openTmpStore } from '@aztec/kv-store/lmdb-v2';
6
- import type { AccessScopes } from '@aztec/pxe/client/lazy';
7
6
  import {
8
7
  AddressStore,
9
8
  AnchorBlockStore,
9
+ CapsuleService,
10
10
  CapsuleStore,
11
11
  ContractStore,
12
+ ContractSyncService,
12
13
  JobCoordinator,
13
14
  NoteService,
14
15
  NoteStore,
@@ -150,6 +151,7 @@ export class TXESession implements TXESessionStateHandler {
150
151
  private chainId: Fr,
151
152
  private version: Fr,
152
153
  private nextBlockTimestamp: bigint,
154
+ private contractSyncService: ContractSyncService,
153
155
  ) {}
154
156
 
155
157
  static async init(contractStore: ContractStore) {
@@ -185,6 +187,9 @@ export class TXESession implements TXESessionStateHandler {
185
187
 
186
188
  const initialJobId = jobCoordinator.beginJob();
187
189
 
190
+ const logger = createLogger('txe:session');
191
+ const contractSyncService = new ContractSyncService(stateMachine.node, contractStore, noteStore, logger);
192
+
188
193
  const topLevelOracleHandler = new TXEOracleTopLevelContext(
189
194
  stateMachine,
190
195
  contractStore,
@@ -201,11 +206,12 @@ export class TXESession implements TXESessionStateHandler {
201
206
  version,
202
207
  chainId,
203
208
  new Map(),
209
+ contractSyncService,
204
210
  );
205
211
  await topLevelOracleHandler.advanceBlocksBy(1);
206
212
 
207
213
  return new TXESession(
208
- createLogger('txe:session'),
214
+ logger,
209
215
  stateMachine,
210
216
  topLevelOracleHandler,
211
217
  contractStore,
@@ -223,6 +229,7 @@ export class TXESession implements TXESessionStateHandler {
223
229
  version,
224
230
  chainId,
225
231
  nextBlockTimestamp,
232
+ contractSyncService,
226
233
  );
227
234
  }
228
235
 
@@ -309,6 +316,7 @@ export class TXESession implements TXESessionStateHandler {
309
316
  this.version,
310
317
  this.chainId,
311
318
  this.authwits,
319
+ this.contractSyncService,
312
320
  );
313
321
 
314
322
  this.state = { name: 'TOP_LEVEL' };
@@ -328,7 +336,7 @@ export class TXESession implements TXESessionStateHandler {
328
336
 
329
337
  await new NoteService(this.noteStore, this.stateMachine.node, anchorBlock!, this.currentJobId).syncNoteNullifiers(
330
338
  contractAddress,
331
- 'ALL_SCOPES',
339
+ await this.keyStore.getAccounts(),
332
340
  );
333
341
  const latestBlock = await this.stateMachine.node.getBlockHeader('latest');
334
342
 
@@ -364,11 +372,11 @@ export class TXESession implements TXESessionStateHandler {
364
372
  senderTaggingStore: this.senderTaggingStore,
365
373
  recipientTaggingStore: this.recipientTaggingStore,
366
374
  senderAddressBookStore: this.senderAddressBookStore,
367
- capsuleStore: this.capsuleStore,
375
+ capsuleService: new CapsuleService(this.capsuleStore, await this.keyStore.getAccounts()),
368
376
  privateEventStore: this.privateEventStore,
369
377
  contractSyncService: this.stateMachine.contractSyncService,
370
378
  jobId: this.currentJobId,
371
- scopes: 'ALL_SCOPES',
379
+ scopes: await this.keyStore.getAccounts(),
372
380
  messageContextService: this.stateMachine.messageContextService,
373
381
  });
374
382
 
@@ -422,7 +430,7 @@ export class TXESession implements TXESessionStateHandler {
422
430
  this.stateMachine.node,
423
431
  anchorBlockHeader,
424
432
  this.currentJobId,
425
- ).syncNoteNullifiers(contractAddress, 'ALL_SCOPES');
433
+ ).syncNoteNullifiers(contractAddress, await this.keyStore.getAccounts());
426
434
 
427
435
  this.oracleHandler = new UtilityExecutionOracle({
428
436
  contractAddress,
@@ -436,11 +444,12 @@ export class TXESession implements TXESessionStateHandler {
436
444
  aztecNode: this.stateMachine.node,
437
445
  recipientTaggingStore: this.recipientTaggingStore,
438
446
  senderAddressBookStore: this.senderAddressBookStore,
439
- capsuleStore: this.capsuleStore,
447
+ capsuleService: new CapsuleService(this.capsuleStore, await this.keyStore.getAccounts()),
440
448
  privateEventStore: this.privateEventStore,
441
449
  messageContextService: this.stateMachine.messageContextService,
450
+ contractSyncService: this.contractSyncService,
442
451
  jobId: this.currentJobId,
443
- scopes: 'ALL_SCOPES',
452
+ scopes: await this.keyStore.getAccounts(),
444
453
  });
445
454
 
446
455
  this.state = { name: 'UTILITY' };
@@ -509,7 +518,7 @@ export class TXESession implements TXESessionStateHandler {
509
518
  }
510
519
 
511
520
  private utilityExecutorForContractSync(anchorBlock: any) {
512
- return async (call: FunctionCall, scopes: AccessScopes) => {
521
+ return async (call: FunctionCall, scopes: AztecAddress[]) => {
513
522
  const entryPointArtifact = await this.contractStore.getFunctionArtifactWithDebugMetadata(call.to, call.selector);
514
523
  if (entryPointArtifact.functionType !== FunctionType.UTILITY) {
515
524
  throw new Error(`Cannot run ${entryPointArtifact.functionType} function as utility`);
@@ -528,9 +537,10 @@ export class TXESession implements TXESessionStateHandler {
528
537
  aztecNode: this.stateMachine.node,
529
538
  recipientTaggingStore: this.recipientTaggingStore,
530
539
  senderAddressBookStore: this.senderAddressBookStore,
531
- capsuleStore: this.capsuleStore,
540
+ capsuleService: new CapsuleService(this.capsuleStore, scopes),
532
541
  privateEventStore: this.privateEventStore,
533
542
  messageContextService: this.stateMachine.messageContextService,
543
+ contractSyncService: this.contractSyncService,
534
544
  jobId: this.currentJobId,
535
545
  scopes,
536
546
  });
@@ -26,8 +26,6 @@ export class TXEPublicContractDataSource implements ContractDataSource {
26
26
  packedBytecode: contractClass.packedBytecode,
27
27
  privateFunctionsRoot: contractClass.privateFunctionsRoot,
28
28
  version: contractClass.version,
29
- privateFunctions: [],
30
- utilityFunctions: [],
31
29
  };
32
30
  }
33
31