@aztec/prover-node 0.56.0 → 0.58.0

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 (102) hide show
  1. package/dest/bond/bond-manager.d.ts +22 -0
  2. package/dest/bond/bond-manager.d.ts.map +1 -0
  3. package/dest/bond/bond-manager.js +42 -0
  4. package/dest/bond/config.d.ts +8 -0
  5. package/dest/bond/config.d.ts.map +1 -0
  6. package/dest/bond/config.js +17 -0
  7. package/dest/bond/escrow-contract.d.ts +22 -0
  8. package/dest/bond/escrow-contract.d.ts.map +1 -0
  9. package/dest/bond/escrow-contract.js +32 -0
  10. package/dest/bond/factory.d.ts +9 -0
  11. package/dest/bond/factory.d.ts.map +1 -0
  12. package/dest/bond/factory.js +19 -0
  13. package/dest/bond/index.d.ts +3 -0
  14. package/dest/bond/index.d.ts.map +1 -0
  15. package/dest/bond/index.js +3 -0
  16. package/dest/bond/token-contract.d.ts +29 -0
  17. package/dest/bond/token-contract.d.ts.map +1 -0
  18. package/dest/bond/token-contract.js +58 -0
  19. package/dest/config.d.ts +10 -4
  20. package/dest/config.d.ts.map +1 -1
  21. package/dest/config.js +30 -9
  22. package/dest/factory.d.ts.map +1 -1
  23. package/dest/factory.js +39 -9
  24. package/dest/job/epoch-proving-job.d.ts +39 -0
  25. package/dest/job/epoch-proving-job.d.ts.map +1 -0
  26. package/dest/job/epoch-proving-job.js +127 -0
  27. package/dest/monitors/claims-monitor.d.ts +22 -0
  28. package/dest/monitors/claims-monitor.d.ts.map +1 -0
  29. package/dest/monitors/claims-monitor.js +37 -0
  30. package/dest/monitors/epoch-monitor.d.ts +20 -0
  31. package/dest/monitors/epoch-monitor.d.ts.map +1 -0
  32. package/dest/monitors/epoch-monitor.js +34 -0
  33. package/dest/monitors/index.d.ts +3 -0
  34. package/dest/monitors/index.d.ts.map +1 -0
  35. package/dest/monitors/index.js +3 -0
  36. package/dest/prover-coordination/config.d.ts +7 -0
  37. package/dest/prover-coordination/config.d.ts.map +1 -0
  38. package/dest/prover-coordination/config.js +12 -0
  39. package/dest/prover-coordination/factory.d.ts +4 -0
  40. package/dest/prover-coordination/factory.d.ts.map +1 -0
  41. package/dest/prover-coordination/factory.js +10 -0
  42. package/dest/prover-coordination/index.d.ts +3 -0
  43. package/dest/prover-coordination/index.d.ts.map +1 -0
  44. package/dest/prover-coordination/index.js +3 -0
  45. package/dest/prover-node.d.ts +57 -33
  46. package/dest/prover-node.d.ts.map +1 -1
  47. package/dest/prover-node.js +128 -76
  48. package/dest/quote-provider/http.d.ts +15 -0
  49. package/dest/quote-provider/http.d.ts.map +1 -0
  50. package/dest/quote-provider/http.js +32 -0
  51. package/dest/quote-provider/index.d.ts +6 -0
  52. package/dest/quote-provider/index.d.ts.map +1 -0
  53. package/dest/quote-provider/index.js +2 -0
  54. package/dest/quote-provider/simple.d.ts +9 -0
  55. package/dest/quote-provider/simple.d.ts.map +1 -0
  56. package/dest/quote-provider/simple.js +11 -0
  57. package/dest/quote-provider/utils.d.ts +4 -0
  58. package/dest/quote-provider/utils.d.ts.map +1 -0
  59. package/dest/quote-provider/utils.js +8 -0
  60. package/dest/quote-signer.d.ts +13 -0
  61. package/dest/quote-signer.d.ts.map +1 -0
  62. package/dest/quote-signer.js +18 -0
  63. package/package.json +19 -13
  64. package/src/bond/bond-manager.ts +48 -0
  65. package/src/bond/config.ts +25 -0
  66. package/src/bond/escrow-contract.ts +63 -0
  67. package/src/bond/factory.ts +48 -0
  68. package/src/bond/index.ts +2 -0
  69. package/src/bond/token-contract.ts +85 -0
  70. package/src/config.ts +47 -12
  71. package/src/factory.ts +51 -10
  72. package/src/job/{block-proving-job.ts → epoch-proving-job.ts} +59 -57
  73. package/src/monitors/claims-monitor.ts +52 -0
  74. package/src/monitors/epoch-monitor.ts +48 -0
  75. package/src/monitors/index.ts +2 -0
  76. package/src/prover-coordination/config.ts +17 -0
  77. package/src/prover-coordination/factory.ts +11 -0
  78. package/src/{tx-provider → prover-coordination}/index.ts +1 -2
  79. package/src/prover-node.ts +169 -99
  80. package/src/quote-provider/http.ts +47 -0
  81. package/src/quote-provider/index.ts +8 -0
  82. package/src/quote-provider/simple.ts +15 -0
  83. package/src/quote-provider/utils.ts +10 -0
  84. package/src/quote-signer.ts +24 -0
  85. package/dest/job/block-proving-job.d.ts +0 -33
  86. package/dest/job/block-proving-job.d.ts.map +0 -1
  87. package/dest/job/block-proving-job.js +0 -120
  88. package/dest/tx-provider/aztec-node-tx-provider.d.ts +0 -8
  89. package/dest/tx-provider/aztec-node-tx-provider.d.ts.map +0 -1
  90. package/dest/tx-provider/aztec-node-tx-provider.js +0 -10
  91. package/dest/tx-provider/config.d.ts +0 -7
  92. package/dest/tx-provider/config.d.ts.map +0 -1
  93. package/dest/tx-provider/config.js +0 -12
  94. package/dest/tx-provider/factory.d.ts +0 -4
  95. package/dest/tx-provider/factory.d.ts.map +0 -1
  96. package/dest/tx-provider/factory.js +0 -12
  97. package/dest/tx-provider/index.d.ts +0 -4
  98. package/dest/tx-provider/index.d.ts.map +0 -1
  99. package/dest/tx-provider/index.js +0 -4
  100. package/src/tx-provider/aztec-node-tx-provider.ts +0 -10
  101. package/src/tx-provider/config.ts +0 -17
  102. package/src/tx-provider/factory.ts +0 -13
