@entity-access/server-pages 1.0.30 → 1.0.31
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/dist/ServerPages.d.ts +4 -2
- package/dist/ServerPages.d.ts.map +1 -1
- package/dist/ServerPages.js +6 -9
- package/dist/ServerPages.js.map +1 -1
- package/dist/core/AsyncStream.d.ts +16 -0
- package/dist/core/AsyncStream.d.ts.map +1 -0
- package/dist/core/AsyncStream.js +55 -0
- package/dist/core/AsyncStream.js.map +1 -0
- package/dist/core/FileApi.d.ts +5 -0
- package/dist/core/FileApi.d.ts.map +1 -0
- package/dist/core/FileApi.js +95 -0
- package/dist/core/FileApi.js.map +1 -0
- package/dist/ssl/ACME.d.ts +37 -0
- package/dist/ssl/ACME.d.ts.map +1 -0
- package/dist/ssl/ACME.js +200 -0
- package/dist/ssl/ACME.js.map +1 -0
- package/dist/ssl/ChallengeStore.d.ts +8 -0
- package/dist/ssl/ChallengeStore.d.ts.map +1 -0
- package/dist/ssl/ChallengeStore.js +34 -0
- package/dist/ssl/ChallengeStore.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +2 -1
- package/src/ServerPages.ts +11 -11
- package/src/core/AsyncStream.ts +83 -0
- package/src/core/FileApi.ts +52 -0
- package/src/ssl/ACME.ts +247 -0
- package/src/ssl/ChallengeStore.ts +26 -0
- package/dist/ssl/SelfSigned.d.ts +0 -7
- package/dist/ssl/SelfSigned.d.ts.map +0 -1
- package/dist/ssl/SelfSigned.js +0 -62
- package/dist/ssl/SelfSigned.js.map +0 -1
- package/src/ssl/SelfSigned.ts +0 -78
package/dist/ServerPages.d.ts
CHANGED
|
@@ -5,6 +5,7 @@ import { ServiceProvider } from "@entity-access/entity-access/dist/di/di.js";
|
|
|
5
5
|
import * as http from "http";
|
|
6
6
|
import * as http2 from "http2";
|
|
7
7
|
import { SecureContext } from "node:tls";
|
|
8
|
+
import { IAcmeOptions } from "./ssl/ACME.js";
|
|
8
9
|
export default class ServerPages {
|
|
9
10
|
static create(globalServiceProvider?: ServiceProvider): ServerPages;
|
|
10
11
|
private root;
|
|
@@ -19,12 +20,13 @@ export default class ServerPages {
|
|
|
19
20
|
* All services should be registered before calling build
|
|
20
21
|
* @param app Express App
|
|
21
22
|
*/
|
|
22
|
-
build({ createSocketService, port, protocol, disableHttp2Warning, SNICallback }: {
|
|
23
|
+
build({ createSocketService, port, protocol, disableHttp2Warning, SNICallback, acmeOptions }: {
|
|
23
24
|
createSocketService?: boolean;
|
|
24
25
|
port: number;
|
|
25
26
|
disableHttp2Warning?: boolean;
|
|
26
27
|
protocol: "http" | "http2" | "https2";
|
|
27
|
-
SNICallback
|
|
28
|
+
SNICallback?: (servername: string, cb: (err: Error | null, ctx?: SecureContext) => void) => void;
|
|
29
|
+
acmeOptions?: IAcmeOptions;
|
|
28
30
|
}): Promise<http2.Http2Server | http.Server<typeof http.IncomingMessage, typeof http.ServerResponse>>;
|
|
29
31
|
protected process(req: any, resp: any): Promise<void>;
|
|
30
32
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ServerPages.d.ts","sourceRoot":"","sources":["../src/ServerPages.ts"],"names":[],"mappings":";;;AACA,OAAO,EAAqB,eAAe,EAAE,MAAM,4CAA4C,CAAC;AAOhG,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAC7B,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAG/B,OAAO,EAAE,aAAa,
|
|
1
|
+
{"version":3,"file":"ServerPages.d.ts","sourceRoot":"","sources":["../src/ServerPages.ts"],"names":[],"mappings":";;;AACA,OAAO,EAAqB,eAAe,EAAE,MAAM,4CAA4C,CAAC;AAOhG,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAC7B,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAG/B,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AACzC,OAAc,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAGpD,MAAM,CAAC,OAAO,OAAO,WAAW;WAEd,MAAM,CAAC,qBAAqB,GAAE,eAAuC;IAKnF,OAAO,CAAC,IAAI,CAA8B;IAE1C;;;;OAIG;IACI,cAAc,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,GAAE,MAAY;IASlD,oBAAoB;IAI3B;;;OAGG;IACU,KAAK,CAAC,EACf,mBAA0B,EAC1B,IAAW,EACX,QAAiB,EACjB,mBAA2B,EAC3B,WAAW,EACX,WAAW,EACd,EAAC;QACE,mBAAmB,CAAC,EAAE,OAAO,CAAC;QAC9B,IAAI,EAAE,MAAM,CAAC;QACb,mBAAmB,CAAC,EAAE,OAAO,CAAC;QAC9B,QAAQ,EAAE,MAAM,GAAG,OAAO,GAAG,QAAQ,CAAC;QACtC,WAAW,CAAC,EAAE,CAAC,UAAU,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,GAAG,EAAE,KAAK,GAAG,IAAI,EAAE,GAAG,CAAC,EAAE,aAAa,KAAK,IAAI,KAAK,IAAI,CAAC;QACjG,WAAW,CAAC,EAAE,YAAY,CAAA;KAC7B;cAoDe,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG;CAgF9C"}
|
package/dist/ServerPages.js
CHANGED
|
@@ -55,8 +55,7 @@ import * as http from "http";
|
|
|
55
55
|
import * as http2 from "http2";
|
|
56
56
|
import SocketService from "./socket/SocketService.js";
|
|
57
57
|
import { Wrapped } from "./core/Wrapped.js";
|
|
58
|
-
import
|
|
59
|
-
import { SelfSigned } from "./ssl/SelfSigned.js";
|
|
58
|
+
import ACME from "./ssl/ACME.js";
|
|
60
59
|
RegisterSingleton;
|
|
61
60
|
export default class ServerPages {
|
|
62
61
|
constructor() {
|
|
@@ -86,7 +85,7 @@ export default class ServerPages {
|
|
|
86
85
|
* All services should be registered before calling build
|
|
87
86
|
* @param app Express App
|
|
88
87
|
*/
|
|
89
|
-
async build({ createSocketService = true, port = 8080, protocol = "http", disableHttp2Warning = false, SNICallback }) {
|
|
88
|
+
async build({ createSocketService = true, port = 8080, protocol = "http", disableHttp2Warning = false, SNICallback, acmeOptions }) {
|
|
90
89
|
try {
|
|
91
90
|
let httpServer = null;
|
|
92
91
|
let socketServer = null;
|
|
@@ -103,12 +102,10 @@ export default class ServerPages {
|
|
|
103
102
|
case "https2":
|
|
104
103
|
let sc = null;
|
|
105
104
|
SNICallback ??= (name, cb) => {
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
sc = createSecureContext({ key, cert });
|
|
111
|
-
cb(null, sc);
|
|
105
|
+
const acme = ServiceProvider.resolve(this, ACME);
|
|
106
|
+
acme.getSecureContext({ ...(acmeOptions ?? {}), host: name }).then((v) => {
|
|
107
|
+
cb(null, v);
|
|
108
|
+
}, cb);
|
|
112
109
|
};
|
|
113
110
|
httpServer = http2.createSecureServer({
|
|
114
111
|
SNICallback
|
package/dist/ServerPages.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ServerPages.js","sourceRoot":"","sources":["../src/ServerPages.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,+BAA+B;AAC/B,OAAO,EAAE,iBAAiB,EAAE,eAAe,EAAE,MAAM,4CAA4C,CAAC;AAChG,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,OAAO,MAAM,cAAc,CAAC;AACnC,OAAO,SAAS,MAAM,qBAAqB,CAAC;AAC5C,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AACzC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAC1C,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AACnC,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAC7B,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,aAAa,MAAM,2BAA2B,CAAC;AACtD,OAAO,EAAE,OAAO,
|
|
1
|
+
{"version":3,"file":"ServerPages.js","sourceRoot":"","sources":["../src/ServerPages.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/// <reference types="node" resolution-mode="require"/>
|
|
2
|
+
export declare abstract class AsyncStream implements Disposable {
|
|
3
|
+
abstract read(n: number): Promise<Buffer>;
|
|
4
|
+
abstract [Symbol.dispose](): any;
|
|
5
|
+
}
|
|
6
|
+
export declare class AsyncFileStream extends AsyncStream {
|
|
7
|
+
private readonly filePath;
|
|
8
|
+
readPosition: number;
|
|
9
|
+
readonly size: number;
|
|
10
|
+
private fd;
|
|
11
|
+
private buffer;
|
|
12
|
+
constructor(filePath: string, readPosition?: number, lockFile?: boolean, bufferSize?: number);
|
|
13
|
+
read(): Promise<Buffer>;
|
|
14
|
+
[Symbol.dispose](): void;
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=AsyncStream.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AsyncStream.d.ts","sourceRoot":"","sources":["../../src/core/AsyncStream.ts"],"names":[],"mappings":";AAEA,8BAAsB,WAAY,YAAW,UAAU;IAEnD,QAAQ,CAAC,IAAI,CAAC,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAEzC,QAAQ,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC;CAE5B;AAID,qBAAa,eAAgB,SAAQ,WAAW;IASxC,OAAO,CAAC,QAAQ,CAAC,QAAQ;IAClB,YAAY;IARvB,SAAgB,IAAI,EAAE,MAAM,CAAC;IAE7B,OAAO,CAAC,EAAE,CAAM;IAEhB,OAAO,CAAC,MAAM,CAAS;gBAGF,QAAQ,EAAE,MAAM,EAC1B,YAAY,SAAI,EACvB,QAAQ,UAAO,EACf,UAAU,SAAgB;IAY9B,IAAI,IAAI,OAAO,CAAC,MAAM,CAAC;IAwCvB,CAAC,MAAM,CAAC,OAAO,CAAC;CAMnB"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { closeSync, openSync, read, statSync } from "fs";
|
|
2
|
+
export class AsyncStream {
|
|
3
|
+
}
|
|
4
|
+
const maxBufferSize = 16 * 1024;
|
|
5
|
+
export class AsyncFileStream extends AsyncStream {
|
|
6
|
+
constructor(filePath, readPosition = 0, lockFile = true, bufferSize = maxBufferSize) {
|
|
7
|
+
super();
|
|
8
|
+
this.filePath = filePath;
|
|
9
|
+
this.readPosition = readPosition;
|
|
10
|
+
if (lockFile) {
|
|
11
|
+
this.fd = openSync(filePath, "r");
|
|
12
|
+
}
|
|
13
|
+
this.buffer = Buffer.alloc(bufferSize);
|
|
14
|
+
const { size } = statSync(filePath);
|
|
15
|
+
this.size = size;
|
|
16
|
+
}
|
|
17
|
+
read() {
|
|
18
|
+
return new Promise((resolve, reject) => {
|
|
19
|
+
const size = this.size - this.readPosition;
|
|
20
|
+
if (size <= 0) {
|
|
21
|
+
resolve(null);
|
|
22
|
+
return;
|
|
23
|
+
}
|
|
24
|
+
const buffer = (size) > this.buffer.byteLength
|
|
25
|
+
? this.buffer
|
|
26
|
+
: Buffer.alloc(size);
|
|
27
|
+
this.readPosition += size;
|
|
28
|
+
if (this.fd) {
|
|
29
|
+
read(this.fd, buffer, 0, buffer.byteLength, this.readPosition, (error) => error ? reject(error) : resolve(buffer));
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
const fd = openSync(this.filePath, "r");
|
|
33
|
+
read(this.fd, buffer, 0, buffer.byteLength, this.readPosition, (error) => {
|
|
34
|
+
try {
|
|
35
|
+
closeSync(fd);
|
|
36
|
+
}
|
|
37
|
+
catch (e) {
|
|
38
|
+
reject(e);
|
|
39
|
+
return;
|
|
40
|
+
}
|
|
41
|
+
if (error) {
|
|
42
|
+
reject(error);
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
resolve(buffer);
|
|
46
|
+
});
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
[Symbol.dispose]() {
|
|
50
|
+
if (this.fd) {
|
|
51
|
+
closeSync(this.fd);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
//# sourceMappingURL=AsyncStream.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AsyncStream.js","sourceRoot":"","sources":["../../src/core/AsyncStream.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,IAAI,CAAC;AAEzD,MAAM,OAAgB,WAAW;CAMhC;AAED,MAAM,aAAa,GAAG,EAAE,GAAC,IAAI,CAAC;AAE9B,MAAM,OAAO,eAAgB,SAAQ,WAAW;IAQ5C,YACqB,QAAgB,EAC1B,eAAe,CAAC,EACvB,QAAQ,GAAG,IAAI,EACf,UAAU,GAAG,aAAa;QAE1B,KAAK,EAAE,CAAC;QALS,aAAQ,GAAR,QAAQ,CAAQ;QAC1B,iBAAY,GAAZ,YAAY,CAAI;QAMvB,IAAI,QAAQ,EAAE,CAAC;YACX,IAAI,CAAC,EAAE,GAAG,QAAQ,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;QACtC,CAAC;QACD,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QACvC,MAAM,EAAE,IAAI,EAAE,GAAG,QAAQ,CAAC,QAAQ,CAAC,CAAC;QACpC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IACrB,CAAC;IAED,IAAI;QAEA,OAAO,IAAI,OAAO,CAAS,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAE3C,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,YAAY,CAAC;YAE3C,IAAI,IAAI,IAAI,CAAC,EAAE,CAAC;gBACZ,OAAO,CAAC,IAAI,CAAC,CAAC;gBACd,OAAO;YACX,CAAC;YAED,MAAM,MAAM,GAAG,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU;gBAC1C,CAAC,CAAC,IAAI,CAAC,MAAM;gBACb,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YAEzB,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC;YAE1B,IAAI,IAAI,CAAC,EAAE,EAAE,CAAC;gBAEV,IAAI,CAAC,IAAI,CAAC,EAAE,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,CAAC,UAAU,EAAE,IAAI,CAAC,YAAY,EACzD,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC;gBACxD,OAAO;YACX,CAAC;YACD,MAAM,EAAE,GAAG,QAAQ,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;YACxC,IAAI,CAAC,IAAI,CAAC,EAAE,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,CAAC,UAAU,EAAE,IAAI,CAAC,YAAY,EACzD,CAAC,KAAK,EAAE,EAAE;gBACN,IAAI,CAAC;oBACD,SAAS,CAAC,EAAE,CAAC,CAAC;gBAClB,CAAC;gBAAC,OAAO,CAAC,EAAE,CAAC;oBACT,MAAM,CAAC,CAAC,CAAC,CAAC;oBACV,OAAO;gBACX,CAAC;gBACD,IAAG,KAAK,EAAG,CAAC;oBACR,MAAM,CAAC,KAAK,CAAC,CAAC;oBACd,OAAO;gBACX,CAAC;gBACD,OAAO,CAAC,MAAM,CAAC,CAAC;YACpB,CAAC,CAAC,CAAC;QACX,CAAC,CAAC,CAAC;IACP,CAAC;IACD,CAAC,MAAM,CAAC,OAAO,CAAC;QACZ,IAAI,IAAI,CAAC,EAAE,EAAE,CAAC;YACV,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACvB,CAAC;IACL,CAAC;CAEJ"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export declare function ensureParentFolder(filePath: string): void;
|
|
2
|
+
export default function ensureDir(folder: string): void;
|
|
3
|
+
export declare const deleteIfExists: (path: any) => void;
|
|
4
|
+
export declare const areFilesEqual: (file1: string, file2: string) => Promise<boolean>;
|
|
5
|
+
//# sourceMappingURL=FileApi.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FileApi.d.ts","sourceRoot":"","sources":["../../src/core/FileApi.ts"],"names":[],"mappings":"AAKA,wBAAgB,kBAAkB,CAAC,QAAQ,EAAE,MAAM,QAElD;AAED,MAAM,CAAC,OAAO,UAAU,SAAS,CAAC,MAAM,EAAE,MAAM,QAa/C;AAED,eAAO,MAAM,cAAc,qBAAyD,CAAC;AAErF,eAAO,MAAM,aAAa,UAAiB,MAAM,SAAS,MAAM,qBAyB/D,CAAC"}
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
var __addDisposableResource = (this && this.__addDisposableResource) || function (env, value, async) {
|
|
2
|
+
if (value !== null && value !== void 0) {
|
|
3
|
+
if (typeof value !== "object" && typeof value !== "function") throw new TypeError("Object expected.");
|
|
4
|
+
var dispose;
|
|
5
|
+
if (async) {
|
|
6
|
+
if (!Symbol.asyncDispose) throw new TypeError("Symbol.asyncDispose is not defined.");
|
|
7
|
+
dispose = value[Symbol.asyncDispose];
|
|
8
|
+
}
|
|
9
|
+
if (dispose === void 0) {
|
|
10
|
+
if (!Symbol.dispose) throw new TypeError("Symbol.dispose is not defined.");
|
|
11
|
+
dispose = value[Symbol.dispose];
|
|
12
|
+
}
|
|
13
|
+
if (typeof dispose !== "function") throw new TypeError("Object not disposable.");
|
|
14
|
+
env.stack.push({ value: value, dispose: dispose, async: async });
|
|
15
|
+
}
|
|
16
|
+
else if (async) {
|
|
17
|
+
env.stack.push({ async: true });
|
|
18
|
+
}
|
|
19
|
+
return value;
|
|
20
|
+
};
|
|
21
|
+
var __disposeResources = (this && this.__disposeResources) || (function (SuppressedError) {
|
|
22
|
+
return function (env) {
|
|
23
|
+
function fail(e) {
|
|
24
|
+
env.error = env.hasError ? new SuppressedError(e, env.error, "An error was suppressed during disposal.") : e;
|
|
25
|
+
env.hasError = true;
|
|
26
|
+
}
|
|
27
|
+
function next() {
|
|
28
|
+
while (env.stack.length) {
|
|
29
|
+
var rec = env.stack.pop();
|
|
30
|
+
try {
|
|
31
|
+
var result = rec.dispose && rec.dispose.call(rec.value);
|
|
32
|
+
if (rec.async) return Promise.resolve(result).then(next, function(e) { fail(e); return next(); });
|
|
33
|
+
}
|
|
34
|
+
catch (e) {
|
|
35
|
+
fail(e);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
if (env.hasError) throw env.error;
|
|
39
|
+
}
|
|
40
|
+
return next();
|
|
41
|
+
};
|
|
42
|
+
})(typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) {
|
|
43
|
+
var e = new Error(message);
|
|
44
|
+
return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
|
|
45
|
+
});
|
|
46
|
+
import { existsSync, unlinkSync, mkdirSync } from "fs";
|
|
47
|
+
import { dirname } from "path";
|
|
48
|
+
import { AsyncFileStream } from "./AsyncStream.js";
|
|
49
|
+
export function ensureParentFolder(filePath) {
|
|
50
|
+
ensureDir(dirname(filePath));
|
|
51
|
+
}
|
|
52
|
+
export default function ensureDir(folder) {
|
|
53
|
+
if (existsSync(folder)) {
|
|
54
|
+
return;
|
|
55
|
+
}
|
|
56
|
+
const parent = dirname(folder);
|
|
57
|
+
if (parent !== "/") {
|
|
58
|
+
ensureDir(parent);
|
|
59
|
+
}
|
|
60
|
+
mkdirSync(folder);
|
|
61
|
+
}
|
|
62
|
+
export const deleteIfExists = (path) => existsSync(path) ? unlinkSync(path) : void 0;
|
|
63
|
+
export const areFilesEqual = async (file1, file2) => {
|
|
64
|
+
const env_1 = { stack: [], error: void 0, hasError: false };
|
|
65
|
+
try {
|
|
66
|
+
const f1 = __addDisposableResource(env_1, new AsyncFileStream(file1), false);
|
|
67
|
+
const f2 = __addDisposableResource(env_1, new AsyncFileStream(file2), false);
|
|
68
|
+
if (f1.size !== f2.size) {
|
|
69
|
+
return false;
|
|
70
|
+
}
|
|
71
|
+
for (;;) {
|
|
72
|
+
const [b1, b2] = await Promise.all([f1.read(), f2.read()]);
|
|
73
|
+
if (b1 === null && b2 === null) {
|
|
74
|
+
return f1.readPosition === f2.readPosition;
|
|
75
|
+
}
|
|
76
|
+
if (b1 === null) {
|
|
77
|
+
return false;
|
|
78
|
+
}
|
|
79
|
+
if (b2 === null) {
|
|
80
|
+
return false;
|
|
81
|
+
}
|
|
82
|
+
if (!b1.equals(b2)) {
|
|
83
|
+
return false;
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
catch (e_1) {
|
|
88
|
+
env_1.error = e_1;
|
|
89
|
+
env_1.hasError = true;
|
|
90
|
+
}
|
|
91
|
+
finally {
|
|
92
|
+
__disposeResources(env_1);
|
|
93
|
+
}
|
|
94
|
+
};
|
|
95
|
+
//# sourceMappingURL=FileApi.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FileApi.js","sourceRoot":"","sources":["../../src/core/FileApi.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,IAAI,CAAC;AAEvD,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAEnD,MAAM,UAAU,kBAAkB,CAAC,QAAgB;IAC/C,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC;AACjC,CAAC;AAED,MAAM,CAAC,OAAO,UAAU,SAAS,CAAC,MAAc;IAE5C,IAAI,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;QACrB,OAAO;IACX,CAAC;IAED,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IAC/B,IAAI,MAAM,KAAK,GAAG,EAAE,CAAC;QACjB,SAAS,CAAC,MAAM,CAAC,CAAC;IACtB,CAAC;IAED,SAAS,CAAC,MAAM,CAAC,CAAC;AAEtB,CAAC;AAED,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,IAAI,EAAE,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;AAErF,MAAM,CAAC,MAAM,aAAa,GAAG,KAAK,EAAE,KAAa,EAAE,KAAa,EAAE,EAAE;;;QAEhE,MAAM,EAAE,kCAAG,IAAI,eAAe,CAAC,KAAK,CAAC,QAAA,CAAC;QACtC,MAAM,EAAE,kCAAG,IAAI,eAAe,CAAC,KAAK,CAAC,QAAA,CAAC;QAEtC,IAAG,EAAE,CAAC,IAAI,KAAK,EAAE,CAAC,IAAI,EAAE,CAAC;YACrB,OAAO,KAAK,CAAC;QACjB,CAAC;QAED,SAAQ,CAAC;YACL,MAAM,CAAC,EAAE,EAAC,EAAE,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;YAC1D,IAAI,EAAE,KAAK,IAAI,IAAI,EAAE,KAAK,IAAI,EAAE,CAAC;gBAC7B,OAAO,EAAE,CAAC,YAAY,KAAK,EAAE,CAAC,YAAY,CAAC;YAC/C,CAAC;YACD,IAAI,EAAE,KAAK,IAAI,EAAE,CAAC;gBACd,OAAO,KAAK,CAAC;YACjB,CAAC;YACD,IAAI,EAAE,KAAK,IAAI,EAAE,CAAC;gBACd,OAAO,KAAK,CAAC;YACjB,CAAC;YACD,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC;gBACjB,OAAO,KAAK,CAAC;YACjB,CAAC;QACL,CAAC;;;;;;;;;CAEJ,CAAC"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
/// <reference types="node" resolution-mode="require"/>
|
|
2
|
+
import * as tls from "node:tls";
|
|
3
|
+
export interface IAcmeOptions {
|
|
4
|
+
sslMode?: string;
|
|
5
|
+
accountPrivateKeyPath?: string;
|
|
6
|
+
emailAddress?: string;
|
|
7
|
+
mode?: "production" | "self-signed" | "staging";
|
|
8
|
+
endPoint?: string;
|
|
9
|
+
eabKid?: string;
|
|
10
|
+
eabHmac?: string;
|
|
11
|
+
}
|
|
12
|
+
export interface ICertOptions extends IAcmeOptions {
|
|
13
|
+
host: string;
|
|
14
|
+
}
|
|
15
|
+
export default class ACME {
|
|
16
|
+
private challengeStore;
|
|
17
|
+
private map;
|
|
18
|
+
getSecureContext(options: ICertOptions): Promise<tls.SecureContext>;
|
|
19
|
+
setup({ host, sslMode, accountPrivateKeyPath, emailAddress, mode, endPoint, eabKid, eabHmac }: {
|
|
20
|
+
host: any;
|
|
21
|
+
sslMode?: string;
|
|
22
|
+
accountPrivateKeyPath?: string;
|
|
23
|
+
emailAddress?: string;
|
|
24
|
+
mode?: "production" | "self-signed" | "staging";
|
|
25
|
+
endPoint?: string;
|
|
26
|
+
eabKid?: string;
|
|
27
|
+
eabHmac?: string;
|
|
28
|
+
}): Promise<{
|
|
29
|
+
key: any;
|
|
30
|
+
cert: any;
|
|
31
|
+
}>;
|
|
32
|
+
setupSelfSigned(sslMode?: string): {
|
|
33
|
+
key: any;
|
|
34
|
+
cert: any;
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=ACME.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ACME.d.ts","sourceRoot":"","sources":["../../src/ssl/ACME.ts"],"names":[],"mappings":";AAUA,OAAO,KAAK,GAAG,MAAM,UAAU,CAAC;AAEhC,MAAM,WAAW,YAAY;IACzB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,qBAAqB,CAAC,EAAE,MAAM,CAAC;IAC/B,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,IAAI,CAAC,EAAG,YAAY,GAAG,aAAa,GAAG,SAAS,CAAC;IACjD,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAA;CACnB;AAED,MAAM,WAAW,YAAa,SAAQ,YAAY;IAC9C,IAAI,EAAE,MAAM,CAAC;CAChB;AAGD,MAAM,CAAC,OAAO,OAAO,IAAI;IAGrB,OAAO,CAAC,cAAc,CAAiB;IAEvC,OAAO,CAAC,GAAG,CAAwC;IAEtC,gBAAgB,CAAC,OAAO,EAAE,YAAY;IAatC,KAAK,CAAC,EACf,IAAI,EACJ,OAAc,EACd,qBAA4B,EAC5B,YAAiB,EACjB,IAA+D,EAC/D,QAAa,EACb,MAAW,EACX,OAAY,EACf;;;;;;;;;KAAA;;;;IAsHM,eAAe,CAAC,OAAO,SAAO;;;;CAwExC"}
|
package/dist/ssl/ACME.js
ADDED
|
@@ -0,0 +1,200 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
|
+
};
|
|
10
|
+
import * as forge from "node-forge";
|
|
11
|
+
import * as crypto from "crypto";
|
|
12
|
+
import * as acme from "acme-client";
|
|
13
|
+
import DateTime from "@entity-access/entity-access/dist/types/DateTime.js";
|
|
14
|
+
import cluster from "cluster";
|
|
15
|
+
import { existsSync, writeFileSync, readFileSync, unlinkSync } from "fs";
|
|
16
|
+
import { join } from "path";
|
|
17
|
+
import ensureDir, { deleteIfExists } from "../core/FileApi.js";
|
|
18
|
+
import Inject, { RegisterSingleton } from "@entity-access/entity-access/dist/di/di.js";
|
|
19
|
+
import ChallengeStore from "./ChallengeStore.js";
|
|
20
|
+
import * as tls from "node:tls";
|
|
21
|
+
;
|
|
22
|
+
let ACME = class ACME {
|
|
23
|
+
constructor() {
|
|
24
|
+
this.map = new Map();
|
|
25
|
+
}
|
|
26
|
+
async getSecureContext(options) {
|
|
27
|
+
const { host } = options;
|
|
28
|
+
let sc = this.map.get(host);
|
|
29
|
+
if (sc) {
|
|
30
|
+
return sc;
|
|
31
|
+
}
|
|
32
|
+
const { key, cert } = await this.setup(options);
|
|
33
|
+
sc = tls.createSecureContext({ cert, key });
|
|
34
|
+
this.map.set(host, sc);
|
|
35
|
+
return sc;
|
|
36
|
+
}
|
|
37
|
+
async setup({ host, sslMode = "./", accountPrivateKeyPath = "./", emailAddress = "", mode = "production", endPoint = "", eabKid = "", eabHmac = "" }) {
|
|
38
|
+
if (mode === "self-signed") {
|
|
39
|
+
return this.setupSelfSigned(sslMode);
|
|
40
|
+
}
|
|
41
|
+
const hostRoot = join(sslMode, host);
|
|
42
|
+
ensureDir(hostRoot);
|
|
43
|
+
const keyPath = join(hostRoot, "cert.key");
|
|
44
|
+
const certPath = join(hostRoot, "cert.crt");
|
|
45
|
+
const logs = [];
|
|
46
|
+
try {
|
|
47
|
+
const maintainerEmail = emailAddress;
|
|
48
|
+
let externalAccountBinding;
|
|
49
|
+
if (eabKid) {
|
|
50
|
+
externalAccountBinding = {
|
|
51
|
+
kid: eabKid,
|
|
52
|
+
hmacKey: eabHmac
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
let cert;
|
|
56
|
+
let key;
|
|
57
|
+
if (!existsSync(keyPath)) {
|
|
58
|
+
deleteIfExists(certPath);
|
|
59
|
+
key = (await acme.crypto.createPrivateRsaKey()).toString();
|
|
60
|
+
writeFileSync(keyPath, key);
|
|
61
|
+
console.log(`Creating key at ${keyPath}`);
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
key = readFileSync(keyPath, "utf8");
|
|
65
|
+
}
|
|
66
|
+
// load cert...
|
|
67
|
+
if (existsSync(certPath)) {
|
|
68
|
+
cert = readFileSync(certPath, "utf8");
|
|
69
|
+
const certificate = new crypto.X509Certificate(cert);
|
|
70
|
+
const validTo = DateTime.parse(certificate.validTo).diff(DateTime.now);
|
|
71
|
+
if (validTo.totalDays > 30) {
|
|
72
|
+
console.log(`Reusing certificate, valid for ${validTo.totalDays}`);
|
|
73
|
+
return { cert, key };
|
|
74
|
+
}
|
|
75
|
+
console.log(`Deleting old certificates`);
|
|
76
|
+
unlinkSync(certPath);
|
|
77
|
+
}
|
|
78
|
+
if (!cluster.isPrimary) {
|
|
79
|
+
console.log(`Generating Self Signed SSL Certificate for ${host} in cluster worker. Contact administrator.`);
|
|
80
|
+
return this.setupSelfSigned();
|
|
81
|
+
}
|
|
82
|
+
let accountKey;
|
|
83
|
+
if (existsSync(accountPrivateKeyPath)) {
|
|
84
|
+
console.log("Reusing the account private key.");
|
|
85
|
+
accountKey = readFileSync(accountPrivateKeyPath);
|
|
86
|
+
}
|
|
87
|
+
else {
|
|
88
|
+
console.log("Creating new private key.");
|
|
89
|
+
accountKey = await acme.crypto.createPrivateKey();
|
|
90
|
+
writeFileSync(accountPrivateKeyPath, accountKey);
|
|
91
|
+
}
|
|
92
|
+
acme.setLogger((message) => {
|
|
93
|
+
// console.log(message);
|
|
94
|
+
logs.push(message);
|
|
95
|
+
});
|
|
96
|
+
let altNames;
|
|
97
|
+
// auto renew...
|
|
98
|
+
const client = new acme.Client({
|
|
99
|
+
directoryUrl: endPoint || acme.directory.letsencrypt[mode],
|
|
100
|
+
accountKey,
|
|
101
|
+
externalAccountBinding,
|
|
102
|
+
});
|
|
103
|
+
/* Create CSR */
|
|
104
|
+
const [csrKey, csr] = await acme.crypto.createCsr({
|
|
105
|
+
commonName: host,
|
|
106
|
+
altNames
|
|
107
|
+
}, key);
|
|
108
|
+
/* Certificate */
|
|
109
|
+
cert = await client.auto({
|
|
110
|
+
csr,
|
|
111
|
+
email: maintainerEmail,
|
|
112
|
+
termsOfServiceAgreed: true,
|
|
113
|
+
skipChallengeVerification: true,
|
|
114
|
+
challengePriority: ["http-01"],
|
|
115
|
+
challengeCreateFn: (authz, challenge, keyAuthorization) => {
|
|
116
|
+
if (challenge.type !== "http-01") {
|
|
117
|
+
return;
|
|
118
|
+
}
|
|
119
|
+
return this.challengeStore.save(challenge.token, keyAuthorization);
|
|
120
|
+
},
|
|
121
|
+
challengeRemoveFn: (authz, challenge, keyAuthorization) => {
|
|
122
|
+
return this.challengeStore.remove(challenge.token);
|
|
123
|
+
},
|
|
124
|
+
});
|
|
125
|
+
writeFileSync(certPath, cert);
|
|
126
|
+
return { cert, key };
|
|
127
|
+
}
|
|
128
|
+
catch (error) {
|
|
129
|
+
console.log(logs.join("\n"));
|
|
130
|
+
console.error(error);
|
|
131
|
+
throw error;
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
setupSelfSigned(sslMode = "./") {
|
|
135
|
+
const selfSigned = `${sslMode}/self-signed/`;
|
|
136
|
+
ensureDir(selfSigned);
|
|
137
|
+
const certPath = `${selfSigned}/cert.crt`;
|
|
138
|
+
const keyPath = `${selfSigned}/key.pem`;
|
|
139
|
+
let key;
|
|
140
|
+
let cert;
|
|
141
|
+
if (existsSync(certPath) && existsSync(keyPath)) {
|
|
142
|
+
key = readFileSync(keyPath);
|
|
143
|
+
cert = readFileSync(certPath);
|
|
144
|
+
return { key, cert };
|
|
145
|
+
}
|
|
146
|
+
const pki = forge.default.pki;
|
|
147
|
+
// generate a key pair or use one you have already
|
|
148
|
+
const keys = pki.rsa.generateKeyPair(2048);
|
|
149
|
+
// create a new certificate
|
|
150
|
+
const crt = pki.createCertificate();
|
|
151
|
+
// fill the required fields
|
|
152
|
+
crt.publicKey = keys.publicKey;
|
|
153
|
+
crt.serialNumber = '01';
|
|
154
|
+
crt.validity.notBefore = new Date();
|
|
155
|
+
crt.validity.notAfter = new Date();
|
|
156
|
+
crt.validity.notAfter.setFullYear(crt.validity.notBefore.getFullYear() + 40);
|
|
157
|
+
// use your own attributes here, or supply a csr (check the docs)
|
|
158
|
+
const attrs = [
|
|
159
|
+
{
|
|
160
|
+
name: 'commonName',
|
|
161
|
+
value: 'dev.socialmail.in'
|
|
162
|
+
}, {
|
|
163
|
+
name: 'countryName',
|
|
164
|
+
value: 'IN'
|
|
165
|
+
}, {
|
|
166
|
+
shortName: 'ST',
|
|
167
|
+
value: 'Maharashtra'
|
|
168
|
+
}, {
|
|
169
|
+
name: 'localityName',
|
|
170
|
+
value: 'Navi Mumbai'
|
|
171
|
+
}, {
|
|
172
|
+
name: 'organizationName',
|
|
173
|
+
value: 'NeuroSpeech Technologies Pvt Ltd'
|
|
174
|
+
}, {
|
|
175
|
+
shortName: 'OU',
|
|
176
|
+
value: 'Test'
|
|
177
|
+
}
|
|
178
|
+
];
|
|
179
|
+
// here we set subject and issuer as the same one
|
|
180
|
+
crt.setSubject(attrs);
|
|
181
|
+
crt.setIssuer(attrs);
|
|
182
|
+
// the actual certificate signing
|
|
183
|
+
crt.sign(keys.privateKey);
|
|
184
|
+
// now convert the Forge certificate to PEM format
|
|
185
|
+
cert = pki.certificateToPem(crt);
|
|
186
|
+
key = pki.privateKeyToPem(keys.privateKey);
|
|
187
|
+
writeFileSync(certPath, cert);
|
|
188
|
+
writeFileSync(keyPath, key);
|
|
189
|
+
return { key, cert };
|
|
190
|
+
}
|
|
191
|
+
};
|
|
192
|
+
__decorate([
|
|
193
|
+
Inject,
|
|
194
|
+
__metadata("design:type", ChallengeStore)
|
|
195
|
+
], ACME.prototype, "challengeStore", void 0);
|
|
196
|
+
ACME = __decorate([
|
|
197
|
+
RegisterSingleton
|
|
198
|
+
], ACME);
|
|
199
|
+
export default ACME;
|
|
200
|
+
//# sourceMappingURL=ACME.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ACME.js","sourceRoot":"","sources":["../../src/ssl/ACME.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/// <reference types="node" resolution-mode="require"/>
|
|
2
|
+
export default class ChallengeStore {
|
|
3
|
+
constructor();
|
|
4
|
+
get(name: string): Promise<Buffer>;
|
|
5
|
+
save(name: string, value: string): Promise<void>;
|
|
6
|
+
remove(name: string): Promise<void>;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=ChallengeStore.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ChallengeStore.d.ts","sourceRoot":"","sources":["../../src/ssl/ChallengeStore.ts"],"names":[],"mappings":";AAQA,MAAM,CAAC,OAAO,OAAO,cAAc;;IAMzB,GAAG,CAAC,IAAI,EAAE,MAAM;IAIhB,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM;IAIhC,MAAM,CAAC,IAAI,EAAE,MAAM;CAG5B"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
|
+
};
|
|
10
|
+
import { RegisterSingleton } from "@entity-access/entity-access/dist/di/di.js";
|
|
11
|
+
import ensureDir from "../core/FileApi.js";
|
|
12
|
+
import { readFileSync, unlinkSync, writeFileSync } from "fs";
|
|
13
|
+
import { join } from "node:path";
|
|
14
|
+
const path = "./challenges";
|
|
15
|
+
let ChallengeStore = class ChallengeStore {
|
|
16
|
+
constructor() {
|
|
17
|
+
ensureDir(path);
|
|
18
|
+
}
|
|
19
|
+
async get(name) {
|
|
20
|
+
return readFileSync(join(path, name));
|
|
21
|
+
}
|
|
22
|
+
async save(name, value) {
|
|
23
|
+
writeFileSync(join(path, name), value, "utf8");
|
|
24
|
+
}
|
|
25
|
+
async remove(name) {
|
|
26
|
+
unlinkSync(join(path, name));
|
|
27
|
+
}
|
|
28
|
+
};
|
|
29
|
+
ChallengeStore = __decorate([
|
|
30
|
+
RegisterSingleton,
|
|
31
|
+
__metadata("design:paramtypes", [])
|
|
32
|
+
], ChallengeStore);
|
|
33
|
+
export default ChallengeStore;
|
|
34
|
+
//# sourceMappingURL=ChallengeStore.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ChallengeStore.js","sourceRoot":"","sources":["../../src/ssl/ChallengeStore.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,4CAA4C,CAAC;AAC/E,OAAO,SAAS,MAAM,oBAAoB,CAAC;AAC3C,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,IAAI,CAAC;AAC7D,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAEjC,MAAM,IAAI,GAAG,cAAc,CAAC;AAGb,IAAM,cAAc,GAApB,MAAM,cAAc;IAE/B;QACI,SAAS,CAAC,IAAI,CAAC,CAAC;IACpB,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,IAAY;QAClB,OAAO,YAAY,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;IAC1C,CAAC;IAED,KAAK,CAAC,IAAI,CAAC,IAAY,EAAE,KAAa;QAClC,aAAa,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;IACnD,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,IAAY;QACrB,UAAU,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;IACjC,CAAC;CACJ,CAAA;AAjBoB,cAAc;IADlC,iBAAiB;;GACG,cAAc,CAiBlC;eAjBoB,cAAc"}
|