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