@@ -1,120 +0,0 @@
1
- import { EmptyTxValidator, PROVING_STATUS, } from '@aztec/circuit-types';
2
- import { createDebugLogger } from '@aztec/foundation/log';
3
- import { Timer } from '@aztec/foundation/timer';
4
- import * as crypto from 'node:crypto';
5
- /**
6
- * Job that grabs a range of blocks from the unfinalised chain from L1, gets their txs given their hashes,
7
- * re-executes their public calls, generates a rollup proof, and submits it to L1. This job will update the
8
- * world state as part of public call execution via the public processor.
9
- */
10
- export class BlockProvingJob {
11
- constructor(prover, publicProcessorFactory, publisher, l2BlockSource, l1ToL2MessageSource, txProvider, metrics, cleanUp = () => Promise.resolve()) {
12
- this.prover = prover;
13
- this.publicProcessorFactory = publicProcessorFactory;
14
- this.publisher = publisher;
15
- this.l2BlockSource = l2BlockSource;
16
- this.l1ToL2MessageSource = l1ToL2MessageSource;
17
- this.txProvider = txProvider;
18
- this.metrics = metrics;
19
- this.cleanUp = cleanUp;
20
- this.state = 'initialized';
21
- this.log = createDebugLogger('aztec:block-proving-job');
22
- this.uuid = crypto.randomUUID();
23
- }
24
- getId() {
25
- return this.uuid;
26
- }
27
- getState() {
28
- return this.state;
29
- }
30
- async run(fromBlock, toBlock) {
31
- if (fromBlock !== toBlock) {
32
- throw new Error(`Block ranges are not yet supported`);
33
- }
34
- this.log.info(`Starting block proving job`, { fromBlock, toBlock, uuid: this.uuid });
35
- this.state = 'processing';
36
- const timer = new Timer();
37
- try {
38
- let historicalHeader = (await this.l2BlockSource.getBlock(fromBlock - 1))?.header;
39
- for (let blockNumber = fromBlock; blockNumber <= toBlock; blockNumber++) {
40
- const block = await this.getBlock(blockNumber);
41
- const globalVariables = block.header.globalVariables;
42
- const txHashes = block.body.txEffects.map(tx => tx.txHash);
43
- const txCount = block.body.numberOfTxsIncludingPadded;
44
- const l1ToL2Messages = await this.getL1ToL2Messages(block);
45
- this.log.verbose(`Starting block processing`, {
46
- number: block.number,
47
- blockHash: block.hash().toString(),
48
- lastArchive: block.header.lastArchive.root,
49
- noteHashTreeRoot: block.header.state.partial.noteHashTree.root,
50
- nullifierTreeRoot: block.header.state.partial.nullifierTree.root,
51
- publicDataTreeRoot: block.header.state.partial.publicDataTree.root,
52
- historicalHeader: historicalHeader?.hash(),
53
- uuid: this.uuid,
54
- ...globalVariables,
55
- });
56
- // When we move to proving epochs, this should change into a startNewEpoch and be lifted outside the loop.
57
- const provingTicket = await this.prover.startNewBlock(txCount, globalVariables, l1ToL2Messages);
58
- const publicProcessor = this.publicProcessorFactory.create(historicalHeader, globalVariables);
59
- const txs = await this.getTxs(txHashes);
60
- await this.processTxs(publicProcessor, txs, txCount);
61
- this.log.verbose(`Processed all txs for block`, {
62
- blockNumber: block.number,
63
- blockHash: block.hash().toString(),
64
- uuid: this.uuid,
65
- });
66
- await this.prover.setBlockCompleted();
67
- // This should be moved outside the loop to match the creation of the proving ticket when we move to epochs.
68
- this.state = 'awaiting-prover';
69
- const result = await provingTicket.provingPromise;
70
- if (result.status === PROVING_STATUS.FAILURE) {
71
- throw new Error(`Block proving failed: ${result.reason}`);
72
- }
73
- historicalHeader = block.header;
74
- }
75
- const { block, aggregationObject, proof } = await this.prover.finaliseBlock();
76
- this.log.info(`Finalised proof for block range`, { fromBlock, toBlock, uuid: this.uuid });
77
- this.state = 'publishing-proof';
78
- await this.publisher.submitProof(block.header, block.archive.root, this.prover.getProverId(), aggregationObject, proof);
79
- this.log.info(`Submitted proof for block range`, { fromBlock, toBlock, uuid: this.uuid });
80
- this.state = 'completed';
81
- this.metrics.recordProvingJob(timer);
82
- }
83
- catch (err) {
84
- this.log.error(`Error running block prover job`, err, { uuid: this.uuid });
85
- this.state = 'failed';
86
- }
87
- finally {
88
- await this.cleanUp(this);
89
- }
90
- }
91
- stop() {
92
- this.prover.cancel();
93
- }
94
- async getBlock(blockNumber) {
95
- const block = await this.l2BlockSource.getBlock(blockNumber);
96
- if (!block) {
97
- throw new Error(`Block ${blockNumber} not found in L2 block source`);
98
- }
99
- return block;
100
- }
101
- async getTxs(txHashes) {
102
- const txs = await Promise.all(txHashes.map(txHash => this.txProvider.getTxByHash(txHash).then(tx => [txHash, tx])));
103
- const notFound = txs.filter(([_, tx]) => !tx);
104
- if (notFound.length) {
105
- throw new Error(`Txs not found: ${notFound.map(([txHash]) => txHash.toString()).join(', ')}`);
106
- }
107
- return txs.map(([_, tx]) => tx);
108
- }
109
- getL1ToL2Messages(block) {
110
- return this.l1ToL2MessageSource.getL1ToL2Messages(BigInt(block.number));
111
- }
112
- async processTxs(publicProcessor, txs, totalNumberOfTxs) {
113
- const [processedTxs, failedTxs] = await publicProcessor.process(txs, totalNumberOfTxs, this.prover, new EmptyTxValidator());
114
- if (failedTxs.length) {
115
- throw new Error(`Failed to process txs: ${failedTxs.map(({ tx, error }) => `${tx.getTxHash()} (${error})`).join(', ')}`);
116
- }
117
- return processedTxs;
118
- }
119
- }
120
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmxvY2stcHJvdmluZy1qb2IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvam9iL2Jsb2NrLXByb3Zpbmctam9iLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFFTCxnQkFBZ0IsRUFJaEIsY0FBYyxHQUtmLE1BQU0sc0JBQXNCLENBQUM7QUFDOUIsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDMUQsT0FBTyxFQUFFLEtBQUssRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBSWhELE9BQU8sS0FBSyxNQUFNLE1BQU0sYUFBYSxDQUFDO0FBSXRDOzs7O0dBSUc7QUFDSCxNQUFNLE9BQU8sZUFBZTtJQUsxQixZQUNVLE1BQW1CLEVBQ25CLHNCQUE4QyxFQUM5QyxTQUFzQixFQUN0QixhQUE0QixFQUM1QixtQkFBd0MsRUFDeEMsVUFBc0IsRUFDdEIsT0FBMEIsRUFDMUIsVUFBbUQsR0FBRyxFQUFFLENBQUMsT0FBTyxDQUFDLE9BQU8sRUFBRTtRQVAxRSxXQUFNLEdBQU4sTUFBTSxDQUFhO1FBQ25CLDJCQUFzQixHQUF0QixzQkFBc0IsQ0FBd0I7UUFDOUMsY0FBUyxHQUFULFNBQVMsQ0FBYTtRQUN0QixrQkFBYSxHQUFiLGFBQWEsQ0FBZTtRQUM1Qix3QkFBbUIsR0FBbkIsbUJBQW1CLENBQXFCO1FBQ3hDLGVBQVUsR0FBVixVQUFVLENBQVk7UUFDdEIsWUFBTyxHQUFQLE9BQU8sQ0FBbUI7UUFDMUIsWUFBTyxHQUFQLE9BQU8sQ0FBbUU7UUFaNUUsVUFBSyxHQUF5QixhQUFhLENBQUM7UUFDNUMsUUFBRyxHQUFHLGlCQUFpQixDQUFDLHlCQUF5QixDQUFDLENBQUM7UUFhekQsSUFBSSxDQUFDLElBQUksR0FBRyxNQUFNLENBQUMsVUFBVSxFQUFFLENBQUM7SUFDbEMsQ0FBQztJQUVNLEtBQUs7UUFDVixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUM7SUFDbkIsQ0FBQztJQUVNLFFBQVE7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
@@ -1,8 +0,0 @@
1
- import { type AztecNode, type Tx, type TxHash, type TxProvider } from '@aztec/circuit-types';
2
- /** Implements TxProvider by querying an Aztec node for the txs. */
3
- export declare class AztecNodeTxProvider implements TxProvider {
4
- private node;
5
- constructor(node: AztecNode);
6
- getTxByHash(txHash: TxHash): Promise<Tx | undefined>;
7
- }
8
- //# sourceMappingURL=aztec-node-tx-provider.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"aztec-node-tx-provider.d.ts","sourceRoot":"","sources":["../../src/tx-provider/aztec-node-tx-provider.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,SAAS,EAAE,KAAK,EAAE,EAAE,KAAK,MAAM,EAAE,KAAK,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAE7F,mEAAmE;AACnE,qBAAa,mBAAoB,YAAW,UAAU;IACxC,OAAO,CAAC,IAAI;gBAAJ,IAAI,EAAE,SAAS;IAEnC,WAAW,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,EAAE,GAAG,SAAS,CAAC;CAGrD"}
@@ -1,10 +0,0 @@
1
- /** Implements TxProvider by querying an Aztec node for the txs. */
2
- export class AztecNodeTxProvider {
3
- constructor(node) {
4
- this.node = node;
5
- }
6
- getTxByHash(txHash) {
7
- return this.node.getTxByHash(txHash);
8
- }
9
- }
10
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXp0ZWMtbm9kZS10eC1wcm92aWRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90eC1wcm92aWRlci9henRlYy1ub2RlLXR4LXByb3ZpZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLG1FQUFtRTtBQUNuRSxNQUFNLE9BQU8sbUJBQW1CO0lBQzlCLFlBQW9CLElBQWU7UUFBZixTQUFJLEdBQUosSUFBSSxDQUFXO0lBQUcsQ0FBQztJQUV2QyxXQUFXLENBQUMsTUFBYztRQUN4QixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ3ZDLENBQUM7Q0FDRiJ9
@@ -1,7 +0,0 @@
1
- import { type ConfigMappingsType } from '@aztec/foundation/config';
2
- export type TxProviderConfig = {
3
- txProviderNodeUrl: string | undefined;
4
- };
5
- export declare const txProviderConfigMappings: ConfigMappingsType<TxProviderConfig>;
6
- export declare function getTxProviderConfigFromEnv(): TxProviderConfig;
7
- //# sourceMappingURL=config.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../src/tx-provider/config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,kBAAkB,EAAyB,MAAM,0BAA0B,CAAC;AAE1F,MAAM,MAAM,gBAAgB,GAAG;IAC7B,iBAAiB,EAAE,MAAM,GAAG,SAAS,CAAC;CACvC,CAAC;AAEF,eAAO,MAAM,wBAAwB,EAAE,kBAAkB,CAAC,gBAAgB,CAMzE,CAAC;AAEF,wBAAgB,0BAA0B,IAAI,gBAAgB,CAE7D"}
@@ -1,12 +0,0 @@
1
- import { getConfigFromMappings } from '@aztec/foundation/config';
2
- export const txProviderConfigMappings = {
3
- txProviderNodeUrl: {
4
- env: 'TX_PROVIDER_NODE_URL',
5
- description: 'The URL of the tx provider node',
6
- parseEnv: (val) => val,
7
- },
8
- };
9
- export function getTxProviderConfigFromEnv() {
10
- return getConfigFromMappings(txProviderConfigMappings);
11
- }
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3R4LXByb3ZpZGVyL2NvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQTJCLHFCQUFxQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFNMUYsTUFBTSxDQUFDLE1BQU0sd0JBQXdCLEdBQXlDO0lBQzVFLGlCQUFpQixFQUFFO1FBQ2pCLEdBQUcsRUFBRSxzQkFBc0I7UUFDM0IsV0FBVyxFQUFFLGlDQUFpQztRQUM5QyxRQUFRLEVBQUUsQ0FBQyxHQUFXLEVBQUUsRUFBRSxDQUFDLEdBQUc7S0FDL0I7Q0FDRixDQUFDO0FBRUYsTUFBTSxVQUFVLDBCQUEwQjtJQUN4QyxPQUFPLHFCQUFxQixDQUFtQix3QkFBd0IsQ0FBQyxDQUFDO0FBQzNFLENBQUMifQ==
@@ -1,4 +0,0 @@
1
- import { type TxProvider } from '@aztec/circuit-types';
2
- import { type TxProviderConfig } from './config.js';
3
- export declare function createTxProvider(config: TxProviderConfig): TxProvider;
4
- //# sourceMappingURL=factory.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"factory.d.ts","sourceRoot":"","sources":["../../src/tx-provider/factory.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,UAAU,EAAyB,MAAM,sBAAsB,CAAC;AAG9E,OAAO,EAAE,KAAK,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAEpD,wBAAgB,gBAAgB,CAAC,MAAM,EAAE,gBAAgB,GAAG,UAAU,CAOrE"}
@@ -1,12 +0,0 @@
1
- import { createAztecNodeClient } from '@aztec/circuit-types';
2
- import { AztecNodeTxProvider } from './aztec-node-tx-provider.js';
3
- export function createTxProvider(config) {
4
- if (config.txProviderNodeUrl) {
5
- const node = createAztecNodeClient(config.txProviderNodeUrl);
6
- return new AztecNodeTxProvider(node);
7
- }
8
- else {
9
- throw new Error(`Aztec Node URL for Tx Provider is not set.`);
10
- }
11
- }
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmFjdG9yeS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90eC1wcm92aWRlci9mYWN0b3J5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBbUIscUJBQXFCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUU5RSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUdsRSxNQUFNLFVBQVUsZ0JBQWdCLENBQUMsTUFBd0I7SUFDdkQsSUFBSSxNQUFNLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztRQUM3QixNQUFNLElBQUksR0FBRyxxQkFBcUIsQ0FBQyxNQUFNLENBQUMsaUJBQWlCLENBQUMsQ0FBQztRQUM3RCxPQUFPLElBQUksbUJBQW1CLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDdkMsQ0FBQztTQUFNLENBQUM7UUFDTixNQUFNLElBQUksS0FBSyxDQUFDLDRDQUE0QyxDQUFDLENBQUM7SUFDaEUsQ0FBQztBQUNILENBQUMifQ==
@@ -1,4 +0,0 @@
1
- export * from './aztec-node-tx-provider.js';
2
- export * from './factory.js';
3
- export * from './config.js';
4
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/tx-provider/index.ts"],"names":[],"mappings":"AAAA,cAAc,6BAA6B,CAAC;AAC5C,cAAc,cAAc,CAAC;AAC7B,cAAc,aAAa,CAAC"}
@@ -1,4 +0,0 @@
1
- export * from './aztec-node-tx-provider.js';
2
- export * from './factory.js';
3
- export * from './config.js';
4
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHgtcHJvdmlkZXIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGFBQWEsQ0FBQyJ9
@@ -1,10 +0,0 @@
1
- import { type AztecNode, type Tx, type TxHash, type TxProvider } from '@aztec/circuit-types';
2
-
3
- /** Implements TxProvider by querying an Aztec node for the txs. */
4
- export class AztecNodeTxProvider implements TxProvider {
5
- constructor(private node: AztecNode) {}
6
-
7
- getTxByHash(txHash: TxHash): Promise<Tx | undefined> {
8
- return this.node.getTxByHash(txHash);
9
- }
10
- }
@@ -1,17 +0,0 @@
1
- import { type ConfigMappingsType, getConfigFromMappings } from '@aztec/foundation/config';
2
-
3
- export type TxProviderConfig = {
4
- txProviderNodeUrl: string | undefined;
5
- };
6
-
7
- export const txProviderConfigMappings: ConfigMappingsType<TxProviderConfig> = {
8
- txProviderNodeUrl: {
9
- env: 'TX_PROVIDER_NODE_URL',
10
- description: 'The URL of the tx provider node',
11
- parseEnv: (val: string) => val,
12
- },
13
- };
14
-
15
- export function getTxProviderConfigFromEnv(): TxProviderConfig {
16
- return getConfigFromMappings<TxProviderConfig>(txProviderConfigMappings);
17
- }
@@ -1,13 +0,0 @@
1
- import { type TxProvider, createAztecNodeClient } from '@aztec/circuit-types';
2
-
3
- import { AztecNodeTxProvider } from './aztec-node-tx-provider.js';
4
- import { type TxProviderConfig } from './config.js';
5
-
6
- export function createTxProvider(config: TxProviderConfig): TxProvider {
7
- if (config.txProviderNodeUrl) {
8
- const node = createAztecNodeClient(config.txProviderNodeUrl);
9
- return new AztecNodeTxProvider(node);
10
- } else {
11
- throw new Error(`Aztec Node URL for Tx Provider is not set.`);
12
- }
13
- }