@aztec/bot 0.0.1-commit.4ad48494d → 0.0.1-commit.4d3c002

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 (46) hide show
  1. package/dest/amm_bot.d.ts +1 -1
  2. package/dest/amm_bot.d.ts.map +1 -1
  3. package/dest/amm_bot.js +24 -17
  4. package/dest/base_bot.d.ts +3 -3
  5. package/dest/base_bot.d.ts.map +1 -1
  6. package/dest/base_bot.js +12 -22
  7. package/dest/bot.d.ts +1 -1
  8. package/dest/bot.d.ts.map +1 -1
  9. package/dest/bot.js +3 -6
  10. package/dest/config.d.ts +28 -12
  11. package/dest/config.d.ts.map +1 -1
  12. package/dest/config.js +31 -9
  13. package/dest/cross_chain_bot.d.ts +54 -0
  14. package/dest/cross_chain_bot.d.ts.map +1 -0
  15. package/dest/cross_chain_bot.js +134 -0
  16. package/dest/factory.d.ts +20 -1
  17. package/dest/factory.d.ts.map +1 -1
  18. package/dest/factory.js +279 -58
  19. package/dest/index.d.ts +2 -1
  20. package/dest/index.d.ts.map +1 -1
  21. package/dest/index.js +1 -0
  22. package/dest/l1_to_l2_seeding.d.ts +8 -0
  23. package/dest/l1_to_l2_seeding.d.ts.map +1 -0
  24. package/dest/l1_to_l2_seeding.js +63 -0
  25. package/dest/runner.d.ts +1 -1
  26. package/dest/runner.d.ts.map +1 -1
  27. package/dest/runner.js +17 -1
  28. package/dest/store/bot_store.d.ts +30 -5
  29. package/dest/store/bot_store.d.ts.map +1 -1
  30. package/dest/store/bot_store.js +37 -6
  31. package/dest/store/index.d.ts +2 -2
  32. package/dest/store/index.d.ts.map +1 -1
  33. package/dest/utils.js +3 -3
  34. package/package.json +16 -13
  35. package/src/amm_bot.ts +21 -16
  36. package/src/base_bot.ts +8 -16
  37. package/src/bot.ts +3 -5
  38. package/src/config.ts +37 -13
  39. package/src/cross_chain_bot.ts +203 -0
  40. package/src/factory.ts +326 -55
  41. package/src/index.ts +1 -0
  42. package/src/l1_to_l2_seeding.ts +79 -0
  43. package/src/runner.ts +16 -3
  44. package/src/store/bot_store.ts +60 -5
  45. package/src/store/index.ts +1 -1
  46. package/src/utils.ts +3 -3
package/dest/factory.d.ts CHANGED
@@ -1,7 +1,9 @@
1
1
  import { AztecAddress } from '@aztec/aztec.js/addresses';
2
+ import type { ExtendedViemWalletClient } from '@aztec/ethereum/types';
2
3
  import { AMMContract } from '@aztec/noir-contracts.js/AMM';
3
4
  import { PrivateTokenContract } from '@aztec/noir-contracts.js/PrivateToken';
4
5
  import { TokenContract } from '@aztec/noir-contracts.js/Token';
6
+ import { TestContract } from '@aztec/noir-test-contracts.js/Test';
5
7
  import type { AztecNode, AztecNodeAdmin } from '@aztec/stdlib/interfaces/client';
6
8
  import { EmbeddedWallet } from '@aztec/wallets/embedded';
7
9
  import { type BotConfig } from './config.js';
@@ -33,17 +35,34 @@ export declare class BotFactory {
33
35
  token1: TokenContract;
34
36
  node: AztecNode;
35
37
  }>;
38
+ /**
39
+ * Initializes the cross-chain bot by deploying TestContract, creating an L1 client,
40
+ * seeding initial L1→L2 messages, and waiting for the first to be ready.
41
+ */
42
+ setupCrossChain(): Promise<{
43
+ wallet: EmbeddedWallet;
44
+ defaultAccountAddress: AztecAddress;
45
+ contract: TestContract;
46
+ node: AztecNode;
47
+ l1Client: ExtendedViemWalletClient;
48
+ rollupVersion: bigint;
49
+ }>;
50
+ private setupTestContract;
36
51
  private setupAccount;
37
52
  private setupAccountWithPrivateKey;
38
53
  private setupTestAccount;
54
+ private setupTokenWithOptionalEarlyRefuel;
55
+ private setupTokenContractWithOptionalEarlyRefuel;
56
+ private getTokenInstance;
39
57
  private setupToken;
40
58
  private setupTokenContract;
41
59
  private setupAmmContract;
42
60
  private fundAmm;
43
61
  private registerOrDeployContract;
62
+ private ensureFeeJuiceBalance;
44
63
  private mintTokens;
45
64
  private getOrCreateBridgeClaim;
46
65
  private bridgeL1FeeJuice;
47
66
  private withNoMinTxsPerBlock;
48
67
  }
