@atomiqlabs/lp-lib 15.0.13 → 15.0.14

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 (163) hide show
  1. package/LICENSE +201 -201
  2. package/dist/fees/IBtcFeeEstimator.d.ts +3 -3
  3. package/dist/fees/IBtcFeeEstimator.js +2 -2
  4. package/dist/index.d.ts +40 -40
  5. package/dist/index.js +56 -56
  6. package/dist/info/InfoHandler.d.ts +17 -17
  7. package/dist/info/InfoHandler.js +58 -61
  8. package/dist/plugins/IPlugin.d.ts +144 -144
  9. package/dist/plugins/IPlugin.js +34 -34
  10. package/dist/plugins/PluginManager.d.ts +113 -113
  11. package/dist/plugins/PluginManager.js +274 -274
  12. package/dist/prices/BinanceSwapPrice.d.ts +26 -26
  13. package/dist/prices/BinanceSwapPrice.js +92 -92
  14. package/dist/prices/CoinGeckoSwapPrice.d.ts +30 -30
  15. package/dist/prices/CoinGeckoSwapPrice.js +64 -64
  16. package/dist/prices/ISwapPrice.d.ts +43 -43
  17. package/dist/prices/ISwapPrice.js +55 -55
  18. package/dist/prices/OKXSwapPrice.d.ts +26 -26
  19. package/dist/prices/OKXSwapPrice.js +92 -92
  20. package/dist/storage/IIntermediaryStorage.d.ts +18 -18
  21. package/dist/storage/IIntermediaryStorage.js +2 -2
  22. package/dist/storagemanager/IntermediaryStorageManager.d.ts +18 -18
  23. package/dist/storagemanager/IntermediaryStorageManager.js +104 -104
  24. package/dist/storagemanager/StorageManager.d.ts +12 -12
  25. package/dist/storagemanager/StorageManager.js +57 -57
  26. package/dist/swaps/SwapHandler.d.ts +153 -156
  27. package/dist/swaps/SwapHandler.js +157 -163
  28. package/dist/swaps/SwapHandlerSwap.d.ts +79 -79
  29. package/dist/swaps/SwapHandlerSwap.js +78 -78
  30. package/dist/swaps/assertions/AmountAssertions.d.ts +28 -28
  31. package/dist/swaps/assertions/AmountAssertions.js +74 -74
  32. package/dist/swaps/assertions/FromBtcAmountAssertions.d.ts +76 -76
  33. package/dist/swaps/assertions/FromBtcAmountAssertions.js +172 -172
  34. package/dist/swaps/assertions/LightningAssertions.d.ts +44 -44
  35. package/dist/swaps/assertions/LightningAssertions.js +86 -86
  36. package/dist/swaps/assertions/ToBtcAmountAssertions.d.ts +53 -53
  37. package/dist/swaps/assertions/ToBtcAmountAssertions.js +150 -150
  38. package/dist/swaps/escrow/EscrowHandler.d.ts +51 -51
  39. package/dist/swaps/escrow/EscrowHandler.js +158 -158
  40. package/dist/swaps/escrow/EscrowHandlerSwap.d.ts +35 -35
  41. package/dist/swaps/escrow/EscrowHandlerSwap.js +69 -69
  42. package/dist/swaps/escrow/FromBtcBaseSwap.d.ts +14 -14
  43. package/dist/swaps/escrow/FromBtcBaseSwap.js +32 -32
  44. package/dist/swaps/escrow/FromBtcBaseSwapHandler.d.ts +101 -101
  45. package/dist/swaps/escrow/FromBtcBaseSwapHandler.js +207 -207
  46. package/dist/swaps/escrow/ToBtcBaseSwap.d.ts +36 -36
  47. package/dist/swaps/escrow/ToBtcBaseSwap.js +67 -67
  48. package/dist/swaps/escrow/ToBtcBaseSwapHandler.d.ts +53 -53
  49. package/dist/swaps/escrow/ToBtcBaseSwapHandler.js +81 -81
  50. package/dist/swaps/escrow/frombtc_abstract/FromBtcAbs.d.ts +83 -83
  51. package/dist/swaps/escrow/frombtc_abstract/FromBtcAbs.js +318 -318
  52. package/dist/swaps/escrow/frombtc_abstract/FromBtcSwapAbs.d.ts +21 -21
  53. package/dist/swaps/escrow/frombtc_abstract/FromBtcSwapAbs.js +50 -50
  54. package/dist/swaps/escrow/frombtcln_abstract/FromBtcLnAbs.d.ts +107 -107
  55. package/dist/swaps/escrow/frombtcln_abstract/FromBtcLnAbs.js +673 -675
  56. package/dist/swaps/escrow/frombtcln_abstract/FromBtcLnSwapAbs.d.ts +32 -32
  57. package/dist/swaps/escrow/frombtcln_abstract/FromBtcLnSwapAbs.js +88 -88
  58. package/dist/swaps/escrow/tobtc_abstract/ToBtcAbs.d.ts +171 -171
  59. package/dist/swaps/escrow/tobtc_abstract/ToBtcAbs.js +718 -718
  60. package/dist/swaps/escrow/tobtc_abstract/ToBtcSwapAbs.d.ts +28 -28
  61. package/dist/swaps/escrow/tobtc_abstract/ToBtcSwapAbs.js +64 -64
  62. package/dist/swaps/escrow/tobtcln_abstract/ToBtcLnAbs.d.ts +177 -177
  63. package/dist/swaps/escrow/tobtcln_abstract/ToBtcLnAbs.js +863 -863
  64. package/dist/swaps/escrow/tobtcln_abstract/ToBtcLnSwapAbs.d.ts +24 -24
  65. package/dist/swaps/escrow/tobtcln_abstract/ToBtcLnSwapAbs.js +58 -58
  66. package/dist/swaps/spv_vault_swap/SpvVault.d.ts +45 -45
  67. package/dist/swaps/spv_vault_swap/SpvVault.js +145 -145
  68. package/dist/swaps/spv_vault_swap/SpvVaultSwap.d.ts +68 -68
  69. package/dist/swaps/spv_vault_swap/SpvVaultSwap.js +158 -158
  70. package/dist/swaps/spv_vault_swap/SpvVaultSwapHandler.d.ts +68 -68
  71. package/dist/swaps/spv_vault_swap/SpvVaultSwapHandler.js +528 -528
  72. package/dist/swaps/spv_vault_swap/SpvVaults.d.ts +68 -68
  73. package/dist/swaps/spv_vault_swap/SpvVaults.js +454 -454
  74. package/dist/swaps/trusted/frombtc_trusted/FromBtcTrusted.d.ts +51 -51
  75. package/dist/swaps/trusted/frombtc_trusted/FromBtcTrusted.js +650 -650
  76. package/dist/swaps/trusted/frombtc_trusted/FromBtcTrustedSwap.d.ts +52 -52
  77. package/dist/swaps/trusted/frombtc_trusted/FromBtcTrustedSwap.js +118 -118
  78. package/dist/swaps/trusted/frombtcln_trusted/FromBtcLnTrusted.d.ts +76 -76
  79. package/dist/swaps/trusted/frombtcln_trusted/FromBtcLnTrusted.js +493 -495
  80. package/dist/swaps/trusted/frombtcln_trusted/FromBtcLnTrustedSwap.d.ts +34 -34
  81. package/dist/swaps/trusted/frombtcln_trusted/FromBtcLnTrustedSwap.js +81 -81
  82. package/dist/utils/BitcoinUtils.d.ts +4 -4
  83. package/dist/utils/BitcoinUtils.js +61 -61
  84. package/dist/utils/Utils.d.ts +29 -29
  85. package/dist/utils/Utils.js +88 -88
  86. package/dist/utils/paramcoders/IParamReader.d.ts +5 -5
  87. package/dist/utils/paramcoders/IParamReader.js +2 -2
  88. package/dist/utils/paramcoders/IParamWriter.d.ts +4 -4
  89. package/dist/utils/paramcoders/IParamWriter.js +2 -2
  90. package/dist/utils/paramcoders/LegacyParamEncoder.d.ts +10 -10
  91. package/dist/utils/paramcoders/LegacyParamEncoder.js +22 -22
  92. package/dist/utils/paramcoders/ParamDecoder.d.ts +25 -25
  93. package/dist/utils/paramcoders/ParamDecoder.js +222 -222
  94. package/dist/utils/paramcoders/ParamEncoder.d.ts +9 -9
  95. package/dist/utils/paramcoders/ParamEncoder.js +22 -22
  96. package/dist/utils/paramcoders/SchemaVerifier.d.ts +21 -21
  97. package/dist/utils/paramcoders/SchemaVerifier.js +84 -84
  98. package/dist/utils/paramcoders/server/ServerParamDecoder.d.ts +8 -8
  99. package/dist/utils/paramcoders/server/ServerParamDecoder.js +105 -105
  100. package/dist/utils/paramcoders/server/ServerParamEncoder.d.ts +11 -11
  101. package/dist/utils/paramcoders/server/ServerParamEncoder.js +65 -65
  102. package/dist/wallets/IBitcoinWallet.d.ts +67 -67
  103. package/dist/wallets/IBitcoinWallet.js +2 -2
  104. package/dist/wallets/ILightningWallet.d.ts +117 -117
  105. package/dist/wallets/ILightningWallet.js +37 -37
  106. package/dist/wallets/ISpvVaultSigner.d.ts +7 -7
  107. package/dist/wallets/ISpvVaultSigner.js +2 -2
  108. package/dist/wallets/ISpvVaultWallet.d.ts +42 -42
  109. package/dist/wallets/ISpvVaultWallet.js +2 -2
  110. package/package.json +36 -36
  111. package/src/fees/IBtcFeeEstimator.ts +6 -6
  112. package/src/index.ts +51 -51
  113. package/src/info/InfoHandler.ts +100 -106
  114. package/src/plugins/IPlugin.ts +174 -174
  115. package/src/plugins/PluginManager.ts +354 -354
  116. package/src/prices/BinanceSwapPrice.ts +113 -113
  117. package/src/prices/CoinGeckoSwapPrice.ts +87 -87
  118. package/src/prices/ISwapPrice.ts +88 -88
  119. package/src/prices/OKXSwapPrice.ts +113 -113
  120. package/src/storage/IIntermediaryStorage.ts +19 -19
  121. package/src/storagemanager/IntermediaryStorageManager.ts +109 -109
  122. package/src/storagemanager/StorageManager.ts +68 -68
  123. package/src/swaps/SwapHandler.ts +272 -280
  124. package/src/swaps/SwapHandlerSwap.ts +141 -141
  125. package/src/swaps/assertions/AmountAssertions.ts +77 -77
  126. package/src/swaps/assertions/FromBtcAmountAssertions.ts +238 -238
  127. package/src/swaps/assertions/LightningAssertions.ts +103 -103
  128. package/src/swaps/assertions/ToBtcAmountAssertions.ts +203 -203
  129. package/src/swaps/escrow/EscrowHandler.ts +179 -179
  130. package/src/swaps/escrow/EscrowHandlerSwap.ts +86 -86
  131. package/src/swaps/escrow/FromBtcBaseSwap.ts +38 -38
  132. package/src/swaps/escrow/FromBtcBaseSwapHandler.ts +283 -283
  133. package/src/swaps/escrow/ToBtcBaseSwap.ts +85 -85
  134. package/src/swaps/escrow/ToBtcBaseSwapHandler.ts +129 -129
  135. package/src/swaps/escrow/frombtc_abstract/FromBtcAbs.ts +452 -452
  136. package/src/swaps/escrow/frombtc_abstract/FromBtcSwapAbs.ts +61 -61
  137. package/src/swaps/escrow/frombtcln_abstract/FromBtcLnAbs.ts +855 -856
  138. package/src/swaps/escrow/frombtcln_abstract/FromBtcLnSwapAbs.ts +137 -137
  139. package/src/swaps/escrow/tobtc_abstract/ToBtcAbs.ts +890 -890
  140. package/src/swaps/escrow/tobtc_abstract/ToBtcSwapAbs.ts +108 -108
  141. package/src/swaps/escrow/tobtcln_abstract/ToBtcLnAbs.ts +1112 -1112
  142. package/src/swaps/escrow/tobtcln_abstract/ToBtcLnSwapAbs.ts +80 -80
  143. package/src/swaps/spv_vault_swap/SpvVault.ts +178 -178
  144. package/src/swaps/spv_vault_swap/SpvVaultSwap.ts +228 -228
  145. package/src/swaps/spv_vault_swap/SpvVaultSwapHandler.ts +671 -671
  146. package/src/swaps/spv_vault_swap/SpvVaults.ts +526 -526
  147. package/src/swaps/trusted/frombtc_trusted/FromBtcTrusted.ts +747 -747
  148. package/src/swaps/trusted/frombtc_trusted/FromBtcTrustedSwap.ts +185 -185
  149. package/src/swaps/trusted/frombtcln_trusted/FromBtcLnTrusted.ts +591 -592
  150. package/src/swaps/trusted/frombtcln_trusted/FromBtcLnTrustedSwap.ts +121 -121
  151. package/src/utils/BitcoinUtils.ts +59 -59
  152. package/src/utils/Utils.ts +102 -102
  153. package/src/utils/paramcoders/IParamReader.ts +7 -7
  154. package/src/utils/paramcoders/IParamWriter.ts +8 -8
  155. package/src/utils/paramcoders/LegacyParamEncoder.ts +27 -27
  156. package/src/utils/paramcoders/ParamDecoder.ts +218 -218
  157. package/src/utils/paramcoders/ParamEncoder.ts +29 -29
  158. package/src/utils/paramcoders/SchemaVerifier.ts +96 -96
  159. package/src/utils/paramcoders/server/ServerParamDecoder.ts +115 -115
  160. package/src/utils/paramcoders/server/ServerParamEncoder.ts +75 -75
  161. package/src/wallets/IBitcoinWallet.ts +68 -68
  162. package/src/wallets/ILightningWallet.ts +178 -178
  163. package/src/wallets/ISpvVaultSigner.ts +10 -10
