@atomiqlabs/chain-evm 1.0.0-dev.89 → 1.0.0-dev.93

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 (185) hide show
  1. package/LICENSE +201 -201
  2. package/dist/chains/botanix/BotanixChainType.d.ts +13 -13
  3. package/dist/chains/botanix/BotanixChainType.js +2 -2
  4. package/dist/chains/botanix/BotanixInitializer.d.ts +30 -30
  5. package/dist/chains/botanix/BotanixInitializer.js +125 -122
  6. package/dist/chains/citrea/CitreaBtcRelay.d.ts +21 -21
  7. package/dist/chains/citrea/CitreaBtcRelay.js +43 -43
  8. package/dist/chains/citrea/CitreaChainType.d.ts +13 -13
  9. package/dist/chains/citrea/CitreaChainType.js +2 -2
  10. package/dist/chains/citrea/CitreaFees.d.ts +29 -29
  11. package/dist/chains/citrea/CitreaFees.js +67 -67
  12. package/dist/chains/citrea/CitreaInitializer.d.ts +30 -30
  13. package/dist/chains/citrea/CitreaInitializer.js +132 -129
  14. package/dist/chains/citrea/CitreaSpvVaultContract.d.ts +15 -15
  15. package/dist/chains/citrea/CitreaSpvVaultContract.js +74 -74
  16. package/dist/chains/citrea/CitreaSwapContract.d.ts +22 -22
  17. package/dist/chains/citrea/CitreaSwapContract.js +96 -96
  18. package/dist/chains/citrea/CitreaTokens.d.ts +9 -9
  19. package/dist/chains/citrea/CitreaTokens.js +20 -20
  20. package/dist/evm/btcrelay/BtcRelayAbi.d.ts +198 -198
  21. package/dist/evm/btcrelay/BtcRelayAbi.js +261 -261
  22. package/dist/evm/btcrelay/BtcRelayTypechain.d.ts +172 -172
  23. package/dist/evm/btcrelay/BtcRelayTypechain.js +2 -2
  24. package/dist/evm/btcrelay/EVMBtcRelay.d.ts +197 -197
  25. package/dist/evm/btcrelay/EVMBtcRelay.js +435 -435
  26. package/dist/evm/btcrelay/headers/EVMBtcHeader.d.ts +33 -33
  27. package/dist/evm/btcrelay/headers/EVMBtcHeader.js +84 -84
  28. package/dist/evm/btcrelay/headers/EVMBtcStoredHeader.d.ts +56 -56
  29. package/dist/evm/btcrelay/headers/EVMBtcStoredHeader.js +123 -123
  30. package/dist/evm/chain/EVMChainInterface.d.ts +54 -51
  31. package/dist/evm/chain/EVMChainInterface.js +89 -89
  32. package/dist/evm/chain/EVMModule.d.ts +9 -9
  33. package/dist/evm/chain/EVMModule.js +13 -13
  34. package/dist/evm/chain/modules/ERC20Abi.d.ts +168 -168
  35. package/dist/evm/chain/modules/ERC20Abi.js +225 -225
  36. package/dist/evm/chain/modules/EVMAddresses.d.ts +10 -10
  37. package/dist/evm/chain/modules/EVMAddresses.js +30 -30
  38. package/dist/evm/chain/modules/EVMBlocks.d.ts +20 -20
  39. package/dist/evm/chain/modules/EVMBlocks.js +64 -64
  40. package/dist/evm/chain/modules/EVMEvents.d.ts +46 -46
  41. package/dist/evm/chain/modules/EVMEvents.js +151 -137
  42. package/dist/evm/chain/modules/EVMFees.d.ts +36 -36
  43. package/dist/evm/chain/modules/EVMFees.js +74 -74
  44. package/dist/evm/chain/modules/EVMSignatures.d.ts +29 -29
  45. package/dist/evm/chain/modules/EVMSignatures.js +68 -68
  46. package/dist/evm/chain/modules/EVMTokens.d.ts +70 -70
  47. package/dist/evm/chain/modules/EVMTokens.js +142 -142
  48. package/dist/evm/chain/modules/EVMTransactions.d.ts +94 -94
  49. package/dist/evm/chain/modules/EVMTransactions.js +288 -286
  50. package/dist/evm/contract/EVMContractBase.d.ts +22 -22
  51. package/dist/evm/contract/EVMContractBase.js +34 -34
  52. package/dist/evm/contract/EVMContractModule.d.ts +8 -8
  53. package/dist/evm/contract/EVMContractModule.js +11 -11
  54. package/dist/evm/contract/modules/EVMContractEvents.d.ts +42 -42
  55. package/dist/evm/contract/modules/EVMContractEvents.js +75 -75
  56. package/dist/evm/events/EVMChainEvents.d.ts +22 -22
  57. package/dist/evm/events/EVMChainEvents.js +69 -69
  58. package/dist/evm/events/EVMChainEventsBrowser.d.ts +102 -102
  59. package/dist/evm/events/EVMChainEventsBrowser.js +412 -412
  60. package/dist/evm/providers/JsonRpcProviderWithRetries.d.ts +16 -16
  61. package/dist/evm/providers/JsonRpcProviderWithRetries.js +27 -27
  62. package/dist/evm/providers/ReconnectingWebSocketProvider.d.ts +22 -22
  63. package/dist/evm/providers/ReconnectingWebSocketProvider.js +91 -91
  64. package/dist/evm/providers/SocketProvider.d.ts +111 -111
  65. package/dist/evm/providers/SocketProvider.js +336 -336
  66. package/dist/evm/providers/WebSocketProviderWithRetries.d.ts +17 -17
  67. package/dist/evm/providers/WebSocketProviderWithRetries.js +23 -23
  68. package/dist/evm/spv_swap/EVMSpvVaultContract.d.ts +107 -79
  69. package/dist/evm/spv_swap/EVMSpvVaultContract.js +578 -482
  70. package/dist/evm/spv_swap/EVMSpvVaultData.d.ts +40 -39
  71. package/dist/evm/spv_swap/EVMSpvVaultData.js +184 -180
  72. package/dist/evm/spv_swap/EVMSpvWithdrawalData.d.ts +19 -19
  73. package/dist/evm/spv_swap/EVMSpvWithdrawalData.js +55 -55
  74. package/dist/evm/spv_swap/SpvVaultContractAbi.d.ts +91 -91
  75. package/dist/evm/spv_swap/SpvVaultContractAbi.js +849 -849
  76. package/dist/evm/spv_swap/SpvVaultContractTypechain.d.ts +450 -450
  77. package/dist/evm/spv_swap/SpvVaultContractTypechain.js +2 -2
  78. package/dist/evm/swaps/EVMSwapContract.d.ts +199 -193
  79. package/dist/evm/swaps/EVMSwapContract.js +394 -378
  80. package/dist/evm/swaps/EVMSwapData.d.ts +66 -66
  81. package/dist/evm/swaps/EVMSwapData.js +260 -260
  82. package/dist/evm/swaps/EVMSwapModule.d.ts +9 -9
  83. package/dist/evm/swaps/EVMSwapModule.js +11 -11
  84. package/dist/evm/swaps/EscrowManagerAbi.d.ts +120 -120
  85. package/dist/evm/swaps/EscrowManagerAbi.js +985 -985
  86. package/dist/evm/swaps/EscrowManagerTypechain.d.ts +475 -475
  87. package/dist/evm/swaps/EscrowManagerTypechain.js +2 -2
  88. package/dist/evm/swaps/handlers/IHandler.d.ts +13 -13
  89. package/dist/evm/swaps/handlers/IHandler.js +2 -2
  90. package/dist/evm/swaps/handlers/claim/ClaimHandlers.d.ts +10 -10
  91. package/dist/evm/swaps/handlers/claim/ClaimHandlers.js +13 -13
  92. package/dist/evm/swaps/handlers/claim/HashlockClaimHandler.d.ts +20 -20
  93. package/dist/evm/swaps/handlers/claim/HashlockClaimHandler.js +39 -39
  94. package/dist/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.d.ts +24 -24
  95. package/dist/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.js +59 -59
  96. package/dist/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.d.ts +25 -25
  97. package/dist/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.js +51 -51
  98. package/dist/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.d.ts +21 -21
  99. package/dist/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.js +28 -28
  100. package/dist/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.d.ts +48 -48
  101. package/dist/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.js +63 -63
  102. package/dist/evm/swaps/handlers/refund/TimelockRefundHandler.d.ts +17 -17
  103. package/dist/evm/swaps/handlers/refund/TimelockRefundHandler.js +28 -28
  104. package/dist/evm/swaps/modules/EVMLpVault.d.ts +69 -69
  105. package/dist/evm/swaps/modules/EVMLpVault.js +134 -134
  106. package/dist/evm/swaps/modules/EVMSwapClaim.d.ts +54 -54
  107. package/dist/evm/swaps/modules/EVMSwapClaim.js +137 -137
  108. package/dist/evm/swaps/modules/EVMSwapInit.d.ts +88 -88
  109. package/dist/evm/swaps/modules/EVMSwapInit.js +274 -274
  110. package/dist/evm/swaps/modules/EVMSwapRefund.d.ts +62 -62
  111. package/dist/evm/swaps/modules/EVMSwapRefund.js +167 -167
  112. package/dist/evm/typechain/common.d.ts +50 -50
  113. package/dist/evm/typechain/common.js +2 -2
  114. package/dist/evm/wallet/EVMBrowserSigner.d.ts +5 -5
  115. package/dist/evm/wallet/EVMBrowserSigner.js +11 -11
  116. package/dist/evm/wallet/EVMPersistentSigner.d.ts +29 -29
  117. package/dist/evm/wallet/EVMPersistentSigner.js +230 -230
  118. package/dist/evm/wallet/EVMSigner.d.ts +11 -11
  119. package/dist/evm/wallet/EVMSigner.js +24 -24
  120. package/dist/index.d.ts +44 -44
  121. package/dist/index.js +60 -60
  122. package/dist/utils/Utils.d.ts +19 -19
  123. package/dist/utils/Utils.js +98 -98
  124. package/package.json +39 -39
  125. package/src/chains/botanix/BotanixChainType.ts +28 -28
  126. package/src/chains/botanix/BotanixInitializer.ts +175 -171
  127. package/src/chains/citrea/CitreaBtcRelay.ts +57 -57
  128. package/src/chains/citrea/CitreaChainType.ts +28 -28
  129. package/src/chains/citrea/CitreaFees.ts +77 -77
  130. package/src/chains/citrea/CitreaInitializer.ts +182 -178
  131. package/src/chains/citrea/CitreaSpvVaultContract.ts +75 -75
  132. package/src/chains/citrea/CitreaSwapContract.ts +102 -102
  133. package/src/chains/citrea/CitreaTokens.ts +21 -21
  134. package/src/evm/btcrelay/BtcRelayAbi.ts +258 -258
  135. package/src/evm/btcrelay/BtcRelayTypechain.ts +371 -371
  136. package/src/evm/btcrelay/EVMBtcRelay.ts +537 -537
  137. package/src/evm/btcrelay/headers/EVMBtcHeader.ts +109 -109
  138. package/src/evm/btcrelay/headers/EVMBtcStoredHeader.ts +152 -152
  139. package/src/evm/chain/EVMChainInterface.ts +158 -155
  140. package/src/evm/chain/EVMModule.ts +21 -21
  141. package/src/evm/chain/modules/ERC20Abi.ts +222 -222
  142. package/src/evm/chain/modules/EVMAddresses.ts +28 -28
  143. package/src/evm/chain/modules/EVMBlocks.ts +75 -75
  144. package/src/evm/chain/modules/EVMEvents.ts +182 -156
  145. package/src/evm/chain/modules/EVMFees.ts +104 -104
  146. package/src/evm/chain/modules/EVMSignatures.ts +76 -76
  147. package/src/evm/chain/modules/EVMTokens.ts +155 -155
  148. package/src/evm/chain/modules/EVMTransactions.ts +327 -325
  149. package/src/evm/contract/EVMContractBase.ts +63 -63
  150. package/src/evm/contract/EVMContractModule.ts +16 -16
  151. package/src/evm/contract/modules/EVMContractEvents.ts +102 -102
  152. package/src/evm/events/EVMChainEvents.ts +82 -82
  153. package/src/evm/events/EVMChainEventsBrowser.ts +533 -533
  154. package/src/evm/providers/JsonRpcProviderWithRetries.ts +33 -33
  155. package/src/evm/providers/ReconnectingWebSocketProvider.ts +106 -106
  156. package/src/evm/providers/SocketProvider.ts +371 -371
  157. package/src/evm/providers/WebSocketProviderWithRetries.ts +34 -34
  158. package/src/evm/spv_swap/EVMSpvVaultContract.ts +723 -615
  159. package/src/evm/spv_swap/EVMSpvVaultData.ts +228 -224
  160. package/src/evm/spv_swap/EVMSpvWithdrawalData.ts +70 -70
  161. package/src/evm/spv_swap/SpvVaultContractAbi.ts +846 -846
  162. package/src/evm/spv_swap/SpvVaultContractTypechain.ts +685 -685
  163. package/src/evm/swaps/EVMSwapContract.ts +621 -600
  164. package/src/evm/swaps/EVMSwapData.ts +378 -378
  165. package/src/evm/swaps/EVMSwapModule.ts +16 -16
  166. package/src/evm/swaps/EscrowManagerAbi.ts +982 -982
  167. package/src/evm/swaps/EscrowManagerTypechain.ts +723 -723
  168. package/src/evm/swaps/handlers/IHandler.ts +17 -17
  169. package/src/evm/swaps/handlers/claim/ClaimHandlers.ts +20 -20
  170. package/src/evm/swaps/handlers/claim/HashlockClaimHandler.ts +46 -46
  171. package/src/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.ts +82 -82
  172. package/src/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.ts +76 -76
  173. package/src/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.ts +46 -46
  174. package/src/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.ts +115 -115
  175. package/src/evm/swaps/handlers/refund/TimelockRefundHandler.ts +37 -37
  176. package/src/evm/swaps/modules/EVMLpVault.ts +154 -154
  177. package/src/evm/swaps/modules/EVMSwapClaim.ts +172 -172
  178. package/src/evm/swaps/modules/EVMSwapInit.ts +328 -328
  179. package/src/evm/swaps/modules/EVMSwapRefund.ts +229 -229
  180. package/src/evm/typechain/common.ts +131 -131
  181. package/src/evm/wallet/EVMBrowserSigner.ts +11 -11
  182. package/src/evm/wallet/EVMPersistentSigner.ts +307 -307
  183. package/src/evm/wallet/EVMSigner.ts +31 -31
  184. package/src/index.ts +53 -53
  185. package/src/utils/Utils.ts +111 -111
