@dreamkit/app 0.0.26 → 0.0.27
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/lib/App.d.ts
CHANGED
|
@@ -17,6 +17,7 @@ export declare class App {
|
|
|
17
17
|
readonly routes: Set<Route>;
|
|
18
18
|
readonly services: Set<AppService>;
|
|
19
19
|
readonly middlewares: Set<MiddlewareConstructor>;
|
|
20
|
+
protected sortedMiddlewares: MiddlewareConstructor[] | undefined;
|
|
20
21
|
readonly settings: Set<SettingsConstructor<import("./builders/SettingsBuilder.js").SettingsData<import("./builders/SettingsBuilder.js").SettingsName, import("./builders/SettingsBuilder.js").SettingsParams, import("./builders/SettingsBuilder.js").SettingsDefaults<import("./builders/SettingsBuilder.js").SettingsParams>>>>;
|
|
21
22
|
readonly api: Map<string, Func>;
|
|
22
23
|
settingsHandler: SettingsHandlerConstructor | undefined;
|
|
@@ -62,6 +63,7 @@ export declare class App {
|
|
|
62
63
|
};
|
|
63
64
|
add(input: Record<string, any> | any[]): Promise<void>;
|
|
64
65
|
createRequestContext(request: Request): RequestContext;
|
|
66
|
+
private getSortedMiddlewares;
|
|
65
67
|
request(request: Request, context?: RequestContext): Promise<any>;
|
|
66
68
|
protected initSettingsValue(constructor: SettingsConstructor): Promise<any>;
|
|
67
69
|
protected registerAllSettings(): Promise<void>;
|
package/lib/App.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"App.d.ts","sourceRoot":"","sources":["../src/App.ts"],"names":[],"mappings":"AAIA,OAAO,EAEL,KAAK,qBAAqB,EAC3B,MAAM,iCAAiC,CAAC;AACzC,OAAO,EAAE,KAAK,EAAE,MAAM,4BAA4B,CAAC;AAEnD,OAAO,EAEL,KAAK,UAAU,EACf,KAAK,kBAAkB,EACxB,MAAM,8BAA8B,CAAC;AAEtC,OAAO,EAEL,KAAK,mBAAmB,EACzB,MAAM,+BAA+B,CAAC;AACvC,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AACtD,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AAC9D,OAAO,EAGL,KAAK,yBAAyB,EAC/B,MAAM,8BAA8B,CAAC;AACtC,OAAO,EAEL,eAAe,EACf,KAAK,0BAA0B,EAChC,MAAM,+BAA+B,CAAC;AAGvC,OAAO,EAAE,KAAK,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAI3C,qBAAa,GAAG;IAId,MAAM,CAAC,WAAW,SAAY;IAC9B,QAAQ,CAAC,OAAO,SAAS;IACzB,QAAQ,CAAC,OAAO,EAAE,UAAU,CAAC;IAC7B,QAAQ,CAAC,OAAO,mBAA0B;IAC1C,QAAQ,CAAC,WAAW,sBAA6B;IACjD,QAAQ,CAAC,gBAAgB,cAAqB;IAC9C,QAAQ,CAAC,MAAM,aAAoB;IACnC,QAAQ,CAAC,QAAQ,kBAAyB;IAC1C,QAAQ,CAAC,WAAW,6BAAoC;IACxD,QAAQ,CAAC,QAAQ,iTAAkC;IACnD,QAAQ,CAAC,GAAG,oBAA2B;IAChC,eAAe,EAAE,0BAA0B,GAAG,SAAS,CAAC;IACxD,cAAc,EAAE,yBAAyB,GAAG,SAAS,CAAC;IAC7D,SAAS,CAAC,SAAS;wBACG;YAAE,EAAE,EAAE,MAAM,CAAC;YAAC,KAAK,EAAE,OAAO,CAAA;SAAE,KAAK,GAAG;2BACnC;YAAE,EAAE,EAAE,MAAM,CAAC;YAAC,KAAK,EAAE,OAAO,CAAA;SAAE,KAAK,GAAG;2BAEpD;YAAE,EAAE,EAAE,MAAM,CAAC;YAAC,KAAK,EAAE,OAAO,CAAC;YAAC,MAAM,EAAE,KAAK,GAAG,QAAQ,CAAA;SAAE,KAAK,GAAG;MAEzE;;IAOF,MAAM,CAAC,QAAQ,IAAI,GAAG;IAKtB,MAAM,CAAC,YAAY,CAAC,QAAQ,EAAE,GAAG;IAGjC,MAAM,CAAC,oBAAoB,IAAI,GAAG;IAKlC,EAAE,CACA,KAAK,EAAE,KAAK,GAAG,QAAQ,EACvB,EAAE,EAAE,CAAC,IAAI,EAAE;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,OAAO,CAAA;KAAE,KAAK,GAAG,GAChD,IAAI;IACP,EAAE,CACA,KAAK,EAAE,QAAQ,EACf,EAAE,EAAE,CAAC,IAAI,EAAE;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,OAAO,CAAC;QAAC,MAAM,EAAE,KAAK,GAAG,QAAQ,CAAA;KAAE,KAAK,GAAG,GAC1E,IAAI;IAKP,GAAG,CAAC,KAAK,EAAE,KAAK,GAAG,QAAQ,GAAG,QAAQ,EAAE,EAAE,EAAE,GAAG,GAAG,IAAI;IAItD,WAAW,CAAC,KAAK,EAAE,OAAO;IAMpB,MAAM,CAAC,GAAG,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;
|
|
1
|
+
{"version":3,"file":"App.d.ts","sourceRoot":"","sources":["../src/App.ts"],"names":[],"mappings":"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"}
|
package/lib/App.js
CHANGED
|
@@ -28,6 +28,7 @@ export class App {
|
|
|
28
28
|
routes = new Set();
|
|
29
29
|
services = new Set();
|
|
30
30
|
middlewares = new Set();
|
|
31
|
+
sortedMiddlewares;
|
|
31
32
|
settings = new Set();
|
|
32
33
|
api = new Map();
|
|
33
34
|
settingsHandler;
|
|
@@ -90,6 +91,7 @@ export class App {
|
|
|
90
91
|
}
|
|
91
92
|
else if (isMiddleware(value)) {
|
|
92
93
|
this.middlewares.delete(value);
|
|
94
|
+
this.sortedMiddlewares = undefined;
|
|
93
95
|
}
|
|
94
96
|
else if (isSettings(value)) {
|
|
95
97
|
this.removeSettings(value);
|
|
@@ -204,6 +206,7 @@ export class App {
|
|
|
204
206
|
}
|
|
205
207
|
else if (isMiddleware(value)) {
|
|
206
208
|
this.middlewares.add(value);
|
|
209
|
+
this.sortedMiddlewares = undefined;
|
|
207
210
|
}
|
|
208
211
|
else if (isSettings(value)) {
|
|
209
212
|
this.settings.add(value);
|
|
@@ -290,11 +293,21 @@ export class App {
|
|
|
290
293
|
});
|
|
291
294
|
return requestContext;
|
|
292
295
|
}
|
|
296
|
+
getSortedMiddlewares() {
|
|
297
|
+
if (this.sortedMiddlewares)
|
|
298
|
+
return this.sortedMiddlewares;
|
|
299
|
+
this.sortedMiddlewares = sortByDeps([...this.middlewares].map((value) => ({
|
|
300
|
+
value,
|
|
301
|
+
deps: value.$options.deps,
|
|
302
|
+
priority: value.$options.priority,
|
|
303
|
+
}))).map((item) => item.value);
|
|
304
|
+
return this.sortedMiddlewares;
|
|
305
|
+
}
|
|
293
306
|
async request(request, context) {
|
|
294
307
|
if (!context)
|
|
295
308
|
context = this.createRequestContext(request);
|
|
296
309
|
log("request", context.resolve(RequestUrl).pathname);
|
|
297
|
-
for (const middleware of this.
|
|
310
|
+
for (const middleware of this.getSortedMiddlewares()) {
|
|
298
311
|
const $md = context.resolve(middleware);
|
|
299
312
|
const response = await $md.onRequest();
|
|
300
313
|
if (response && response instanceof Response) {
|
|
@@ -302,8 +315,8 @@ export class App {
|
|
|
302
315
|
for (const [name, value] of headers.entries()) {
|
|
303
316
|
response.headers.set(name, value);
|
|
304
317
|
}
|
|
318
|
+
return response;
|
|
305
319
|
}
|
|
306
|
-
return response;
|
|
307
320
|
}
|
|
308
321
|
}
|
|
309
322
|
async initSettingsValue(constructor) {
|
|
@@ -406,6 +419,7 @@ export class App {
|
|
|
406
419
|
this.routes.clear();
|
|
407
420
|
this.services.clear();
|
|
408
421
|
this.middlewares.clear();
|
|
422
|
+
this.sortedMiddlewares = undefined;
|
|
409
423
|
this.settings.clear();
|
|
410
424
|
this.api.clear();
|
|
411
425
|
this.context.resolve(EJSON).clear();
|
|
@@ -4,6 +4,8 @@ export declare const kindMiddleware: (input: object, name?: string) => void, isM
|
|
|
4
4
|
export type MiddlewareSelf = IocParamsUserConfig | undefined;
|
|
5
5
|
export type MiddlewareData<TSelf extends MiddlewareSelf = MiddlewareSelf> = {
|
|
6
6
|
self?: TSelf;
|
|
7
|
+
deps?: MiddlewareConstructor[];
|
|
8
|
+
priority?: number;
|
|
7
9
|
};
|
|
8
10
|
export type MiddlewareOptions<T extends MiddlewareData = MiddlewareData> = T & {
|
|
9
11
|
static?: Record<string, any>;
|
|
@@ -12,7 +14,9 @@ export type MergeMiddlewareData<D1 extends MiddlewareData, D2 extends Partial<Mi
|
|
|
12
14
|
export declare abstract class Middleware {
|
|
13
15
|
abstract onRequest(): any;
|
|
14
16
|
}
|
|
15
|
-
export type MiddlewareConstructor = Constructor<Middleware
|
|
17
|
+
export type MiddlewareConstructor = Constructor<Middleware> & {
|
|
18
|
+
$options: MiddlewareOptions;
|
|
19
|
+
};
|
|
16
20
|
export declare class MiddlewareBuilder<T extends MiddlewareData = {}> {
|
|
17
21
|
readonly data: T;
|
|
18
22
|
readonly options: MiddlewareOptions<T>;
|
|
@@ -21,6 +25,8 @@ export declare class MiddlewareBuilder<T extends MiddlewareData = {}> {
|
|
|
21
25
|
self<TSelf extends MiddlewareSelf>(value: TSelf): MiddlewareBuilder<MergeMiddlewareData<T, {
|
|
22
26
|
self: TSelf;
|
|
23
27
|
}>>;
|
|
28
|
+
deps(deps: MiddlewareConstructor[]): this;
|
|
29
|
+
priority(priority: number): this;
|
|
24
30
|
create(): IocClass<T["self"] & {}, Middleware>;
|
|
25
31
|
}
|
|
26
32
|
//# sourceMappingURL=MiddlewareBuilder.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MiddlewareBuilder.d.ts","sourceRoot":"","sources":["../../src/builders/MiddlewareBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,QAAQ,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAC;AAE9E,OAAO,KAAK,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAEhE,eAAO,MAAO,cAAc,0CAAE,YAAY,oDAEzC,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG,mBAAmB,GAAG,SAAS,CAAC;AAC7D,MAAM,MAAM,cAAc,CAAC,KAAK,SAAS,cAAc,GAAG,cAAc,IAAI;IAC1E,IAAI,CAAC,EAAE,KAAK,CAAC;
|
|
1
|
+
{"version":3,"file":"MiddlewareBuilder.d.ts","sourceRoot":"","sources":["../../src/builders/MiddlewareBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,QAAQ,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAC;AAE9E,OAAO,KAAK,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAEhE,eAAO,MAAO,cAAc,0CAAE,YAAY,oDAEzC,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG,mBAAmB,GAAG,SAAS,CAAC;AAC7D,MAAM,MAAM,cAAc,CAAC,KAAK,SAAS,cAAc,GAAG,cAAc,IAAI;IAC1E,IAAI,CAAC,EAAE,KAAK,CAAC;IACb,IAAI,CAAC,EAAE,qBAAqB,EAAE,CAAC;IAC/B,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB,CAAC;AAEF,MAAM,MAAM,iBAAiB,CAAC,CAAC,SAAS,cAAc,GAAG,cAAc,IAAI,CAAC,GAAG;IAC7E,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;CAC9B,CAAC;AAEF,MAAM,MAAM,mBAAmB,CAC7B,EAAE,SAAS,cAAc,EACzB,EAAE,SAAS,OAAO,CAAC,cAAc,CAAC,IAChC,KAAK,CAAC,cAAc,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;AAElC,8BAAsB,UAAU;IAI9B,QAAQ,CAAC,SAAS,IAAI,GAAG;CAC1B;AAED,MAAM,MAAM,qBAAqB,GAAG,WAAW,CAAC,UAAU,CAAC,GAAG;IAC5D,QAAQ,EAAE,iBAAiB,CAAC;CAC7B,CAAC;AAIF,qBAAa,iBAAiB,CAAC,CAAC,SAAS,cAAc,GAAG,EAAE;IAC1D,QAAQ,CAAC,IAAI,EAAE,CAAC,CAAC;IACjB,QAAQ,CAAC,OAAO,EAAE,iBAAiB,CAAC,CAAC,CAAC,CAAC;gBAC3B,OAAO,GAAE,iBAAiB,CAAC,CAAC,CAAa;IASrD,SAAS,CAAC,KAAK,CAAC,IAAI,EAAE,OAAO,CAAC,iBAAiB,CAAC,GAAG,IAAI;IAOvD,IAAI,CAAC,KAAK,SAAS,cAAc,EAC/B,KAAK,EAAE,KAAK,GACX,iBAAiB,CAAC,mBAAmB,CAAC,CAAC,EAAE;QAAE,IAAI,EAAE,KAAK,CAAA;KAAE,CAAC,CAAC;IAG7D,IAAI,CAAC,IAAI,EAAE,qBAAqB,EAAE,GAAG,IAAI;IAGzC,QAAQ,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAGhC,MAAM,IAAI,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,EAAE,EAAE,UAAU,CAAC;CAM/C"}
|
|
@@ -29,8 +29,15 @@ export class MiddlewareBuilder {
|
|
|
29
29
|
self(value) {
|
|
30
30
|
return this.clone({ self: value });
|
|
31
31
|
}
|
|
32
|
+
deps(deps) {
|
|
33
|
+
return this.clone({ deps });
|
|
34
|
+
}
|
|
35
|
+
priority(priority) {
|
|
36
|
+
return this.clone({ priority });
|
|
37
|
+
}
|
|
32
38
|
create() {
|
|
33
39
|
const Class = MiddlewareClass(this.options.self || {});
|
|
40
|
+
Object.assign(Class, { $options: this.options });
|
|
34
41
|
if (this.options.static)
|
|
35
42
|
Object.assign(Class, this.options.static);
|
|
36
43
|
return Class;
|