@atomiqlabs/lp-lib 16.2.0 → 16.2.1
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.
- package/LICENSE +201 -201
- package/dist/fees/IBtcFeeEstimator.d.ts +3 -3
- package/dist/fees/IBtcFeeEstimator.js +2 -2
- package/dist/index.d.ts +42 -42
- package/dist/index.js +58 -58
- package/dist/info/InfoHandler.d.ts +17 -17
- package/dist/info/InfoHandler.js +60 -60
- package/dist/plugins/IPlugin.d.ts +144 -144
- package/dist/plugins/IPlugin.js +34 -34
- package/dist/plugins/PluginManager.d.ts +113 -113
- package/dist/plugins/PluginManager.js +274 -274
- package/dist/prices/BinanceSwapPrice.d.ts +29 -29
- package/dist/prices/BinanceSwapPrice.js +79 -79
- package/dist/prices/CoinGeckoSwapPrice.d.ts +33 -33
- package/dist/prices/CoinGeckoSwapPrice.js +51 -51
- package/dist/prices/ISwapPrice.d.ts +43 -43
- package/dist/prices/ISwapPrice.js +55 -55
- package/dist/prices/OKXSwapPrice.d.ts +29 -29
- package/dist/prices/OKXSwapPrice.js +79 -79
- package/dist/storage/IIntermediaryStorage.d.ts +18 -18
- package/dist/storage/IIntermediaryStorage.js +2 -2
- package/dist/storagemanager/IntermediaryStorageManager.d.ts +19 -19
- package/dist/storagemanager/IntermediaryStorageManager.js +111 -111
- package/dist/storagemanager/StorageManager.d.ts +13 -13
- package/dist/storagemanager/StorageManager.js +64 -64
- package/dist/swaps/SwapHandler.d.ts +171 -171
- package/dist/swaps/SwapHandler.js +217 -217
- package/dist/swaps/SwapHandlerSwap.d.ts +79 -79
- package/dist/swaps/SwapHandlerSwap.js +78 -78
- package/dist/swaps/assertions/AmountAssertions.d.ts +28 -28
- package/dist/swaps/assertions/AmountAssertions.js +74 -74
- package/dist/swaps/assertions/FromBtcAmountAssertions.d.ts +76 -76
- package/dist/swaps/assertions/FromBtcAmountAssertions.js +185 -185
- package/dist/swaps/assertions/LightningAssertions.d.ts +44 -44
- package/dist/swaps/assertions/LightningAssertions.js +86 -86
- package/dist/swaps/assertions/ToBtcAmountAssertions.d.ts +53 -53
- package/dist/swaps/assertions/ToBtcAmountAssertions.js +150 -150
- package/dist/swaps/escrow/EscrowHandler.d.ts +50 -50
- package/dist/swaps/escrow/EscrowHandler.js +151 -151
- package/dist/swaps/escrow/EscrowHandlerSwap.d.ts +35 -35
- package/dist/swaps/escrow/EscrowHandlerSwap.js +69 -69
- package/dist/swaps/escrow/FromBtcBaseSwap.d.ts +14 -14
- package/dist/swaps/escrow/FromBtcBaseSwap.js +32 -32
- package/dist/swaps/escrow/FromBtcBaseSwapHandler.d.ts +102 -102
- package/dist/swaps/escrow/FromBtcBaseSwapHandler.js +210 -210
- package/dist/swaps/escrow/ToBtcBaseSwap.d.ts +36 -36
- package/dist/swaps/escrow/ToBtcBaseSwap.js +67 -67
- package/dist/swaps/escrow/ToBtcBaseSwapHandler.d.ts +53 -53
- package/dist/swaps/escrow/ToBtcBaseSwapHandler.js +81 -81
- package/dist/swaps/escrow/frombtc_abstract/FromBtcAbs.d.ts +84 -84
- package/dist/swaps/escrow/frombtc_abstract/FromBtcAbs.js +322 -322
- package/dist/swaps/escrow/frombtc_abstract/FromBtcSwapAbs.d.ts +21 -21
- package/dist/swaps/escrow/frombtc_abstract/FromBtcSwapAbs.js +50 -50
- package/dist/swaps/escrow/frombtcln_abstract/FromBtcLnAbs.d.ts +108 -108
- package/dist/swaps/escrow/frombtcln_abstract/FromBtcLnAbs.js +695 -695
- package/dist/swaps/escrow/frombtcln_abstract/FromBtcLnSwapAbs.d.ts +33 -33
- package/dist/swaps/escrow/frombtcln_abstract/FromBtcLnSwapAbs.js +91 -91
- package/dist/swaps/escrow/frombtcln_autoinit/FromBtcLnAuto.d.ts +112 -112
- package/dist/swaps/escrow/frombtcln_autoinit/FromBtcLnAuto.js +708 -708
- package/dist/swaps/escrow/frombtcln_autoinit/FromBtcLnAutoSwap.d.ts +55 -55
- package/dist/swaps/escrow/frombtcln_autoinit/FromBtcLnAutoSwap.js +120 -120
- package/dist/swaps/escrow/tobtc_abstract/ToBtcAbs.d.ts +170 -170
- package/dist/swaps/escrow/tobtc_abstract/ToBtcAbs.js +745 -745
- package/dist/swaps/escrow/tobtc_abstract/ToBtcSwapAbs.d.ts +28 -28
- package/dist/swaps/escrow/tobtc_abstract/ToBtcSwapAbs.js +64 -64
- package/dist/swaps/escrow/tobtcln_abstract/ToBtcLnAbs.d.ts +178 -178
- package/dist/swaps/escrow/tobtcln_abstract/ToBtcLnAbs.js +900 -899
- package/dist/swaps/escrow/tobtcln_abstract/ToBtcLnSwapAbs.d.ts +24 -24
- package/dist/swaps/escrow/tobtcln_abstract/ToBtcLnSwapAbs.js +58 -58
- package/dist/swaps/spv_vault_swap/SpvVault.d.ts +44 -44
- package/dist/swaps/spv_vault_swap/SpvVault.js +145 -145
- package/dist/swaps/spv_vault_swap/SpvVaultSwap.d.ts +68 -68
- package/dist/swaps/spv_vault_swap/SpvVaultSwap.js +158 -158
- package/dist/swaps/spv_vault_swap/SpvVaultSwapHandler.d.ts +68 -68
- package/dist/swaps/spv_vault_swap/SpvVaultSwapHandler.js +561 -561
- package/dist/swaps/spv_vault_swap/SpvVaults.d.ts +63 -63
- package/dist/swaps/spv_vault_swap/SpvVaults.js +491 -491
- package/dist/swaps/trusted/frombtc_trusted/FromBtcTrusted.d.ts +52 -52
- package/dist/swaps/trusted/frombtc_trusted/FromBtcTrusted.js +662 -662
- package/dist/swaps/trusted/frombtc_trusted/FromBtcTrustedSwap.d.ts +52 -52
- package/dist/swaps/trusted/frombtc_trusted/FromBtcTrustedSwap.js +118 -118
- package/dist/swaps/trusted/frombtcln_trusted/FromBtcLnTrusted.d.ts +77 -77
- package/dist/swaps/trusted/frombtcln_trusted/FromBtcLnTrusted.js +504 -504
- package/dist/swaps/trusted/frombtcln_trusted/FromBtcLnTrustedSwap.d.ts +34 -34
- package/dist/swaps/trusted/frombtcln_trusted/FromBtcLnTrustedSwap.js +81 -81
- package/dist/utils/BitcoinUtils.d.ts +4 -4
- package/dist/utils/BitcoinUtils.js +61 -61
- package/dist/utils/Utils.d.ts +32 -32
- package/dist/utils/Utils.js +129 -129
- package/dist/utils/paramcoders/IParamReader.d.ts +5 -5
- package/dist/utils/paramcoders/IParamReader.js +2 -2
- package/dist/utils/paramcoders/IParamWriter.d.ts +4 -4
- package/dist/utils/paramcoders/IParamWriter.js +2 -2
- package/dist/utils/paramcoders/LegacyParamEncoder.d.ts +10 -10
- package/dist/utils/paramcoders/LegacyParamEncoder.js +22 -22
- package/dist/utils/paramcoders/ParamDecoder.d.ts +25 -25
- package/dist/utils/paramcoders/ParamDecoder.js +222 -222
- package/dist/utils/paramcoders/ParamEncoder.d.ts +9 -9
- package/dist/utils/paramcoders/ParamEncoder.js +22 -22
- package/dist/utils/paramcoders/SchemaVerifier.d.ts +21 -21
- package/dist/utils/paramcoders/SchemaVerifier.js +84 -84
- package/dist/utils/paramcoders/server/ServerParamDecoder.d.ts +8 -8
- package/dist/utils/paramcoders/server/ServerParamDecoder.js +107 -107
- package/dist/utils/paramcoders/server/ServerParamEncoder.d.ts +11 -11
- package/dist/utils/paramcoders/server/ServerParamEncoder.js +65 -65
- package/dist/wallets/IBitcoinWallet.d.ts +149 -149
- package/dist/wallets/IBitcoinWallet.js +97 -97
- package/dist/wallets/ILightningWallet.d.ts +136 -136
- package/dist/wallets/ILightningWallet.js +37 -37
- package/dist/wallets/ISpvVaultSigner.d.ts +7 -7
- package/dist/wallets/ISpvVaultSigner.js +2 -2
- package/package.json +36 -36
- package/src/fees/IBtcFeeEstimator.ts +6 -6
- package/src/index.ts +53 -53
- package/src/info/InfoHandler.ts +103 -103
- package/src/plugins/IPlugin.ts +174 -174
- package/src/plugins/PluginManager.ts +354 -354
- package/src/prices/BinanceSwapPrice.ts +101 -101
- package/src/prices/CoinGeckoSwapPrice.ts +75 -75
- package/src/prices/ISwapPrice.ts +88 -88
- package/src/prices/OKXSwapPrice.ts +101 -101
- package/src/storage/IIntermediaryStorage.ts +19 -19
- package/src/storagemanager/IntermediaryStorageManager.ts +118 -118
- package/src/storagemanager/StorageManager.ts +78 -78
- package/src/swaps/SwapHandler.ts +323 -323
- package/src/swaps/SwapHandlerSwap.ts +141 -141
- package/src/swaps/assertions/AmountAssertions.ts +77 -77
- package/src/swaps/assertions/FromBtcAmountAssertions.ts +251 -251
- package/src/swaps/assertions/LightningAssertions.ts +103 -103
- package/src/swaps/assertions/ToBtcAmountAssertions.ts +203 -203
- package/src/swaps/escrow/EscrowHandler.ts +172 -172
- package/src/swaps/escrow/EscrowHandlerSwap.ts +86 -86
- package/src/swaps/escrow/FromBtcBaseSwap.ts +38 -38
- package/src/swaps/escrow/FromBtcBaseSwapHandler.ts +286 -286
- package/src/swaps/escrow/ToBtcBaseSwap.ts +85 -85
- package/src/swaps/escrow/ToBtcBaseSwapHandler.ts +129 -129
- package/src/swaps/escrow/frombtc_abstract/FromBtcAbs.ts +457 -457
- package/src/swaps/escrow/frombtc_abstract/FromBtcSwapAbs.ts +61 -61
- package/src/swaps/escrow/frombtcln_abstract/FromBtcLnAbs.ts +873 -873
- package/src/swaps/escrow/frombtcln_abstract/FromBtcLnSwapAbs.ts +141 -141
- package/src/swaps/escrow/frombtcln_autoinit/FromBtcLnAuto.ts +866 -866
- package/src/swaps/escrow/frombtcln_autoinit/FromBtcLnAutoSwap.ts +196 -196
- package/src/swaps/escrow/tobtc_abstract/ToBtcAbs.ts +920 -920
- package/src/swaps/escrow/tobtc_abstract/ToBtcSwapAbs.ts +108 -108
- package/src/swaps/escrow/tobtcln_abstract/ToBtcLnAbs.ts +1150 -1149
- package/src/swaps/escrow/tobtcln_abstract/ToBtcLnSwapAbs.ts +80 -80
- package/src/swaps/spv_vault_swap/SpvVault.ts +178 -178
- package/src/swaps/spv_vault_swap/SpvVaultSwap.ts +228 -228
- package/src/swaps/spv_vault_swap/SpvVaultSwapHandler.ts +718 -718
- package/src/swaps/spv_vault_swap/SpvVaults.ts +567 -567
- package/src/swaps/trusted/frombtc_trusted/FromBtcTrusted.ts +762 -762
- package/src/swaps/trusted/frombtc_trusted/FromBtcTrustedSwap.ts +185 -185
- package/src/swaps/trusted/frombtcln_trusted/FromBtcLnTrusted.ts +603 -603
- package/src/swaps/trusted/frombtcln_trusted/FromBtcLnTrustedSwap.ts +121 -121
- package/src/utils/BitcoinUtils.ts +59 -59
- package/src/utils/Utils.ts +150 -150
- package/src/utils/paramcoders/IParamReader.ts +7 -7
- package/src/utils/paramcoders/IParamWriter.ts +8 -8
- package/src/utils/paramcoders/LegacyParamEncoder.ts +27 -27
- package/src/utils/paramcoders/ParamDecoder.ts +218 -218
- package/src/utils/paramcoders/ParamEncoder.ts +29 -29
- package/src/utils/paramcoders/SchemaVerifier.ts +96 -96
- package/src/utils/paramcoders/server/ServerParamDecoder.ts +118 -118
- package/src/utils/paramcoders/server/ServerParamEncoder.ts +75 -75
- package/src/wallets/IBitcoinWallet.ts +237 -237
- package/src/wallets/ILightningWallet.ts +200 -200
- package/src/wallets/ISpvVaultSigner.ts +10 -10
|
@@ -1,217 +1,217 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.SwapHandler = exports.SwapHandlerType = void 0;
|
|
4
|
-
const PluginManager_1 = require("../plugins/PluginManager");
|
|
5
|
-
const Utils_1 = require("../utils/Utils");
|
|
6
|
-
var SwapHandlerType;
|
|
7
|
-
(function (SwapHandlerType) {
|
|
8
|
-
SwapHandlerType["TO_BTC"] = "TO_BTC";
|
|
9
|
-
SwapHandlerType["FROM_BTC"] = "FROM_BTC";
|
|
10
|
-
SwapHandlerType["TO_BTCLN"] = "TO_BTCLN";
|
|
11
|
-
SwapHandlerType["FROM_BTCLN"] = "FROM_BTCLN";
|
|
12
|
-
SwapHandlerType["FROM_BTCLN_TRUSTED"] = "FROM_BTCLN_TRUSTED";
|
|
13
|
-
SwapHandlerType["FROM_BTC_TRUSTED"] = "FROM_BTC_TRUSTED";
|
|
14
|
-
SwapHandlerType["FROM_BTC_SPV"] = "FROM_BTC_SPV";
|
|
15
|
-
SwapHandlerType["FROM_BTCLN_AUTO"] = "FROM_BTCLN_AUTO";
|
|
16
|
-
})(SwapHandlerType = exports.SwapHandlerType || (exports.SwapHandlerType = {}));
|
|
17
|
-
/**
|
|
18
|
-
* An abstract class defining a singular swap service
|
|
19
|
-
*/
|
|
20
|
-
class SwapHandler {
|
|
21
|
-
constructor(storageDirectory, path, chainsData, swapPricing) {
|
|
22
|
-
this.inflightSwaps = new Set();
|
|
23
|
-
this.logger = (0, Utils_1.getLogger)(() => "SwapHandler(" + this.type + "): ");
|
|
24
|
-
this.swapLogger = {
|
|
25
|
-
debug: (swap, msg, ...args) => this.logger.debug(swap.getIdentifier() + ": " + msg, ...args),
|
|
26
|
-
info: (swap, msg, ...args) => this.logger.info(swap.getIdentifier() + ": " + msg, ...args),
|
|
27
|
-
warn: (swap, msg, ...args) => this.logger.warn(swap.getIdentifier() + ": " + msg, ...args),
|
|
28
|
-
error: (swap, msg, ...args) => this.logger.error(swap.getIdentifier() + ": " + msg, ...args)
|
|
29
|
-
};
|
|
30
|
-
this.storageManager = storageDirectory;
|
|
31
|
-
this.chains = chainsData;
|
|
32
|
-
this.path = path;
|
|
33
|
-
this.swapPricing = swapPricing;
|
|
34
|
-
this.allowedTokens = {};
|
|
35
|
-
for (let chainId in chainsData.chains) {
|
|
36
|
-
this.allowedTokens[chainId] = new Set(chainsData.chains[chainId].allowedTokens);
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
getChain(identifier) {
|
|
40
|
-
if (this.chains.chains[identifier] == null)
|
|
41
|
-
throw {
|
|
42
|
-
code: 20200,
|
|
43
|
-
msg: "Invalid chain specified!"
|
|
44
|
-
};
|
|
45
|
-
return this.chains.chains[identifier];
|
|
46
|
-
}
|
|
47
|
-
/**
|
|
48
|
-
* Starts the watchdog checking past swaps for expiry or claim eligibility.
|
|
49
|
-
*/
|
|
50
|
-
async startWatchdog() {
|
|
51
|
-
let rerun;
|
|
52
|
-
rerun = async () => {
|
|
53
|
-
await this.processPastSwaps().catch(e => this.logger.error("startWatchdog(): Error when processing past swaps: ", e));
|
|
54
|
-
setTimeout(rerun, this.config.swapCheckInterval);
|
|
55
|
-
};
|
|
56
|
-
await rerun();
|
|
57
|
-
}
|
|
58
|
-
async loadData(ctor) {
|
|
59
|
-
await this.storageManager.loadData(ctor);
|
|
60
|
-
//Check if all swaps contain a valid amount
|
|
61
|
-
for (let { obj: swap, hash, sequence } of await this.storageManager.query([])) {
|
|
62
|
-
if (hash !== swap.getIdentifierHash() || sequence !== (swap.getSequence() ?? 0n)) {
|
|
63
|
-
this.swapLogger.info(swap, "loadData(): Swap storage key or sequence mismatch, fixing," +
|
|
64
|
-
" old hash: " + hash + " new hash: " + swap.getIdentifierHash() +
|
|
65
|
-
" old seq: " + sequence.toString(10) + " new seq: " + (swap.getSequence() ?? 0n).toString(10));
|
|
66
|
-
await this.storageManager.removeData(hash, sequence);
|
|
67
|
-
await this.storageManager.saveData(swap.getIdentifierHash(), swap.getSequence(), swap);
|
|
68
|
-
}
|
|
69
|
-
if (this.inflightSwapStates.has(swap.state))
|
|
70
|
-
this.inflightSwaps.add(swap.getIdentifier());
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
/**
|
|
74
|
-
* Remove swap data
|
|
75
|
-
*
|
|
76
|
-
* @param swap
|
|
77
|
-
* @param ultimateState set the ultimate state of the swap before removing
|
|
78
|
-
*/
|
|
79
|
-
async removeSwapData(swap, ultimateState) {
|
|
80
|
-
this.inflightSwaps.delete(swap.getIdentifier());
|
|
81
|
-
this.logger.debug("removeSwapData(): Removing in-flight swap, current in-flight swaps: " + this.inflightSwaps.size);
|
|
82
|
-
if (ultimateState != null)
|
|
83
|
-
await swap.setState(ultimateState);
|
|
84
|
-
if (swap != null)
|
|
85
|
-
await PluginManager_1.PluginManager.swapRemove(swap);
|
|
86
|
-
this.swapLogger.debug(swap, "removeSwapData(): removing swap final state: " + swap.state);
|
|
87
|
-
await this.storageManager.removeData(swap.getIdentifierHash(), swap.getSequence());
|
|
88
|
-
}
|
|
89
|
-
async saveSwapData(swap) {
|
|
90
|
-
if (this.inflightSwapStates.has(swap.state)) {
|
|
91
|
-
this.inflightSwaps.add(swap.getIdentifier());
|
|
92
|
-
this.logger.debug("removeSwapData(): Adding in-flight swap, current in-flight swaps: " + this.inflightSwaps.size);
|
|
93
|
-
}
|
|
94
|
-
else {
|
|
95
|
-
this.inflightSwaps.delete(swap.getIdentifier());
|
|
96
|
-
this.logger.debug("removeSwapData(): Removing in-flight swap, current in-flight swaps: " + this.inflightSwaps.size);
|
|
97
|
-
}
|
|
98
|
-
await this.storageManager.saveData(swap.getIdentifierHash(), swap.getSequence(), swap);
|
|
99
|
-
}
|
|
100
|
-
/**
|
|
101
|
-
* Pre-fetches native balance to further check if we have enough reserve in a native token
|
|
102
|
-
*
|
|
103
|
-
* @param chainIdentifier
|
|
104
|
-
* @param abortController
|
|
105
|
-
* @protected
|
|
106
|
-
*/
|
|
107
|
-
prefetchNativeBalanceIfNeeded(chainIdentifier, abortController) {
|
|
108
|
-
const minNativeTokenReserve = this.config.minNativeBalances?.[chainIdentifier] ?? 0n;
|
|
109
|
-
if (minNativeTokenReserve === 0n)
|
|
110
|
-
return null;
|
|
111
|
-
const { chainInterface, signer } = this.getChain(chainIdentifier);
|
|
112
|
-
return chainInterface.getBalance(signer.getAddress(), chainInterface.getNativeCurrencyAddress()).catch(e => {
|
|
113
|
-
this.logger.error("getBalancePrefetch(): balancePrefetch error: ", e);
|
|
114
|
-
abortController.abort(e);
|
|
115
|
-
return null;
|
|
116
|
-
});
|
|
117
|
-
}
|
|
118
|
-
/**
|
|
119
|
-
* Checks if we have enough native balance to facilitate swaps
|
|
120
|
-
*
|
|
121
|
-
* @param chainIdentifier
|
|
122
|
-
* @param balancePrefetch
|
|
123
|
-
* @param signal
|
|
124
|
-
* @throws {DefinedRuntimeError} will throw an error if there are not enough funds in the vault
|
|
125
|
-
*/
|
|
126
|
-
async checkNativeBalance(chainIdentifier, balancePrefetch, signal) {
|
|
127
|
-
if (signal != null)
|
|
128
|
-
signal.throwIfAborted();
|
|
129
|
-
const minNativeTokenReserve = this.config.minNativeBalances?.[chainIdentifier] ?? 0n;
|
|
130
|
-
if (minNativeTokenReserve === 0n)
|
|
131
|
-
return;
|
|
132
|
-
const balance = await balancePrefetch;
|
|
133
|
-
if (balance == null || balance < minNativeTokenReserve) {
|
|
134
|
-
throw {
|
|
135
|
-
code: 20012,
|
|
136
|
-
msg: "LP ran out of native token to cover gas fees"
|
|
137
|
-
};
|
|
138
|
-
}
|
|
139
|
-
}
|
|
140
|
-
/**
|
|
141
|
-
* Checks whether there are too many swaps in-flight currently
|
|
142
|
-
* @private
|
|
143
|
-
*/
|
|
144
|
-
checkTooManyInflightSwaps() {
|
|
145
|
-
if (this.config.maxInflightSwaps == null)
|
|
146
|
-
return;
|
|
147
|
-
if (this.inflightSwaps.size >= this.config.maxInflightSwaps)
|
|
148
|
-
throw {
|
|
149
|
-
code: 20013,
|
|
150
|
-
msg: "LP has too many in-flight swaps, retry later!"
|
|
151
|
-
};
|
|
152
|
-
}
|
|
153
|
-
/**
|
|
154
|
-
* Checks if we have enough balance of the token in the swap vault
|
|
155
|
-
*
|
|
156
|
-
* @param totalInToken
|
|
157
|
-
* @param balancePrefetch
|
|
158
|
-
* @param signal
|
|
159
|
-
* @throws {DefinedRuntimeError} will throw an error if there are not enough funds in the vault
|
|
160
|
-
*/
|
|
161
|
-
async checkBalance(totalInToken, balancePrefetch, signal) {
|
|
162
|
-
const balance = await balancePrefetch;
|
|
163
|
-
if (signal != null)
|
|
164
|
-
signal.throwIfAborted();
|
|
165
|
-
if (balance == null || balance < totalInToken) {
|
|
166
|
-
throw {
|
|
167
|
-
code: 20002,
|
|
168
|
-
msg: "Not enough liquidity"
|
|
169
|
-
};
|
|
170
|
-
}
|
|
171
|
-
}
|
|
172
|
-
/**
|
|
173
|
-
* Checks if the sequence number is between 0-2^64
|
|
174
|
-
*
|
|
175
|
-
* @param sequence
|
|
176
|
-
* @throws {DefinedRuntimeError} will throw an error if sequence number is out of bounds
|
|
177
|
-
*/
|
|
178
|
-
checkSequence(sequence) {
|
|
179
|
-
if (sequence < 0n || sequence >= 2n ** 64n) {
|
|
180
|
-
throw {
|
|
181
|
-
code: 20060,
|
|
182
|
-
msg: "Invalid sequence"
|
|
183
|
-
};
|
|
184
|
-
}
|
|
185
|
-
}
|
|
186
|
-
/**
|
|
187
|
-
* Checks whether a given token is supported on a specified chain
|
|
188
|
-
*
|
|
189
|
-
* @param chainId
|
|
190
|
-
* @param token
|
|
191
|
-
* @protected
|
|
192
|
-
*/
|
|
193
|
-
isTokenSupported(chainId, token) {
|
|
194
|
-
const chainTokens = this.allowedTokens[chainId];
|
|
195
|
-
if (chainTokens == null)
|
|
196
|
-
return false;
|
|
197
|
-
return chainTokens.has(token);
|
|
198
|
-
}
|
|
199
|
-
getInfo() {
|
|
200
|
-
const chainTokens = {};
|
|
201
|
-
for (let chainId in this.allowedTokens) {
|
|
202
|
-
chainTokens[chainId] = Array.from(this.allowedTokens[chainId]);
|
|
203
|
-
}
|
|
204
|
-
return {
|
|
205
|
-
swapFeePPM: Number(this.config.feePPM),
|
|
206
|
-
swapBaseFee: Number(this.config.baseFee),
|
|
207
|
-
min: Number(this.config.min),
|
|
208
|
-
max: Number(this.config.max),
|
|
209
|
-
data: this.getInfoData(),
|
|
210
|
-
chainTokens
|
|
211
|
-
};
|
|
212
|
-
}
|
|
213
|
-
getInitAuthorizationTimeout(chainIdentifier) {
|
|
214
|
-
return this.config.initAuthorizationTimeouts?.[chainIdentifier] ?? this.config.initAuthorizationTimeout;
|
|
215
|
-
}
|
|
216
|
-
}
|
|
217
|
-
exports.SwapHandler = SwapHandler;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SwapHandler = exports.SwapHandlerType = void 0;
|
|
4
|
+
const PluginManager_1 = require("../plugins/PluginManager");
|
|
5
|
+
const Utils_1 = require("../utils/Utils");
|
|
6
|
+
var SwapHandlerType;
|
|
7
|
+
(function (SwapHandlerType) {
|
|
8
|
+
SwapHandlerType["TO_BTC"] = "TO_BTC";
|
|
9
|
+
SwapHandlerType["FROM_BTC"] = "FROM_BTC";
|
|
10
|
+
SwapHandlerType["TO_BTCLN"] = "TO_BTCLN";
|
|
11
|
+
SwapHandlerType["FROM_BTCLN"] = "FROM_BTCLN";
|
|
12
|
+
SwapHandlerType["FROM_BTCLN_TRUSTED"] = "FROM_BTCLN_TRUSTED";
|
|
13
|
+
SwapHandlerType["FROM_BTC_TRUSTED"] = "FROM_BTC_TRUSTED";
|
|
14
|
+
SwapHandlerType["FROM_BTC_SPV"] = "FROM_BTC_SPV";
|
|
15
|
+
SwapHandlerType["FROM_BTCLN_AUTO"] = "FROM_BTCLN_AUTO";
|
|
16
|
+
})(SwapHandlerType = exports.SwapHandlerType || (exports.SwapHandlerType = {}));
|
|
17
|
+
/**
|
|
18
|
+
* An abstract class defining a singular swap service
|
|
19
|
+
*/
|
|
20
|
+
class SwapHandler {
|
|
21
|
+
constructor(storageDirectory, path, chainsData, swapPricing) {
|
|
22
|
+
this.inflightSwaps = new Set();
|
|
23
|
+
this.logger = (0, Utils_1.getLogger)(() => "SwapHandler(" + this.type + "): ");
|
|
24
|
+
this.swapLogger = {
|
|
25
|
+
debug: (swap, msg, ...args) => this.logger.debug(swap.getIdentifier() + ": " + msg, ...args),
|
|
26
|
+
info: (swap, msg, ...args) => this.logger.info(swap.getIdentifier() + ": " + msg, ...args),
|
|
27
|
+
warn: (swap, msg, ...args) => this.logger.warn(swap.getIdentifier() + ": " + msg, ...args),
|
|
28
|
+
error: (swap, msg, ...args) => this.logger.error(swap.getIdentifier() + ": " + msg, ...args)
|
|
29
|
+
};
|
|
30
|
+
this.storageManager = storageDirectory;
|
|
31
|
+
this.chains = chainsData;
|
|
32
|
+
this.path = path;
|
|
33
|
+
this.swapPricing = swapPricing;
|
|
34
|
+
this.allowedTokens = {};
|
|
35
|
+
for (let chainId in chainsData.chains) {
|
|
36
|
+
this.allowedTokens[chainId] = new Set(chainsData.chains[chainId].allowedTokens);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
getChain(identifier) {
|
|
40
|
+
if (this.chains.chains[identifier] == null)
|
|
41
|
+
throw {
|
|
42
|
+
code: 20200,
|
|
43
|
+
msg: "Invalid chain specified!"
|
|
44
|
+
};
|
|
45
|
+
return this.chains.chains[identifier];
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Starts the watchdog checking past swaps for expiry or claim eligibility.
|
|
49
|
+
*/
|
|
50
|
+
async startWatchdog() {
|
|
51
|
+
let rerun;
|
|
52
|
+
rerun = async () => {
|
|
53
|
+
await this.processPastSwaps().catch(e => this.logger.error("startWatchdog(): Error when processing past swaps: ", e));
|
|
54
|
+
setTimeout(rerun, this.config.swapCheckInterval);
|
|
55
|
+
};
|
|
56
|
+
await rerun();
|
|
57
|
+
}
|
|
58
|
+
async loadData(ctor) {
|
|
59
|
+
await this.storageManager.loadData(ctor);
|
|
60
|
+
//Check if all swaps contain a valid amount
|
|
61
|
+
for (let { obj: swap, hash, sequence } of await this.storageManager.query([])) {
|
|
62
|
+
if (hash !== swap.getIdentifierHash() || sequence !== (swap.getSequence() ?? 0n)) {
|
|
63
|
+
this.swapLogger.info(swap, "loadData(): Swap storage key or sequence mismatch, fixing," +
|
|
64
|
+
" old hash: " + hash + " new hash: " + swap.getIdentifierHash() +
|
|
65
|
+
" old seq: " + sequence.toString(10) + " new seq: " + (swap.getSequence() ?? 0n).toString(10));
|
|
66
|
+
await this.storageManager.removeData(hash, sequence);
|
|
67
|
+
await this.storageManager.saveData(swap.getIdentifierHash(), swap.getSequence(), swap);
|
|
68
|
+
}
|
|
69
|
+
if (this.inflightSwapStates.has(swap.state))
|
|
70
|
+
this.inflightSwaps.add(swap.getIdentifier());
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* Remove swap data
|
|
75
|
+
*
|
|
76
|
+
* @param swap
|
|
77
|
+
* @param ultimateState set the ultimate state of the swap before removing
|
|
78
|
+
*/
|
|
79
|
+
async removeSwapData(swap, ultimateState) {
|
|
80
|
+
this.inflightSwaps.delete(swap.getIdentifier());
|
|
81
|
+
this.logger.debug("removeSwapData(): Removing in-flight swap, current in-flight swaps: " + this.inflightSwaps.size);
|
|
82
|
+
if (ultimateState != null)
|
|
83
|
+
await swap.setState(ultimateState);
|
|
84
|
+
if (swap != null)
|
|
85
|
+
await PluginManager_1.PluginManager.swapRemove(swap);
|
|
86
|
+
this.swapLogger.debug(swap, "removeSwapData(): removing swap final state: " + swap.state);
|
|
87
|
+
await this.storageManager.removeData(swap.getIdentifierHash(), swap.getSequence());
|
|
88
|
+
}
|
|
89
|
+
async saveSwapData(swap) {
|
|
90
|
+
if (this.inflightSwapStates.has(swap.state)) {
|
|
91
|
+
this.inflightSwaps.add(swap.getIdentifier());
|
|
92
|
+
this.logger.debug("removeSwapData(): Adding in-flight swap, current in-flight swaps: " + this.inflightSwaps.size);
|
|
93
|
+
}
|
|
94
|
+
else {
|
|
95
|
+
this.inflightSwaps.delete(swap.getIdentifier());
|
|
96
|
+
this.logger.debug("removeSwapData(): Removing in-flight swap, current in-flight swaps: " + this.inflightSwaps.size);
|
|
97
|
+
}
|
|
98
|
+
await this.storageManager.saveData(swap.getIdentifierHash(), swap.getSequence(), swap);
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* Pre-fetches native balance to further check if we have enough reserve in a native token
|
|
102
|
+
*
|
|
103
|
+
* @param chainIdentifier
|
|
104
|
+
* @param abortController
|
|
105
|
+
* @protected
|
|
106
|
+
*/
|
|
107
|
+
prefetchNativeBalanceIfNeeded(chainIdentifier, abortController) {
|
|
108
|
+
const minNativeTokenReserve = this.config.minNativeBalances?.[chainIdentifier] ?? 0n;
|
|
109
|
+
if (minNativeTokenReserve === 0n)
|
|
110
|
+
return null;
|
|
111
|
+
const { chainInterface, signer } = this.getChain(chainIdentifier);
|
|
112
|
+
return chainInterface.getBalance(signer.getAddress(), chainInterface.getNativeCurrencyAddress()).catch(e => {
|
|
113
|
+
this.logger.error("getBalancePrefetch(): balancePrefetch error: ", e);
|
|
114
|
+
abortController.abort(e);
|
|
115
|
+
return null;
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
/**
|
|
119
|
+
* Checks if we have enough native balance to facilitate swaps
|
|
120
|
+
*
|
|
121
|
+
* @param chainIdentifier
|
|
122
|
+
* @param balancePrefetch
|
|
123
|
+
* @param signal
|
|
124
|
+
* @throws {DefinedRuntimeError} will throw an error if there are not enough funds in the vault
|
|
125
|
+
*/
|
|
126
|
+
async checkNativeBalance(chainIdentifier, balancePrefetch, signal) {
|
|
127
|
+
if (signal != null)
|
|
128
|
+
signal.throwIfAborted();
|
|
129
|
+
const minNativeTokenReserve = this.config.minNativeBalances?.[chainIdentifier] ?? 0n;
|
|
130
|
+
if (minNativeTokenReserve === 0n)
|
|
131
|
+
return;
|
|
132
|
+
const balance = await balancePrefetch;
|
|
133
|
+
if (balance == null || balance < minNativeTokenReserve) {
|
|
134
|
+
throw {
|
|
135
|
+
code: 20012,
|
|
136
|
+
msg: "LP ran out of native token to cover gas fees"
|
|
137
|
+
};
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
/**
|
|
141
|
+
* Checks whether there are too many swaps in-flight currently
|
|
142
|
+
* @private
|
|
143
|
+
*/
|
|
144
|
+
checkTooManyInflightSwaps() {
|
|
145
|
+
if (this.config.maxInflightSwaps == null)
|
|
146
|
+
return;
|
|
147
|
+
if (this.inflightSwaps.size >= this.config.maxInflightSwaps)
|
|
148
|
+
throw {
|
|
149
|
+
code: 20013,
|
|
150
|
+
msg: "LP has too many in-flight swaps, retry later!"
|
|
151
|
+
};
|
|
152
|
+
}
|
|
153
|
+
/**
|
|
154
|
+
* Checks if we have enough balance of the token in the swap vault
|
|
155
|
+
*
|
|
156
|
+
* @param totalInToken
|
|
157
|
+
* @param balancePrefetch
|
|
158
|
+
* @param signal
|
|
159
|
+
* @throws {DefinedRuntimeError} will throw an error if there are not enough funds in the vault
|
|
160
|
+
*/
|
|
161
|
+
async checkBalance(totalInToken, balancePrefetch, signal) {
|
|
162
|
+
const balance = await balancePrefetch;
|
|
163
|
+
if (signal != null)
|
|
164
|
+
signal.throwIfAborted();
|
|
165
|
+
if (balance == null || balance < totalInToken) {
|
|
166
|
+
throw {
|
|
167
|
+
code: 20002,
|
|
168
|
+
msg: "Not enough liquidity"
|
|
169
|
+
};
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
/**
|
|
173
|
+
* Checks if the sequence number is between 0-2^64
|
|
174
|
+
*
|
|
175
|
+
* @param sequence
|
|
176
|
+
* @throws {DefinedRuntimeError} will throw an error if sequence number is out of bounds
|
|
177
|
+
*/
|
|
178
|
+
checkSequence(sequence) {
|
|
179
|
+
if (sequence < 0n || sequence >= 2n ** 64n) {
|
|
180
|
+
throw {
|
|
181
|
+
code: 20060,
|
|
182
|
+
msg: "Invalid sequence"
|
|
183
|
+
};
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
/**
|
|
187
|
+
* Checks whether a given token is supported on a specified chain
|
|
188
|
+
*
|
|
189
|
+
* @param chainId
|
|
190
|
+
* @param token
|
|
191
|
+
* @protected
|
|
192
|
+
*/
|
|
193
|
+
isTokenSupported(chainId, token) {
|
|
194
|
+
const chainTokens = this.allowedTokens[chainId];
|
|
195
|
+
if (chainTokens == null)
|
|
196
|
+
return false;
|
|
197
|
+
return chainTokens.has(token);
|
|
198
|
+
}
|
|
199
|
+
getInfo() {
|
|
200
|
+
const chainTokens = {};
|
|
201
|
+
for (let chainId in this.allowedTokens) {
|
|
202
|
+
chainTokens[chainId] = Array.from(this.allowedTokens[chainId]);
|
|
203
|
+
}
|
|
204
|
+
return {
|
|
205
|
+
swapFeePPM: Number(this.config.feePPM),
|
|
206
|
+
swapBaseFee: Number(this.config.baseFee),
|
|
207
|
+
min: Number(this.config.min),
|
|
208
|
+
max: Number(this.config.max),
|
|
209
|
+
data: this.getInfoData(),
|
|
210
|
+
chainTokens
|
|
211
|
+
};
|
|
212
|
+
}
|
|
213
|
+
getInitAuthorizationTimeout(chainIdentifier) {
|
|
214
|
+
return this.config.initAuthorizationTimeouts?.[chainIdentifier] ?? this.config.initAuthorizationTimeout;
|
|
215
|
+
}
|
|
216
|
+
}
|
|
217
|
+
exports.SwapHandler = SwapHandler;
|
|
@@ -1,79 +1,79 @@
|
|
|
1
|
-
import { Lockable, StorageObject } from "@atomiqlabs/base";
|
|
2
|
-
import { SwapHandlerType } from "./SwapHandler";
|
|
3
|
-
export declare abstract class SwapHandlerSwap<S = any> extends Lockable implements StorageObject {
|
|
4
|
-
type: SwapHandlerType;
|
|
5
|
-
chainIdentifier: string;
|
|
6
|
-
state: S;
|
|
7
|
-
metadata: {
|
|
8
|
-
request: any;
|
|
9
|
-
times: {
|
|
10
|
-
[key: string]: number;
|
|
11
|
-
};
|
|
12
|
-
[key: string]: any;
|
|
13
|
-
};
|
|
14
|
-
txIds: {
|
|
15
|
-
[key: string]: string;
|
|
16
|
-
};
|
|
17
|
-
readonly swapFee: bigint;
|
|
18
|
-
readonly swapFeeInToken: bigint;
|
|
19
|
-
protected constructor(chainIdentifier: string, swapFee: bigint, swapFeeInToken: bigint);
|
|
20
|
-
protected constructor(obj: any);
|
|
21
|
-
serialize(): any;
|
|
22
|
-
/**
|
|
23
|
-
* Sets the state of the swap and also calls swap change listener on plugins
|
|
24
|
-
*
|
|
25
|
-
* @param newState
|
|
26
|
-
*/
|
|
27
|
-
setState(newState: S): Promise<void>;
|
|
28
|
-
/**
|
|
29
|
-
* Returns the identification hash of the swap, usually claim data hash, but can be overriden, e.g. for
|
|
30
|
-
* lightning swaps the identifier hash is used instead of claim data hash
|
|
31
|
-
*/
|
|
32
|
-
abstract getIdentifierHash(): string;
|
|
33
|
-
abstract getSequence(): bigint | null;
|
|
34
|
-
/**
|
|
35
|
-
* Returns unique identifier of the swap in the form <hash>_<sequence> or just <hash> if the swap type doesn't
|
|
36
|
-
* use sequence number
|
|
37
|
-
*/
|
|
38
|
-
getIdentifier(): string;
|
|
39
|
-
/**
|
|
40
|
-
* Returns the smart chain token used for the swap
|
|
41
|
-
*/
|
|
42
|
-
abstract getToken(): string;
|
|
43
|
-
/**
|
|
44
|
-
* Checks whether the swap is finished, such that it is final and either successful or failed
|
|
45
|
-
*/
|
|
46
|
-
isFinished(): boolean;
|
|
47
|
-
/**
|
|
48
|
-
* Checks whether the swap was initiated by the user
|
|
49
|
-
*/
|
|
50
|
-
abstract isInitiated(): boolean;
|
|
51
|
-
/**
|
|
52
|
-
* Checks whether the swap was finished and was successful
|
|
53
|
-
*/
|
|
54
|
-
abstract isSuccess(): boolean;
|
|
55
|
-
/**
|
|
56
|
-
* Checks whether the swap was finished and was failed
|
|
57
|
-
*/
|
|
58
|
-
abstract isFailed(): boolean;
|
|
59
|
-
/**
|
|
60
|
-
* Returns the input amount paid by the user (excluding fees)
|
|
61
|
-
*/
|
|
62
|
-
getInputAmount(): bigint;
|
|
63
|
-
/**
|
|
64
|
-
* Returns the total input amount paid by the user (including all fees)
|
|
65
|
-
*/
|
|
66
|
-
abstract getTotalInputAmount(): bigint;
|
|
67
|
-
/**
|
|
68
|
-
* Returns the actual output amount paid out to the user
|
|
69
|
-
*/
|
|
70
|
-
abstract getOutputAmount(): bigint;
|
|
71
|
-
/**
|
|
72
|
-
* Returns swap fee, denominated in input & output tokens (the fee is paid only once, it is just represented here in
|
|
73
|
-
* both denomination for ease of use)
|
|
74
|
-
*/
|
|
75
|
-
abstract getSwapFee(): {
|
|
76
|
-
inInputToken: bigint;
|
|
77
|
-
inOutputToken: bigint;
|
|
78
|
-
};
|
|
79
|
-
}
|
|
1
|
+
import { Lockable, StorageObject } from "@atomiqlabs/base";
|
|
2
|
+
import { SwapHandlerType } from "./SwapHandler";
|
|
3
|
+
export declare abstract class SwapHandlerSwap<S = any> extends Lockable implements StorageObject {
|
|
4
|
+
type: SwapHandlerType;
|
|
5
|
+
chainIdentifier: string;
|
|
6
|
+
state: S;
|
|
7
|
+
metadata: {
|
|
8
|
+
request: any;
|
|
9
|
+
times: {
|
|
10
|
+
[key: string]: number;
|
|
11
|
+
};
|
|
12
|
+
[key: string]: any;
|
|
13
|
+
};
|
|
14
|
+
txIds: {
|
|
15
|
+
[key: string]: string;
|
|
16
|
+
};
|
|
17
|
+
readonly swapFee: bigint;
|
|
18
|
+
readonly swapFeeInToken: bigint;
|
|
19
|
+
protected constructor(chainIdentifier: string, swapFee: bigint, swapFeeInToken: bigint);
|
|
20
|
+
protected constructor(obj: any);
|
|
21
|
+
serialize(): any;
|
|
22
|
+
/**
|
|
23
|
+
* Sets the state of the swap and also calls swap change listener on plugins
|
|
24
|
+
*
|
|
25
|
+
* @param newState
|
|
26
|
+
*/
|
|
27
|
+
setState(newState: S): Promise<void>;
|
|
28
|
+
/**
|
|
29
|
+
* Returns the identification hash of the swap, usually claim data hash, but can be overriden, e.g. for
|
|
30
|
+
* lightning swaps the identifier hash is used instead of claim data hash
|
|
31
|
+
*/
|
|
32
|
+
abstract getIdentifierHash(): string;
|
|
33
|
+
abstract getSequence(): bigint | null;
|
|
34
|
+
/**
|
|
35
|
+
* Returns unique identifier of the swap in the form <hash>_<sequence> or just <hash> if the swap type doesn't
|
|
36
|
+
* use sequence number
|
|
37
|
+
*/
|
|
38
|
+
getIdentifier(): string;
|
|
39
|
+
/**
|
|
40
|
+
* Returns the smart chain token used for the swap
|
|
41
|
+
*/
|
|
42
|
+
abstract getToken(): string;
|
|
43
|
+
/**
|
|
44
|
+
* Checks whether the swap is finished, such that it is final and either successful or failed
|
|
45
|
+
*/
|
|
46
|
+
isFinished(): boolean;
|
|
47
|
+
/**
|
|
48
|
+
* Checks whether the swap was initiated by the user
|
|
49
|
+
*/
|
|
50
|
+
abstract isInitiated(): boolean;
|
|
51
|
+
/**
|
|
52
|
+
* Checks whether the swap was finished and was successful
|
|
53
|
+
*/
|
|
54
|
+
abstract isSuccess(): boolean;
|
|
55
|
+
/**
|
|
56
|
+
* Checks whether the swap was finished and was failed
|
|
57
|
+
*/
|
|
58
|
+
abstract isFailed(): boolean;
|
|
59
|
+
/**
|
|
60
|
+
* Returns the input amount paid by the user (excluding fees)
|
|
61
|
+
*/
|
|
62
|
+
getInputAmount(): bigint;
|
|
63
|
+
/**
|
|
64
|
+
* Returns the total input amount paid by the user (including all fees)
|
|
65
|
+
*/
|
|
66
|
+
abstract getTotalInputAmount(): bigint;
|
|
67
|
+
/**
|
|
68
|
+
* Returns the actual output amount paid out to the user
|
|
69
|
+
*/
|
|
70
|
+
abstract getOutputAmount(): bigint;
|
|
71
|
+
/**
|
|
72
|
+
* Returns swap fee, denominated in input & output tokens (the fee is paid only once, it is just represented here in
|
|
73
|
+
* both denomination for ease of use)
|
|
74
|
+
*/
|
|
75
|
+
abstract getSwapFee(): {
|
|
76
|
+
inInputToken: bigint;
|
|
77
|
+
inOutputToken: bigint;
|
|
78
|
+
};
|
|
79
|
+
}
|