49
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmFjdG9yeS5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2ZhY3RvcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBb0J6RCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDM0QsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDN0UsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBRy9ELE9BQU8sS0FBSyxFQUFFLFNBQVMsRUFBRSxjQUFjLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUVqRixPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFFekQsT0FBTyxFQUFFLEtBQUssU0FBUyxFQUEyQixNQUFNLGFBQWEsQ0FBQztBQUN0RSxPQUFPLEtBQUssRUFBRSxRQUFRLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQU1qRCxxQkFBYSxVQUFVO0lBSW5CLE9BQU8sQ0FBQyxRQUFRLENBQUMsTUFBTTtJQUN2QixPQUFPLENBQUMsUUFBUSxDQUFDLE1BQU07SUFDdkIsT0FBTyxDQUFDLFFBQVEsQ0FBQyxLQUFLO0lBQ3RCLE9BQU8sQ0FBQyxRQUFRLENBQUMsU0FBUztJQUMxQixPQUFPLENBQUMsUUFBUSxDQUFDLGNBQWMsQ0FBQztJQVBsQyxPQUFPLENBQUMsR0FBRyxDQUF1QjtJQUVsQyxZQUNtQixNQUFNLEVBQUUsU0FBUyxFQUNqQixNQUFNLEVBQUUsY0FBYyxFQUN0QixLQUFLLEVBQUUsUUFBUSxFQUNmLFNBQVMsRUFBRSxTQUFTLEVBQ3BCLGNBQWMsQ0FBQyw0QkFBZ0IsRUFDOUM7SUFFSjs7O09BR0c7SUFDVSxLQUFLLElBQUksT0FBTyxDQUFDO1FBQzVCLE1BQU0sRUFBRSxjQUFjLENBQUM7UUFDdkIscUJBQXFCLEVBQUUsWUFBWSxDQUFDO1FBQ3BDLEtBQUssRUFBRSxhQUFhLEdBQUcsb0JBQW9CLENBQUM7UUFDNUMsSUFBSSxFQUFFLFNBQVMsQ0FBQztRQUNoQixTQUFTLEVBQUUsWUFBWSxDQUFDO0tBQ3pCLENBQUMsQ0FNRDtJQUVZLFFBQVEsSUFBSSxPQUFPLENBQUM7UUFDL0IsTUFBTSxFQUFFLGNBQWMsQ0FBQztRQUN2QixxQkFBcUIsRUFBRSxZQUFZLENBQUM7UUFDcEMsR0FBRyxFQUFFLFdBQVcsQ0FBQztRQUNqQixNQUFNLEVBQUUsYUFBYSxDQUFDO1FBQ3RCLE1BQU0sRUFBRSxhQUFhLENBQUM7UUFDdEIsSUFBSSxFQUFFLFNBQVMsQ0FBQztLQUNqQixDQUFDLENBc0JEO1lBTWEsWUFBWTtZQVdaLDBCQUEwQjtZQXlDMUIsZ0JBQWdCO1lBZWhCLFVBQVU7WUFvRFYsa0JBQWtCO1lBYWxCLGdCQUFnQjtZQXNCaEIsT0FBTztZQTZFUCx3QkFBd0I7WUEwQnhCLFVBQVU7WUEwQ1Ysc0JBQXNCO1lBNEJ0QixnQkFBZ0I7WUFnQ2hCLG9CQUFvQjtDQWVuQyJ9
68
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmFjdG9yeS5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2ZhY3RvcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBcUJ6RCxPQUFPLEtBQUssRUFBRSx3QkFBd0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBSXRFLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUM3RSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDL0QsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBR2xFLE9BQU8sS0FBSyxFQUFFLFNBQVMsRUFBRSxjQUFjLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUVqRixPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFFekQsT0FBTyxFQUFFLEtBQUssU0FBUyxFQUEyQixNQUFNLGFBQWEsQ0FBQztBQUV0RSxPQUFPLEtBQUssRUFBRSxRQUFRLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQVFqRCxxQkFBYSxVQUFVO0lBSW5CLE9BQU8sQ0FBQyxRQUFRLENBQUMsTUFBTTtJQUN2QixPQUFPLENBQUMsUUFBUSxDQUFDLE1BQU07SUFDdkIsT0FBTyxDQUFDLFFBQVEsQ0FBQyxLQUFLO0lBQ3RCLE9BQU8sQ0FBQyxRQUFRLENBQUMsU0FBUztJQUMxQixPQUFPLENBQUMsUUFBUSxDQUFDLGNBQWMsQ0FBQztJQVBsQyxPQUFPLENBQUMsR0FBRyxDQUF1QjtJQUVsQyxZQUNtQixNQUFNLEVBQUUsU0FBUyxFQUNqQixNQUFNLEVBQUUsY0FBYyxFQUN0QixLQUFLLEVBQUUsUUFBUSxFQUNmLFNBQVMsRUFBRSxTQUFTLEVBQ3BCLGNBQWMsQ0FBQyw0QkFBZ0IsRUFLakQ7SUFFRDs7O09BR0c7SUFDVSxLQUFLLElBQUksT0FBTyxDQUFDO1FBQzVCLE1BQU0sRUFBRSxjQUFjLENBQUM7UUFDdkIscUJBQXFCLEVBQUUsWUFBWSxDQUFDO1FBQ3BDLEtBQUssRUFBRSxhQUFhLEdBQUcsb0JBQW9CLENBQUM7UUFDNUMsSUFBSSxFQUFFLFNBQVMsQ0FBQztRQUNoQixTQUFTLEVBQUUsWUFBWSxDQUFDO0tBQ3pCLENBQUMsQ0FPRDtJQUVZLFFBQVEsSUFBSSxPQUFPLENBQUM7UUFDL0IsTUFBTSxFQUFFLGNBQWMsQ0FBQztRQUN2QixxQkFBcUIsRUFBRSxZQUFZLENBQUM7UUFDcEMsR0FBRyxFQUFFLFdBQVcsQ0FBQztRQUNqQixNQUFNLEVBQUUsYUFBYSxDQUFDO1FBQ3RCLE1BQU0sRUFBRSxhQUFhLENBQUM7UUFDdEIsSUFBSSxFQUFFLFNBQVMsQ0FBQztLQUNqQixDQUFDLENBNEJEO0lBRUQ7OztPQUdHO0lBQ1UsZUFBZSxJQUFJLE9BQU8sQ0FBQztRQUN0QyxNQUFNLEVBQUUsY0FBYyxDQUFDO1FBQ3ZCLHFCQUFxQixFQUFFLFlBQVksQ0FBQztRQUNwQyxRQUFRLEVBQUUsWUFBWSxDQUFDO1FBQ3ZCLElBQUksRUFBRSxTQUFTLENBQUM7UUFDaEIsUUFBUSxFQUFFLHdCQUF3QixDQUFDO1FBQ25DLGFBQWEsRUFBRSxNQUFNLENBQUM7S0FDdkIsQ0FBQyxDQTJERDtZQUVhLGlCQUFpQjtZQWVqQixZQUFZO1lBV1osMEJBQTBCO1lBdUMxQixnQkFBZ0I7WUFlaEIsaUNBQWlDO1lBY2pDLHlDQUF5QztZQW1CekMsZ0JBQWdCO1lBaUNoQixVQUFVO1lBd0NWLGtCQUFrQjtZQWFsQixnQkFBZ0I7WUF3QmhCLE9BQU87WUErRlAsd0JBQXdCO1lBNkR4QixxQkFBcUI7WUF1RHJCLFVBQVU7WUFpRFYsc0JBQXNCO1lBMkJ0QixnQkFBZ0I7WUErQmhCLG9CQUFvQjtDQWVuQyJ9
@@ -1 +1 @@
1
- {"version":3,"file":"factory.d.ts","sourceRoot":"","sources":["../src/factory.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAoBzD,OAAO,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAC;AAC3D,OAAO,EAAE,oBAAoB,EAAE,MAAM,uCAAuC,CAAC;AAC7E,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAG/D,OAAO,KAAK,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AAEjF,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAEzD,OAAO,EAAE,KAAK,SAAS,EAA2B,MAAM,aAAa,CAAC;AACtE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAMjD,qBAAa,UAAU;IAInB,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,KAAK;IACtB,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAC;IAPlC,OAAO,CAAC,GAAG,CAAuB;IAElC,YACmB,MAAM,EAAE,SAAS,EACjB,MAAM,EAAE,cAAc,EACtB,KAAK,EAAE,QAAQ,EACf,SAAS,EAAE,SAAS,EACpB,cAAc,CAAC,4BAAgB,EAC9C;IAEJ;;;OAGG;IACU,KAAK,IAAI,OAAO,CAAC;QAC5B,MAAM,EAAE,cAAc,CAAC;QACvB,qBAAqB,EAAE,YAAY,CAAC;QACpC,KAAK,EAAE,aAAa,GAAG,oBAAoB,CAAC;QAC5C,IAAI,EAAE,SAAS,CAAC;QAChB,SAAS,EAAE,YAAY,CAAC;KACzB,CAAC,CAMD;IAEY,QAAQ,IAAI,OAAO,CAAC;QAC/B,MAAM,EAAE,cAAc,CAAC;QACvB,qBAAqB,EAAE,YAAY,CAAC;QACpC,GAAG,EAAE,WAAW,CAAC;QACjB,MAAM,EAAE,aAAa,CAAC;QACtB,MAAM,EAAE,aAAa,CAAC;QACtB,IAAI,EAAE,SAAS,CAAC;KACjB,CAAC,CAsBD;YAMa,YAAY;YAWZ,0BAA0B;YAyC1B,gBAAgB;YAehB,UAAU;YAoDV,kBAAkB;YAalB,gBAAgB;YAsBhB,OAAO;YA6EP,wBAAwB;YA0BxB,UAAU;YA0CV,sBAAsB;YA4BtB,gBAAgB;YAgChB,oBAAoB;CAenC"}
1
+ {"version":3,"file":"factory.d.ts","sourceRoot":"","sources":["../src/factory.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAqBzD,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,uBAAuB,CAAC;AAItE,OAAO,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAC;AAC3D,OAAO,EAAE,oBAAoB,EAAE,MAAM,uCAAuC,CAAC;AAC7E,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAC/D,OAAO,EAAE,YAAY,EAAE,MAAM,oCAAoC,CAAC;AAGlE,OAAO,KAAK,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AAEjF,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAEzD,OAAO,EAAE,KAAK,SAAS,EAA2B,MAAM,aAAa,CAAC;AAEtE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAQjD,qBAAa,UAAU;IAInB,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,KAAK;IACtB,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAC;IAPlC,OAAO,CAAC,GAAG,CAAuB;IAElC,YACmB,MAAM,EAAE,SAAS,EACjB,MAAM,EAAE,cAAc,EACtB,KAAK,EAAE,QAAQ,EACf,SAAS,EAAE,SAAS,EACpB,cAAc,CAAC,4BAAgB,EAKjD;IAED;;;OAGG;IACU,KAAK,IAAI,OAAO,CAAC;QAC5B,MAAM,EAAE,cAAc,CAAC;QACvB,qBAAqB,EAAE,YAAY,CAAC;QACpC,KAAK,EAAE,aAAa,GAAG,oBAAoB,CAAC;QAC5C,IAAI,EAAE,SAAS,CAAC;QAChB,SAAS,EAAE,YAAY,CAAC;KACzB,CAAC,CAOD;IAEY,QAAQ,IAAI,OAAO,CAAC;QAC/B,MAAM,EAAE,cAAc,CAAC;QACvB,qBAAqB,EAAE,YAAY,CAAC;QACpC,GAAG,EAAE,WAAW,CAAC;QACjB,MAAM,EAAE,aAAa,CAAC;QACtB,MAAM,EAAE,aAAa,CAAC;QACtB,IAAI,EAAE,SAAS,CAAC;KACjB,CAAC,CA4BD;IAED;;;OAGG;IACU,eAAe,IAAI,OAAO,CAAC;QACtC,MAAM,EAAE,cAAc,CAAC;QACvB,qBAAqB,EAAE,YAAY,CAAC;QACpC,QAAQ,EAAE,YAAY,CAAC;QACvB,IAAI,EAAE,SAAS,CAAC;QAChB,QAAQ,EAAE,wBAAwB,CAAC;QACnC,aAAa,EAAE,MAAM,CAAC;KACvB,CAAC,CA2DD;YAEa,iBAAiB;YAejB,YAAY;YAWZ,0BAA0B;YAuC1B,gBAAgB;YAehB,iCAAiC;YAcjC,yCAAyC;YAmBzC,gBAAgB;YAiChB,UAAU;YAwCV,kBAAkB;YAalB,gBAAgB;YAwBhB,OAAO;YA+FP,wBAAwB;YA6DxB,qBAAqB;YAuDrB,UAAU;YAiDV,sBAAsB;YA2BtB,gBAAgB;YA+BhB,oBAAoB;CAenC"}
package/dest/factory.js CHANGED
@@ -1,5 +1,5 @@
1
1
  import { getInitialTestAccountsData } from '@aztec/accounts/testing';
2
- import { AztecAddress } from '@aztec/aztec.js/addresses';
2
+ import { NO_FROM } from '@aztec/aztec.js/account';
3
3
  import { BatchCall, NO_WAIT } from '@aztec/aztec.js/contracts';
4
4
  import { L1FeeJuicePortalManager } from '@aztec/aztec.js/ethereum';
5
5
  import { FeeJuicePaymentMethodWithClaim } from '@aztec/aztec.js/fee';
@@ -7,19 +7,27 @@ import { deriveKeys } from '@aztec/aztec.js/keys';
7
7
  import { createLogger } from '@aztec/aztec.js/log';
8
8
  import { waitForL1ToL2MessageReady } from '@aztec/aztec.js/messaging';
9
9
  import { waitForTx } from '@aztec/aztec.js/node';
10
+ import { getFeeJuiceBalance } from '@aztec/aztec.js/utils';
11
+ import { ContractInitializationStatus } from '@aztec/aztec.js/wallet';
10
12
  import { createEthereumChain } from '@aztec/ethereum/chain';
11
13
  import { createExtendedL1Client } from '@aztec/ethereum/client';
14
+ import { RollupContract } from '@aztec/ethereum/contracts';
12
15
  import { Fr } from '@aztec/foundation/curves/bn254';
16
+ import { EthAddress } from '@aztec/foundation/eth-address';
13
17
  import { Timer } from '@aztec/foundation/timer';
14
18
  import { AMMContract } from '@aztec/noir-contracts.js/AMM';
15
19
  import { PrivateTokenContract } from '@aztec/noir-contracts.js/PrivateToken';
16
20
  import { TokenContract } from '@aztec/noir-contracts.js/Token';
17
- import { GasSettings } from '@aztec/stdlib/gas';
21
+ import { TestContract } from '@aztec/noir-test-contracts.js/Test';
22
+ import { GasFees, GasSettings } from '@aztec/stdlib/gas';
18
23
  import { deriveSigningKey } from '@aztec/stdlib/keys';
19
24
  import { SupportedTokenContracts } from './config.js';
25
+ import { seedL1ToL2Message } from './l1_to_l2_seeding.js';
20
26
  import { getBalances, getPrivateBalance, isStandardTokenContract } from './utils.js';
21
27
  const MINT_BALANCE = 1e12;
22
28
  const MIN_BALANCE = 1e3;
29
+ const FEE_JUICE_TOP_UP_THRESHOLD = 100n * 10n ** 18n;
30
+ const FEE_JUICE_TOP_UP_TARGET = 10_000n * 10n ** 18n;
23
31
  export class BotFactory {
24
32
  config;
25
33
  wallet;
@@ -34,6 +42,9 @@ export class BotFactory {
34
42
  this.aztecNode = aztecNode;
35
43
  this.aztecNodeAdmin = aztecNodeAdmin;
36
44
  this.log = createLogger('bot');
45
+ // Set fee padding on the wallet so that all transactions during setup
46
+ // (token deploy, minting, etc.) use the configured padding, not the default.
47
+ this.wallet.setMinFeePadding(config.minFeePadding);
37
48
  }
38
49
  /**
39
50
  * Initializes a new bot by setting up the sender account, registering the recipient,
@@ -41,7 +52,8 @@ export class BotFactory {
41
52
  */ async setup() {
42
53
  const defaultAccountAddress = await this.setupAccount();
43
54
  const recipient = (await this.wallet.createSchnorrAccount(Fr.random(), Fr.random())).address;
44
- const token = await this.setupToken(defaultAccountAddress);
55
+ const token = await this.setupTokenWithOptionalEarlyRefuel(defaultAccountAddress);
56
+ await this.ensureFeeJuiceBalance(defaultAccountAddress, token);
45
57
  await this.mintTokens(token, defaultAccountAddress);
46
58
  return {
47
59
  wallet: this.wallet,
@@ -53,7 +65,8 @@ export class BotFactory {
53
65
  }
54
66
  async setupAmm() {
55
67
  const defaultAccountAddress = await this.setupAccount();
56
- const token0 = await this.setupTokenContract(defaultAccountAddress, this.config.tokenSalt, 'BotToken0', 'BOT0');
68
+ const token0 = await this.setupTokenContractWithOptionalEarlyRefuel(defaultAccountAddress, this.config.tokenSalt, 'BotToken0', 'BOT0');
69
+ await this.ensureFeeJuiceBalance(defaultAccountAddress, token0);
57
70
  const token1 = await this.setupTokenContract(defaultAccountAddress, this.config.tokenSalt, 'BotToken1', 'BOT1');
58
71
  const liquidityToken = await this.setupTokenContract(defaultAccountAddress, this.config.tokenSalt, 'BotLPToken', 'BOTLP');
59
72
  const amm = await this.setupAmmContract(defaultAccountAddress, this.config.tokenSalt, token0, token1, liquidityToken);
@@ -69,6 +82,65 @@ export class BotFactory {
69
82
  };
70
83
  }
71
84
  /**
85
+ * Initializes the cross-chain bot by deploying TestContract, creating an L1 client,
86
+ * seeding initial L1→L2 messages, and waiting for the first to be ready.
87
+ */ async setupCrossChain() {
88
+ const defaultAccountAddress = await this.setupAccount();
89
+ // Create L1 client (same pattern as bridgeL1FeeJuice)
90
+ const l1RpcUrls = this.config.l1RpcUrls;
91
+ if (!l1RpcUrls?.length) {
92
+ throw new Error('L1 RPC URLs required for cross-chain bot');
93
+ }
94
+ const mnemonicOrPrivateKey = this.config.l1PrivateKey?.getValue() ?? this.config.l1Mnemonic?.getValue();
95
+ if (!mnemonicOrPrivateKey) {
96
+ throw new Error('L1 mnemonic or private key required for cross-chain bot');
97
+ }
98
+ const { l1ChainId, l1ContractAddresses } = await this.aztecNode.getNodeInfo();
99
+ const chain = createEthereumChain(l1RpcUrls, l1ChainId);
100
+ const l1Client = createExtendedL1Client(chain.rpcUrls, mnemonicOrPrivateKey, chain.chainInfo);
101
+ // Fetch Rollup version (needed for Inbox L2Actor struct)
102
+ const rollupContract = new RollupContract(l1Client, l1ContractAddresses.rollupAddress.toString());
103
+ const rollupVersion = await rollupContract.getVersion();
104
+ // Deploy TestContract
105
+ const contract = await this.setupTestContract(defaultAccountAddress);
106
+ // Recover any pending messages from store (clean up stale ones first)
107
+ await this.store.cleanupOldPendingMessages();
108
+ const pendingMessages = await this.store.getUnconsumedL1ToL2Messages();
109
+ // Seed initial L1→L2 messages if pipeline is empty
110
+ const seedCount = Math.max(0, this.config.l1ToL2SeedCount - pendingMessages.length);
111
+ for(let i = 0; i < seedCount; i++){
112
+ await seedL1ToL2Message(l1Client, EthAddress.fromString(l1ContractAddresses.inboxAddress.toString()), contract.address, rollupVersion, this.store, this.log);
113
+ }
114
+ // Block until at least one message is ready
115
+ const allMessages = await this.store.getUnconsumedL1ToL2Messages();
116
+ if (allMessages.length > 0) {
117
+ this.log.info(`Waiting for first L1→L2 message to be ready...`);
118
+ const firstMsg = allMessages[0];
119
+ await waitForL1ToL2MessageReady(this.aztecNode, Fr.fromHexString(firstMsg.msgHash), {
120
+ timeoutSeconds: this.config.l1ToL2MessageTimeoutSeconds
121
+ });
122
+ this.log.info(`First L1→L2 message is ready`);
123
+ }
124
+ return {
125
+ wallet: this.wallet,
126
+ defaultAccountAddress,
127
+ contract,
128
+ node: this.aztecNode,
129
+ l1Client,
130
+ rollupVersion
131
+ };
132
+ }
133
+ async setupTestContract(deployer) {
134
+ const deployOpts = {
135
+ from: deployer,
136
+ contractAddressSalt: this.config.tokenSalt,
137
+ universalDeploy: true
138
+ };
139
+ const deploy = TestContract.deploy(this.wallet);
140
+ const instance = await this.registerOrDeployContract('TestContract', deploy, deployOpts);
141
+ return TestContract.at(instance.address, this.wallet);
142
+ }
143
+ /**
72
144
  * Checks if the sender account contract is initialized, and initializes it if necessary.
73
145
  * @returns The sender wallet.
74
146
  */ async setupAccount() {
@@ -86,7 +158,7 @@ export class BotFactory {
86
158
  const signingKey = deriveSigningKey(secret);
87
159
  const accountManager = await this.wallet.createSchnorrAccount(secret, salt, signingKey);
88
160
  const metadata = await this.wallet.getContractMetadata(accountManager.address);
89
- if (metadata.isContractInitialized) {
161
+ if (metadata.initializationStatus === ContractInitializationStatus.INITIALIZED) {
90
162
  this.log.info(`Account at ${accountManager.address.toString()} already initialized`);
91
163
  const timer = new Timer();
92
164
  const address = accountManager.address;
@@ -99,15 +171,10 @@ export class BotFactory {
99
171
  const claim = await this.getOrCreateBridgeClaim(address);
100
172
  const paymentMethod = new FeeJuicePaymentMethodWithClaim(accountManager.address, claim);
101
173
  const deployMethod = await accountManager.getDeployMethod();
102
- const maxFeesPerGas = (await this.aztecNode.getCurrentMinFees()).mul(1 + this.config.minFeePadding);
103
- const gasSettings = GasSettings.default({
104
- maxFeesPerGas
105
- });
106
174
  await this.withNoMinTxsPerBlock(async ()=>{
107
- const txHash = await deployMethod.send({
108
- from: AztecAddress.ZERO,
175
+ const { txHash } = await deployMethod.send({
176
+ from: NO_FROM,
109
177
  fee: {
110
- gasSettings,
111
178
  paymentMethod
112
179
  },
113
180
  wait: NO_WAIT
@@ -129,12 +196,70 @@ export class BotFactory {
129
196
  return accountManager.address;
130
197
  }
131
198
  /**
199
+ * Setup token and refuel first: if the token already exists (restart scenario),
200
+ * run ensureFeeJuiceBalance before any step that might need fee juice. When deploying,
201
+ * use a bridge claim if balance is below threshold.
202
+ */ async setupTokenWithOptionalEarlyRefuel(sender) {
203
+ const token = await this.getTokenInstance(sender);
204
+ const address = token.address;
205
+ const metadata = await this.wallet.getContractMetadata(address);
206
+ if (metadata.isContractPublished) {
207
+ this.log.info(`Token at ${address.toString()} already deployed, refueling before setup`);
208
+ await this.ensureFeeJuiceBalance(sender, token);
209
+ }
210
+ return this.setupToken(sender);
211
+ }
212
+ /**
213
+ * Setup token0 for AMM with refuel-first behaviour when token already exists.
214
+ */ async setupTokenContractWithOptionalEarlyRefuel(deployer, contractAddressSalt, name, ticker, decimals = 18) {
215
+ const deployOpts = {
216
+ from: deployer,
217
+ contractAddressSalt,
218
+ universalDeploy: true
219
+ };
220
+ const deploy = TokenContract.deploy(this.wallet, deployer, name, ticker, decimals);
221
+ const instance = await deploy.getInstance(deployOpts);
222
+ const metadata = await this.wallet.getContractMetadata(instance.address);
223
+ if (metadata.isContractPublished) {
224
+ this.log.info(`Token ${name} at ${instance.address.toString()} already deployed, refueling before setup`);
225
+ const token = TokenContract.at(instance.address, this.wallet);
226
+ await this.ensureFeeJuiceBalance(deployer, token);
227
+ }
228
+ return this.setupTokenContract(deployer, contractAddressSalt, name, ticker, decimals);
229
+ }
230
+ async getTokenInstance(sender) {
231
+ const deployOpts = {
232
+ from: sender,
233
+ contractAddressSalt: this.config.tokenSalt,
234
+ universalDeploy: true
235
+ };
236
+ if (this.config.contract === SupportedTokenContracts.TokenContract) {
237
+ const deploy = TokenContract.deploy(this.wallet, sender, 'BotToken', 'BOT', 18);
238
+ const instance = await deploy.getInstance(deployOpts);
239
+ return TokenContract.at(instance.address, this.wallet);
240
+ }
241
+ if (this.config.contract === SupportedTokenContracts.PrivateTokenContract) {
242
+ const tokenSecretKey = Fr.random();
243
+ const tokenPublicKeys = (await deriveKeys(tokenSecretKey)).publicKeys;
244
+ const deploy = PrivateTokenContract.deployWithPublicKeys(tokenPublicKeys, this.wallet, MINT_BALANCE, sender);
245
+ const instance = await deploy.getInstance({
246
+ ...deployOpts,
247
+ skipInstancePublication: true,
248
+ skipClassPublication: true,
249
+ skipInitialization: false
250
+ });
251
+ return PrivateTokenContract.at(instance.address, this.wallet);
252
+ }
253
+ throw new Error(`Unsupported token contract type: ${this.config.contract}`);
254
+ }
255
+ /**
132
256
  * Checks if the token contract is deployed and deploys it if necessary.
133
- * @param wallet - Wallet to deploy the token contract from.
134
- * @returns The TokenContract instance.
257
+ * Uses a bridge claim for deploy when balance is below threshold to avoid failing before refuel.
258
+ * @param sender - Aztec address to deploy the token contract from.
259
+ * @param existingToken - Optional token instance when called from setupTokenWithOptionalEarlyRefuel.
260
+ * @returns The TokenContract or PrivateTokenContract instance.
135
261
  */ async setupToken(sender) {
136
262
  let deploy;
137
- let tokenInstance;
138
263
  const deployOpts = {
139
264
  from: sender,
140
265
  contractAddressSalt: this.config.tokenSalt,
@@ -143,8 +268,8 @@ export class BotFactory {
143
268
  let token;
144
269
  if (this.config.contract === SupportedTokenContracts.TokenContract) {
145
270
  deploy = TokenContract.deploy(this.wallet, sender, 'BotToken', 'BOT', 18);
146
- tokenInstance = await deploy.getInstance(deployOpts);
147
- token = TokenContract.at(tokenInstance.address, this.wallet);
271
+ const instance = await deploy.getInstance(deployOpts);
272
+ token = TokenContract.at(instance.address, this.wallet);
148
273
  } else if (this.config.contract === SupportedTokenContracts.PrivateTokenContract) {
149
274
  // Generate keys for the contract since PrivateToken uses SinglePrivateMutable which requires keys
150
275
  const tokenSecretKey = Fr.random();
@@ -154,31 +279,17 @@ export class BotFactory {
154
279
  deployOpts.skipClassPublication = true;
155
280
  deployOpts.skipInitialization = false;
156
281
  // Register the contract with the secret key before deployment
157
- tokenInstance = await deploy.getInstance(deployOpts);
282
+ const tokenInstance = await deploy.getInstance(deployOpts);
158
283
  token = PrivateTokenContract.at(tokenInstance.address, this.wallet);
159
284
  await this.wallet.registerContract(tokenInstance, PrivateTokenContract.artifact, tokenSecretKey);
285
+ // The contract constructor initializes private storage vars that need the contract's own nullifier key.
286
+ deployOpts.additionalScopes = [
287
+ tokenInstance.address
288
+ ];
160
289
  } else {
161
290
  throw new Error(`Unsupported token contract type: ${this.config.contract}`);
162
291
  }
163
- const address = tokenInstance?.address ?? (await deploy.getInstance(deployOpts)).address;
164
- const metadata = await this.wallet.getContractMetadata(address);
165
- if (metadata.isContractPublished) {
166
- this.log.info(`Token at ${address.toString()} already deployed`);
167
- await deploy.register();
168
- } else {
169
- this.log.info(`Deploying token contract at ${address.toString()}`);
170
- const txHash = await deploy.send({
171
- ...deployOpts,
172
- wait: NO_WAIT
173
- });
174
- this.log.info(`Sent tx for token setup with hash ${txHash.toString()}`);
175
- await this.withNoMinTxsPerBlock(async ()=>{
176
- await waitForTx(this.aztecNode, txHash, {
177
- timeout: this.config.txMinedWaitSeconds
178
- });
179
- return token;
180
- });
181
- }
292
+ await this.registerOrDeployContract('token', deploy, deployOpts);
182
293
  return token;
183
294
  }
184
295
  /**
@@ -205,7 +316,8 @@ export class BotFactory {
205
316
  const instance = await this.registerOrDeployContract('AMM', deploy, deployOpts);
206
317
  const amm = AMMContract.at(instance.address, this.wallet);
207
318
  this.log.info(`AMM deployed at ${amm.address}`);
208
- const minterReceipt = await lpToken.methods.set_minter(amm.address, true).send({
319
+ const setMinterInteraction = lpToken.methods.set_minter(amm.address, true);
320
+ const { receipt: minterReceipt } = await setMinterInteraction.send({
209
321
  from: deployer,
210
322
  wait: {
211
323
  timeout: this.config.txMinedWaitSeconds
@@ -219,13 +331,13 @@ export class BotFactory {
219
331
  const getPrivateBalances = ()=>Promise.all([
220
332
  token0.methods.balance_of_private(liquidityProvider).simulate({
221
333
  from: liquidityProvider
222
- }),
334
+ }).then((r)=>r.result),
223
335
  token1.methods.balance_of_private(liquidityProvider).simulate({
224
336
  from: liquidityProvider
225
- }),
337
+ }).then((r)=>r.result),
226
338
  lpToken.methods.balance_of_private(liquidityProvider).simulate({
227
339
  from: liquidityProvider
228
- })
340
+ }).then((r)=>r.result)
229
341
  ]);
230
342
  const authwitNonce = Fr.random();
231
343
  // keep some tokens for swapping
@@ -244,17 +356,19 @@ export class BotFactory {
244
356
  caller: amm.address,
245
357
  call: await token1.methods.transfer_to_public_and_prepare_private_balance_increase(liquidityProvider, amm.address, amount1Max, authwitNonce).getFunctionCall()
246
358
  });
247
- const mintReceipt = await new BatchCall(this.wallet, [
359
+ const mintBatch = new BatchCall(this.wallet, [
248
360
  token0.methods.mint_to_private(liquidityProvider, MINT_BALANCE),
249
361
  token1.methods.mint_to_private(liquidityProvider, MINT_BALANCE)
250
- ]).send({
362
+ ]);
363
+ const { receipt: mintReceipt } = await mintBatch.send({
251
364
  from: liquidityProvider,
252
365
  wait: {
253
366
  timeout: this.config.txMinedWaitSeconds
254
367
  }
255
368
  });
256
369
  this.log.info(`Sent mint tx: ${mintReceipt.txHash.toString()}`);
257
- const addLiquidityReceipt = await amm.methods.add_liquidity(amount0Max, amount1Max, amount0Min, amount1Min, authwitNonce).send({
370
+ const addLiquidityInteraction = amm.methods.add_liquidity(amount0Max, amount1Max, amount0Min, amount1Min, authwitNonce);
371
+ const { receipt: addLiquidityReceipt } = await addLiquidityInteraction.send({
258
372
  from: liquidityProvider,
259
373
  authWitnesses: [
260
374
  token0Authwit,
@@ -277,24 +391,127 @@ export class BotFactory {
277
391
  this.log.info(`Contract ${name} at ${address.toString()} already deployed`);
278
392
  await deploy.register();
279
393
  } else {
280
- this.log.info(`Deploying contract ${name} at ${address.toString()}`);
281
- await this.withNoMinTxsPerBlock(async ()=>{
282
- const txHash = await deploy.send({
394
+ const sender = deployOpts.from === NO_FROM ? undefined : deployOpts.from;
395
+ const balance = sender ? await getFeeJuiceBalance(sender, this.aztecNode) : 0n;
396
+ const useClaim = sender && balance < FEE_JUICE_TOP_UP_THRESHOLD && this.config.feePaymentMethod === 'fee_juice' && !!this.config.l1RpcUrls?.length;
397
+ const mnemonicOrPrivateKey = this.config.l1PrivateKey?.getValue() ?? this.config.l1Mnemonic?.getValue();
398
+ if (useClaim && mnemonicOrPrivateKey) {
399
+ const claim = await this.getOrCreateBridgeClaim(sender);
400
+ const paymentMethod = new FeeJuicePaymentMethodWithClaim(sender, claim);
401
+ const { estimatedGas } = await deploy.simulate({
283
402
  ...deployOpts,
284
- wait: NO_WAIT
403
+ fee: {
404
+ estimateGas: true,
405
+ paymentMethod
406
+ }
285
407
  });
286
- this.log.info(`Sent contract ${name} setup tx with hash ${txHash.toString()}`);
287
- return waitForTx(this.aztecNode, txHash, {
288
- timeout: this.config.txMinedWaitSeconds
408
+ const maxFeesPerGas = (await this.aztecNode.getCurrentMinFees()).mul(1 + this.config.minFeePadding);
409
+ const gasSettings = GasSettings.from({
410
+ ...estimatedGas,
411
+ maxFeesPerGas,
412
+ maxPriorityFeesPerGas: GasFees.empty()
289
413
  });
290
- });
414
+ await this.withNoMinTxsPerBlock(async ()=>{
415
+ const { txHash } = await deploy.send({
416
+ ...deployOpts,
417
+ fee: {
418
+ gasSettings,
419
+ paymentMethod
420
+ },
421
+ wait: NO_WAIT
422
+ });
423
+ this.log.info(`Sent contract ${name} deploy tx ${txHash.toString()} (using bridge claim, balance was ${balance})`);
424
+ return waitForTx(this.aztecNode, txHash, {
425
+ timeout: this.config.txMinedWaitSeconds
426
+ });
427
+ });
428
+ await this.store.deleteBridgeClaim(sender);
429
+ } else {
430
+ const { estimatedGas } = await deploy.simulate({
431
+ ...deployOpts,
432
+ fee: {
433
+ estimateGas: true
434
+ }
435
+ });
436
+ this.log.info(`Deploying contract ${name} at ${address.toString()}`, {
437
+ estimatedGas
438
+ });
439
+ await this.withNoMinTxsPerBlock(async ()=>{
440
+ const { txHash } = await deploy.send({
441
+ ...deployOpts,
442
+ fee: {
443
+ gasSettings: estimatedGas
444
+ },
445
+ wait: NO_WAIT
446
+ });
447
+ this.log.info(`Sent contract ${name} setup tx with hash ${txHash.toString()}`);
448
+ return waitForTx(this.aztecNode, txHash, {
449
+ timeout: this.config.txMinedWaitSeconds
450
+ });
451
+ });
452
+ }
291
453
  }
292
454
  return instance;
293
455
  }
294
456
  /**
295
457
  * Mints private and public tokens for the sender if their balance is below the minimum.
296
458
  * @param token - Token contract.
297
- */ async mintTokens(token, minter) {
459
+ */ /**
460
+ * Ensures the account has sufficient fee juice by bridging from L1 if balance is below threshold.
461
+ * Bridges repeatedly until balance reaches the target (10k FJ).
462
+ * Used on startup/restart to top up when the account has run out after previous runs.
463
+ */ async ensureFeeJuiceBalance(account, token) {
464
+ const { feePaymentMethod, l1RpcUrls } = this.config;
465
+ if (feePaymentMethod !== 'fee_juice' || !l1RpcUrls?.length) {
466
+ return;
467
+ }
468
+ const mnemonicOrPrivateKey = this.config.l1PrivateKey?.getValue() ?? this.config.l1Mnemonic?.getValue();
469
+ if (!mnemonicOrPrivateKey) {
470
+ return;
471
+ }
472
+ let balance = await getFeeJuiceBalance(account, this.aztecNode);
473
+ if (balance >= FEE_JUICE_TOP_UP_THRESHOLD) {
474
+ this.log.info(`Fee juice balance ${balance} above threshold ${FEE_JUICE_TOP_UP_THRESHOLD}, skipping top-up`);
475
+ return;
476
+ }
477
+ this.log.info(`Fee juice balance ${balance} below threshold ${FEE_JUICE_TOP_UP_THRESHOLD}, bridging from L1 until ${FEE_JUICE_TOP_UP_TARGET}`);
478
+ const maxFeesPerGas = (await this.aztecNode.getCurrentMinFees()).mul(1 + this.config.minFeePadding);
479
+ const minimalInteraction = isStandardTokenContract(token) ? token.methods.transfer_in_public(account, account, 0n, 0) : token.methods.transfer(0n, account, account);
480
+ while(balance < FEE_JUICE_TOP_UP_TARGET){
481
+ const claim = await this.bridgeL1FeeJuice(account);
482
+ const paymentMethod = new FeeJuicePaymentMethodWithClaim(account, claim);
483
+ const { estimatedGas } = await minimalInteraction.simulate({
484
+ from: account,
485
+ fee: {
486
+ estimateGas: true,
487
+ paymentMethod
488
+ }
489
+ });
490
+ const gasSettings = GasSettings.from({
491
+ ...estimatedGas,
492
+ maxFeesPerGas,
493
+ maxPriorityFeesPerGas: GasFees.empty()
494
+ });
495
+ await this.withNoMinTxsPerBlock(async ()=>{
496
+ const { txHash } = await minimalInteraction.send({
497
+ from: account,
498
+ fee: {
499
+ gasSettings,
500
+ paymentMethod
501
+ },
502
+ wait: NO_WAIT
503
+ });
504
+ this.log.info(`Sent fee juice top-up tx ${txHash.toString()}`);
505
+ return waitForTx(this.aztecNode, txHash, {
506
+ timeout: this.config.txMinedWaitSeconds
507
+ });
508
+ });
509
+ balance = await getFeeJuiceBalance(account, this.aztecNode);
510
+ this.log.info(`Fee juice balance after top-up: ${balance}`);
511
+ }
512
+ this.log.info(`Fee juice top-up complete for ${account.toString()}`);
513
+ }
514
+ async mintTokens(token, minter) {
298
515
  const isStandardToken = isStandardTokenContract(token);
299
516
  let privateBalance = 0n;
300
517
  let publicBalance = 0n;
@@ -316,9 +533,15 @@ export class BotFactory {
316
533
  this.log.info(`Skipping minting as ${minter.toString()} has enough tokens`);
317
534
  return;
318
535
  }
536
+ // PrivateToken's mint accesses contract-level private storage vars (admin, total_supply).
537
+ const additionalScopes = isStandardToken ? undefined : [
538
+ token.address
539
+ ];
540
+ const mintBatch = new BatchCall(token.wallet, calls);
319
541
  await this.withNoMinTxsPerBlock(async ()=>{
320
- const txHash = await new BatchCall(token.wallet, calls).send({
542
+ const { txHash } = await mintBatch.send({
321
543
  from: minter,
544
+ additionalScopes,
322
545
  wait: NO_WAIT
323
546
  });
324
547
  this.log.info(`Sent token mint tx with hash ${txHash.toString()}`);
@@ -340,8 +563,7 @@ export class BotFactory {
340
563
  try {
341
564
  const messageHash = Fr.fromHexString(existingClaim.claim.messageHash);
342
565
  await this.withNoMinTxsPerBlock(()=>waitForL1ToL2MessageReady(this.aztecNode, messageHash, {
343
- timeoutSeconds: this.config.l1ToL2MessageTimeoutSeconds,
344
- forPublicConsumption: false
566
+ timeoutSeconds: this.config.l1ToL2MessageTimeoutSeconds
345
567
  }));
346
568
  return existingClaim.claim;
347
569
  } catch (err) {
@@ -369,8 +591,7 @@ export class BotFactory {
369
591
  const mintAmount = await portal.getTokenManager().getMintAmount();
370
592
  const claim = await portal.bridgeTokensPublic(recipient, mintAmount, true);
371
593
  await this.withNoMinTxsPerBlock(()=>waitForL1ToL2MessageReady(this.aztecNode, Fr.fromHexString(claim.messageHash), {
372
- timeoutSeconds: this.config.l1ToL2MessageTimeoutSeconds,
373
- forPublicConsumption: false
594
+ timeoutSeconds: this.config.l1ToL2MessageTimeoutSeconds
374
595
  }));
375
596
  this.log.info(`Created a claim for ${mintAmount} L1 fee juice to ${recipient}.`, claim);
376
597
  return claim;
package/dest/index.d.ts CHANGED
@@ -1,8 +1,9 @@
1
1
  export { Bot } from './bot.js';
2
2
  export { AmmBot } from './amm_bot.js';
3
+ export { CrossChainBot } from './cross_chain_bot.js';
3
4
  export { BotRunner } from './runner.js';
4
5
  export { BotStore } from './store/bot_store.js';
5
6
  export { type BotConfig, getBotConfigFromEnv, getBotDefaultConfig, botConfigMappings, SupportedTokenContracts, } from './config.js';
6
7
  export { getBotRunnerApiHandler } from './rpc.js';
7
8
  export * from './interface.js';
8
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBQy9CLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDdEMsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUN4QyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDaEQsT0FBTyxFQUNMLEtBQUssU0FBUyxFQUNkLG1CQUFtQixFQUNuQixtQkFBbUIsRUFDbkIsaUJBQWlCLEVBQ2pCLHVCQUF1QixHQUN4QixNQUFNLGFBQWEsQ0FBQztBQUNyQixPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFDbEQsY0FBYyxnQkFBZ0IsQ0FBQyJ9
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBQy9CLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDdEMsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDeEMsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ2hELE9BQU8sRUFDTCxLQUFLLFNBQVMsRUFDZCxtQkFBbUIsRUFDbkIsbUJBQW1CLEVBQ25CLGlCQUFpQixFQUNqQix1QkFBdUIsR0FDeEIsTUFBTSxhQUFhLENBQUM7QUFDckIsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sVUFBVSxDQUFDO0FBQ2xELGNBQWMsZ0JBQWdCLENBQUMifQ==
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AACtC,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAChD,OAAO,EACL,KAAK,SAAS,EACd,mBAAmB,EACnB,mBAAmB,EACnB,iBAAiB,EACjB,uBAAuB,GACxB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,sBAAsB,EAAE,MAAM,UAAU,CAAC;AAClD,cAAc,gBAAgB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AACtC,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAChD,OAAO,EACL,KAAK,SAAS,EACd,mBAAmB,EACnB,mBAAmB,EACnB,iBAAiB,EACjB,uBAAuB,GACxB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,sBAAsB,EAAE,MAAM,UAAU,CAAC;AAClD,cAAc,gBAAgB,CAAC"}
package/dest/index.js CHANGED
@@ -1,5 +1,6 @@
1
1
  export { Bot } from './bot.js';
2
2
  export { AmmBot } from './amm_bot.js';
3
+ export { CrossChainBot } from './cross_chain_bot.js';
3
4
  export { BotRunner } from './runner.js';
4
5
  export { BotStore } from './store/bot_store.js';
5
6
  export { getBotConfigFromEnv, getBotDefaultConfig, botConfigMappings, SupportedTokenContracts } from './config.js';
@@ -0,0 +1,8 @@
1
+ import type { ExtendedViemWalletClient } from '@aztec/ethereum/types';
2
+ import { EthAddress } from '@aztec/foundation/eth-address';
3
+ import type { Logger } from '@aztec/foundation/log';
4
+ import type { AztecAddress } from '@aztec/stdlib/aztec-address';
5
+ import type { BotStore, PendingL1ToL2Message } from './store/index.js';
6
+ /** Sends an L1→L2 message via the Inbox contract and stores it. */
7
+ export declare function seedL1ToL2Message(l1Client: ExtendedViemWalletClient, inboxAddress: EthAddress, l2Recipient: AztecAddress, rollupVersion: bigint, store: BotStore, log: Logger): Promise<PendingL1ToL2Message>;
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibDFfdG9fbDJfc2VlZGluZy5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2wxX3RvX2wyX3NlZWRpbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxLQUFLLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUd0RSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDM0QsT0FBTyxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFFcEQsT0FBTyxLQUFLLEVBQUUsWUFBWSxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFJaEUsT0FBTyxLQUFLLEVBQUUsUUFBUSxFQUFFLG9CQUFvQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFFdkUscUVBQW1FO0FBQ25FLHdCQUFzQixpQkFBaUIsQ0FDckMsUUFBUSxFQUFFLHdCQUF3QixFQUNsQyxZQUFZLEVBQUUsVUFBVSxFQUN4QixXQUFXLEVBQUUsWUFBWSxFQUN6QixhQUFhLEVBQUUsTUFBTSxFQUNyQixLQUFLLEVBQUUsUUFBUSxFQUNmLEdBQUcsRUFBRSxNQUFNLEdBQ1YsT0FBTyxDQUFDLG9CQUFvQixDQUFDLENBeUQvQiJ9
@@ -0,0 +1 @@
1
+ {"version":3,"file":"l1_to_l2_seeding.d.ts","sourceRoot":"","sources":["../src/l1_to_l2_seeding.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,uBAAuB,CAAC;AAGtE,OAAO,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAC3D,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAEpD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAIhE,OAAO,KAAK,EAAE,QAAQ,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AAEvE,qEAAmE;AACnE,wBAAsB,iBAAiB,CACrC,QAAQ,EAAE,wBAAwB,EAClC,YAAY,EAAE,UAAU,EACxB,WAAW,EAAE,YAAY,EACzB,aAAa,EAAE,MAAM,EACrB,KAAK,EAAE,QAAQ,EACf,GAAG,EAAE,MAAM,GACV,OAAO,CAAC,oBAAoB,CAAC,CAyD/B"}