@atomiqlabs/lp-lib 16.1.2 → 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 -29
- package/dist/utils/Utils.js +129 -89
- 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 -74
- package/dist/wallets/IBitcoinWallet.js +97 -2
- 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 -712
- 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 -104
- 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 -76
- package/src/wallets/ILightningWallet.ts +200 -200
- package/src/wallets/ISpvVaultSigner.ts +10 -10
|
@@ -1,78 +1,78 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.SwapHandlerSwap = void 0;
|
|
4
|
-
const base_1 = require("@atomiqlabs/base");
|
|
5
|
-
const PluginManager_1 = require("../plugins/PluginManager");
|
|
6
|
-
const Utils_1 = require("../utils/Utils");
|
|
7
|
-
function objectBigIntsToString(obj) {
|
|
8
|
-
for (let key in obj) {
|
|
9
|
-
if (typeof obj[key] === "bigint")
|
|
10
|
-
obj[key] = obj[key].toString(10);
|
|
11
|
-
if (typeof obj[key] === "object")
|
|
12
|
-
objectBigIntsToString(obj[key]);
|
|
13
|
-
}
|
|
14
|
-
return obj;
|
|
15
|
-
}
|
|
16
|
-
class SwapHandlerSwap extends base_1.Lockable {
|
|
17
|
-
constructor(obj, swapFee, swapFeeInToken) {
|
|
18
|
-
super();
|
|
19
|
-
this.txIds = {};
|
|
20
|
-
if (typeof (obj) === "string" && typeof (swapFee) === "bigint" && typeof (swapFeeInToken) === "bigint") {
|
|
21
|
-
this.chainIdentifier = obj;
|
|
22
|
-
this.swapFee = swapFee;
|
|
23
|
-
this.swapFeeInToken = swapFeeInToken;
|
|
24
|
-
return;
|
|
25
|
-
}
|
|
26
|
-
else {
|
|
27
|
-
this.metadata = obj.metadata;
|
|
28
|
-
this.chainIdentifier = obj.chainIdentifier;
|
|
29
|
-
this.txIds = obj.txIds || {};
|
|
30
|
-
this.state = obj.state;
|
|
31
|
-
this.swapFee = (0, Utils_1.deserializeBN)(obj.swapFee);
|
|
32
|
-
this.swapFeeInToken = (0, Utils_1.deserializeBN)(obj.swapFeeInToken);
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
serialize() {
|
|
36
|
-
return {
|
|
37
|
-
state: this.state,
|
|
38
|
-
chainIdentifier: this.chainIdentifier,
|
|
39
|
-
metadata: objectBigIntsToString(this.metadata),
|
|
40
|
-
txIds: this.txIds,
|
|
41
|
-
swapFee: (0, Utils_1.serializeBN)(this.swapFee),
|
|
42
|
-
swapFeeInToken: (0, Utils_1.serializeBN)(this.swapFeeInToken)
|
|
43
|
-
};
|
|
44
|
-
}
|
|
45
|
-
/**
|
|
46
|
-
* Sets the state of the swap and also calls swap change listener on plugins
|
|
47
|
-
*
|
|
48
|
-
* @param newState
|
|
49
|
-
*/
|
|
50
|
-
setState(newState) {
|
|
51
|
-
const oldState = this.state;
|
|
52
|
-
this.state = newState;
|
|
53
|
-
return PluginManager_1.PluginManager.swapStateChange(this, oldState);
|
|
54
|
-
}
|
|
55
|
-
/**
|
|
56
|
-
* Returns unique identifier of the swap in the form <hash>_<sequence> or just <hash> if the swap type doesn't
|
|
57
|
-
* use sequence number
|
|
58
|
-
*/
|
|
59
|
-
getIdentifier() {
|
|
60
|
-
if (this.getSequence() != null) {
|
|
61
|
-
return this.chainIdentifier + "_" + this.getIdentifierHash() + "_" + this.getSequence().toString(16);
|
|
62
|
-
}
|
|
63
|
-
return this.chainIdentifier + "_" + this.getIdentifierHash();
|
|
64
|
-
}
|
|
65
|
-
/**
|
|
66
|
-
* Checks whether the swap is finished, such that it is final and either successful or failed
|
|
67
|
-
*/
|
|
68
|
-
isFinished() {
|
|
69
|
-
return this.isSuccess() || this.isFailed();
|
|
70
|
-
}
|
|
71
|
-
/**
|
|
72
|
-
* Returns the input amount paid by the user (excluding fees)
|
|
73
|
-
*/
|
|
74
|
-
getInputAmount() {
|
|
75
|
-
return this.getTotalInputAmount() - this.getSwapFee().inInputToken;
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
exports.SwapHandlerSwap = SwapHandlerSwap;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SwapHandlerSwap = void 0;
|
|
4
|
+
const base_1 = require("@atomiqlabs/base");
|
|
5
|
+
const PluginManager_1 = require("../plugins/PluginManager");
|
|
6
|
+
const Utils_1 = require("../utils/Utils");
|
|
7
|
+
function objectBigIntsToString(obj) {
|
|
8
|
+
for (let key in obj) {
|
|
9
|
+
if (typeof obj[key] === "bigint")
|
|
10
|
+
obj[key] = obj[key].toString(10);
|
|
11
|
+
if (typeof obj[key] === "object")
|
|
12
|
+
objectBigIntsToString(obj[key]);
|
|
13
|
+
}
|
|
14
|
+
return obj;
|
|
15
|
+
}
|
|
16
|
+
class SwapHandlerSwap extends base_1.Lockable {
|
|
17
|
+
constructor(obj, swapFee, swapFeeInToken) {
|
|
18
|
+
super();
|
|
19
|
+
this.txIds = {};
|
|
20
|
+
if (typeof (obj) === "string" && typeof (swapFee) === "bigint" && typeof (swapFeeInToken) === "bigint") {
|
|
21
|
+
this.chainIdentifier = obj;
|
|
22
|
+
this.swapFee = swapFee;
|
|
23
|
+
this.swapFeeInToken = swapFeeInToken;
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
this.metadata = obj.metadata;
|
|
28
|
+
this.chainIdentifier = obj.chainIdentifier;
|
|
29
|
+
this.txIds = obj.txIds || {};
|
|
30
|
+
this.state = obj.state;
|
|
31
|
+
this.swapFee = (0, Utils_1.deserializeBN)(obj.swapFee);
|
|
32
|
+
this.swapFeeInToken = (0, Utils_1.deserializeBN)(obj.swapFeeInToken);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
serialize() {
|
|
36
|
+
return {
|
|
37
|
+
state: this.state,
|
|
38
|
+
chainIdentifier: this.chainIdentifier,
|
|
39
|
+
metadata: objectBigIntsToString(this.metadata),
|
|
40
|
+
txIds: this.txIds,
|
|
41
|
+
swapFee: (0, Utils_1.serializeBN)(this.swapFee),
|
|
42
|
+
swapFeeInToken: (0, Utils_1.serializeBN)(this.swapFeeInToken)
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* Sets the state of the swap and also calls swap change listener on plugins
|
|
47
|
+
*
|
|
48
|
+
* @param newState
|
|
49
|
+
*/
|
|
50
|
+
setState(newState) {
|
|
51
|
+
const oldState = this.state;
|
|
52
|
+
this.state = newState;
|
|
53
|
+
return PluginManager_1.PluginManager.swapStateChange(this, oldState);
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Returns unique identifier of the swap in the form <hash>_<sequence> or just <hash> if the swap type doesn't
|
|
57
|
+
* use sequence number
|
|
58
|
+
*/
|
|
59
|
+
getIdentifier() {
|
|
60
|
+
if (this.getSequence() != null) {
|
|
61
|
+
return this.chainIdentifier + "_" + this.getIdentifierHash() + "_" + this.getSequence().toString(16);
|
|
62
|
+
}
|
|
63
|
+
return this.chainIdentifier + "_" + this.getIdentifierHash();
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* Checks whether the swap is finished, such that it is final and either successful or failed
|
|
67
|
+
*/
|
|
68
|
+
isFinished() {
|
|
69
|
+
return this.isSuccess() || this.isFailed();
|
|
70
|
+
}
|
|
71
|
+
/**
|
|
72
|
+
* Returns the input amount paid by the user (excluding fees)
|
|
73
|
+
*/
|
|
74
|
+
getInputAmount() {
|
|
75
|
+
return this.getTotalInputAmount() - this.getSwapFee().inInputToken;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
exports.SwapHandlerSwap = SwapHandlerSwap;
|
|
@@ -1,28 +1,28 @@
|
|
|
1
|
-
import { ISwapPrice } from "../../prices/ISwapPrice";
|
|
2
|
-
export type AmountAssertionsConfig = {
|
|
3
|
-
min: bigint;
|
|
4
|
-
max: bigint;
|
|
5
|
-
baseFee: bigint;
|
|
6
|
-
feePPM: bigint;
|
|
7
|
-
};
|
|
8
|
-
export declare abstract class AmountAssertions {
|
|
9
|
-
readonly config: AmountAssertionsConfig;
|
|
10
|
-
readonly swapPricing: ISwapPrice;
|
|
11
|
-
constructor(config: AmountAssertionsConfig, swapPricing: ISwapPrice);
|
|
12
|
-
/**
|
|
13
|
-
* Checks whether the bitcoin amount is within specified min/max bounds
|
|
14
|
-
*
|
|
15
|
-
* @param amount
|
|
16
|
-
* @protected
|
|
17
|
-
* @throws {DefinedRuntimeError} will throw an error if the amount is outside minimum/maximum bounds
|
|
18
|
-
*/
|
|
19
|
-
protected checkBtcAmountInBounds(amount: bigint): void;
|
|
20
|
-
/**
|
|
21
|
-
* Handles and throws plugin errors
|
|
22
|
-
*
|
|
23
|
-
* @param res Response as returned from the PluginManager.onHandlePost{To,From}BtcQuote
|
|
24
|
-
* @protected
|
|
25
|
-
* @throws {DefinedRuntimeError} will throw an error if the response is an error
|
|
26
|
-
*/
|
|
27
|
-
static handlePluginErrorResponses(res: any): void;
|
|
28
|
-
}
|
|
1
|
+
import { ISwapPrice } from "../../prices/ISwapPrice";
|
|
2
|
+
export type AmountAssertionsConfig = {
|
|
3
|
+
min: bigint;
|
|
4
|
+
max: bigint;
|
|
5
|
+
baseFee: bigint;
|
|
6
|
+
feePPM: bigint;
|
|
7
|
+
};
|
|
8
|
+
export declare abstract class AmountAssertions {
|
|
9
|
+
readonly config: AmountAssertionsConfig;
|
|
10
|
+
readonly swapPricing: ISwapPrice;
|
|
11
|
+
constructor(config: AmountAssertionsConfig, swapPricing: ISwapPrice);
|
|
12
|
+
/**
|
|
13
|
+
* Checks whether the bitcoin amount is within specified min/max bounds
|
|
14
|
+
*
|
|
15
|
+
* @param amount
|
|
16
|
+
* @protected
|
|
17
|
+
* @throws {DefinedRuntimeError} will throw an error if the amount is outside minimum/maximum bounds
|
|
18
|
+
*/
|
|
19
|
+
protected checkBtcAmountInBounds(amount: bigint): void;
|
|
20
|
+
/**
|
|
21
|
+
* Handles and throws plugin errors
|
|
22
|
+
*
|
|
23
|
+
* @param res Response as returned from the PluginManager.onHandlePost{To,From}BtcQuote
|
|
24
|
+
* @protected
|
|
25
|
+
* @throws {DefinedRuntimeError} will throw an error if the response is an error
|
|
26
|
+
*/
|
|
27
|
+
static handlePluginErrorResponses(res: any): void;
|
|
28
|
+
}
|
|
@@ -1,74 +1,74 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.AmountAssertions = void 0;
|
|
4
|
-
const IPlugin_1 = require("../../plugins/IPlugin");
|
|
5
|
-
class AmountAssertions {
|
|
6
|
-
constructor(config, swapPricing) {
|
|
7
|
-
this.config = config;
|
|
8
|
-
this.swapPricing = swapPricing;
|
|
9
|
-
}
|
|
10
|
-
/**
|
|
11
|
-
* Checks whether the bitcoin amount is within specified min/max bounds
|
|
12
|
-
*
|
|
13
|
-
* @param amount
|
|
14
|
-
* @protected
|
|
15
|
-
* @throws {DefinedRuntimeError} will throw an error if the amount is outside minimum/maximum bounds
|
|
16
|
-
*/
|
|
17
|
-
checkBtcAmountInBounds(amount) {
|
|
18
|
-
if (amount < this.config.min) {
|
|
19
|
-
throw {
|
|
20
|
-
code: 20003,
|
|
21
|
-
msg: "Amount too low!",
|
|
22
|
-
data: {
|
|
23
|
-
min: this.config.min.toString(10),
|
|
24
|
-
max: this.config.max.toString(10)
|
|
25
|
-
}
|
|
26
|
-
};
|
|
27
|
-
}
|
|
28
|
-
if (amount > this.config.max) {
|
|
29
|
-
throw {
|
|
30
|
-
code: 20004,
|
|
31
|
-
msg: "Amount too high!",
|
|
32
|
-
data: {
|
|
33
|
-
min: this.config.min.toString(10),
|
|
34
|
-
max: this.config.max.toString(10)
|
|
35
|
-
}
|
|
36
|
-
};
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
/**
|
|
40
|
-
* Handles and throws plugin errors
|
|
41
|
-
*
|
|
42
|
-
* @param res Response as returned from the PluginManager.onHandlePost{To,From}BtcQuote
|
|
43
|
-
* @protected
|
|
44
|
-
* @throws {DefinedRuntimeError} will throw an error if the response is an error
|
|
45
|
-
*/
|
|
46
|
-
static handlePluginErrorResponses(res) {
|
|
47
|
-
if (res == null)
|
|
48
|
-
return;
|
|
49
|
-
if ((0, IPlugin_1.isQuoteThrow)(res))
|
|
50
|
-
throw {
|
|
51
|
-
code: 29999,
|
|
52
|
-
msg: res.message
|
|
53
|
-
};
|
|
54
|
-
if ((0, IPlugin_1.isQuoteAmountTooHigh)(res))
|
|
55
|
-
throw {
|
|
56
|
-
code: 20004,
|
|
57
|
-
msg: "Amount too high!",
|
|
58
|
-
data: {
|
|
59
|
-
min: res.data.min.toString(10),
|
|
60
|
-
max: res.data.max.toString(10)
|
|
61
|
-
}
|
|
62
|
-
};
|
|
63
|
-
if ((0, IPlugin_1.isQuoteAmountTooLow)(res))
|
|
64
|
-
throw {
|
|
65
|
-
code: 20003,
|
|
66
|
-
msg: "Amount too low!",
|
|
67
|
-
data: {
|
|
68
|
-
min: res.data.min.toString(10),
|
|
69
|
-
max: res.data.max.toString(10)
|
|
70
|
-
}
|
|
71
|
-
};
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
exports.AmountAssertions = AmountAssertions;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AmountAssertions = void 0;
|
|
4
|
+
const IPlugin_1 = require("../../plugins/IPlugin");
|
|
5
|
+
class AmountAssertions {
|
|
6
|
+
constructor(config, swapPricing) {
|
|
7
|
+
this.config = config;
|
|
8
|
+
this.swapPricing = swapPricing;
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* Checks whether the bitcoin amount is within specified min/max bounds
|
|
12
|
+
*
|
|
13
|
+
* @param amount
|
|
14
|
+
* @protected
|
|
15
|
+
* @throws {DefinedRuntimeError} will throw an error if the amount is outside minimum/maximum bounds
|
|
16
|
+
*/
|
|
17
|
+
checkBtcAmountInBounds(amount) {
|
|
18
|
+
if (amount < this.config.min) {
|
|
19
|
+
throw {
|
|
20
|
+
code: 20003,
|
|
21
|
+
msg: "Amount too low!",
|
|
22
|
+
data: {
|
|
23
|
+
min: this.config.min.toString(10),
|
|
24
|
+
max: this.config.max.toString(10)
|
|
25
|
+
}
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
if (amount > this.config.max) {
|
|
29
|
+
throw {
|
|
30
|
+
code: 20004,
|
|
31
|
+
msg: "Amount too high!",
|
|
32
|
+
data: {
|
|
33
|
+
min: this.config.min.toString(10),
|
|
34
|
+
max: this.config.max.toString(10)
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Handles and throws plugin errors
|
|
41
|
+
*
|
|
42
|
+
* @param res Response as returned from the PluginManager.onHandlePost{To,From}BtcQuote
|
|
43
|
+
* @protected
|
|
44
|
+
* @throws {DefinedRuntimeError} will throw an error if the response is an error
|
|
45
|
+
*/
|
|
46
|
+
static handlePluginErrorResponses(res) {
|
|
47
|
+
if (res == null)
|
|
48
|
+
return;
|
|
49
|
+
if ((0, IPlugin_1.isQuoteThrow)(res))
|
|
50
|
+
throw {
|
|
51
|
+
code: 29999,
|
|
52
|
+
msg: res.message
|
|
53
|
+
};
|
|
54
|
+
if ((0, IPlugin_1.isQuoteAmountTooHigh)(res))
|
|
55
|
+
throw {
|
|
56
|
+
code: 20004,
|
|
57
|
+
msg: "Amount too high!",
|
|
58
|
+
data: {
|
|
59
|
+
min: res.data.min.toString(10),
|
|
60
|
+
max: res.data.max.toString(10)
|
|
61
|
+
}
|
|
62
|
+
};
|
|
63
|
+
if ((0, IPlugin_1.isQuoteAmountTooLow)(res))
|
|
64
|
+
throw {
|
|
65
|
+
code: 20003,
|
|
66
|
+
msg: "Amount too low!",
|
|
67
|
+
data: {
|
|
68
|
+
min: res.data.min.toString(10),
|
|
69
|
+
max: res.data.max.toString(10)
|
|
70
|
+
}
|
|
71
|
+
};
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
exports.AmountAssertions = AmountAssertions;
|
|
@@ -1,76 +1,76 @@
|
|
|
1
|
-
import { FromBtcLnRequestType } from "../escrow/frombtcln_abstract/FromBtcLnAbs";
|
|
2
|
-
import { FromBtcRequestType } from "../escrow/frombtc_abstract/FromBtcAbs";
|
|
3
|
-
import { FromBtcLnTrustedRequestType } from "../trusted/frombtcln_trusted/FromBtcLnTrusted";
|
|
4
|
-
import { RequestData, SwapHandlerType } from "../SwapHandler";
|
|
5
|
-
import { AmountAssertions, AmountAssertionsConfig } from "./AmountAssertions";
|
|
6
|
-
import { ISwapPrice } from "../../prices/ISwapPrice";
|
|
7
|
-
import { FromBtcTrustedRequestType } from "../trusted/frombtc_trusted/FromBtcTrusted";
|
|
8
|
-
import { SpvVaultSwapRequestType } from "../spv_vault_swap/SpvVaultSwapHandler";
|
|
9
|
-
export type FromBtcAmountAssertionsConfig = AmountAssertionsConfig & {
|
|
10
|
-
gasTokenMax?: {
|
|
11
|
-
[chainId: string]: bigint;
|
|
12
|
-
};
|
|
13
|
-
};
|
|
14
|
-
export declare class FromBtcAmountAssertions extends AmountAssertions {
|
|
15
|
-
readonly config: FromBtcAmountAssertionsConfig;
|
|
16
|
-
constructor(config: FromBtcAmountAssertionsConfig, swapPricing: ISwapPrice);
|
|
17
|
-
/**
|
|
18
|
-
* Checks minimums/maximums, calculates the fee & total amount
|
|
19
|
-
*
|
|
20
|
-
* @param swapType
|
|
21
|
-
* @param request
|
|
22
|
-
* @param requestedAmount
|
|
23
|
-
* @param gasAmount
|
|
24
|
-
* @throws {DefinedRuntimeError} will throw an error if the amount is outside minimum/maximum bounds
|
|
25
|
-
*/
|
|
26
|
-
preCheckFromBtcAmounts(swapType: SwapHandlerType.FROM_BTCLN | SwapHandlerType.FROM_BTC | SwapHandlerType.FROM_BTCLN_TRUSTED | SwapHandlerType.FROM_BTC_TRUSTED | SwapHandlerType.FROM_BTC_SPV | SwapHandlerType.FROM_BTCLN_AUTO, request: RequestData<FromBtcLnRequestType | FromBtcRequestType | FromBtcLnTrustedRequestType | FromBtcTrustedRequestType | SpvVaultSwapRequestType>, requestedAmount: {
|
|
27
|
-
input: boolean;
|
|
28
|
-
amount: bigint;
|
|
29
|
-
token: string;
|
|
30
|
-
}, gasAmount?: {
|
|
31
|
-
input: false;
|
|
32
|
-
amount: bigint;
|
|
33
|
-
token: string;
|
|
34
|
-
}): Promise<{
|
|
35
|
-
baseFee: bigint;
|
|
36
|
-
feePPM: bigint;
|
|
37
|
-
securityDepositApyPPM?: bigint;
|
|
38
|
-
securityDepositBaseMultiplierPPM?: bigint;
|
|
39
|
-
}>;
|
|
40
|
-
/**
|
|
41
|
-
* Checks minimums/maximums, calculates the fee & total amount
|
|
42
|
-
*
|
|
43
|
-
* @param swapType
|
|
44
|
-
* @param request
|
|
45
|
-
* @param requestedAmount
|
|
46
|
-
* @param fees
|
|
47
|
-
* @param signal
|
|
48
|
-
* @param gasTokenAmount
|
|
49
|
-
* @throws {DefinedRuntimeError} will throw an error if the amount is outside minimum/maximum bounds
|
|
50
|
-
*/
|
|
51
|
-
checkFromBtcAmount(swapType: SwapHandlerType.FROM_BTCLN | SwapHandlerType.FROM_BTC | SwapHandlerType.FROM_BTCLN_TRUSTED | SwapHandlerType.FROM_BTC_TRUSTED | SwapHandlerType.FROM_BTC_SPV | SwapHandlerType.FROM_BTCLN_AUTO, request: RequestData<FromBtcLnRequestType | FromBtcRequestType | FromBtcLnTrustedRequestType | FromBtcTrustedRequestType | SpvVaultSwapRequestType>, requestedAmount: {
|
|
52
|
-
input: boolean;
|
|
53
|
-
amount: bigint;
|
|
54
|
-
token: string;
|
|
55
|
-
pricePrefetch?: Promise<bigint>;
|
|
56
|
-
}, fees: {
|
|
57
|
-
baseFee: bigint;
|
|
58
|
-
feePPM: bigint;
|
|
59
|
-
}, signal: AbortSignal, gasTokenAmount?: {
|
|
60
|
-
input: false;
|
|
61
|
-
amount: bigint;
|
|
62
|
-
token: string;
|
|
63
|
-
pricePrefetch?: Promise<bigint>;
|
|
64
|
-
}): Promise<{
|
|
65
|
-
amountBD: bigint;
|
|
66
|
-
swapFee: bigint;
|
|
67
|
-
swapFeeInToken: bigint;
|
|
68
|
-
totalInToken: bigint;
|
|
69
|
-
amountBDgas?: bigint;
|
|
70
|
-
gasSwapFee?: bigint;
|
|
71
|
-
gasSwapFeeInToken?: bigint;
|
|
72
|
-
totalInGasToken?: bigint;
|
|
73
|
-
securityDepositApyPPM?: bigint;
|
|
74
|
-
securityDepositBaseMultiplierPPM?: bigint;
|
|
75
|
-
}>;
|
|
76
|
-
}
|
|
1
|
+
import { FromBtcLnRequestType } from "../escrow/frombtcln_abstract/FromBtcLnAbs";
|
|
2
|
+
import { FromBtcRequestType } from "../escrow/frombtc_abstract/FromBtcAbs";
|
|
3
|
+
import { FromBtcLnTrustedRequestType } from "../trusted/frombtcln_trusted/FromBtcLnTrusted";
|
|
4
|
+
import { RequestData, SwapHandlerType } from "../SwapHandler";
|
|
5
|
+
import { AmountAssertions, AmountAssertionsConfig } from "./AmountAssertions";
|
|
6
|
+
import { ISwapPrice } from "../../prices/ISwapPrice";
|
|
7
|
+
import { FromBtcTrustedRequestType } from "../trusted/frombtc_trusted/FromBtcTrusted";
|
|
8
|
+
import { SpvVaultSwapRequestType } from "../spv_vault_swap/SpvVaultSwapHandler";
|
|
9
|
+
export type FromBtcAmountAssertionsConfig = AmountAssertionsConfig & {
|
|
10
|
+
gasTokenMax?: {
|
|
11
|
+
[chainId: string]: bigint;
|
|
12
|
+
};
|
|
13
|
+
};
|
|
14
|
+
export declare class FromBtcAmountAssertions extends AmountAssertions {
|
|
15
|
+
readonly config: FromBtcAmountAssertionsConfig;
|
|
16
|
+
constructor(config: FromBtcAmountAssertionsConfig, swapPricing: ISwapPrice);
|
|
17
|
+
/**
|
|
18
|
+
* Checks minimums/maximums, calculates the fee & total amount
|
|
19
|
+
*
|
|
20
|
+
* @param swapType
|
|
21
|
+
* @param request
|
|
22
|
+
* @param requestedAmount
|
|
23
|
+
* @param gasAmount
|
|
24
|
+
* @throws {DefinedRuntimeError} will throw an error if the amount is outside minimum/maximum bounds
|
|
25
|
+
*/
|
|
26
|
+
preCheckFromBtcAmounts(swapType: SwapHandlerType.FROM_BTCLN | SwapHandlerType.FROM_BTC | SwapHandlerType.FROM_BTCLN_TRUSTED | SwapHandlerType.FROM_BTC_TRUSTED | SwapHandlerType.FROM_BTC_SPV | SwapHandlerType.FROM_BTCLN_AUTO, request: RequestData<FromBtcLnRequestType | FromBtcRequestType | FromBtcLnTrustedRequestType | FromBtcTrustedRequestType | SpvVaultSwapRequestType>, requestedAmount: {
|
|
27
|
+
input: boolean;
|
|
28
|
+
amount: bigint;
|
|
29
|
+
token: string;
|
|
30
|
+
}, gasAmount?: {
|
|
31
|
+
input: false;
|
|
32
|
+
amount: bigint;
|
|
33
|
+
token: string;
|
|
34
|
+
}): Promise<{
|
|
35
|
+
baseFee: bigint;
|
|
36
|
+
feePPM: bigint;
|
|
37
|
+
securityDepositApyPPM?: bigint;
|
|
38
|
+
securityDepositBaseMultiplierPPM?: bigint;
|
|
39
|
+
}>;
|
|
40
|
+
/**
|
|
41
|
+
* Checks minimums/maximums, calculates the fee & total amount
|
|
42
|
+
*
|
|
43
|
+
* @param swapType
|
|
44
|
+
* @param request
|
|
45
|
+
* @param requestedAmount
|
|
46
|
+
* @param fees
|
|
47
|
+
* @param signal
|
|
48
|
+
* @param gasTokenAmount
|
|
49
|
+
* @throws {DefinedRuntimeError} will throw an error if the amount is outside minimum/maximum bounds
|
|
50
|
+
*/
|
|
51
|
+
checkFromBtcAmount(swapType: SwapHandlerType.FROM_BTCLN | SwapHandlerType.FROM_BTC | SwapHandlerType.FROM_BTCLN_TRUSTED | SwapHandlerType.FROM_BTC_TRUSTED | SwapHandlerType.FROM_BTC_SPV | SwapHandlerType.FROM_BTCLN_AUTO, request: RequestData<FromBtcLnRequestType | FromBtcRequestType | FromBtcLnTrustedRequestType | FromBtcTrustedRequestType | SpvVaultSwapRequestType>, requestedAmount: {
|
|
52
|
+
input: boolean;
|
|
53
|
+
amount: bigint;
|
|
54
|
+
token: string;
|
|
55
|
+
pricePrefetch?: Promise<bigint>;
|
|
56
|
+
}, fees: {
|
|
57
|
+
baseFee: bigint;
|
|
58
|
+
feePPM: bigint;
|
|
59
|
+
}, signal: AbortSignal, gasTokenAmount?: {
|
|
60
|
+
input: false;
|
|
61
|
+
amount: bigint;
|
|
62
|
+
token: string;
|
|
63
|
+
pricePrefetch?: Promise<bigint>;
|
|
64
|
+
}): Promise<{
|
|
65
|
+
amountBD: bigint;
|
|
66
|
+
swapFee: bigint;
|
|
67
|
+
swapFeeInToken: bigint;
|
|
68
|
+
totalInToken: bigint;
|
|
69
|
+
amountBDgas?: bigint;
|
|
70
|
+
gasSwapFee?: bigint;
|
|
71
|
+
gasSwapFeeInToken?: bigint;
|
|
72
|
+
totalInGasToken?: bigint;
|
|
73
|
+
securityDepositApyPPM?: bigint;
|
|
74
|
+
securityDepositBaseMultiplierPPM?: bigint;
|
|
75
|
+
}>;
|
|
76
|
+
}
|