@atomiqlabs/chain-evm 1.0.0-dev.22

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 (146) hide show
  1. package/LICENSE +201 -0
  2. package/dist/chains/citrea/CitreaChainType.d.ts +13 -0
  3. package/dist/chains/citrea/CitreaChainType.js +2 -0
  4. package/dist/chains/citrea/CitreaInitializer.d.ts +30 -0
  5. package/dist/chains/citrea/CitreaInitializer.js +120 -0
  6. package/dist/evm/btcrelay/BtcRelayAbi.d.ts +198 -0
  7. package/dist/evm/btcrelay/BtcRelayAbi.js +261 -0
  8. package/dist/evm/btcrelay/BtcRelayTypechain.d.ts +172 -0
  9. package/dist/evm/btcrelay/BtcRelayTypechain.js +2 -0
  10. package/dist/evm/btcrelay/EVMBtcRelay.d.ts +188 -0
  11. package/dist/evm/btcrelay/EVMBtcRelay.js +419 -0
  12. package/dist/evm/btcrelay/headers/EVMBtcHeader.d.ts +33 -0
  13. package/dist/evm/btcrelay/headers/EVMBtcHeader.js +84 -0
  14. package/dist/evm/btcrelay/headers/EVMBtcStoredHeader.d.ts +56 -0
  15. package/dist/evm/btcrelay/headers/EVMBtcStoredHeader.js +123 -0
  16. package/dist/evm/chain/EVMChainInterface.d.ts +51 -0
  17. package/dist/evm/chain/EVMChainInterface.js +90 -0
  18. package/dist/evm/chain/EVMModule.d.ts +9 -0
  19. package/dist/evm/chain/EVMModule.js +13 -0
  20. package/dist/evm/chain/modules/ERC20Abi.d.ts +168 -0
  21. package/dist/evm/chain/modules/ERC20Abi.js +225 -0
  22. package/dist/evm/chain/modules/EVMAddresses.d.ts +9 -0
  23. package/dist/evm/chain/modules/EVMAddresses.js +26 -0
  24. package/dist/evm/chain/modules/EVMBlocks.d.ts +20 -0
  25. package/dist/evm/chain/modules/EVMBlocks.js +64 -0
  26. package/dist/evm/chain/modules/EVMEvents.d.ts +36 -0
  27. package/dist/evm/chain/modules/EVMEvents.js +122 -0
  28. package/dist/evm/chain/modules/EVMFees.d.ts +35 -0
  29. package/dist/evm/chain/modules/EVMFees.js +73 -0
  30. package/dist/evm/chain/modules/EVMSignatures.d.ts +29 -0
  31. package/dist/evm/chain/modules/EVMSignatures.js +68 -0
  32. package/dist/evm/chain/modules/EVMTokens.d.ts +49 -0
  33. package/dist/evm/chain/modules/EVMTokens.js +105 -0
  34. package/dist/evm/chain/modules/EVMTransactions.d.ts +89 -0
  35. package/dist/evm/chain/modules/EVMTransactions.js +216 -0
  36. package/dist/evm/contract/EVMContractBase.d.ts +22 -0
  37. package/dist/evm/contract/EVMContractBase.js +34 -0
  38. package/dist/evm/contract/EVMContractModule.d.ts +8 -0
  39. package/dist/evm/contract/EVMContractModule.js +11 -0
  40. package/dist/evm/contract/modules/EVMContractEvents.d.ts +42 -0
  41. package/dist/evm/contract/modules/EVMContractEvents.js +75 -0
  42. package/dist/evm/events/EVMChainEvents.d.ts +22 -0
  43. package/dist/evm/events/EVMChainEvents.js +67 -0
  44. package/dist/evm/events/EVMChainEventsBrowser.d.ts +86 -0
  45. package/dist/evm/events/EVMChainEventsBrowser.js +294 -0
  46. package/dist/evm/spv_swap/EVMSpvVaultContract.d.ts +64 -0
  47. package/dist/evm/spv_swap/EVMSpvVaultContract.js +410 -0
  48. package/dist/evm/spv_swap/EVMSpvVaultData.d.ts +38 -0
  49. package/dist/evm/spv_swap/EVMSpvVaultData.js +159 -0
  50. package/dist/evm/spv_swap/EVMSpvWithdrawalData.d.ts +19 -0
  51. package/dist/evm/spv_swap/EVMSpvWithdrawalData.js +55 -0
  52. package/dist/evm/spv_swap/SpvVaultContractAbi.d.ts +91 -0
  53. package/dist/evm/spv_swap/SpvVaultContractAbi.js +849 -0
  54. package/dist/evm/spv_swap/SpvVaultContractTypechain.d.ts +450 -0
  55. package/dist/evm/spv_swap/SpvVaultContractTypechain.js +2 -0
  56. package/dist/evm/swaps/EVMSwapContract.d.ts +192 -0
  57. package/dist/evm/swaps/EVMSwapContract.js +373 -0
  58. package/dist/evm/swaps/EVMSwapData.d.ts +64 -0
  59. package/dist/evm/swaps/EVMSwapData.js +254 -0
  60. package/dist/evm/swaps/EVMSwapModule.d.ts +9 -0
  61. package/dist/evm/swaps/EVMSwapModule.js +11 -0
  62. package/dist/evm/swaps/EscrowManagerAbi.d.ts +120 -0
  63. package/dist/evm/swaps/EscrowManagerAbi.js +985 -0
  64. package/dist/evm/swaps/EscrowManagerTypechain.d.ts +475 -0
  65. package/dist/evm/swaps/EscrowManagerTypechain.js +2 -0
  66. package/dist/evm/swaps/handlers/IHandler.d.ts +13 -0
  67. package/dist/evm/swaps/handlers/IHandler.js +2 -0
  68. package/dist/evm/swaps/handlers/claim/ClaimHandlers.d.ts +10 -0
  69. package/dist/evm/swaps/handlers/claim/ClaimHandlers.js +13 -0
  70. package/dist/evm/swaps/handlers/claim/HashlockClaimHandler.d.ts +20 -0
  71. package/dist/evm/swaps/handlers/claim/HashlockClaimHandler.js +39 -0
  72. package/dist/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.d.ts +24 -0
  73. package/dist/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.js +59 -0
  74. package/dist/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.d.ts +25 -0
  75. package/dist/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.js +51 -0
  76. package/dist/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.d.ts +21 -0
  77. package/dist/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.js +28 -0
  78. package/dist/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.d.ts +48 -0
  79. package/dist/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.js +63 -0
  80. package/dist/evm/swaps/handlers/refund/TimelockRefundHandler.d.ts +17 -0
  81. package/dist/evm/swaps/handlers/refund/TimelockRefundHandler.js +28 -0
  82. package/dist/evm/swaps/modules/EVMLpVault.d.ts +69 -0
  83. package/dist/evm/swaps/modules/EVMLpVault.js +131 -0
  84. package/dist/evm/swaps/modules/EVMSwapClaim.d.ts +53 -0
  85. package/dist/evm/swaps/modules/EVMSwapClaim.js +101 -0
  86. package/dist/evm/swaps/modules/EVMSwapInit.d.ts +88 -0
  87. package/dist/evm/swaps/modules/EVMSwapInit.js +241 -0
  88. package/dist/evm/swaps/modules/EVMSwapRefund.d.ts +62 -0
  89. package/dist/evm/swaps/modules/EVMSwapRefund.js +132 -0
  90. package/dist/evm/typechain/common.d.ts +50 -0
  91. package/dist/evm/typechain/common.js +2 -0
  92. package/dist/evm/wallet/EVMSigner.d.ts +9 -0
  93. package/dist/evm/wallet/EVMSigner.js +16 -0
  94. package/dist/index.d.ts +37 -0
  95. package/dist/index.js +53 -0
  96. package/dist/utils/Utils.d.ts +15 -0
  97. package/dist/utils/Utils.js +71 -0
  98. package/package.json +37 -0
  99. package/src/chains/citrea/CitreaChainType.ts +28 -0
  100. package/src/chains/citrea/CitreaInitializer.ts +167 -0
  101. package/src/evm/btcrelay/BtcRelayAbi.ts +258 -0
  102. package/src/evm/btcrelay/BtcRelayTypechain.ts +371 -0
  103. package/src/evm/btcrelay/EVMBtcRelay.ts +517 -0
  104. package/src/evm/btcrelay/headers/EVMBtcHeader.ts +110 -0
  105. package/src/evm/btcrelay/headers/EVMBtcStoredHeader.ts +153 -0
  106. package/src/evm/chain/EVMChainInterface.ts +157 -0
  107. package/src/evm/chain/EVMModule.ts +21 -0
  108. package/src/evm/chain/modules/ERC20Abi.ts +222 -0
  109. package/src/evm/chain/modules/EVMAddresses.ts +24 -0
  110. package/src/evm/chain/modules/EVMBlocks.ts +75 -0
  111. package/src/evm/chain/modules/EVMEvents.ts +139 -0
  112. package/src/evm/chain/modules/EVMFees.ts +105 -0
  113. package/src/evm/chain/modules/EVMSignatures.ts +76 -0
  114. package/src/evm/chain/modules/EVMTokens.ts +115 -0
  115. package/src/evm/chain/modules/EVMTransactions.ts +246 -0
  116. package/src/evm/contract/EVMContractBase.ts +63 -0
  117. package/src/evm/contract/EVMContractModule.ts +16 -0
  118. package/src/evm/contract/modules/EVMContractEvents.ts +102 -0
  119. package/src/evm/events/EVMChainEvents.ts +81 -0
  120. package/src/evm/events/EVMChainEventsBrowser.ts +390 -0
  121. package/src/evm/spv_swap/EVMSpvVaultContract.ts +533 -0
  122. package/src/evm/spv_swap/EVMSpvVaultData.ts +201 -0
  123. package/src/evm/spv_swap/EVMSpvWithdrawalData.ts +70 -0
  124. package/src/evm/spv_swap/SpvVaultContractAbi.ts +846 -0
  125. package/src/evm/spv_swap/SpvVaultContractTypechain.ts +685 -0
  126. package/src/evm/swaps/EVMSwapContract.ts +590 -0
  127. package/src/evm/swaps/EVMSwapData.ts +367 -0
  128. package/src/evm/swaps/EVMSwapModule.ts +16 -0
  129. package/src/evm/swaps/EscrowManagerAbi.ts +982 -0
  130. package/src/evm/swaps/EscrowManagerTypechain.ts +723 -0
  131. package/src/evm/swaps/handlers/IHandler.ts +17 -0
  132. package/src/evm/swaps/handlers/claim/ClaimHandlers.ts +20 -0
  133. package/src/evm/swaps/handlers/claim/HashlockClaimHandler.ts +47 -0
  134. package/src/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.ts +82 -0
  135. package/src/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.ts +76 -0
  136. package/src/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.ts +46 -0
  137. package/src/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.ts +115 -0
  138. package/src/evm/swaps/handlers/refund/TimelockRefundHandler.ts +38 -0
  139. package/src/evm/swaps/modules/EVMLpVault.ts +153 -0
  140. package/src/evm/swaps/modules/EVMSwapClaim.ts +141 -0
  141. package/src/evm/swaps/modules/EVMSwapInit.ts +292 -0
  142. package/src/evm/swaps/modules/EVMSwapRefund.ts +198 -0
  143. package/src/evm/typechain/common.ts +131 -0
  144. package/src/evm/wallet/EVMSigner.ts +23 -0
  145. package/src/index.ts +44 -0
  146. package/src/utils/Utils.ts +81 -0
