@atomiqlabs/lp-lib 14.0.0-dev.9 → 15.0.2

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 (166) 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 -42
  5. package/dist/index.js +56 -58
  6. package/dist/info/InfoHandler.d.ts +17 -17
  7. package/dist/info/InfoHandler.js +61 -61
  8. package/dist/plugins/IPlugin.d.ts +143 -143
  9. package/dist/plugins/IPlugin.js +34 -34
  10. package/dist/plugins/PluginManager.d.ts +112 -112
  11. package/dist/plugins/PluginManager.js +259 -259
  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 -19
  23. package/dist/storagemanager/IntermediaryStorageManager.js +104 -111
  24. package/dist/storagemanager/StorageManager.d.ts +12 -13
  25. package/dist/storagemanager/StorageManager.js +57 -64
  26. package/dist/swaps/SwapHandler.d.ts +156 -153
  27. package/dist/swaps/SwapHandler.js +163 -160
  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 +72 -72
  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 -102
  45. package/dist/swaps/escrow/FromBtcBaseSwapHandler.js +207 -210
  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 +675 -648
  56. package/dist/swaps/escrow/frombtcln_abstract/FromBtcLnSwapAbs.d.ts +32 -33
  57. package/dist/swaps/escrow/frombtcln_abstract/FromBtcLnSwapAbs.js +88 -91
  58. package/dist/swaps/escrow/tobtc_abstract/ToBtcAbs.d.ts +171 -171
  59. package/dist/swaps/escrow/tobtc_abstract/ToBtcAbs.js +706 -706
  60. package/dist/swaps/escrow/tobtc_abstract/ToBtcSwapAbs.d.ts +26 -26
  61. package/dist/swaps/escrow/tobtc_abstract/ToBtcSwapAbs.js +62 -62
  62. package/dist/swaps/escrow/tobtcln_abstract/ToBtcLnAbs.d.ts +177 -177
  63. package/dist/swaps/escrow/tobtcln_abstract/ToBtcLnAbs.js +861 -861
  64. package/dist/swaps/escrow/tobtcln_abstract/ToBtcLnSwapAbs.d.ts +23 -23
  65. package/dist/swaps/escrow/tobtcln_abstract/ToBtcLnSwapAbs.js +56 -56
  66. package/dist/swaps/spv_vault_swap/SpvVault.d.ts +41 -41
  67. package/dist/swaps/spv_vault_swap/SpvVault.js +111 -111
  68. package/dist/swaps/spv_vault_swap/SpvVaultSwap.d.ts +67 -67
  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 +491 -490
  72. package/dist/swaps/spv_vault_swap/SpvVaults.d.ts +57 -52
  73. package/dist/swaps/spv_vault_swap/SpvVaults.js +369 -364
  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 +495 -494
  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/Utils.d.ts +29 -29
  83. package/dist/utils/Utils.js +88 -89
  84. package/dist/utils/paramcoders/IParamReader.d.ts +5 -5
  85. package/dist/utils/paramcoders/IParamReader.js +2 -2
  86. package/dist/utils/paramcoders/IParamWriter.d.ts +4 -4
  87. package/dist/utils/paramcoders/IParamWriter.js +2 -2
  88. package/dist/utils/paramcoders/LegacyParamEncoder.d.ts +10 -10
  89. package/dist/utils/paramcoders/LegacyParamEncoder.js +22 -22
  90. package/dist/utils/paramcoders/ParamDecoder.d.ts +25 -25
  91. package/dist/utils/paramcoders/ParamDecoder.js +222 -222
  92. package/dist/utils/paramcoders/ParamEncoder.d.ts +9 -9
  93. package/dist/utils/paramcoders/ParamEncoder.js +22 -22
  94. package/dist/utils/paramcoders/SchemaVerifier.d.ts +21 -21
  95. package/dist/utils/paramcoders/SchemaVerifier.js +84 -84
  96. package/dist/utils/paramcoders/server/ServerParamDecoder.d.ts +8 -8
  97. package/dist/utils/paramcoders/server/ServerParamDecoder.js +105 -107
  98. package/dist/utils/paramcoders/server/ServerParamEncoder.d.ts +11 -11
  99. package/dist/utils/paramcoders/server/ServerParamEncoder.js +65 -65
  100. package/dist/wallets/IBitcoinWallet.d.ts +67 -67
  101. package/dist/wallets/IBitcoinWallet.js +2 -2
  102. package/dist/wallets/ILightningWallet.d.ts +117 -117
  103. package/dist/wallets/ILightningWallet.js +37 -37
  104. package/dist/wallets/ISpvVaultSigner.d.ts +7 -7
  105. package/dist/wallets/ISpvVaultSigner.js +2 -2
  106. package/dist/wallets/ISpvVaultWallet.d.ts +42 -0
  107. package/dist/wallets/ISpvVaultWallet.js +2 -0
  108. package/package.json +36 -36
  109. package/src/fees/IBtcFeeEstimator.ts +6 -6
  110. package/src/index.ts +51 -53
  111. package/src/info/InfoHandler.ts +106 -106
  112. package/src/plugins/IPlugin.ts +168 -168
  113. package/src/plugins/PluginManager.ts +336 -336
  114. package/src/prices/BinanceSwapPrice.ts +113 -113
  115. package/src/prices/CoinGeckoSwapPrice.ts +87 -87
  116. package/src/prices/ISwapPrice.ts +88 -88
  117. package/src/prices/OKXSwapPrice.ts +113 -113
  118. package/src/storage/IIntermediaryStorage.ts +19 -19
  119. package/src/storagemanager/IntermediaryStorageManager.ts +109 -118
  120. package/src/storagemanager/StorageManager.ts +68 -78
  121. package/src/swaps/SwapHandler.ts +280 -277
  122. package/src/swaps/SwapHandlerSwap.ts +141 -141
  123. package/src/swaps/assertions/AmountAssertions.ts +76 -76
  124. package/src/swaps/assertions/FromBtcAmountAssertions.ts +238 -238
  125. package/src/swaps/assertions/LightningAssertions.ts +103 -103
  126. package/src/swaps/assertions/ToBtcAmountAssertions.ts +203 -203
  127. package/src/swaps/escrow/EscrowHandler.ts +179 -179
  128. package/src/swaps/escrow/EscrowHandlerSwap.ts +86 -86
  129. package/src/swaps/escrow/FromBtcBaseSwap.ts +38 -38
  130. package/src/swaps/escrow/FromBtcBaseSwapHandler.ts +283 -286
  131. package/src/swaps/escrow/ToBtcBaseSwap.ts +85 -85
  132. package/src/swaps/escrow/ToBtcBaseSwapHandler.ts +129 -129
  133. package/src/swaps/escrow/frombtc_abstract/FromBtcAbs.ts +452 -452
  134. package/src/swaps/escrow/frombtc_abstract/FromBtcSwapAbs.ts +61 -61
  135. package/src/swaps/escrow/frombtcln_abstract/FromBtcLnAbs.ts +856 -828
  136. package/src/swaps/escrow/frombtcln_abstract/FromBtcLnSwapAbs.ts +137 -141
  137. package/src/swaps/escrow/tobtc_abstract/ToBtcAbs.ts +879 -879
  138. package/src/swaps/escrow/tobtc_abstract/ToBtcSwapAbs.ts +102 -102
  139. package/src/swaps/escrow/tobtcln_abstract/ToBtcLnAbs.ts +1110 -1110
  140. package/src/swaps/escrow/tobtcln_abstract/ToBtcLnSwapAbs.ts +77 -77
  141. package/src/swaps/spv_vault_swap/SpvVault.ts +143 -143
  142. package/src/swaps/spv_vault_swap/SpvVaultSwap.ts +225 -225
  143. package/src/swaps/spv_vault_swap/SpvVaultSwapHandler.ts +627 -626
  144. package/src/swaps/spv_vault_swap/SpvVaults.ts +440 -435
  145. package/src/swaps/trusted/frombtc_trusted/FromBtcTrusted.ts +747 -747
  146. package/src/swaps/trusted/frombtc_trusted/FromBtcTrustedSwap.ts +185 -185
  147. package/src/swaps/trusted/frombtcln_trusted/FromBtcLnTrusted.ts +592 -590
  148. package/src/swaps/trusted/frombtcln_trusted/FromBtcLnTrustedSwap.ts +121 -121
  149. package/src/utils/Utils.ts +102 -104
  150. package/src/utils/paramcoders/IParamReader.ts +7 -7
  151. package/src/utils/paramcoders/IParamWriter.ts +8 -8
  152. package/src/utils/paramcoders/LegacyParamEncoder.ts +27 -27
  153. package/src/utils/paramcoders/ParamDecoder.ts +218 -218
  154. package/src/utils/paramcoders/ParamEncoder.ts +29 -29
  155. package/src/utils/paramcoders/SchemaVerifier.ts +96 -96
  156. package/src/utils/paramcoders/server/ServerParamDecoder.ts +115 -118
  157. package/src/utils/paramcoders/server/ServerParamEncoder.ts +75 -75
  158. package/src/wallets/IBitcoinWallet.ts +68 -68
  159. package/src/wallets/ILightningWallet.ts +178 -178
  160. package/src/wallets/ISpvVaultSigner.ts +10 -10
  161. package/dist/swaps/escrow/frombtcln_autoinit/FromBtcLnAuto.d.ts +0 -104
  162. package/dist/swaps/escrow/frombtcln_autoinit/FromBtcLnAuto.js +0 -629
  163. package/dist/swaps/escrow/frombtcln_autoinit/FromBtcLnAutoSwap.d.ts +0 -54
  164. package/dist/swaps/escrow/frombtcln_autoinit/FromBtcLnAutoSwap.js +0 -117
  165. package/src/swaps/escrow/frombtcln_autoinit/FromBtcLnAuto.ts +0 -789
  166. package/src/swaps/escrow/frombtcln_autoinit/FromBtcLnAutoSwap.ts +0 -192
