@aztec/aztec 0.0.1-commit.b655e406 → 0.0.1-commit.b6e433891

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 (165) hide show
  1. package/README.md +1 -1
  2. package/dest/bin/index.d.ts +1 -1
  3. package/dest/bin/index.js +13 -6
  4. package/dest/cli/admin_api_key_store.d.ts +45 -0
  5. package/dest/cli/admin_api_key_store.d.ts.map +1 -0
  6. package/dest/cli/admin_api_key_store.js +98 -0
  7. package/dest/cli/aztec_start_action.d.ts +1 -1
  8. package/dest/cli/aztec_start_action.d.ts.map +1 -1
  9. package/dest/cli/aztec_start_action.js +72 -26
  10. package/dest/cli/aztec_start_options.d.ts +1 -1
  11. package/dest/cli/aztec_start_options.d.ts.map +1 -1
  12. package/dest/cli/aztec_start_options.js +48 -41
  13. package/dest/cli/cli.d.ts +1 -1
  14. package/dest/cli/cli.js +7 -7
  15. package/dest/cli/cmds/compile.d.ts +4 -0
  16. package/dest/cli/cmds/compile.d.ts.map +1 -0
  17. package/dest/cli/cmds/compile.js +166 -0
  18. package/dest/cli/cmds/migrate_ha_db.d.ts +3 -0
  19. package/dest/cli/cmds/migrate_ha_db.d.ts.map +1 -0
  20. package/dest/cli/cmds/migrate_ha_db.js +27 -0
  21. package/dest/cli/cmds/profile.d.ts +4 -0
  22. package/dest/cli/cmds/profile.d.ts.map +1 -0
  23. package/dest/cli/cmds/profile.js +8 -0
  24. package/dest/cli/cmds/profile_flamegraph.d.ts +4 -0
  25. package/dest/cli/cmds/profile_flamegraph.d.ts.map +1 -0
  26. package/dest/cli/cmds/profile_flamegraph.js +52 -0
  27. package/dest/cli/cmds/profile_gates.d.ts +4 -0
  28. package/dest/cli/cmds/profile_gates.d.ts.map +1 -0
  29. package/dest/cli/cmds/profile_gates.js +58 -0
  30. package/dest/cli/cmds/profile_utils.d.ts +18 -0
  31. package/dest/cli/cmds/profile_utils.d.ts.map +1 -0
  32. package/dest/cli/cmds/profile_utils.js +50 -0
  33. package/dest/cli/cmds/standby.d.ts +32 -0
  34. package/dest/cli/cmds/standby.d.ts.map +1 -0
  35. package/dest/cli/cmds/standby.js +97 -0
  36. package/dest/cli/cmds/start_archiver.d.ts +2 -2
  37. package/dest/cli/cmds/start_archiver.d.ts.map +1 -1
  38. package/dest/cli/cmds/start_archiver.js +12 -14
  39. package/dest/cli/cmds/start_bot.d.ts +3 -3
  40. package/dest/cli/cmds/start_bot.d.ts.map +1 -1
  41. package/dest/cli/cmds/start_bot.js +10 -6
  42. package/dest/cli/cmds/start_node.d.ts +3 -2
  43. package/dest/cli/cmds/start_node.d.ts.map +1 -1
  44. package/dest/cli/cmds/start_node.js +87 -31
  45. package/dest/cli/cmds/start_p2p_bootstrap.d.ts +2 -2
  46. package/dest/cli/cmds/start_p2p_bootstrap.d.ts.map +1 -1
  47. package/dest/cli/cmds/start_p2p_bootstrap.js +2 -3
  48. package/dest/cli/cmds/start_prover_agent.d.ts +1 -1
  49. package/dest/cli/cmds/start_prover_agent.d.ts.map +1 -1
  50. package/dest/cli/cmds/start_prover_agent.js +4 -4
  51. package/dest/cli/cmds/start_prover_broker.d.ts +1 -1
  52. package/dest/cli/cmds/start_prover_broker.d.ts.map +1 -1
  53. package/dest/cli/cmds/start_prover_broker.js +15 -9
  54. package/dest/cli/cmds/start_txe.d.ts +1 -1
  55. package/dest/cli/cmds/utils/artifacts.d.ts +21 -0
  56. package/dest/cli/cmds/utils/artifacts.d.ts.map +1 -0
  57. package/dest/cli/cmds/utils/artifacts.js +24 -0
  58. package/dest/cli/cmds/utils/needs_recompile.d.ts +10 -0
  59. package/dest/cli/cmds/utils/needs_recompile.d.ts.map +1 -0
  60. package/dest/cli/cmds/utils/needs_recompile.js +134 -0
  61. package/dest/cli/cmds/utils/spawn.d.ts +3 -0
  62. package/dest/cli/cmds/utils/spawn.d.ts.map +1 -0
  63. package/dest/cli/cmds/utils/spawn.js +16 -0
  64. package/dest/cli/index.d.ts +1 -1
  65. package/dest/cli/preload_crs.d.ts +1 -1
  66. package/dest/cli/util.d.ts +12 -23
  67. package/dest/cli/util.d.ts.map +1 -1
  68. package/dest/cli/util.js +51 -87
  69. package/dest/cli/versioning.d.ts +1 -1
  70. package/dest/examples/token.d.ts +1 -1
  71. package/dest/examples/token.js +10 -10
  72. package/dest/examples/util.d.ts +2 -2
  73. package/dest/examples/util.d.ts.map +1 -1
  74. package/dest/index.d.ts +2 -2
  75. package/dest/index.d.ts.map +1 -1
  76. package/dest/index.js +1 -1
  77. package/dest/local-network/banana_fpc.d.ts +10 -0
  78. package/dest/local-network/banana_fpc.d.ts.map +1 -0
  79. package/dest/{sandbox → local-network}/banana_fpc.js +4 -4
  80. package/dest/local-network/index.d.ts +4 -0
  81. package/dest/local-network/index.d.ts.map +1 -0
  82. package/dest/{sandbox → local-network}/index.js +1 -1
  83. package/dest/local-network/local-network.d.ts +73 -0
  84. package/dest/local-network/local-network.d.ts.map +1 -0
  85. package/dest/{sandbox/sandbox.js → local-network/local-network.js} +93 -50
  86. package/dest/local-network/sponsored_fpc.d.ts +5 -0
  87. package/dest/local-network/sponsored_fpc.d.ts.map +1 -0
  88. package/dest/mnemonic.d.ts +1 -1
  89. package/dest/splash.d.ts +1 -1
  90. package/dest/testing/anvil_test_watcher.d.ts +12 -4
  91. package/dest/testing/anvil_test_watcher.d.ts.map +1 -1
  92. package/dest/testing/anvil_test_watcher.js +68 -29
  93. package/dest/testing/cheat_codes.d.ts +1 -1
  94. package/dest/testing/cheat_codes.d.ts.map +1 -1
  95. package/dest/testing/epoch_test_settler.d.ts +19 -0
  96. package/dest/testing/epoch_test_settler.d.ts.map +1 -0
  97. package/dest/testing/epoch_test_settler.js +61 -0
  98. package/dest/testing/index.d.ts +3 -1
  99. package/dest/testing/index.d.ts.map +1 -1
  100. package/dest/testing/index.js +2 -0
  101. package/dest/testing/token_allowed_setup.d.ts +7 -0
  102. package/dest/testing/token_allowed_setup.d.ts.map +1 -0
  103. package/dest/testing/token_allowed_setup.js +20 -0
  104. package/package.json +41 -37
  105. package/scripts/add_crate.sh +102 -0
  106. package/scripts/aztec.sh +69 -0
  107. package/scripts/init.sh +39 -0
  108. package/scripts/new.sh +83 -0
  109. package/scripts/setup_workspace.sh +68 -0
  110. package/src/bin/index.ts +14 -6
  111. package/src/cli/admin_api_key_store.ts +128 -0
  112. package/src/cli/aztec_start_action.ts +70 -21
  113. package/src/cli/aztec_start_options.ts +49 -39
  114. package/src/cli/cli.ts +11 -11
  115. package/src/cli/cmds/compile.ts +191 -0
  116. package/src/cli/cmds/migrate_ha_db.ts +43 -0
  117. package/src/cli/cmds/profile.ts +25 -0
  118. package/src/cli/cmds/profile_flamegraph.ts +64 -0
  119. package/src/cli/cmds/profile_gates.ts +68 -0
  120. package/src/cli/cmds/profile_utils.ts +58 -0
  121. package/src/cli/cmds/standby.ts +132 -0
  122. package/src/cli/cmds/start_archiver.ts +8 -19
  123. package/src/cli/cmds/start_bot.ts +9 -6
  124. package/src/cli/cmds/start_node.ts +87 -37
  125. package/src/cli/cmds/start_p2p_bootstrap.ts +3 -3
  126. package/src/cli/cmds/start_prover_agent.ts +4 -12
  127. package/src/cli/cmds/start_prover_broker.ts +20 -16
  128. package/src/cli/cmds/utils/artifacts.ts +44 -0
  129. package/src/cli/cmds/utils/needs_recompile.ts +151 -0
  130. package/src/cli/cmds/utils/spawn.ts +16 -0
  131. package/src/cli/util.ts +60 -98
  132. package/src/examples/token.ts +11 -11
  133. package/src/examples/util.ts +1 -1
  134. package/src/index.ts +2 -2
  135. package/src/{sandbox → local-network}/banana_fpc.ts +12 -8
  136. package/src/{sandbox → local-network}/index.ts +1 -1
  137. package/src/local-network/local-network.ts +277 -0
  138. package/src/{sandbox → local-network}/sponsored_fpc.ts +3 -2
  139. package/src/testing/anvil_test_watcher.ts +76 -30
  140. package/src/testing/cheat_codes.ts +3 -2
  141. package/src/testing/epoch_test_settler.ts +70 -0
  142. package/src/testing/index.ts +2 -0
  143. package/src/testing/token_allowed_setup.ts +19 -0
  144. package/dest/cli/cmds/start_blob_sink.d.ts +0 -3
  145. package/dest/cli/cmds/start_blob_sink.d.ts.map +0 -1
  146. package/dest/cli/cmds/start_blob_sink.js +0 -33
  147. package/dest/cli/cmds/start_prover_node.d.ts +0 -7
  148. package/dest/cli/cmds/start_prover_node.d.ts.map +0 -1
  149. package/dest/cli/cmds/start_prover_node.js +0 -108
  150. package/dest/cli/release_version.d.ts +0 -2
  151. package/dest/cli/release_version.d.ts.map +0 -1
  152. package/dest/cli/release_version.js +0 -14
  153. package/dest/sandbox/banana_fpc.d.ts +0 -10
  154. package/dest/sandbox/banana_fpc.d.ts.map +0 -1
  155. package/dest/sandbox/index.d.ts +0 -4
  156. package/dest/sandbox/index.d.ts.map +0 -1
  157. package/dest/sandbox/sandbox.d.ts +0 -74
  158. package/dest/sandbox/sandbox.d.ts.map +0 -1
  159. package/dest/sandbox/sponsored_fpc.d.ts +0 -4
  160. package/dest/sandbox/sponsored_fpc.d.ts.map +0 -1
  161. package/src/cli/cmds/start_blob_sink.ts +0 -57
  162. package/src/cli/cmds/start_prover_node.ts +0 -124
  163. package/src/cli/release_version.ts +0 -21
  164. package/src/sandbox/sandbox.ts +0 -242
  165. /package/dest/{sandbox → local-network}/sponsored_fpc.js +0 -0