@@ -0,0 +1,89 @@
1
+ import { EVMModule } from "../EVMModule";
2
+ import { Transaction, TransactionRequest } from "ethers";
3
+ import { EVMSigner } from "../../wallet/EVMSigner";
4
+ export type EVMTx = TransactionRequest;
5
+ export type EVMTxTrace = {
6
+ from: string;
7
+ gas: string;
8
+ gasused: string;
9
+ to: string;
10
+ input: string;
11
+ output: string;
12
+ error: string;
13
+ revertReason: string;
14
+ calls: EVMTxTrace[];
15
+ type: "CREATE" | "CALL" | "STATICCALL";
16
+ };
17
+ export declare class EVMTransactions extends EVMModule<any> {
18
+ private readonly latestConfirmedNonces;
19
+ private cbkBeforeTxSigned;
20
+ private cbkSendTransaction;
21
+ /**
22
+ * Waits for transaction confirmation using WS subscription and occasional HTTP polling, also re-sends
23
+ * the transaction at regular interval
24
+ *
25
+ * @param tx EVM transaction to wait for confirmation for
26
+ * @param abortSignal signal to abort waiting for tx confirmation
27
+ * @private
28
+ */
29
+ private confirmTransaction;
30
+ /**
31
+ * Prepares starknet transactions, checks if the account is deployed, assigns nonces if needed & calls beforeTxSigned callback
32
+ *
33
+ * @param signer
34
+ * @param txs
35
+ * @private
36
+ */
37
+ private prepareTransactions;
38
+ /**
39
+ * Sends out a signed transaction to the RPC
40
+ *
41
+ * @param tx EVM tx to send
42
+ * @param onBeforePublish a callback called before every transaction is published
43
+ * @private
44
+ */
45
+ private sendSignedTransaction;
46
+ /**
47
+ * Prepares, signs, sends (in parallel or sequentially) & optionally waits for confirmation
48
+ * of a batch of EVM transactions
49
+ *
50
+ * @param signer
51
+ * @param txs transactions to send
52
+ * @param waitForConfirmation whether to wait for transaction confirmations (this also makes sure the transactions
53
+ * are re-sent at regular intervals)
54
+ * @param abortSignal abort signal to abort waiting for transaction confirmations
55
+ * @param parallel whether the send all the transaction at once in parallel or sequentially (such that transactions
56
+ * are executed in order)
57
+ * @param onBeforePublish a callback called before every transaction is published
58
+ */
59
+ sendAndConfirm(signer: EVMSigner, txs: TransactionRequest[], waitForConfirmation?: boolean, abortSignal?: AbortSignal, parallel?: boolean, onBeforePublish?: (txId: string, rawTx: string) => Promise<void>): Promise<string[]>;
60
+ /**
61
+ * Serializes the signed EVM transaction
62
+ *
63
+ * @param tx
64
+ */
65
+ serializeTx(tx: Transaction): Promise<string>;
66
+ /**
67
+ * Deserializes signed EVM transaction
68
+ *
69
+ * @param txData
70
+ */
71
+ deserializeTx(txData: string): Promise<Transaction>;
72
+ /**
73
+ * Gets the status of the raw starknet transaction
74
+ *
75
+ * @param tx
76
+ */
77
+ getTxStatus(tx: string): Promise<"pending" | "success" | "not_found" | "reverted">;
78
+ /**
79
+ * Gets the status of the starknet transaction with a specific txId
80
+ *
81
+ * @param txId
82
+ */
83
+ getTxIdStatus(txId: string): Promise<"pending" | "success" | "not_found" | "reverted">;
84
+ onBeforeTxSigned(callback: (tx: TransactionRequest) => Promise<void>): void;
85
+ offBeforeTxSigned(callback: (tx: TransactionRequest) => Promise<void>): boolean;
86
+ onSendTransaction(callback: (tx: string) => Promise<string>): void;
87
+ offSendTransaction(callback: (tx: string) => Promise<string>): boolean;
88
+ traceTransaction(txId: string): Promise<EVMTxTrace>;
89
+ }
@@ -0,0 +1,216 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.EVMTransactions = void 0;
4
+ const EVMModule_1 = require("../EVMModule");
5
+ const ethers_1 = require("ethers");
6
+ const Utils_1 = require("../../../utils/Utils");
7
+ class EVMTransactions extends EVMModule_1.EVMModule {
8
+ constructor() {
9
+ super(...arguments);
10
+ this.latestConfirmedNonces = {};
11
+ }
12
+ /**
13
+ * Waits for transaction confirmation using WS subscription and occasional HTTP polling, also re-sends
14
+ * the transaction at regular interval
15
+ *
16
+ * @param tx EVM transaction to wait for confirmation for
17
+ * @param abortSignal signal to abort waiting for tx confirmation
18
+ * @private
19
+ */
20
+ async confirmTransaction(tx, abortSignal) {
21
+ let state = "pending";
22
+ while (state === "pending" || state === "not_found") {
23
+ await (0, Utils_1.timeoutPromise)(3000, abortSignal);
24
+ state = await this.getTxIdStatus(tx.hash);
25
+ //Don't re-send transactions
26
+ // if(state==="not_found") await this.sendSignedTransaction(tx).catch(e => {
27
+ // if(e.baseError?.code === 59) return; //Transaction already in the mempool
28
+ // this.logger.error("confirmTransaction(): Error on transaction re-send: ", e);
29
+ // });
30
+ }
31
+ const nextAccountNonce = tx.nonce + 1;
32
+ const currentNonce = this.latestConfirmedNonces[tx.from];
33
+ if (currentNonce == null || nextAccountNonce > currentNonce) {
34
+ this.latestConfirmedNonces[tx.from] = nextAccountNonce;
35
+ }
36
+ if (state === "reverted")
37
+ throw new Error("Transaction reverted!");
38
+ }
39
+ /**
40
+ * Prepares starknet transactions, checks if the account is deployed, assigns nonces if needed & calls beforeTxSigned callback
41
+ *
42
+ * @param signer
43
+ * @param txs
44
+ * @private
45
+ */
46
+ async prepareTransactions(signer, txs) {
47
+ let nonce = (await signer.getNonce()) ?? await this.root.provider.getTransactionCount(signer.getAddress(), "pending");
48
+ const latestConfirmedNonce = this.latestConfirmedNonces[signer.getAddress()];
49
+ if (latestConfirmedNonce != null && latestConfirmedNonce > nonce) {
50
+ this.logger.debug("prepareTransactions(): Using nonce from local cache!");
51
+ nonce = latestConfirmedNonce;
52
+ }
53
+ for (let i = 0; i < txs.length; i++) {
54
+ const tx = txs[i];
55
+ tx.chainId = this.root.evmChainId;
56
+ tx.from = signer.getAddress();
57
+ if (tx.nonce != null)
58
+ nonce = tx.nonce; //Take the nonce from last tx
59
+ if (nonce == null)
60
+ nonce = await this.root.provider.getTransactionCount(signer.getAddress(), "pending"); //Fetch the nonce
61
+ if (tx.nonce == null)
62
+ tx.nonce = nonce;
63
+ this.logger.debug("sendAndConfirm(): transaction prepared (" + (i + 1) + "/" + txs.length + "), nonce: " + tx.nonce);
64
+ nonce++;
65
+ if (this.cbkBeforeTxSigned != null)
66
+ await this.cbkBeforeTxSigned(tx);
67
+ }
68
+ }
69
+ /**
70
+ * Sends out a signed transaction to the RPC
71
+ *
72
+ * @param tx EVM tx to send
73
+ * @param onBeforePublish a callback called before every transaction is published
74
+ * @private
75
+ */
76
+ async sendSignedTransaction(tx, onBeforePublish) {
77
+ if (onBeforePublish != null)
78
+ await onBeforePublish(tx.hash, await this.serializeTx(tx));
79
+ this.logger.debug("sendSignedTransaction(): sending transaction: ", tx.hash);
80
+ const serializedTx = tx.serialized;
81
+ let result;
82
+ if (this.cbkSendTransaction != null)
83
+ result = await this.cbkSendTransaction(serializedTx);
84
+ if (result == null) {
85
+ const broadcastResult = await this.provider.broadcastTransaction(tx.serialized);
86
+ result = broadcastResult.hash;
87
+ }
88
+ this.logger.info("sendSignedTransaction(): tx sent, txHash: " + result);
89
+ return result;
90
+ }
91
+ /**
92
+ * Prepares, signs, sends (in parallel or sequentially) & optionally waits for confirmation
93
+ * of a batch of EVM transactions
94
+ *
95
+ * @param signer
96
+ * @param txs transactions to send
97
+ * @param waitForConfirmation whether to wait for transaction confirmations (this also makes sure the transactions
98
+ * are re-sent at regular intervals)
99
+ * @param abortSignal abort signal to abort waiting for transaction confirmations
100
+ * @param parallel whether the send all the transaction at once in parallel or sequentially (such that transactions
101
+ * are executed in order)
102
+ * @param onBeforePublish a callback called before every transaction is published
103
+ */
104
+ async sendAndConfirm(signer, txs, waitForConfirmation, abortSignal, parallel, onBeforePublish) {
105
+ await this.prepareTransactions(signer, txs);
106
+ const signedTxs = [];
107
+ //TODO: Maybe don't separate the signing process from the sending when using browser-based wallet,
108
+ // like with Starknet
109
+ for (let i = 0; i < txs.length; i++) {
110
+ const tx = txs[i];
111
+ const signedTx = ethers_1.Transaction.from(await signer.account.signTransaction(tx));
112
+ signedTxs.push(signedTx);
113
+ this.logger.debug("sendAndConfirm(): transaction signed (" + (i + 1) + "/" + txs.length + "): " + signedTx);
114
+ }
115
+ this.logger.debug("sendAndConfirm(): sending transactions, count: " + txs.length +
116
+ " waitForConfirmation: " + waitForConfirmation + " parallel: " + parallel);
117
+ const txIds = [];
118
+ if (parallel) {
119
+ const promises = [];
120
+ for (let i = 0; i < signedTxs.length; i++) {
121
+ const signedTx = signedTxs[i];
122
+ const txId = await this.sendSignedTransaction(signedTx, onBeforePublish);
123
+ if (waitForConfirmation)
124
+ promises.push(this.confirmTransaction(signedTx, abortSignal));
125
+ txIds.push(txId);
126
+ this.logger.debug("sendAndConfirm(): transaction sent (" + (i + 1) + "/" + signedTxs.length + "): " + signedTx.hash);
127
+ }
128
+ if (promises.length > 0)
129
+ await Promise.all(promises);
130
+ }
131
+ else {
132
+ for (let i = 0; i < signedTxs.length; i++) {
133
+ const signedTx = signedTxs[i];
134
+ const txId = await this.sendSignedTransaction(signedTx, onBeforePublish);
135
+ const confirmPromise = this.confirmTransaction(signedTx, abortSignal);
136
+ this.logger.debug("sendAndConfirm(): transaction sent (" + (i + 1) + "/" + txs.length + "): " + signedTx.hash);
137
+ //Don't await the last promise when !waitForConfirmation
138
+ if (i < txs.length - 1 || waitForConfirmation)
139
+ await confirmPromise;
140
+ txIds.push(txId);
141
+ }
142
+ }
143
+ this.logger.info("sendAndConfirm(): sent transactions, count: " + txs.length +
144
+ " waitForConfirmation: " + waitForConfirmation + " parallel: " + parallel);
145
+ return txIds;
146
+ }
147
+ /**
148
+ * Serializes the signed EVM transaction
149
+ *
150
+ * @param tx
151
+ */
152
+ serializeTx(tx) {
153
+ return Promise.resolve(tx.serialized);
154
+ }
155
+ /**
156
+ * Deserializes signed EVM transaction
157
+ *
158
+ * @param txData
159
+ */
160
+ deserializeTx(txData) {
161
+ return Promise.resolve(ethers_1.Transaction.from(txData));
162
+ }
163
+ /**
164
+ * Gets the status of the raw starknet transaction
165
+ *
166
+ * @param tx
167
+ */
168
+ async getTxStatus(tx) {
169
+ const parsedTx = await this.deserializeTx(tx);
170
+ return await this.getTxIdStatus(parsedTx.hash);
171
+ }
172
+ /**
173
+ * Gets the status of the starknet transaction with a specific txId
174
+ *
175
+ * @param txId
176
+ */
177
+ async getTxIdStatus(txId) {
178
+ const txResponse = await this.provider.getTransaction(txId);
179
+ if (txResponse == null)
180
+ return "not_found";
181
+ if (txResponse.blockHash == null)
182
+ return "pending";
183
+ const [safeBlockNumber, txReceipt] = await Promise.all([
184
+ this.root.config.safeBlockTag === "latest" ? Promise.resolve(null) : this.provider.getBlock(this.root.config.safeBlockTag).then(res => res.number),
185
+ this.provider.getTransactionReceipt(txId)
186
+ ]);
187
+ if (txReceipt == null || (safeBlockNumber != null && txReceipt.blockNumber < safeBlockNumber))
188
+ return "pending";
189
+ if (txReceipt.status === 0)
190
+ return "reverted";
191
+ return "success";
192
+ }
193
+ onBeforeTxSigned(callback) {
194
+ this.cbkBeforeTxSigned = callback;
195
+ }
196
+ offBeforeTxSigned(callback) {
197
+ this.cbkBeforeTxSigned = null;
198
+ return true;
199
+ }
200
+ onSendTransaction(callback) {
201
+ this.cbkSendTransaction = callback;
202
+ }
203
+ offSendTransaction(callback) {
204
+ this.cbkSendTransaction = null;
205
+ return true;
206
+ }
207
+ traceTransaction(txId) {
208
+ return this.provider.send("debug_traceTransaction", [
209
+ txId,
210
+ {
211
+ tracer: "callTracer"
212
+ }
213
+ ]);
214
+ }
215
+ }
216
+ exports.EVMTransactions = EVMTransactions;
@@ -0,0 +1,22 @@
1
+ import { BaseContract, Log, TransactionDescription } from "ethers";
2
+ import { EVMChainInterface } from "../chain/EVMChainInterface";
3
+ import { EVMContractEvents } from "./modules/EVMContractEvents";
4
+ import { TypedContractMethod, TypedEventLog } from "../typechain/common";
5
+ type __TypechainOutputObject<T> = T extends TypedContractMethod<infer V> ? V : never;
6
+ export interface TypedFunctionCall<TCMethod extends TypedContractMethod> extends Omit<TransactionDescription, "args"> {
7
+ args: __TypechainOutputObject<TCMethod>;
8
+ }
9
+ /**
10
+ * Base class providing program specific utilities
11
+ */
12
+ export declare class EVMContractBase<T extends BaseContract> {
13
+ contract: T;
14
+ readonly Events: EVMContractEvents<T>;
15
+ readonly Chain: EVMChainInterface<any>;
16
+ readonly contractAddress: string;
17
+ readonly contractDeploymentHeight: number;
18
+ constructor(chainInterface: EVMChainInterface<any>, contractAddress: string, contractAbi: any, contractDeploymentHeight?: number);
19
+ toTypedEvent<TEventName extends keyof T["filters"] = keyof T["filters"]>(log: Log): TypedEventLog<T["filters"][TEventName]>;
20
+ parseCalldata<TMethod extends TypedContractMethod>(calldata: string): TypedFunctionCall<TMethod>;
21
+ }
22
+ export {};
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.EVMContractBase = void 0;
4
+ const ethers_1 = require("ethers");
5
+ const EVMContractEvents_1 = require("./modules/EVMContractEvents");
6
+ /**
7
+ * Base class providing program specific utilities
8
+ */
9
+ class EVMContractBase {
10
+ constructor(chainInterface, contractAddress, contractAbi, contractDeploymentHeight) {
11
+ this.Chain = chainInterface;
12
+ this.contract = new ethers_1.Contract(contractAddress, contractAbi, chainInterface.provider);
13
+ this.Events = new EVMContractEvents_1.EVMContractEvents(chainInterface, this);
14
+ this.contractAddress = contractAddress;
15
+ this.contractDeploymentHeight = contractDeploymentHeight;
16
+ }
17
+ toTypedEvent(log) {
18
+ let foundFragment;
19
+ try {
20
+ foundFragment = this.contract.interface.getEvent(log.topics[0]);
21
+ }
22
+ catch (error) { }
23
+ if (!foundFragment)
24
+ return null;
25
+ try {
26
+ return new ethers_1.EventLog(log, this.contract.interface, foundFragment);
27
+ }
28
+ catch (error) { }
29
+ }
30
+ parseCalldata(calldata) {
31
+ return this.contract.interface.parseTransaction({ data: calldata });
32
+ }
33
+ }
34
+ exports.EVMContractBase = EVMContractBase;
@@ -0,0 +1,8 @@
1
+ import { BaseContract } from "ethers";
2
+ import { EVMModule } from "../chain/EVMModule";
3
+ import { EVMChainInterface } from "../chain/EVMChainInterface";
4
+ import { EVMContractBase } from "./EVMContractBase";
5
+ export declare class EVMContractModule<T extends BaseContract> extends EVMModule<any> {
6
+ readonly contract: EVMContractBase<T>;
7
+ constructor(chainInterface: EVMChainInterface<any>, contract: EVMContractBase<T>);
8
+ }
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.EVMContractModule = void 0;
4
+ const EVMModule_1 = require("../chain/EVMModule");
5
+ class EVMContractModule extends EVMModule_1.EVMModule {
6
+ constructor(chainInterface, contract) {
7
+ super(chainInterface);
8
+ this.contract = contract;
9
+ }
10
+ }
11
+ exports.EVMContractModule = EVMContractModule;
@@ -0,0 +1,42 @@
1
+ import { BaseContract } from "ethers";
2
+ import { EVMEvents } from "../../chain/modules/EVMEvents";
3
+ import { EVMContractBase } from "../EVMContractBase";
4
+ import { EVMChainInterface } from "../../chain/EVMChainInterface";
5
+ import { TypedEventLog } from "../../typechain/common";
6
+ export declare class EVMContractEvents<T extends BaseContract> extends EVMEvents {
7
+ readonly contract: EVMContractBase<T>;
8
+ readonly baseContract: T;
9
+ constructor(chainInterface: EVMChainInterface<any>, contract: EVMContractBase<T>);
10
+ private toTypedEvents;
11
+ private toFilter;
12
+ /**
13
+ * Returns the events occuring in a range of EVM blocks as identified by the contract and keys,
14
+ * returns pending events if no startHeight & endHeight is passed
15
+ *
16
+ * @param events
17
+ * @param keys
18
+ * @param startBlockHeight
19
+ * @param endBlockHeight
20
+ */
21
+ getContractBlockEvents<TEventName extends keyof T["filters"]>(events: TEventName[], keys: string[], startBlockHeight?: number, endBlockHeight?: number): Promise<TypedEventLog<T["filters"][TEventName]>[]>;
22
+ /**
23
+ * Runs a search backwards in time, processing the events for a specific topic public key
24
+ *
25
+ * @param events
26
+ * @param keys
27
+ * @param processor called for every event, should return a value if the correct event was found, or null
28
+ * if the search should continue
29
+ * @param abortSignal
30
+ */
31
+ findInContractEvents<TResult, TEventName extends keyof T["filters"]>(events: TEventName[], keys: string[], processor: (event: TypedEventLog<T["filters"][TEventName]>) => Promise<TResult>, abortSignal?: AbortSignal): Promise<TResult>;
32
+ /**
33
+ * Runs a search forwards in time, processing the events for a specific topic
34
+ *
35
+ * @param events
36
+ * @param keys
37
+ * @param processor called for every event, should return a value if the correct event was found, or null
38
+ * if the search should continue
39
+ * @param abortSignal
40
+ */
41
+ findInContractEventsForward<TResult, TEventName extends keyof T["filters"]>(events: TEventName[], keys: string[], processor: (event: TypedEventLog<T["filters"][TEventName]>) => Promise<TResult>, abortSignal?: AbortSignal): Promise<TResult>;
42
+ }
@@ -0,0 +1,75 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.EVMContractEvents = void 0;
4
+ const EVMEvents_1 = require("../../chain/modules/EVMEvents");
5
+ class EVMContractEvents extends EVMEvents_1.EVMEvents {
6
+ constructor(chainInterface, contract) {
7
+ super(chainInterface);
8
+ this.contract = contract;
9
+ this.baseContract = contract.contract;
10
+ }
11
+ toTypedEvents(blockEvents) {
12
+ return blockEvents.map(log => this.contract.toTypedEvent(log));
13
+ }
14
+ toFilter(events, keys) {
15
+ const filterArray = [];
16
+ filterArray.push(events.map(name => {
17
+ return this.baseContract.getEvent(name).fragment.topicHash;
18
+ }));
19
+ if (keys != null)
20
+ keys.forEach(key => filterArray.push(key));
21
+ return filterArray;
22
+ }
23
+ /**
24
+ * Returns the events occuring in a range of EVM blocks as identified by the contract and keys,
25
+ * returns pending events if no startHeight & endHeight is passed
26
+ *
27
+ * @param events
28
+ * @param keys
29
+ * @param startBlockHeight
30
+ * @param endBlockHeight
31
+ */
32
+ async getContractBlockEvents(events, keys, startBlockHeight, endBlockHeight = startBlockHeight) {
33
+ const blockEvents = await super.getBlockEvents(await this.baseContract.getAddress(), this.toFilter(events, keys), startBlockHeight, endBlockHeight);
34
+ return this.toTypedEvents(blockEvents);
35
+ }
36
+ /**
37
+ * Runs a search backwards in time, processing the events for a specific topic public key
38
+ *
39
+ * @param events
40
+ * @param keys
41
+ * @param processor called for every event, should return a value if the correct event was found, or null
42
+ * if the search should continue
43
+ * @param abortSignal
44
+ */
45
+ async findInContractEvents(events, keys, processor, abortSignal) {
46
+ return this.findInEvents(await this.baseContract.getAddress(), this.toFilter(events, keys), async (events) => {
47
+ const parsedEvents = this.toTypedEvents(events);
48
+ for (let event of parsedEvents) {
49
+ const result = await processor(event);
50
+ if (result != null)
51
+ return result;
52
+ }
53
+ }, abortSignal, this.contract.contractDeploymentHeight);
54
+ }
55
+ /**
56
+ * Runs a search forwards in time, processing the events for a specific topic
57
+ *
58
+ * @param events
59
+ * @param keys
60
+ * @param processor called for every event, should return a value if the correct event was found, or null
61
+ * if the search should continue
62
+ * @param abortSignal
63
+ */
64
+ async findInContractEventsForward(events, keys, processor, abortSignal) {
65
+ return this.findInEventsForward(await this.baseContract.getAddress(), this.toFilter(events, keys), async (events) => {
66
+ const parsedEvents = this.toTypedEvents(events);
67
+ for (let event of parsedEvents) {
68
+ const result = await processor(event);
69
+ if (result != null)
70
+ return result;
71
+ }
72
+ }, abortSignal, this.contract.contractDeploymentHeight);
73
+ }
74
+ }
75
+ exports.EVMContractEvents = EVMContractEvents;
@@ -0,0 +1,22 @@
1
+ import { EVMChainEventsBrowser } from "./EVMChainEventsBrowser";
2
+ import { EVMChainInterface } from "../chain/EVMChainInterface";
3
+ import { EVMSwapContract } from "../swaps/EVMSwapContract";
4
+ import { EVMSpvVaultContract } from "../spv_swap/EVMSpvVaultContract";
5
+ export declare class EVMChainEvents extends EVMChainEventsBrowser {
6
+ private readonly directory;
7
+ private readonly BLOCKHEIGHT_FILENAME;
8
+ constructor(directory: string, chainInterface: EVMChainInterface, evmSwapContract: EVMSwapContract, evmSpvVaultContract: EVMSpvVaultContract<any>, pollIntervalSeconds?: number);
9
+ /**
10
+ * Retrieves last signature & slot from filesystem
11
+ *
12
+ * @private
13
+ */
14
+ private getLastEventData;
15
+ /**
16
+ * Saves last signature & slot to the filesystem
17
+ *
18
+ * @private
19
+ */
20
+ private saveLastEventData;
21
+ init(): Promise<void>;
22
+ }
@@ -0,0 +1,67 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.EVMChainEvents = void 0;
4
+ //@ts-ignore
5
+ const fs = require("fs/promises");
6
+ const EVMChainEventsBrowser_1 = require("./EVMChainEventsBrowser");
7
+ class EVMChainEvents extends EVMChainEventsBrowser_1.EVMChainEventsBrowser {
8
+ constructor(directory, chainInterface, evmSwapContract, evmSpvVaultContract, pollIntervalSeconds) {
9
+ super(chainInterface, evmSwapContract, evmSpvVaultContract, pollIntervalSeconds);
10
+ this.BLOCKHEIGHT_FILENAME = "/" + chainInterface.chainId + "-blockheight.txt";
11
+ this.directory = directory;
12
+ }
13
+ /**
14
+ * Retrieves last signature & slot from filesystem
15
+ *
16
+ * @private
17
+ */
18
+ async getLastEventData() {
19
+ try {
20
+ const txt = (await fs.readFile(this.directory + this.BLOCKHEIGHT_FILENAME)).toString();
21
+ const arr = txt.split(";");
22
+ return arr.map(val => {
23
+ const stateResult = val.split(",");
24
+ if (stateResult.length >= 3) {
25
+ return {
26
+ lastBlockNumber: parseInt(stateResult[0]),
27
+ lastEvent: {
28
+ blockHash: stateResult[1],
29
+ logIndex: parseInt(stateResult[2])
30
+ }
31
+ };
32
+ }
33
+ else if (stateResult.length >= 1) {
34
+ return {
35
+ lastBlockNumber: parseInt(stateResult[0])
36
+ };
37
+ }
38
+ else {
39
+ return null;
40
+ }
41
+ });
42
+ }
43
+ catch (e) {
44
+ return null;
45
+ }
46
+ }
47
+ /**
48
+ * Saves last signature & slot to the filesystem
49
+ *
50
+ * @private
51
+ */
52
+ saveLastEventData(newState) {
53
+ return fs.writeFile(this.directory + this.BLOCKHEIGHT_FILENAME, newState.map(val => {
54
+ if (val.lastEvent == null) {
55
+ return val.lastBlockNumber.toString(10);
56
+ }
57
+ else {
58
+ return val.lastBlockNumber.toString(10) + "," + val.lastEvent.blockHash + "," + val.lastEvent.logIndex.toString(10);
59
+ }
60
+ }).join(";"));
61
+ }
62
+ async init() {
63
+ const lastState = await this.getLastEventData();
64
+ await this.setupPoll(lastState, (newState) => this.saveLastEventData(newState));
65
+ }
66
+ }
67
+ exports.EVMChainEvents = EVMChainEvents;