@@ -1,224 +1,228 @@
1
- import {
2
- SpvVaultClaimEvent,
3
- SpvVaultCloseEvent,
4
- SpvVaultData, SpvVaultDepositEvent, SpvVaultOpenEvent,
5
- SpvVaultTokenBalance,
6
- SpvVaultTokenData
7
- } from "@atomiqlabs/base";
8
- import {Buffer} from "buffer";
9
- import { EVMSpvWithdrawalData } from "./EVMSpvWithdrawalData";
10
- import {
11
- SpvVaultParametersStruct,
12
- SpvVaultStateStruct
13
- } from "./SpvVaultContractTypechain";
14
- import {hexlify, randomBytes} from "ethers";
15
- import {AbiCoder, keccak256} from "ethers";
16
- import {EVMAddresses} from "../chain/modules/EVMAddresses";
17
- import type {AddressLike, BigNumberish, BytesLike} from "ethers/lib.esm";
18
-
19
- export function getVaultParamsCommitment(vaultParams: SpvVaultParametersStruct) {
20
- return keccak256(AbiCoder.defaultAbiCoder().encode(
21
- ["address", "address", "address", "uint192", "uint192", "uint256"],
22
- [vaultParams.btcRelayContract, vaultParams.token0, vaultParams.token1, vaultParams.token0Multiplier, vaultParams.token1Multiplier, vaultParams.confirmations]
23
- ));
24
- }
25
-
26
- export class EVMSpvVaultData extends SpvVaultData<EVMSpvWithdrawalData> {
27
-
28
- readonly owner: string;
29
- readonly vaultId: bigint;
30
-
31
- readonly relayContract: string;
32
- readonly token0: {
33
- token: string,
34
- multiplier: bigint,
35
- rawAmount: bigint
36
- }
37
- readonly token1: {
38
- token: string,
39
- multiplier: bigint,
40
- rawAmount: bigint
41
- };
42
- readonly initialUtxo: string;
43
- utxo: string;
44
- readonly confirmations: number;
45
- withdrawCount: number;
46
- depositCount: number;
47
-
48
- constructor(owner: string, vaultId: bigint, state: SpvVaultStateStruct, params: SpvVaultParametersStruct, initialUtxo?: string);
49
- constructor(serializedObj: any);
50
- constructor(ownerOrObj: string | any, vaultId?: bigint, state?: SpvVaultStateStruct, params?: SpvVaultParametersStruct, initialUtxo?: string) {
51
- super();
52
- if(typeof(ownerOrObj) === "string") {
53
- this.owner = ownerOrObj;
54
- this.vaultId = vaultId;
55
- this.relayContract = params.btcRelayContract as string;
56
- this.token0 = {
57
- token: params.token0 as string,
58
- multiplier: BigInt(params.token0Multiplier),
59
- rawAmount: BigInt(state.token0Amount)
60
- };
61
- this.token1 = {
62
- token: params.token1 as string,
63
- multiplier: BigInt(params.token1Multiplier),
64
- rawAmount: BigInt(state.token1Amount)
65
- };
66
- const txHash = Buffer.from(hexlify(state.utxoTxHash).substring(2), "hex");
67
- this.utxo = txHash.reverse().toString("hex")+":"+BigInt(state.utxoVout).toString(10);
68
- this.confirmations = Number(params.confirmations);
69
- this.withdrawCount = Number(state.withdrawCount);
70
- this.depositCount = Number(state.depositCount);
71
- this.initialUtxo = initialUtxo;
72
- } else {
73
- this.owner = ownerOrObj.owner;
74
- this.vaultId = BigInt(ownerOrObj.vaultId);
75
- this.relayContract = ownerOrObj.relayContract;
76
- this.token0 = {
77
- token: ownerOrObj.token0.token,
78
- multiplier: BigInt(ownerOrObj.token0.multiplier),
79
- rawAmount: BigInt(ownerOrObj.token0.rawAmount)
80
- }
81
- this.token1 = {
82
- token: ownerOrObj.token1.token,
83
- multiplier: BigInt(ownerOrObj.token1.multiplier),
84
- rawAmount: BigInt(ownerOrObj.token1.rawAmount)
85
- };
86
- this.utxo = ownerOrObj.utxo;
87
- this.confirmations = ownerOrObj.confirmations;
88
- this.withdrawCount = ownerOrObj.withdrawCount;
89
- this.depositCount = ownerOrObj.depositCount;
90
- this.initialUtxo = ownerOrObj.initialUtxo;
91
- }
92
- }
93
-
94
- getBalances(): SpvVaultTokenBalance[] {
95
- return [
96
- {...this.token0, scaledAmount: this.token0.rawAmount * this.token0.multiplier},
97
- {...this.token1, scaledAmount: this.token1.rawAmount * this.token1.multiplier}
98
- ];
99
- }
100
-
101
- getConfirmations(): number {
102
- return this.confirmations;
103
- }
104
-
105
- getOwner(): string {
106
- return this.owner;
107
- }
108
-
109
- getTokenData(): SpvVaultTokenData[] {
110
- return [this.token0, this.token1];
111
- }
112
-
113
- getUtxo(): string {
114
- return this.isOpened() ? this.utxo : this.initialUtxo;
115
- }
116
-
117
- getVaultId(): bigint {
118
- return this.vaultId;
119
- }
120
-
121
- getWithdrawalCount(): number {
122
- return this.withdrawCount;
123
- }
124
-
125
- isOpened(): boolean {
126
- return this.utxo!=="0000000000000000000000000000000000000000000000000000000000000000:0";
127
- }
128
-
129
- serialize(): any {
130
- return {
131
- type: "EVM",
132
- owner: this.owner,
133
- vaultId: this.vaultId.toString(10),
134
- relayContract: this.relayContract,
135
- token0: {
136
- token: this.token0.token,
137
- multiplier: this.token0.multiplier.toString(10),
138
- rawAmount: this.token0.rawAmount.toString(10)
139
- },
140
- token1: {
141
- token: this.token1.token,
142
- multiplier: this.token1.multiplier.toString(10),
143
- rawAmount: this.token1.rawAmount.toString(10)
144
- },
145
- utxo: this.utxo,
146
- confirmations: this.confirmations,
147
- withdrawCount: this.withdrawCount,
148
- depositCount: this.depositCount,
149
- initialUtxo: this.initialUtxo
150
- }
151
- }
152
-
153
- updateState(withdrawalTxOrEvent: SpvVaultClaimEvent | SpvVaultCloseEvent | SpvVaultOpenEvent | SpvVaultDepositEvent | EVMSpvWithdrawalData): void {
154
- if(withdrawalTxOrEvent instanceof SpvVaultClaimEvent) {
155
- if(withdrawalTxOrEvent.withdrawCount <= this.withdrawCount) return;
156
- this.token0.rawAmount -= withdrawalTxOrEvent.amounts[0];
157
- this.token1.rawAmount -= withdrawalTxOrEvent.amounts[1];
158
- this.withdrawCount = withdrawalTxOrEvent.withdrawCount;
159
- this.utxo = withdrawalTxOrEvent.btcTxId+":0";
160
- }
161
- if(withdrawalTxOrEvent instanceof SpvVaultCloseEvent) {
162
- this.token0.rawAmount = 0n;
163
- this.token1.rawAmount = 0n;
164
- this.utxo = "0000000000000000000000000000000000000000000000000000000000000000:0";
165
- }
166
- if(withdrawalTxOrEvent instanceof SpvVaultOpenEvent) {
167
- if(this.isOpened()) return;
168
- this.utxo = withdrawalTxOrEvent.btcTxId+":"+withdrawalTxOrEvent.vout;
169
- }
170
- if(withdrawalTxOrEvent instanceof SpvVaultDepositEvent) {
171
- if(withdrawalTxOrEvent.depositCount <= this.depositCount) return;
172
- this.token0.rawAmount += withdrawalTxOrEvent.amounts[0];
173
- this.token1.rawAmount += withdrawalTxOrEvent.amounts[1];
174
- this.depositCount = withdrawalTxOrEvent.depositCount;
175
- }
176
- if(withdrawalTxOrEvent instanceof EVMSpvWithdrawalData) {
177
- if(withdrawalTxOrEvent.getSpentVaultUtxo()!==this.utxo) return;
178
- const amounts = withdrawalTxOrEvent.getTotalOutput();
179
- this.token0.rawAmount -= amounts[0];
180
- this.token1.rawAmount -= amounts[1];
181
- this.withdrawCount++;
182
- this.utxo = withdrawalTxOrEvent.btcTx.txid+":0";
183
- }
184
- }
185
-
186
- getDepositCount(): number {
187
- return this.depositCount;
188
- }
189
-
190
- getVaultParamsStruct(): SpvVaultParametersStruct {
191
- return {
192
- btcRelayContract: this.relayContract,
193
- token0: this.token0.token,
194
- token1: this.token1.token,
195
- token0Multiplier: this.token0.multiplier,
196
- token1Multiplier: this.token1.multiplier,
197
- confirmations: this.confirmations
198
- }
199
- }
200
-
201
- static randomVault(): EVMSpvVaultData {
202
- const spvVaultParams = {
203
- btcRelayContract: EVMAddresses.randomAddress(),
204
- token0: EVMAddresses.randomAddress(),
205
- token1: EVMAddresses.randomAddress(),
206
- token0Multiplier: 1n,
207
- token1Multiplier: 1n,
208
- confirmations: 3n,
209
- }
210
- return new EVMSpvVaultData(EVMAddresses.randomAddress(), 0n, {
211
- spvVaultParametersCommitment: getVaultParamsCommitment(spvVaultParams),
212
- utxoTxHash: randomBytes(32),
213
- utxoVout: 0n,
214
- openBlockheight: 0n,
215
- withdrawCount: 0n,
216
- depositCount: 0n,
217
- token0Amount: 0n,
218
- token1Amount: 0n
219
- }, spvVaultParams);
220
- }
221
-
222
- }
223
-
224
- SpvVaultData.deserializers["EVM"] = EVMSpvVaultData;
1
+ import {
2
+ SpvVaultClaimEvent,
3
+ SpvVaultCloseEvent,
4
+ SpvVaultData, SpvVaultDepositEvent, SpvVaultOpenEvent,
5
+ SpvVaultTokenBalance,
6
+ SpvVaultTokenData
7
+ } from "@atomiqlabs/base";
8
+ import {Buffer} from "buffer";
9
+ import { EVMSpvWithdrawalData } from "./EVMSpvWithdrawalData";
10
+ import {
11
+ SpvVaultParametersStruct,
12
+ SpvVaultStateStruct
13
+ } from "./SpvVaultContractTypechain";
14
+ import {hexlify, randomBytes} from "ethers";
15
+ import {AbiCoder, keccak256} from "ethers";
16
+ import {EVMAddresses} from "../chain/modules/EVMAddresses";
17
+ import type {AddressLike, BigNumberish, BytesLike} from "ethers/lib.esm";
18
+
19
+ export function getVaultParamsCommitment(vaultParams: SpvVaultParametersStruct) {
20
+ return keccak256(AbiCoder.defaultAbiCoder().encode(
21
+ ["address", "address", "address", "uint192", "uint192", "uint256"],
22
+ [vaultParams.btcRelayContract, vaultParams.token0, vaultParams.token1, vaultParams.token0Multiplier, vaultParams.token1Multiplier, vaultParams.confirmations]
23
+ ));
24
+ }
25
+
26
+ export function getVaultUtxoFromState(state: SpvVaultStateStruct): string {
27
+ const txHash = Buffer.from(hexlify(state.utxoTxHash).substring(2), "hex");
28
+ return txHash.reverse().toString("hex")+":"+BigInt(state.utxoVout).toString(10);
29
+ }
30
+
31
+ export class EVMSpvVaultData extends SpvVaultData<EVMSpvWithdrawalData> {
32
+
33
+ readonly owner: string;
34
+ readonly vaultId: bigint;
35
+
36
+ readonly relayContract: string;
37
+ readonly token0: {
38
+ token: string,
39
+ multiplier: bigint,
40
+ rawAmount: bigint
41
+ }
42
+ readonly token1: {
43
+ token: string,
44
+ multiplier: bigint,
45
+ rawAmount: bigint
46
+ };
47
+ readonly initialUtxo: string;
48
+ utxo: string;
49
+ readonly confirmations: number;
50
+ withdrawCount: number;
51
+ depositCount: number;
52
+
53
+ constructor(owner: string, vaultId: bigint, state: SpvVaultStateStruct, params: SpvVaultParametersStruct, initialUtxo?: string);
54
+ constructor(serializedObj: any);
55
+ constructor(ownerOrObj: string | any, vaultId?: bigint, state?: SpvVaultStateStruct, params?: SpvVaultParametersStruct, initialUtxo?: string) {
56
+ super();
57
+ if(typeof(ownerOrObj) === "string") {
58
+ this.owner = ownerOrObj;
59
+ this.vaultId = vaultId;
60
+ this.relayContract = params.btcRelayContract as string;
61
+ this.token0 = {
62
+ token: params.token0 as string,
63
+ multiplier: BigInt(params.token0Multiplier),
64
+ rawAmount: BigInt(state.token0Amount)
65
+ };
66
+ this.token1 = {
67
+ token: params.token1 as string,
68
+ multiplier: BigInt(params.token1Multiplier),
69
+ rawAmount: BigInt(state.token1Amount)
70
+ };
71
+ this.utxo = getVaultUtxoFromState(state);
72
+ this.confirmations = Number(params.confirmations);
73
+ this.withdrawCount = Number(state.withdrawCount);
74
+ this.depositCount = Number(state.depositCount);
75
+ this.initialUtxo = initialUtxo;
76
+ } else {
77
+ this.owner = ownerOrObj.owner;
78
+ this.vaultId = BigInt(ownerOrObj.vaultId);
79
+ this.relayContract = ownerOrObj.relayContract;
80
+ this.token0 = {
81
+ token: ownerOrObj.token0.token,
82
+ multiplier: BigInt(ownerOrObj.token0.multiplier),
83
+ rawAmount: BigInt(ownerOrObj.token0.rawAmount)
84
+ }
85
+ this.token1 = {
86
+ token: ownerOrObj.token1.token,
87
+ multiplier: BigInt(ownerOrObj.token1.multiplier),
88
+ rawAmount: BigInt(ownerOrObj.token1.rawAmount)
89
+ };
90
+ this.utxo = ownerOrObj.utxo;
91
+ this.confirmations = ownerOrObj.confirmations;
92
+ this.withdrawCount = ownerOrObj.withdrawCount;
93
+ this.depositCount = ownerOrObj.depositCount;
94
+ this.initialUtxo = ownerOrObj.initialUtxo;
95
+ }
96
+ }
97
+
98
+ getBalances(): SpvVaultTokenBalance[] {
99
+ return [
100
+ {...this.token0, scaledAmount: this.token0.rawAmount * this.token0.multiplier},
101
+ {...this.token1, scaledAmount: this.token1.rawAmount * this.token1.multiplier}
102
+ ];
103
+ }
104
+
105
+ getConfirmations(): number {
106
+ return this.confirmations;
107
+ }
108
+
109
+ getOwner(): string {
110
+ return this.owner;
111
+ }
112
+
113
+ getTokenData(): SpvVaultTokenData[] {
114
+ return [this.token0, this.token1];
115
+ }
116
+
117
+ getUtxo(): string {
118
+ return this.isOpened() ? this.utxo : this.initialUtxo;
119
+ }
120
+
121
+ getVaultId(): bigint {
122
+ return this.vaultId;
123
+ }
124
+
125
+ getWithdrawalCount(): number {
126
+ return this.withdrawCount;
127
+ }
128
+
129
+ isOpened(): boolean {
130
+ return this.utxo!=="0000000000000000000000000000000000000000000000000000000000000000:0";
131
+ }
132
+
133
+ serialize(): any {
134
+ return {
135
+ type: "EVM",
136
+ owner: this.owner,
137
+ vaultId: this.vaultId.toString(10),
138
+ relayContract: this.relayContract,
139
+ token0: {
140
+ token: this.token0.token,
141
+ multiplier: this.token0.multiplier.toString(10),
142
+ rawAmount: this.token0.rawAmount.toString(10)
143
+ },
144
+ token1: {
145
+ token: this.token1.token,
146
+ multiplier: this.token1.multiplier.toString(10),
147
+ rawAmount: this.token1.rawAmount.toString(10)
148
+ },
149
+ utxo: this.utxo,
150
+ confirmations: this.confirmations,
151
+ withdrawCount: this.withdrawCount,
152
+ depositCount: this.depositCount,
153
+ initialUtxo: this.initialUtxo
154
+ }
155
+ }
156
+
157
+ updateState(withdrawalTxOrEvent: SpvVaultClaimEvent | SpvVaultCloseEvent | SpvVaultOpenEvent | SpvVaultDepositEvent | EVMSpvWithdrawalData): void {
158
+ if(withdrawalTxOrEvent instanceof SpvVaultClaimEvent) {
159
+ if(withdrawalTxOrEvent.withdrawCount <= this.withdrawCount) return;
160
+ this.token0.rawAmount -= withdrawalTxOrEvent.amounts[0];
161
+ this.token1.rawAmount -= withdrawalTxOrEvent.amounts[1];
162
+ this.withdrawCount = withdrawalTxOrEvent.withdrawCount;
163
+ this.utxo = withdrawalTxOrEvent.btcTxId+":0";
164
+ }
165
+ if(withdrawalTxOrEvent instanceof SpvVaultCloseEvent) {
166
+ this.token0.rawAmount = 0n;
167
+ this.token1.rawAmount = 0n;
168
+ this.utxo = "0000000000000000000000000000000000000000000000000000000000000000:0";
169
+ }
170
+ if(withdrawalTxOrEvent instanceof SpvVaultOpenEvent) {
171
+ if(this.isOpened()) return;
172
+ this.utxo = withdrawalTxOrEvent.btcTxId+":"+withdrawalTxOrEvent.vout;
173
+ }
174
+ if(withdrawalTxOrEvent instanceof SpvVaultDepositEvent) {
175
+ if(withdrawalTxOrEvent.depositCount <= this.depositCount) return;
176
+ this.token0.rawAmount += withdrawalTxOrEvent.amounts[0];
177
+ this.token1.rawAmount += withdrawalTxOrEvent.amounts[1];
178
+ this.depositCount = withdrawalTxOrEvent.depositCount;
179
+ }
180
+ if(withdrawalTxOrEvent instanceof EVMSpvWithdrawalData) {
181
+ if(withdrawalTxOrEvent.getSpentVaultUtxo()!==this.utxo) return;
182
+ const amounts = withdrawalTxOrEvent.getTotalOutput();
183
+ this.token0.rawAmount -= amounts[0];
184
+ this.token1.rawAmount -= amounts[1];
185
+ this.withdrawCount++;
186
+ this.utxo = withdrawalTxOrEvent.btcTx.txid+":0";
187
+ }
188
+ }
189
+
190
+ getDepositCount(): number {
191
+ return this.depositCount;
192
+ }
193
+
194
+ getVaultParamsStruct(): SpvVaultParametersStruct {
195
+ return {
196
+ btcRelayContract: this.relayContract,
197
+ token0: this.token0.token,
198
+ token1: this.token1.token,
199
+ token0Multiplier: this.token0.multiplier,
200
+ token1Multiplier: this.token1.multiplier,
201
+ confirmations: this.confirmations
202
+ }
203
+ }
204
+
205
+ static randomVault(): EVMSpvVaultData {
206
+ const spvVaultParams = {
207
+ btcRelayContract: EVMAddresses.randomAddress(),
208
+ token0: EVMAddresses.randomAddress(),
209
+ token1: EVMAddresses.randomAddress(),
210
+ token0Multiplier: 1n,
211
+ token1Multiplier: 1n,
212
+ confirmations: 3n,
213
+ }
214
+ return new EVMSpvVaultData(EVMAddresses.randomAddress(), 0n, {
215
+ spvVaultParametersCommitment: getVaultParamsCommitment(spvVaultParams),
216
+ utxoTxHash: randomBytes(32),
217
+ utxoVout: 0n,
218
+ openBlockheight: 0n,
219
+ withdrawCount: 0n,
220
+ depositCount: 0n,
221
+ token0Amount: 0n,
222
+ token1Amount: 0n
223
+ }, spvVaultParams);
224
+ }
225
+
226
+ }
227
+
228
+ SpvVaultData.deserializers["EVM"] = EVMSpvVaultData;
@@ -1,70 +1,70 @@
1
- import {SpvWithdrawalTransactionData} from "@atomiqlabs/base";
2
- import {Buffer} from "buffer";
3
- import { EVMSpvVaultContract } from "./EVMSpvVaultContract";
4
- import {BitcoinVaultTransactionDataStruct} from "./SpvVaultContractTypechain";
5
- import {AbiCoder, keccak256, ZeroHash} from "ethers";
6
-
7
-
8
- export class EVMSpvWithdrawalData extends SpvWithdrawalTransactionData {
9
-
10
- private getExecutionHashWith0x() {
11
- return this.executionHash==null ? ZeroHash : (this.executionHash.startsWith("0x") ? this.executionHash : "0x"+this.executionHash)
12
- }
13
-
14
- protected fromOpReturnData(data: Buffer): { recipient: string; rawAmounts: bigint[]; executionHash: string } {
15
- return EVMSpvVaultContract.fromOpReturnData(data);
16
- }
17
-
18
- isRecipient(address: string): boolean {
19
- return this.getRecipient().toLowerCase()===address.toLowerCase();
20
- }
21
-
22
- getFrontingId(): string {
23
- const callerFee = this.getCallerFee();
24
- const frontingFee = this.getFrontingFee();
25
- const txDataHash = keccak256(AbiCoder.defaultAbiCoder().encode(
26
- ["address", "uint64", "uint64", "uint64", "uint64", "uint64", "uint64", "uint64", "bytes32", "uint256"],
27
- [this.recipient, this.rawAmounts[0], this.rawAmounts[1], callerFee[0], callerFee[1], frontingFee[0], frontingFee[1], this.getExecutionFee()[0], this.getExecutionHashWith0x(), this.executionExpiry]
28
- ));
29
- return keccak256(AbiCoder.defaultAbiCoder().encode(
30
- ["bytes32", "bytes32"],
31
- [txDataHash, this.getTxHash()]
32
- )).substring(2);
33
- }
34
-
35
- getTxHash(): string {
36
- return "0x"+Buffer.from(this.btcTx.txid, "hex").reverse().toString("hex");
37
- }
38
-
39
- getFrontingAmount(): bigint[] {
40
- return [this.rawAmounts[0] + this.getExecutionFee()[0], this.rawAmounts[1]];
41
- }
42
-
43
- serialize(): any {
44
- return {
45
- type: "EVM",
46
- ...super.serialize()
47
- };
48
- }
49
-
50
- serializeToStruct(): BitcoinVaultTransactionDataStruct {
51
- const callerFee = this.getCallerFee();
52
- const frontingFee = this.getFrontingFee();
53
- const executionFee = this.getExecutionFee();
54
- return {
55
- recipient: this.recipient,
56
- amount0: this.rawAmounts[0],
57
- amount1: this.rawAmounts[1] ?? 0n,
58
- callerFee0: callerFee[0],
59
- callerFee1: callerFee[1] ?? 0n,
60
- frontingFee0: frontingFee[0],
61
- frontingFee1: frontingFee[1] ?? 0n,
62
- executionHandlerFeeAmount0: executionFee[0],
63
- executionHash: this.getExecutionHashWith0x(),
64
- executionExpiry: BigInt(this.executionExpiry)
65
- }
66
- }
67
-
68
- }
69
-
70
- SpvWithdrawalTransactionData.deserializers["EVM"] = EVMSpvWithdrawalData;
1
+ import {SpvWithdrawalTransactionData} from "@atomiqlabs/base";
2
+ import {Buffer} from "buffer";
3
+ import { EVMSpvVaultContract } from "./EVMSpvVaultContract";
4
+ import {BitcoinVaultTransactionDataStruct} from "./SpvVaultContractTypechain";
5
+ import {AbiCoder, keccak256, ZeroHash} from "ethers";
6
+
7
+
8
+ export class EVMSpvWithdrawalData extends SpvWithdrawalTransactionData {
9
+
10
+ private getExecutionHashWith0x() {
11
+ return this.executionHash==null ? ZeroHash : (this.executionHash.startsWith("0x") ? this.executionHash : "0x"+this.executionHash)
12
+ }
13
+
14
+ protected fromOpReturnData(data: Buffer): { recipient: string; rawAmounts: bigint[]; executionHash: string } {
15
+ return EVMSpvVaultContract.fromOpReturnData(data);
16
+ }
17
+
18
+ isRecipient(address: string): boolean {
19
+ return this.getRecipient().toLowerCase()===address.toLowerCase();
20
+ }
21
+
22
+ getFrontingId(): string {
23
+ const callerFee = this.getCallerFee();
24
+ const frontingFee = this.getFrontingFee();
25
+ const txDataHash = keccak256(AbiCoder.defaultAbiCoder().encode(
26
+ ["address", "uint64", "uint64", "uint64", "uint64", "uint64", "uint64", "uint64", "bytes32", "uint256"],
27
+ [this.recipient, this.rawAmounts[0], this.rawAmounts[1], callerFee[0], callerFee[1], frontingFee[0], frontingFee[1], this.getExecutionFee()[0], this.getExecutionHashWith0x(), this.executionExpiry]
28
+ ));
29
+ return keccak256(AbiCoder.defaultAbiCoder().encode(
30
+ ["bytes32", "bytes32"],
31
+ [txDataHash, this.getTxHash()]
32
+ )).substring(2);
33
+ }
34
+
35
+ getTxHash(): string {
36
+ return "0x"+Buffer.from(this.btcTx.txid, "hex").reverse().toString("hex");
37
+ }
38
+
39
+ getFrontingAmount(): bigint[] {
40
+ return [this.rawAmounts[0] + this.getExecutionFee()[0], this.rawAmounts[1]];
41
+ }
42
+
43
+ serialize(): any {
44
+ return {
45
+ type: "EVM",
46
+ ...super.serialize()
47
+ };
48
+ }
49
+
50
+ serializeToStruct(): BitcoinVaultTransactionDataStruct {
51
+ const callerFee = this.getCallerFee();
52
+ const frontingFee = this.getFrontingFee();
53
+ const executionFee = this.getExecutionFee();
54
+ return {
55
+ recipient: this.recipient,
56
+ amount0: this.rawAmounts[0],
57
+ amount1: this.rawAmounts[1] ?? 0n,
58
+ callerFee0: callerFee[0],
59
+ callerFee1: callerFee[1] ?? 0n,
60
+ frontingFee0: frontingFee[0],
61
+ frontingFee1: frontingFee[1] ?? 0n,
62
+ executionHandlerFeeAmount0: executionFee[0],
63
+ executionHash: this.getExecutionHashWith0x(),
64
+ executionExpiry: BigInt(this.executionExpiry)
65
+ }
66
+ }
67
+
68
+ }
69
+
70
+ SpvWithdrawalTransactionData.deserializers["EVM"] = EVMSpvWithdrawalData;