@atomiqlabs/lp-lib 14.0.0-dev.21 → 14.0.0-dev.23
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 +61 -61
- package/dist/plugins/IPlugin.d.ts +143 -143
- package/dist/plugins/IPlugin.js +34 -34
- package/dist/plugins/PluginManager.d.ts +112 -112
- package/dist/plugins/PluginManager.js +259 -259
- package/dist/prices/BinanceSwapPrice.d.ts +26 -26
- package/dist/prices/BinanceSwapPrice.js +92 -92
- package/dist/prices/CoinGeckoSwapPrice.d.ts +30 -30
- package/dist/prices/CoinGeckoSwapPrice.js +64 -64
- package/dist/prices/ISwapPrice.d.ts +43 -43
- package/dist/prices/ISwapPrice.js +55 -55
- package/dist/prices/OKXSwapPrice.d.ts +26 -26
- package/dist/prices/OKXSwapPrice.js +92 -92
- 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 +153 -153
- package/dist/swaps/SwapHandler.js +160 -160
- 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 +72 -72
- package/dist/swaps/assertions/FromBtcAmountAssertions.d.ts +76 -76
- package/dist/swaps/assertions/FromBtcAmountAssertions.js +180 -180
- 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 +51 -51
- package/dist/swaps/escrow/EscrowHandler.js +158 -158
- 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 +83 -83
- package/dist/swaps/escrow/frombtc_abstract/FromBtcAbs.js +318 -318
- 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 +107 -107
- package/dist/swaps/escrow/frombtcln_abstract/FromBtcLnAbs.js +675 -675
- 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 +111 -111
- package/dist/swaps/escrow/frombtcln_autoinit/FromBtcLnAuto.js +684 -684
- 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 +171 -171
- package/dist/swaps/escrow/tobtc_abstract/ToBtcAbs.js +706 -706
- package/dist/swaps/escrow/tobtc_abstract/ToBtcSwapAbs.d.ts +26 -26
- package/dist/swaps/escrow/tobtc_abstract/ToBtcSwapAbs.js +62 -62
- package/dist/swaps/escrow/tobtcln_abstract/ToBtcLnAbs.d.ts +177 -177
- package/dist/swaps/escrow/tobtcln_abstract/ToBtcLnAbs.js +863 -863
- 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 +40 -41
- package/dist/swaps/spv_vault_swap/SpvVault.js +111 -111
- package/dist/swaps/spv_vault_swap/SpvVaultSwap.d.ts +67 -67
- 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 +492 -492
- package/dist/swaps/spv_vault_swap/SpvVaults.d.ts +52 -52
- package/dist/swaps/spv_vault_swap/SpvVaults.js +386 -364
- package/dist/swaps/trusted/frombtc_trusted/FromBtcTrusted.d.ts +51 -51
- package/dist/swaps/trusted/frombtc_trusted/FromBtcTrusted.js +650 -650
- 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 +76 -76
- package/dist/swaps/trusted/frombtcln_trusted/FromBtcLnTrusted.js +494 -494
- 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 +2 -2
- package/dist/utils/BitcoinUtils.js +45 -45
- package/dist/utils/Utils.d.ts +29 -29
- package/dist/utils/Utils.js +89 -89
- package/dist/utils/paramcoders/IParamReader.d.ts +5 -5
- package/dist/utils/paramcoders/IParamReader.js +2 -2
- package/dist/utils/paramcoders/IParamWriter.d.ts +4 -4
- package/dist/utils/paramcoders/IParamWriter.js +2 -2
- package/dist/utils/paramcoders/LegacyParamEncoder.d.ts +10 -10
- package/dist/utils/paramcoders/LegacyParamEncoder.js +22 -22
- package/dist/utils/paramcoders/ParamDecoder.d.ts +25 -25
- package/dist/utils/paramcoders/ParamDecoder.js +222 -222
- package/dist/utils/paramcoders/ParamEncoder.d.ts +9 -9
- package/dist/utils/paramcoders/ParamEncoder.js +22 -22
- package/dist/utils/paramcoders/SchemaVerifier.d.ts +21 -21
- package/dist/utils/paramcoders/SchemaVerifier.js +84 -84
- package/dist/utils/paramcoders/server/ServerParamDecoder.d.ts +8 -8
- package/dist/utils/paramcoders/server/ServerParamDecoder.js +107 -107
- package/dist/utils/paramcoders/server/ServerParamEncoder.d.ts +11 -11
- package/dist/utils/paramcoders/server/ServerParamEncoder.js +65 -65
- package/dist/wallets/IBitcoinWallet.d.ts +67 -67
- package/dist/wallets/IBitcoinWallet.js +2 -2
- package/dist/wallets/ILightningWallet.d.ts +117 -117
- 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 +106 -106
- package/src/plugins/IPlugin.ts +168 -168
- package/src/plugins/PluginManager.ts +336 -336
- package/src/prices/BinanceSwapPrice.ts +113 -113
- package/src/prices/CoinGeckoSwapPrice.ts +87 -87
- package/src/prices/ISwapPrice.ts +88 -88
- package/src/prices/OKXSwapPrice.ts +113 -113
- 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 +277 -277
- package/src/swaps/SwapHandlerSwap.ts +141 -141
- package/src/swaps/assertions/AmountAssertions.ts +76 -76
- package/src/swaps/assertions/FromBtcAmountAssertions.ts +246 -246
- package/src/swaps/assertions/LightningAssertions.ts +103 -103
- package/src/swaps/assertions/ToBtcAmountAssertions.ts +203 -203
- package/src/swaps/escrow/EscrowHandler.ts +179 -179
- 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 +452 -452
- package/src/swaps/escrow/frombtc_abstract/FromBtcSwapAbs.ts +61 -61
- package/src/swaps/escrow/frombtcln_abstract/FromBtcLnAbs.ts +856 -856
- package/src/swaps/escrow/frombtcln_abstract/FromBtcLnSwapAbs.ts +141 -141
- package/src/swaps/escrow/frombtcln_autoinit/FromBtcLnAuto.ts +850 -850
- package/src/swaps/escrow/frombtcln_autoinit/FromBtcLnAutoSwap.ts +196 -196
- package/src/swaps/escrow/tobtc_abstract/ToBtcAbs.ts +879 -879
- package/src/swaps/escrow/tobtc_abstract/ToBtcSwapAbs.ts +102 -102
- package/src/swaps/escrow/tobtcln_abstract/ToBtcLnAbs.ts +1112 -1112
- package/src/swaps/escrow/tobtcln_abstract/ToBtcLnSwapAbs.ts +80 -80
- package/src/swaps/spv_vault_swap/SpvVault.ts +143 -143
- package/src/swaps/spv_vault_swap/SpvVaultSwap.ts +225 -225
- package/src/swaps/spv_vault_swap/SpvVaultSwapHandler.ts +628 -628
- package/src/swaps/spv_vault_swap/SpvVaults.ts +458 -435
- package/src/swaps/trusted/frombtc_trusted/FromBtcTrusted.ts +747 -747
- package/src/swaps/trusted/frombtc_trusted/FromBtcTrustedSwap.ts +185 -185
- package/src/swaps/trusted/frombtcln_trusted/FromBtcLnTrusted.ts +590 -590
- package/src/swaps/trusted/frombtcln_trusted/FromBtcLnTrustedSwap.ts +121 -121
- package/src/utils/BitcoinUtils.ts +42 -42
- package/src/utils/Utils.ts +104 -104
- package/src/utils/paramcoders/IParamReader.ts +7 -7
- package/src/utils/paramcoders/IParamWriter.ts +8 -8
- package/src/utils/paramcoders/LegacyParamEncoder.ts +27 -27
- package/src/utils/paramcoders/ParamDecoder.ts +218 -218
- package/src/utils/paramcoders/ParamEncoder.ts +29 -29
- package/src/utils/paramcoders/SchemaVerifier.ts +96 -96
- package/src/utils/paramcoders/server/ServerParamDecoder.ts +118 -118
- package/src/utils/paramcoders/server/ServerParamEncoder.ts +75 -75
- package/src/wallets/IBitcoinWallet.ts +68 -68
- package/src/wallets/ILightningWallet.ts +178 -178
- package/src/wallets/ISpvVaultSigner.ts +10 -10
|
@@ -1,121 +1,121 @@
|
|
|
1
|
-
import {createHash} from "crypto";
|
|
2
|
-
import {deserializeBN, serializeBN} from "../../../utils/Utils";
|
|
3
|
-
import {SwapHandlerSwap} from "../../SwapHandlerSwap";
|
|
4
|
-
import {SwapHandlerType} from "../../SwapHandler";
|
|
5
|
-
|
|
6
|
-
export enum FromBtcLnTrustedSwapState {
|
|
7
|
-
REFUNDED = -2,
|
|
8
|
-
CANCELED = -1,
|
|
9
|
-
CREATED = 0,
|
|
10
|
-
RECEIVED = 1,
|
|
11
|
-
SENT = 2,
|
|
12
|
-
CONFIRMED = 3,
|
|
13
|
-
SETTLED = 4,
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
export class FromBtcLnTrustedSwap extends SwapHandlerSwap<FromBtcLnTrustedSwapState> {
|
|
17
|
-
|
|
18
|
-
readonly pr: string;
|
|
19
|
-
amount: bigint;
|
|
20
|
-
readonly output: bigint;
|
|
21
|
-
readonly dstAddress: string;
|
|
22
|
-
readonly secret: string;
|
|
23
|
-
readonly token: string;
|
|
24
|
-
|
|
25
|
-
scRawTx: string;
|
|
26
|
-
|
|
27
|
-
constructor(
|
|
28
|
-
chainIdentifier: string,
|
|
29
|
-
pr: string,
|
|
30
|
-
inputMtokens: bigint,
|
|
31
|
-
swapFee: bigint,
|
|
32
|
-
swapFeeInToken: bigint,
|
|
33
|
-
output: bigint,
|
|
34
|
-
secret: string,
|
|
35
|
-
dstAddress: string,
|
|
36
|
-
token: string
|
|
37
|
-
);
|
|
38
|
-
constructor(obj: any);
|
|
39
|
-
|
|
40
|
-
constructor(
|
|
41
|
-
chainIdOrObj: string | any,
|
|
42
|
-
pr?: string,
|
|
43
|
-
inputMtokens?: bigint,
|
|
44
|
-
swapFee?: bigint,
|
|
45
|
-
swapFeeInToken?: bigint,
|
|
46
|
-
output?: bigint,
|
|
47
|
-
secret?: string,
|
|
48
|
-
dstAddress?: string,
|
|
49
|
-
token?: string
|
|
50
|
-
) {
|
|
51
|
-
if(typeof(chainIdOrObj)==="string") {
|
|
52
|
-
super(chainIdOrObj, swapFee, swapFeeInToken);
|
|
53
|
-
this.state = FromBtcLnTrustedSwapState.CREATED;
|
|
54
|
-
this.pr = pr;
|
|
55
|
-
this.amount = (inputMtokens + 999n) / 1000n;
|
|
56
|
-
this.output = output;
|
|
57
|
-
this.secret = secret;
|
|
58
|
-
this.dstAddress = dstAddress;
|
|
59
|
-
this.token = token;
|
|
60
|
-
} else {
|
|
61
|
-
super(chainIdOrObj);
|
|
62
|
-
this.pr = chainIdOrObj.pr;
|
|
63
|
-
this.amount = deserializeBN(chainIdOrObj.amount);
|
|
64
|
-
this.output = deserializeBN(chainIdOrObj.output);
|
|
65
|
-
this.secret = chainIdOrObj.secret;
|
|
66
|
-
this.dstAddress = chainIdOrObj.dstAddress;
|
|
67
|
-
this.token = chainIdOrObj.token;
|
|
68
|
-
this.scRawTx = chainIdOrObj.scRawTx;
|
|
69
|
-
}
|
|
70
|
-
this.type = SwapHandlerType.FROM_BTCLN_TRUSTED;
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
getToken(): string {
|
|
74
|
-
return this.token;
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
getOutputAmount(): bigint {
|
|
78
|
-
return this.output;
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
getSwapFee(): { inInputToken: bigint; inOutputToken: bigint } {
|
|
82
|
-
return {inInputToken: this.swapFee, inOutputToken: this.swapFeeInToken};
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
getTotalInputAmount(): bigint {
|
|
86
|
-
return this.amount;
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
getSequence(): bigint {
|
|
90
|
-
return 0n;
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
serialize(): any {
|
|
94
|
-
const partialSerialized = super.serialize();
|
|
95
|
-
partialSerialized.pr = this.pr;
|
|
96
|
-
partialSerialized.amount = serializeBN(this.amount);
|
|
97
|
-
partialSerialized.output = serializeBN(this.output);
|
|
98
|
-
partialSerialized.secret = this.secret;
|
|
99
|
-
partialSerialized.dstAddress = this.dstAddress;
|
|
100
|
-
partialSerialized.token = this.token;
|
|
101
|
-
partialSerialized.scRawTx = this.scRawTx;
|
|
102
|
-
return partialSerialized;
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
isFailed(): boolean {
|
|
106
|
-
return this.state===FromBtcLnTrustedSwapState.CANCELED || this.state===FromBtcLnTrustedSwapState.REFUNDED;
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
isInitiated(): boolean {
|
|
110
|
-
return this.state!==FromBtcLnTrustedSwapState.CREATED;
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
isSuccess(): boolean {
|
|
114
|
-
return this.state===FromBtcLnTrustedSwapState.SETTLED;
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
getIdentifierHash(): string {
|
|
118
|
-
return createHash("sha256").update(Buffer.from(this.secret, "hex")).digest().toString("hex");
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
}
|
|
1
|
+
import {createHash} from "crypto";
|
|
2
|
+
import {deserializeBN, serializeBN} from "../../../utils/Utils";
|
|
3
|
+
import {SwapHandlerSwap} from "../../SwapHandlerSwap";
|
|
4
|
+
import {SwapHandlerType} from "../../SwapHandler";
|
|
5
|
+
|
|
6
|
+
export enum FromBtcLnTrustedSwapState {
|
|
7
|
+
REFUNDED = -2,
|
|
8
|
+
CANCELED = -1,
|
|
9
|
+
CREATED = 0,
|
|
10
|
+
RECEIVED = 1,
|
|
11
|
+
SENT = 2,
|
|
12
|
+
CONFIRMED = 3,
|
|
13
|
+
SETTLED = 4,
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
export class FromBtcLnTrustedSwap extends SwapHandlerSwap<FromBtcLnTrustedSwapState> {
|
|
17
|
+
|
|
18
|
+
readonly pr: string;
|
|
19
|
+
amount: bigint;
|
|
20
|
+
readonly output: bigint;
|
|
21
|
+
readonly dstAddress: string;
|
|
22
|
+
readonly secret: string;
|
|
23
|
+
readonly token: string;
|
|
24
|
+
|
|
25
|
+
scRawTx: string;
|
|
26
|
+
|
|
27
|
+
constructor(
|
|
28
|
+
chainIdentifier: string,
|
|
29
|
+
pr: string,
|
|
30
|
+
inputMtokens: bigint,
|
|
31
|
+
swapFee: bigint,
|
|
32
|
+
swapFeeInToken: bigint,
|
|
33
|
+
output: bigint,
|
|
34
|
+
secret: string,
|
|
35
|
+
dstAddress: string,
|
|
36
|
+
token: string
|
|
37
|
+
);
|
|
38
|
+
constructor(obj: any);
|
|
39
|
+
|
|
40
|
+
constructor(
|
|
41
|
+
chainIdOrObj: string | any,
|
|
42
|
+
pr?: string,
|
|
43
|
+
inputMtokens?: bigint,
|
|
44
|
+
swapFee?: bigint,
|
|
45
|
+
swapFeeInToken?: bigint,
|
|
46
|
+
output?: bigint,
|
|
47
|
+
secret?: string,
|
|
48
|
+
dstAddress?: string,
|
|
49
|
+
token?: string
|
|
50
|
+
) {
|
|
51
|
+
if(typeof(chainIdOrObj)==="string") {
|
|
52
|
+
super(chainIdOrObj, swapFee, swapFeeInToken);
|
|
53
|
+
this.state = FromBtcLnTrustedSwapState.CREATED;
|
|
54
|
+
this.pr = pr;
|
|
55
|
+
this.amount = (inputMtokens + 999n) / 1000n;
|
|
56
|
+
this.output = output;
|
|
57
|
+
this.secret = secret;
|
|
58
|
+
this.dstAddress = dstAddress;
|
|
59
|
+
this.token = token;
|
|
60
|
+
} else {
|
|
61
|
+
super(chainIdOrObj);
|
|
62
|
+
this.pr = chainIdOrObj.pr;
|
|
63
|
+
this.amount = deserializeBN(chainIdOrObj.amount);
|
|
64
|
+
this.output = deserializeBN(chainIdOrObj.output);
|
|
65
|
+
this.secret = chainIdOrObj.secret;
|
|
66
|
+
this.dstAddress = chainIdOrObj.dstAddress;
|
|
67
|
+
this.token = chainIdOrObj.token;
|
|
68
|
+
this.scRawTx = chainIdOrObj.scRawTx;
|
|
69
|
+
}
|
|
70
|
+
this.type = SwapHandlerType.FROM_BTCLN_TRUSTED;
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
getToken(): string {
|
|
74
|
+
return this.token;
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
getOutputAmount(): bigint {
|
|
78
|
+
return this.output;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
getSwapFee(): { inInputToken: bigint; inOutputToken: bigint } {
|
|
82
|
+
return {inInputToken: this.swapFee, inOutputToken: this.swapFeeInToken};
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
getTotalInputAmount(): bigint {
|
|
86
|
+
return this.amount;
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
getSequence(): bigint {
|
|
90
|
+
return 0n;
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
serialize(): any {
|
|
94
|
+
const partialSerialized = super.serialize();
|
|
95
|
+
partialSerialized.pr = this.pr;
|
|
96
|
+
partialSerialized.amount = serializeBN(this.amount);
|
|
97
|
+
partialSerialized.output = serializeBN(this.output);
|
|
98
|
+
partialSerialized.secret = this.secret;
|
|
99
|
+
partialSerialized.dstAddress = this.dstAddress;
|
|
100
|
+
partialSerialized.token = this.token;
|
|
101
|
+
partialSerialized.scRawTx = this.scRawTx;
|
|
102
|
+
return partialSerialized;
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
isFailed(): boolean {
|
|
106
|
+
return this.state===FromBtcLnTrustedSwapState.CANCELED || this.state===FromBtcLnTrustedSwapState.REFUNDED;
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
isInitiated(): boolean {
|
|
110
|
+
return this.state!==FromBtcLnTrustedSwapState.CREATED;
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
isSuccess(): boolean {
|
|
114
|
+
return this.state===FromBtcLnTrustedSwapState.SETTLED;
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
getIdentifierHash(): string {
|
|
118
|
+
return createHash("sha256").update(Buffer.from(this.secret, "hex")).digest().toString("hex");
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
}
|
|
@@ -1,42 +1,42 @@
|
|
|
1
|
-
import {TransactionInput} from "@scure/btc-signer/psbt";
|
|
2
|
-
import {getPrevOut} from "@scure/btc-signer/utxo";
|
|
3
|
-
import {OutScript} from "@scure/btc-signer";
|
|
4
|
-
|
|
5
|
-
function parsePushOpcode(script: Uint8Array): Uint8Array {
|
|
6
|
-
if(script[0]===0x00) {
|
|
7
|
-
return Uint8Array.from([]);
|
|
8
|
-
}
|
|
9
|
-
if(script[0]<=0x4b) {
|
|
10
|
-
return script.slice(1, 1+script[0]);
|
|
11
|
-
}
|
|
12
|
-
if(script[0]===0x4c) {
|
|
13
|
-
return script.slice(2, 2+script[1]);
|
|
14
|
-
}
|
|
15
|
-
if(script[0]===0x4d) {
|
|
16
|
-
const length = Buffer.from(script.slice(1, 3)).readUInt16LE();
|
|
17
|
-
return script.slice(3, 3+length);
|
|
18
|
-
}
|
|
19
|
-
if(script[0]===0x4e) {
|
|
20
|
-
const length = Buffer.from(script.slice(1, 5)).readUInt32LE();
|
|
21
|
-
return script.slice(5, 5+length);
|
|
22
|
-
}
|
|
23
|
-
if(script[0]===0x4f) {
|
|
24
|
-
return Uint8Array.from([0x81]);
|
|
25
|
-
}
|
|
26
|
-
if(script[0]>=0x51 && script[0]<=0x60) {
|
|
27
|
-
return Uint8Array.from([script[0] - 0x50]);
|
|
28
|
-
}
|
|
29
|
-
throw new Error("No push opcode detected");
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
export function isLegacyInput(input: TransactionInput): boolean {
|
|
33
|
-
const prevOut = getPrevOut(input);
|
|
34
|
-
const first = OutScript.decode(prevOut.script);
|
|
35
|
-
if(first.type==="tr" || first.type==="wsh" || first.type==="wpkh") return false;
|
|
36
|
-
if(first.type==="sh") {
|
|
37
|
-
const redeemScript = input.redeemScript ?? parsePushOpcode(input.finalScriptSig);
|
|
38
|
-
const second = OutScript.decode(redeemScript);
|
|
39
|
-
if(second.type==="wsh" || second.type==="wpkh") return false;
|
|
40
|
-
}
|
|
41
|
-
return true;
|
|
42
|
-
}
|
|
1
|
+
import {TransactionInput} from "@scure/btc-signer/psbt";
|
|
2
|
+
import {getPrevOut} from "@scure/btc-signer/utxo";
|
|
3
|
+
import {OutScript} from "@scure/btc-signer";
|
|
4
|
+
|
|
5
|
+
function parsePushOpcode(script: Uint8Array): Uint8Array {
|
|
6
|
+
if(script[0]===0x00) {
|
|
7
|
+
return Uint8Array.from([]);
|
|
8
|
+
}
|
|
9
|
+
if(script[0]<=0x4b) {
|
|
10
|
+
return script.slice(1, 1+script[0]);
|
|
11
|
+
}
|
|
12
|
+
if(script[0]===0x4c) {
|
|
13
|
+
return script.slice(2, 2+script[1]);
|
|
14
|
+
}
|
|
15
|
+
if(script[0]===0x4d) {
|
|
16
|
+
const length = Buffer.from(script.slice(1, 3)).readUInt16LE();
|
|
17
|
+
return script.slice(3, 3+length);
|
|
18
|
+
}
|
|
19
|
+
if(script[0]===0x4e) {
|
|
20
|
+
const length = Buffer.from(script.slice(1, 5)).readUInt32LE();
|
|
21
|
+
return script.slice(5, 5+length);
|
|
22
|
+
}
|
|
23
|
+
if(script[0]===0x4f) {
|
|
24
|
+
return Uint8Array.from([0x81]);
|
|
25
|
+
}
|
|
26
|
+
if(script[0]>=0x51 && script[0]<=0x60) {
|
|
27
|
+
return Uint8Array.from([script[0] - 0x50]);
|
|
28
|
+
}
|
|
29
|
+
throw new Error("No push opcode detected");
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
export function isLegacyInput(input: TransactionInput): boolean {
|
|
33
|
+
const prevOut = getPrevOut(input);
|
|
34
|
+
const first = OutScript.decode(prevOut.script);
|
|
35
|
+
if(first.type==="tr" || first.type==="wsh" || first.type==="wpkh") return false;
|
|
36
|
+
if(first.type==="sh") {
|
|
37
|
+
const redeemScript = input.redeemScript ?? parsePushOpcode(input.finalScriptSig);
|
|
38
|
+
const second = OutScript.decode(redeemScript);
|
|
39
|
+
if(second.type==="wsh" || second.type==="wpkh") return false;
|
|
40
|
+
}
|
|
41
|
+
return true;
|
|
42
|
+
}
|
package/src/utils/Utils.ts
CHANGED
|
@@ -1,104 +1,104 @@
|
|
|
1
|
-
import {Request, Response} from "express";
|
|
2
|
-
import {ServerParamEncoder} from "./paramcoders/server/ServerParamEncoder";
|
|
3
|
-
|
|
4
|
-
export type LoggerType = {
|
|
5
|
-
debug: (msg: string, ...args: any[]) => void,
|
|
6
|
-
info: (msg: string, ...args: any[]) => void,
|
|
7
|
-
warn: (msg: string, ...args: any[]) => void,
|
|
8
|
-
error: (msg: string, ...args: any[]) => void
|
|
9
|
-
};
|
|
10
|
-
|
|
11
|
-
export function getLogger(prefix: string | (() => string)): LoggerType {
|
|
12
|
-
return {
|
|
13
|
-
debug: (msg, ...args) => global.atomiqLogLevel >= 3 && console.debug((typeof(prefix)==="function" ? prefix() : prefix)+msg, ...args),
|
|
14
|
-
info: (msg, ...args) => global.atomiqLogLevel >= 2 && console.info((typeof(prefix)==="function" ? prefix() : prefix)+msg, ...args),
|
|
15
|
-
warn: (msg, ...args) => (global.atomiqLogLevel==null || global.atomiqLogLevel >= 1) && console.warn((typeof(prefix)==="function" ? prefix() : prefix)+msg, ...args),
|
|
16
|
-
error: (msg, ...args) => (global.atomiqLogLevel==null || global.atomiqLogLevel >= 0) && console.error((typeof(prefix)==="function" ? prefix() : prefix)+msg, ...args)
|
|
17
|
-
};
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
export type DefinedRuntimeError = {
|
|
21
|
-
code: number;
|
|
22
|
-
msg?: string;
|
|
23
|
-
_httpStatus?: number;
|
|
24
|
-
data?: any;
|
|
25
|
-
};
|
|
26
|
-
|
|
27
|
-
export function isDefinedRuntimeError(obj: any): obj is DefinedRuntimeError {
|
|
28
|
-
if(obj.code!=null && typeof(obj.code)==="number") {
|
|
29
|
-
if(obj.msg!=null && typeof(obj.msg)!=="string") return false;
|
|
30
|
-
if(obj._httpStatus!=null && typeof(obj._httpStatus)!=="number") return false;
|
|
31
|
-
return true;
|
|
32
|
-
}
|
|
33
|
-
return false;
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
const expressHandlerWrapperLogger = getLogger("ExpressHandlerWrapper: ");
|
|
37
|
-
|
|
38
|
-
export function expressHandlerWrapper(func: (
|
|
39
|
-
req: Request,
|
|
40
|
-
res: Response
|
|
41
|
-
) => Promise<void>) : ((
|
|
42
|
-
req: Request,
|
|
43
|
-
res: Response & {responseStream: ServerParamEncoder}
|
|
44
|
-
) => void) {
|
|
45
|
-
return (
|
|
46
|
-
req: Request,
|
|
47
|
-
res: Response & {responseStream: ServerParamEncoder}
|
|
48
|
-
) => {
|
|
49
|
-
(async () => {
|
|
50
|
-
try {
|
|
51
|
-
await func(req, res);
|
|
52
|
-
} catch (e) {
|
|
53
|
-
expressHandlerWrapperLogger.error("Error in called function "+req.path+": ", e);
|
|
54
|
-
let statusCode = 500;
|
|
55
|
-
const obj: {code: number, msg: string, data?: any} = {
|
|
56
|
-
code: 0,
|
|
57
|
-
msg: "Internal server error"
|
|
58
|
-
};
|
|
59
|
-
if(isDefinedRuntimeError(e)) {
|
|
60
|
-
obj.msg = e.msg;
|
|
61
|
-
obj.code = e.code;
|
|
62
|
-
obj.data = e.data;
|
|
63
|
-
statusCode = 400;
|
|
64
|
-
if(e._httpStatus!=null) statusCode = e._httpStatus;
|
|
65
|
-
}
|
|
66
|
-
if(res.responseStream!=null) {
|
|
67
|
-
if(res.responseStream.getAbortSignal().aborted) return;
|
|
68
|
-
res.responseStream.writeParamsAndEnd(obj).catch(e => null);
|
|
69
|
-
} else {
|
|
70
|
-
res.status(statusCode).json(obj);
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
})();
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
export const HEX_REGEX = /[0-9a-fA-F]+/;
|
|
78
|
-
|
|
79
|
-
export function serializeBN(bn: bigint | null): string | null {
|
|
80
|
-
return bn==null ? null : bn.toString(10);
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
export function deserializeBN(str: string | null): bigint | null {
|
|
84
|
-
return str==null ? null : BigInt(str);
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
export function bigIntSorter(a: bigint, b: bigint): -1 | 0 | 1 {
|
|
88
|
-
if(a < b) return -1;
|
|
89
|
-
if(a > b) return 1;
|
|
90
|
-
return 0;
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
/**
|
|
94
|
-
* Creates an abort controller that extends the responseStream's abort signal
|
|
95
|
-
*
|
|
96
|
-
* @param responseStream
|
|
97
|
-
*/
|
|
98
|
-
export function getAbortController(responseStream: ServerParamEncoder): AbortController {
|
|
99
|
-
const abortController = new AbortController();
|
|
100
|
-
if(responseStream==null || responseStream.getAbortSignal==null) return abortController;
|
|
101
|
-
const responseStreamAbortController = responseStream.getAbortSignal();
|
|
102
|
-
responseStreamAbortController.addEventListener("abort", () => abortController.abort(responseStreamAbortController.reason));
|
|
103
|
-
return abortController;
|
|
104
|
-
}
|
|
1
|
+
import {Request, Response} from "express";
|
|
2
|
+
import {ServerParamEncoder} from "./paramcoders/server/ServerParamEncoder";
|
|
3
|
+
|
|
4
|
+
export type LoggerType = {
|
|
5
|
+
debug: (msg: string, ...args: any[]) => void,
|
|
6
|
+
info: (msg: string, ...args: any[]) => void,
|
|
7
|
+
warn: (msg: string, ...args: any[]) => void,
|
|
8
|
+
error: (msg: string, ...args: any[]) => void
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
export function getLogger(prefix: string | (() => string)): LoggerType {
|
|
12
|
+
return {
|
|
13
|
+
debug: (msg, ...args) => global.atomiqLogLevel >= 3 && console.debug((typeof(prefix)==="function" ? prefix() : prefix)+msg, ...args),
|
|
14
|
+
info: (msg, ...args) => global.atomiqLogLevel >= 2 && console.info((typeof(prefix)==="function" ? prefix() : prefix)+msg, ...args),
|
|
15
|
+
warn: (msg, ...args) => (global.atomiqLogLevel==null || global.atomiqLogLevel >= 1) && console.warn((typeof(prefix)==="function" ? prefix() : prefix)+msg, ...args),
|
|
16
|
+
error: (msg, ...args) => (global.atomiqLogLevel==null || global.atomiqLogLevel >= 0) && console.error((typeof(prefix)==="function" ? prefix() : prefix)+msg, ...args)
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
export type DefinedRuntimeError = {
|
|
21
|
+
code: number;
|
|
22
|
+
msg?: string;
|
|
23
|
+
_httpStatus?: number;
|
|
24
|
+
data?: any;
|
|
25
|
+
};
|
|
26
|
+
|
|
27
|
+
export function isDefinedRuntimeError(obj: any): obj is DefinedRuntimeError {
|
|
28
|
+
if(obj.code!=null && typeof(obj.code)==="number") {
|
|
29
|
+
if(obj.msg!=null && typeof(obj.msg)!=="string") return false;
|
|
30
|
+
if(obj._httpStatus!=null && typeof(obj._httpStatus)!=="number") return false;
|
|
31
|
+
return true;
|
|
32
|
+
}
|
|
33
|
+
return false;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
const expressHandlerWrapperLogger = getLogger("ExpressHandlerWrapper: ");
|
|
37
|
+
|
|
38
|
+
export function expressHandlerWrapper(func: (
|
|
39
|
+
req: Request,
|
|
40
|
+
res: Response
|
|
41
|
+
) => Promise<void>) : ((
|
|
42
|
+
req: Request,
|
|
43
|
+
res: Response & {responseStream: ServerParamEncoder}
|
|
44
|
+
) => void) {
|
|
45
|
+
return (
|
|
46
|
+
req: Request,
|
|
47
|
+
res: Response & {responseStream: ServerParamEncoder}
|
|
48
|
+
) => {
|
|
49
|
+
(async () => {
|
|
50
|
+
try {
|
|
51
|
+
await func(req, res);
|
|
52
|
+
} catch (e) {
|
|
53
|
+
expressHandlerWrapperLogger.error("Error in called function "+req.path+": ", e);
|
|
54
|
+
let statusCode = 500;
|
|
55
|
+
const obj: {code: number, msg: string, data?: any} = {
|
|
56
|
+
code: 0,
|
|
57
|
+
msg: "Internal server error"
|
|
58
|
+
};
|
|
59
|
+
if(isDefinedRuntimeError(e)) {
|
|
60
|
+
obj.msg = e.msg;
|
|
61
|
+
obj.code = e.code;
|
|
62
|
+
obj.data = e.data;
|
|
63
|
+
statusCode = 400;
|
|
64
|
+
if(e._httpStatus!=null) statusCode = e._httpStatus;
|
|
65
|
+
}
|
|
66
|
+
if(res.responseStream!=null) {
|
|
67
|
+
if(res.responseStream.getAbortSignal().aborted) return;
|
|
68
|
+
res.responseStream.writeParamsAndEnd(obj).catch(e => null);
|
|
69
|
+
} else {
|
|
70
|
+
res.status(statusCode).json(obj);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
})();
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
export const HEX_REGEX = /[0-9a-fA-F]+/;
|
|
78
|
+
|
|
79
|
+
export function serializeBN(bn: bigint | null): string | null {
|
|
80
|
+
return bn==null ? null : bn.toString(10);
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
export function deserializeBN(str: string | null): bigint | null {
|
|
84
|
+
return str==null ? null : BigInt(str);
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
export function bigIntSorter(a: bigint, b: bigint): -1 | 0 | 1 {
|
|
88
|
+
if(a < b) return -1;
|
|
89
|
+
if(a > b) return 1;
|
|
90
|
+
return 0;
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
/**
|
|
94
|
+
* Creates an abort controller that extends the responseStream's abort signal
|
|
95
|
+
*
|
|
96
|
+
* @param responseStream
|
|
97
|
+
*/
|
|
98
|
+
export function getAbortController(responseStream: ServerParamEncoder): AbortController {
|
|
99
|
+
const abortController = new AbortController();
|
|
100
|
+
if(responseStream==null || responseStream.getAbortSignal==null) return abortController;
|
|
101
|
+
const responseStreamAbortController = responseStream.getAbortSignal();
|
|
102
|
+
responseStreamAbortController.addEventListener("abort", () => abortController.abort(responseStreamAbortController.reason));
|
|
103
|
+
return abortController;
|
|
104
|
+
}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import {RequestSchema, RequestSchemaResult} from "./SchemaVerifier";
|
|
2
|
-
|
|
3
|
-
export interface IParamReader {
|
|
4
|
-
|
|
5
|
-
getParams<T extends RequestSchema>(schema: T): Promise<RequestSchemaResult<T>>;
|
|
6
|
-
getExistingParamsOrNull<T extends RequestSchema>(schema: T): RequestSchemaResult<T>;
|
|
7
|
-
|
|
1
|
+
import {RequestSchema, RequestSchemaResult} from "./SchemaVerifier";
|
|
2
|
+
|
|
3
|
+
export interface IParamReader {
|
|
4
|
+
|
|
5
|
+
getParams<T extends RequestSchema>(schema: T): Promise<RequestSchemaResult<T>>;
|
|
6
|
+
getExistingParamsOrNull<T extends RequestSchema>(schema: T): RequestSchemaResult<T>;
|
|
7
|
+
|
|
8
8
|
}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
|
|
2
|
-
export interface IParamWriter {
|
|
3
|
-
|
|
4
|
-
end(): Promise<void>;
|
|
5
|
-
writeParams(data: any): Promise<void>;
|
|
6
|
-
|
|
7
|
-
}
|
|
8
|
-
|
|
1
|
+
|
|
2
|
+
export interface IParamWriter {
|
|
3
|
+
|
|
4
|
+
end(): Promise<void>;
|
|
5
|
+
writeParams(data: any): Promise<void>;
|
|
6
|
+
|
|
7
|
+
}
|
|
8
|
+
|
|
@@ -1,28 +1,28 @@
|
|
|
1
|
-
import {IParamWriter} from "./IParamWriter";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
export class LegacyParamEncoder implements IParamWriter {
|
|
5
|
-
|
|
6
|
-
private readonly writeFN: (data: Buffer) => Promise<void>;
|
|
7
|
-
private readonly endFN: () => Promise<void>;
|
|
8
|
-
|
|
9
|
-
private obj = {};
|
|
10
|
-
|
|
11
|
-
constructor(write: (data: Buffer) => Promise<void>, end: () => Promise<void>) {
|
|
12
|
-
this.writeFN = write;
|
|
13
|
-
this.endFN = end;
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
writeParams(data: any): Promise<void> {
|
|
17
|
-
for(let key in data) {
|
|
18
|
-
if(this.obj[key]==null) this.obj[key] = data[key];
|
|
19
|
-
}
|
|
20
|
-
return Promise.resolve();
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
async end(): Promise<void> {
|
|
24
|
-
await this.writeFN(Buffer.from(JSON.stringify(this.obj)));
|
|
25
|
-
await this.endFN();
|
|
26
|
-
}
|
|
27
|
-
|
|
1
|
+
import {IParamWriter} from "./IParamWriter";
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
export class LegacyParamEncoder implements IParamWriter {
|
|
5
|
+
|
|
6
|
+
private readonly writeFN: (data: Buffer) => Promise<void>;
|
|
7
|
+
private readonly endFN: () => Promise<void>;
|
|
8
|
+
|
|
9
|
+
private obj = {};
|
|
10
|
+
|
|
11
|
+
constructor(write: (data: Buffer) => Promise<void>, end: () => Promise<void>) {
|
|
12
|
+
this.writeFN = write;
|
|
13
|
+
this.endFN = end;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
writeParams(data: any): Promise<void> {
|
|
17
|
+
for(let key in data) {
|
|
18
|
+
if(this.obj[key]==null) this.obj[key] = data[key];
|
|
19
|
+
}
|
|
20
|
+
return Promise.resolve();
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
async end(): Promise<void> {
|
|
24
|
+
await this.writeFN(Buffer.from(JSON.stringify(this.obj)));
|
|
25
|
+
await this.endFN();
|
|
26
|
+
}
|
|
27
|
+
|
|
28
28
|
}
|