@atomiqlabs/lp-lib 16.2.0 → 16.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +201 -201
- package/dist/fees/IBtcFeeEstimator.d.ts +3 -3
- package/dist/fees/IBtcFeeEstimator.js +2 -2
- package/dist/index.d.ts +42 -42
- package/dist/index.js +58 -58
- package/dist/info/InfoHandler.d.ts +17 -17
- package/dist/info/InfoHandler.js +60 -60
- package/dist/plugins/IPlugin.d.ts +144 -144
- package/dist/plugins/IPlugin.js +34 -34
- package/dist/plugins/PluginManager.d.ts +113 -113
- package/dist/plugins/PluginManager.js +274 -274
- package/dist/prices/BinanceSwapPrice.d.ts +29 -29
- package/dist/prices/BinanceSwapPrice.js +79 -79
- package/dist/prices/CoinGeckoSwapPrice.d.ts +33 -33
- package/dist/prices/CoinGeckoSwapPrice.js +51 -51
- package/dist/prices/ISwapPrice.d.ts +43 -43
- package/dist/prices/ISwapPrice.js +55 -55
- package/dist/prices/OKXSwapPrice.d.ts +29 -29
- package/dist/prices/OKXSwapPrice.js +79 -79
- package/dist/storage/IIntermediaryStorage.d.ts +18 -18
- package/dist/storage/IIntermediaryStorage.js +2 -2
- package/dist/storagemanager/IntermediaryStorageManager.d.ts +19 -19
- package/dist/storagemanager/IntermediaryStorageManager.js +111 -111
- package/dist/storagemanager/StorageManager.d.ts +13 -13
- package/dist/storagemanager/StorageManager.js +64 -64
- package/dist/swaps/SwapHandler.d.ts +171 -171
- package/dist/swaps/SwapHandler.js +217 -217
- package/dist/swaps/SwapHandlerSwap.d.ts +79 -79
- package/dist/swaps/SwapHandlerSwap.js +78 -78
- package/dist/swaps/assertions/AmountAssertions.d.ts +28 -28
- package/dist/swaps/assertions/AmountAssertions.js +74 -74
- package/dist/swaps/assertions/FromBtcAmountAssertions.d.ts +76 -76
- package/dist/swaps/assertions/FromBtcAmountAssertions.js +185 -185
- package/dist/swaps/assertions/LightningAssertions.d.ts +44 -44
- package/dist/swaps/assertions/LightningAssertions.js +86 -86
- package/dist/swaps/assertions/ToBtcAmountAssertions.d.ts +53 -53
- package/dist/swaps/assertions/ToBtcAmountAssertions.js +150 -150
- package/dist/swaps/escrow/EscrowHandler.d.ts +50 -50
- package/dist/swaps/escrow/EscrowHandler.js +151 -151
- package/dist/swaps/escrow/EscrowHandlerSwap.d.ts +35 -35
- package/dist/swaps/escrow/EscrowHandlerSwap.js +69 -69
- package/dist/swaps/escrow/FromBtcBaseSwap.d.ts +14 -14
- package/dist/swaps/escrow/FromBtcBaseSwap.js +32 -32
- package/dist/swaps/escrow/FromBtcBaseSwapHandler.d.ts +102 -102
- package/dist/swaps/escrow/FromBtcBaseSwapHandler.js +210 -210
- package/dist/swaps/escrow/ToBtcBaseSwap.d.ts +36 -36
- package/dist/swaps/escrow/ToBtcBaseSwap.js +67 -67
- package/dist/swaps/escrow/ToBtcBaseSwapHandler.d.ts +53 -53
- package/dist/swaps/escrow/ToBtcBaseSwapHandler.js +81 -81
- package/dist/swaps/escrow/frombtc_abstract/FromBtcAbs.d.ts +84 -84
- package/dist/swaps/escrow/frombtc_abstract/FromBtcAbs.js +322 -322
- package/dist/swaps/escrow/frombtc_abstract/FromBtcSwapAbs.d.ts +21 -21
- package/dist/swaps/escrow/frombtc_abstract/FromBtcSwapAbs.js +50 -50
- package/dist/swaps/escrow/frombtcln_abstract/FromBtcLnAbs.d.ts +108 -108
- package/dist/swaps/escrow/frombtcln_abstract/FromBtcLnAbs.js +695 -695
- package/dist/swaps/escrow/frombtcln_abstract/FromBtcLnSwapAbs.d.ts +33 -33
- package/dist/swaps/escrow/frombtcln_abstract/FromBtcLnSwapAbs.js +91 -91
- package/dist/swaps/escrow/frombtcln_autoinit/FromBtcLnAuto.d.ts +112 -112
- package/dist/swaps/escrow/frombtcln_autoinit/FromBtcLnAuto.js +708 -708
- package/dist/swaps/escrow/frombtcln_autoinit/FromBtcLnAutoSwap.d.ts +55 -55
- package/dist/swaps/escrow/frombtcln_autoinit/FromBtcLnAutoSwap.js +120 -120
- package/dist/swaps/escrow/tobtc_abstract/ToBtcAbs.d.ts +170 -170
- package/dist/swaps/escrow/tobtc_abstract/ToBtcAbs.js +745 -745
- package/dist/swaps/escrow/tobtc_abstract/ToBtcSwapAbs.d.ts +28 -28
- package/dist/swaps/escrow/tobtc_abstract/ToBtcSwapAbs.js +64 -64
- package/dist/swaps/escrow/tobtcln_abstract/ToBtcLnAbs.d.ts +178 -178
- package/dist/swaps/escrow/tobtcln_abstract/ToBtcLnAbs.js +900 -899
- package/dist/swaps/escrow/tobtcln_abstract/ToBtcLnSwapAbs.d.ts +24 -24
- package/dist/swaps/escrow/tobtcln_abstract/ToBtcLnSwapAbs.js +58 -58
- package/dist/swaps/spv_vault_swap/SpvVault.d.ts +44 -44
- package/dist/swaps/spv_vault_swap/SpvVault.js +145 -145
- package/dist/swaps/spv_vault_swap/SpvVaultSwap.d.ts +68 -68
- package/dist/swaps/spv_vault_swap/SpvVaultSwap.js +158 -158
- package/dist/swaps/spv_vault_swap/SpvVaultSwapHandler.d.ts +68 -68
- package/dist/swaps/spv_vault_swap/SpvVaultSwapHandler.js +561 -561
- package/dist/swaps/spv_vault_swap/SpvVaults.d.ts +63 -63
- package/dist/swaps/spv_vault_swap/SpvVaults.js +491 -491
- package/dist/swaps/trusted/frombtc_trusted/FromBtcTrusted.d.ts +52 -52
- package/dist/swaps/trusted/frombtc_trusted/FromBtcTrusted.js +662 -662
- package/dist/swaps/trusted/frombtc_trusted/FromBtcTrustedSwap.d.ts +52 -52
- package/dist/swaps/trusted/frombtc_trusted/FromBtcTrustedSwap.js +118 -118
- package/dist/swaps/trusted/frombtcln_trusted/FromBtcLnTrusted.d.ts +77 -77
- package/dist/swaps/trusted/frombtcln_trusted/FromBtcLnTrusted.js +504 -504
- package/dist/swaps/trusted/frombtcln_trusted/FromBtcLnTrustedSwap.d.ts +34 -34
- package/dist/swaps/trusted/frombtcln_trusted/FromBtcLnTrustedSwap.js +81 -81
- package/dist/utils/BitcoinUtils.d.ts +4 -4
- package/dist/utils/BitcoinUtils.js +61 -61
- package/dist/utils/Utils.d.ts +32 -32
- package/dist/utils/Utils.js +129 -129
- package/dist/utils/paramcoders/IParamReader.d.ts +5 -5
- package/dist/utils/paramcoders/IParamReader.js +2 -2
- package/dist/utils/paramcoders/IParamWriter.d.ts +4 -4
- package/dist/utils/paramcoders/IParamWriter.js +2 -2
- package/dist/utils/paramcoders/LegacyParamEncoder.d.ts +10 -10
- package/dist/utils/paramcoders/LegacyParamEncoder.js +22 -22
- package/dist/utils/paramcoders/ParamDecoder.d.ts +25 -25
- package/dist/utils/paramcoders/ParamDecoder.js +222 -222
- package/dist/utils/paramcoders/ParamEncoder.d.ts +9 -9
- package/dist/utils/paramcoders/ParamEncoder.js +22 -22
- package/dist/utils/paramcoders/SchemaVerifier.d.ts +21 -21
- package/dist/utils/paramcoders/SchemaVerifier.js +84 -84
- package/dist/utils/paramcoders/server/ServerParamDecoder.d.ts +8 -8
- package/dist/utils/paramcoders/server/ServerParamDecoder.js +107 -107
- package/dist/utils/paramcoders/server/ServerParamEncoder.d.ts +11 -11
- package/dist/utils/paramcoders/server/ServerParamEncoder.js +65 -65
- package/dist/wallets/IBitcoinWallet.d.ts +149 -149
- package/dist/wallets/IBitcoinWallet.js +97 -97
- package/dist/wallets/ILightningWallet.d.ts +136 -136
- package/dist/wallets/ILightningWallet.js +37 -37
- package/dist/wallets/ISpvVaultSigner.d.ts +7 -7
- package/dist/wallets/ISpvVaultSigner.js +2 -2
- package/package.json +36 -36
- package/src/fees/IBtcFeeEstimator.ts +6 -6
- package/src/index.ts +53 -53
- package/src/info/InfoHandler.ts +103 -103
- package/src/plugins/IPlugin.ts +174 -174
- package/src/plugins/PluginManager.ts +354 -354
- package/src/prices/BinanceSwapPrice.ts +101 -101
- package/src/prices/CoinGeckoSwapPrice.ts +75 -75
- package/src/prices/ISwapPrice.ts +88 -88
- package/src/prices/OKXSwapPrice.ts +101 -101
- package/src/storage/IIntermediaryStorage.ts +19 -19
- package/src/storagemanager/IntermediaryStorageManager.ts +118 -118
- package/src/storagemanager/StorageManager.ts +78 -78
- package/src/swaps/SwapHandler.ts +323 -323
- package/src/swaps/SwapHandlerSwap.ts +141 -141
- package/src/swaps/assertions/AmountAssertions.ts +77 -77
- package/src/swaps/assertions/FromBtcAmountAssertions.ts +251 -251
- package/src/swaps/assertions/LightningAssertions.ts +103 -103
- package/src/swaps/assertions/ToBtcAmountAssertions.ts +203 -203
- package/src/swaps/escrow/EscrowHandler.ts +172 -172
- package/src/swaps/escrow/EscrowHandlerSwap.ts +86 -86
- package/src/swaps/escrow/FromBtcBaseSwap.ts +38 -38
- package/src/swaps/escrow/FromBtcBaseSwapHandler.ts +286 -286
- package/src/swaps/escrow/ToBtcBaseSwap.ts +85 -85
- package/src/swaps/escrow/ToBtcBaseSwapHandler.ts +129 -129
- package/src/swaps/escrow/frombtc_abstract/FromBtcAbs.ts +457 -457
- package/src/swaps/escrow/frombtc_abstract/FromBtcSwapAbs.ts +61 -61
- package/src/swaps/escrow/frombtcln_abstract/FromBtcLnAbs.ts +873 -873
- package/src/swaps/escrow/frombtcln_abstract/FromBtcLnSwapAbs.ts +141 -141
- package/src/swaps/escrow/frombtcln_autoinit/FromBtcLnAuto.ts +866 -866
- package/src/swaps/escrow/frombtcln_autoinit/FromBtcLnAutoSwap.ts +196 -196
- package/src/swaps/escrow/tobtc_abstract/ToBtcAbs.ts +920 -920
- package/src/swaps/escrow/tobtc_abstract/ToBtcSwapAbs.ts +108 -108
- package/src/swaps/escrow/tobtcln_abstract/ToBtcLnAbs.ts +1150 -1149
- package/src/swaps/escrow/tobtcln_abstract/ToBtcLnSwapAbs.ts +80 -80
- package/src/swaps/spv_vault_swap/SpvVault.ts +178 -178
- package/src/swaps/spv_vault_swap/SpvVaultSwap.ts +228 -228
- package/src/swaps/spv_vault_swap/SpvVaultSwapHandler.ts +718 -718
- package/src/swaps/spv_vault_swap/SpvVaults.ts +567 -567
- package/src/swaps/trusted/frombtc_trusted/FromBtcTrusted.ts +762 -762
- package/src/swaps/trusted/frombtc_trusted/FromBtcTrustedSwap.ts +185 -185
- package/src/swaps/trusted/frombtcln_trusted/FromBtcLnTrusted.ts +603 -603
- package/src/swaps/trusted/frombtcln_trusted/FromBtcLnTrustedSwap.ts +121 -121
- package/src/utils/BitcoinUtils.ts +59 -59
- package/src/utils/Utils.ts +150 -150
- package/src/utils/paramcoders/IParamReader.ts +7 -7
- package/src/utils/paramcoders/IParamWriter.ts +8 -8
- package/src/utils/paramcoders/LegacyParamEncoder.ts +27 -27
- package/src/utils/paramcoders/ParamDecoder.ts +218 -218
- package/src/utils/paramcoders/ParamEncoder.ts +29 -29
- package/src/utils/paramcoders/SchemaVerifier.ts +96 -96
- package/src/utils/paramcoders/server/ServerParamDecoder.ts +118 -118
- package/src/utils/paramcoders/server/ServerParamEncoder.ts +75 -75
- package/src/wallets/IBitcoinWallet.ts +237 -237
- package/src/wallets/ILightningWallet.ts +200 -200
- package/src/wallets/ISpvVaultSigner.ts +10 -10
|
@@ -1,34 +1,34 @@
|
|
|
1
|
-
import { SwapHandlerSwap } from "../../SwapHandlerSwap";
|
|
2
|
-
export declare enum FromBtcLnTrustedSwapState {
|
|
3
|
-
REFUNDED = -2,
|
|
4
|
-
CANCELED = -1,
|
|
5
|
-
CREATED = 0,
|
|
6
|
-
RECEIVED = 1,
|
|
7
|
-
SENT = 2,
|
|
8
|
-
CONFIRMED = 3,
|
|
9
|
-
SETTLED = 4
|
|
10
|
-
}
|
|
11
|
-
export declare class FromBtcLnTrustedSwap extends SwapHandlerSwap<FromBtcLnTrustedSwapState> {
|
|
12
|
-
readonly pr: string;
|
|
13
|
-
amount: bigint;
|
|
14
|
-
readonly output: bigint;
|
|
15
|
-
readonly dstAddress: string;
|
|
16
|
-
readonly secret: string;
|
|
17
|
-
readonly token: string;
|
|
18
|
-
scRawTx: string;
|
|
19
|
-
constructor(chainIdentifier: string, pr: string, inputMtokens: bigint, swapFee: bigint, swapFeeInToken: bigint, output: bigint, secret: string, dstAddress: string, token: string);
|
|
20
|
-
constructor(obj: any);
|
|
21
|
-
getToken(): string;
|
|
22
|
-
getOutputAmount(): bigint;
|
|
23
|
-
getSwapFee(): {
|
|
24
|
-
inInputToken: bigint;
|
|
25
|
-
inOutputToken: bigint;
|
|
26
|
-
};
|
|
27
|
-
getTotalInputAmount(): bigint;
|
|
28
|
-
getSequence(): bigint;
|
|
29
|
-
serialize(): any;
|
|
30
|
-
isFailed(): boolean;
|
|
31
|
-
isInitiated(): boolean;
|
|
32
|
-
isSuccess(): boolean;
|
|
33
|
-
getIdentifierHash(): string;
|
|
34
|
-
}
|
|
1
|
+
import { SwapHandlerSwap } from "../../SwapHandlerSwap";
|
|
2
|
+
export declare enum FromBtcLnTrustedSwapState {
|
|
3
|
+
REFUNDED = -2,
|
|
4
|
+
CANCELED = -1,
|
|
5
|
+
CREATED = 0,
|
|
6
|
+
RECEIVED = 1,
|
|
7
|
+
SENT = 2,
|
|
8
|
+
CONFIRMED = 3,
|
|
9
|
+
SETTLED = 4
|
|
10
|
+
}
|
|
11
|
+
export declare class FromBtcLnTrustedSwap extends SwapHandlerSwap<FromBtcLnTrustedSwapState> {
|
|
12
|
+
readonly pr: string;
|
|
13
|
+
amount: bigint;
|
|
14
|
+
readonly output: bigint;
|
|
15
|
+
readonly dstAddress: string;
|
|
16
|
+
readonly secret: string;
|
|
17
|
+
readonly token: string;
|
|
18
|
+
scRawTx: string;
|
|
19
|
+
constructor(chainIdentifier: string, pr: string, inputMtokens: bigint, swapFee: bigint, swapFeeInToken: bigint, output: bigint, secret: string, dstAddress: string, token: string);
|
|
20
|
+
constructor(obj: any);
|
|
21
|
+
getToken(): string;
|
|
22
|
+
getOutputAmount(): bigint;
|
|
23
|
+
getSwapFee(): {
|
|
24
|
+
inInputToken: bigint;
|
|
25
|
+
inOutputToken: bigint;
|
|
26
|
+
};
|
|
27
|
+
getTotalInputAmount(): bigint;
|
|
28
|
+
getSequence(): bigint;
|
|
29
|
+
serialize(): any;
|
|
30
|
+
isFailed(): boolean;
|
|
31
|
+
isInitiated(): boolean;
|
|
32
|
+
isSuccess(): boolean;
|
|
33
|
+
getIdentifierHash(): string;
|
|
34
|
+
}
|
|
@@ -1,81 +1,81 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.FromBtcLnTrustedSwap = exports.FromBtcLnTrustedSwapState = void 0;
|
|
4
|
-
const crypto_1 = require("crypto");
|
|
5
|
-
const Utils_1 = require("../../../utils/Utils");
|
|
6
|
-
const SwapHandlerSwap_1 = require("../../SwapHandlerSwap");
|
|
7
|
-
const SwapHandler_1 = require("../../SwapHandler");
|
|
8
|
-
var FromBtcLnTrustedSwapState;
|
|
9
|
-
(function (FromBtcLnTrustedSwapState) {
|
|
10
|
-
FromBtcLnTrustedSwapState[FromBtcLnTrustedSwapState["REFUNDED"] = -2] = "REFUNDED";
|
|
11
|
-
FromBtcLnTrustedSwapState[FromBtcLnTrustedSwapState["CANCELED"] = -1] = "CANCELED";
|
|
12
|
-
FromBtcLnTrustedSwapState[FromBtcLnTrustedSwapState["CREATED"] = 0] = "CREATED";
|
|
13
|
-
FromBtcLnTrustedSwapState[FromBtcLnTrustedSwapState["RECEIVED"] = 1] = "RECEIVED";
|
|
14
|
-
FromBtcLnTrustedSwapState[FromBtcLnTrustedSwapState["SENT"] = 2] = "SENT";
|
|
15
|
-
FromBtcLnTrustedSwapState[FromBtcLnTrustedSwapState["CONFIRMED"] = 3] = "CONFIRMED";
|
|
16
|
-
FromBtcLnTrustedSwapState[FromBtcLnTrustedSwapState["SETTLED"] = 4] = "SETTLED";
|
|
17
|
-
})(FromBtcLnTrustedSwapState = exports.FromBtcLnTrustedSwapState || (exports.FromBtcLnTrustedSwapState = {}));
|
|
18
|
-
class FromBtcLnTrustedSwap extends SwapHandlerSwap_1.SwapHandlerSwap {
|
|
19
|
-
constructor(chainIdOrObj, pr, inputMtokens, swapFee, swapFeeInToken, output, secret, dstAddress, token) {
|
|
20
|
-
if (typeof (chainIdOrObj) === "string") {
|
|
21
|
-
super(chainIdOrObj, swapFee, swapFeeInToken);
|
|
22
|
-
this.state = FromBtcLnTrustedSwapState.CREATED;
|
|
23
|
-
this.pr = pr;
|
|
24
|
-
this.amount = (inputMtokens + 999n) / 1000n;
|
|
25
|
-
this.output = output;
|
|
26
|
-
this.secret = secret;
|
|
27
|
-
this.dstAddress = dstAddress;
|
|
28
|
-
this.token = token;
|
|
29
|
-
}
|
|
30
|
-
else {
|
|
31
|
-
super(chainIdOrObj);
|
|
32
|
-
this.pr = chainIdOrObj.pr;
|
|
33
|
-
this.amount = (0, Utils_1.deserializeBN)(chainIdOrObj.amount);
|
|
34
|
-
this.output = (0, Utils_1.deserializeBN)(chainIdOrObj.output);
|
|
35
|
-
this.secret = chainIdOrObj.secret;
|
|
36
|
-
this.dstAddress = chainIdOrObj.dstAddress;
|
|
37
|
-
this.token = chainIdOrObj.token;
|
|
38
|
-
this.scRawTx = chainIdOrObj.scRawTx;
|
|
39
|
-
}
|
|
40
|
-
this.type = SwapHandler_1.SwapHandlerType.FROM_BTCLN_TRUSTED;
|
|
41
|
-
}
|
|
42
|
-
getToken() {
|
|
43
|
-
return this.token;
|
|
44
|
-
}
|
|
45
|
-
getOutputAmount() {
|
|
46
|
-
return this.output;
|
|
47
|
-
}
|
|
48
|
-
getSwapFee() {
|
|
49
|
-
return { inInputToken: this.swapFee, inOutputToken: this.swapFeeInToken };
|
|
50
|
-
}
|
|
51
|
-
getTotalInputAmount() {
|
|
52
|
-
return this.amount;
|
|
53
|
-
}
|
|
54
|
-
getSequence() {
|
|
55
|
-
return 0n;
|
|
56
|
-
}
|
|
57
|
-
serialize() {
|
|
58
|
-
const partialSerialized = super.serialize();
|
|
59
|
-
partialSerialized.pr = this.pr;
|
|
60
|
-
partialSerialized.amount = (0, Utils_1.serializeBN)(this.amount);
|
|
61
|
-
partialSerialized.output = (0, Utils_1.serializeBN)(this.output);
|
|
62
|
-
partialSerialized.secret = this.secret;
|
|
63
|
-
partialSerialized.dstAddress = this.dstAddress;
|
|
64
|
-
partialSerialized.token = this.token;
|
|
65
|
-
partialSerialized.scRawTx = this.scRawTx;
|
|
66
|
-
return partialSerialized;
|
|
67
|
-
}
|
|
68
|
-
isFailed() {
|
|
69
|
-
return this.state === FromBtcLnTrustedSwapState.CANCELED || this.state === FromBtcLnTrustedSwapState.REFUNDED;
|
|
70
|
-
}
|
|
71
|
-
isInitiated() {
|
|
72
|
-
return this.state !== FromBtcLnTrustedSwapState.CREATED;
|
|
73
|
-
}
|
|
74
|
-
isSuccess() {
|
|
75
|
-
return this.state === FromBtcLnTrustedSwapState.SETTLED;
|
|
76
|
-
}
|
|
77
|
-
getIdentifierHash() {
|
|
78
|
-
return (0, crypto_1.createHash)("sha256").update(Buffer.from(this.secret, "hex")).digest().toString("hex");
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
exports.FromBtcLnTrustedSwap = FromBtcLnTrustedSwap;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.FromBtcLnTrustedSwap = exports.FromBtcLnTrustedSwapState = void 0;
|
|
4
|
+
const crypto_1 = require("crypto");
|
|
5
|
+
const Utils_1 = require("../../../utils/Utils");
|
|
6
|
+
const SwapHandlerSwap_1 = require("../../SwapHandlerSwap");
|
|
7
|
+
const SwapHandler_1 = require("../../SwapHandler");
|
|
8
|
+
var FromBtcLnTrustedSwapState;
|
|
9
|
+
(function (FromBtcLnTrustedSwapState) {
|
|
10
|
+
FromBtcLnTrustedSwapState[FromBtcLnTrustedSwapState["REFUNDED"] = -2] = "REFUNDED";
|
|
11
|
+
FromBtcLnTrustedSwapState[FromBtcLnTrustedSwapState["CANCELED"] = -1] = "CANCELED";
|
|
12
|
+
FromBtcLnTrustedSwapState[FromBtcLnTrustedSwapState["CREATED"] = 0] = "CREATED";
|
|
13
|
+
FromBtcLnTrustedSwapState[FromBtcLnTrustedSwapState["RECEIVED"] = 1] = "RECEIVED";
|
|
14
|
+
FromBtcLnTrustedSwapState[FromBtcLnTrustedSwapState["SENT"] = 2] = "SENT";
|
|
15
|
+
FromBtcLnTrustedSwapState[FromBtcLnTrustedSwapState["CONFIRMED"] = 3] = "CONFIRMED";
|
|
16
|
+
FromBtcLnTrustedSwapState[FromBtcLnTrustedSwapState["SETTLED"] = 4] = "SETTLED";
|
|
17
|
+
})(FromBtcLnTrustedSwapState = exports.FromBtcLnTrustedSwapState || (exports.FromBtcLnTrustedSwapState = {}));
|
|
18
|
+
class FromBtcLnTrustedSwap extends SwapHandlerSwap_1.SwapHandlerSwap {
|
|
19
|
+
constructor(chainIdOrObj, pr, inputMtokens, swapFee, swapFeeInToken, output, secret, dstAddress, token) {
|
|
20
|
+
if (typeof (chainIdOrObj) === "string") {
|
|
21
|
+
super(chainIdOrObj, swapFee, swapFeeInToken);
|
|
22
|
+
this.state = FromBtcLnTrustedSwapState.CREATED;
|
|
23
|
+
this.pr = pr;
|
|
24
|
+
this.amount = (inputMtokens + 999n) / 1000n;
|
|
25
|
+
this.output = output;
|
|
26
|
+
this.secret = secret;
|
|
27
|
+
this.dstAddress = dstAddress;
|
|
28
|
+
this.token = token;
|
|
29
|
+
}
|
|
30
|
+
else {
|
|
31
|
+
super(chainIdOrObj);
|
|
32
|
+
this.pr = chainIdOrObj.pr;
|
|
33
|
+
this.amount = (0, Utils_1.deserializeBN)(chainIdOrObj.amount);
|
|
34
|
+
this.output = (0, Utils_1.deserializeBN)(chainIdOrObj.output);
|
|
35
|
+
this.secret = chainIdOrObj.secret;
|
|
36
|
+
this.dstAddress = chainIdOrObj.dstAddress;
|
|
37
|
+
this.token = chainIdOrObj.token;
|
|
38
|
+
this.scRawTx = chainIdOrObj.scRawTx;
|
|
39
|
+
}
|
|
40
|
+
this.type = SwapHandler_1.SwapHandlerType.FROM_BTCLN_TRUSTED;
|
|
41
|
+
}
|
|
42
|
+
getToken() {
|
|
43
|
+
return this.token;
|
|
44
|
+
}
|
|
45
|
+
getOutputAmount() {
|
|
46
|
+
return this.output;
|
|
47
|
+
}
|
|
48
|
+
getSwapFee() {
|
|
49
|
+
return { inInputToken: this.swapFee, inOutputToken: this.swapFeeInToken };
|
|
50
|
+
}
|
|
51
|
+
getTotalInputAmount() {
|
|
52
|
+
return this.amount;
|
|
53
|
+
}
|
|
54
|
+
getSequence() {
|
|
55
|
+
return 0n;
|
|
56
|
+
}
|
|
57
|
+
serialize() {
|
|
58
|
+
const partialSerialized = super.serialize();
|
|
59
|
+
partialSerialized.pr = this.pr;
|
|
60
|
+
partialSerialized.amount = (0, Utils_1.serializeBN)(this.amount);
|
|
61
|
+
partialSerialized.output = (0, Utils_1.serializeBN)(this.output);
|
|
62
|
+
partialSerialized.secret = this.secret;
|
|
63
|
+
partialSerialized.dstAddress = this.dstAddress;
|
|
64
|
+
partialSerialized.token = this.token;
|
|
65
|
+
partialSerialized.scRawTx = this.scRawTx;
|
|
66
|
+
return partialSerialized;
|
|
67
|
+
}
|
|
68
|
+
isFailed() {
|
|
69
|
+
return this.state === FromBtcLnTrustedSwapState.CANCELED || this.state === FromBtcLnTrustedSwapState.REFUNDED;
|
|
70
|
+
}
|
|
71
|
+
isInitiated() {
|
|
72
|
+
return this.state !== FromBtcLnTrustedSwapState.CREATED;
|
|
73
|
+
}
|
|
74
|
+
isSuccess() {
|
|
75
|
+
return this.state === FromBtcLnTrustedSwapState.SETTLED;
|
|
76
|
+
}
|
|
77
|
+
getIdentifierHash() {
|
|
78
|
+
return (0, crypto_1.createHash)("sha256").update(Buffer.from(this.secret, "hex")).digest().toString("hex");
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
exports.FromBtcLnTrustedSwap = FromBtcLnTrustedSwap;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { TransactionInput } from "@scure/btc-signer/psbt";
|
|
2
|
-
import { BitcoinRpc, BtcTx } from "@atomiqlabs/base";
|
|
3
|
-
export declare function isLegacyInput(input: TransactionInput): boolean;
|
|
4
|
-
export declare function checkTransactionReplaced(txId: string, txRaw: string, bitcoin: BitcoinRpc<any>): Promise<BtcTx>;
|
|
1
|
+
import { TransactionInput } from "@scure/btc-signer/psbt";
|
|
2
|
+
import { BitcoinRpc, BtcTx } from "@atomiqlabs/base";
|
|
3
|
+
export declare function isLegacyInput(input: TransactionInput): boolean;
|
|
4
|
+
export declare function checkTransactionReplaced(txId: string, txRaw: string, bitcoin: BitcoinRpc<any>): Promise<BtcTx>;
|
|
@@ -1,61 +1,61 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.checkTransactionReplaced = exports.isLegacyInput = void 0;
|
|
4
|
-
const utxo_1 = require("@scure/btc-signer/utxo");
|
|
5
|
-
const btc_signer_1 = require("@scure/btc-signer");
|
|
6
|
-
const Utils_1 = require("./Utils");
|
|
7
|
-
const logger = (0, Utils_1.getLogger)("BitcoinUtils: ");
|
|
8
|
-
function parsePushOpcode(script) {
|
|
9
|
-
if (script[0] === 0x00) {
|
|
10
|
-
return Uint8Array.from([]);
|
|
11
|
-
}
|
|
12
|
-
if (script[0] <= 0x4b) {
|
|
13
|
-
return script.slice(1, 1 + script[0]);
|
|
14
|
-
}
|
|
15
|
-
if (script[0] === 0x4c) {
|
|
16
|
-
return script.slice(2, 2 + script[1]);
|
|
17
|
-
}
|
|
18
|
-
if (script[0] === 0x4d) {
|
|
19
|
-
const length = Buffer.from(script.slice(1, 3)).readUInt16LE();
|
|
20
|
-
return script.slice(3, 3 + length);
|
|
21
|
-
}
|
|
22
|
-
if (script[0] === 0x4e) {
|
|
23
|
-
const length = Buffer.from(script.slice(1, 5)).readUInt32LE();
|
|
24
|
-
return script.slice(5, 5 + length);
|
|
25
|
-
}
|
|
26
|
-
if (script[0] === 0x4f) {
|
|
27
|
-
return Uint8Array.from([0x81]);
|
|
28
|
-
}
|
|
29
|
-
if (script[0] >= 0x51 && script[0] <= 0x60) {
|
|
30
|
-
return Uint8Array.from([script[0] - 0x50]);
|
|
31
|
-
}
|
|
32
|
-
throw new Error("No push opcode detected");
|
|
33
|
-
}
|
|
34
|
-
function isLegacyInput(input) {
|
|
35
|
-
const prevOut = (0, utxo_1.getPrevOut)(input);
|
|
36
|
-
const first = btc_signer_1.OutScript.decode(prevOut.script);
|
|
37
|
-
if (first.type === "tr" || first.type === "wsh" || first.type === "wpkh")
|
|
38
|
-
return false;
|
|
39
|
-
if (first.type === "sh") {
|
|
40
|
-
const redeemScript = input.redeemScript ?? parsePushOpcode(input.finalScriptSig);
|
|
41
|
-
const second = btc_signer_1.OutScript.decode(redeemScript);
|
|
42
|
-
if (second.type === "wsh" || second.type === "wpkh")
|
|
43
|
-
return false;
|
|
44
|
-
}
|
|
45
|
-
return true;
|
|
46
|
-
}
|
|
47
|
-
exports.isLegacyInput = isLegacyInput;
|
|
48
|
-
async function checkTransactionReplaced(txId, txRaw, bitcoin) {
|
|
49
|
-
const existingTx = await bitcoin.getTransaction(txId);
|
|
50
|
-
if (existingTx != null)
|
|
51
|
-
return existingTx;
|
|
52
|
-
//Try to re-broadcast
|
|
53
|
-
try {
|
|
54
|
-
await bitcoin.sendRawTransaction(txRaw);
|
|
55
|
-
}
|
|
56
|
-
catch (e) {
|
|
57
|
-
logger.error("checkTransactionReplaced(" + txId + "): Error when trying to re-broadcast raw transaction: ", e);
|
|
58
|
-
}
|
|
59
|
-
return await bitcoin.getTransaction(txId);
|
|
60
|
-
}
|
|
61
|
-
exports.checkTransactionReplaced = checkTransactionReplaced;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.checkTransactionReplaced = exports.isLegacyInput = void 0;
|
|
4
|
+
const utxo_1 = require("@scure/btc-signer/utxo");
|
|
5
|
+
const btc_signer_1 = require("@scure/btc-signer");
|
|
6
|
+
const Utils_1 = require("./Utils");
|
|
7
|
+
const logger = (0, Utils_1.getLogger)("BitcoinUtils: ");
|
|
8
|
+
function parsePushOpcode(script) {
|
|
9
|
+
if (script[0] === 0x00) {
|
|
10
|
+
return Uint8Array.from([]);
|
|
11
|
+
}
|
|
12
|
+
if (script[0] <= 0x4b) {
|
|
13
|
+
return script.slice(1, 1 + script[0]);
|
|
14
|
+
}
|
|
15
|
+
if (script[0] === 0x4c) {
|
|
16
|
+
return script.slice(2, 2 + script[1]);
|
|
17
|
+
}
|
|
18
|
+
if (script[0] === 0x4d) {
|
|
19
|
+
const length = Buffer.from(script.slice(1, 3)).readUInt16LE();
|
|
20
|
+
return script.slice(3, 3 + length);
|
|
21
|
+
}
|
|
22
|
+
if (script[0] === 0x4e) {
|
|
23
|
+
const length = Buffer.from(script.slice(1, 5)).readUInt32LE();
|
|
24
|
+
return script.slice(5, 5 + length);
|
|
25
|
+
}
|
|
26
|
+
if (script[0] === 0x4f) {
|
|
27
|
+
return Uint8Array.from([0x81]);
|
|
28
|
+
}
|
|
29
|
+
if (script[0] >= 0x51 && script[0] <= 0x60) {
|
|
30
|
+
return Uint8Array.from([script[0] - 0x50]);
|
|
31
|
+
}
|
|
32
|
+
throw new Error("No push opcode detected");
|
|
33
|
+
}
|
|
34
|
+
function isLegacyInput(input) {
|
|
35
|
+
const prevOut = (0, utxo_1.getPrevOut)(input);
|
|
36
|
+
const first = btc_signer_1.OutScript.decode(prevOut.script);
|
|
37
|
+
if (first.type === "tr" || first.type === "wsh" || first.type === "wpkh")
|
|
38
|
+
return false;
|
|
39
|
+
if (first.type === "sh") {
|
|
40
|
+
const redeemScript = input.redeemScript ?? parsePushOpcode(input.finalScriptSig);
|
|
41
|
+
const second = btc_signer_1.OutScript.decode(redeemScript);
|
|
42
|
+
if (second.type === "wsh" || second.type === "wpkh")
|
|
43
|
+
return false;
|
|
44
|
+
}
|
|
45
|
+
return true;
|
|
46
|
+
}
|
|
47
|
+
exports.isLegacyInput = isLegacyInput;
|
|
48
|
+
async function checkTransactionReplaced(txId, txRaw, bitcoin) {
|
|
49
|
+
const existingTx = await bitcoin.getTransaction(txId);
|
|
50
|
+
if (existingTx != null)
|
|
51
|
+
return existingTx;
|
|
52
|
+
//Try to re-broadcast
|
|
53
|
+
try {
|
|
54
|
+
await bitcoin.sendRawTransaction(txRaw);
|
|
55
|
+
}
|
|
56
|
+
catch (e) {
|
|
57
|
+
logger.error("checkTransactionReplaced(" + txId + "): Error when trying to re-broadcast raw transaction: ", e);
|
|
58
|
+
}
|
|
59
|
+
return await bitcoin.getTransaction(txId);
|
|
60
|
+
}
|
|
61
|
+
exports.checkTransactionReplaced = checkTransactionReplaced;
|
package/dist/utils/Utils.d.ts
CHANGED
|
@@ -1,32 +1,32 @@
|
|
|
1
|
-
import { Request, Response } from "express";
|
|
2
|
-
import { ServerParamEncoder } from "./paramcoders/server/ServerParamEncoder";
|
|
3
|
-
import { Transaction } from "@scure/btc-signer";
|
|
4
|
-
import { BtcTx } from "@atomiqlabs/base";
|
|
5
|
-
export type LoggerType = {
|
|
6
|
-
debug: (msg: string, ...args: any[]) => void;
|
|
7
|
-
info: (msg: string, ...args: any[]) => void;
|
|
8
|
-
warn: (msg: string, ...args: any[]) => void;
|
|
9
|
-
error: (msg: string, ...args: any[]) => void;
|
|
10
|
-
};
|
|
11
|
-
export declare function getLogger(prefix: string | (() => string)): LoggerType;
|
|
12
|
-
export type DefinedRuntimeError = {
|
|
13
|
-
code: number;
|
|
14
|
-
msg?: string;
|
|
15
|
-
_httpStatus?: number;
|
|
16
|
-
data?: any;
|
|
17
|
-
};
|
|
18
|
-
export declare function isDefinedRuntimeError(obj: any): obj is DefinedRuntimeError;
|
|
19
|
-
export declare function expressHandlerWrapper(func: (req: Request, res: Response) => Promise<void>): ((req: Request, res: Response & {
|
|
20
|
-
responseStream: ServerParamEncoder;
|
|
21
|
-
}) => void);
|
|
22
|
-
export declare const HEX_REGEX: RegExp;
|
|
23
|
-
export declare function serializeBN(bn: bigint | null): string | null;
|
|
24
|
-
export declare function deserializeBN(str: string | null): bigint | null;
|
|
25
|
-
export declare function bigIntSorter(a: bigint, b: bigint): -1 | 0 | 1;
|
|
26
|
-
/**
|
|
27
|
-
* Creates an abort controller that extends the responseStream's abort signal
|
|
28
|
-
*
|
|
29
|
-
* @param responseStream
|
|
30
|
-
*/
|
|
31
|
-
export declare function getAbortController(responseStream: ServerParamEncoder): AbortController;
|
|
32
|
-
export declare function parsePsbt(btcTx: Transaction): BtcTx;
|
|
1
|
+
import { Request, Response } from "express";
|
|
2
|
+
import { ServerParamEncoder } from "./paramcoders/server/ServerParamEncoder";
|
|
3
|
+
import { Transaction } from "@scure/btc-signer";
|
|
4
|
+
import { BtcTx } from "@atomiqlabs/base";
|
|
5
|
+
export type LoggerType = {
|
|
6
|
+
debug: (msg: string, ...args: any[]) => void;
|
|
7
|
+
info: (msg: string, ...args: any[]) => void;
|
|
8
|
+
warn: (msg: string, ...args: any[]) => void;
|
|
9
|
+
error: (msg: string, ...args: any[]) => void;
|
|
10
|
+
};
|
|
11
|
+
export declare function getLogger(prefix: string | (() => string)): LoggerType;
|
|
12
|
+
export type DefinedRuntimeError = {
|
|
13
|
+
code: number;
|
|
14
|
+
msg?: string;
|
|
15
|
+
_httpStatus?: number;
|
|
16
|
+
data?: any;
|
|
17
|
+
};
|
|
18
|
+
export declare function isDefinedRuntimeError(obj: any): obj is DefinedRuntimeError;
|
|
19
|
+
export declare function expressHandlerWrapper(func: (req: Request, res: Response) => Promise<void>): ((req: Request, res: Response & {
|
|
20
|
+
responseStream: ServerParamEncoder;
|
|
21
|
+
}) => void);
|
|
22
|
+
export declare const HEX_REGEX: RegExp;
|
|
23
|
+
export declare function serializeBN(bn: bigint | null): string | null;
|
|
24
|
+
export declare function deserializeBN(str: string | null): bigint | null;
|
|
25
|
+
export declare function bigIntSorter(a: bigint, b: bigint): -1 | 0 | 1;
|
|
26
|
+
/**
|
|
27
|
+
* Creates an abort controller that extends the responseStream's abort signal
|
|
28
|
+
*
|
|
29
|
+
* @param responseStream
|
|
30
|
+
*/
|
|
31
|
+
export declare function getAbortController(responseStream: ServerParamEncoder): AbortController;
|
|
32
|
+
export declare function parsePsbt(btcTx: Transaction): BtcTx;
|