@@ -1,19 +1,27 @@
1
1
  #!/usr/bin/env -S node --no-warnings
2
2
  import { getInitialTestAccountsData } from '@aztec/accounts/testing';
3
- import { AztecNodeService, getConfigEnvVars } from '@aztec/aztec-node';
4
- import { EthAddress } from '@aztec/aztec.js/addresses';
5
- import { createBlobSinkClient } from '@aztec/blob-sink/client';
3
+ import { AztecNodeService } from '@aztec/aztec-node';
4
+ import { getConfigEnvVars } from '@aztec/aztec-node/config';
5
+ import { Fr } from '@aztec/aztec.js/fields';
6
+ import { createLogger } from '@aztec/aztec.js/log';
7
+ import { createBlobClient } from '@aztec/blob-client/client';
6
8
  import { GENESIS_ARCHIVE_ROOT } from '@aztec/constants';
7
- import { NULL_KEY, createEthereumChain, deployL1Contracts, deployMulticall3, getL1ContractsConfigEnvVars, waitForPublicClient } from '@aztec/ethereum';
9
+ import { createEthereumChain } from '@aztec/ethereum/chain';
10
+ import { waitForPublicClient } from '@aztec/ethereum/client';
11
+ import { getL1ContractsConfigEnvVars } from '@aztec/ethereum/config';
12
+ import { NULL_KEY } from '@aztec/ethereum/constants';
13
+ import { deployAztecL1Contracts } from '@aztec/ethereum/deploy-aztec-l1-contracts';
8
14
  import { EthCheatCodes } from '@aztec/ethereum/test';
9
15
  import { SecretValue } from '@aztec/foundation/config';
10
- import { Fr } from '@aztec/foundation/fields';
11
- import { createLogger } from '@aztec/foundation/log';
16
+ import { EthAddress } from '@aztec/foundation/eth-address';
12
17
  import { TestDateProvider } from '@aztec/foundation/timer';
13
18
  import { getVKTreeRoot } from '@aztec/noir-protocol-circuits-types/vk-tree';
14
19
  import { protocolContractsHash } from '@aztec/protocol-contracts';
20
+ import { SequencerState } from '@aztec/sequencer-client';
21
+ import { AztecAddress } from '@aztec/stdlib/aztec-address';
15
22
  import { getConfigEnvVars as getTelemetryClientConfig, initTelemetryClient } from '@aztec/telemetry-client';
16
- import { TestWallet, deployFundedSchnorrAccounts } from '@aztec/test-wallet/server';
23
+ import { EmbeddedWallet } from '@aztec/wallets/embedded';
24
+ import { deployFundedSchnorrAccounts } from '@aztec/wallets/testing';
17
25
  import { getGenesisValues } from '@aztec/world-state/testing';
18
26
  import { createPublicClient, fallback, http as httpViemTransport } from 'viem';
19
27
  import { mnemonicToAccount, privateKeyToAddress } from 'viem/accounts';
@@ -21,32 +29,29 @@ import { foundry } from 'viem/chains';
21
29
  import { createAccountLogs } from '../cli/util.js';
22
30
  import { DefaultMnemonic } from '../mnemonic.js';
23
31
  import { AnvilTestWatcher } from '../testing/anvil_test_watcher.js';
32
+ import { EpochTestSettler } from '../testing/epoch_test_settler.js';
33
+ import { getTokenAllowedSetupFunctions } from '../testing/token_allowed_setup.js';
24
34
  import { getBananaFPCAddress, setupBananaFPC } from './banana_fpc.js';
25
35
  import { getSponsoredFPCAddress } from './sponsored_fpc.js';
26
- const logger = createLogger('sandbox');
36
+ const logger = createLogger('local-network');
27
37
  const localAnvil = foundry;
