@atomiqlabs/chain-evm 1.0.0-dev.34 → 1.0.0-dev.36

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 (161) hide show
  1. package/LICENSE +201 -201
  2. package/dist/chains/citrea/CitreaBtcRelay.d.ts +21 -21
  3. package/dist/chains/citrea/CitreaBtcRelay.js +43 -43
  4. package/dist/chains/citrea/CitreaChainType.d.ts +13 -13
  5. package/dist/chains/citrea/CitreaChainType.js +2 -2
  6. package/dist/chains/citrea/CitreaFees.d.ts +29 -29
  7. package/dist/chains/citrea/CitreaFees.js +67 -67
  8. package/dist/chains/citrea/CitreaInitializer.d.ts +30 -30
  9. package/dist/chains/citrea/CitreaInitializer.js +127 -127
  10. package/dist/chains/citrea/CitreaSpvVaultContract.d.ts +15 -15
  11. package/dist/chains/citrea/CitreaSpvVaultContract.js +74 -74
  12. package/dist/chains/citrea/CitreaSwapContract.d.ts +22 -22
  13. package/dist/chains/citrea/CitreaSwapContract.js +96 -96
  14. package/dist/chains/citrea/CitreaTokens.d.ts +9 -9
  15. package/dist/chains/citrea/CitreaTokens.js +20 -20
  16. package/dist/evm/btcrelay/BtcRelayAbi.d.ts +198 -198
  17. package/dist/evm/btcrelay/BtcRelayAbi.js +261 -261
  18. package/dist/evm/btcrelay/BtcRelayTypechain.d.ts +172 -172
  19. package/dist/evm/btcrelay/BtcRelayTypechain.js +2 -2
  20. package/dist/evm/btcrelay/EVMBtcRelay.d.ts +195 -195
  21. package/dist/evm/btcrelay/EVMBtcRelay.js +423 -423
  22. package/dist/evm/btcrelay/headers/EVMBtcHeader.d.ts +33 -33
  23. package/dist/evm/btcrelay/headers/EVMBtcHeader.js +84 -84
  24. package/dist/evm/btcrelay/headers/EVMBtcStoredHeader.d.ts +56 -56
  25. package/dist/evm/btcrelay/headers/EVMBtcStoredHeader.js +123 -123
  26. package/dist/evm/chain/EVMChainInterface.d.ts +51 -51
  27. package/dist/evm/chain/EVMChainInterface.js +89 -89
  28. package/dist/evm/chain/EVMModule.d.ts +9 -9
  29. package/dist/evm/chain/EVMModule.js +13 -13
  30. package/dist/evm/chain/modules/ERC20Abi.d.ts +168 -168
  31. package/dist/evm/chain/modules/ERC20Abi.js +225 -225
  32. package/dist/evm/chain/modules/EVMAddresses.d.ts +10 -10
  33. package/dist/evm/chain/modules/EVMAddresses.js +30 -30
  34. package/dist/evm/chain/modules/EVMBlocks.d.ts +20 -20
  35. package/dist/evm/chain/modules/EVMBlocks.js +64 -64
  36. package/dist/evm/chain/modules/EVMEvents.d.ts +36 -36
  37. package/dist/evm/chain/modules/EVMEvents.js +122 -122
  38. package/dist/evm/chain/modules/EVMFees.d.ts +36 -36
  39. package/dist/evm/chain/modules/EVMFees.js +73 -73
  40. package/dist/evm/chain/modules/EVMSignatures.d.ts +29 -29
  41. package/dist/evm/chain/modules/EVMSignatures.js +68 -68
  42. package/dist/evm/chain/modules/EVMTokens.d.ts +70 -51
  43. package/dist/evm/chain/modules/EVMTokens.js +142 -113
  44. package/dist/evm/chain/modules/EVMTransactions.d.ts +89 -89
  45. package/dist/evm/chain/modules/EVMTransactions.js +216 -216
  46. package/dist/evm/contract/EVMContractBase.d.ts +22 -22
  47. package/dist/evm/contract/EVMContractBase.js +34 -34
  48. package/dist/evm/contract/EVMContractModule.d.ts +8 -8
  49. package/dist/evm/contract/EVMContractModule.js +11 -11
  50. package/dist/evm/contract/modules/EVMContractEvents.d.ts +42 -42
  51. package/dist/evm/contract/modules/EVMContractEvents.js +75 -75
  52. package/dist/evm/events/EVMChainEvents.d.ts +22 -22
  53. package/dist/evm/events/EVMChainEvents.js +67 -67
  54. package/dist/evm/events/EVMChainEventsBrowser.d.ts +86 -86
  55. package/dist/evm/events/EVMChainEventsBrowser.js +294 -294
  56. package/dist/evm/spv_swap/EVMSpvVaultContract.d.ts +78 -78
  57. package/dist/evm/spv_swap/EVMSpvVaultContract.js +478 -480
  58. package/dist/evm/spv_swap/EVMSpvVaultData.d.ts +39 -39
  59. package/dist/evm/spv_swap/EVMSpvVaultData.js +180 -180
  60. package/dist/evm/spv_swap/EVMSpvWithdrawalData.d.ts +19 -19
  61. package/dist/evm/spv_swap/EVMSpvWithdrawalData.js +55 -55
  62. package/dist/evm/spv_swap/SpvVaultContractAbi.d.ts +91 -91
  63. package/dist/evm/spv_swap/SpvVaultContractAbi.js +849 -849
  64. package/dist/evm/spv_swap/SpvVaultContractTypechain.d.ts +450 -450
  65. package/dist/evm/spv_swap/SpvVaultContractTypechain.js +2 -2
  66. package/dist/evm/swaps/EVMSwapContract.d.ts +193 -193
  67. package/dist/evm/swaps/EVMSwapContract.js +374 -374
  68. package/dist/evm/swaps/EVMSwapData.d.ts +66 -66
  69. package/dist/evm/swaps/EVMSwapData.js +260 -259
  70. package/dist/evm/swaps/EVMSwapModule.d.ts +9 -9
  71. package/dist/evm/swaps/EVMSwapModule.js +11 -11
  72. package/dist/evm/swaps/EscrowManagerAbi.d.ts +120 -120
  73. package/dist/evm/swaps/EscrowManagerAbi.js +985 -985
  74. package/dist/evm/swaps/EscrowManagerTypechain.d.ts +475 -475
  75. package/dist/evm/swaps/EscrowManagerTypechain.js +2 -2
  76. package/dist/evm/swaps/handlers/IHandler.d.ts +13 -13
  77. package/dist/evm/swaps/handlers/IHandler.js +2 -2
  78. package/dist/evm/swaps/handlers/claim/ClaimHandlers.d.ts +10 -10
  79. package/dist/evm/swaps/handlers/claim/ClaimHandlers.js +13 -13
  80. package/dist/evm/swaps/handlers/claim/HashlockClaimHandler.d.ts +20 -20
  81. package/dist/evm/swaps/handlers/claim/HashlockClaimHandler.js +39 -39
  82. package/dist/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.d.ts +24 -24
  83. package/dist/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.js +59 -59
  84. package/dist/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.d.ts +25 -25
  85. package/dist/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.js +51 -51
  86. package/dist/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.d.ts +21 -21
  87. package/dist/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.js +28 -28
  88. package/dist/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.d.ts +48 -48
  89. package/dist/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.js +63 -63
  90. package/dist/evm/swaps/handlers/refund/TimelockRefundHandler.d.ts +17 -17
  91. package/dist/evm/swaps/handlers/refund/TimelockRefundHandler.js +28 -28
  92. package/dist/evm/swaps/modules/EVMLpVault.d.ts +69 -69
  93. package/dist/evm/swaps/modules/EVMLpVault.js +134 -131
  94. package/dist/evm/swaps/modules/EVMSwapClaim.d.ts +54 -54
  95. package/dist/evm/swaps/modules/EVMSwapClaim.js +137 -137
  96. package/dist/evm/swaps/modules/EVMSwapInit.d.ts +88 -88
  97. package/dist/evm/swaps/modules/EVMSwapInit.js +274 -275
  98. package/dist/evm/swaps/modules/EVMSwapRefund.d.ts +62 -62
  99. package/dist/evm/swaps/modules/EVMSwapRefund.js +167 -167
  100. package/dist/evm/typechain/common.d.ts +50 -50
  101. package/dist/evm/typechain/common.js +2 -2
  102. package/dist/evm/wallet/EVMSigner.d.ts +9 -9
  103. package/dist/evm/wallet/EVMSigner.js +16 -16
  104. package/dist/index.d.ts +38 -38
  105. package/dist/index.js +54 -54
  106. package/dist/utils/Utils.d.ts +15 -15
  107. package/dist/utils/Utils.js +71 -71
  108. package/package.json +37 -37
  109. package/src/chains/citrea/CitreaBtcRelay.ts +57 -57
  110. package/src/chains/citrea/CitreaChainType.ts +28 -28
  111. package/src/chains/citrea/CitreaFees.ts +77 -77
  112. package/src/chains/citrea/CitreaInitializer.ts +178 -178
  113. package/src/chains/citrea/CitreaSpvVaultContract.ts +75 -75
  114. package/src/chains/citrea/CitreaSwapContract.ts +102 -102
  115. package/src/chains/citrea/CitreaTokens.ts +21 -21
  116. package/src/evm/btcrelay/BtcRelayAbi.ts +258 -258
  117. package/src/evm/btcrelay/BtcRelayTypechain.ts +371 -371
  118. package/src/evm/btcrelay/EVMBtcRelay.ts +522 -522
  119. package/src/evm/btcrelay/headers/EVMBtcHeader.ts +109 -109
  120. package/src/evm/btcrelay/headers/EVMBtcStoredHeader.ts +152 -152
  121. package/src/evm/chain/EVMChainInterface.ts +155 -155
  122. package/src/evm/chain/EVMModule.ts +21 -21
  123. package/src/evm/chain/modules/ERC20Abi.ts +222 -222
  124. package/src/evm/chain/modules/EVMAddresses.ts +28 -28
  125. package/src/evm/chain/modules/EVMBlocks.ts +75 -75
  126. package/src/evm/chain/modules/EVMEvents.ts +139 -139
  127. package/src/evm/chain/modules/EVMFees.ts +104 -104
  128. package/src/evm/chain/modules/EVMSignatures.ts +76 -76
  129. package/src/evm/chain/modules/EVMTokens.ts +155 -126
  130. package/src/evm/chain/modules/EVMTransactions.ts +246 -246
  131. package/src/evm/contract/EVMContractBase.ts +63 -63
  132. package/src/evm/contract/EVMContractModule.ts +16 -16
  133. package/src/evm/contract/modules/EVMContractEvents.ts +102 -102
  134. package/src/evm/events/EVMChainEvents.ts +81 -81
  135. package/src/evm/events/EVMChainEventsBrowser.ts +390 -390
  136. package/src/evm/spv_swap/EVMSpvVaultContract.ts +608 -603
  137. package/src/evm/spv_swap/EVMSpvVaultData.ts +224 -224
  138. package/src/evm/spv_swap/EVMSpvWithdrawalData.ts +70 -70
  139. package/src/evm/spv_swap/SpvVaultContractAbi.ts +846 -846
  140. package/src/evm/spv_swap/SpvVaultContractTypechain.ts +685 -685
  141. package/src/evm/swaps/EVMSwapContract.ts +592 -592
  142. package/src/evm/swaps/EVMSwapData.ts +378 -377
  143. package/src/evm/swaps/EVMSwapModule.ts +16 -16
  144. package/src/evm/swaps/EscrowManagerAbi.ts +982 -982
  145. package/src/evm/swaps/EscrowManagerTypechain.ts +723 -723
  146. package/src/evm/swaps/handlers/IHandler.ts +17 -17
  147. package/src/evm/swaps/handlers/claim/ClaimHandlers.ts +20 -20
  148. package/src/evm/swaps/handlers/claim/HashlockClaimHandler.ts +46 -46
  149. package/src/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.ts +82 -82
  150. package/src/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.ts +76 -76
  151. package/src/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.ts +46 -46
  152. package/src/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.ts +115 -115
  153. package/src/evm/swaps/handlers/refund/TimelockRefundHandler.ts +37 -37
  154. package/src/evm/swaps/modules/EVMLpVault.ts +154 -152
  155. package/src/evm/swaps/modules/EVMSwapClaim.ts +172 -172
  156. package/src/evm/swaps/modules/EVMSwapInit.ts +328 -325
  157. package/src/evm/swaps/modules/EVMSwapRefund.ts +229 -229
  158. package/src/evm/typechain/common.ts +131 -131
  159. package/src/evm/wallet/EVMSigner.ts +23 -23
  160. package/src/index.ts +45 -45
  161. package/src/utils/Utils.ts +81 -81
