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

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 -125
  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 -132
  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 -54
  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 -151
  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 +307 -288
  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 -107
  69. package/dist/evm/spv_swap/EVMSpvVaultContract.js +578 -578
  70. package/dist/evm/spv_swap/EVMSpvVaultData.d.ts +40 -40
  71. package/dist/evm/spv_swap/EVMSpvVaultData.js +184 -184
  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 -199
  79. package/dist/evm/swaps/EVMSwapContract.js +394 -394
  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 -175
  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 -182
  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 -158
  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 -182
  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 +346 -327
  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 -723
  159. package/src/evm/spv_swap/EVMSpvVaultData.ts +228 -228
  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 -621
  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,228 +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 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
+ 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;