@atomiqlabs/lp-lib 15.0.5 → 15.0.6
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 +40 -40
- package/dist/index.js +56 -56
- 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 +18 -18
- package/dist/storagemanager/IntermediaryStorageManager.js +104 -104
- package/dist/storagemanager/StorageManager.d.ts +12 -12
- package/dist/storagemanager/StorageManager.js +57 -57
- package/dist/swaps/SwapHandler.d.ts +156 -156
- package/dist/swaps/SwapHandler.js +163 -163
- 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 +172 -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 +101 -101
- package/dist/swaps/escrow/FromBtcBaseSwapHandler.js +207 -207
- 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 +32 -32
- package/dist/swaps/escrow/frombtcln_abstract/FromBtcLnSwapAbs.js +88 -88
- package/dist/swaps/escrow/tobtc_abstract/ToBtcAbs.d.ts +171 -171
- package/dist/swaps/escrow/tobtc_abstract/ToBtcAbs.js +718 -718
- package/dist/swaps/escrow/tobtc_abstract/ToBtcSwapAbs.d.ts +28 -28
- package/dist/swaps/escrow/tobtc_abstract/ToBtcSwapAbs.js +64 -64
- package/dist/swaps/escrow/tobtcln_abstract/ToBtcLnAbs.d.ts +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 +43 -43
- package/dist/swaps/spv_vault_swap/SpvVault.js +111 -111
- package/dist/swaps/spv_vault_swap/SpvVaultSwap.d.ts +68 -68
- package/dist/swaps/spv_vault_swap/SpvVaultSwap.js +158 -158
- package/dist/swaps/spv_vault_swap/SpvVaultSwapHandler.d.ts +68 -68
- package/dist/swaps/spv_vault_swap/SpvVaultSwapHandler.js +517 -517
- package/dist/swaps/spv_vault_swap/SpvVaults.d.ts +61 -61
- package/dist/swaps/spv_vault_swap/SpvVaults.js +372 -372
- 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 +495 -495
- 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 +6 -6
- package/dist/utils/BitcoinUtils.js +75 -75
- package/dist/utils/Utils.d.ts +29 -29
- package/dist/utils/Utils.js +88 -88
- 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 +105 -105
- 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/dist/wallets/ISpvVaultWallet.d.ts +42 -42
- package/dist/wallets/ISpvVaultWallet.js +2 -2
- package/package.json +36 -36
- package/src/fees/IBtcFeeEstimator.ts +6 -6
- package/src/index.ts +51 -51
- 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 +109 -109
- package/src/storagemanager/StorageManager.ts +68 -68
- package/src/swaps/SwapHandler.ts +280 -280
- package/src/swaps/SwapHandlerSwap.ts +141 -141
- package/src/swaps/assertions/AmountAssertions.ts +76 -76
- package/src/swaps/assertions/FromBtcAmountAssertions.ts +238 -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 +283 -283
- 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 +137 -137
- package/src/swaps/escrow/tobtc_abstract/ToBtcAbs.ts +890 -890
- package/src/swaps/escrow/tobtc_abstract/ToBtcSwapAbs.ts +108 -108
- 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 +228 -228
- package/src/swaps/spv_vault_swap/SpvVaultSwapHandler.ts +654 -654
- package/src/swaps/spv_vault_swap/SpvVaults.ts +444 -444
- 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 +592 -592
- package/src/swaps/trusted/frombtcln_trusted/FromBtcLnTrustedSwap.ts +121 -121
- package/src/utils/BitcoinUtils.ts +71 -71
- package/src/utils/Utils.ts +102 -102
- 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 +115 -115
- 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,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
|
}
|
|
@@ -1,219 +1,219 @@
|
|
|
1
|
-
import {FieldTypeEnum, parseBigInt, RequestSchema, RequestSchemaResult, verifySchema} from "./SchemaVerifier";
|
|
2
|
-
import {IParamReader} from "./IParamReader";
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
export class ParamDecoder implements IParamReader {
|
|
6
|
-
|
|
7
|
-
frameHeader: Buffer = null;
|
|
8
|
-
frameData: Buffer[] = [];
|
|
9
|
-
frameDataLength: number = 0;
|
|
10
|
-
|
|
11
|
-
closed: boolean = false;
|
|
12
|
-
|
|
13
|
-
params: {
|
|
14
|
-
[key: string]: {
|
|
15
|
-
promise: Promise<any>,
|
|
16
|
-
resolve: (data: any) => void,
|
|
17
|
-
reject: (err: any) => void,
|
|
18
|
-
value: any
|
|
19
|
-
}
|
|
20
|
-
} = {};
|
|
21
|
-
|
|
22
|
-
constructor() {
|
|
23
|
-
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
private onFrameRead(data: Buffer) {
|
|
27
|
-
const obj = JSON.parse(data.toString());
|
|
28
|
-
for(let key in obj) {
|
|
29
|
-
if(this.params[key]==null) {
|
|
30
|
-
this.params[key] = {
|
|
31
|
-
promise: Promise.resolve(obj[key]),
|
|
32
|
-
resolve: null,
|
|
33
|
-
reject: null,
|
|
34
|
-
value: obj[key]
|
|
35
|
-
};
|
|
36
|
-
} else {
|
|
37
|
-
if(this.params[key].resolve!=null) {
|
|
38
|
-
this.params[key].resolve(obj[key]);
|
|
39
|
-
this.params[key].resolve = null;
|
|
40
|
-
this.params[key].reject = null;
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
onData(data: Buffer): void {
|
|
47
|
-
let leavesBuffer = data;
|
|
48
|
-
while(leavesBuffer!=null && leavesBuffer.length>0) {
|
|
49
|
-
if(this.frameHeader==null) {
|
|
50
|
-
if(leavesBuffer.length<=4) {
|
|
51
|
-
this.frameHeader = leavesBuffer;
|
|
52
|
-
leavesBuffer = null;
|
|
53
|
-
} else {
|
|
54
|
-
this.frameHeader = leavesBuffer.subarray(0, 4);
|
|
55
|
-
leavesBuffer = leavesBuffer.subarray(4);
|
|
56
|
-
}
|
|
57
|
-
} else if(this.frameHeader.length<4) {
|
|
58
|
-
const requiredLen = 4-this.frameHeader.length;
|
|
59
|
-
if(leavesBuffer.length<=requiredLen) {
|
|
60
|
-
this.frameHeader = Buffer.concat([this.frameHeader, leavesBuffer]);
|
|
61
|
-
leavesBuffer = null;
|
|
62
|
-
} else {
|
|
63
|
-
this.frameHeader = Buffer.concat([this.frameHeader, leavesBuffer.subarray(0, requiredLen)]);
|
|
64
|
-
leavesBuffer = leavesBuffer.subarray(requiredLen);
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
if(leavesBuffer==null) continue;
|
|
68
|
-
if(this.frameHeader==null || this.frameHeader.length<4) continue;
|
|
69
|
-
|
|
70
|
-
const frameLength = this.frameHeader.readUint32LE();
|
|
71
|
-
const requiredLen = frameLength-this.frameDataLength;
|
|
72
|
-
|
|
73
|
-
if(leavesBuffer.length<=requiredLen) {
|
|
74
|
-
this.frameData.push(leavesBuffer);
|
|
75
|
-
this.frameDataLength += leavesBuffer.length;
|
|
76
|
-
|
|
77
|
-
leavesBuffer = null;
|
|
78
|
-
} else {
|
|
79
|
-
this.frameData.push(leavesBuffer.subarray(0, requiredLen));
|
|
80
|
-
this.frameDataLength += requiredLen;
|
|
81
|
-
|
|
82
|
-
leavesBuffer = leavesBuffer.subarray(requiredLen);
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
if(frameLength===this.frameDataLength) {
|
|
86
|
-
//Message read success
|
|
87
|
-
this.onFrameRead(Buffer.concat(this.frameData));
|
|
88
|
-
this.frameHeader = null;
|
|
89
|
-
this.frameData = [];
|
|
90
|
-
this.frameDataLength = 0;
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
onEnd(): void {
|
|
96
|
-
for(let key in this.params) {
|
|
97
|
-
if(this.params[key].reject!=null) {
|
|
98
|
-
this.params[key].reject(new Error("EOF before field seen!"));
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
this.closed = true;
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
onError(e: any): void {
|
|
105
|
-
for(let key in this.params) {
|
|
106
|
-
if(this.params[key].reject!=null) {
|
|
107
|
-
this.params[key].reject(e);
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
this.closed = true;
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
getParam(key: string): Promise<any> {
|
|
114
|
-
if(this.params[key]==null) {
|
|
115
|
-
if(this.closed) return Promise.reject(new Error("Stream already closed without param received!"));
|
|
116
|
-
let resolve: (data: any) => void;
|
|
117
|
-
let reject: (err: any) => void;
|
|
118
|
-
const promise = new Promise((_resolve, _reject) => {
|
|
119
|
-
resolve = _resolve
|
|
120
|
-
reject = _reject;
|
|
121
|
-
});
|
|
122
|
-
this.params[key] = {
|
|
123
|
-
resolve,
|
|
124
|
-
reject,
|
|
125
|
-
promise,
|
|
126
|
-
value: null
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
|
-
return this.params[key].promise;
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
async getParams<T extends RequestSchema>(schema: T): Promise<RequestSchemaResult<T>> {
|
|
133
|
-
const resultSchema: any = {};
|
|
134
|
-
for(let fieldName in schema) {
|
|
135
|
-
const val: any = await this.getParam(fieldName);
|
|
136
|
-
const type: FieldTypeEnum | RequestSchema | ((val: any) => boolean) = schema[fieldName];
|
|
137
|
-
if(typeof(type)==="function") {
|
|
138
|
-
const result = type(val);
|
|
139
|
-
if(result==null) return null;
|
|
140
|
-
resultSchema[fieldName] = result;
|
|
141
|
-
continue;
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
if(val==null && (type as number)>=100) {
|
|
145
|
-
resultSchema[fieldName] = null;
|
|
146
|
-
continue;
|
|
147
|
-
}
|
|
148
|
-
|
|
149
|
-
if(type===FieldTypeEnum.Any || type===FieldTypeEnum.AnyOptional) {
|
|
150
|
-
resultSchema[fieldName] = val;
|
|
151
|
-
} else if(type===FieldTypeEnum.Boolean || type===FieldTypeEnum.BooleanOptional) {
|
|
152
|
-
if(typeof(val)!=="boolean") return null;
|
|
153
|
-
resultSchema[fieldName] = val;
|
|
154
|
-
} else if(type===FieldTypeEnum.Number || type===FieldTypeEnum.NumberOptional) {
|
|
155
|
-
if(typeof(val)!=="number") return null;
|
|
156
|
-
if(isNaN(val as number)) return null;
|
|
157
|
-
resultSchema[fieldName] = val;
|
|
158
|
-
} else if(type===FieldTypeEnum.BigInt || type===FieldTypeEnum.BigIntOptional) {
|
|
159
|
-
const result = parseBigInt(val);
|
|
160
|
-
if(result==null) return null;
|
|
161
|
-
resultSchema[fieldName] = result;
|
|
162
|
-
} else if(type===FieldTypeEnum.String || type===FieldTypeEnum.StringOptional) {
|
|
163
|
-
if(typeof(val)!=="string") return null;
|
|
164
|
-
resultSchema[fieldName] = val;
|
|
165
|
-
} else {
|
|
166
|
-
//Probably another request schema
|
|
167
|
-
const result = verifySchema(val, type as RequestSchema);
|
|
168
|
-
if(result==null) return null;
|
|
169
|
-
resultSchema[fieldName] = result;
|
|
170
|
-
}
|
|
171
|
-
}
|
|
172
|
-
return resultSchema;
|
|
173
|
-
}
|
|
174
|
-
|
|
175
|
-
getExistingParamsOrNull<T extends RequestSchema>(schema: T): RequestSchemaResult<T> {
|
|
176
|
-
const resultSchema: any = {};
|
|
177
|
-
for(let fieldName in schema) {
|
|
178
|
-
const val: any = this.params[fieldName]?.value;
|
|
179
|
-
|
|
180
|
-
if(val==null) {
|
|
181
|
-
resultSchema[fieldName] = null;
|
|
182
|
-
continue;
|
|
183
|
-
}
|
|
184
|
-
|
|
185
|
-
const type: FieldTypeEnum | RequestSchema | ((val: any) => boolean) = schema[fieldName];
|
|
186
|
-
if(typeof(type)==="function") {
|
|
187
|
-
const result = type(val);
|
|
188
|
-
if(result==null) return null;
|
|
189
|
-
resultSchema[fieldName] = result;
|
|
190
|
-
continue;
|
|
191
|
-
}
|
|
192
|
-
|
|
193
|
-
if(type===FieldTypeEnum.Any || type===FieldTypeEnum.AnyOptional) {
|
|
194
|
-
resultSchema[fieldName] = val;
|
|
195
|
-
} else if(type===FieldTypeEnum.Boolean || type===FieldTypeEnum.BooleanOptional) {
|
|
196
|
-
if(typeof(val)!=="boolean") return null;
|
|
197
|
-
resultSchema[fieldName] = val;
|
|
198
|
-
} else if(type===FieldTypeEnum.Number || type===FieldTypeEnum.NumberOptional) {
|
|
199
|
-
if(typeof(val)!=="number") return null;
|
|
200
|
-
if(isNaN(val as number)) return null;
|
|
201
|
-
resultSchema[fieldName] = val;
|
|
202
|
-
} else if(type===FieldTypeEnum.BigInt || type===FieldTypeEnum.BigIntOptional) {
|
|
203
|
-
const result = parseBigInt(val);
|
|
204
|
-
if(result==null) return null;
|
|
205
|
-
resultSchema[fieldName] = result;
|
|
206
|
-
} else if(type===FieldTypeEnum.String || type===FieldTypeEnum.StringOptional) {
|
|
207
|
-
if(typeof(val)!=="string") return null;
|
|
208
|
-
resultSchema[fieldName] = val;
|
|
209
|
-
} else {
|
|
210
|
-
//Probably another request schema
|
|
211
|
-
const result = verifySchema(val, type as RequestSchema);
|
|
212
|
-
if(result==null) return null;
|
|
213
|
-
resultSchema[fieldName] = result;
|
|
214
|
-
}
|
|
215
|
-
}
|
|
216
|
-
return resultSchema;
|
|
217
|
-
}
|
|
218
|
-
|
|
1
|
+
import {FieldTypeEnum, parseBigInt, RequestSchema, RequestSchemaResult, verifySchema} from "./SchemaVerifier";
|
|
2
|
+
import {IParamReader} from "./IParamReader";
|
|
3
|
+
|
|
4
|
+
|
|
5
|
+
export class ParamDecoder implements IParamReader {
|
|
6
|
+
|
|
7
|
+
frameHeader: Buffer = null;
|
|
8
|
+
frameData: Buffer[] = [];
|
|
9
|
+
frameDataLength: number = 0;
|
|
10
|
+
|
|
11
|
+
closed: boolean = false;
|
|
12
|
+
|
|
13
|
+
params: {
|
|
14
|
+
[key: string]: {
|
|
15
|
+
promise: Promise<any>,
|
|
16
|
+
resolve: (data: any) => void,
|
|
17
|
+
reject: (err: any) => void,
|
|
18
|
+
value: any
|
|
19
|
+
}
|
|
20
|
+
} = {};
|
|
21
|
+
|
|
22
|
+
constructor() {
|
|
23
|
+
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
private onFrameRead(data: Buffer) {
|
|
27
|
+
const obj = JSON.parse(data.toString());
|
|
28
|
+
for(let key in obj) {
|
|
29
|
+
if(this.params[key]==null) {
|
|
30
|
+
this.params[key] = {
|
|
31
|
+
promise: Promise.resolve(obj[key]),
|
|
32
|
+
resolve: null,
|
|
33
|
+
reject: null,
|
|
34
|
+
value: obj[key]
|
|
35
|
+
};
|
|
36
|
+
} else {
|
|
37
|
+
if(this.params[key].resolve!=null) {
|
|
38
|
+
this.params[key].resolve(obj[key]);
|
|
39
|
+
this.params[key].resolve = null;
|
|
40
|
+
this.params[key].reject = null;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
onData(data: Buffer): void {
|
|
47
|
+
let leavesBuffer = data;
|
|
48
|
+
while(leavesBuffer!=null && leavesBuffer.length>0) {
|
|
49
|
+
if(this.frameHeader==null) {
|
|
50
|
+
if(leavesBuffer.length<=4) {
|
|
51
|
+
this.frameHeader = leavesBuffer;
|
|
52
|
+
leavesBuffer = null;
|
|
53
|
+
} else {
|
|
54
|
+
this.frameHeader = leavesBuffer.subarray(0, 4);
|
|
55
|
+
leavesBuffer = leavesBuffer.subarray(4);
|
|
56
|
+
}
|
|
57
|
+
} else if(this.frameHeader.length<4) {
|
|
58
|
+
const requiredLen = 4-this.frameHeader.length;
|
|
59
|
+
if(leavesBuffer.length<=requiredLen) {
|
|
60
|
+
this.frameHeader = Buffer.concat([this.frameHeader, leavesBuffer]);
|
|
61
|
+
leavesBuffer = null;
|
|
62
|
+
} else {
|
|
63
|
+
this.frameHeader = Buffer.concat([this.frameHeader, leavesBuffer.subarray(0, requiredLen)]);
|
|
64
|
+
leavesBuffer = leavesBuffer.subarray(requiredLen);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
if(leavesBuffer==null) continue;
|
|
68
|
+
if(this.frameHeader==null || this.frameHeader.length<4) continue;
|
|
69
|
+
|
|
70
|
+
const frameLength = this.frameHeader.readUint32LE();
|
|
71
|
+
const requiredLen = frameLength-this.frameDataLength;
|
|
72
|
+
|
|
73
|
+
if(leavesBuffer.length<=requiredLen) {
|
|
74
|
+
this.frameData.push(leavesBuffer);
|
|
75
|
+
this.frameDataLength += leavesBuffer.length;
|
|
76
|
+
|
|
77
|
+
leavesBuffer = null;
|
|
78
|
+
} else {
|
|
79
|
+
this.frameData.push(leavesBuffer.subarray(0, requiredLen));
|
|
80
|
+
this.frameDataLength += requiredLen;
|
|
81
|
+
|
|
82
|
+
leavesBuffer = leavesBuffer.subarray(requiredLen);
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
if(frameLength===this.frameDataLength) {
|
|
86
|
+
//Message read success
|
|
87
|
+
this.onFrameRead(Buffer.concat(this.frameData));
|
|
88
|
+
this.frameHeader = null;
|
|
89
|
+
this.frameData = [];
|
|
90
|
+
this.frameDataLength = 0;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
onEnd(): void {
|
|
96
|
+
for(let key in this.params) {
|
|
97
|
+
if(this.params[key].reject!=null) {
|
|
98
|
+
this.params[key].reject(new Error("EOF before field seen!"));
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
this.closed = true;
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
onError(e: any): void {
|
|
105
|
+
for(let key in this.params) {
|
|
106
|
+
if(this.params[key].reject!=null) {
|
|
107
|
+
this.params[key].reject(e);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
this.closed = true;
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
getParam(key: string): Promise<any> {
|
|
114
|
+
if(this.params[key]==null) {
|
|
115
|
+
if(this.closed) return Promise.reject(new Error("Stream already closed without param received!"));
|
|
116
|
+
let resolve: (data: any) => void;
|
|
117
|
+
let reject: (err: any) => void;
|
|
118
|
+
const promise = new Promise((_resolve, _reject) => {
|
|
119
|
+
resolve = _resolve
|
|
120
|
+
reject = _reject;
|
|
121
|
+
});
|
|
122
|
+
this.params[key] = {
|
|
123
|
+
resolve,
|
|
124
|
+
reject,
|
|
125
|
+
promise,
|
|
126
|
+
value: null
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
return this.params[key].promise;
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
async getParams<T extends RequestSchema>(schema: T): Promise<RequestSchemaResult<T>> {
|
|
133
|
+
const resultSchema: any = {};
|
|
134
|
+
for(let fieldName in schema) {
|
|
135
|
+
const val: any = await this.getParam(fieldName);
|
|
136
|
+
const type: FieldTypeEnum | RequestSchema | ((val: any) => boolean) = schema[fieldName];
|
|
137
|
+
if(typeof(type)==="function") {
|
|
138
|
+
const result = type(val);
|
|
139
|
+
if(result==null) return null;
|
|
140
|
+
resultSchema[fieldName] = result;
|
|
141
|
+
continue;
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
if(val==null && (type as number)>=100) {
|
|
145
|
+
resultSchema[fieldName] = null;
|
|
146
|
+
continue;
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
if(type===FieldTypeEnum.Any || type===FieldTypeEnum.AnyOptional) {
|
|
150
|
+
resultSchema[fieldName] = val;
|
|
151
|
+
} else if(type===FieldTypeEnum.Boolean || type===FieldTypeEnum.BooleanOptional) {
|
|
152
|
+
if(typeof(val)!=="boolean") return null;
|
|
153
|
+
resultSchema[fieldName] = val;
|
|
154
|
+
} else if(type===FieldTypeEnum.Number || type===FieldTypeEnum.NumberOptional) {
|
|
155
|
+
if(typeof(val)!=="number") return null;
|
|
156
|
+
if(isNaN(val as number)) return null;
|
|
157
|
+
resultSchema[fieldName] = val;
|
|
158
|
+
} else if(type===FieldTypeEnum.BigInt || type===FieldTypeEnum.BigIntOptional) {
|
|
159
|
+
const result = parseBigInt(val);
|
|
160
|
+
if(result==null) return null;
|
|
161
|
+
resultSchema[fieldName] = result;
|
|
162
|
+
} else if(type===FieldTypeEnum.String || type===FieldTypeEnum.StringOptional) {
|
|
163
|
+
if(typeof(val)!=="string") return null;
|
|
164
|
+
resultSchema[fieldName] = val;
|
|
165
|
+
} else {
|
|
166
|
+
//Probably another request schema
|
|
167
|
+
const result = verifySchema(val, type as RequestSchema);
|
|
168
|
+
if(result==null) return null;
|
|
169
|
+
resultSchema[fieldName] = result;
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
return resultSchema;
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
getExistingParamsOrNull<T extends RequestSchema>(schema: T): RequestSchemaResult<T> {
|
|
176
|
+
const resultSchema: any = {};
|
|
177
|
+
for(let fieldName in schema) {
|
|
178
|
+
const val: any = this.params[fieldName]?.value;
|
|
179
|
+
|
|
180
|
+
if(val==null) {
|
|
181
|
+
resultSchema[fieldName] = null;
|
|
182
|
+
continue;
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
const type: FieldTypeEnum | RequestSchema | ((val: any) => boolean) = schema[fieldName];
|
|
186
|
+
if(typeof(type)==="function") {
|
|
187
|
+
const result = type(val);
|
|
188
|
+
if(result==null) return null;
|
|
189
|
+
resultSchema[fieldName] = result;
|
|
190
|
+
continue;
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
if(type===FieldTypeEnum.Any || type===FieldTypeEnum.AnyOptional) {
|
|
194
|
+
resultSchema[fieldName] = val;
|
|
195
|
+
} else if(type===FieldTypeEnum.Boolean || type===FieldTypeEnum.BooleanOptional) {
|
|
196
|
+
if(typeof(val)!=="boolean") return null;
|
|
197
|
+
resultSchema[fieldName] = val;
|
|
198
|
+
} else if(type===FieldTypeEnum.Number || type===FieldTypeEnum.NumberOptional) {
|
|
199
|
+
if(typeof(val)!=="number") return null;
|
|
200
|
+
if(isNaN(val as number)) return null;
|
|
201
|
+
resultSchema[fieldName] = val;
|
|
202
|
+
} else if(type===FieldTypeEnum.BigInt || type===FieldTypeEnum.BigIntOptional) {
|
|
203
|
+
const result = parseBigInt(val);
|
|
204
|
+
if(result==null) return null;
|
|
205
|
+
resultSchema[fieldName] = result;
|
|
206
|
+
} else if(type===FieldTypeEnum.String || type===FieldTypeEnum.StringOptional) {
|
|
207
|
+
if(typeof(val)!=="string") return null;
|
|
208
|
+
resultSchema[fieldName] = val;
|
|
209
|
+
} else {
|
|
210
|
+
//Probably another request schema
|
|
211
|
+
const result = verifySchema(val, type as RequestSchema);
|
|
212
|
+
if(result==null) return null;
|
|
213
|
+
resultSchema[fieldName] = result;
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
return resultSchema;
|
|
217
|
+
}
|
|
218
|
+
|
|
219
219
|
}
|
|
@@ -1,30 +1,30 @@
|
|
|
1
|
-
import {IParamWriter} from "./IParamWriter";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
export class ParamEncoder implements IParamWriter {
|
|
5
|
-
|
|
6
|
-
private readonly writeFN: (data: Buffer) => Promise<void>;
|
|
7
|
-
private readonly endFN: () => Promise<void>;
|
|
8
|
-
|
|
9
|
-
constructor(write: (data: Buffer) => Promise<void>, end: () => Promise<void>) {
|
|
10
|
-
this.writeFN = write;
|
|
11
|
-
this.endFN = end;
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
writeParams(data: any): Promise<void> {
|
|
15
|
-
const serialized: Buffer = Buffer.from(JSON.stringify(data));
|
|
16
|
-
|
|
17
|
-
const frameLengthBuffer = Buffer.alloc(4);
|
|
18
|
-
frameLengthBuffer.writeUint32LE(serialized.length);
|
|
19
|
-
|
|
20
|
-
return this.writeFN(Buffer.concat([
|
|
21
|
-
frameLengthBuffer,
|
|
22
|
-
serialized
|
|
23
|
-
]));
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
end(): Promise<void> {
|
|
27
|
-
return this.endFN();
|
|
28
|
-
}
|
|
29
|
-
|
|
1
|
+
import {IParamWriter} from "./IParamWriter";
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
export class ParamEncoder implements IParamWriter {
|
|
5
|
+
|
|
6
|
+
private readonly writeFN: (data: Buffer) => Promise<void>;
|
|
7
|
+
private readonly endFN: () => Promise<void>;
|
|
8
|
+
|
|
9
|
+
constructor(write: (data: Buffer) => Promise<void>, end: () => Promise<void>) {
|
|
10
|
+
this.writeFN = write;
|
|
11
|
+
this.endFN = end;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
writeParams(data: any): Promise<void> {
|
|
15
|
+
const serialized: Buffer = Buffer.from(JSON.stringify(data));
|
|
16
|
+
|
|
17
|
+
const frameLengthBuffer = Buffer.alloc(4);
|
|
18
|
+
frameLengthBuffer.writeUint32LE(serialized.length);
|
|
19
|
+
|
|
20
|
+
return this.writeFN(Buffer.concat([
|
|
21
|
+
frameLengthBuffer,
|
|
22
|
+
serialized
|
|
23
|
+
]));
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
end(): Promise<void> {
|
|
27
|
+
return this.endFN();
|
|
28
|
+
}
|
|
29
|
+
|
|
30
30
|
}
|