@@ -1,294 +1,294 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.EVMChainEventsBrowser = void 0;
4
- const base_1 = require("@atomiqlabs/base");
5
- const EVMSwapData_1 = require("../swaps/EVMSwapData");
6
- const ethers_1 = require("ethers");
7
- const Utils_1 = require("../../utils/Utils");
8
- const EVMSpvVaultContract_1 = require("../spv_swap/EVMSpvVaultContract");
9
- const LOGS_SLIDING_WINDOW_LENGTH = 60;
10
- /**
11
- * EVM on-chain event handler for front-end systems without access to fs, uses WS or long-polling to subscribe, might lose
12
- * out on some events if the network is unreliable, front-end systems should take this into consideration and not
13
- * rely purely on events
14
- */
15
- class EVMChainEventsBrowser {
16
- constructor(chainInterface, evmSwapContract, evmSpvVaultContract, pollIntervalSeconds = 5) {
17
- this.listeners = [];
18
- this.logger = (0, Utils_1.getLogger)("EVMChainEventsBrowser: ");
19
- this.chainInterface = chainInterface;
20
- this.provider = chainInterface.provider;
21
- this.evmSwapContract = evmSwapContract;
22
- this.evmSpvVaultContract = evmSpvVaultContract;
23
- this.pollIntervalSeconds = pollIntervalSeconds;
24
- }
25
- findInitSwapData(call, escrowHash, claimHandler) {
26
- if (call.to.toLowerCase() === this.evmSwapContract.contractAddress.toLowerCase()) {
27
- const result = this.evmSwapContract.parseCalldata(call.input);
28
- if (result != null && result.name === "initialize") {
29
- //Found, check correct escrow hash
30
- const [escrowData, signature, timeout, extraData] = result.args;
31
- const escrow = EVMSwapData_1.EVMSwapData.deserializeFromStruct(escrowData, claimHandler);
32
- if ("0x" + escrow.getEscrowHash() === escrowHash) {
33
- const extraDataHex = (0, ethers_1.hexlify)(extraData);
34
- if (extraDataHex.length > 2) {
35
- escrow.setExtraData(extraDataHex.substring(2));
36
- }
37
- return escrow;
38
- }
39
- }
40
- }
41
- for (let _call of call.calls) {
42
- const found = this.findInitSwapData(_call, escrowHash, claimHandler);
43
- if (found != null)
44
- return found;
45
- }
46
- return null;
47
- }
48
- /**
49
- * Returns async getter for fetching on-demand initialize event swap data
50
- *
51
- * @param event
52
- * @param claimHandler
53
- * @private
54
- * @returns {() => Promise<EVMSwapData>} getter to be passed to InitializeEvent constructor
55
- */
56
- getSwapDataGetter(event, claimHandler) {
57
- return async () => {
58
- const trace = await this.chainInterface.Transactions.traceTransaction(event.transactionHash);
59
- if (trace == null)
60
- return null;
61
- return this.findInitSwapData(trace, event.args.escrowHash, claimHandler);
62
- };
63
- }
64
- parseInitializeEvent(event) {
65
- const escrowHash = event.args.escrowHash.substring(2);
66
- const claimHandlerHex = event.args.claimHandler;
67
- const claimHandler = this.evmSwapContract.claimHandlersByAddress[claimHandlerHex.toLowerCase()];
68
- if (claimHandler == null) {
69
- this.logger.warn("parseInitializeEvent(" + escrowHash + "): Unknown claim handler with claim: " + claimHandlerHex);
70
- return null;
71
- }
72
- const swapType = claimHandler.getType();
73
- this.logger.debug("InitializeEvent escrowHash: " + escrowHash);
74
- return new base_1.InitializeEvent(escrowHash, swapType, (0, Utils_1.onceAsync)(this.getSwapDataGetter(event, claimHandler)));
75
- }
76
- parseRefundEvent(event) {
77
- const escrowHash = event.args.escrowHash.substring(2);
78
- this.logger.debug("RefundEvent escrowHash: " + escrowHash);
79
- return new base_1.RefundEvent(escrowHash);
80
- }
81
- parseClaimEvent(event) {
82
- const escrowHash = event.args.escrowHash.substring(2);
83
- const claimHandlerHex = event.args.claimHandler;
84
- const claimHandler = this.evmSwapContract.claimHandlersByAddress[claimHandlerHex.toLowerCase()];
85
- if (claimHandler == null) {
86
- this.logger.warn("parseClaimEvent(" + escrowHash + "): Unknown claim handler with claim: " + claimHandlerHex);
87
- return null;
88
- }
89
- const witnessResult = event.args.witnessResult.substring(2);
90
- this.logger.debug("ClaimEvent witnessResult: " + witnessResult + " escrowHash: " + escrowHash);
91
- return new base_1.ClaimEvent(escrowHash, witnessResult);
92
- }
93
- parseSpvOpenEvent(event) {
94
- const owner = event.args.owner;
95
- const vaultId = event.args.vaultId;
96
- const btcTxId = Buffer.from(event.args.btcTxHash.substring(2), "hex").reverse().toString("hex");
97
- const vout = Number(event.args.vout);
98
- this.logger.debug("SpvOpenEvent owner: " + owner + " vaultId: " + vaultId + " utxo: " + btcTxId + ":" + vout);
99
- return new base_1.SpvVaultOpenEvent(owner, vaultId, btcTxId, vout);
100
- }
101
- parseSpvDepositEvent(event) {
102
- const [owner, vaultId] = (0, EVMSpvVaultContract_1.unpackOwnerAndVaultId)(event.args.ownerAndVaultId);
103
- const amounts = [event.args.amount0, event.args.amount1];
104
- const depositCount = Number(event.args.depositCount);
105
- this.logger.debug("SpvDepositEvent owner: " + owner + " vaultId: " + vaultId + " depositCount: " + depositCount + " amounts: ", amounts);
106
- return new base_1.SpvVaultDepositEvent(owner, vaultId, amounts, depositCount);
107
- }
108
- parseSpvFrontEvent(event) {
109
- const [owner, vaultId] = (0, EVMSpvVaultContract_1.unpackOwnerAndVaultId)(event.args.ownerAndVaultId);
110
- const btcTxId = Buffer.from(event.args.btcTxHash.substring(2), "hex").reverse().toString("hex");
111
- const recipient = event.args.recipient;
112
- const executionHash = event.args.executionHash;
113
- const amounts = [event.args.amount0, event.args.amount1];
114
- const frontingAddress = event.args.caller;
115
- this.logger.debug("SpvFrontEvent owner: " + owner + " vaultId: " + vaultId + " btcTxId: " + btcTxId +
116
- " recipient: " + recipient + " frontedBy: " + frontingAddress + " amounts: ", amounts);
117
- return new base_1.SpvVaultFrontEvent(owner, vaultId, btcTxId, recipient, executionHash, amounts, frontingAddress);
118
- }
119
- parseSpvClaimEvent(event) {
120
- const [owner, vaultId] = (0, EVMSpvVaultContract_1.unpackOwnerAndVaultId)(event.args.ownerAndVaultId);
121
- const btcTxId = Buffer.from(event.args.btcTxHash.substring(2), "hex").reverse().toString("hex");
122
- const recipient = event.args.recipient;
123
- const executionHash = event.args.executionHash;
124
- const amounts = [event.args.amount0, event.args.amount1];
125
- const caller = event.args.caller;
126
- const frontingAddress = event.args.frontingAddress;
127
- const withdrawCount = Number(event.args.withdrawCount);
128
- this.logger.debug("SpvClaimEvent owner: " + owner + " vaultId: " + vaultId + " btcTxId: " + btcTxId + " withdrawCount: " + withdrawCount +
129
- " recipient: " + recipient + " frontedBy: " + frontingAddress + " claimedBy: " + caller + " amounts: ", amounts);
130
- return new base_1.SpvVaultClaimEvent(owner, vaultId, btcTxId, recipient, executionHash, amounts, caller, frontingAddress, withdrawCount);
131
- }
132
- parseSpvCloseEvent(event) {
133
- const btcTxId = Buffer.from(event.args.btcTxHash.substring(2), "hex").reverse().toString("hex");
134
- return new base_1.SpvVaultCloseEvent(event.args.owner, event.args.vaultId, btcTxId, event.args.error);
135
- }
136
- /**
137
- * Processes event as received from the chain, parses it & calls event listeners
138
- *
139
- * @param events
140
- * @param currentBlock
141
- * @protected
142
- */
143
- async processEvents(events, currentBlock) {
144
- const parsedEvents = [];
145
- for (let event of events) {
146
- let parsedEvent;
147
- switch (event.eventName) {
148
- case "Claim":
149
- parsedEvent = this.parseClaimEvent(event);
150
- break;
151
- case "Refund":
152
- parsedEvent = this.parseRefundEvent(event);
153
- break;
154
- case "Initialize":
155
- parsedEvent = this.parseInitializeEvent(event);
156
- break;
157
- case "Opened":
158
- parsedEvent = this.parseSpvOpenEvent(event);
159
- break;
160
- case "Deposited":
161
- parsedEvent = this.parseSpvDepositEvent(event);
162
- break;
163
- case "Fronted":
164
- parsedEvent = this.parseSpvFrontEvent(event);
165
- break;
166
- case "Claimed":
167
- parsedEvent = this.parseSpvClaimEvent(event);
168
- break;
169
- case "Closed":
170
- parsedEvent = this.parseSpvCloseEvent(event);
171
- break;
172
- }
173
- const timestamp = event.blockNumber === currentBlock.number ? currentBlock.timestamp : await this.chainInterface.Blocks.getBlockTime(event.blockNumber);
174
- parsedEvent.meta = {
175
- blockTime: timestamp,
176
- txId: event.transactionHash,
177
- timestamp //Maybe deprecated
178
- };
179
- parsedEvents.push(parsedEvent);
180
- }
181
- for (let listener of this.listeners) {
182
- await listener(parsedEvents);
183
- }
184
- }
185
- async checkEventsEcrowManager(currentBlock, lastProcessedEvent, lastBlockNumber) {
186
- lastBlockNumber ?? (lastBlockNumber = currentBlock.number);
187
- // this.logger.debug(`checkEvents(EscrowManager): Requesting logs: ${lastBlockNumber}...${currentBlock.number}`);
188
- let events = await this.evmSwapContract.Events.getContractBlockEvents(["Initialize", "Claim", "Refund"], [], lastBlockNumber, currentBlock.number);
189
- if (lastProcessedEvent != null) {
190
- const latestProcessedEventIndex = events.findIndex(val => val.blockHash === lastProcessedEvent.blockHash && val.index === lastProcessedEvent.logIndex);
191
- if (latestProcessedEventIndex !== -1) {
192
- events.splice(0, latestProcessedEventIndex + 1);
193
- this.logger.debug("checkEvents(EscrowManager): Splicing processed events, resulting size: " + events.length);
194
- }
195
- }
196
- if (events.length > 0) {
197
- await this.processEvents(events, currentBlock);
198
- const lastProcessed = events[events.length - 1];
199
- lastProcessedEvent = {
200
- blockHash: lastProcessed.blockHash,
201
- logIndex: lastProcessed.index
202
- };
203
- if (lastProcessed.blockNumber > lastBlockNumber)
204
- lastBlockNumber = lastProcessed.blockNumber;
205
- }
206
- else if (currentBlock.number - lastBlockNumber > LOGS_SLIDING_WINDOW_LENGTH) {
207
- lastProcessedEvent = null;
208
- lastBlockNumber = currentBlock.number - LOGS_SLIDING_WINDOW_LENGTH;
209
- }
210
- return [lastProcessedEvent, lastBlockNumber];
211
- }
212
- async checkEventsSpvVaults(currentBlock, lastProcessedEvent, lastBlockNumber) {
213
- lastBlockNumber ?? (lastBlockNumber = currentBlock.number);
214
- // this.logger.debug(`checkEvents(SpvVaults): Requesting logs: ${lastBlockNumber}...${currentBlock.number}`);
215
- let events = await this.evmSpvVaultContract.Events.getContractBlockEvents(["Opened", "Deposited", "Closed", "Fronted", "Claimed"], [], lastBlockNumber, currentBlock.number);
216
- if (lastProcessedEvent != null) {
217
- const latestProcessedEventIndex = events.findIndex(val => val.blockHash === lastProcessedEvent.blockHash && val.index === lastProcessedEvent.logIndex);
218
- if (latestProcessedEventIndex !== -1) {
219
- events.splice(0, latestProcessedEventIndex + 1);
220
- this.logger.debug("checkEvents(SpvVaults): Splicing processed events, resulting size: " + events.length);
221
- }
222
- }
223
- if (events.length > 0) {
224
- await this.processEvents(events, currentBlock);
225
- const lastProcessed = events[events.length - 1];
226
- lastProcessedEvent = {
227
- blockHash: lastProcessed.blockHash,
228
- logIndex: lastProcessed.index
229
- };
230
- if (lastProcessed.blockNumber > lastBlockNumber)
231
- lastBlockNumber = lastProcessed.blockNumber;
232
- }
233
- else if (currentBlock.number - lastBlockNumber > LOGS_SLIDING_WINDOW_LENGTH) {
234
- lastProcessedEvent = null;
235
- lastBlockNumber = currentBlock.number - LOGS_SLIDING_WINDOW_LENGTH;
236
- }
237
- return [lastProcessedEvent, lastBlockNumber];
238
- }
239
- async checkEvents(lastState) {
240
- lastState ?? (lastState = []);
241
- const currentBlock = await this.provider.getBlock(this.chainInterface.config.safeBlockTag, false);
242
- const [lastEscrowEvent, lastEscrowHeight] = await this.checkEventsEcrowManager(currentBlock, lastState?.[0]?.lastEvent, lastState?.[0]?.lastBlockNumber);
243
- const [lastSpvVaultEvent, lastSpvVaultHeight] = await this.checkEventsSpvVaults(currentBlock, lastState?.[1]?.lastEvent, lastState?.[1]?.lastBlockNumber);
244
- lastState = [
245
- { lastBlockNumber: lastEscrowHeight, lastEvent: lastEscrowEvent },
246
- { lastBlockNumber: lastSpvVaultHeight, lastEvent: lastSpvVaultEvent }
247
- ];
248
- return lastState;
249
- }
250
- /**
251
- * Sets up event handlers listening for swap events over websocket
252
- *
253
- * @protected
254
- */
255
- async setupPoll(lastState, saveLatestProcessedBlockNumber) {
256
- this.stopped = false;
257
- let func;
258
- func = async () => {
259
- await this.checkEvents(lastState).then(newState => {
260
- lastState = newState;
261
- if (saveLatestProcessedBlockNumber != null)
262
- return saveLatestProcessedBlockNumber(newState);
263
- }).catch(e => {
264
- this.logger.error("setupPoll(): Failed to fetch evm log: ", e);
265
- });
266
- if (this.stopped)
267
- return;
268
- this.timeout = setTimeout(func, this.pollIntervalSeconds * 1000);
269
- };
270
- await func();
271
- }
272
- async init() {
273
- this.setupPoll();
274
- this.stopped = false;
275
- return Promise.resolve();
276
- }
277
- async stop() {
278
- this.stopped = true;
279
- if (this.timeout != null)
280
- clearTimeout(this.timeout);
281
- }
282
- registerListener(cbk) {
283
- this.listeners.push(cbk);
284
- }
285
- unregisterListener(cbk) {
286
- const index = this.listeners.indexOf(cbk);
287
- if (index >= 0) {
288
- this.listeners.splice(index, 1);
289
- return true;
290
- }
291
- return false;
292
- }
293
- }
294
- exports.EVMChainEventsBrowser = EVMChainEventsBrowser;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.EVMChainEventsBrowser = void 0;
4
+ const base_1 = require("@atomiqlabs/base");
5
+ const EVMSwapData_1 = require("../swaps/EVMSwapData");
6
+ const ethers_1 = require("ethers");
7
+ const Utils_1 = require("../../utils/Utils");
8
+ const EVMSpvVaultContract_1 = require("../spv_swap/EVMSpvVaultContract");
9
+ const LOGS_SLIDING_WINDOW_LENGTH = 60;
10
+ /**
11
+ * EVM on-chain event handler for front-end systems without access to fs, uses WS or long-polling to subscribe, might lose
12
+ * out on some events if the network is unreliable, front-end systems should take this into consideration and not
13
+ * rely purely on events
14
+ */
15
+ class EVMChainEventsBrowser {
16
+ constructor(chainInterface, evmSwapContract, evmSpvVaultContract, pollIntervalSeconds = 5) {
17
+ this.listeners = [];
18
+ this.logger = (0, Utils_1.getLogger)("EVMChainEventsBrowser: ");
19
+ this.chainInterface = chainInterface;
20
+ this.provider = chainInterface.provider;
21
+ this.evmSwapContract = evmSwapContract;
22
+ this.evmSpvVaultContract = evmSpvVaultContract;
23
+ this.pollIntervalSeconds = pollIntervalSeconds;
24
+ }
25
+ findInitSwapData(call, escrowHash, claimHandler) {
26
+ if (call.to.toLowerCase() === this.evmSwapContract.contractAddress.toLowerCase()) {
27
+ const result = this.evmSwapContract.parseCalldata(call.input);
28
+ if (result != null && result.name === "initialize") {
29
+ //Found, check correct escrow hash
30
+ const [escrowData, signature, timeout, extraData] = result.args;
31
+ const escrow = EVMSwapData_1.EVMSwapData.deserializeFromStruct(escrowData, claimHandler);
32
+ if ("0x" + escrow.getEscrowHash() === escrowHash) {
33
+ const extraDataHex = (0, ethers_1.hexlify)(extraData);
34
+ if (extraDataHex.length > 2) {
35
+ escrow.setExtraData(extraDataHex.substring(2));
36
+ }
37
+ return escrow;
38
+ }
39
+ }
40
+ }
41
+ for (let _call of call.calls) {
42
+ const found = this.findInitSwapData(_call, escrowHash, claimHandler);
43
+ if (found != null)
44
+ return found;
45
+ }
46
+ return null;
47
+ }
48
+ /**
49
+ * Returns async getter for fetching on-demand initialize event swap data
50
+ *
51
+ * @param event
52
+ * @param claimHandler
53
+ * @private
54
+ * @returns {() => Promise<EVMSwapData>} getter to be passed to InitializeEvent constructor
55
+ */
56
+ getSwapDataGetter(event, claimHandler) {
57
+ return async () => {
58
+ const trace = await this.chainInterface.Transactions.traceTransaction(event.transactionHash);
59
+ if (trace == null)
60
+ return null;
61
+ return this.findInitSwapData(trace, event.args.escrowHash, claimHandler);
62
+ };
63
+ }
64
+ parseInitializeEvent(event) {
65
+ const escrowHash = event.args.escrowHash.substring(2);
66
+ const claimHandlerHex = event.args.claimHandler;
67
+ const claimHandler = this.evmSwapContract.claimHandlersByAddress[claimHandlerHex.toLowerCase()];
68
+ if (claimHandler == null) {
69
+ this.logger.warn("parseInitializeEvent(" + escrowHash + "): Unknown claim handler with claim: " + claimHandlerHex);
70
+ return null;
71
+ }
72
+ const swapType = claimHandler.getType();
73
+ this.logger.debug("InitializeEvent escrowHash: " + escrowHash);
74
+ return new base_1.InitializeEvent(escrowHash, swapType, (0, Utils_1.onceAsync)(this.getSwapDataGetter(event, claimHandler)));
75
+ }
76
+ parseRefundEvent(event) {
77
+ const escrowHash = event.args.escrowHash.substring(2);
78
+ this.logger.debug("RefundEvent escrowHash: " + escrowHash);
79
+ return new base_1.RefundEvent(escrowHash);
80
+ }
81
+ parseClaimEvent(event) {
82
+ const escrowHash = event.args.escrowHash.substring(2);
83
+ const claimHandlerHex = event.args.claimHandler;
84
+ const claimHandler = this.evmSwapContract.claimHandlersByAddress[claimHandlerHex.toLowerCase()];
85
+ if (claimHandler == null) {
86
+ this.logger.warn("parseClaimEvent(" + escrowHash + "): Unknown claim handler with claim: " + claimHandlerHex);
87
+ return null;
88
+ }
89
+ const witnessResult = event.args.witnessResult.substring(2);
90
+ this.logger.debug("ClaimEvent witnessResult: " + witnessResult + " escrowHash: " + escrowHash);
91
+ return new base_1.ClaimEvent(escrowHash, witnessResult);
92
+ }
93
+ parseSpvOpenEvent(event) {
94
+ const owner = event.args.owner;
95
+ const vaultId = event.args.vaultId;
96
+ const btcTxId = Buffer.from(event.args.btcTxHash.substring(2), "hex").reverse().toString("hex");
97
+ const vout = Number(event.args.vout);
98
+ this.logger.debug("SpvOpenEvent owner: " + owner + " vaultId: " + vaultId + " utxo: " + btcTxId + ":" + vout);
99
+ return new base_1.SpvVaultOpenEvent(owner, vaultId, btcTxId, vout);
100
+ }
101
+ parseSpvDepositEvent(event) {
102
+ const [owner, vaultId] = (0, EVMSpvVaultContract_1.unpackOwnerAndVaultId)(event.args.ownerAndVaultId);
103
+ const amounts = [event.args.amount0, event.args.amount1];
104
+ const depositCount = Number(event.args.depositCount);
105
+ this.logger.debug("SpvDepositEvent owner: " + owner + " vaultId: " + vaultId + " depositCount: " + depositCount + " amounts: ", amounts);
106
+ return new base_1.SpvVaultDepositEvent(owner, vaultId, amounts, depositCount);
107
+ }
108
+ parseSpvFrontEvent(event) {
109
+ const [owner, vaultId] = (0, EVMSpvVaultContract_1.unpackOwnerAndVaultId)(event.args.ownerAndVaultId);
110
+ const btcTxId = Buffer.from(event.args.btcTxHash.substring(2), "hex").reverse().toString("hex");
111
+ const recipient = event.args.recipient;
112
+ const executionHash = event.args.executionHash;
113
+ const amounts = [event.args.amount0, event.args.amount1];
114
+ const frontingAddress = event.args.caller;
115
+ this.logger.debug("SpvFrontEvent owner: " + owner + " vaultId: " + vaultId + " btcTxId: " + btcTxId +
116
+ " recipient: " + recipient + " frontedBy: " + frontingAddress + " amounts: ", amounts);
117
+ return new base_1.SpvVaultFrontEvent(owner, vaultId, btcTxId, recipient, executionHash, amounts, frontingAddress);
118
+ }
119
+ parseSpvClaimEvent(event) {
120
+ const [owner, vaultId] = (0, EVMSpvVaultContract_1.unpackOwnerAndVaultId)(event.args.ownerAndVaultId);
121
+ const btcTxId = Buffer.from(event.args.btcTxHash.substring(2), "hex").reverse().toString("hex");
122
+ const recipient = event.args.recipient;
123
+ const executionHash = event.args.executionHash;
124
+ const amounts = [event.args.amount0, event.args.amount1];
125
+ const caller = event.args.caller;
126
+ const frontingAddress = event.args.frontingAddress;
127
+ const withdrawCount = Number(event.args.withdrawCount);
128
+ this.logger.debug("SpvClaimEvent owner: " + owner + " vaultId: " + vaultId + " btcTxId: " + btcTxId + " withdrawCount: " + withdrawCount +
129
+ " recipient: " + recipient + " frontedBy: " + frontingAddress + " claimedBy: " + caller + " amounts: ", amounts);
130
+ return new base_1.SpvVaultClaimEvent(owner, vaultId, btcTxId, recipient, executionHash, amounts, caller, frontingAddress, withdrawCount);
131
+ }
132
+ parseSpvCloseEvent(event) {
133
+ const btcTxId = Buffer.from(event.args.btcTxHash.substring(2), "hex").reverse().toString("hex");
134
+ return new base_1.SpvVaultCloseEvent(event.args.owner, event.args.vaultId, btcTxId, event.args.error);
135
+ }
136
+ /**
137
+ * Processes event as received from the chain, parses it & calls event listeners
138
+ *
139
+ * @param events
140
+ * @param currentBlock
141
+ * @protected
142
+ */
143
+ async processEvents(events, currentBlock) {
144
+ const parsedEvents = [];
145
+ for (let event of events) {
146
+ let parsedEvent;
147
+ switch (event.eventName) {
148
+ case "Claim":
149
+ parsedEvent = this.parseClaimEvent(event);
150
+ break;
151
+ case "Refund":
152
+ parsedEvent = this.parseRefundEvent(event);
153
+ break;
154
+ case "Initialize":
155
+ parsedEvent = this.parseInitializeEvent(event);
156
+ break;
157
+ case "Opened":
158
+ parsedEvent = this.parseSpvOpenEvent(event);
159
+ break;
160
+ case "Deposited":
161
+ parsedEvent = this.parseSpvDepositEvent(event);
162
+ break;
163
+ case "Fronted":
164
+ parsedEvent = this.parseSpvFrontEvent(event);
165
+ break;
166
+ case "Claimed":
167
+ parsedEvent = this.parseSpvClaimEvent(event);
168
+ break;
169
+ case "Closed":
170
+ parsedEvent = this.parseSpvCloseEvent(event);
171
+ break;
172
+ }
173
+ const timestamp = event.blockNumber === currentBlock.number ? currentBlock.timestamp : await this.chainInterface.Blocks.getBlockTime(event.blockNumber);
174
+ parsedEvent.meta = {
175
+ blockTime: timestamp,
176
+ txId: event.transactionHash,
177
+ timestamp //Maybe deprecated
178
+ };
179
+ parsedEvents.push(parsedEvent);
180
+ }
181
+ for (let listener of this.listeners) {
182
+ await listener(parsedEvents);
183
+ }
184
+ }
185
+ async checkEventsEcrowManager(currentBlock, lastProcessedEvent, lastBlockNumber) {
186
+ lastBlockNumber ?? (lastBlockNumber = currentBlock.number);
187
+ // this.logger.debug(`checkEvents(EscrowManager): Requesting logs: ${lastBlockNumber}...${currentBlock.number}`);
188
+ let events = await this.evmSwapContract.Events.getContractBlockEvents(["Initialize", "Claim", "Refund"], [], lastBlockNumber, currentBlock.number);
189
+ if (lastProcessedEvent != null) {
190
+ const latestProcessedEventIndex = events.findIndex(val => val.blockHash === lastProcessedEvent.blockHash && val.index === lastProcessedEvent.logIndex);
191
+ if (latestProcessedEventIndex !== -1) {
192
+ events.splice(0, latestProcessedEventIndex + 1);
193
+ this.logger.debug("checkEvents(EscrowManager): Splicing processed events, resulting size: " + events.length);
194
+ }
195
+ }
196
+ if (events.length > 0) {
197
+ await this.processEvents(events, currentBlock);
198
+ const lastProcessed = events[events.length - 1];
199
+ lastProcessedEvent = {
200
+ blockHash: lastProcessed.blockHash,
201
+ logIndex: lastProcessed.index
202
+ };
203
+ if (lastProcessed.blockNumber > lastBlockNumber)
204
+ lastBlockNumber = lastProcessed.blockNumber;
205
+ }
206
+ else if (currentBlock.number - lastBlockNumber > LOGS_SLIDING_WINDOW_LENGTH) {
207
+ lastProcessedEvent = null;
208
+ lastBlockNumber = currentBlock.number - LOGS_SLIDING_WINDOW_LENGTH;
209
+ }
210
+ return [lastProcessedEvent, lastBlockNumber];
211
+ }
212
+ async checkEventsSpvVaults(currentBlock, lastProcessedEvent, lastBlockNumber) {
213
+ lastBlockNumber ?? (lastBlockNumber = currentBlock.number);
214
+ // this.logger.debug(`checkEvents(SpvVaults): Requesting logs: ${lastBlockNumber}...${currentBlock.number}`);
215
+ let events = await this.evmSpvVaultContract.Events.getContractBlockEvents(["Opened", "Deposited", "Closed", "Fronted", "Claimed"], [], lastBlockNumber, currentBlock.number);
216
+ if (lastProcessedEvent != null) {
217
+ const latestProcessedEventIndex = events.findIndex(val => val.blockHash === lastProcessedEvent.blockHash && val.index === lastProcessedEvent.logIndex);
218
+ if (latestProcessedEventIndex !== -1) {
219
+ events.splice(0, latestProcessedEventIndex + 1);
220
+ this.logger.debug("checkEvents(SpvVaults): Splicing processed events, resulting size: " + events.length);
221
+ }
222
+ }
223
+ if (events.length > 0) {
224
+ await this.processEvents(events, currentBlock);
225
+ const lastProcessed = events[events.length - 1];
226
+ lastProcessedEvent = {
227
+ blockHash: lastProcessed.blockHash,
228
+ logIndex: lastProcessed.index
229
+ };
230
+ if (lastProcessed.blockNumber > lastBlockNumber)
231
+ lastBlockNumber = lastProcessed.blockNumber;
232
+ }
233
+ else if (currentBlock.number - lastBlockNumber > LOGS_SLIDING_WINDOW_LENGTH) {
234
+ lastProcessedEvent = null;
235
+ lastBlockNumber = currentBlock.number - LOGS_SLIDING_WINDOW_LENGTH;
236
+ }
237
+ return [lastProcessedEvent, lastBlockNumber];
238
+ }
239
+ async checkEvents(lastState) {
240
+ lastState ?? (lastState = []);
241
+ const currentBlock = await this.provider.getBlock(this.chainInterface.config.safeBlockTag, false);
242
+ const [lastEscrowEvent, lastEscrowHeight] = await this.checkEventsEcrowManager(currentBlock, lastState?.[0]?.lastEvent, lastState?.[0]?.lastBlockNumber);
243
+ const [lastSpvVaultEvent, lastSpvVaultHeight] = await this.checkEventsSpvVaults(currentBlock, lastState?.[1]?.lastEvent, lastState?.[1]?.lastBlockNumber);
244
+ lastState = [
245
+ { lastBlockNumber: lastEscrowHeight, lastEvent: lastEscrowEvent },
246
+ { lastBlockNumber: lastSpvVaultHeight, lastEvent: lastSpvVaultEvent }
247
+ ];
248
+ return lastState;
249
+ }
250
+ /**
251
+ * Sets up event handlers listening for swap events over websocket
252
+ *
253
+ * @protected
254
+ */
255
+ async setupPoll(lastState, saveLatestProcessedBlockNumber) {
256
+ this.stopped = false;
257
+ let func;
258
+ func = async () => {
259
+ await this.checkEvents(lastState).then(newState => {
260
+ lastState = newState;
261
+ if (saveLatestProcessedBlockNumber != null)
262
+ return saveLatestProcessedBlockNumber(newState);
263
+ }).catch(e => {
264
+ this.logger.error("setupPoll(): Failed to fetch evm log: ", e);
265
+ });
266
+ if (this.stopped)
267
+ return;
268
+ this.timeout = setTimeout(func, this.pollIntervalSeconds * 1000);
269
+ };
270
+ await func();
271
+ }
272
+ async init() {
273
+ this.setupPoll();
274
+ this.stopped = false;
275
+ return Promise.resolve();
276
+ }
277
+ async stop() {
278
+ this.stopped = true;
279
+ if (this.timeout != null)
280
+ clearTimeout(this.timeout);
281
+ }
282
+ registerListener(cbk) {
283
+ this.listeners.push(cbk);
284
+ }
285
+ unregisterListener(cbk) {
286
+ const index = this.listeners.indexOf(cbk);
287
+ if (index >= 0) {
288
+ this.listeners.splice(index, 1);
289
+ return true;
290
+ }
291
+ return false;
292
+ }
293
+ }
294
+ exports.EVMChainEventsBrowser = EVMChainEventsBrowser;