@atomiqlabs/sdk 8.8.3 → 8.8.4
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/README.md +1760 -1760
- package/dist/SmartChainAssets.d.ts +181 -181
- package/dist/SmartChainAssets.js +181 -181
- package/dist/bitcoin/coinselect2/accumulative.d.ts +7 -7
- package/dist/bitcoin/coinselect2/accumulative.js +52 -52
- package/dist/bitcoin/coinselect2/blackjack.d.ts +7 -7
- package/dist/bitcoin/coinselect2/blackjack.js +38 -38
- package/dist/bitcoin/coinselect2/index.d.ts +20 -20
- package/dist/bitcoin/coinselect2/index.js +69 -69
- package/dist/bitcoin/coinselect2/utils.d.ts +82 -82
- package/dist/bitcoin/coinselect2/utils.js +158 -158
- package/dist/bitcoin/wallet/BitcoinWallet.d.ts +113 -113
- package/dist/bitcoin/wallet/BitcoinWallet.js +335 -335
- package/dist/bitcoin/wallet/IBitcoinWallet.d.ts +116 -116
- package/dist/bitcoin/wallet/IBitcoinWallet.js +21 -21
- package/dist/bitcoin/wallet/SingleAddressBitcoinWallet.d.ts +106 -106
- package/dist/bitcoin/wallet/SingleAddressBitcoinWallet.js +196 -196
- 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 +132 -132
- package/dist/http/HttpUtils.d.ts +27 -27
- package/dist/http/HttpUtils.js +91 -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 +44 -44
- package/dist/http/paramcoders/ParamDecoder.js +137 -137
- package/dist/http/paramcoders/ParamEncoder.d.ts +20 -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 +13 -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 +174 -174
- package/dist/index.d.ts +85 -85
- package/dist/index.js +158 -158
- package/dist/intermediaries/Intermediary.d.ts +178 -178
- package/dist/intermediaries/Intermediary.js +166 -166
- package/dist/intermediaries/IntermediaryDiscovery.d.ts +211 -211
- package/dist/intermediaries/IntermediaryDiscovery.js +424 -424
- package/dist/intermediaries/apis/IntermediaryAPI.d.ts +450 -450
- package/dist/intermediaries/apis/IntermediaryAPI.js +618 -618
- 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 -168
- package/dist/prices/abstract/ISwapPrice.js +279 -279
- 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 +732 -732
- package/dist/swapper/Swapper.js +1713 -1713
- package/dist/swapper/SwapperFactory.d.ts +135 -135
- package/dist/swapper/SwapperFactory.js +162 -162
- package/dist/swapper/SwapperUtils.d.ts +206 -206
- package/dist/swapper/SwapperUtils.js +481 -481
- 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 +14 -14
- package/dist/swaps/IBTCWalletSwap.d.ts +73 -73
- package/dist/swaps/IBTCWalletSwap.js +18 -18
- package/dist/swaps/IClaimableSwap.d.ts +49 -49
- package/dist/swaps/IClaimableSwap.js +15 -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 +14 -14
- package/dist/swaps/ISwap.d.ts +392 -392
- package/dist/swaps/ISwap.js +349 -349
- package/dist/swaps/ISwapWithGasDrop.d.ts +21 -21
- package/dist/swaps/ISwapWithGasDrop.js +12 -12
- package/dist/swaps/ISwapWrapper.d.ts +285 -285
- 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 +139 -139
- package/dist/swaps/escrow_swaps/IEscrowSwap.js +170 -170
- package/dist/swaps/escrow_swaps/IEscrowSwapWrapper.d.ts +128 -128
- package/dist/swaps/escrow_swaps/IEscrowSwapWrapper.js +167 -167
- package/dist/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.d.ts +105 -105
- package/dist/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.js +129 -129
- 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 +64 -64
- package/dist/swaps/escrow_swaps/frombtc/IFromBTCWrapper.js +82 -82
- package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.d.ts +531 -531
- package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.js +1285 -1285
- package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.d.ts +190 -190
- package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.js +432 -432
- package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.d.ts +583 -583
- package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.js +1371 -1371
- package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.d.ts +235 -235
- package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.js +525 -525
- 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 +202 -202
- package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.js +406 -406
- 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 +68 -68
- package/dist/swaps/escrow_swaps/tobtc/IToBTCWrapper.js +117 -117
- package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.d.ts +127 -127
- package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.js +256 -256
- package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.d.ts +251 -251
- package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.js +536 -536
- 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 +132 -132
- package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.js +286 -286
- package/dist/swaps/spv_swaps/SpvFromBTCSwap.d.ts +637 -637
- package/dist/swaps/spv_swaps/SpvFromBTCSwap.js +1448 -1448
- package/dist/swaps/spv_swaps/SpvFromBTCWrapper.d.ts +257 -257
- package/dist/swaps/spv_swaps/SpvFromBTCWrapper.js +947 -947
- 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 +83 -83
- 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 +69 -69
- package/dist/swaps/trusted/onchain/OnchainForGasWrapper.js +93 -93
- 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 +57 -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 +43 -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 +60 -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 +18 -18
- package/dist/types/lnurl/LNURLPay.d.ts +61 -61
- package/dist/types/lnurl/LNURLPay.js +31 -31
- package/dist/types/lnurl/LNURLWithdraw.d.ts +48 -48
- package/dist/types/lnurl/LNURLWithdraw.js +27 -27
- package/dist/types/wallets/LightningInvoiceCreateService.d.ts +24 -24
- package/dist/types/wallets/LightningInvoiceCreateService.js +15 -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 +70 -70
- package/dist/utils/BitcoinUtils.d.ts +16 -16
- package/dist/utils/BitcoinUtils.js +141 -141
- package/dist/utils/BitcoinWalletUtils.d.ts +7 -7
- package/dist/utils/BitcoinWalletUtils.js +14 -14
- package/dist/utils/Logger.d.ts +7 -7
- package/dist/utils/Logger.js +12 -12
- package/dist/utils/RetryUtils.d.ts +22 -22
- package/dist/utils/RetryUtils.js +67 -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 +55 -55
- package/dist/utils/TokenUtils.d.ts +19 -19
- package/dist/utils/TokenUtils.js +37 -37
- package/dist/utils/TypeUtils.d.ts +7 -7
- package/dist/utils/TypeUtils.js +2 -2
- package/dist/utils/Utils.d.ts +67 -67
- package/dist/utils/Utils.js +208 -208
- package/package.json +43 -43
- package/src/SmartChainAssets.ts +186 -186
- package/src/bitcoin/coinselect2/accumulative.ts +69 -69
- package/src/bitcoin/coinselect2/blackjack.ts +50 -50
- package/src/bitcoin/coinselect2/index.ts +93 -93
- package/src/bitcoin/coinselect2/utils.ts +236 -236
- package/src/bitcoin/wallet/BitcoinWallet.ts +439 -439
- package/src/bitcoin/wallet/IBitcoinWallet.ts +140 -140
- package/src/bitcoin/wallet/SingleAddressBitcoinWallet.ts +225 -225
- package/src/enums/FeeType.ts +15 -15
- package/src/enums/SwapAmountType.ts +16 -16
- package/src/enums/SwapDirection.ts +15 -15
- package/src/enums/SwapSide.ts +16 -16
- package/src/enums/SwapType.ts +75 -75
- package/src/errors/IntermediaryError.ts +28 -28
- package/src/errors/RequestError.ts +64 -64
- package/src/errors/UserError.ts +15 -15
- package/src/events/UnifiedSwapEventListener.ts +173 -173
- package/src/http/HttpUtils.ts +91 -91
- package/src/http/paramcoders/IParamReader.ts +9 -9
- package/src/http/paramcoders/ParamDecoder.ts +145 -145
- package/src/http/paramcoders/ParamEncoder.ts +40 -40
- package/src/http/paramcoders/SchemaVerifier.ts +153 -153
- package/src/http/paramcoders/client/ResponseParamDecoder.ts +57 -57
- package/src/http/paramcoders/client/StreamParamEncoder.ts +28 -28
- package/src/http/paramcoders/client/StreamingFetchPromise.ts +192 -192
- package/src/index.ts +140 -140
- package/src/intermediaries/Intermediary.ts +280 -280
- package/src/intermediaries/IntermediaryDiscovery.ts +541 -541
- package/src/intermediaries/apis/IntermediaryAPI.ts +963 -963
- package/src/intermediaries/apis/TrustedIntermediaryAPI.ts +257 -257
- package/src/lnurl/LNURL.ts +402 -402
- package/src/prices/RedundantSwapPrice.ts +264 -264
- package/src/prices/SingleSwapPrice.ts +50 -50
- package/src/prices/SwapPriceWithChain.ts +194 -194
- package/src/prices/abstract/ICachedSwapPrice.ts +85 -85
- package/src/prices/abstract/IPriceProvider.ts +127 -127
- package/src/prices/abstract/ISwapPrice.ts +390 -390
- package/src/prices/providers/BinancePriceProvider.ts +48 -48
- package/src/prices/providers/CoinGeckoPriceProvider.ts +46 -46
- package/src/prices/providers/CoinPaprikaPriceProvider.ts +49 -49
- package/src/prices/providers/CustomPriceProvider.ts +40 -40
- package/src/prices/providers/KrakenPriceProvider.ts +83 -83
- package/src/prices/providers/OKXPriceProvider.ts +59 -59
- package/src/prices/providers/abstract/ExchangePriceProvider.ts +31 -31
- package/src/prices/providers/abstract/HttpPriceProvider.ts +14 -14
- package/src/storage/IUnifiedStorage.ts +95 -95
- package/src/storage/UnifiedSwapStorage.ts +141 -141
- package/src/storage-browser/IndexedDBUnifiedStorage.ts +350 -350
- package/src/storage-browser/LocalStorageManager.ts +106 -106
- package/src/swapper/Swapper.ts +2488 -2488
- package/src/swapper/SwapperFactory.ts +307 -307
- package/src/swapper/SwapperUtils.ts +570 -570
- package/src/swapper/SwapperWithChain.ts +707 -707
- package/src/swapper/SwapperWithSigner.ts +511 -511
- package/src/swaps/IAddressSwap.ts +30 -30
- package/src/swaps/IBTCWalletSwap.ts +92 -92
- package/src/swaps/IClaimableSwap.ts +65 -65
- package/src/swaps/IClaimableSwapWrapper.ts +17 -17
- package/src/swaps/IRefundableSwap.ts +58 -58
- package/src/swaps/ISwap.ts +703 -703
- package/src/swaps/ISwapWithGasDrop.ts +25 -25
- package/src/swaps/ISwapWrapper.ts +539 -539
- package/src/swaps/escrow_swaps/IEscrowSelfInitSwap.ts +217 -217
- package/src/swaps/escrow_swaps/IEscrowSwap.ts +269 -269
- package/src/swaps/escrow_swaps/IEscrowSwapWrapper.ts +282 -282
- package/src/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.ts +169 -169
- package/src/swaps/escrow_swaps/frombtc/IFromBTCSelfInitSwap.ts +300 -300
- package/src/swaps/escrow_swaps/frombtc/IFromBTCWrapper.ts +107 -107
- package/src/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.ts +1473 -1474
- package/src/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.ts +601 -601
- package/src/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.ts +1582 -1582
- package/src/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.ts +750 -750
- package/src/swaps/escrow_swaps/frombtc/onchain/FromBTCSwap.ts +1299 -1299
- package/src/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.ts +610 -610
- package/src/swaps/escrow_swaps/tobtc/IToBTCSwap.ts +1096 -1096
- package/src/swaps/escrow_swaps/tobtc/IToBTCWrapper.ts +138 -138
- package/src/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.ts +304 -304
- package/src/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.ts +786 -786
- package/src/swaps/escrow_swaps/tobtc/onchain/ToBTCSwap.ts +206 -206
- package/src/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.ts +401 -401
- package/src/swaps/spv_swaps/SpvFromBTCSwap.ts +1812 -1812
- package/src/swaps/spv_swaps/SpvFromBTCWrapper.ts +1236 -1236
- package/src/swaps/trusted/ln/LnForGasSwap.ts +589 -589
- package/src/swaps/trusted/ln/LnForGasWrapper.ts +91 -91
- package/src/swaps/trusted/onchain/OnchainForGasSwap.ts +862 -862
- package/src/swaps/trusted/onchain/OnchainForGasWrapper.ts +131 -131
- package/src/types/AmountData.ts +9 -9
- package/src/types/CustomPriceFunction.ts +11 -11
- package/src/types/PriceInfoType.ts +66 -66
- package/src/types/SwapExecutionAction.ts +99 -99
- package/src/types/SwapStateInfo.ts +6 -6
- package/src/types/SwapWithSigner.ts +61 -61
- package/src/types/Token.ts +163 -163
- package/src/types/TokenAmount.ts +132 -132
- package/src/types/fees/Fee.ts +56 -56
- package/src/types/fees/FeeBreakdown.ts +11 -11
- package/src/types/fees/PercentagePPM.ts +26 -26
- package/src/types/lnurl/LNURLPay.ts +79 -79
- package/src/types/lnurl/LNURLWithdraw.ts +61 -61
- package/src/types/wallets/LightningInvoiceCreateService.ts +30 -30
- package/src/types/wallets/MinimalBitcoinWalletInterface.ts +21 -21
- package/src/types/wallets/MinimalLightningNetworkWalletInterface.ts +9 -9
- package/src/utils/AutomaticClockDriftCorrection.ts +71 -71
- package/src/utils/BitcoinUtils.ts +132 -132
- package/src/utils/BitcoinWalletUtils.ts +15 -15
- package/src/utils/Logger.ts +14 -14
- package/src/utils/RetryUtils.ts +78 -78
- package/src/utils/SwapUtils.ts +99 -99
- package/src/utils/TimeoutUtils.ts +49 -49
- package/src/utils/TokenUtils.ts +33 -33
- package/src/utils/TypeUtils.ts +8 -8
- package/src/utils/Utils.ts +212 -212
package/src/types/TokenAmount.ts
CHANGED
|
@@ -1,133 +1,133 @@
|
|
|
1
|
-
import {ISwapPrice} from "../prices/abstract/ISwapPrice";
|
|
2
|
-
import {Token} from "./Token";
|
|
3
|
-
import {PriceInfoType} from "./PriceInfoType";
|
|
4
|
-
import {toDecimal} from "../utils/Utils";
|
|
5
|
-
|
|
6
|
-
/**
|
|
7
|
-
* Represents a token amount along with its formatted values and USD valuation helpers
|
|
8
|
-
*
|
|
9
|
-
* @category Tokens
|
|
10
|
-
*/
|
|
11
|
-
export type TokenAmount<
|
|
12
|
-
T extends Token = Token,
|
|
13
|
-
Known extends boolean = boolean
|
|
14
|
-
> = {
|
|
15
|
-
/**
|
|
16
|
-
* Raw amount in base units represented as bigint, might be `undefined` when the amount is unknown
|
|
17
|
-
*/
|
|
18
|
-
rawAmount: Known extends true ? bigint : undefined,
|
|
19
|
-
/**
|
|
20
|
-
* Human readable amount with decimal places, might be empty string `""` when the amount is unknown
|
|
21
|
-
*/
|
|
22
|
-
amount: string,
|
|
23
|
-
/**
|
|
24
|
-
* Number representation of the decimal token amount (can lose precision!), might be `NaN` when
|
|
25
|
-
* the amount is unknown
|
|
26
|
-
*/
|
|
27
|
-
_amount: number,
|
|
28
|
-
/**
|
|
29
|
-
* Token associated with this amount
|
|
30
|
-
*/
|
|
31
|
-
token: T,
|
|
32
|
-
/**
|
|
33
|
-
* Fetches the current USD value of the amount, might return `NaN` when the amount is unknown
|
|
34
|
-
*
|
|
35
|
-
* @param abortSignal
|
|
36
|
-
* @param preFetchedUsdPrice You can supply a pre-fetched usd price to the pricing function
|
|
37
|
-
* @returns A promise resolving to the current USD value of the token amount
|
|
38
|
-
*/
|
|
39
|
-
currentUsdValue: (abortSignal?: AbortSignal, preFetchedUsdPrice?: number) => Promise<number>,
|
|
40
|
-
/**
|
|
41
|
-
* Gets USD value of the amount, if this amount was returned from a swap it uses the USD value
|
|
42
|
-
* when the swap was created, otherwise fetches the usd value on-demand, might return `NaN`
|
|
43
|
-
* when the amount is unknown
|
|
44
|
-
*
|
|
45
|
-
* @param abortSignal
|
|
46
|
-
* @param preFetchedUsdPrice You can supply a pre-fetched usd price to the pricing function
|
|
47
|
-
* @returns A promise resolving to the current USD value of the token amount
|
|
48
|
-
*/
|
|
49
|
-
usdValue: (abortSignal?: AbortSignal, preFetchedUsdPrice?: number) => Promise<number>,
|
|
50
|
-
/**
|
|
51
|
-
* USD value of the amount when swap was created - only present for token amounts obtained
|
|
52
|
-
* from swaps, left for convenience only, use usdValue() instead, which automatically
|
|
53
|
-
* recognizes which pricing to use (either past value if available or fetches it on-demand),
|
|
54
|
-
* might be `NaN` when the amount is unknown
|
|
55
|
-
*/
|
|
56
|
-
pastUsdValue?: number,
|
|
57
|
-
/**
|
|
58
|
-
* Returns the string representation of the amount along with the token ticker in format: `"{amount} {ticker}"`,
|
|
59
|
-
* in case the anmount is unknown returns `"??? {ticker}"`
|
|
60
|
-
*/
|
|
61
|
-
toString: () => string,
|
|
62
|
-
/**
|
|
63
|
-
* Whether the token amount contains an unknown or undefined amount, in this case numeric values are `NaN`,
|
|
64
|
-
* raw amount is `undefined`, string representation is `""` and `toString()` returns `"??? {ticker}"`
|
|
65
|
-
*/
|
|
66
|
-
isUnknown: Known extends true ? false : true
|
|
67
|
-
};
|
|
68
|
-
|
|
69
|
-
/**
|
|
70
|
-
* Factory function to create a TokenAmount
|
|
71
|
-
*
|
|
72
|
-
* @category Tokens
|
|
73
|
-
* @internal
|
|
74
|
-
*/
|
|
75
|
-
export function toTokenAmount<
|
|
76
|
-
T extends Token = Token,
|
|
77
|
-
Known extends boolean = boolean
|
|
78
|
-
>(
|
|
79
|
-
amount: Known extends true ? bigint : null,
|
|
80
|
-
token: T,
|
|
81
|
-
prices: ISwapPrice,
|
|
82
|
-
pricingInfo?: PriceInfoType
|
|
83
|
-
): TokenAmount<T, Known> {
|
|
84
|
-
if (amount == null) return {
|
|
85
|
-
rawAmount: undefined,
|
|
86
|
-
amount: "",
|
|
87
|
-
_amount: NaN,
|
|
88
|
-
token,
|
|
89
|
-
currentUsdValue: () => Promise.resolve(NaN),
|
|
90
|
-
pastUsdValue: NaN,
|
|
91
|
-
usdValue: () => Promise.resolve(NaN),
|
|
92
|
-
toString: () => "??? " + token.ticker,
|
|
93
|
-
isUnknown: true
|
|
94
|
-
} as TokenAmount<T>;
|
|
95
|
-
const amountStr = toDecimal(amount, token.decimals, undefined, token.displayDecimals);
|
|
96
|
-
const _amount = parseFloat(amountStr);
|
|
97
|
-
|
|
98
|
-
let usdValue: number | undefined = undefined;
|
|
99
|
-
if (pricingInfo != null) {
|
|
100
|
-
if (token.chain === "BTC" && token.ticker === "BTC") {
|
|
101
|
-
if (pricingInfo.realPriceUsdPerBitcoin != null) {
|
|
102
|
-
usdValue = Number(amount) * pricingInfo.realPriceUsdPerBitcoin;
|
|
103
|
-
}
|
|
104
|
-
} else {
|
|
105
|
-
if (pricingInfo.realPriceUsdPerBitcoin != null && pricingInfo.realPriceUSatPerToken != null) {
|
|
106
|
-
usdValue = _amount
|
|
107
|
-
* pricingInfo.realPriceUsdPerBitcoin
|
|
108
|
-
* Number(pricingInfo.realPriceUSatPerToken)
|
|
109
|
-
/ 1_000_000;
|
|
110
|
-
}
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
const currentUsdValue = (abortSignal?: AbortSignal, preFetchedUsdPrice?: number) =>
|
|
115
|
-
prices.getUsdValue(amount, token, abortSignal, preFetchedUsdPrice);
|
|
116
|
-
|
|
117
|
-
return {
|
|
118
|
-
rawAmount: amount,
|
|
119
|
-
amount: amountStr,
|
|
120
|
-
_amount,
|
|
121
|
-
token,
|
|
122
|
-
currentUsdValue,
|
|
123
|
-
pastUsdValue: usdValue,
|
|
124
|
-
usdValue: async (abortSignal?: AbortSignal, preFetchedUsdPrice?: number) => {
|
|
125
|
-
if (usdValue == null) {
|
|
126
|
-
usdValue = await currentUsdValue(abortSignal, preFetchedUsdPrice);
|
|
127
|
-
}
|
|
128
|
-
return usdValue;
|
|
129
|
-
},
|
|
130
|
-
toString: () => amountStr + " " + token.ticker,
|
|
131
|
-
isUnknown: false
|
|
132
|
-
} as TokenAmount<T>;
|
|
1
|
+
import {ISwapPrice} from "../prices/abstract/ISwapPrice";
|
|
2
|
+
import {Token} from "./Token";
|
|
3
|
+
import {PriceInfoType} from "./PriceInfoType";
|
|
4
|
+
import {toDecimal} from "../utils/Utils";
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* Represents a token amount along with its formatted values and USD valuation helpers
|
|
8
|
+
*
|
|
9
|
+
* @category Tokens
|
|
10
|
+
*/
|
|
11
|
+
export type TokenAmount<
|
|
12
|
+
T extends Token = Token,
|
|
13
|
+
Known extends boolean = boolean
|
|
14
|
+
> = {
|
|
15
|
+
/**
|
|
16
|
+
* Raw amount in base units represented as bigint, might be `undefined` when the amount is unknown
|
|
17
|
+
*/
|
|
18
|
+
rawAmount: Known extends true ? bigint : undefined,
|
|
19
|
+
/**
|
|
20
|
+
* Human readable amount with decimal places, might be empty string `""` when the amount is unknown
|
|
21
|
+
*/
|
|
22
|
+
amount: string,
|
|
23
|
+
/**
|
|
24
|
+
* Number representation of the decimal token amount (can lose precision!), might be `NaN` when
|
|
25
|
+
* the amount is unknown
|
|
26
|
+
*/
|
|
27
|
+
_amount: number,
|
|
28
|
+
/**
|
|
29
|
+
* Token associated with this amount
|
|
30
|
+
*/
|
|
31
|
+
token: T,
|
|
32
|
+
/**
|
|
33
|
+
* Fetches the current USD value of the amount, might return `NaN` when the amount is unknown
|
|
34
|
+
*
|
|
35
|
+
* @param abortSignal
|
|
36
|
+
* @param preFetchedUsdPrice You can supply a pre-fetched usd price to the pricing function
|
|
37
|
+
* @returns A promise resolving to the current USD value of the token amount
|
|
38
|
+
*/
|
|
39
|
+
currentUsdValue: (abortSignal?: AbortSignal, preFetchedUsdPrice?: number) => Promise<number>,
|
|
40
|
+
/**
|
|
41
|
+
* Gets USD value of the amount, if this amount was returned from a swap it uses the USD value
|
|
42
|
+
* when the swap was created, otherwise fetches the usd value on-demand, might return `NaN`
|
|
43
|
+
* when the amount is unknown
|
|
44
|
+
*
|
|
45
|
+
* @param abortSignal
|
|
46
|
+
* @param preFetchedUsdPrice You can supply a pre-fetched usd price to the pricing function
|
|
47
|
+
* @returns A promise resolving to the current USD value of the token amount
|
|
48
|
+
*/
|
|
49
|
+
usdValue: (abortSignal?: AbortSignal, preFetchedUsdPrice?: number) => Promise<number>,
|
|
50
|
+
/**
|
|
51
|
+
* USD value of the amount when swap was created - only present for token amounts obtained
|
|
52
|
+
* from swaps, left for convenience only, use usdValue() instead, which automatically
|
|
53
|
+
* recognizes which pricing to use (either past value if available or fetches it on-demand),
|
|
54
|
+
* might be `NaN` when the amount is unknown
|
|
55
|
+
*/
|
|
56
|
+
pastUsdValue?: number,
|
|
57
|
+
/**
|
|
58
|
+
* Returns the string representation of the amount along with the token ticker in format: `"{amount} {ticker}"`,
|
|
59
|
+
* in case the anmount is unknown returns `"??? {ticker}"`
|
|
60
|
+
*/
|
|
61
|
+
toString: () => string,
|
|
62
|
+
/**
|
|
63
|
+
* Whether the token amount contains an unknown or undefined amount, in this case numeric values are `NaN`,
|
|
64
|
+
* raw amount is `undefined`, string representation is `""` and `toString()` returns `"??? {ticker}"`
|
|
65
|
+
*/
|
|
66
|
+
isUnknown: Known extends true ? false : true
|
|
67
|
+
};
|
|
68
|
+
|
|
69
|
+
/**
|
|
70
|
+
* Factory function to create a TokenAmount
|
|
71
|
+
*
|
|
72
|
+
* @category Tokens
|
|
73
|
+
* @internal
|
|
74
|
+
*/
|
|
75
|
+
export function toTokenAmount<
|
|
76
|
+
T extends Token = Token,
|
|
77
|
+
Known extends boolean = boolean
|
|
78
|
+
>(
|
|
79
|
+
amount: Known extends true ? bigint : null,
|
|
80
|
+
token: T,
|
|
81
|
+
prices: ISwapPrice,
|
|
82
|
+
pricingInfo?: PriceInfoType
|
|
83
|
+
): TokenAmount<T, Known> {
|
|
84
|
+
if (amount == null) return {
|
|
85
|
+
rawAmount: undefined,
|
|
86
|
+
amount: "",
|
|
87
|
+
_amount: NaN,
|
|
88
|
+
token,
|
|
89
|
+
currentUsdValue: () => Promise.resolve(NaN),
|
|
90
|
+
pastUsdValue: NaN,
|
|
91
|
+
usdValue: () => Promise.resolve(NaN),
|
|
92
|
+
toString: () => "??? " + token.ticker,
|
|
93
|
+
isUnknown: true
|
|
94
|
+
} as TokenAmount<T>;
|
|
95
|
+
const amountStr = toDecimal(amount, token.decimals, undefined, token.displayDecimals);
|
|
96
|
+
const _amount = parseFloat(amountStr);
|
|
97
|
+
|
|
98
|
+
let usdValue: number | undefined = undefined;
|
|
99
|
+
if (pricingInfo != null) {
|
|
100
|
+
if (token.chain === "BTC" && token.ticker === "BTC") {
|
|
101
|
+
if (pricingInfo.realPriceUsdPerBitcoin != null) {
|
|
102
|
+
usdValue = Number(amount) * pricingInfo.realPriceUsdPerBitcoin;
|
|
103
|
+
}
|
|
104
|
+
} else {
|
|
105
|
+
if (pricingInfo.realPriceUsdPerBitcoin != null && pricingInfo.realPriceUSatPerToken != null) {
|
|
106
|
+
usdValue = _amount
|
|
107
|
+
* pricingInfo.realPriceUsdPerBitcoin
|
|
108
|
+
* Number(pricingInfo.realPriceUSatPerToken)
|
|
109
|
+
/ 1_000_000;
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
const currentUsdValue = (abortSignal?: AbortSignal, preFetchedUsdPrice?: number) =>
|
|
115
|
+
prices.getUsdValue(amount, token, abortSignal, preFetchedUsdPrice);
|
|
116
|
+
|
|
117
|
+
return {
|
|
118
|
+
rawAmount: amount,
|
|
119
|
+
amount: amountStr,
|
|
120
|
+
_amount,
|
|
121
|
+
token,
|
|
122
|
+
currentUsdValue,
|
|
123
|
+
pastUsdValue: usdValue,
|
|
124
|
+
usdValue: async (abortSignal?: AbortSignal, preFetchedUsdPrice?: number) => {
|
|
125
|
+
if (usdValue == null) {
|
|
126
|
+
usdValue = await currentUsdValue(abortSignal, preFetchedUsdPrice);
|
|
127
|
+
}
|
|
128
|
+
return usdValue;
|
|
129
|
+
},
|
|
130
|
+
toString: () => amountStr + " " + token.ticker,
|
|
131
|
+
isUnknown: false
|
|
132
|
+
} as TokenAmount<T>;
|
|
133
133
|
}
|
package/src/types/fees/Fee.ts
CHANGED
|
@@ -1,56 +1,56 @@
|
|
|
1
|
-
import {PercentagePPM} from "./PercentagePPM";
|
|
2
|
-
import {TokenAmount} from "../TokenAmount";
|
|
3
|
-
import {Token} from "../Token";
|
|
4
|
-
|
|
5
|
-
/**
|
|
6
|
-
* Fee represented in both, source and destination tokens, as well as providing USD valuation helpers and
|
|
7
|
-
* fee composition
|
|
8
|
-
*
|
|
9
|
-
* @category Pricing
|
|
10
|
-
*/
|
|
11
|
-
export type Fee<
|
|
12
|
-
ChainIdentifier extends string = string,
|
|
13
|
-
TSrc extends Token<ChainIdentifier> = Token<ChainIdentifier>,
|
|
14
|
-
TDst extends Token<ChainIdentifier> = Token<ChainIdentifier>
|
|
15
|
-
> = {
|
|
16
|
-
/**
|
|
17
|
-
* Fee value equivalent in source token
|
|
18
|
-
*/
|
|
19
|
-
amountInSrcToken: TokenAmount<TSrc, true>,
|
|
20
|
-
/**
|
|
21
|
-
* Fee value equivalent in destination token
|
|
22
|
-
*/
|
|
23
|
-
amountInDstToken: TokenAmount<TDst, true>,
|
|
24
|
-
/**
|
|
25
|
-
* Fetches the current USD value of the fee
|
|
26
|
-
*
|
|
27
|
-
* @param abortSignal
|
|
28
|
-
* @param preFetchedUsdPrice You can supply a pre-fetched usd price to the pricing function
|
|
29
|
-
* @returns A promise resolving to the current USD value of the token amount
|
|
30
|
-
*/
|
|
31
|
-
currentUsdValue: (abortSignal?: AbortSignal, preFetchedUsdPrice?: number) => Promise<number>,
|
|
32
|
-
/**
|
|
33
|
-
* Gets USD value of the fee, if the USD value when the swap was created is known (newer swaps) it returns this value,
|
|
34
|
-
* otherwise fetches the usd value on-demand
|
|
35
|
-
*
|
|
36
|
-
* @param abortSignal
|
|
37
|
-
* @param preFetchedUsdPrice You can supply a pre-fetched usd price to the pricing function
|
|
38
|
-
* @returns A promise resolving to the current USD value of the fee
|
|
39
|
-
*/
|
|
40
|
-
usdValue: (abortSignal?: AbortSignal, preFetchedUsdPrice?: number) => Promise<number>,
|
|
41
|
-
/**
|
|
42
|
-
* USD value of the fee when swap was created - only present for newer swaps where the USD value at create
|
|
43
|
-
* time is known. Left for convenience only, use usdValue() instead, which automatically
|
|
44
|
-
* recognizes which pricing to use (either past value if available or fetches it on-demand)
|
|
45
|
-
*/
|
|
46
|
-
pastUsdValue?: number,
|
|
47
|
-
/**
|
|
48
|
-
* Returns the composition of the fee (base fee + percentage fee) if known, the total fee is calculated as:
|
|
49
|
-
* base_fee + amount * percentage_fee
|
|
50
|
-
*/
|
|
51
|
-
composition?: {
|
|
52
|
-
base: TokenAmount,
|
|
53
|
-
percentage: PercentagePPM
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
|
|
1
|
+
import {PercentagePPM} from "./PercentagePPM";
|
|
2
|
+
import {TokenAmount} from "../TokenAmount";
|
|
3
|
+
import {Token} from "../Token";
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Fee represented in both, source and destination tokens, as well as providing USD valuation helpers and
|
|
7
|
+
* fee composition
|
|
8
|
+
*
|
|
9
|
+
* @category Pricing
|
|
10
|
+
*/
|
|
11
|
+
export type Fee<
|
|
12
|
+
ChainIdentifier extends string = string,
|
|
13
|
+
TSrc extends Token<ChainIdentifier> = Token<ChainIdentifier>,
|
|
14
|
+
TDst extends Token<ChainIdentifier> = Token<ChainIdentifier>
|
|
15
|
+
> = {
|
|
16
|
+
/**
|
|
17
|
+
* Fee value equivalent in source token
|
|
18
|
+
*/
|
|
19
|
+
amountInSrcToken: TokenAmount<TSrc, true>,
|
|
20
|
+
/**
|
|
21
|
+
* Fee value equivalent in destination token
|
|
22
|
+
*/
|
|
23
|
+
amountInDstToken: TokenAmount<TDst, true>,
|
|
24
|
+
/**
|
|
25
|
+
* Fetches the current USD value of the fee
|
|
26
|
+
*
|
|
27
|
+
* @param abortSignal
|
|
28
|
+
* @param preFetchedUsdPrice You can supply a pre-fetched usd price to the pricing function
|
|
29
|
+
* @returns A promise resolving to the current USD value of the token amount
|
|
30
|
+
*/
|
|
31
|
+
currentUsdValue: (abortSignal?: AbortSignal, preFetchedUsdPrice?: number) => Promise<number>,
|
|
32
|
+
/**
|
|
33
|
+
* Gets USD value of the fee, if the USD value when the swap was created is known (newer swaps) it returns this value,
|
|
34
|
+
* otherwise fetches the usd value on-demand
|
|
35
|
+
*
|
|
36
|
+
* @param abortSignal
|
|
37
|
+
* @param preFetchedUsdPrice You can supply a pre-fetched usd price to the pricing function
|
|
38
|
+
* @returns A promise resolving to the current USD value of the fee
|
|
39
|
+
*/
|
|
40
|
+
usdValue: (abortSignal?: AbortSignal, preFetchedUsdPrice?: number) => Promise<number>,
|
|
41
|
+
/**
|
|
42
|
+
* USD value of the fee when swap was created - only present for newer swaps where the USD value at create
|
|
43
|
+
* time is known. Left for convenience only, use usdValue() instead, which automatically
|
|
44
|
+
* recognizes which pricing to use (either past value if available or fetches it on-demand)
|
|
45
|
+
*/
|
|
46
|
+
pastUsdValue?: number,
|
|
47
|
+
/**
|
|
48
|
+
* Returns the composition of the fee (base fee + percentage fee) if known, the total fee is calculated as:
|
|
49
|
+
* base_fee + amount * percentage_fee
|
|
50
|
+
*/
|
|
51
|
+
composition?: {
|
|
52
|
+
base: TokenAmount,
|
|
53
|
+
percentage: PercentagePPM
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
|
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
import {FeeType} from "../../enums/FeeType";
|
|
2
|
-
import {Fee} from "./Fee";
|
|
3
|
-
|
|
4
|
-
/**
|
|
5
|
-
* Breakdown of fees by type (swap fee, network fee, etc.)
|
|
6
|
-
*
|
|
7
|
-
* @category Pricing
|
|
8
|
-
*/
|
|
9
|
-
export type FeeBreakdown<ChainIdentifier extends string = string> = {
|
|
10
|
-
type: FeeType,
|
|
11
|
-
fee: Fee<ChainIdentifier>
|
|
1
|
+
import {FeeType} from "../../enums/FeeType";
|
|
2
|
+
import {Fee} from "./Fee";
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Breakdown of fees by type (swap fee, network fee, etc.)
|
|
6
|
+
*
|
|
7
|
+
* @category Pricing
|
|
8
|
+
*/
|
|
9
|
+
export type FeeBreakdown<ChainIdentifier extends string = string> = {
|
|
10
|
+
type: FeeType,
|
|
11
|
+
fee: Fee<ChainIdentifier>
|
|
12
12
|
}[];
|
|
@@ -1,26 +1,26 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Parts-per-million fee representation with conversion helpers
|
|
3
|
-
*
|
|
4
|
-
* @category Pricing
|
|
5
|
-
*/
|
|
6
|
-
export type PercentagePPM = {
|
|
7
|
-
ppm: bigint,
|
|
8
|
-
decimal: number,
|
|
9
|
-
percentage: number,
|
|
10
|
-
toString: (decimal?: number) => string
|
|
11
|
-
};
|
|
12
|
-
|
|
13
|
-
/**
|
|
14
|
-
* Converts parts-per-million to percentage representation
|
|
15
|
-
*
|
|
16
|
-
* @category Pricing
|
|
17
|
-
*/
|
|
18
|
-
export function ppmToPercentage(ppm: bigint): PercentagePPM {
|
|
19
|
-
const percentage = Number(ppm) / 10_000;
|
|
20
|
-
return {
|
|
21
|
-
ppm,
|
|
22
|
-
decimal: Number(ppm) / 1_000_000,
|
|
23
|
-
percentage: percentage,
|
|
24
|
-
toString: (decimals?: number) => (decimals != null ? percentage.toFixed(decimals) : percentage) + "%"
|
|
25
|
-
}
|
|
26
|
-
}
|
|
1
|
+
/**
|
|
2
|
+
* Parts-per-million fee representation with conversion helpers
|
|
3
|
+
*
|
|
4
|
+
* @category Pricing
|
|
5
|
+
*/
|
|
6
|
+
export type PercentagePPM = {
|
|
7
|
+
ppm: bigint,
|
|
8
|
+
decimal: number,
|
|
9
|
+
percentage: number,
|
|
10
|
+
toString: (decimal?: number) => string
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* Converts parts-per-million to percentage representation
|
|
15
|
+
*
|
|
16
|
+
* @category Pricing
|
|
17
|
+
*/
|
|
18
|
+
export function ppmToPercentage(ppm: bigint): PercentagePPM {
|
|
19
|
+
const percentage = Number(ppm) / 10_000;
|
|
20
|
+
return {
|
|
21
|
+
ppm,
|
|
22
|
+
decimal: Number(ppm) / 1_000_000,
|
|
23
|
+
percentage: percentage,
|
|
24
|
+
toString: (decimals?: number) => (decimals != null ? percentage.toFixed(decimals) : percentage) + "%"
|
|
25
|
+
}
|
|
26
|
+
}
|
|
@@ -1,79 +1,79 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Response of the LNURL-pay link
|
|
3
|
-
*
|
|
4
|
-
* @category Lightning
|
|
5
|
-
*/
|
|
6
|
-
export type LNURLPayParams = {
|
|
7
|
-
tag: "payRequest";
|
|
8
|
-
callback: string;
|
|
9
|
-
domain: string;
|
|
10
|
-
minSendable: number;
|
|
11
|
-
maxSendable: number;
|
|
12
|
-
metadata: string;
|
|
13
|
-
decodedMetadata: string[][];
|
|
14
|
-
commentAllowed: number;
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
/**
|
|
18
|
-
* Response of the LNURL-pay link with the added original url
|
|
19
|
-
*
|
|
20
|
-
* @category Lightning
|
|
21
|
-
*/
|
|
22
|
-
export type LNURLPayParamsWithUrl = LNURLPayParams & { url: string };
|
|
23
|
-
|
|
24
|
-
/**
|
|
25
|
-
* Parsed LNURL-pay specification
|
|
26
|
-
*
|
|
27
|
-
* @category Lightning
|
|
28
|
-
*/
|
|
29
|
-
export type LNURLPay = {
|
|
30
|
-
type: "pay",
|
|
31
|
-
min: bigint,
|
|
32
|
-
max: bigint,
|
|
33
|
-
commentMaxLength: number,
|
|
34
|
-
shortDescription?: string,
|
|
35
|
-
longDescription?: string,
|
|
36
|
-
icon?: string,
|
|
37
|
-
params: LNURLPayParamsWithUrl
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
/**
|
|
41
|
-
* Type guard for {@link LNURLPayParams}
|
|
42
|
-
*
|
|
43
|
-
* @category Lightning
|
|
44
|
-
* @internal
|
|
45
|
-
*/
|
|
46
|
-
export function isLNURLPayParams(obj: any): obj is LNURLPayParams {
|
|
47
|
-
return obj.tag === "payRequest";
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
/**
|
|
51
|
-
* Type guard for {@link LNURLPay}
|
|
52
|
-
*
|
|
53
|
-
* @category Lightning
|
|
54
|
-
*/
|
|
55
|
-
export function isLNURLPay(value: any): value is LNURLPay {
|
|
56
|
-
return (
|
|
57
|
-
typeof value === "object" &&
|
|
58
|
-
value != null &&
|
|
59
|
-
value.type === "pay" &&
|
|
60
|
-
typeof (value.min) === "bigint" &&
|
|
61
|
-
typeof (value.max) === "bigint" &&
|
|
62
|
-
typeof value.commentMaxLength === "number" &&
|
|
63
|
-
(value.shortDescription === undefined || typeof value.shortDescription === "string") &&
|
|
64
|
-
(value.longDescription === undefined || typeof value.longDescription === "string") &&
|
|
65
|
-
(value.icon === undefined || typeof value.icon === "string") &&
|
|
66
|
-
isLNURLPayParams(value.params)
|
|
67
|
-
);
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
/**
|
|
71
|
-
* Decoded LNURL-pay success action, revealed after a lightning payment is finished
|
|
72
|
-
*
|
|
73
|
-
* @category Lightning
|
|
74
|
-
*/
|
|
75
|
-
export type LNURLDecodedSuccessAction = {
|
|
76
|
-
description: string,
|
|
77
|
-
text?: string,
|
|
78
|
-
url?: string
|
|
79
|
-
};
|
|
1
|
+
/**
|
|
2
|
+
* Response of the LNURL-pay link
|
|
3
|
+
*
|
|
4
|
+
* @category Lightning
|
|
5
|
+
*/
|
|
6
|
+
export type LNURLPayParams = {
|
|
7
|
+
tag: "payRequest";
|
|
8
|
+
callback: string;
|
|
9
|
+
domain: string;
|
|
10
|
+
minSendable: number;
|
|
11
|
+
maxSendable: number;
|
|
12
|
+
metadata: string;
|
|
13
|
+
decodedMetadata: string[][];
|
|
14
|
+
commentAllowed: number;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Response of the LNURL-pay link with the added original url
|
|
19
|
+
*
|
|
20
|
+
* @category Lightning
|
|
21
|
+
*/
|
|
22
|
+
export type LNURLPayParamsWithUrl = LNURLPayParams & { url: string };
|
|
23
|
+
|
|
24
|
+
/**
|
|
25
|
+
* Parsed LNURL-pay specification
|
|
26
|
+
*
|
|
27
|
+
* @category Lightning
|
|
28
|
+
*/
|
|
29
|
+
export type LNURLPay = {
|
|
30
|
+
type: "pay",
|
|
31
|
+
min: bigint,
|
|
32
|
+
max: bigint,
|
|
33
|
+
commentMaxLength: number,
|
|
34
|
+
shortDescription?: string,
|
|
35
|
+
longDescription?: string,
|
|
36
|
+
icon?: string,
|
|
37
|
+
params: LNURLPayParamsWithUrl
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
/**
|
|
41
|
+
* Type guard for {@link LNURLPayParams}
|
|
42
|
+
*
|
|
43
|
+
* @category Lightning
|
|
44
|
+
* @internal
|
|
45
|
+
*/
|
|
46
|
+
export function isLNURLPayParams(obj: any): obj is LNURLPayParams {
|
|
47
|
+
return obj.tag === "payRequest";
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
/**
|
|
51
|
+
* Type guard for {@link LNURLPay}
|
|
52
|
+
*
|
|
53
|
+
* @category Lightning
|
|
54
|
+
*/
|
|
55
|
+
export function isLNURLPay(value: any): value is LNURLPay {
|
|
56
|
+
return (
|
|
57
|
+
typeof value === "object" &&
|
|
58
|
+
value != null &&
|
|
59
|
+
value.type === "pay" &&
|
|
60
|
+
typeof (value.min) === "bigint" &&
|
|
61
|
+
typeof (value.max) === "bigint" &&
|
|
62
|
+
typeof value.commentMaxLength === "number" &&
|
|
63
|
+
(value.shortDescription === undefined || typeof value.shortDescription === "string") &&
|
|
64
|
+
(value.longDescription === undefined || typeof value.longDescription === "string") &&
|
|
65
|
+
(value.icon === undefined || typeof value.icon === "string") &&
|
|
66
|
+
isLNURLPayParams(value.params)
|
|
67
|
+
);
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
/**
|
|
71
|
+
* Decoded LNURL-pay success action, revealed after a lightning payment is finished
|
|
72
|
+
*
|
|
73
|
+
* @category Lightning
|
|
74
|
+
*/
|
|
75
|
+
export type LNURLDecodedSuccessAction = {
|
|
76
|
+
description: string,
|
|
77
|
+
text?: string,
|
|
78
|
+
url?: string
|
|
79
|
+
};
|