@atomiqlabs/chain-evm 1.0.0-dev.35 → 1.0.0-dev.37

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 +230 -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 -260
  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 +10 -9
  103. package/dist/evm/wallet/EVMSigner.js +17 -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 +257 -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 -378
  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 +25 -23
  160. package/src/index.ts +45 -45
  161. package/src/utils/Utils.ts +81 -81
@@ -1,224 +1,224 @@
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 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,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;