@atomiqlabs/sdk 8.6.4 → 8.6.6
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/dist/SmartChainAssets.d.ts +181 -181
- package/dist/SmartChainAssets.js +181 -181
- package/dist/bitcoin/coinselect2/accumulative.d.ts +6 -6
- package/dist/bitcoin/coinselect2/accumulative.js +51 -52
- package/dist/bitcoin/coinselect2/blackjack.d.ts +6 -6
- package/dist/bitcoin/coinselect2/blackjack.js +37 -38
- package/dist/bitcoin/coinselect2/index.d.ts +17 -19
- package/dist/bitcoin/coinselect2/index.js +69 -69
- package/dist/bitcoin/coinselect2/utils.d.ts +75 -77
- package/dist/bitcoin/coinselect2/utils.js +123 -123
- package/dist/bitcoin/wallet/BitcoinWallet.d.ts +128 -130
- package/dist/bitcoin/wallet/BitcoinWallet.js +322 -322
- package/dist/bitcoin/wallet/IBitcoinWallet.d.ts +78 -78
- package/dist/bitcoin/wallet/IBitcoinWallet.js +20 -21
- package/dist/bitcoin/wallet/SingleAddressBitcoinWallet.d.ts +99 -101
- package/dist/bitcoin/wallet/SingleAddressBitcoinWallet.js +176 -176
- package/dist/enums/FeeType.d.ts +15 -15
- package/dist/enums/FeeType.js +19 -19
- package/dist/enums/SwapAmountType.d.ts +15 -15
- package/dist/enums/SwapAmountType.js +19 -19
- package/dist/enums/SwapDirection.d.ts +15 -15
- package/dist/enums/SwapDirection.js +19 -19
- package/dist/enums/SwapSide.d.ts +15 -15
- package/dist/enums/SwapSide.js +19 -19
- package/dist/enums/SwapType.d.ts +75 -75
- package/dist/enums/SwapType.js +79 -79
- package/dist/errors/IntermediaryError.d.ts +13 -13
- package/dist/errors/IntermediaryError.js +27 -27
- package/dist/errors/RequestError.d.ts +32 -32
- package/dist/errors/RequestError.js +54 -54
- package/dist/errors/UserError.d.ts +8 -8
- package/dist/errors/UserError.js +16 -16
- package/dist/events/UnifiedSwapEventListener.d.ts +23 -23
- package/dist/events/UnifiedSwapEventListener.js +130 -130
- package/dist/http/HttpUtils.d.ts +27 -27
- package/dist/http/HttpUtils.js +90 -91
- package/dist/http/paramcoders/IParamReader.d.ts +8 -8
- package/dist/http/paramcoders/IParamReader.js +2 -2
- package/dist/http/paramcoders/ParamDecoder.d.ts +42 -44
- package/dist/http/paramcoders/ParamDecoder.js +137 -137
- package/dist/http/paramcoders/ParamEncoder.d.ts +18 -20
- package/dist/http/paramcoders/ParamEncoder.js +36 -36
- package/dist/http/paramcoders/SchemaVerifier.d.ts +26 -26
- package/dist/http/paramcoders/SchemaVerifier.js +145 -145
- package/dist/http/paramcoders/client/ResponseParamDecoder.d.ts +11 -11
- package/dist/http/paramcoders/client/ResponseParamDecoder.js +57 -57
- package/dist/http/paramcoders/client/StreamParamEncoder.d.ts +11 -13
- package/dist/http/paramcoders/client/StreamParamEncoder.js +26 -26
- package/dist/http/paramcoders/client/StreamingFetchPromise.d.ts +16 -16
- package/dist/http/paramcoders/client/StreamingFetchPromise.js +173 -174
- package/dist/index.d.ts +85 -85
- package/dist/index.js +158 -158
- package/dist/intermediaries/Intermediary.d.ts +157 -157
- package/dist/intermediaries/Intermediary.js +142 -142
- package/dist/intermediaries/IntermediaryDiscovery.d.ts +198 -199
- package/dist/intermediaries/IntermediaryDiscovery.js +406 -406
- package/dist/intermediaries/apis/IntermediaryAPI.d.ts +437 -438
- package/dist/intermediaries/apis/IntermediaryAPI.js +603 -602
- package/dist/intermediaries/apis/TrustedIntermediaryAPI.d.ts +155 -155
- package/dist/intermediaries/apis/TrustedIntermediaryAPI.js +137 -137
- package/dist/lnurl/LNURL.d.ts +102 -102
- package/dist/lnurl/LNURL.js +321 -321
- package/dist/prices/RedundantSwapPrice.d.ts +110 -110
- package/dist/prices/RedundantSwapPrice.js +222 -222
- package/dist/prices/SingleSwapPrice.d.ts +34 -34
- package/dist/prices/SingleSwapPrice.js +44 -44
- package/dist/prices/SwapPriceWithChain.d.ts +107 -107
- package/dist/prices/SwapPriceWithChain.js +128 -128
- package/dist/prices/abstract/ICachedSwapPrice.d.ts +28 -28
- package/dist/prices/abstract/ICachedSwapPrice.js +62 -62
- package/dist/prices/abstract/IPriceProvider.d.ts +81 -81
- package/dist/prices/abstract/IPriceProvider.js +74 -74
- package/dist/prices/abstract/ISwapPrice.d.ts +168 -166
- package/dist/prices/abstract/ISwapPrice.js +279 -267
- package/dist/prices/providers/BinancePriceProvider.d.ts +23 -23
- package/dist/prices/providers/BinancePriceProvider.js +30 -30
- package/dist/prices/providers/CoinGeckoPriceProvider.d.ts +23 -23
- package/dist/prices/providers/CoinGeckoPriceProvider.js +29 -29
- package/dist/prices/providers/CoinPaprikaPriceProvider.d.ts +25 -25
- package/dist/prices/providers/CoinPaprikaPriceProvider.js +29 -29
- package/dist/prices/providers/CustomPriceProvider.d.ts +24 -24
- package/dist/prices/providers/CustomPriceProvider.js +35 -35
- package/dist/prices/providers/KrakenPriceProvider.d.ts +38 -38
- package/dist/prices/providers/KrakenPriceProvider.js +45 -45
- package/dist/prices/providers/OKXPriceProvider.d.ts +34 -34
- package/dist/prices/providers/OKXPriceProvider.js +29 -29
- package/dist/prices/providers/abstract/ExchangePriceProvider.d.ts +17 -17
- package/dist/prices/providers/abstract/ExchangePriceProvider.js +21 -21
- package/dist/prices/providers/abstract/HttpPriceProvider.d.ts +7 -7
- package/dist/prices/providers/abstract/HttpPriceProvider.js +12 -12
- package/dist/storage/IUnifiedStorage.d.ts +85 -85
- package/dist/storage/IUnifiedStorage.js +2 -2
- package/dist/storage/UnifiedSwapStorage.d.ts +114 -114
- package/dist/storage/UnifiedSwapStorage.js +116 -116
- package/dist/storage-browser/IndexedDBUnifiedStorage.d.ts +63 -63
- package/dist/storage-browser/IndexedDBUnifiedStorage.js +298 -298
- package/dist/storage-browser/LocalStorageManager.d.ts +49 -49
- package/dist/storage-browser/LocalStorageManager.js +93 -93
- package/dist/swapper/Swapper.d.ts +686 -687
- package/dist/swapper/Swapper.js +1603 -1603
- package/dist/swapper/SwapperFactory.d.ts +135 -135
- package/dist/swapper/SwapperFactory.js +162 -162
- package/dist/swapper/SwapperUtils.d.ts +200 -200
- package/dist/swapper/SwapperUtils.js +467 -467
- package/dist/swapper/SwapperWithChain.d.ts +404 -404
- package/dist/swapper/SwapperWithChain.js +469 -469
- package/dist/swapper/SwapperWithSigner.d.ts +322 -322
- package/dist/swapper/SwapperWithSigner.js +318 -318
- package/dist/swaps/IAddressSwap.d.ts +22 -22
- package/dist/swaps/IAddressSwap.js +13 -14
- package/dist/swaps/IBTCWalletSwap.d.ts +73 -73
- package/dist/swaps/IBTCWalletSwap.js +17 -18
- package/dist/swaps/IClaimableSwap.d.ts +49 -49
- package/dist/swaps/IClaimableSwap.js +14 -15
- package/dist/swaps/IClaimableSwapWrapper.d.ts +15 -15
- package/dist/swaps/IClaimableSwapWrapper.js +2 -2
- package/dist/swaps/IRefundableSwap.d.ts +43 -43
- package/dist/swaps/IRefundableSwap.js +13 -14
- package/dist/swaps/ISwap.d.ts +386 -387
- package/dist/swaps/ISwap.js +346 -341
- package/dist/swaps/ISwapWithGasDrop.d.ts +21 -21
- package/dist/swaps/ISwapWithGasDrop.js +11 -12
- package/dist/swaps/ISwapWrapper.d.ts +283 -284
- package/dist/swaps/ISwapWrapper.js +353 -353
- package/dist/swaps/escrow_swaps/IEscrowSelfInitSwap.d.ts +98 -98
- package/dist/swaps/escrow_swaps/IEscrowSelfInitSwap.js +126 -126
- package/dist/swaps/escrow_swaps/IEscrowSwap.d.ts +133 -135
- package/dist/swaps/escrow_swaps/IEscrowSwap.js +169 -169
- package/dist/swaps/escrow_swaps/IEscrowSwapWrapper.d.ts +114 -115
- package/dist/swaps/escrow_swaps/IEscrowSwapWrapper.js +134 -134
- package/dist/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.d.ts +98 -101
- package/dist/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.js +130 -130
- package/dist/swaps/escrow_swaps/frombtc/IFromBTCSelfInitSwap.d.ts +162 -162
- package/dist/swaps/escrow_swaps/frombtc/IFromBTCSelfInitSwap.js +190 -190
- package/dist/swaps/escrow_swaps/frombtc/IFromBTCWrapper.d.ts +58 -58
- package/dist/swaps/escrow_swaps/frombtc/IFromBTCWrapper.js +78 -78
- package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.d.ts +529 -531
- package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.js +1285 -1285
- package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.d.ts +181 -184
- package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.js +418 -417
- package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.d.ts +581 -583
- package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.js +1371 -1371
- package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.d.ts +225 -228
- package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.js +506 -506
- package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCSwap.d.ts +458 -458
- package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCSwap.js +1126 -1126
- package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.d.ts +190 -191
- package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.js +378 -377
- package/dist/swaps/escrow_swaps/tobtc/IToBTCSwap.d.ts +403 -403
- package/dist/swaps/escrow_swaps/tobtc/IToBTCSwap.js +924 -924
- package/dist/swaps/escrow_swaps/tobtc/IToBTCWrapper.d.ts +62 -62
- package/dist/swaps/escrow_swaps/tobtc/IToBTCWrapper.js +112 -112
- package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.d.ts +125 -127
- package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.js +256 -256
- package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.d.ts +241 -242
- package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.js +520 -520
- package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCSwap.d.ts +73 -73
- package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCSwap.js +155 -155
- package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.d.ts +127 -128
- package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.js +278 -278
- package/dist/swaps/spv_swaps/SpvFromBTCSwap.d.ts +630 -630
- package/dist/swaps/spv_swaps/SpvFromBTCSwap.js +1443 -1443
- package/dist/swaps/spv_swaps/SpvFromBTCWrapper.d.ts +213 -207
- package/dist/swaps/spv_swaps/SpvFromBTCWrapper.js +756 -755
- package/dist/swaps/trusted/ln/LnForGasSwap.d.ts +261 -261
- package/dist/swaps/trusted/ln/LnForGasSwap.js +511 -511
- package/dist/swaps/trusted/ln/LnForGasWrapper.d.ts +40 -40
- package/dist/swaps/trusted/ln/LnForGasWrapper.js +82 -82
- package/dist/swaps/trusted/onchain/OnchainForGasSwap.d.ts +342 -342
- package/dist/swaps/trusted/onchain/OnchainForGasSwap.js +715 -715
- package/dist/swaps/trusted/onchain/OnchainForGasWrapper.d.ts +68 -69
- package/dist/swaps/trusted/onchain/OnchainForGasWrapper.js +92 -92
- package/dist/types/AmountData.d.ts +10 -10
- package/dist/types/AmountData.js +2 -2
- package/dist/types/CustomPriceFunction.d.ts +11 -11
- package/dist/types/CustomPriceFunction.js +2 -2
- package/dist/types/PriceInfoType.d.ts +28 -28
- package/dist/types/PriceInfoType.js +56 -57
- package/dist/types/SwapExecutionAction.d.ts +88 -88
- package/dist/types/SwapExecutionAction.js +2 -2
- package/dist/types/SwapStateInfo.d.ts +5 -5
- package/dist/types/SwapStateInfo.js +2 -2
- package/dist/types/SwapWithSigner.d.ts +17 -17
- package/dist/types/SwapWithSigner.js +42 -43
- package/dist/types/Token.d.ts +99 -99
- package/dist/types/Token.js +76 -76
- package/dist/types/TokenAmount.d.ts +69 -69
- package/dist/types/TokenAmount.js +59 -60
- package/dist/types/fees/Fee.d.ts +50 -50
- package/dist/types/fees/Fee.js +2 -2
- package/dist/types/fees/FeeBreakdown.d.ts +11 -11
- package/dist/types/fees/FeeBreakdown.js +2 -2
- package/dist/types/fees/PercentagePPM.d.ts +17 -17
- package/dist/types/fees/PercentagePPM.js +17 -18
- package/dist/types/lnurl/LNURLPay.d.ts +61 -61
- package/dist/types/lnurl/LNURLPay.js +30 -31
- package/dist/types/lnurl/LNURLWithdraw.d.ts +48 -48
- package/dist/types/lnurl/LNURLWithdraw.js +26 -27
- package/dist/types/wallets/LightningInvoiceCreateService.d.ts +24 -24
- package/dist/types/wallets/LightningInvoiceCreateService.js +14 -15
- package/dist/types/wallets/MinimalBitcoinWalletInterface.d.ts +23 -23
- package/dist/types/wallets/MinimalBitcoinWalletInterface.js +2 -2
- package/dist/types/wallets/MinimalLightningNetworkWalletInterface.d.ts +9 -9
- package/dist/types/wallets/MinimalLightningNetworkWalletInterface.js +2 -2
- package/dist/utils/AutomaticClockDriftCorrection.d.ts +1 -1
- package/dist/utils/AutomaticClockDriftCorrection.js +69 -70
- package/dist/utils/BitcoinUtils.d.ts +12 -14
- package/dist/utils/BitcoinUtils.js +101 -102
- package/dist/utils/BitcoinWalletUtils.d.ts +7 -7
- package/dist/utils/BitcoinWalletUtils.js +13 -14
- package/dist/utils/Logger.d.ts +7 -7
- package/dist/utils/Logger.js +11 -12
- package/dist/utils/RetryUtils.d.ts +22 -22
- package/dist/utils/RetryUtils.js +66 -67
- package/dist/utils/SwapUtils.d.ts +88 -88
- package/dist/utils/SwapUtils.js +72 -72
- package/dist/utils/TimeoutUtils.d.ts +17 -17
- package/dist/utils/TimeoutUtils.js +54 -55
- package/dist/utils/TokenUtils.d.ts +19 -19
- package/dist/utils/TokenUtils.js +36 -37
- package/dist/utils/TypeUtils.d.ts +7 -7
- package/dist/utils/TypeUtils.js +2 -2
- package/dist/utils/Utils.d.ts +56 -58
- package/dist/utils/Utils.js +193 -194
- package/package.json +1 -1
- package/src/intermediaries/apis/IntermediaryAPI.ts +4 -2
- package/src/prices/abstract/ISwapPrice.ts +19 -6
- package/src/swaps/ISwap.ts +17 -6
- package/src/swaps/ISwapWrapper.ts +4 -3
- package/src/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.ts +4 -2
- package/src/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.ts +4 -1
- package/src/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.ts +2 -2
- package/src/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.ts +4 -2
- package/src/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.ts +6 -6
- package/src/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.ts +5 -5
- package/src/swaps/spv_swaps/SpvFromBTCSwap.ts +4 -1
- package/src/swaps/spv_swaps/SpvFromBTCWrapper.ts +10 -2
- package/src/swaps/trusted/ln/LnForGasWrapper.ts +1 -1
- package/src/swaps/trusted/onchain/OnchainForGasWrapper.ts +1 -1
|
@@ -1,73 +1,73 @@
|
|
|
1
|
-
import { ToBTCDefinition, ToBTCWrapper } from "./ToBTCWrapper";
|
|
2
|
-
import { IToBTCSwap, IToBTCSwapInit } from "../IToBTCSwap";
|
|
3
|
-
import { SwapType } from "../../../../enums/SwapType";
|
|
4
|
-
import { ChainType, SwapData } from "@atomiqlabs/base";
|
|
5
|
-
import { TokenAmount } from "../../../../types/TokenAmount";
|
|
6
|
-
import { BtcToken } from "../../../../types/Token";
|
|
7
|
-
import { LoggerType } from "../../../../utils/Logger";
|
|
8
|
-
export type ToBTCSwapInit<T extends SwapData> = IToBTCSwapInit<T> & {
|
|
9
|
-
address?: string;
|
|
10
|
-
amount?: bigint;
|
|
11
|
-
confirmationTarget: number;
|
|
12
|
-
satsPerVByte: number;
|
|
13
|
-
requiredConfirmations?: number;
|
|
14
|
-
nonce?: bigint;
|
|
15
|
-
};
|
|
16
|
-
export declare function isToBTCSwapInit<T extends SwapData>(obj: any): obj is ToBTCSwapInit<T>;
|
|
17
|
-
/**
|
|
18
|
-
* Escrow based (PrTLC) swap for Smart chains -> Bitcoin
|
|
19
|
-
*
|
|
20
|
-
* @category Swaps/Smart chain → Bitcoin
|
|
21
|
-
*/
|
|
22
|
-
export declare class ToBTCSwap<T extends ChainType = ChainType> extends IToBTCSwap<T, ToBTCDefinition<T>> {
|
|
23
|
-
protected readonly TYPE: SwapType.TO_BTC;
|
|
24
|
-
/**
|
|
25
|
-
* @internal
|
|
26
|
-
*/
|
|
27
|
-
protected readonly outputToken: BtcToken<false>;
|
|
28
|
-
/**
|
|
29
|
-
* @internal
|
|
30
|
-
*/
|
|
31
|
-
protected readonly logger: LoggerType;
|
|
32
|
-
private address?;
|
|
33
|
-
private amount?;
|
|
34
|
-
private readonly confirmationTarget;
|
|
35
|
-
private readonly satsPerVByte;
|
|
36
|
-
private requiredConfirmations?;
|
|
37
|
-
private nonce?;
|
|
38
|
-
private txId?;
|
|
39
|
-
constructor(wrapper: ToBTCWrapper<T>, serializedObject: any);
|
|
40
|
-
constructor(wrapper: ToBTCWrapper<T>, init: ToBTCSwapInit<T["Data"]>);
|
|
41
|
-
/**
|
|
42
|
-
* @inheritDoc
|
|
43
|
-
* @internal
|
|
44
|
-
*/
|
|
45
|
-
_setPaymentResult(result: {
|
|
46
|
-
secret?: string;
|
|
47
|
-
txId?: string;
|
|
48
|
-
}, check?: boolean): Promise<boolean>;
|
|
49
|
-
/**
|
|
50
|
-
* @inheritDoc
|
|
51
|
-
*/
|
|
52
|
-
getOutputToken(): BtcToken<false>;
|
|
53
|
-
/**
|
|
54
|
-
* @inheritDoc
|
|
55
|
-
*/
|
|
56
|
-
getOutput(): TokenAmount<BtcToken<false>>;
|
|
57
|
-
/**
|
|
58
|
-
* @inheritDoc
|
|
59
|
-
*/
|
|
60
|
-
getOutputAddress(): string | null;
|
|
61
|
-
/**
|
|
62
|
-
* @inheritDoc
|
|
63
|
-
*/
|
|
64
|
-
getOutputTxId(): string | null;
|
|
65
|
-
/**
|
|
66
|
-
* Returns fee rate of the output bitcoin transaction in sats/vB as reported by the intermediary (LP)
|
|
67
|
-
*/
|
|
68
|
-
getBitcoinFeeRate(): number;
|
|
69
|
-
/**
|
|
70
|
-
* @inheritDoc
|
|
71
|
-
*/
|
|
72
|
-
serialize(): any;
|
|
73
|
-
}
|
|
1
|
+
import { ToBTCDefinition, ToBTCWrapper } from "./ToBTCWrapper";
|
|
2
|
+
import { IToBTCSwap, IToBTCSwapInit } from "../IToBTCSwap";
|
|
3
|
+
import { SwapType } from "../../../../enums/SwapType";
|
|
4
|
+
import { ChainType, SwapData } from "@atomiqlabs/base";
|
|
5
|
+
import { TokenAmount } from "../../../../types/TokenAmount";
|
|
6
|
+
import { BtcToken } from "../../../../types/Token";
|
|
7
|
+
import { LoggerType } from "../../../../utils/Logger";
|
|
8
|
+
export type ToBTCSwapInit<T extends SwapData> = IToBTCSwapInit<T> & {
|
|
9
|
+
address?: string;
|
|
10
|
+
amount?: bigint;
|
|
11
|
+
confirmationTarget: number;
|
|
12
|
+
satsPerVByte: number;
|
|
13
|
+
requiredConfirmations?: number;
|
|
14
|
+
nonce?: bigint;
|
|
15
|
+
};
|
|
16
|
+
export declare function isToBTCSwapInit<T extends SwapData>(obj: any): obj is ToBTCSwapInit<T>;
|
|
17
|
+
/**
|
|
18
|
+
* Escrow based (PrTLC) swap for Smart chains -> Bitcoin
|
|
19
|
+
*
|
|
20
|
+
* @category Swaps/Smart chain → Bitcoin
|
|
21
|
+
*/
|
|
22
|
+
export declare class ToBTCSwap<T extends ChainType = ChainType> extends IToBTCSwap<T, ToBTCDefinition<T>> {
|
|
23
|
+
protected readonly TYPE: SwapType.TO_BTC;
|
|
24
|
+
/**
|
|
25
|
+
* @internal
|
|
26
|
+
*/
|
|
27
|
+
protected readonly outputToken: BtcToken<false>;
|
|
28
|
+
/**
|
|
29
|
+
* @internal
|
|
30
|
+
*/
|
|
31
|
+
protected readonly logger: LoggerType;
|
|
32
|
+
private address?;
|
|
33
|
+
private amount?;
|
|
34
|
+
private readonly confirmationTarget;
|
|
35
|
+
private readonly satsPerVByte;
|
|
36
|
+
private requiredConfirmations?;
|
|
37
|
+
private nonce?;
|
|
38
|
+
private txId?;
|
|
39
|
+
constructor(wrapper: ToBTCWrapper<T>, serializedObject: any);
|
|
40
|
+
constructor(wrapper: ToBTCWrapper<T>, init: ToBTCSwapInit<T["Data"]>);
|
|
41
|
+
/**
|
|
42
|
+
* @inheritDoc
|
|
43
|
+
* @internal
|
|
44
|
+
*/
|
|
45
|
+
_setPaymentResult(result: {
|
|
46
|
+
secret?: string;
|
|
47
|
+
txId?: string;
|
|
48
|
+
}, check?: boolean): Promise<boolean>;
|
|
49
|
+
/**
|
|
50
|
+
* @inheritDoc
|
|
51
|
+
*/
|
|
52
|
+
getOutputToken(): BtcToken<false>;
|
|
53
|
+
/**
|
|
54
|
+
* @inheritDoc
|
|
55
|
+
*/
|
|
56
|
+
getOutput(): TokenAmount<BtcToken<false>>;
|
|
57
|
+
/**
|
|
58
|
+
* @inheritDoc
|
|
59
|
+
*/
|
|
60
|
+
getOutputAddress(): string | null;
|
|
61
|
+
/**
|
|
62
|
+
* @inheritDoc
|
|
63
|
+
*/
|
|
64
|
+
getOutputTxId(): string | null;
|
|
65
|
+
/**
|
|
66
|
+
* Returns fee rate of the output bitcoin transaction in sats/vB as reported by the intermediary (LP)
|
|
67
|
+
*/
|
|
68
|
+
getBitcoinFeeRate(): number;
|
|
69
|
+
/**
|
|
70
|
+
* @inheritDoc
|
|
71
|
+
*/
|
|
72
|
+
serialize(): any;
|
|
73
|
+
}
|
|
@@ -1,155 +1,155 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.ToBTCSwap =
|
|
4
|
-
|
|
5
|
-
const
|
|
6
|
-
const
|
|
7
|
-
const
|
|
8
|
-
const
|
|
9
|
-
const
|
|
10
|
-
const
|
|
11
|
-
const
|
|
12
|
-
const
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
typeof (obj.
|
|
17
|
-
typeof (obj.
|
|
18
|
-
|
|
19
|
-
(obj.
|
|
20
|
-
(
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
/**
|
|
24
|
-
* Escrow based (PrTLC) swap for Smart chains -> Bitcoin
|
|
25
|
-
*
|
|
26
|
-
* @category Swaps/Smart chain → Bitcoin
|
|
27
|
-
*/
|
|
28
|
-
class ToBTCSwap extends IToBTCSwap_1.IToBTCSwap {
|
|
29
|
-
constructor(wrapper, initOrObject) {
|
|
30
|
-
if (isToBTCSwapInit(initOrObject) && initOrObject.url != null)
|
|
31
|
-
initOrObject.url += "/tobtc";
|
|
32
|
-
super(wrapper, initOrObject);
|
|
33
|
-
this.TYPE = SwapType_1.SwapType.TO_BTC;
|
|
34
|
-
/**
|
|
35
|
-
* @internal
|
|
36
|
-
*/
|
|
37
|
-
this.outputToken = Token_1.BitcoinTokens.BTC;
|
|
38
|
-
if (isToBTCSwapInit(initOrObject)) {
|
|
39
|
-
this.address = initOrObject.address;
|
|
40
|
-
this.amount = initOrObject.amount;
|
|
41
|
-
this.confirmationTarget = initOrObject.confirmationTarget;
|
|
42
|
-
this.satsPerVByte = initOrObject.satsPerVByte;
|
|
43
|
-
this.requiredConfirmations = initOrObject.requiredConfirmations;
|
|
44
|
-
this.nonce = initOrObject.nonce;
|
|
45
|
-
}
|
|
46
|
-
else {
|
|
47
|
-
this.address = initOrObject.address;
|
|
48
|
-
this.amount = (0, Utils_1.toBigInt)(initOrObject.amount);
|
|
49
|
-
this.confirmationTarget = initOrObject.confirmationTarget;
|
|
50
|
-
this.satsPerVByte = initOrObject.satsPerVByte;
|
|
51
|
-
this.txId = initOrObject.txId;
|
|
52
|
-
this.requiredConfirmations = initOrObject.requiredConfirmations ?? this._data.getConfirmationsHint();
|
|
53
|
-
this.nonce = (0, Utils_1.toBigInt)(initOrObject.nonce) ?? this._data.getNonceHint();
|
|
54
|
-
}
|
|
55
|
-
this.logger = (0, Logger_1.getLogger)("ToBTC(" + this.getIdentifierHashString() + "): ");
|
|
56
|
-
this.tryRecomputeSwapPrice();
|
|
57
|
-
}
|
|
58
|
-
/**
|
|
59
|
-
* @inheritDoc
|
|
60
|
-
* @internal
|
|
61
|
-
*/
|
|
62
|
-
async _setPaymentResult(result, check = false) {
|
|
63
|
-
if (result == null)
|
|
64
|
-
return false;
|
|
65
|
-
if (result.txId == null)
|
|
66
|
-
throw new IntermediaryError_1.IntermediaryError("No btc txId returned!");
|
|
67
|
-
if (check || this.address == null || this.amount == null || this.nonce == null || this.requiredConfirmations == null) {
|
|
68
|
-
const btcTx = await this.wrapper._btcRpc.getTransaction(result.txId);
|
|
69
|
-
if (btcTx == null)
|
|
70
|
-
return false;
|
|
71
|
-
//Extract nonce from tx
|
|
72
|
-
const nonce = this.nonce ?? (BigInt(btcTx.ins[0].sequence) & 0x00ffffffn) | (BigInt(btcTx.locktime -
|
|
73
|
-
let requiredConfirmations = this.requiredConfirmations;
|
|
74
|
-
const foundVout = btcTx.outs.find(vout => {
|
|
75
|
-
if (requiredConfirmations != null) {
|
|
76
|
-
return this._data.getClaimHash() === this.wrapper._contract.getHashForOnchain(buffer_1.Buffer.from(vout.scriptPubKey.hex, "hex"), BigInt(vout.value), requiredConfirmations, nonce).toString("hex");
|
|
77
|
-
}
|
|
78
|
-
else {
|
|
79
|
-
for (let i = 1; i <= 20; i++) {
|
|
80
|
-
if (this._data.getClaimHash() === this.wrapper._contract.getHashForOnchain(buffer_1.Buffer.from(vout.scriptPubKey.hex, "hex"), BigInt(vout.value), i, nonce).toString("hex")) {
|
|
81
|
-
requiredConfirmations = i;
|
|
82
|
-
return true;
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
});
|
|
87
|
-
if (requiredConfirmations == null)
|
|
88
|
-
this.logger.warn(`_setPaymentResult(): Tried to recover data from bitcoin transaction ${result.txId} data, but wasn't able to!`);
|
|
89
|
-
if (foundVout != null) {
|
|
90
|
-
this.nonce = nonce;
|
|
91
|
-
this.address = (0, BitcoinUtils_1.fromOutputScript)(this.wrapper._options.bitcoinNetwork, foundVout.scriptPubKey.hex);
|
|
92
|
-
this.amount = BigInt(foundVout.value);
|
|
93
|
-
this.requiredConfirmations = requiredConfirmations;
|
|
94
|
-
}
|
|
95
|
-
else {
|
|
96
|
-
if (check)
|
|
97
|
-
throw new IntermediaryError_1.IntermediaryError("Invalid btc txId returned");
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
this.txId = result.txId;
|
|
101
|
-
return true;
|
|
102
|
-
}
|
|
103
|
-
//////////////////////////////
|
|
104
|
-
//// Amounts & fees
|
|
105
|
-
/**
|
|
106
|
-
* @inheritDoc
|
|
107
|
-
*/
|
|
108
|
-
getOutputToken() {
|
|
109
|
-
return Token_1.BitcoinTokens.BTC;
|
|
110
|
-
}
|
|
111
|
-
/**
|
|
112
|
-
* @inheritDoc
|
|
113
|
-
*/
|
|
114
|
-
getOutput() {
|
|
115
|
-
return (0, TokenAmount_1.toTokenAmount)(this.amount ?? null, this.outputToken, this.wrapper._prices, this.pricingInfo);
|
|
116
|
-
}
|
|
117
|
-
//////////////////////////////
|
|
118
|
-
//// Getters & utils
|
|
119
|
-
/**
|
|
120
|
-
* @inheritDoc
|
|
121
|
-
*/
|
|
122
|
-
getOutputAddress() {
|
|
123
|
-
return this.address ?? null;
|
|
124
|
-
}
|
|
125
|
-
/**
|
|
126
|
-
* @inheritDoc
|
|
127
|
-
*/
|
|
128
|
-
getOutputTxId() {
|
|
129
|
-
return this.txId ?? null;
|
|
130
|
-
}
|
|
131
|
-
/**
|
|
132
|
-
* Returns fee rate of the output bitcoin transaction in sats/vB as reported by the intermediary (LP)
|
|
133
|
-
*/
|
|
134
|
-
getBitcoinFeeRate() {
|
|
135
|
-
return this.satsPerVByte;
|
|
136
|
-
}
|
|
137
|
-
//////////////////////////////
|
|
138
|
-
//// Storage
|
|
139
|
-
/**
|
|
140
|
-
* @inheritDoc
|
|
141
|
-
*/
|
|
142
|
-
serialize() {
|
|
143
|
-
return {
|
|
144
|
-
...super.serialize(),
|
|
145
|
-
address: this.address,
|
|
146
|
-
amount: this.amount == null ? null : this.amount.toString(10),
|
|
147
|
-
confirmationTarget: this.confirmationTarget,
|
|
148
|
-
satsPerVByte: this.satsPerVByte,
|
|
149
|
-
nonce: this.nonce == null ? null : this.nonce.toString(10),
|
|
150
|
-
requiredConfirmations: this.requiredConfirmations,
|
|
151
|
-
txId: this.txId
|
|
152
|
-
};
|
|
153
|
-
}
|
|
154
|
-
}
|
|
155
|
-
exports.ToBTCSwap = ToBTCSwap;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ToBTCSwap = void 0;
|
|
4
|
+
exports.isToBTCSwapInit = isToBTCSwapInit;
|
|
5
|
+
const IToBTCSwap_1 = require("../IToBTCSwap");
|
|
6
|
+
const SwapType_1 = require("../../../../enums/SwapType");
|
|
7
|
+
const buffer_1 = require("buffer");
|
|
8
|
+
const IntermediaryError_1 = require("../../../../errors/IntermediaryError");
|
|
9
|
+
const Utils_1 = require("../../../../utils/Utils");
|
|
10
|
+
const TokenAmount_1 = require("../../../../types/TokenAmount");
|
|
11
|
+
const Token_1 = require("../../../../types/Token");
|
|
12
|
+
const Logger_1 = require("../../../../utils/Logger");
|
|
13
|
+
const BitcoinUtils_1 = require("../../../../utils/BitcoinUtils");
|
|
14
|
+
function isToBTCSwapInit(obj) {
|
|
15
|
+
return (obj.address == null || typeof (obj.address) === "string") &&
|
|
16
|
+
(obj.amount == null || typeof (obj.amount) === "bigint") &&
|
|
17
|
+
typeof (obj.confirmationTarget) === "number" &&
|
|
18
|
+
typeof (obj.satsPerVByte) === "number" &&
|
|
19
|
+
(obj.requiredConfirmations == null || typeof (obj.requiredConfirmations) === "number") &&
|
|
20
|
+
(obj.nonce == null || typeof (obj.nonce) === "bigint") &&
|
|
21
|
+
(0, IToBTCSwap_1.isIToBTCSwapInit)(obj);
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Escrow based (PrTLC) swap for Smart chains -> Bitcoin
|
|
25
|
+
*
|
|
26
|
+
* @category Swaps/Smart chain → Bitcoin
|
|
27
|
+
*/
|
|
28
|
+
class ToBTCSwap extends IToBTCSwap_1.IToBTCSwap {
|
|
29
|
+
constructor(wrapper, initOrObject) {
|
|
30
|
+
if (isToBTCSwapInit(initOrObject) && initOrObject.url != null)
|
|
31
|
+
initOrObject.url += "/tobtc";
|
|
32
|
+
super(wrapper, initOrObject);
|
|
33
|
+
this.TYPE = SwapType_1.SwapType.TO_BTC;
|
|
34
|
+
/**
|
|
35
|
+
* @internal
|
|
36
|
+
*/
|
|
37
|
+
this.outputToken = Token_1.BitcoinTokens.BTC;
|
|
38
|
+
if (isToBTCSwapInit(initOrObject)) {
|
|
39
|
+
this.address = initOrObject.address;
|
|
40
|
+
this.amount = initOrObject.amount;
|
|
41
|
+
this.confirmationTarget = initOrObject.confirmationTarget;
|
|
42
|
+
this.satsPerVByte = initOrObject.satsPerVByte;
|
|
43
|
+
this.requiredConfirmations = initOrObject.requiredConfirmations;
|
|
44
|
+
this.nonce = initOrObject.nonce;
|
|
45
|
+
}
|
|
46
|
+
else {
|
|
47
|
+
this.address = initOrObject.address;
|
|
48
|
+
this.amount = (0, Utils_1.toBigInt)(initOrObject.amount);
|
|
49
|
+
this.confirmationTarget = initOrObject.confirmationTarget;
|
|
50
|
+
this.satsPerVByte = initOrObject.satsPerVByte;
|
|
51
|
+
this.txId = initOrObject.txId;
|
|
52
|
+
this.requiredConfirmations = initOrObject.requiredConfirmations ?? this._data.getConfirmationsHint();
|
|
53
|
+
this.nonce = (0, Utils_1.toBigInt)(initOrObject.nonce) ?? this._data.getNonceHint();
|
|
54
|
+
}
|
|
55
|
+
this.logger = (0, Logger_1.getLogger)("ToBTC(" + this.getIdentifierHashString() + "): ");
|
|
56
|
+
this.tryRecomputeSwapPrice();
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* @inheritDoc
|
|
60
|
+
* @internal
|
|
61
|
+
*/
|
|
62
|
+
async _setPaymentResult(result, check = false) {
|
|
63
|
+
if (result == null)
|
|
64
|
+
return false;
|
|
65
|
+
if (result.txId == null)
|
|
66
|
+
throw new IntermediaryError_1.IntermediaryError("No btc txId returned!");
|
|
67
|
+
if (check || this.address == null || this.amount == null || this.nonce == null || this.requiredConfirmations == null) {
|
|
68
|
+
const btcTx = await this.wrapper._btcRpc.getTransaction(result.txId);
|
|
69
|
+
if (btcTx == null)
|
|
70
|
+
return false;
|
|
71
|
+
//Extract nonce from tx
|
|
72
|
+
const nonce = this.nonce ?? (BigInt(btcTx.ins[0].sequence) & 0x00ffffffn) | (BigInt(btcTx.locktime - 500_000_000) << 24n);
|
|
73
|
+
let requiredConfirmations = this.requiredConfirmations;
|
|
74
|
+
const foundVout = btcTx.outs.find(vout => {
|
|
75
|
+
if (requiredConfirmations != null) {
|
|
76
|
+
return this._data.getClaimHash() === this.wrapper._contract.getHashForOnchain(buffer_1.Buffer.from(vout.scriptPubKey.hex, "hex"), BigInt(vout.value), requiredConfirmations, nonce).toString("hex");
|
|
77
|
+
}
|
|
78
|
+
else {
|
|
79
|
+
for (let i = 1; i <= 20; i++) {
|
|
80
|
+
if (this._data.getClaimHash() === this.wrapper._contract.getHashForOnchain(buffer_1.Buffer.from(vout.scriptPubKey.hex, "hex"), BigInt(vout.value), i, nonce).toString("hex")) {
|
|
81
|
+
requiredConfirmations = i;
|
|
82
|
+
return true;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
});
|
|
87
|
+
if (requiredConfirmations == null)
|
|
88
|
+
this.logger.warn(`_setPaymentResult(): Tried to recover data from bitcoin transaction ${result.txId} data, but wasn't able to!`);
|
|
89
|
+
if (foundVout != null) {
|
|
90
|
+
this.nonce = nonce;
|
|
91
|
+
this.address = (0, BitcoinUtils_1.fromOutputScript)(this.wrapper._options.bitcoinNetwork, foundVout.scriptPubKey.hex);
|
|
92
|
+
this.amount = BigInt(foundVout.value);
|
|
93
|
+
this.requiredConfirmations = requiredConfirmations;
|
|
94
|
+
}
|
|
95
|
+
else {
|
|
96
|
+
if (check)
|
|
97
|
+
throw new IntermediaryError_1.IntermediaryError("Invalid btc txId returned");
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
this.txId = result.txId;
|
|
101
|
+
return true;
|
|
102
|
+
}
|
|
103
|
+
//////////////////////////////
|
|
104
|
+
//// Amounts & fees
|
|
105
|
+
/**
|
|
106
|
+
* @inheritDoc
|
|
107
|
+
*/
|
|
108
|
+
getOutputToken() {
|
|
109
|
+
return Token_1.BitcoinTokens.BTC;
|
|
110
|
+
}
|
|
111
|
+
/**
|
|
112
|
+
* @inheritDoc
|
|
113
|
+
*/
|
|
114
|
+
getOutput() {
|
|
115
|
+
return (0, TokenAmount_1.toTokenAmount)(this.amount ?? null, this.outputToken, this.wrapper._prices, this.pricingInfo);
|
|
116
|
+
}
|
|
117
|
+
//////////////////////////////
|
|
118
|
+
//// Getters & utils
|
|
119
|
+
/**
|
|
120
|
+
* @inheritDoc
|
|
121
|
+
*/
|
|
122
|
+
getOutputAddress() {
|
|
123
|
+
return this.address ?? null;
|
|
124
|
+
}
|
|
125
|
+
/**
|
|
126
|
+
* @inheritDoc
|
|
127
|
+
*/
|
|
128
|
+
getOutputTxId() {
|
|
129
|
+
return this.txId ?? null;
|
|
130
|
+
}
|
|
131
|
+
/**
|
|
132
|
+
* Returns fee rate of the output bitcoin transaction in sats/vB as reported by the intermediary (LP)
|
|
133
|
+
*/
|
|
134
|
+
getBitcoinFeeRate() {
|
|
135
|
+
return this.satsPerVByte;
|
|
136
|
+
}
|
|
137
|
+
//////////////////////////////
|
|
138
|
+
//// Storage
|
|
139
|
+
/**
|
|
140
|
+
* @inheritDoc
|
|
141
|
+
*/
|
|
142
|
+
serialize() {
|
|
143
|
+
return {
|
|
144
|
+
...super.serialize(),
|
|
145
|
+
address: this.address,
|
|
146
|
+
amount: this.amount == null ? null : this.amount.toString(10),
|
|
147
|
+
confirmationTarget: this.confirmationTarget,
|
|
148
|
+
satsPerVByte: this.satsPerVByte,
|
|
149
|
+
nonce: this.nonce == null ? null : this.nonce.toString(10),
|
|
150
|
+
requiredConfirmations: this.requiredConfirmations,
|
|
151
|
+
txId: this.txId
|
|
152
|
+
};
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
exports.ToBTCSwap = ToBTCSwap;
|