@atomiqlabs/lp-lib 14.0.0-dev.13 → 14.0.0-dev.16
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 -172
- 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 +104 -104
- package/dist/swaps/escrow/frombtcln_autoinit/FromBtcLnAuto.js +659 -659
- 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 +861 -861
- package/dist/swaps/escrow/tobtcln_abstract/ToBtcLnSwapAbs.d.ts +23 -23
- package/dist/swaps/escrow/tobtcln_abstract/ToBtcLnSwapAbs.js +56 -56
- package/dist/swaps/spv_vault_swap/SpvVault.d.ts +41 -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 +491 -491
- package/dist/swaps/spv_vault_swap/SpvVaults.d.ts +52 -52
- package/dist/swaps/spv_vault_swap/SpvVaults.js +364 -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/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 -238
- 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 +822 -822
- 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 +1110 -1110
- package/src/swaps/escrow/tobtcln_abstract/ToBtcLnSwapAbs.ts +77 -77
- 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 +627 -627
- package/src/swaps/spv_vault_swap/SpvVaults.ts +435 -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/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,84 +1,84 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.verifySchema = exports.FieldTypeEnum = exports.parseBigInt = void 0;
|
|
4
|
-
function parseBigInt(str) {
|
|
5
|
-
if (str == null)
|
|
6
|
-
return null;
|
|
7
|
-
if (typeof (str) !== "string" && typeof (str) !== "number")
|
|
8
|
-
return null;
|
|
9
|
-
try {
|
|
10
|
-
return BigInt(str);
|
|
11
|
-
}
|
|
12
|
-
catch (e) {
|
|
13
|
-
return null;
|
|
14
|
-
}
|
|
15
|
-
}
|
|
16
|
-
exports.parseBigInt = parseBigInt;
|
|
17
|
-
var FieldTypeEnum;
|
|
18
|
-
(function (FieldTypeEnum) {
|
|
19
|
-
FieldTypeEnum[FieldTypeEnum["String"] = 0] = "String";
|
|
20
|
-
FieldTypeEnum[FieldTypeEnum["Boolean"] = 1] = "Boolean";
|
|
21
|
-
FieldTypeEnum[FieldTypeEnum["Number"] = 2] = "Number";
|
|
22
|
-
FieldTypeEnum[FieldTypeEnum["BigInt"] = 3] = "BigInt";
|
|
23
|
-
FieldTypeEnum[FieldTypeEnum["Any"] = 4] = "Any";
|
|
24
|
-
FieldTypeEnum[FieldTypeEnum["StringOptional"] = 100] = "StringOptional";
|
|
25
|
-
FieldTypeEnum[FieldTypeEnum["BooleanOptional"] = 101] = "BooleanOptional";
|
|
26
|
-
FieldTypeEnum[FieldTypeEnum["NumberOptional"] = 102] = "NumberOptional";
|
|
27
|
-
FieldTypeEnum[FieldTypeEnum["BigIntOptional"] = 103] = "BigIntOptional";
|
|
28
|
-
FieldTypeEnum[FieldTypeEnum["AnyOptional"] = 104] = "AnyOptional";
|
|
29
|
-
})(FieldTypeEnum = exports.FieldTypeEnum || (exports.FieldTypeEnum = {}));
|
|
30
|
-
function verifySchema(req, schema) {
|
|
31
|
-
if (req == null)
|
|
32
|
-
return null;
|
|
33
|
-
const resultSchema = {};
|
|
34
|
-
for (let fieldName in schema) {
|
|
35
|
-
const val = req[fieldName];
|
|
36
|
-
const type = schema[fieldName];
|
|
37
|
-
if (typeof (type) === "function") {
|
|
38
|
-
const result = type(val);
|
|
39
|
-
if (result == null)
|
|
40
|
-
return null;
|
|
41
|
-
resultSchema[fieldName] = result;
|
|
42
|
-
continue;
|
|
43
|
-
}
|
|
44
|
-
if (val == null && type >= 100) {
|
|
45
|
-
resultSchema[fieldName] = null;
|
|
46
|
-
continue;
|
|
47
|
-
}
|
|
48
|
-
if (type === FieldTypeEnum.Any || type === FieldTypeEnum.AnyOptional) {
|
|
49
|
-
resultSchema[fieldName] = val;
|
|
50
|
-
}
|
|
51
|
-
else if (type === FieldTypeEnum.Boolean || type === FieldTypeEnum.BooleanOptional) {
|
|
52
|
-
if (typeof (val) !== "boolean")
|
|
53
|
-
return null;
|
|
54
|
-
resultSchema[fieldName] = val;
|
|
55
|
-
}
|
|
56
|
-
else if (type === FieldTypeEnum.Number || type === FieldTypeEnum.NumberOptional) {
|
|
57
|
-
if (typeof (val) !== "number")
|
|
58
|
-
return null;
|
|
59
|
-
if (isNaN(val))
|
|
60
|
-
return null;
|
|
61
|
-
resultSchema[fieldName] = val;
|
|
62
|
-
}
|
|
63
|
-
else if (type === FieldTypeEnum.BigInt || type === FieldTypeEnum.BigIntOptional) {
|
|
64
|
-
const result = parseBigInt(val);
|
|
65
|
-
if (result == null)
|
|
66
|
-
return null;
|
|
67
|
-
resultSchema[fieldName] = result;
|
|
68
|
-
}
|
|
69
|
-
else if (type === FieldTypeEnum.String || type === FieldTypeEnum.StringOptional) {
|
|
70
|
-
if (typeof (val) !== "string")
|
|
71
|
-
return null;
|
|
72
|
-
resultSchema[fieldName] = val;
|
|
73
|
-
}
|
|
74
|
-
else {
|
|
75
|
-
//Probably another request schema
|
|
76
|
-
const result = verifySchema(val, type);
|
|
77
|
-
if (result == null)
|
|
78
|
-
return null;
|
|
79
|
-
resultSchema[fieldName] = result;
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
return resultSchema;
|
|
83
|
-
}
|
|
84
|
-
exports.verifySchema = verifySchema;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.verifySchema = exports.FieldTypeEnum = exports.parseBigInt = void 0;
|
|
4
|
+
function parseBigInt(str) {
|
|
5
|
+
if (str == null)
|
|
6
|
+
return null;
|
|
7
|
+
if (typeof (str) !== "string" && typeof (str) !== "number")
|
|
8
|
+
return null;
|
|
9
|
+
try {
|
|
10
|
+
return BigInt(str);
|
|
11
|
+
}
|
|
12
|
+
catch (e) {
|
|
13
|
+
return null;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
exports.parseBigInt = parseBigInt;
|
|
17
|
+
var FieldTypeEnum;
|
|
18
|
+
(function (FieldTypeEnum) {
|
|
19
|
+
FieldTypeEnum[FieldTypeEnum["String"] = 0] = "String";
|
|
20
|
+
FieldTypeEnum[FieldTypeEnum["Boolean"] = 1] = "Boolean";
|
|
21
|
+
FieldTypeEnum[FieldTypeEnum["Number"] = 2] = "Number";
|
|
22
|
+
FieldTypeEnum[FieldTypeEnum["BigInt"] = 3] = "BigInt";
|
|
23
|
+
FieldTypeEnum[FieldTypeEnum["Any"] = 4] = "Any";
|
|
24
|
+
FieldTypeEnum[FieldTypeEnum["StringOptional"] = 100] = "StringOptional";
|
|
25
|
+
FieldTypeEnum[FieldTypeEnum["BooleanOptional"] = 101] = "BooleanOptional";
|
|
26
|
+
FieldTypeEnum[FieldTypeEnum["NumberOptional"] = 102] = "NumberOptional";
|
|
27
|
+
FieldTypeEnum[FieldTypeEnum["BigIntOptional"] = 103] = "BigIntOptional";
|
|
28
|
+
FieldTypeEnum[FieldTypeEnum["AnyOptional"] = 104] = "AnyOptional";
|
|
29
|
+
})(FieldTypeEnum = exports.FieldTypeEnum || (exports.FieldTypeEnum = {}));
|
|
30
|
+
function verifySchema(req, schema) {
|
|
31
|
+
if (req == null)
|
|
32
|
+
return null;
|
|
33
|
+
const resultSchema = {};
|
|
34
|
+
for (let fieldName in schema) {
|
|
35
|
+
const val = req[fieldName];
|
|
36
|
+
const type = schema[fieldName];
|
|
37
|
+
if (typeof (type) === "function") {
|
|
38
|
+
const result = type(val);
|
|
39
|
+
if (result == null)
|
|
40
|
+
return null;
|
|
41
|
+
resultSchema[fieldName] = result;
|
|
42
|
+
continue;
|
|
43
|
+
}
|
|
44
|
+
if (val == null && type >= 100) {
|
|
45
|
+
resultSchema[fieldName] = null;
|
|
46
|
+
continue;
|
|
47
|
+
}
|
|
48
|
+
if (type === FieldTypeEnum.Any || type === FieldTypeEnum.AnyOptional) {
|
|
49
|
+
resultSchema[fieldName] = val;
|
|
50
|
+
}
|
|
51
|
+
else if (type === FieldTypeEnum.Boolean || type === FieldTypeEnum.BooleanOptional) {
|
|
52
|
+
if (typeof (val) !== "boolean")
|
|
53
|
+
return null;
|
|
54
|
+
resultSchema[fieldName] = val;
|
|
55
|
+
}
|
|
56
|
+
else if (type === FieldTypeEnum.Number || type === FieldTypeEnum.NumberOptional) {
|
|
57
|
+
if (typeof (val) !== "number")
|
|
58
|
+
return null;
|
|
59
|
+
if (isNaN(val))
|
|
60
|
+
return null;
|
|
61
|
+
resultSchema[fieldName] = val;
|
|
62
|
+
}
|
|
63
|
+
else if (type === FieldTypeEnum.BigInt || type === FieldTypeEnum.BigIntOptional) {
|
|
64
|
+
const result = parseBigInt(val);
|
|
65
|
+
if (result == null)
|
|
66
|
+
return null;
|
|
67
|
+
resultSchema[fieldName] = result;
|
|
68
|
+
}
|
|
69
|
+
else if (type === FieldTypeEnum.String || type === FieldTypeEnum.StringOptional) {
|
|
70
|
+
if (typeof (val) !== "string")
|
|
71
|
+
return null;
|
|
72
|
+
resultSchema[fieldName] = val;
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
//Probably another request schema
|
|
76
|
+
const result = verifySchema(val, type);
|
|
77
|
+
if (result == null)
|
|
78
|
+
return null;
|
|
79
|
+
resultSchema[fieldName] = result;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
return resultSchema;
|
|
83
|
+
}
|
|
84
|
+
exports.verifySchema = verifySchema;
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { Request, Response } from "express";
|
|
2
|
-
export declare class RequestTimeoutError extends Error {
|
|
3
|
-
constructor();
|
|
4
|
-
}
|
|
5
|
-
export declare class RequestParsingError extends Error {
|
|
6
|
-
constructor();
|
|
7
|
-
}
|
|
8
|
-
export declare const serverParamDecoder: (timeoutMillis: number) => (req: Request, res: Response, next: () => void) => void;
|
|
1
|
+
import { Request, Response } from "express";
|
|
2
|
+
export declare class RequestTimeoutError extends Error {
|
|
3
|
+
constructor();
|
|
4
|
+
}
|
|
5
|
+
export declare class RequestParsingError extends Error {
|
|
6
|
+
constructor();
|
|
7
|
+
}
|
|
8
|
+
export declare const serverParamDecoder: (timeoutMillis: number) => (req: Request, res: Response, next: () => void) => void;
|
|
@@ -1,107 +1,107 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.serverParamDecoder = exports.RequestParsingError = exports.RequestTimeoutError = void 0;
|
|
4
|
-
const SchemaVerifier_1 = require("../SchemaVerifier");
|
|
5
|
-
const ParamDecoder_1 = require("../ParamDecoder");
|
|
6
|
-
const ServerParamEncoder_1 = require("./ServerParamEncoder");
|
|
7
|
-
const Utils_1 = require("../../Utils");
|
|
8
|
-
class RequestTimeoutError extends Error {
|
|
9
|
-
constructor() {
|
|
10
|
-
super("Request timed out");
|
|
11
|
-
// Set the prototype explicitly.
|
|
12
|
-
Object.setPrototypeOf(this, RequestTimeoutError.prototype);
|
|
13
|
-
}
|
|
14
|
-
}
|
|
15
|
-
exports.RequestTimeoutError = RequestTimeoutError;
|
|
16
|
-
class RequestParsingError extends Error {
|
|
17
|
-
constructor() {
|
|
18
|
-
super("Request cannot be parsed");
|
|
19
|
-
// Set the prototype explicitly.
|
|
20
|
-
Object.setPrototypeOf(this, RequestParsingError.prototype);
|
|
21
|
-
}
|
|
22
|
-
}
|
|
23
|
-
exports.RequestParsingError = RequestParsingError;
|
|
24
|
-
const logger = (0, Utils_1.getLogger)("ServerParamDecoder: ");
|
|
25
|
-
const serverParamDecoder = (timeoutMillis) => (req, res, next) => {
|
|
26
|
-
let timeout;
|
|
27
|
-
res.responseStream = new ServerParamEncoder_1.ServerParamEncoder(res, 200, req);
|
|
28
|
-
if (req.headers['content-type'] !== "application/x-multiple-json") {
|
|
29
|
-
const dataBuffers = [];
|
|
30
|
-
req.on("data", (data) => {
|
|
31
|
-
dataBuffers.push(data);
|
|
32
|
-
});
|
|
33
|
-
req.on("end", () => {
|
|
34
|
-
try {
|
|
35
|
-
const body = dataBuffers.length === 0 ? {} : JSON.parse(Buffer.concat(dataBuffers).toString());
|
|
36
|
-
const paramReader = {
|
|
37
|
-
getParams: (schema) => {
|
|
38
|
-
return Promise.resolve((0, SchemaVerifier_1.verifySchema)(body, schema));
|
|
39
|
-
},
|
|
40
|
-
getExistingParamsOrNull: (schema) => {
|
|
41
|
-
return (0, SchemaVerifier_1.verifySchema)(body, schema);
|
|
42
|
-
}
|
|
43
|
-
};
|
|
44
|
-
req.paramReader = paramReader;
|
|
45
|
-
next();
|
|
46
|
-
}
|
|
47
|
-
catch (e) {
|
|
48
|
-
logger.error("error reading legacy (non-streaming) http request", e);
|
|
49
|
-
req.destroy(new RequestParsingError());
|
|
50
|
-
res.destroy(new RequestParsingError());
|
|
51
|
-
}
|
|
52
|
-
clearTimeout(timeout);
|
|
53
|
-
});
|
|
54
|
-
req.on("error", (e) => {
|
|
55
|
-
logger.error("error reading legacy (non-streaming) http request", e);
|
|
56
|
-
});
|
|
57
|
-
timeout = setTimeout(() => {
|
|
58
|
-
req.destroy(new RequestTimeoutError());
|
|
59
|
-
res.destroy(new RequestTimeoutError());
|
|
60
|
-
}, timeoutMillis);
|
|
61
|
-
return;
|
|
62
|
-
}
|
|
63
|
-
const decoder = new ParamDecoder_1.ParamDecoder();
|
|
64
|
-
req.on("data", (data) => {
|
|
65
|
-
try {
|
|
66
|
-
decoder.onData(data);
|
|
67
|
-
}
|
|
68
|
-
catch (e) {
|
|
69
|
-
logger.error("error reading streaming http request: on(\"data\")", e);
|
|
70
|
-
req.destroy(new RequestParsingError());
|
|
71
|
-
res.destroy(new RequestParsingError());
|
|
72
|
-
}
|
|
73
|
-
});
|
|
74
|
-
req.on("end", () => {
|
|
75
|
-
try {
|
|
76
|
-
decoder.onEnd();
|
|
77
|
-
}
|
|
78
|
-
catch (e) {
|
|
79
|
-
logger.error("error reading streaming http request: on(\"end\")", e);
|
|
80
|
-
req.destroy(new RequestParsingError());
|
|
81
|
-
res.destroy(new RequestParsingError());
|
|
82
|
-
}
|
|
83
|
-
clearTimeout(timeout);
|
|
84
|
-
});
|
|
85
|
-
req.on("error", (e) => {
|
|
86
|
-
try {
|
|
87
|
-
decoder.onError(e);
|
|
88
|
-
}
|
|
89
|
-
catch (e) {
|
|
90
|
-
logger.error("error reading streaming http request: on(\"error\")", e);
|
|
91
|
-
}
|
|
92
|
-
});
|
|
93
|
-
timeout = setTimeout(() => {
|
|
94
|
-
try {
|
|
95
|
-
decoder.onEnd();
|
|
96
|
-
}
|
|
97
|
-
catch (e) {
|
|
98
|
-
logger.error("error reading streaming http request: timeout", e);
|
|
99
|
-
}
|
|
100
|
-
req.destroy(new RequestTimeoutError());
|
|
101
|
-
res.destroy(new RequestTimeoutError());
|
|
102
|
-
}, timeoutMillis);
|
|
103
|
-
req.paramReader = decoder;
|
|
104
|
-
next();
|
|
105
|
-
return;
|
|
106
|
-
};
|
|
107
|
-
exports.serverParamDecoder = serverParamDecoder;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.serverParamDecoder = exports.RequestParsingError = exports.RequestTimeoutError = void 0;
|
|
4
|
+
const SchemaVerifier_1 = require("../SchemaVerifier");
|
|
5
|
+
const ParamDecoder_1 = require("../ParamDecoder");
|
|
6
|
+
const ServerParamEncoder_1 = require("./ServerParamEncoder");
|
|
7
|
+
const Utils_1 = require("../../Utils");
|
|
8
|
+
class RequestTimeoutError extends Error {
|
|
9
|
+
constructor() {
|
|
10
|
+
super("Request timed out");
|
|
11
|
+
// Set the prototype explicitly.
|
|
12
|
+
Object.setPrototypeOf(this, RequestTimeoutError.prototype);
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
exports.RequestTimeoutError = RequestTimeoutError;
|
|
16
|
+
class RequestParsingError extends Error {
|
|
17
|
+
constructor() {
|
|
18
|
+
super("Request cannot be parsed");
|
|
19
|
+
// Set the prototype explicitly.
|
|
20
|
+
Object.setPrototypeOf(this, RequestParsingError.prototype);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
exports.RequestParsingError = RequestParsingError;
|
|
24
|
+
const logger = (0, Utils_1.getLogger)("ServerParamDecoder: ");
|
|
25
|
+
const serverParamDecoder = (timeoutMillis) => (req, res, next) => {
|
|
26
|
+
let timeout;
|
|
27
|
+
res.responseStream = new ServerParamEncoder_1.ServerParamEncoder(res, 200, req);
|
|
28
|
+
if (req.headers['content-type'] !== "application/x-multiple-json") {
|
|
29
|
+
const dataBuffers = [];
|
|
30
|
+
req.on("data", (data) => {
|
|
31
|
+
dataBuffers.push(data);
|
|
32
|
+
});
|
|
33
|
+
req.on("end", () => {
|
|
34
|
+
try {
|
|
35
|
+
const body = dataBuffers.length === 0 ? {} : JSON.parse(Buffer.concat(dataBuffers).toString());
|
|
36
|
+
const paramReader = {
|
|
37
|
+
getParams: (schema) => {
|
|
38
|
+
return Promise.resolve((0, SchemaVerifier_1.verifySchema)(body, schema));
|
|
39
|
+
},
|
|
40
|
+
getExistingParamsOrNull: (schema) => {
|
|
41
|
+
return (0, SchemaVerifier_1.verifySchema)(body, schema);
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
req.paramReader = paramReader;
|
|
45
|
+
next();
|
|
46
|
+
}
|
|
47
|
+
catch (e) {
|
|
48
|
+
logger.error("error reading legacy (non-streaming) http request", e);
|
|
49
|
+
req.destroy(new RequestParsingError());
|
|
50
|
+
res.destroy(new RequestParsingError());
|
|
51
|
+
}
|
|
52
|
+
clearTimeout(timeout);
|
|
53
|
+
});
|
|
54
|
+
req.on("error", (e) => {
|
|
55
|
+
logger.error("error reading legacy (non-streaming) http request", e);
|
|
56
|
+
});
|
|
57
|
+
timeout = setTimeout(() => {
|
|
58
|
+
req.destroy(new RequestTimeoutError());
|
|
59
|
+
res.destroy(new RequestTimeoutError());
|
|
60
|
+
}, timeoutMillis);
|
|
61
|
+
return;
|
|
62
|
+
}
|
|
63
|
+
const decoder = new ParamDecoder_1.ParamDecoder();
|
|
64
|
+
req.on("data", (data) => {
|
|
65
|
+
try {
|
|
66
|
+
decoder.onData(data);
|
|
67
|
+
}
|
|
68
|
+
catch (e) {
|
|
69
|
+
logger.error("error reading streaming http request: on(\"data\")", e);
|
|
70
|
+
req.destroy(new RequestParsingError());
|
|
71
|
+
res.destroy(new RequestParsingError());
|
|
72
|
+
}
|
|
73
|
+
});
|
|
74
|
+
req.on("end", () => {
|
|
75
|
+
try {
|
|
76
|
+
decoder.onEnd();
|
|
77
|
+
}
|
|
78
|
+
catch (e) {
|
|
79
|
+
logger.error("error reading streaming http request: on(\"end\")", e);
|
|
80
|
+
req.destroy(new RequestParsingError());
|
|
81
|
+
res.destroy(new RequestParsingError());
|
|
82
|
+
}
|
|
83
|
+
clearTimeout(timeout);
|
|
84
|
+
});
|
|
85
|
+
req.on("error", (e) => {
|
|
86
|
+
try {
|
|
87
|
+
decoder.onError(e);
|
|
88
|
+
}
|
|
89
|
+
catch (e) {
|
|
90
|
+
logger.error("error reading streaming http request: on(\"error\")", e);
|
|
91
|
+
}
|
|
92
|
+
});
|
|
93
|
+
timeout = setTimeout(() => {
|
|
94
|
+
try {
|
|
95
|
+
decoder.onEnd();
|
|
96
|
+
}
|
|
97
|
+
catch (e) {
|
|
98
|
+
logger.error("error reading streaming http request: timeout", e);
|
|
99
|
+
}
|
|
100
|
+
req.destroy(new RequestTimeoutError());
|
|
101
|
+
res.destroy(new RequestTimeoutError());
|
|
102
|
+
}, timeoutMillis);
|
|
103
|
+
req.paramReader = decoder;
|
|
104
|
+
next();
|
|
105
|
+
return;
|
|
106
|
+
};
|
|
107
|
+
exports.serverParamDecoder = serverParamDecoder;
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
import { Response, Request } from "express";
|
|
2
|
-
export declare class ServerParamEncoder {
|
|
3
|
-
private response;
|
|
4
|
-
private controller;
|
|
5
|
-
private paramWriter;
|
|
6
|
-
constructor(response: Response, statusCode: number, request: Request);
|
|
7
|
-
writeParams(params: any): Promise<void>;
|
|
8
|
-
end(): Promise<void>;
|
|
9
|
-
writeParamsAndEnd(params: any): Promise<void>;
|
|
10
|
-
getAbortSignal(): AbortSignal;
|
|
11
|
-
}
|
|
1
|
+
import { Response, Request } from "express";
|
|
2
|
+
export declare class ServerParamEncoder {
|
|
3
|
+
private response;
|
|
4
|
+
private controller;
|
|
5
|
+
private paramWriter;
|
|
6
|
+
constructor(response: Response, statusCode: number, request: Request);
|
|
7
|
+
writeParams(params: any): Promise<void>;
|
|
8
|
+
end(): Promise<void>;
|
|
9
|
+
writeParamsAndEnd(params: any): Promise<void>;
|
|
10
|
+
getAbortSignal(): AbortSignal;
|
|
11
|
+
}
|
|
@@ -1,65 +1,65 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.ServerParamEncoder = void 0;
|
|
4
|
-
const ParamEncoder_1 = require("../ParamEncoder");
|
|
5
|
-
const LegacyParamEncoder_1 = require("../LegacyParamEncoder");
|
|
6
|
-
class ServerParamEncoder {
|
|
7
|
-
constructor(response, statusCode, request) {
|
|
8
|
-
const legacy = !request.headers['accept'].includes("application/x-multiple-json");
|
|
9
|
-
let requestEnd = false;
|
|
10
|
-
let responseShouldEnd = false;
|
|
11
|
-
request.on("end", () => {
|
|
12
|
-
requestEnd = true;
|
|
13
|
-
if (responseShouldEnd && requestEnd)
|
|
14
|
-
response.end();
|
|
15
|
-
});
|
|
16
|
-
const onEnd = () => {
|
|
17
|
-
responseShouldEnd = true;
|
|
18
|
-
if (responseShouldEnd && requestEnd)
|
|
19
|
-
return new Promise(resolve => response.end(() => resolve()));
|
|
20
|
-
return Promise.resolve();
|
|
21
|
-
};
|
|
22
|
-
const onWrite = (data) => {
|
|
23
|
-
if (responseShouldEnd)
|
|
24
|
-
return Promise.resolve();
|
|
25
|
-
if (firstWrite) {
|
|
26
|
-
response.writeHead(statusCode);
|
|
27
|
-
firstWrite = false;
|
|
28
|
-
}
|
|
29
|
-
return new Promise((resolve, reject) => response.write(data, (error) => {
|
|
30
|
-
if (error != null) {
|
|
31
|
-
reject(error);
|
|
32
|
-
return;
|
|
33
|
-
}
|
|
34
|
-
resolve();
|
|
35
|
-
}));
|
|
36
|
-
};
|
|
37
|
-
let firstWrite = false;
|
|
38
|
-
if (legacy) {
|
|
39
|
-
response.header("Content-Type", "application/json");
|
|
40
|
-
this.paramWriter = new LegacyParamEncoder_1.LegacyParamEncoder(onWrite, onEnd);
|
|
41
|
-
}
|
|
42
|
-
else {
|
|
43
|
-
response.header("Content-Type", "application/x-multiple-json");
|
|
44
|
-
this.paramWriter = new ParamEncoder_1.ParamEncoder(onWrite, onEnd);
|
|
45
|
-
}
|
|
46
|
-
this.response = response;
|
|
47
|
-
this.controller = new AbortController();
|
|
48
|
-
this.response.on("close", () => this.controller.abort(new Error("Response stream closed!")));
|
|
49
|
-
this.response.on("error", (err) => this.controller.abort(err));
|
|
50
|
-
}
|
|
51
|
-
writeParams(params) {
|
|
52
|
-
return this.paramWriter.writeParams(params);
|
|
53
|
-
}
|
|
54
|
-
end() {
|
|
55
|
-
return this.paramWriter.end();
|
|
56
|
-
}
|
|
57
|
-
async writeParamsAndEnd(params) {
|
|
58
|
-
await this.writeParams(params);
|
|
59
|
-
await this.end();
|
|
60
|
-
}
|
|
61
|
-
getAbortSignal() {
|
|
62
|
-
return this.controller.signal;
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
exports.ServerParamEncoder = ServerParamEncoder;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ServerParamEncoder = void 0;
|
|
4
|
+
const ParamEncoder_1 = require("../ParamEncoder");
|
|
5
|
+
const LegacyParamEncoder_1 = require("../LegacyParamEncoder");
|
|
6
|
+
class ServerParamEncoder {
|
|
7
|
+
constructor(response, statusCode, request) {
|
|
8
|
+
const legacy = !request.headers['accept'].includes("application/x-multiple-json");
|
|
9
|
+
let requestEnd = false;
|
|
10
|
+
let responseShouldEnd = false;
|
|
11
|
+
request.on("end", () => {
|
|
12
|
+
requestEnd = true;
|
|
13
|
+
if (responseShouldEnd && requestEnd)
|
|
14
|
+
response.end();
|
|
15
|
+
});
|
|
16
|
+
const onEnd = () => {
|
|
17
|
+
responseShouldEnd = true;
|
|
18
|
+
if (responseShouldEnd && requestEnd)
|
|
19
|
+
return new Promise(resolve => response.end(() => resolve()));
|
|
20
|
+
return Promise.resolve();
|
|
21
|
+
};
|
|
22
|
+
const onWrite = (data) => {
|
|
23
|
+
if (responseShouldEnd)
|
|
24
|
+
return Promise.resolve();
|
|
25
|
+
if (firstWrite) {
|
|
26
|
+
response.writeHead(statusCode);
|
|
27
|
+
firstWrite = false;
|
|
28
|
+
}
|
|
29
|
+
return new Promise((resolve, reject) => response.write(data, (error) => {
|
|
30
|
+
if (error != null) {
|
|
31
|
+
reject(error);
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
resolve();
|
|
35
|
+
}));
|
|
36
|
+
};
|
|
37
|
+
let firstWrite = false;
|
|
38
|
+
if (legacy) {
|
|
39
|
+
response.header("Content-Type", "application/json");
|
|
40
|
+
this.paramWriter = new LegacyParamEncoder_1.LegacyParamEncoder(onWrite, onEnd);
|
|
41
|
+
}
|
|
42
|
+
else {
|
|
43
|
+
response.header("Content-Type", "application/x-multiple-json");
|
|
44
|
+
this.paramWriter = new ParamEncoder_1.ParamEncoder(onWrite, onEnd);
|
|
45
|
+
}
|
|
46
|
+
this.response = response;
|
|
47
|
+
this.controller = new AbortController();
|
|
48
|
+
this.response.on("close", () => this.controller.abort(new Error("Response stream closed!")));
|
|
49
|
+
this.response.on("error", (err) => this.controller.abort(err));
|
|
50
|
+
}
|
|
51
|
+
writeParams(params) {
|
|
52
|
+
return this.paramWriter.writeParams(params);
|
|
53
|
+
}
|
|
54
|
+
end() {
|
|
55
|
+
return this.paramWriter.end();
|
|
56
|
+
}
|
|
57
|
+
async writeParamsAndEnd(params) {
|
|
58
|
+
await this.writeParams(params);
|
|
59
|
+
await this.end();
|
|
60
|
+
}
|
|
61
|
+
getAbortSignal() {
|
|
62
|
+
return this.controller.signal;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
exports.ServerParamEncoder = ServerParamEncoder;
|