@@ -1,69 +1,69 @@
1
- import {BtcTx} from "@atomiqlabs/base";
2
- import {Command} from "@atomiqlabs/server-base";
3
- import {Transaction} from "@scure/btc-signer";
4
-
5
- export type BitcoinUtxo = {
6
- address: string,
7
- type: "p2wpkh" | "p2sh-p2wpkh" | "p2tr",
8
- confirmations: number,
9
- outputScript: Buffer,
10
- value: number,
11
- txId: string,
12
- vout: number
13
- };
14
-
15
- export type SignPsbtResponse = {
16
- psbt: Transaction,
17
- tx: Transaction,
18
- raw: string,
19
- txId: string,
20
- networkFee: number
21
- };
22
-
23
- export interface IBitcoinWallet {
24
-
25
- init(): Promise<void>;
26
-
27
- isReady(): boolean;
28
- getStatus(): string;
29
- getStatusInfo(): Promise<Record<string, string>>;
30
- getCommands(): Command<any>[];
31
-
32
- toOutputScript(address: string): Buffer;
33
-
34
- getAddressType(): "p2wpkh" | "p2sh-p2wpkh" | "p2tr";
35
- /**
36
- * Returns an unused address suitable for receiving
37
- */
38
- getAddress(): Promise<string>;
39
- /**
40
- * Adds previously returned address (with getAddress call), to the pool of unused addresses
41
- * @param address
42
- */
43
- addUnusedAddress(address: string): Promise<void>;
44
-
45
- getUtxos(): Promise<BitcoinUtxo[]>;
46
- getBalance(): Promise<{confirmed: number, unconfirmed: number}>;
47
- /**
48
- * Returns required reserve amount that needs to be kept in the wallet (for e.g. lightning anchor channels)
49
- */
50
- getRequiredReserve(): Promise<number>;
51
- getWalletTransactions(startHeight?: number): Promise<BtcTx[]>;
52
- getWalletTransaction(txId: string): Promise<BtcTx | null>;
53
- subscribeToWalletTransactions(callback: (tx: BtcTx) => void, abortSignal?: AbortSignal): void;
54
-
55
- fundPsbt(psbt: Transaction, feeRate?: number): Promise<Transaction>;
56
- signPsbt(psbt: Transaction): Promise<SignPsbtResponse>;
57
- sendRawTransaction(tx: string): Promise<void>;
58
- getSignedTransaction(destination: string, amount: number, feeRate?: number, nonce?: bigint, maxAllowedFeeRate?: number): Promise<SignPsbtResponse>;
59
- getSignedMultiTransaction(destinations: {address: string, amount: number}[], feeRate?: number, nonce?: bigint, maxAllowedFeeRate?: number): Promise<SignPsbtResponse>;
60
- estimateFee(destination: string, amount: number, feeRate?: number, feeRateMultiplier?: number): Promise<{satsPerVbyte: number, networkFee: number}>;
61
- drainAll(destination: string | Buffer, inputs: Omit<BitcoinUtxo, "address">[], feeRate?: number): Promise<SignPsbtResponse>;
62
- burnAll(inputs: Omit<BitcoinUtxo, "address">[]): Promise<SignPsbtResponse>;
63
-
64
- parsePsbt(psbt: Transaction): Promise<BtcTx>;
65
-
66
- getBlockheight(): Promise<number>;
67
- getFeeRate(): Promise<number>;
68
-
1
+ import {BtcTx} from "@atomiqlabs/base";
2
+ import {Command} from "@atomiqlabs/server-base";
3
+ import {Transaction} from "@scure/btc-signer";
4
+
5
+ export type BitcoinUtxo = {
6
+ address: string,
7
+ type: "p2wpkh" | "p2sh-p2wpkh" | "p2tr",
8
+ confirmations: number,
9
+ outputScript: Buffer,
10
+ value: number,
11
+ txId: string,
12
+ vout: number
13
+ };
14
+
15
+ export type SignPsbtResponse = {
16
+ psbt: Transaction,
17
+ tx: Transaction,
18
+ raw: string,
19
+ txId: string,
20
+ networkFee: number
21
+ };
22
+
23
+ export interface IBitcoinWallet {
24
+
25
+ init(): Promise<void>;
26
+
27
+ isReady(): boolean;
28
+ getStatus(): string;
29
+ getStatusInfo(): Promise<Record<string, string>>;
30
+ getCommands(): Command<any>[];
31
+
32
+ toOutputScript(address: string): Buffer;
33
+
34
+ getAddressType(): "p2wpkh" | "p2sh-p2wpkh" | "p2tr";
35
+ /**
36
+ * Returns an unused address suitable for receiving
37
+ */
38
+ getAddress(): Promise<string>;
39
+ /**
40
+ * Adds previously returned address (with getAddress call), to the pool of unused addresses
41
+ * @param address
42
+ */
43
+ addUnusedAddress(address: string): Promise<void>;
44
+
45
+ getUtxos(): Promise<BitcoinUtxo[]>;
46
+ getBalance(): Promise<{confirmed: number, unconfirmed: number}>;
47
+ /**
48
+ * Returns required reserve amount that needs to be kept in the wallet (for e.g. lightning anchor channels)
49
+ */
50
+ getRequiredReserve(): Promise<number>;
51
+ getWalletTransactions(startHeight?: number): Promise<BtcTx[]>;
52
+ getWalletTransaction(txId: string): Promise<BtcTx | null>;
53
+ subscribeToWalletTransactions(callback: (tx: BtcTx) => void, abortSignal?: AbortSignal): void;
54
+
55
+ fundPsbt(psbt: Transaction, feeRate?: number): Promise<Transaction>;
56
+ signPsbt(psbt: Transaction): Promise<SignPsbtResponse>;
57
+ sendRawTransaction(tx: string): Promise<void>;
58
+ getSignedTransaction(destination: string, amount: number, feeRate?: number, nonce?: bigint, maxAllowedFeeRate?: number): Promise<SignPsbtResponse>;
59
+ getSignedMultiTransaction(destinations: {address: string, amount: number}[], feeRate?: number, nonce?: bigint, maxAllowedFeeRate?: number): Promise<SignPsbtResponse>;
60
+ estimateFee(destination: string, amount: number, feeRate?: number, feeRateMultiplier?: number): Promise<{satsPerVbyte: number, networkFee: number}>;
61
+ drainAll(destination: string | Buffer, inputs: Omit<BitcoinUtxo, "address">[], feeRate?: number): Promise<SignPsbtResponse>;
62
+ burnAll(inputs: Omit<BitcoinUtxo, "address">[]): Promise<SignPsbtResponse>;
63
+
64
+ parsePsbt(psbt: Transaction): Promise<BtcTx>;
65
+
66
+ getBlockheight(): Promise<number>;
67
+ getFeeRate(): Promise<number>;
68
+
69
69
  }
@@ -1,178 +1,178 @@
1
- import {Command} from "@atomiqlabs/server-base";
2
-
3
- export type IncomingLightningNetworkPayment = {
4
- createdAt: number,
5
- confirmedAt: number,
6
-
7
- createdHeight: number,
8
- timeout: number,
9
-
10
- status: "held" | "canceled" | "confirmed"
11
-
12
- mtokens: bigint
13
- }
14
-
15
- export type LightningNetworkInvoice = {
16
- id: string,
17
- request: string,
18
- secret?: string,
19
-
20
- cltvDelta: number,
21
- mtokens: bigint,
22
-
23
- createdAt: number,
24
- expiresAt: number,
25
-
26
- description: string,
27
- descriptionHash?: string,
28
-
29
- payments: IncomingLightningNetworkPayment[],
30
-
31
- status: "unpaid" | "held" | "canceled" | "confirmed"
32
- };
33
-
34
- export type OutgoingLightningNetworkPayment = {
35
- failedReason?: "insufficient_balance" | "invalid_payment" | "pathfinding_timeout" | "route_not_found",
36
- status: "confirmed" | "failed" | "pending",
37
- secret?: string,
38
- feeMtokens?: bigint
39
- };
40
-
41
- export type LightningNetworkChannel = {
42
- id: string,
43
- capacity: bigint,
44
- isActive: boolean,
45
-
46
- localBalance: bigint,
47
- localReserve: bigint,
48
- remoteBalance: bigint,
49
- remoteReserve: bigint,
50
- unsettledBalance: bigint,
51
- transactionId: string,
52
- transactionVout: number
53
- };
54
-
55
- export type InvoiceInit = {
56
- mtokens: bigint,
57
- descriptionHash?: string
58
- description?: string,
59
- cltvDelta?: number,
60
- expiresAt?: number,
61
- };
62
-
63
- export type HodlInvoiceInit = {
64
- description: string,
65
- cltvDelta: number,
66
- expiresAt: number,
67
- id: string,
68
- mtokens: bigint,
69
- descriptionHash?: string
70
- };
71
-
72
- export type LNRoutes = {
73
- publicKey: string,
74
- feeRate?: number,
75
- cltvDelta?: number,
76
- channel?: string,
77
- baseFeeMtokens?: bigint
78
- }[][];
79
-
80
- export type ParsedPaymentRequest = {
81
- id: string,
82
- mtokens: bigint,
83
- expiryEpochMillis: number,
84
- destination: string,
85
- cltvDelta: number,
86
- description: string,
87
- routes: LNRoutes
88
- };
89
-
90
- export type LightningPaymentInit = {
91
- request: string,
92
- maxFeeMtokens?: bigint,
93
- maxTimeoutHeight?: number
94
- };
95
-
96
- export type LightningBalanceResponse = {
97
- localBalance: bigint,
98
- remoteBalance: bigint,
99
- unsettledBalance: bigint
100
- };
101
-
102
- export type ProbeAndRouteInit = {
103
- request: string,
104
- amountMtokens: bigint,
105
- maxFeeMtokens: bigint,
106
- maxTimeoutHeight: number
107
- }
108
-
109
- export type ProbeAndRouteResponse = {
110
- confidence: number,
111
- feeMtokens: bigint,
112
- destination: string,
113
- privateRoutes: LNRoutes
114
- }
115
-
116
- export function routesMatch(routesA: LNRoutes, routesB: LNRoutes) {
117
- if(routesA===routesB) return true;
118
- if(routesA==null || routesB==null) {
119
- return false;
120
- }
121
- if(routesA.length!==routesB.length) return false;
122
- for(let i=0;i<routesA.length;i++) {
123
- if(routesA[i]===routesB[i]) continue;
124
- if(routesA[i]==null || routesB[i]==null) {
125
- return false;
126
- }
127
- if(routesA[i].length!==routesB[i].length) return false;
128
- for(let e=0;e<routesA[i].length;e++) {
129
- if(routesA[i][e]===routesB[i][e]) continue;
130
- if(routesA[i][e]==null || routesB[i][e]==null) {
131
- return false;
132
- }
133
- if(
134
- routesA[i][e].publicKey!==routesB[i][e].publicKey ||
135
- routesA[i][e].baseFeeMtokens!==routesB[i][e].baseFeeMtokens ||
136
- routesA[i][e].channel!==routesB[i][e].channel ||
137
- routesA[i][e].cltvDelta!==routesB[i][e].cltvDelta ||
138
- routesA[i][e].feeRate!==routesB[i][e].feeRate
139
- ) {
140
- return false;
141
- }
142
- }
143
- }
144
-
145
- return true;
146
- }
147
-
148
- export interface ILightningWallet {
149
-
150
- init(): Promise<void>;
151
-
152
- isReady(): boolean;
153
- getStatus(): string;
154
- getStatusInfo(): Promise<Record<string, string>>;
155
- getCommands(): Command<any>[];
156
-
157
- createInvoice(init: InvoiceInit): Promise<LightningNetworkInvoice>;
158
- createHodlInvoice(init: HodlInvoiceInit): Promise<LightningNetworkInvoice>;
159
- getInvoice(paymentHash: string): Promise<LightningNetworkInvoice | null>;
160
- cancelHodlInvoice(paymentHash: string): Promise<void>;
161
- settleHodlInvoice(secret: string): Promise<void>;
162
- waitForInvoice(paymentHash: string, abortSignal?: AbortSignal): Promise<LightningNetworkInvoice>;
163
-
164
- pay(init: LightningPaymentInit): Promise<void>;
165
- getPayment(paymentHash: string): Promise<OutgoingLightningNetworkPayment | null>
166
- waitForPayment(paymentHash: string, abortSignal?: AbortSignal): Promise<OutgoingLightningNetworkPayment>;
167
- probe(init: ProbeAndRouteInit): Promise<ProbeAndRouteResponse | null>;
168
- route(init: ProbeAndRouteInit): Promise<ProbeAndRouteResponse | null>;
169
-
170
- parsePaymentRequest(request: string): Promise<ParsedPaymentRequest>;
171
-
172
- getBlockheight(): Promise<number>;
173
- getChannels(activeOnly?: boolean): Promise<LightningNetworkChannel[]>;
174
- getLightningBalance(): Promise<LightningBalanceResponse>;
175
-
176
- getIdentityPublicKey(): Promise<string>;
177
-
178
- }
1
+ import {Command} from "@atomiqlabs/server-base";
2
+
3
+ export type IncomingLightningNetworkPayment = {
4
+ createdAt: number,
5
+ confirmedAt: number,
6
+
7
+ createdHeight: number,
8
+ timeout: number,
9
+
10
+ status: "held" | "canceled" | "confirmed"
11
+
12
+ mtokens: bigint
13
+ }
14
+
15
+ export type LightningNetworkInvoice = {
16
+ id: string,
17
+ request: string,
18
+ secret?: string,
19
+
20
+ cltvDelta: number,
21
+ mtokens: bigint,
22
+
23
+ createdAt: number,
24
+ expiresAt: number,
25
+
26
+ description: string,
27
+ descriptionHash?: string,
28
+
29
+ payments: IncomingLightningNetworkPayment[],
30
+
31
+ status: "unpaid" | "held" | "canceled" | "confirmed"
32
+ };
33
+
34
+ export type OutgoingLightningNetworkPayment = {
35
+ failedReason?: "insufficient_balance" | "invalid_payment" | "pathfinding_timeout" | "route_not_found",
36
+ status: "confirmed" | "failed" | "pending",
37
+ secret?: string,
38
+ feeMtokens?: bigint
39
+ };
40
+
41
+ export type LightningNetworkChannel = {
42
+ id: string,
43
+ capacity: bigint,
44
+ isActive: boolean,
45
+
46
+ localBalance: bigint,
47
+ localReserve: bigint,
48
+ remoteBalance: bigint,
49
+ remoteReserve: bigint,
50
+ unsettledBalance: bigint,
51
+ transactionId: string,
52
+ transactionVout: number
53
+ };
54
+
55
+ export type InvoiceInit = {
56
+ mtokens: bigint,
57
+ descriptionHash?: string
58
+ description?: string,
59
+ cltvDelta?: number,
60
+ expiresAt?: number,
61
+ };
62
+
63
+ export type HodlInvoiceInit = {
64
+ description: string,
65
+ cltvDelta: number,
66
+ expiresAt: number,
67
+ id: string,
68
+ mtokens: bigint,
69
+ descriptionHash?: string
70
+ };
71
+
72
+ export type LNRoutes = {
73
+ publicKey: string,
74
+ feeRate?: number,
75
+ cltvDelta?: number,
76
+ channel?: string,
77
+ baseFeeMtokens?: bigint
78
+ }[][];
79
+
80
+ export type ParsedPaymentRequest = {
81
+ id: string,
82
+ mtokens: bigint,
83
+ expiryEpochMillis: number,
84
+ destination: string,
85
+ cltvDelta: number,
86
+ description: string,
87
+ routes: LNRoutes
88
+ };
89
+
90
+ export type LightningPaymentInit = {
91
+ request: string,
92
+ maxFeeMtokens?: bigint,
93
+ maxTimeoutHeight?: number
94
+ };
95
+
96
+ export type LightningBalanceResponse = {
97
+ localBalance: bigint,
98
+ remoteBalance: bigint,
99
+ unsettledBalance: bigint
100
+ };
101
+
102
+ export type ProbeAndRouteInit = {
103
+ request: string,
104
+ amountMtokens: bigint,
105
+ maxFeeMtokens: bigint,
106
+ maxTimeoutHeight: number
107
+ }
108
+
109
+ export type ProbeAndRouteResponse = {
110
+ confidence: number,
111
+ feeMtokens: bigint,
112
+ destination: string,
113
+ privateRoutes: LNRoutes
114
+ }
115
+
116
+ export function routesMatch(routesA: LNRoutes, routesB: LNRoutes) {
117
+ if(routesA===routesB) return true;
118
+ if(routesA==null || routesB==null) {
119
+ return false;
120
+ }
121
+ if(routesA.length!==routesB.length) return false;
122
+ for(let i=0;i<routesA.length;i++) {
123
+ if(routesA[i]===routesB[i]) continue;
124
+ if(routesA[i]==null || routesB[i]==null) {
125
+ return false;
126
+ }
127
+ if(routesA[i].length!==routesB[i].length) return false;
128
+ for(let e=0;e<routesA[i].length;e++) {
129
+ if(routesA[i][e]===routesB[i][e]) continue;
130
+ if(routesA[i][e]==null || routesB[i][e]==null) {
131
+ return false;
132
+ }
133
+ if(
134
+ routesA[i][e].publicKey!==routesB[i][e].publicKey ||
135
+ routesA[i][e].baseFeeMtokens!==routesB[i][e].baseFeeMtokens ||
136
+ routesA[i][e].channel!==routesB[i][e].channel ||
137
+ routesA[i][e].cltvDelta!==routesB[i][e].cltvDelta ||
138
+ routesA[i][e].feeRate!==routesB[i][e].feeRate
139
+ ) {
140
+ return false;
141
+ }
142
+ }
143
+ }
144
+
145
+ return true;
146
+ }
147
+
148
+ export interface ILightningWallet {
149
+
150
+ init(): Promise<void>;
151
+
152
+ isReady(): boolean;
153
+ getStatus(): string;
154
+ getStatusInfo(): Promise<Record<string, string>>;
155
+ getCommands(): Command<any>[];
156
+
157
+ createInvoice(init: InvoiceInit): Promise<LightningNetworkInvoice>;
158
+ createHodlInvoice(init: HodlInvoiceInit): Promise<LightningNetworkInvoice>;
159
+ getInvoice(paymentHash: string): Promise<LightningNetworkInvoice | null>;
160
+ cancelHodlInvoice(paymentHash: string): Promise<void>;
161
+ settleHodlInvoice(secret: string): Promise<void>;
162
+ waitForInvoice(paymentHash: string, abortSignal?: AbortSignal): Promise<LightningNetworkInvoice>;
163
+
164
+ pay(init: LightningPaymentInit): Promise<void>;
165
+ getPayment(paymentHash: string): Promise<OutgoingLightningNetworkPayment | null>
166
+ waitForPayment(paymentHash: string, abortSignal?: AbortSignal): Promise<OutgoingLightningNetworkPayment>;
167
+ probe(init: ProbeAndRouteInit): Promise<ProbeAndRouteResponse | null>;
168
+ route(init: ProbeAndRouteInit): Promise<ProbeAndRouteResponse | null>;
169
+
170
+ parsePaymentRequest(request: string): Promise<ParsedPaymentRequest>;
171
+
172
+ getBlockheight(): Promise<number>;
173
+ getChannels(activeOnly?: boolean): Promise<LightningNetworkChannel[]>;
174
+ getLightningBalance(): Promise<LightningBalanceResponse>;
175
+
176
+ getIdentityPublicKey(): Promise<string>;
177
+
178
+ }
@@ -1,11 +1,11 @@
1
- import {Transaction} from "@scure/btc-signer";
2
-
3
- export interface ISpvVaultSigner {
4
-
5
- init(): Promise<void>;
6
-
7
- getAddressType(): "p2wpkh" | "p2tr";
8
- getAddress(chainId: string, vaultId: bigint): Promise<string>;
9
- signPsbt(chainId: string, vaultId: bigint, psbt: Transaction, inputs: number[]): Promise<Transaction>;
10
-
1
+ import {Transaction} from "@scure/btc-signer";
2
+
3
+ export interface ISpvVaultSigner {
4
+
5
+ init(): Promise<void>;
6
+
7
+ getAddressType(): "p2wpkh" | "p2tr";
8
+ getAddress(chainId: string, vaultId: bigint): Promise<string>;
9
+ signPsbt(chainId: string, vaultId: bigint, psbt: Transaction, inputs: number[]): Promise<Transaction>;
10
+
11
11
  }
@@ -1,104 +0,0 @@
1
- import { Express } from "express";
2
- import { FromBtcLnAutoSwap, FromBtcLnAutoSwapState } from "./FromBtcLnAutoSwap";
3
- import { MultichainData, SwapHandlerType } from "../../SwapHandler";
4
- import { ISwapPrice } from "../../../prices/ISwapPrice";
5
- import { ChainSwapType, ClaimEvent, InitializeEvent, RefundEvent, SwapData } from "@atomiqlabs/base";
6
- import { IIntermediaryStorage } from "../../../storage/IIntermediaryStorage";
7
- import { FromBtcBaseConfig, FromBtcBaseSwapHandler } from "../FromBtcBaseSwapHandler";
8
- import { ILightningWallet } from "../../../wallets/ILightningWallet";
9
- import { LightningAssertions } from "../../assertions/LightningAssertions";
10
- export type FromBtcLnAutoConfig = FromBtcBaseConfig & {
11
- invoiceTimeoutSeconds?: number;
12
- minCltv: bigint;
13
- gracePeriod: bigint;
14
- gasTokenMax: {
15
- [chainId: string]: bigint;
16
- };
17
- };
18
- export type FromBtcLnAutoRequestType = {
19
- address: string;
20
- paymentHash: string;
21
- amount: bigint;
22
- token: string;
23
- gasToken: string;
24
- gasAmount: bigint;
25
- claimerBounty: bigint;
26
- descriptionHash?: string;
27
- exactOut?: boolean;
28
- };
29
- /**
30
- * Swap handler handling from BTCLN swaps using submarine swaps
31
- */
32
- export declare class FromBtcLnAuto extends FromBtcBaseSwapHandler<FromBtcLnAutoSwap, FromBtcLnAutoSwapState> {
33
- readonly type = SwapHandlerType.FROM_BTCLN_AUTO;
34
- readonly swapType = ChainSwapType.HTLC;
35
- readonly config: FromBtcLnAutoConfig;
36
- readonly lightning: ILightningWallet;
37
- readonly LightningAssertions: LightningAssertions;
38
- constructor(storageDirectory: IIntermediaryStorage<FromBtcLnAutoSwap>, path: string, chains: MultichainData, lightning: ILightningWallet, swapPricing: ISwapPrice, config: FromBtcLnAutoConfig);
39
- protected processPastSwap(swap: FromBtcLnAutoSwap): Promise<"REFUND" | "SETTLE" | null>;
40
- protected refundSwaps(refundSwaps: FromBtcLnAutoSwap[]): Promise<void>;
41
- protected settleInvoices(swaps: FromBtcLnAutoSwap[]): Promise<void>;
42
- /**
43
- * Checks past swaps, refunds and deletes ones that are already expired.
44
- */
45
- protected processPastSwaps(): Promise<void>;
46
- protected processInitializeEvent(chainIdentifier: string, savedSwap: FromBtcLnAutoSwap, event: InitializeEvent<SwapData>): Promise<void>;
47
- protected processClaimEvent(chainIdentifier: string, savedSwap: FromBtcLnAutoSwap, event: ClaimEvent<SwapData>): Promise<void>;
48
- protected processRefundEvent(chainIdentifier: string, savedSwap: FromBtcLnAutoSwap, event: RefundEvent<SwapData>): Promise<void>;
49
- /**
50
- * Called when lightning HTLC is received, also signs an init transaction on the smart chain side, expiry of the
51
- * smart chain authorization starts ticking as soon as this HTLC is received
52
- *
53
- * @param invoiceData
54
- * @param invoice
55
- */
56
- private htlcReceived;
57
- private offerHtlc;
58
- /**
59
- * Checks invoice description hash
60
- *
61
- * @param descriptionHash
62
- * @throws {DefinedRuntimeError} will throw an error if the description hash is invalid
63
- */
64
- private checkDescriptionHash;
65
- /**
66
- * Asynchronously sends the LN node's public key to the client, so he can pre-fetch the node's channels from 1ml api
67
- *
68
- * @param responseStream
69
- */
70
- private sendPublicKeyAsync;
71
- /**
72
- * Returns the CLTV timeout (blockheight) of the received HTLC corresponding to the invoice. If multiple HTLCs are
73
- * received (MPP) it returns the lowest of the timeouts
74
- *
75
- * @param invoice
76
- */
77
- private getInvoicePaymentsTimeout;
78
- /**
79
- * Checks if the received HTLC's CLTV timeout is large enough to still process the swap
80
- *
81
- * @param invoice
82
- * @throws {DefinedRuntimeError} Will throw if HTLC expires too soon and therefore cannot be processed
83
- * @returns expiry timeout in seconds
84
- */
85
- private checkHtlcExpiry;
86
- /**
87
- * Cancels the swap (CANCELED state) & also cancels the LN invoice (including all pending HTLCs)
88
- *
89
- * @param invoiceData
90
- */
91
- private cancelSwapAndInvoice;
92
- /**
93
- *
94
- * Checks if the lightning invoice is in HELD state (htlcs received but yet unclaimed)
95
- *
96
- * @param paymentHash
97
- * @throws {DefinedRuntimeError} Will throw if the lightning invoice is not found, or if it isn't in the HELD state
98
- * @returns the fetched lightning invoice
99
- */
100
- private checkInvoiceStatus;
101
- startRestServer(restServer: Express): void;
102
- init(): Promise<void>;
103
- getInfoData(): any;
104
- }