28
38
  /**
29
- * Function to deploy our L1 contracts to the sandbox L1
39
+ * Function to deploy our L1 contracts to the local network L1
30
40
  * @param aztecNodeConfig - The Aztec Node Config
31
41
  * @param hdAccount - Account for publishing L1 contracts
32
- */ export async function deployContractsToL1(aztecNodeConfig, hdAccount, contractDeployLogger = logger, opts = {}) {
33
- const chain = aztecNodeConfig.l1RpcUrls.length > 0 ? createEthereumChain(aztecNodeConfig.l1RpcUrls, aztecNodeConfig.l1ChainId) : {
34
- chainInfo: localAnvil
35
- };
42
+ */ export async function deployContractsToL1(aztecNodeConfig, privateKey, opts = {}) {
36
43
  await waitForPublicClient(aztecNodeConfig);
37
- const l1Contracts = await deployL1Contracts(aztecNodeConfig.l1RpcUrls, hdAccount, chain.chainInfo, contractDeployLogger, {
44
+ const l1Contracts = await deployAztecL1Contracts(aztecNodeConfig.l1RpcUrls[0], privateKey, foundry.id, {
38
45
  ...getL1ContractsConfigEnvVars(),
39
46
  ...aztecNodeConfig,
40
47
  vkTreeRoot: getVKTreeRoot(),
41
48
  protocolContractsHash,
42
49
  genesisArchiveRoot: opts.genesisArchiveRoot ?? new Fr(GENESIS_ARCHIVE_ROOT),
43
- salt: opts.salt,
44
50
  feeJuicePortalInitialBalance: opts.feeJuicePortalInitialBalance,
45
51
  aztecTargetCommitteeSize: 0,
46
52
  slasherFlavor: 'none',
47
53
  realVerifier: false
48
54
  });
49
- await deployMulticall3(l1Contracts.l1Client, logger);
50
55
  aztecNodeConfig.l1Contracts = l1Contracts.l1ContractAddresses;
51
56
  aztecNodeConfig.rollupVersion = l1Contracts.rollupVersion;
52
57
  return aztecNodeConfig.l1Contracts;
@@ -54,24 +59,31 @@ const localAnvil = foundry;
54
59
  /**
55
60
  * Create and start a new Aztec Node and PXE. Deploys L1 contracts.
56
61
  * Does not start any HTTP services nor populate any initial accounts.
57
- * @param config - Optional Sandbox settings.
58
- */ export async function createSandbox(config = {}, userLog) {
59
- // sandbox is meant for test envs. We should only need one l1RpcUrl
62
+ * @param config - Optional local network settings.
63
+ */ export async function createLocalNetwork(config = {}, userLog) {
64
+ // local network is meant for test envs. We should only need one l1RpcUrl
60
65
  const l1RpcUrl = config.l1RpcUrls?.[0];
61
66
  if (!l1RpcUrl) {
62
67
  throw new Error('An L1 RPC URL is required');
63
68
  }
64
69
  if ((config.l1RpcUrls?.length || 0) > 1) {
65
- logger.warn(`Multiple L1 RPC URLs provided. Sandbox will only use the first one: ${l1RpcUrl}`);
70
+ logger.warn(`Multiple L1 RPC URLs provided. Local networks will only use the first one: ${l1RpcUrl}`);
66
71
  }
72
+ // The local network deploys a banana FPC with Token contracts, so include Token entries
73
+ // in the setup allowlist so FPC-based fee payments work out of the box.
74
+ const tokenAllowList = await getTokenAllowedSetupFunctions();
67
75
  const aztecNodeConfig = {
68
76
  ...getConfigEnvVars(),
69
- ...config
77
+ ...config,
78
+ txPublicSetupAllowListExtend: [
79
+ ...tokenAllowList,
80
+ ...config.txPublicSetupAllowListExtend ?? []
81
+ ]
70
82
  };
71
83
  const hdAccount = mnemonicToAccount(config.l1Mnemonic || DefaultMnemonic);
72
- if (aztecNodeConfig.publisherPrivateKeys == undefined || !aztecNodeConfig.publisherPrivateKeys.length || aztecNodeConfig.publisherPrivateKeys[0].getValue() === NULL_KEY) {
84
+ if (aztecNodeConfig.sequencerPublisherPrivateKeys == undefined || !aztecNodeConfig.sequencerPublisherPrivateKeys.length || aztecNodeConfig.sequencerPublisherPrivateKeys[0].getValue() === NULL_KEY) {
73
85
  const privKey = hdAccount.getHdKey().privateKey;
74
- aztecNodeConfig.publisherPrivateKeys = [
86
+ aztecNodeConfig.sequencerPublisherPrivateKeys = [
75
87
  new SecretValue(`0x${Buffer.from(privKey).toString('hex')}`)
76
88
  ];
77
89
  }
@@ -95,21 +107,25 @@ const localAnvil = foundry;
95
107
  })();
96
108
  const bananaFPC = await getBananaFPCAddress(initialAccounts);
97
109
  const sponsoredFPC = await getSponsoredFPCAddress();
98
- const fundedAddresses = initialAccounts.length ? [
110
+ const prefundAddresses = (aztecNodeConfig.prefundAddresses ?? []).map((a)=>AztecAddress.fromString(a));
111
+ const fundedAddresses = [
99
112
  ...initialAccounts.map((a)=>a.address),
100
- bananaFPC,
101
- sponsoredFPC
102
- ] : [];
113
+ ...initialAccounts.length ? [
114
+ bananaFPC,
115
+ sponsoredFPC
116
+ ] : [],
117
+ ...prefundAddresses
118
+ ];
103
119
  const { genesisArchiveRoot, prefilledPublicData, fundingNeeded } = await getGenesisValues(fundedAddresses);
104
- let watcher = undefined;
105
120
  const dateProvider = new TestDateProvider();
121
+ let cheatcodes;
122
+ let rollupAddress;
123
+ let watcher;
106
124
  if (!aztecNodeConfig.p2pEnabled) {
107
- const l1ContractAddresses = await deployContractsToL1(aztecNodeConfig, hdAccount, undefined, {
108
- assumeProvenThroughBlockNumber: Number.MAX_SAFE_INTEGER,
125
+ ({ rollupAddress } = await deployContractsToL1(aztecNodeConfig, aztecNodeConfig.validatorPrivateKeys.getValue()[0], {
109
126
  genesisArchiveRoot,
110
- salt: config.deployAztecContractsSalt ? parseInt(config.deployAztecContractsSalt) : undefined,
111
127
  feeJuicePortalInitialBalance: fundingNeeded
112
- });
128
+ }));
113
129
  const chain = aztecNodeConfig.l1RpcUrls.length > 0 ? createEthereumChain([
114
130
  l1RpcUrl
115
131
  ], aztecNodeConfig.l1ChainId) : {
@@ -121,34 +137,55 @@ const localAnvil = foundry;
121
137
  httpViemTransport(l1RpcUrl)
122
138
  ])
123
139
  });
124
- watcher = new AnvilTestWatcher(new EthCheatCodes([
140
+ cheatcodes = new EthCheatCodes([
125
141
  l1RpcUrl
126
- ], dateProvider), l1ContractAddresses.rollupAddress, publicClient, dateProvider);
127
- watcher.setIsSandbox(true);
142
+ ], dateProvider);
143
+ watcher = new AnvilTestWatcher(cheatcodes, rollupAddress, publicClient, dateProvider);
144
+ watcher.setisLocalNetwork(true);
145
+ watcher.setIsMarkingAsProven(false); // Do not mark as proven in the watcher. It's marked in the epochTestSettler after the out hash is set.
128
146
  await watcher.start();
129
147
  }
130
- const telemetry = initTelemetryClient(getTelemetryClientConfig());
131
- // Create a local blob sink client inside the sandbox, no http connectivity
132
- const blobSinkClient = createBlobSinkClient();
148
+ const telemetry = await initTelemetryClient(getTelemetryClientConfig());
149
+ // Create a local blob client client inside the local network, no http connectivity
150
+ const blobClient = createBlobClient();
133
151
  const node = await createAztecNode(aztecNodeConfig, {
134
152
  telemetry,
135
- blobSinkClient,
153
+ blobClient,
136
154
  dateProvider
137
155
  }, {
138
156
  prefilledPublicData
139
157
  });
158
+ // Now that the node is up, let the watcher check for pending txs so it can skip unfilled slots faster when
159
+ // transactions are waiting in the mempool. Also let it check if the sequencer is actively building, to avoid
160
+ // warping time out from under an in-progress block.
161
+ watcher?.setGetPendingTxCount(()=>node.getPendingTxCount());
162
+ const sequencer = node.getSequencer()?.getSequencer();
163
+ if (sequencer) {
164
+ const idleStates = new Set([
165
+ SequencerState.STOPPED,
166
+ SequencerState.STOPPING,
167
+ SequencerState.IDLE,
168
+ SequencerState.SYNCHRONIZING
169
+ ]);
170
+ watcher?.setIsSequencerBuilding(()=>!idleStates.has(sequencer.getState()));
171
+ }
172
+ let epochTestSettler;
173
+ if (!aztecNodeConfig.p2pEnabled) {
174
+ epochTestSettler = new EpochTestSettler(cheatcodes, rollupAddress, node.getBlockSource(), logger.createChild('epoch-settler'), {
175
+ pollingIntervalMs: 200
176
+ });
177
+ await epochTestSettler.start();
178
+ }
140
179
  if (initialAccounts.length) {
141
- const PXEConfig = {
142
- proverEnabled: aztecNodeConfig.realProofs
143
- };
144
- const wallet = await TestWallet.create(node, PXEConfig);
180
+ const wallet = await EmbeddedWallet.create(node, {
181
+ pxeConfig: {
182
+ proverEnabled: aztecNodeConfig.realProofs
183
+ },
184
+ ephemeral: true
185
+ });
145
186
  userLog('Setting up funded test accounts...');
146
- const accountManagers = await deployFundedSchnorrAccounts(wallet, node, initialAccounts);
147
- const accountsWithSecrets = accountManagers.map((manager, i)=>({
148
- account: manager,
149
- secretKey: initialAccounts[i].secret
150
- }));
151
- const accLogs = await createAccountLogs(accountsWithSecrets, wallet);
187
+ const accountManagers = await deployFundedSchnorrAccounts(wallet, initialAccounts);
188
+ const accLogs = await createAccountLogs(accountManagers, wallet);
152
189
  userLog(accLogs.join(''));
153
190
  await setupBananaFPC(initialAccounts, wallet, userLog);
154
191
  userLog(`SponsoredFPC: ${await getSponsoredFPCAddress()}`);
@@ -158,6 +195,7 @@ const localAnvil = foundry;
158
195
  const stop = async ()=>{
159
196
  await node.stop();
160
197
  await watcher?.stop();
198
+ await epochTestSettler?.stop();
161
199
  };
162
200
  return {
163
201
  node,
@@ -178,6 +216,11 @@ const localAnvil = foundry;
178
216
  ...config.l1Contracts
179
217
  }
180
218
  };
181
- const node = await AztecNodeService.createAndSync(aztecNodeConfig, deps, options);
219
+ const node = await AztecNodeService.createAndSync(aztecNodeConfig, {
220
+ ...deps,
221
+ proverNodeDeps: {
222
+ broker: deps.proverBroker
223
+ }
224
+ }, options);
182
225
  return node;
183
226
  }
@@ -0,0 +1,5 @@
1
+ import type { AztecAddress } from '@aztec/aztec.js/addresses';
2
+ import type { Wallet } from '@aztec/aztec.js/wallet';
3
+ export declare function getSponsoredFPCAddress(): Promise<AztecAddress>;
4
+ export declare function registerDeployedSponsoredFPCInWalletAndGetAddress(wallet: Wallet): Promise<AztecAddress>;
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3BvbnNvcmVkX2ZwYy5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2xvY2FsLW5ldHdvcmsvc3BvbnNvcmVkX2ZwYy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssRUFBRSxZQUFZLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQU05RCxPQUFPLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQVVyRCx3QkFBc0Isc0JBQXNCLElBQUksT0FBTyxDQUFDLFlBQVksQ0FBQyxDQUVwRTtBQUVELHdCQUFzQixpREFBaUQsQ0FBQyxNQUFNLEVBQUUsTUFBTSxHQUFHLE9BQU8sQ0FBQyxZQUFZLENBQUMsQ0FLN0cifQ==
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sponsored_fpc.d.ts","sourceRoot":"","sources":["../../src/local-network/sponsored_fpc.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAM9D,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAUrD,wBAAsB,sBAAsB,IAAI,OAAO,CAAC,YAAY,CAAC,CAEpE;AAED,wBAAsB,iDAAiD,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC,CAK7G"}
@@ -1,2 +1,2 @@
1
1
  export declare const DefaultMnemonic = "test test test test test test test test test test test junk";
2
- //# sourceMappingURL=mnemonic.d.ts.map
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW5lbW9uaWMuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9tbmVtb25pYy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxlQUFPLE1BQU0sZUFBZSxnRUFBZ0UsQ0FBQyJ9
package/dest/splash.d.ts CHANGED
@@ -1,3 +1,3 @@
1
1
  export declare const splash: string;
2
2
  export declare const github = "https://github.com/AztecProtocol";
3
- //# sourceMappingURL=splash.d.ts.map
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3BsYXNoLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvc3BsYXNoLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGVBQU8sTUFBTSxNQUFNLEVBQUUsTUFPa0IsQ0FBQztBQUV4QyxlQUFPLE1BQU0sTUFBTSxxQ0FBcUMsQ0FBQyJ9
@@ -1,5 +1,5 @@
1
- import type { ViemClient } from '@aztec/ethereum';
2
1
  import { EthCheatCodes } from '@aztec/ethereum/test';
2
+ import type { ViemClient } from '@aztec/ethereum/types';
3
3
  import type { EthAddress } from '@aztec/foundation/eth-address';
4
4
  import type { TestDateProvider } from '@aztec/foundation/timer';
5
5
  /**
@@ -12,7 +12,7 @@ import type { TestDateProvider } from '@aztec/foundation/timer';
12
12
  export declare class AnvilTestWatcher {
13
13
  private cheatcodes;
14
14
  private dateProvider?;
15
- private isSandbox;
15
+ private isLocalNetwork;
16
16
  private rollup;
17
17
  private rollupCheatCodes;
18
18
  private l2SlotDuration;
@@ -21,14 +21,22 @@ export declare class AnvilTestWatcher {
21
21
  private markingAsProvenRunningPromise?;
22
22
  private logger;
23
23
  private isMarkingAsProven;
24
+ private getPendingTxCount?;
25
+ private isSequencerBuilding?;
26
+ private unfilledSlotFirstSeen?;
24
27
  constructor(cheatcodes: EthCheatCodes, rollupAddress: EthAddress, l1Client: ViemClient, dateProvider?: TestDateProvider | undefined);
25
28
  setIsMarkingAsProven(isMarkingAsProven: boolean): void;
26
- setIsSandbox(isSandbox: boolean): void;
29
+ setisLocalNetwork(isLocalNetwork: boolean): void;
30
+ /** Sets a callback to check for pending txs, used to skip unfilled slots faster when txs are waiting. */
31
+ setGetPendingTxCount(fn: () => Promise<number>): void;
32
+ /** Sets a callback to check if the sequencer is actively building, to avoid warping while it works. */
33
+ setIsSequencerBuilding(fn: () => boolean): void;
27
34
  start(): Promise<void>;
28
35
  stop(): Promise<void>;
29
36
  trigger(): Promise<void>;
30
37
  markAsProven(): Promise<void>;
31
38
  syncDateProviderToL1IfBehind(): Promise<void>;
32
39
  warpTimeIfNeeded(): Promise<void>;
40
+ private warpToTimestamp;
33
41
  }
34
- //# sourceMappingURL=anvil_test_watcher.d.ts.map
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW52aWxfdGVzdF93YXRjaGVyLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdGVzdGluZy9hbnZpbF90ZXN0X3dhdGNoZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGFBQWEsRUFBb0IsTUFBTSxzQkFBc0IsQ0FBQztBQUN2RSxPQUFPLEtBQUssRUFBRSxVQUFVLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUV4RCxPQUFPLEtBQUssRUFBRSxVQUFVLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUdoRSxPQUFPLEtBQUssRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBS2hFOzs7Ozs7R0FNRztBQUNILHFCQUFhLGdCQUFnQjtJQXlCekIsT0FBTyxDQUFDLFVBQVU7SUFHbEIsT0FBTyxDQUFDLFlBQVksQ0FBQztJQTNCdkIsT0FBTyxDQUFDLGNBQWMsQ0FBa0I7SUFFeEMsT0FBTyxDQUFDLE1BQU0sQ0FBc0Q7SUFDcEUsT0FBTyxDQUFDLGdCQUFnQixDQUFtQjtJQUMzQyxPQUFPLENBQUMsY0FBYyxDQUFVO0lBRWhDLE9BQU8sQ0FBQyxvQkFBb0IsQ0FBQyxDQUFpQjtJQUM5QyxPQUFPLENBQUMsdUJBQXVCLENBQUMsQ0FBaUI7SUFDakQsT0FBTyxDQUFDLDZCQUE2QixDQUFDLENBQWlCO0lBRXZELE9BQU8sQ0FBQyxNQUFNLENBQWlEO0lBRS9ELE9BQU8sQ0FBQyxpQkFBaUIsQ0FBUTtJQUdqQyxPQUFPLENBQUMsaUJBQWlCLENBQUMsQ0FBd0I7SUFHbEQsT0FBTyxDQUFDLG1CQUFtQixDQUFDLENBQWdCO0lBRzVDLE9BQU8sQ0FBQyxxQkFBcUIsQ0FBQyxDQUFxQztJQUVuRSxZQUNVLFVBQVUsRUFBRSxhQUFhLEVBQ2pDLGFBQWEsRUFBRSxVQUFVLEVBQ3pCLFFBQVEsRUFBRSxVQUFVLEVBQ1osWUFBWSxDQUFDLDhCQUFrQixFQWF4QztJQUVELG9CQUFvQixDQUFDLGlCQUFpQixFQUFFLE9BQU8sUUFHOUM7SUFFRCxpQkFBaUIsQ0FBQyxjQUFjLEVBQUUsT0FBTyxRQUV4QztJQUVELHlHQUF5RztJQUN6RyxvQkFBb0IsQ0FBQyxFQUFFLEVBQUUsTUFBTSxPQUFPLENBQUMsTUFBTSxDQUFDLFFBRTdDO0lBRUQsdUdBQXVHO0lBQ3ZHLHNCQUFzQixDQUFDLEVBQUUsRUFBRSxNQUFNLE9BQU8sUUFFdkM7SUFFSyxLQUFLLGtCQXlCVjtJQUVLLElBQUksa0JBSVQ7SUFFSyxPQUFPLGtCQUlaO0lBRUssWUFBWSxrQkFLakI7SUFFSyw0QkFBNEIsa0JBZWpDO0lBRUssZ0JBQWdCLGtCQXlEckI7WUFFYSxlQUFlO0NBTzlCIn0=
@@ -1 +1 @@
1
- {"version":3,"file":"anvil_test_watcher.d.ts","sourceRoot":"","sources":["../../src/testing/anvil_test_watcher.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,EAAE,aAAa,EAAoB,MAAM,sBAAsB,CAAC;AACvE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAGhE,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAKhE;;;;;;GAMG;AACH,qBAAa,gBAAgB;IAgBzB,OAAO,CAAC,UAAU;IAGlB,OAAO,CAAC,YAAY,CAAC;IAlBvB,OAAO,CAAC,SAAS,CAAkB;IAEnC,OAAO,CAAC,MAAM,CAAsD;IACpE,OAAO,CAAC,gBAAgB,CAAmB;IAC3C,OAAO,CAAC,cAAc,CAAU;IAEhC,OAAO,CAAC,oBAAoB,CAAC,CAAiB;IAC9C,OAAO,CAAC,uBAAuB,CAAC,CAAiB;IACjD,OAAO,CAAC,6BAA6B,CAAC,CAAiB;IAEvD,OAAO,CAAC,MAAM,CAAiD;IAE/D,OAAO,CAAC,iBAAiB,CAAQ;gBAGvB,UAAU,EAAE,aAAa,EACjC,aAAa,EAAE,UAAU,EACzB,QAAQ,EAAE,UAAU,EACZ,YAAY,CAAC,EAAE,gBAAgB,YAAA;IAezC,oBAAoB,CAAC,iBAAiB,EAAE,OAAO;IAK/C,YAAY,CAAC,SAAS,EAAE,OAAO;IAIzB,KAAK;IA2BL,IAAI;IAMJ,OAAO;IAMP,YAAY;IAOZ,4BAA4B;IAiB5B,gBAAgB;CAwCvB"}
1
+ {"version":3,"file":"anvil_test_watcher.d.ts","sourceRoot":"","sources":["../../src/testing/anvil_test_watcher.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAoB,MAAM,sBAAsB,CAAC;AACvE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AAExD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAGhE,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAKhE;;;;;;GAMG;AACH,qBAAa,gBAAgB;IAyBzB,OAAO,CAAC,UAAU;IAGlB,OAAO,CAAC,YAAY,CAAC;IA3BvB,OAAO,CAAC,cAAc,CAAkB;IAExC,OAAO,CAAC,MAAM,CAAsD;IACpE,OAAO,CAAC,gBAAgB,CAAmB;IAC3C,OAAO,CAAC,cAAc,CAAU;IAEhC,OAAO,CAAC,oBAAoB,CAAC,CAAiB;IAC9C,OAAO,CAAC,uBAAuB,CAAC,CAAiB;IACjD,OAAO,CAAC,6BAA6B,CAAC,CAAiB;IAEvD,OAAO,CAAC,MAAM,CAAiD;IAE/D,OAAO,CAAC,iBAAiB,CAAQ;IAGjC,OAAO,CAAC,iBAAiB,CAAC,CAAwB;IAGlD,OAAO,CAAC,mBAAmB,CAAC,CAAgB;IAG5C,OAAO,CAAC,qBAAqB,CAAC,CAAqC;IAEnE,YACU,UAAU,EAAE,aAAa,EACjC,aAAa,EAAE,UAAU,EACzB,QAAQ,EAAE,UAAU,EACZ,YAAY,CAAC,8BAAkB,EAaxC;IAED,oBAAoB,CAAC,iBAAiB,EAAE,OAAO,QAG9C;IAED,iBAAiB,CAAC,cAAc,EAAE,OAAO,QAExC;IAED,yGAAyG;IACzG,oBAAoB,CAAC,EAAE,EAAE,MAAM,OAAO,CAAC,MAAM,CAAC,QAE7C;IAED,uGAAuG;IACvG,sBAAsB,CAAC,EAAE,EAAE,MAAM,OAAO,QAEvC;IAEK,KAAK,kBAyBV;IAEK,IAAI,kBAIT;IAEK,OAAO,kBAIZ;IAEK,YAAY,kBAKjB;IAEK,4BAA4B,kBAejC;IAEK,gBAAgB,kBAyDrB;YAEa,eAAe;CAO9B"}
@@ -1,4 +1,5 @@
1
1
  import { RollupCheatCodes } from '@aztec/ethereum/test';
2
+ import { SlotNumber } from '@aztec/foundation/branded-types';
2
3
  import { createLogger } from '@aztec/foundation/log';
3
4
  import { RunningPromise } from '@aztec/foundation/running-promise';
4
5
  import { RollupAbi } from '@aztec/l1-artifacts/RollupAbi';
@@ -12,7 +13,7 @@ import { getAddress, getContract } from 'viem';
12
13
  */ export class AnvilTestWatcher {
13
14
  cheatcodes;
14
15
  dateProvider;
15
- isSandbox;
16
+ isLocalNetwork;
16
17
  rollup;
17
18
  rollupCheatCodes;
18
19
  l2SlotDuration;
@@ -21,10 +22,16 @@ import { getAddress, getContract } from 'viem';
21
22
  markingAsProvenRunningPromise;
22
23
  logger;
23
24
  isMarkingAsProven;
25
+ // Optional callback to check if there are pending txs in the mempool.
26
+ getPendingTxCount;
27
+ // Optional callback to check if the sequencer is actively building a block.
28
+ isSequencerBuilding;
29
+ // Tracks when we first observed the current unfilled slot with pending txs (real wall time).
30
+ unfilledSlotFirstSeen;
24
31
  constructor(cheatcodes, rollupAddress, l1Client, dateProvider){
25
32
  this.cheatcodes = cheatcodes;
26
33
  this.dateProvider = dateProvider;
27
- this.isSandbox = false;
34
+ this.isLocalNetwork = false;
28
35
  this.logger = createLogger(`aztecjs:utils:watcher`);
29
36
  this.isMarkingAsProven = true;
30
37
  this.rollup = getContract({
@@ -41,8 +48,14 @@ import { getAddress, getContract } from 'viem';
41
48
  this.logger.warn(`Watcher is now ${isMarkingAsProven ? 'marking' : 'not marking'} blocks as proven`);
42
49
  this.isMarkingAsProven = isMarkingAsProven;
43
50
  }
44
- setIsSandbox(isSandbox) {
45
- this.isSandbox = isSandbox;
51
+ setisLocalNetwork(isLocalNetwork) {
52
+ this.isLocalNetwork = isLocalNetwork;
53
+ }
54
+ /** Sets a callback to check for pending txs, used to skip unfilled slots faster when txs are waiting. */ setGetPendingTxCount(fn) {
55
+ this.getPendingTxCount = fn;
56
+ }
57
+ /** Sets a callback to check if the sequencer is actively building, to avoid warping while it works. */ setIsSequencerBuilding(fn) {
58
+ this.isSequencerBuilding = fn;
46
59
  }
47
60
  async start() {
48
61
  if (this.filledRunningPromise) {
@@ -52,7 +65,7 @@ import { getAddress, getContract } from 'viem';
52
65
  this.l2SlotDuration = config.slotDuration;
53
66
  // If auto mining is not supported (e.g., we are on a real network), then we
54
67
  // will simple do nothing. But if on an anvil or the like, this make sure that
55
- // the sandbox and tests don't break because time is frozen and we never get to
68
+ // the local network and tests don't break because time is frozen and we never get to
56
69
  // the next slot.
57
70
  const isAutoMining = await this.cheatcodes.isAutoMining();
58
71
  if (isAutoMining) {
@@ -84,7 +97,7 @@ import { getAddress, getContract } from 'viem';
84
97
  await this.rollupCheatCodes.markAsProven();
85
98
  }
86
99
  async syncDateProviderToL1IfBehind() {
87
- // this doesn't apply to the sandbox, because we don't have a date provider in the sandbox
100
+ // this doesn't apply to the local network, because we don't have a date provider in the local network
88
101
  if (!this.dateProvider) {
89
102
  return;
90
103
  }
@@ -100,43 +113,69 @@ import { getAddress, getContract } from 'viem';
100
113
  }
101
114
  async warpTimeIfNeeded() {
102
115
  try {
103
- const currentSlot = await this.rollup.read.getCurrentSlot();
104
- const pendingBlockNumber = BigInt(await this.rollup.read.getPendingBlockNumber());
105
- const blockLog = await this.rollup.read.getBlock([
106
- pendingBlockNumber
116
+ const currentSlot = SlotNumber.fromBigInt(await this.rollup.read.getCurrentSlot());
117
+ const pendingCheckpointNumber = await this.rollup.read.getPendingCheckpointNumber();
118
+ const checkpointLog = await this.rollup.read.getCheckpoint([
119
+ pendingCheckpointNumber
107
120
  ]);
121
+ const nextSlot = SlotNumber(currentSlot + 1);
108
122
  const nextSlotTimestamp = Number(await this.rollup.read.getTimestampForSlot([
109
- currentSlot + 1n
123
+ BigInt(nextSlot)
110
124
  ]));
111
- if (currentSlot === blockLog.slotNumber) {
112
- // We should jump to the next slot
113
- try {
114
- await this.cheatcodes.warp(nextSlotTimestamp, {
115
- resetBlockInterval: true
116
- });
117
- } catch (e) {
118
- this.logger.error(`Failed to warp to timestamp ${nextSlotTimestamp}: ${e}`);
119
- }
125
+ if (BigInt(currentSlot) === checkpointLog.slotNumber) {
126
+ // The current slot has been filled, we should jump to the next slot.
127
+ await this.warpToTimestamp(nextSlotTimestamp);
120
128
  this.logger.info(`Slot ${currentSlot} was filled, jumped to next slot`);
121
129
  return;
122
130
  }
123
- // If we are not in sandbox, we don't need to warp time
124
- if (!this.isSandbox) {
131
+ // If we are not in local network, we don't need to warp time
132
+ if (!this.isLocalNetwork) {
125
133
  return;
126
134
  }
135
+ // If there are pending txs and the sequencer missed them, warp quickly (after a 2s real-time debounce) so the
136
+ // sequencer can retry in the next slot. Without this, we'd have to wait a full real-time slot duration (~36s) for
137
+ // the dateProvider to catch up to the next slot timestamp. We skip the warp if the sequencer is actively building
138
+ // to avoid invalidating its in-progress work.
139
+ if (this.getPendingTxCount) {
140
+ const pendingTxs = await this.getPendingTxCount();
141
+ if (pendingTxs > 0) {
142
+ if (this.isSequencerBuilding?.()) {
143
+ this.unfilledSlotFirstSeen = undefined;
144
+ return;
145
+ }
146
+ const realNow = Date.now();
147
+ if (!this.unfilledSlotFirstSeen || this.unfilledSlotFirstSeen.slot !== currentSlot) {
148
+ this.unfilledSlotFirstSeen = {
149
+ slot: currentSlot,
150
+ realTime: realNow
151
+ };
152
+ return;
153
+ }
154
+ if (realNow - this.unfilledSlotFirstSeen.realTime > 2000) {
155
+ await this.warpToTimestamp(nextSlotTimestamp);
156
+ this.unfilledSlotFirstSeen = undefined;
157
+ this.logger.info(`Slot ${currentSlot} was missed with pending txs, jumped to next slot`);
158
+ }
159
+ return;
160
+ }
161
+ }
162
+ // Fallback: warp when the dateProvider time has passed the next slot timestamp.
127
163
  const currentTimestamp = this.dateProvider?.now() ?? Date.now();
128
164
  if (currentTimestamp > nextSlotTimestamp * 1000) {
129
- try {
130
- await this.cheatcodes.warp(nextSlotTimestamp, {
131
- resetBlockInterval: true
132
- });
133
- } catch (e) {
134
- this.logger.error(`Failed to warp to timestamp ${nextSlotTimestamp}: ${e}`);
135
- }
165
+ await this.warpToTimestamp(nextSlotTimestamp);
136
166
  this.logger.info(`Slot ${currentSlot} was missed, jumped to next slot`);
137
167
  }
138
168
  } catch {
139
169
  this.logger.error('mineIfSlotFilled failed');
140
170
  }
141
171
  }
172
+ async warpToTimestamp(timestamp) {
173
+ try {
174
+ await this.cheatcodes.warp(timestamp, {
175
+ resetBlockInterval: true
176
+ });
177
+ } catch (e) {
178
+ this.logger.error(`Failed to warp to timestamp ${timestamp}: ${e}`);
179
+ }
180
+ }
142
181
  }
@@ -40,4 +40,4 @@ export declare class CheatCodes {
40
40
  */
41
41
  warpL2TimeAtLeastBy(sequencerClient: SequencerClient, node: AztecNode, duration: bigint | number): Promise<void>;
42
42
  }
43
- //# sourceMappingURL=cheat_codes.d.ts.map
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlYXRfY29kZXMuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90ZXN0aW5nL2NoZWF0X2NvZGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxhQUFhLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUd2RSxPQUFPLEtBQUssRUFBRSxZQUFZLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM1RCxPQUFPLEtBQUssRUFBRSxlQUFlLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUMvRCxPQUFPLEtBQUssRUFBRSxTQUFTLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUVqRTs7Ozs7R0FLRztBQUNILHFCQUFhLFVBQVU7SUFFbkIseUJBQXlCO0lBQ2xCLEdBQUcsRUFBRSxhQUFhO0lBQ3pCLHVEQUF1RDtJQUNoRCxNQUFNLEVBQUUsZ0JBQWdCO0lBSmpDO0lBQ0UseUJBQXlCO0lBQ2xCLEdBQUcsRUFBRSxhQUFhO0lBQ3pCLHVEQUF1RDtJQUNoRCxNQUFNLEVBQUUsZ0JBQWdCLEVBQzdCO0lBRUosT0FBYSxNQUFNLENBQUMsT0FBTyxFQUFFLE1BQU0sRUFBRSxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLFlBQVksR0FBRyxPQUFPLENBQUMsVUFBVSxDQUFDLENBT3ZHO0lBRUQ7Ozs7Ozs7O09BUUc7SUFDRyxtQkFBbUIsQ0FBQyxlQUFlLEVBQUUsZUFBZSxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUUsZUFBZSxFQUFFLE1BQU0sR0FBRyxNQUFNLGlCQXVCNUc7SUFFRDs7Ozs7Ozs7T0FRRztJQUNHLG1CQUFtQixDQUFDLGVBQWUsRUFBRSxlQUFlLEVBQUUsSUFBSSxFQUFFLFNBQVMsRUFBRSxRQUFRLEVBQUUsTUFBTSxHQUFHLE1BQU0saUJBSXJHO0NBQ0YifQ==
@@ -1 +1 @@
1
- {"version":3,"file":"cheat_codes.d.ts","sourceRoot":"","sources":["../../src/testing/cheat_codes.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAEvE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAC5D,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC/D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iCAAiC,CAAC;AAEjE;;;;;GAKG;AACH,qBAAa,UAAU;IAEnB,yBAAyB;IAClB,GAAG,EAAE,aAAa;IACzB,uDAAuD;IAChD,MAAM,EAAE,gBAAgB;;IAH/B,yBAAyB;IAClB,GAAG,EAAE,aAAa;IACzB,uDAAuD;IAChD,MAAM,EAAE,gBAAgB;WAGpB,MAAM,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,YAAY,EAAE,YAAY,GAAG,OAAO,CAAC,UAAU,CAAC;IASxG;;;;;;;;OAQG;IACG,mBAAmB,CAAC,eAAe,EAAE,eAAe,EAAE,IAAI,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,GAAG,MAAM;IAyB7G;;;;;;;;OAQG;IACG,mBAAmB,CAAC,eAAe,EAAE,eAAe,EAAE,IAAI,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,GAAG,MAAM;CAKvG"}
1
+ {"version":3,"file":"cheat_codes.d.ts","sourceRoot":"","sources":["../../src/testing/cheat_codes.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAGvE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAC5D,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC/D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iCAAiC,CAAC;AAEjE;;;;;GAKG;AACH,qBAAa,UAAU;IAEnB,yBAAyB;IAClB,GAAG,EAAE,aAAa;IACzB,uDAAuD;IAChD,MAAM,EAAE,gBAAgB;IAJjC;IACE,yBAAyB;IAClB,GAAG,EAAE,aAAa;IACzB,uDAAuD;IAChD,MAAM,EAAE,gBAAgB,EAC7B;IAEJ,OAAa,MAAM,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,YAAY,EAAE,YAAY,GAAG,OAAO,CAAC,UAAU,CAAC,CAOvG;IAED;;;;;;;;OAQG;IACG,mBAAmB,CAAC,eAAe,EAAE,eAAe,EAAE,IAAI,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,GAAG,MAAM,iBAuB5G;IAED;;;;;;;;OAQG;IACG,mBAAmB,CAAC,eAAe,EAAE,eAAe,EAAE,IAAI,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,GAAG,MAAM,iBAIrG;CACF"}
@@ -0,0 +1,19 @@
1
+ import { type EthCheatCodes } from '@aztec/ethereum/test';
2
+ import { type EpochNumber } from '@aztec/foundation/branded-types';
3
+ import type { Logger } from '@aztec/foundation/log';
4
+ import type { EthAddress, L2BlockSource } from '@aztec/stdlib/block';
5
+ export declare class EpochTestSettler {
6
+ private l2BlockSource;
7
+ private log;
8
+ private options;
9
+ private rollupCheatCodes;
10
+ private epochMonitor?;
11
+ constructor(cheatcodes: EthCheatCodes, rollupAddress: EthAddress, l2BlockSource: L2BlockSource, log: Logger, options: {
12
+ pollingIntervalMs: number;
13
+ provingDelayMs?: number;
14
+ });
15
+ start(): Promise<void>;
16
+ stop(): Promise<void>;
17
+ handleEpochReadyToProve(epoch: EpochNumber): Promise<boolean>;
18
+ }
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXBvY2hfdGVzdF9zZXR0bGVyLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdGVzdGluZy9lcG9jaF90ZXN0X3NldHRsZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLEtBQUssYUFBYSxFQUFvQixNQUFNLHNCQUFzQixDQUFDO0FBQzVFLE9BQU8sRUFBRSxLQUFLLFdBQVcsRUFBYyxNQUFNLGlDQUFpQyxDQUFDO0FBQy9FLE9BQU8sS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBRXBELE9BQU8sS0FBSyxFQUFFLFVBQVUsRUFBRSxhQUFhLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUdyRSxxQkFBYSxnQkFBZ0I7SUFPekIsT0FBTyxDQUFDLGFBQWE7SUFDckIsT0FBTyxDQUFDLEdBQUc7SUFDWCxPQUFPLENBQUMsT0FBTztJQVJqQixPQUFPLENBQUMsZ0JBQWdCLENBQW1CO0lBQzNDLE9BQU8sQ0FBQyxZQUFZLENBQUMsQ0FBZTtJQUVwQyxZQUNFLFVBQVUsRUFBRSxhQUFhLEVBQ3pCLGFBQWEsRUFBRSxVQUFVLEVBQ2pCLGFBQWEsRUFBRSxhQUFhLEVBQzVCLEdBQUcsRUFBRSxNQUFNLEVBQ1gsT0FBTyxFQUFFO1FBQUUsaUJBQWlCLEVBQUUsTUFBTSxDQUFDO1FBQUMsY0FBYyxDQUFDLEVBQUUsTUFBTSxDQUFBO0tBQUUsRUFHeEU7SUFFSyxLQUFLLGtCQUlWO0lBRUssSUFBSSxrQkFFVDtJQUVLLHVCQUF1QixDQUFDLEtBQUssRUFBRSxXQUFXLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQW9DbEU7Q0FDRiJ9
@@ -0,0 +1 @@
1
+ {"version":3,"file":"epoch_test_settler.d.ts","sourceRoot":"","sources":["../../src/testing/epoch_test_settler.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,aAAa,EAAoB,MAAM,sBAAsB,CAAC;AAC5E,OAAO,EAAE,KAAK,WAAW,EAAc,MAAM,iCAAiC,CAAC;AAC/E,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAEpD,OAAO,KAAK,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAGrE,qBAAa,gBAAgB;IAOzB,OAAO,CAAC,aAAa;IACrB,OAAO,CAAC,GAAG;IACX,OAAO,CAAC,OAAO;IARjB,OAAO,CAAC,gBAAgB,CAAmB;IAC3C,OAAO,CAAC,YAAY,CAAC,CAAe;IAEpC,YACE,UAAU,EAAE,aAAa,EACzB,aAAa,EAAE,UAAU,EACjB,aAAa,EAAE,aAAa,EAC5B,GAAG,EAAE,MAAM,EACX,OAAO,EAAE;QAAE,iBAAiB,EAAE,MAAM,CAAC;QAAC,cAAc,CAAC,EAAE,MAAM,CAAA;KAAE,EAGxE;IAEK,KAAK,kBAIV;IAEK,IAAI,kBAET;IAEK,uBAAuB,CAAC,KAAK,EAAE,WAAW,GAAG,OAAO,CAAC,OAAO,CAAC,CAoClE;CACF"}
@@ -0,0 +1,61 @@
1
+ import { RollupCheatCodes } from '@aztec/ethereum/test';
2
+ import { SlotNumber } from '@aztec/foundation/branded-types';
3
+ import { EpochMonitor } from '@aztec/prover-node';
4
+ import { computeEpochOutHash } from '@aztec/stdlib/messaging';
5
+ export class EpochTestSettler {
6
+ l2BlockSource;
7
+ log;
8
+ options;
9
+ rollupCheatCodes;
10
+ epochMonitor;
11
+ constructor(cheatcodes, rollupAddress, l2BlockSource, log, options){
12
+ this.l2BlockSource = l2BlockSource;
13
+ this.log = log;
14
+ this.options = options;
15
+ this.rollupCheatCodes = new RollupCheatCodes(cheatcodes, {
16
+ rollupAddress
17
+ });
18
+ }
19
+ async start() {
20
+ const { epochDuration } = await this.rollupCheatCodes.getConfig();
21
+ this.epochMonitor = new EpochMonitor(this.l2BlockSource, {
22
+ epochDuration: Number(epochDuration)
23
+ }, this.options);
24
+ this.epochMonitor.start(this);
25
+ }
26
+ async stop() {
27
+ await this.epochMonitor?.stop();
28
+ }
29
+ async handleEpochReadyToProve(epoch) {
30
+ const checkpointedBlocks = await this.l2BlockSource.getCheckpointedBlocksForEpoch(epoch);
31
+ const blocks = checkpointedBlocks.map((b)=>b.block);
32
+ this.log.info(`Settling epoch ${epoch} with blocks ${blocks[0]?.header.getBlockNumber()} to ${blocks.at(-1)?.header.getBlockNumber()}`, {
33
+ blocks: blocks.map((b)=>b.toBlockInfo())
34
+ });
35
+ const messagesInEpoch = [];
36
+ let previousSlotNumber = SlotNumber.ZERO;
37
+ let checkpointIndex = -1;
38
+ for (const block of blocks){
39
+ const slotNumber = block.header.globalVariables.slotNumber;
40
+ if (slotNumber !== previousSlotNumber) {
41
+ checkpointIndex++;
42
+ messagesInEpoch[checkpointIndex] = [];
43
+ previousSlotNumber = slotNumber;
44
+ }
45
+ messagesInEpoch[checkpointIndex].push(block.body.txEffects.map((txEffect)=>txEffect.l2ToL1Msgs));
46
+ }
47
+ const outHash = computeEpochOutHash(messagesInEpoch);
48
+ if (!outHash.isZero()) {
49
+ await this.rollupCheatCodes.insertOutbox(epoch, outHash.toBigInt());
50
+ } else {
51
+ this.log.info(`No L2 to L1 messages in epoch ${epoch}`);
52
+ }
53
+ const lastCheckpoint = checkpointedBlocks.at(-1)?.checkpointNumber;
54
+ if (lastCheckpoint !== undefined) {
55
+ await this.rollupCheatCodes.markAsProven(lastCheckpoint);
56
+ } else {
57
+ this.log.warn(`No checkpoint found for epoch ${epoch}`);
58
+ }
59
+ return true;
60
+ }
61
+ }
@@ -1,4 +1,6 @@
1
1
  export { AnvilTestWatcher } from './anvil_test_watcher.js';
2
2
  export { EthCheatCodes, RollupCheatCodes } from '@aztec/ethereum/test';
3
3
  export { CheatCodes } from './cheat_codes.js';
4
- //# sourceMappingURL=index.d.ts.map
4
+ export { EpochTestSettler } from './epoch_test_settler.js';
5
+ export { getTokenAllowedSetupFunctions } from './token_allowed_setup.js';
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90ZXN0aW5nL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzNELE9BQU8sRUFBRSxhQUFhLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN2RSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDOUMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDM0QsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sMEJBQTBCLENBQUMifQ==
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/testing/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAC3D,OAAO,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AACvE,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/testing/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAC3D,OAAO,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AACvE,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAC3D,OAAO,EAAE,6BAA6B,EAAE,MAAM,0BAA0B,CAAC"}
@@ -1,3 +1,5 @@
1
1
  export { AnvilTestWatcher } from './anvil_test_watcher.js';
2
2
  export { EthCheatCodes, RollupCheatCodes } from '@aztec/ethereum/test';
3
3
  export { CheatCodes } from './cheat_codes.js';
4
+ export { EpochTestSettler } from './epoch_test_settler.js';
5
+ export { getTokenAllowedSetupFunctions } from './token_allowed_setup.js';
@@ -0,0 +1,7 @@
1
+ import type { AllowedElement } from '@aztec/stdlib/interfaces/server';
2
+ /**
3
+ * Returns Token-specific allowlist entries needed for FPC-based fee payments.
4
+ * These are test-only: FPC-based fee payment with custom tokens won't work on mainnet alpha.
5
+ */
6
+ export declare function getTokenAllowedSetupFunctions(): Promise<AllowedElement[]>;
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9rZW5fYWxsb3dlZF9zZXR1cC5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3Rlc3RpbmcvdG9rZW5fYWxsb3dlZF9zZXR1cC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHQSxPQUFPLEtBQUssRUFBRSxjQUFjLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUV0RTs7O0dBR0c7QUFDSCx3QkFBc0IsNkJBQTZCLElBQUksT0FBTyxDQUFDLGNBQWMsRUFBRSxDQUFDLENBUy9FIn0=
@@ -0,0 +1 @@
1
+ {"version":3,"file":"token_allowed_setup.d.ts","sourceRoot":"","sources":["../../src/testing/token_allowed_setup.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AAEtE;;;GAGG;AACH,wBAAsB,6BAA6B,IAAI,OAAO,CAAC,cAAc,EAAE,CAAC,CAS/E"}
@@ -0,0 +1,20 @@
1
+ import { TokenContractArtifact } from '@aztec/noir-contracts.js/Token';
2
+ import { buildAllowedElement } from '@aztec/p2p/msg_validators';
3
+ import { getContractClassFromArtifact } from '@aztec/stdlib/contract';
4
+ /**
5
+ * Returns Token-specific allowlist entries needed for FPC-based fee payments.
6
+ * These are test-only: FPC-based fee payment with custom tokens won't work on mainnet alpha.
7
+ */ export async function getTokenAllowedSetupFunctions() {
8
+ const tokenClassId = (await getContractClassFromArtifact(TokenContractArtifact)).id;
9
+ const target = {
10
+ classId: tokenClassId
11
+ };
12
+ return Promise.all([
13
+ // Token: needed for private transfers via FPC (transfer_to_public enqueues this)
14
+ buildAllowedElement(TokenContractArtifact, target, '_increase_public_balance', {
15
+ onlySelf: true
16
+ }),
17
+ // Token: needed for public transfers via FPC (fee_entrypoint_public enqueues this)
18
+ buildAllowedElement(TokenContractArtifact, target, 'transfer_in_public')
19
+ ]);
20
+ }