@@ -1,81 +1,81 @@
1
- import {SwapData} from "@atomiqlabs/base";
2
- import {SwapHandlerType} from "../../../index";
3
- import {deserializeBN} from "../../../utils/Utils";
4
- import {ToBtcBaseSwap} from "../ToBtcBaseSwap";
5
-
6
- export enum ToBtcLnSwapState {
7
- REFUNDED = -3,
8
- CANCELED = -2,
9
- NON_PAYABLE = -1,
10
- SAVED = 0,
11
- COMMITED = 1,
12
- PAID = 2,
13
- CLAIMED = 3
14
- }
15
-
16
- export class ToBtcLnSwapAbs<T extends SwapData = SwapData> extends ToBtcBaseSwap<T, ToBtcLnSwapState> {
17
-
18
- lnPaymentHash: string;
19
- readonly pr: string;
20
- payInitiated: boolean;
21
-
22
- secret: string;
23
-
24
- constructor(
25
- chainIdentifier: string,
26
- lnPaymentHash: string,
27
- pr: string,
28
- amountMtokens: bigint,
29
- swapFee: bigint,
30
- swapFeeInToken: bigint,
31
- quotedNetworkFee: bigint,
32
- quotedNetworkFeeInToken: bigint,
33
- );
34
- constructor(obj: any);
35
-
36
- constructor(chainIdOrObj: string | any, lnPaymentHash?: string, pr?: string, amount?: bigint, swapFee?: bigint, swapFeeInToken?: bigint, quotedNetworkFee?: bigint, quotedNetworkFeeInToken?: bigint) {
37
- if(typeof(chainIdOrObj)==="string") {
38
- super(chainIdOrObj, (amount + 999n) / 1000n, swapFee, swapFeeInToken, quotedNetworkFee, quotedNetworkFeeInToken);
39
- this.state = ToBtcLnSwapState.SAVED;
40
- this.lnPaymentHash = lnPaymentHash;
41
- this.pr = pr;
42
- } else {
43
- super(chainIdOrObj);
44
- this.pr = chainIdOrObj.pr;
45
- this.secret = chainIdOrObj.secret;
46
- this.lnPaymentHash = chainIdOrObj.lnPaymentHash;
47
- this.payInitiated = chainIdOrObj.payInitiated;
48
-
49
- //Compatibility with older versions
50
- this.quotedNetworkFee ??= deserializeBN(chainIdOrObj.maxFee);
51
- this.realNetworkFee ??= deserializeBN(chainIdOrObj.realRoutingFee);
52
- }
53
- this.type = SwapHandlerType.TO_BTCLN;
54
- }
55
-
56
- getIdentifierHash(): string {
57
- return this.lnPaymentHash;
58
- }
59
-
60
- serialize(): any {
61
- const partialSerialized = super.serialize();
62
- partialSerialized.pr = this.pr;
63
- partialSerialized.lnPaymentHash = this.lnPaymentHash;
64
- partialSerialized.secret = this.secret;
65
- partialSerialized.payInitiated = this.payInitiated;
66
- return partialSerialized;
67
- }
68
-
69
- isInitiated(): boolean {
70
- return this.state!==ToBtcLnSwapState.SAVED;
71
- }
72
-
73
- isFailed(): boolean {
74
- return this.state===ToBtcLnSwapState.NON_PAYABLE || this.state===ToBtcLnSwapState.CANCELED || this.state===ToBtcLnSwapState.REFUNDED;
75
- }
76
-
77
- isSuccess(): boolean {
78
- return this.state===ToBtcLnSwapState.CLAIMED;
79
- }
80
-
1
+ import {SwapData} from "@atomiqlabs/base";
2
+ import {SwapHandlerType} from "../../../index";
3
+ import {deserializeBN} from "../../../utils/Utils";
4
+ import {ToBtcBaseSwap} from "../ToBtcBaseSwap";
5
+
6
+ export enum ToBtcLnSwapState {
7
+ REFUNDED = -3,
8
+ CANCELED = -2,
9
+ NON_PAYABLE = -1,
10
+ SAVED = 0,
11
+ COMMITED = 1,
12
+ PAID = 2,
13
+ CLAIMED = 3
14
+ }
15
+
16
+ export class ToBtcLnSwapAbs<T extends SwapData = SwapData> extends ToBtcBaseSwap<T, ToBtcLnSwapState> {
17
+
18
+ lnPaymentHash: string;
19
+ readonly pr: string;
20
+ payInitiated: boolean;
21
+
22
+ secret: string;
23
+
24
+ constructor(
25
+ chainIdentifier: string,
26
+ lnPaymentHash: string,
27
+ pr: string,
28
+ amountMtokens: bigint,
29
+ swapFee: bigint,
30
+ swapFeeInToken: bigint,
31
+ quotedNetworkFee: bigint,
32
+ quotedNetworkFeeInToken: bigint,
33
+ );
34
+ constructor(obj: any);
35
+
36
+ constructor(chainIdOrObj: string | any, lnPaymentHash?: string, pr?: string, amount?: bigint, swapFee?: bigint, swapFeeInToken?: bigint, quotedNetworkFee?: bigint, quotedNetworkFeeInToken?: bigint) {
37
+ if(typeof(chainIdOrObj)==="string") {
38
+ super(chainIdOrObj, (amount + 999n) / 1000n, swapFee, swapFeeInToken, quotedNetworkFee, quotedNetworkFeeInToken);
39
+ this.state = ToBtcLnSwapState.SAVED;
40
+ this.lnPaymentHash = lnPaymentHash;
41
+ this.pr = pr;
42
+ } else {
43
+ super(chainIdOrObj);
44
+ this.pr = chainIdOrObj.pr;
45
+ this.secret = chainIdOrObj.secret;
46
+ this.lnPaymentHash = chainIdOrObj.lnPaymentHash;
47
+ this.payInitiated = chainIdOrObj.payInitiated;
48
+
49
+ //Compatibility with older versions
50
+ this.quotedNetworkFee ??= deserializeBN(chainIdOrObj.maxFee);
51
+ this.realNetworkFee ??= deserializeBN(chainIdOrObj.realRoutingFee);
52
+ }
53
+ this.type = SwapHandlerType.TO_BTCLN;
54
+ }
55
+
56
+ getIdentifierHash(): string {
57
+ return this.lnPaymentHash;
58
+ }
59
+
60
+ serialize(): any {
61
+ const partialSerialized = super.serialize();
62
+ partialSerialized.pr = this.pr;
63
+ partialSerialized.lnPaymentHash = this.lnPaymentHash;
64
+ partialSerialized.secret = this.secret;
65
+ partialSerialized.payInitiated = this.payInitiated;
66
+ return partialSerialized;
67
+ }
68
+
69
+ isInitiated(): boolean {
70
+ return this.state!==ToBtcLnSwapState.SAVED;
71
+ }
72
+
73
+ isFailed(): boolean {
74
+ return this.state===ToBtcLnSwapState.NON_PAYABLE || this.state===ToBtcLnSwapState.CANCELED || this.state===ToBtcLnSwapState.REFUNDED;
75
+ }
76
+
77
+ isSuccess(): boolean {
78
+ return this.state===ToBtcLnSwapState.CLAIMED;
79
+ }
80
+
81
81
  }
@@ -1,178 +1,178 @@
1
- import {
2
- Lockable,
3
- SpvVaultClaimEvent,
4
- SpvVaultCloseEvent,
5
- SpvVaultData,
6
- SpvVaultDepositEvent,
7
- SpvVaultOpenEvent,
8
- SpvVaultTokenBalance,
9
- SpvWithdrawalTransactionData,
10
- StorageObject
11
- } from "@atomiqlabs/base";
12
-
13
- export enum SpvVaultState {
14
- CLOSED = -1,
15
- BTC_INITIATED = 0,
16
- BTC_CONFIRMED = 1,
17
- OPENED = 2
18
- }
19
-
20
- export class SpvVault<
21
- D extends SpvWithdrawalTransactionData = SpvWithdrawalTransactionData & {sending?: boolean},
22
- T extends SpvVaultData = SpvVaultData
23
- > extends Lockable implements StorageObject {
24
-
25
- readonly chainId: string;
26
-
27
- readonly initialUtxo: string;
28
- readonly btcAddress: string;
29
-
30
- readonly pendingWithdrawals: D[];
31
- readonly replacedWithdrawals: Map<number, D[]>;
32
- data: T;
33
-
34
- state: SpvVaultState;
35
-
36
- balances: SpvVaultTokenBalance[];
37
-
38
- scOpenTx: {txId: string, rawTx: string};
39
-
40
- constructor(chainId: string, vault: T, btcAddress: string);
41
- constructor(obj: any);
42
- constructor(chainIdOrObj: string | any, vault?: T, btcAddress?: string) {
43
- super();
44
- if(typeof(chainIdOrObj)==="string") {
45
- this.state = SpvVaultState.BTC_INITIATED;
46
- this.chainId = chainIdOrObj;
47
- this.data = vault;
48
- this.initialUtxo = vault.getUtxo();
49
- this.btcAddress = btcAddress;
50
- this.pendingWithdrawals = [];
51
- this.replacedWithdrawals = new Map();
52
- } else {
53
- this.state = chainIdOrObj.state;
54
- this.chainId = chainIdOrObj.chainId;
55
- this.data = SpvVaultData.deserialize<T>(chainIdOrObj.data);
56
- this.initialUtxo = chainIdOrObj.initialUtxo;
57
- this.btcAddress = chainIdOrObj.btcAddress;
58
- this.pendingWithdrawals = chainIdOrObj.pendingWithdrawals.map(SpvWithdrawalTransactionData.deserialize<D>);
59
- this.scOpenTx = chainIdOrObj.scOpenTx;
60
- this.replacedWithdrawals = new Map();
61
- if(chainIdOrObj.replacedWithdrawals!=null) {
62
- chainIdOrObj.replacedWithdrawals.forEach((val: [number, any[]]) => {
63
- this.replacedWithdrawals.set(val[0], val[1].map(SpvWithdrawalTransactionData.deserialize<D>));
64
- });
65
- }
66
- }
67
- this.balances = this.data.calculateStateAfter(this.pendingWithdrawals).balances;
68
- }
69
-
70
- update(event: SpvVaultOpenEvent | SpvVaultDepositEvent | SpvVaultCloseEvent | SpvVaultClaimEvent): void {
71
- if(event instanceof SpvVaultClaimEvent || event instanceof SpvVaultCloseEvent) {
72
- const processedWithdrawalIndex = this.pendingWithdrawals.findIndex(val => val.btcTx.txid === event.btcTxId);
73
- if(processedWithdrawalIndex!==-1) this.pendingWithdrawals.splice(0, processedWithdrawalIndex + 1);
74
- if(event instanceof SpvVaultClaimEvent) {
75
- for(let key of this.replacedWithdrawals.keys()) {
76
- if(key<=event.withdrawCount) this.replacedWithdrawals.delete(key);
77
- }
78
- }
79
- if(event instanceof SpvVaultCloseEvent) {
80
- this.replacedWithdrawals.clear();
81
- }
82
- }
83
- this.data.updateState(event);
84
- this.balances = this.data.calculateStateAfter(this.pendingWithdrawals).balances;
85
- }
86
-
87
- addWithdrawal(withdrawalData: D): void {
88
- //Make sure this is a valid state transition before adding the tx to pending withdrawals
89
- this.balances = this.data.calculateStateAfter([...this.pendingWithdrawals, withdrawalData]).balances;
90
- this.pendingWithdrawals.push(withdrawalData);
91
- }
92
-
93
- removeWithdrawal(withdrawalData: D): boolean {
94
- const index = this.pendingWithdrawals.indexOf(withdrawalData);
95
- if(index===-1) return false;
96
- this.pendingWithdrawals.splice(index, 1);
97
- this.balances = this.data.calculateStateAfter(this.pendingWithdrawals).balances;
98
- return true;
99
- }
100
-
101
- doubleSpendPendingWithdrawal(withdrawalData: D): boolean {
102
- const index = this.pendingWithdrawals.indexOf(withdrawalData);
103
- if(index===-1) return false;
104
- this.pendingWithdrawals.splice(index, 1);
105
- this.balances = this.data.calculateStateAfter(this.pendingWithdrawals).balances;
106
-
107
- const withdrawalIndex = this.data.getWithdrawalCount()+index+1;
108
- let arr = this.replacedWithdrawals.get(withdrawalIndex);
109
- if(arr==null) this.replacedWithdrawals.set(withdrawalIndex, arr = []);
110
- arr.push(withdrawalData);
111
- return true;
112
- }
113
-
114
- toRawAmounts(amounts: bigint[]): bigint[] {
115
- return amounts.map((amt, index) => {
116
- const tokenData = this.data.getTokenData()[index];
117
- if(tokenData==null) throw new Error("Amount index out of bounds!");
118
- return amt / tokenData.multiplier;
119
- });
120
- }
121
-
122
- fromRawAmounts(rawAmounts: bigint[]): bigint[] {
123
- return rawAmounts.map((amt, index) => {
124
- const tokenData = this.data.getTokenData()[index];
125
- if(tokenData==null) throw new Error("Amount index out of bounds!");
126
- return amt * tokenData.multiplier;
127
- });
128
- }
129
-
130
- /**
131
- * Returns the vault balance after processing all currently confirmed (at least 1 btc confirmation) withdrawals
132
- */
133
- getConfirmedBalance(): SpvVaultTokenBalance[] {
134
- return this.data.calculateStateAfter(this.pendingWithdrawals.filter(val => val.btcTx.confirmations>=1)).balances;
135
- }
136
-
137
- serialize(): any {
138
- const replacedWithdrawals: [number, any[]][] = [];
139
- this.replacedWithdrawals.forEach((value, key) => {
140
- replacedWithdrawals.push([key, value.map(val => val.serialize())])
141
- });
142
-
143
- return {
144
- state: this.state,
145
- chainId: this.chainId,
146
- data: this.data.serialize(),
147
- initialUtxo: this.initialUtxo,
148
- btcAddress: this.btcAddress,
149
- pendingWithdrawals: this.pendingWithdrawals.map(val => val.serialize()),
150
- replacedWithdrawals,
151
- scOpenTx: this.scOpenTx
152
- }
153
- }
154
-
155
- getIdentifier(): string {
156
- return this.chainId+"_"+this.data.getOwner()+"_"+this.data.getVaultId().toString(10);
157
- }
158
-
159
- /**
160
- * Returns the latest vault utxo
161
- */
162
- getLatestUtxo(): string {
163
- if(this.pendingWithdrawals.length===0) {
164
- return this.data.getUtxo();
165
- }
166
- const latestWithdrawal = this.pendingWithdrawals[this.pendingWithdrawals.length - 1];
167
- if(latestWithdrawal.btcTx.confirmations>=1) return latestWithdrawal.btcTx.txid+":0";
168
- return null;
169
- }
170
-
171
- /**
172
- * Returns whether the vault is ready for the next swap
173
- */
174
- isReady(): boolean {
175
- return this.data.isOpened() && this.getLatestUtxo()!=null;
176
- }
177
-
178
- }
1
+ import {
2
+ Lockable,
3
+ SpvVaultClaimEvent,
4
+ SpvVaultCloseEvent,
5
+ SpvVaultData,
6
+ SpvVaultDepositEvent,
7
+ SpvVaultOpenEvent,
8
+ SpvVaultTokenBalance,
9
+ SpvWithdrawalTransactionData,
10
+ StorageObject
11
+ } from "@atomiqlabs/base";
12
+
13
+ export enum SpvVaultState {
14
+ CLOSED = -1,
15
+ BTC_INITIATED = 0,
16
+ BTC_CONFIRMED = 1,
17
+ OPENED = 2
18
+ }
19
+
20
+ export class SpvVault<
21
+ D extends SpvWithdrawalTransactionData = SpvWithdrawalTransactionData & {sending?: boolean},
22
+ T extends SpvVaultData = SpvVaultData
23
+ > extends Lockable implements StorageObject {
24
+
25
+ readonly chainId: string;
26
+
27
+ readonly initialUtxo: string;
28
+ readonly btcAddress: string;
29
+
30
+ readonly pendingWithdrawals: D[];
31
+ readonly replacedWithdrawals: Map<number, D[]>;
32
+ data: T;
33
+
34
+ state: SpvVaultState;
35
+
36
+ balances: SpvVaultTokenBalance[];
37
+
38
+ scOpenTx: {txId: string, rawTx: string};
39
+
40
+ constructor(chainId: string, vault: T, btcAddress: string);
41
+ constructor(obj: any);
42
+ constructor(chainIdOrObj: string | any, vault?: T, btcAddress?: string) {
43
+ super();
44
+ if(typeof(chainIdOrObj)==="string") {
45
+ this.state = SpvVaultState.BTC_INITIATED;
46
+ this.chainId = chainIdOrObj;
47
+ this.data = vault;
48
+ this.initialUtxo = vault.getUtxo();
49
+ this.btcAddress = btcAddress;
50
+ this.pendingWithdrawals = [];
51
+ this.replacedWithdrawals = new Map();
52
+ } else {
53
+ this.state = chainIdOrObj.state;
54
+ this.chainId = chainIdOrObj.chainId;
55
+ this.data = SpvVaultData.deserialize<T>(chainIdOrObj.data);
56
+ this.initialUtxo = chainIdOrObj.initialUtxo;
57
+ this.btcAddress = chainIdOrObj.btcAddress;
58
+ this.pendingWithdrawals = chainIdOrObj.pendingWithdrawals.map(SpvWithdrawalTransactionData.deserialize<D>);
59
+ this.scOpenTx = chainIdOrObj.scOpenTx;
60
+ this.replacedWithdrawals = new Map();
61
+ if(chainIdOrObj.replacedWithdrawals!=null) {
62
+ chainIdOrObj.replacedWithdrawals.forEach((val: [number, any[]]) => {
63
+ this.replacedWithdrawals.set(val[0], val[1].map(SpvWithdrawalTransactionData.deserialize<D>));
64
+ });
65
+ }
66
+ }
67
+ this.balances = this.data.calculateStateAfter(this.pendingWithdrawals).balances;
68
+ }
69
+
70
+ update(event: SpvVaultOpenEvent | SpvVaultDepositEvent | SpvVaultCloseEvent | SpvVaultClaimEvent): void {
71
+ if(event instanceof SpvVaultClaimEvent || event instanceof SpvVaultCloseEvent) {
72
+ const processedWithdrawalIndex = this.pendingWithdrawals.findIndex(val => val.btcTx.txid === event.btcTxId);
73
+ if(processedWithdrawalIndex!==-1) this.pendingWithdrawals.splice(0, processedWithdrawalIndex + 1);
74
+ if(event instanceof SpvVaultClaimEvent) {
75
+ for(let key of this.replacedWithdrawals.keys()) {
76
+ if(key<=event.withdrawCount) this.replacedWithdrawals.delete(key);
77
+ }
78
+ }
79
+ if(event instanceof SpvVaultCloseEvent) {
80
+ this.replacedWithdrawals.clear();
81
+ }
82
+ }
83
+ this.data.updateState(event);
84
+ this.balances = this.data.calculateStateAfter(this.pendingWithdrawals).balances;
85
+ }
86
+
87
+ addWithdrawal(withdrawalData: D): void {
88
+ //Make sure this is a valid state transition before adding the tx to pending withdrawals
89
+ this.balances = this.data.calculateStateAfter([...this.pendingWithdrawals, withdrawalData]).balances;
90
+ this.pendingWithdrawals.push(withdrawalData);
91
+ }
92
+
93
+ removeWithdrawal(withdrawalData: D): boolean {
94
+ const index = this.pendingWithdrawals.indexOf(withdrawalData);
95
+ if(index===-1) return false;
96
+ this.pendingWithdrawals.splice(index, 1);
97
+ this.balances = this.data.calculateStateAfter(this.pendingWithdrawals).balances;
98
+ return true;
99
+ }
100
+
101
+ doubleSpendPendingWithdrawal(withdrawalData: D): boolean {
102
+ const index = this.pendingWithdrawals.indexOf(withdrawalData);
103
+ if(index===-1) return false;
104
+ this.pendingWithdrawals.splice(index, 1);
105
+ this.balances = this.data.calculateStateAfter(this.pendingWithdrawals).balances;
106
+
107
+ const withdrawalIndex = this.data.getWithdrawalCount()+index+1;
108
+ let arr = this.replacedWithdrawals.get(withdrawalIndex);
109
+ if(arr==null) this.replacedWithdrawals.set(withdrawalIndex, arr = []);
110
+ arr.push(withdrawalData);
111
+ return true;
112
+ }
113
+
114
+ toRawAmounts(amounts: bigint[]): bigint[] {
115
+ return amounts.map((amt, index) => {
116
+ const tokenData = this.data.getTokenData()[index];
117
+ if(tokenData==null) throw new Error("Amount index out of bounds!");
118
+ return amt / tokenData.multiplier;
119
+ });
120
+ }
121
+
122
+ fromRawAmounts(rawAmounts: bigint[]): bigint[] {
123
+ return rawAmounts.map((amt, index) => {
124
+ const tokenData = this.data.getTokenData()[index];
125
+ if(tokenData==null) throw new Error("Amount index out of bounds!");
126
+ return amt * tokenData.multiplier;
127
+ });
128
+ }
129
+
130
+ /**
131
+ * Returns the vault balance after processing all currently confirmed (at least 1 btc confirmation) withdrawals
132
+ */
133
+ getConfirmedBalance(): SpvVaultTokenBalance[] {
134
+ return this.data.calculateStateAfter(this.pendingWithdrawals.filter(val => val.btcTx.confirmations>=1)).balances;
135
+ }
136
+
137
+ serialize(): any {
138
+ const replacedWithdrawals: [number, any[]][] = [];
139
+ this.replacedWithdrawals.forEach((value, key) => {
140
+ replacedWithdrawals.push([key, value.map(val => val.serialize())])
141
+ });
142
+
143
+ return {
144
+ state: this.state,
145
+ chainId: this.chainId,
146
+ data: this.data.serialize(),
147
+ initialUtxo: this.initialUtxo,
148
+ btcAddress: this.btcAddress,
149
+ pendingWithdrawals: this.pendingWithdrawals.map(val => val.serialize()),
150
+ replacedWithdrawals,
151
+ scOpenTx: this.scOpenTx
152
+ }
153
+ }
154
+
155
+ getIdentifier(): string {
156
+ return this.chainId+"_"+this.data.getOwner()+"_"+this.data.getVaultId().toString(10);
157
+ }
158
+
159
+ /**
160
+ * Returns the latest vault utxo
161
+ */
162
+ getLatestUtxo(): string {
163
+ if(this.pendingWithdrawals.length===0) {
164
+ return this.data.getUtxo();
165
+ }
166
+ const latestWithdrawal = this.pendingWithdrawals[this.pendingWithdrawals.length - 1];
167
+ if(latestWithdrawal.btcTx.confirmations>=1) return latestWithdrawal.btcTx.txid+":0";
168
+ return null;
169
+ }
170
+
171
+ /**
172
+ * Returns whether the vault is ready for the next swap
173
+ */
174
+ isReady(): boolean {
175
+ return this.data.isOpened() && this.getLatestUtxo()!=null;
176
+ }
177
+
178
+ }