@koala-ts/framework 2.14.0 → 2.15.0
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/Config/types.d.ts +8 -0
- package/dist/Config/types.d.ts.map +1 -1
- package/dist/Http/Scope/State/ScopeStoreFactory.test.js +6 -6
- package/dist/Http/Scope/State/ScopeStoreFactory.test.js.map +1 -1
- package/dist/Http/Scope/index.d.ts +1 -0
- package/dist/Http/Scope/index.d.ts.map +1 -1
- package/dist/Http/Scope/index.js +1 -0
- package/dist/Http/Scope/index.js.map +1 -1
- package/dist/Http/Scope/initialize-scope.d.ts +8 -0
- package/dist/Http/Scope/initialize-scope.d.ts.map +1 -0
- package/dist/Http/Scope/initialize-scope.js +26 -0
- package/dist/Http/Scope/initialize-scope.js.map +1 -0
- package/dist/Http/Scope/initialize-scope.test.d.ts +2 -0
- package/dist/Http/Scope/initialize-scope.test.d.ts.map +1 -0
- package/dist/Http/Scope/initialize-scope.test.js +63 -0
- package/dist/Http/Scope/initialize-scope.test.js.map +1 -0
- package/dist/Http/Scope/request-scope-storage.d.ts +13 -0
- package/dist/Http/Scope/request-scope-storage.d.ts.map +1 -0
- package/dist/Http/Scope/request-scope-storage.js +15 -0
- package/dist/Http/Scope/request-scope-storage.js.map +1 -0
- package/dist/Http/Scope/request-scope-storage.test.d.ts +2 -0
- package/dist/Http/Scope/request-scope-storage.test.d.ts.map +1 -0
- package/dist/{Kernel/HttpKernel.test.js → Http/Scope/request-scope-storage.test.js} +4 -4
- package/dist/Http/Scope/request-scope-storage.test.js.map +1 -0
- package/dist/Http/middleware/apply-configured-global-middleware.d.ts +3 -0
- package/dist/Http/middleware/apply-configured-global-middleware.d.ts.map +1 -0
- package/dist/Http/middleware/apply-configured-global-middleware.js +9 -0
- package/dist/Http/middleware/apply-configured-global-middleware.js.map +1 -0
- package/dist/Http/middleware/apply-configured-global-middleware.test.d.ts +2 -0
- package/dist/Http/middleware/apply-configured-global-middleware.test.d.ts.map +1 -0
- package/dist/Http/middleware/apply-configured-global-middleware.test.js +53 -0
- package/dist/Http/middleware/apply-configured-global-middleware.test.js.map +1 -0
- package/dist/Kernel/index.d.ts +2 -1
- package/dist/Kernel/index.d.ts.map +1 -1
- package/dist/Kernel/index.js +2 -1
- package/dist/Kernel/index.js.map +1 -1
- package/dist/Kernel/register-event-subscribers.d.ts +4 -0
- package/dist/Kernel/register-event-subscribers.d.ts.map +1 -0
- package/dist/Kernel/register-event-subscribers.js +22 -0
- package/dist/Kernel/register-event-subscribers.js.map +1 -0
- package/dist/Kernel/register-event-subscribers.test.d.ts +2 -0
- package/dist/Kernel/register-event-subscribers.test.d.ts.map +1 -0
- package/dist/Kernel/register-event-subscribers.test.js +19 -0
- package/dist/Kernel/register-event-subscribers.test.js.map +1 -0
- package/dist/Testing/TestAgentFactory.d.ts +1 -1
- package/dist/Testing/TestAgentFactory.d.ts.map +1 -1
- package/dist/Testing/TestAgentFactory.js +1 -1
- package/dist/Testing/TestAgentFactory.js.map +1 -1
- package/dist/{Application/types.d.ts → application/application.d.ts} +1 -1
- package/dist/application/application.d.ts.map +1 -0
- package/dist/application/application.js +1 -0
- package/dist/application/application.js.map +1 -0
- package/dist/{Application/ApplicationFactory.d.ts → application/create-application.d.ts} +2 -2
- package/dist/application/create-application.d.ts.map +1 -0
- package/dist/application/create-application.js +25 -0
- package/dist/application/create-application.js.map +1 -0
- package/dist/application/create-application.test.d.ts +2 -0
- package/dist/application/create-application.test.d.ts.map +1 -0
- package/dist/application/create-application.test.js +57 -0
- package/dist/application/create-application.test.js.map +1 -0
- package/dist/index.d.ts +20 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +17 -2
- package/dist/index.js.map +1 -1
- package/dist/routing/decorator/legacy-router.d.ts +10 -0
- package/dist/routing/decorator/legacy-router.d.ts.map +1 -0
- package/dist/routing/decorator/legacy-router.js +56 -0
- package/dist/routing/decorator/legacy-router.js.map +1 -0
- package/dist/routing/decorator/legacy-router.test.d.ts +2 -0
- package/dist/routing/decorator/legacy-router.test.d.ts.map +1 -0
- package/dist/routing/decorator/legacy-router.test.js +39 -0
- package/dist/routing/decorator/legacy-router.test.js.map +1 -0
- package/dist/routing/decorator/route-metadata.d.ts +15 -0
- package/dist/routing/decorator/route-metadata.d.ts.map +1 -0
- package/dist/routing/decorator/route-metadata.js +1 -0
- package/dist/routing/decorator/route-metadata.js.map +1 -0
- package/dist/routing/decorator/route.d.ts +18 -0
- package/dist/routing/decorator/route.d.ts.map +1 -0
- package/dist/routing/decorator/route.js +6 -0
- package/dist/routing/decorator/route.js.map +1 -0
- package/dist/routing/definition/create-route-definition.d.ts +15 -0
- package/dist/routing/definition/create-route-definition.d.ts.map +1 -0
- package/dist/routing/definition/create-route-definition.js +21 -0
- package/dist/routing/definition/create-route-definition.js.map +1 -0
- package/dist/routing/definition/create-route-definition.test.d.ts +2 -0
- package/dist/routing/definition/create-route-definition.test.d.ts.map +1 -0
- package/dist/routing/definition/create-route-definition.test.js +83 -0
- package/dist/routing/definition/create-route-definition.test.js.map +1 -0
- package/dist/routing/definition/resolve-route-options.d.ts +5 -0
- package/dist/routing/definition/resolve-route-options.d.ts.map +1 -0
- package/dist/routing/definition/resolve-route-options.js +20 -0
- package/dist/routing/definition/resolve-route-options.js.map +1 -0
- package/dist/routing/definition/resolve-route-options.test.d.ts +2 -0
- package/dist/routing/definition/resolve-route-options.test.d.ts.map +1 -0
- package/dist/routing/definition/resolve-route-options.test.js +60 -0
- package/dist/routing/definition/resolve-route-options.test.js.map +1 -0
- package/dist/routing/definition/route-definition.d.ts +13 -0
- package/dist/routing/definition/route-definition.d.ts.map +1 -0
- package/dist/routing/definition/route-definition.js +1 -0
- package/dist/routing/definition/route-definition.js.map +1 -0
- package/dist/routing/helpers/create-path-for.d.ts +7 -0
- package/dist/routing/helpers/create-path-for.d.ts.map +1 -0
- package/dist/routing/helpers/create-path-for.js +16 -0
- package/dist/routing/helpers/create-path-for.js.map +1 -0
- package/dist/routing/helpers/create-path-for.test.d.ts +2 -0
- package/dist/routing/helpers/create-path-for.test.d.ts.map +1 -0
- package/dist/routing/helpers/create-path-for.test.js +47 -0
- package/dist/routing/helpers/create-path-for.test.js.map +1 -0
- package/dist/routing/helpers/http-verb-helpers.d.ts +17 -0
- package/dist/routing/helpers/http-verb-helpers.d.ts.map +1 -0
- package/dist/routing/helpers/http-verb-helpers.js +32 -0
- package/dist/routing/helpers/http-verb-helpers.js.map +1 -0
- package/dist/routing/helpers/http-verb-helpers.test.d.ts +2 -0
- package/dist/routing/helpers/http-verb-helpers.test.d.ts.map +1 -0
- package/dist/routing/helpers/http-verb-helpers.test.js +52 -0
- package/dist/routing/helpers/http-verb-helpers.test.js.map +1 -0
- package/dist/routing/helpers/route-group.d.ts +17 -0
- package/dist/routing/helpers/route-group.d.ts.map +1 -0
- package/dist/routing/helpers/route-group.js +8 -0
- package/dist/routing/helpers/route-group.js.map +1 -0
- package/dist/routing/helpers/route-group.test.d.ts +2 -0
- package/dist/routing/helpers/route-group.test.d.ts.map +1 -0
- package/dist/routing/helpers/route-group.test.js +32 -0
- package/dist/routing/helpers/route-group.test.js.map +1 -0
- package/dist/routing/http-method.d.ts +2 -0
- package/dist/routing/http-method.d.ts.map +1 -0
- package/dist/routing/http-method.js +1 -0
- package/dist/routing/http-method.js.map +1 -0
- package/dist/routing/index.d.ts +10 -0
- package/dist/routing/index.d.ts.map +1 -0
- package/dist/routing/index.js +5 -0
- package/dist/routing/index.js.map +1 -0
- package/dist/routing/registration/expand-route-definitions.d.ts +4 -0
- package/dist/routing/registration/expand-route-definitions.d.ts.map +1 -0
- package/dist/routing/registration/expand-route-definitions.js +21 -0
- package/dist/routing/registration/expand-route-definitions.js.map +1 -0
- package/dist/routing/registration/expand-route-definitions.test.d.ts +2 -0
- package/dist/routing/registration/expand-route-definitions.test.d.ts.map +1 -0
- package/dist/routing/registration/expand-route-definitions.test.js +48 -0
- package/dist/routing/registration/expand-route-definitions.test.js.map +1 -0
- package/dist/routing/registration/register-routes.d.ts +4 -0
- package/dist/routing/registration/register-routes.d.ts.map +1 -0
- package/dist/routing/registration/register-routes.js +21 -0
- package/dist/routing/registration/register-routes.js.map +1 -0
- package/dist/routing/registration/register-routes.test.d.ts +2 -0
- package/dist/routing/registration/register-routes.test.d.ts.map +1 -0
- package/dist/routing/registration/register-routes.test.js +139 -0
- package/dist/routing/registration/register-routes.test.js.map +1 -0
- package/dist/routing/registration/route-registration.d.ts +8 -0
- package/dist/routing/registration/route-registration.d.ts.map +1 -0
- package/dist/routing/registration/route-registration.js +1 -0
- package/dist/routing/registration/route-registration.js.map +1 -0
- package/dist/routing/route-options.d.ts +5 -0
- package/dist/routing/route-options.d.ts.map +1 -0
- package/dist/routing/route-options.js +1 -0
- package/dist/routing/route-options.js.map +1 -0
- package/dist/routing/route.d.ts +14 -0
- package/dist/routing/route.d.ts.map +1 -0
- package/dist/routing/route.js +5 -0
- package/dist/routing/route.js.map +1 -0
- package/dist/routing/route.test.d.ts +2 -0
- package/dist/routing/route.test.d.ts.map +1 -0
- package/dist/routing/route.test.js +31 -0
- package/dist/routing/route.test.js.map +1 -0
- package/dist/routing/router-method.d.ts +2 -0
- package/dist/routing/router-method.d.ts.map +1 -0
- package/dist/routing/router-method.js +1 -0
- package/dist/routing/router-method.js.map +1 -0
- package/dist/routing/source/create-path-catalog.d.ts +3 -0
- package/dist/routing/source/create-path-catalog.d.ts.map +1 -0
- package/dist/routing/source/create-path-catalog.js +15 -0
- package/dist/routing/source/create-path-catalog.js.map +1 -0
- package/dist/routing/source/create-path-catalog.test.d.ts +2 -0
- package/dist/routing/source/create-path-catalog.test.d.ts.map +1 -0
- package/dist/routing/source/create-path-catalog.test.js +62 -0
- package/dist/routing/source/create-path-catalog.test.js.map +1 -0
- package/dist/routing/source/normalize-route-sources.d.ts +10 -0
- package/dist/routing/source/normalize-route-sources.d.ts.map +1 -0
- package/dist/routing/source/normalize-route-sources.js +82 -0
- package/dist/routing/source/normalize-route-sources.js.map +1 -0
- package/dist/routing/source/normalize-route-sources.test.d.ts +2 -0
- package/dist/routing/source/normalize-route-sources.test.d.ts.map +1 -0
- package/dist/routing/source/normalize-route-sources.test.js +268 -0
- package/dist/routing/source/normalize-route-sources.test.js.map +1 -0
- package/dist/routing/source/resolve-path-template.d.ts +6 -0
- package/dist/routing/source/resolve-path-template.d.ts.map +1 -0
- package/dist/routing/source/resolve-path-template.js +58 -0
- package/dist/routing/source/resolve-path-template.js.map +1 -0
- package/dist/routing/source/resolve-path-template.test.d.ts +2 -0
- package/dist/routing/source/resolve-path-template.test.d.ts.map +1 -0
- package/dist/routing/source/resolve-path-template.test.js +44 -0
- package/dist/routing/source/resolve-path-template.test.js.map +1 -0
- package/dist/routing/source/route-source.d.ts +4 -0
- package/dist/routing/source/route-source.d.ts.map +1 -0
- package/dist/routing/source/route-source.js +1 -0
- package/dist/routing/source/route-source.js.map +1 -0
- package/dist/routing/validation/validate-route-definitions.d.ts +4 -0
- package/dist/routing/validation/validate-route-definitions.d.ts.map +1 -0
- package/dist/routing/validation/validate-route-definitions.js +27 -0
- package/dist/routing/validation/validate-route-definitions.js.map +1 -0
- package/dist/routing/validation/validate-route-definitions.test.d.ts +2 -0
- package/dist/routing/validation/validate-route-definitions.test.d.ts.map +1 -0
- package/dist/routing/validation/validate-route-definitions.test.js +105 -0
- package/dist/routing/validation/validate-route-definitions.test.js.map +1 -0
- package/dist/routing/verify-routing-mode.d.ts +4 -0
- package/dist/routing/verify-routing-mode.d.ts.map +1 -0
- package/dist/routing/verify-routing-mode.js +8 -0
- package/dist/routing/verify-routing-mode.js.map +1 -0
- package/dist/routing/verify-routing-mode.test.d.ts +2 -0
- package/dist/routing/verify-routing-mode.test.d.ts.map +1 -0
- package/dist/routing/verify-routing-mode.test.js +24 -0
- package/dist/routing/verify-routing-mode.test.js.map +1 -0
- package/dist/validator/validator.test.js +2 -2
- package/dist/validator/validator.test.js.map +1 -1
- package/package.json +8 -7
- package/dist/Application/ApplicationFactory.d.ts.map +0 -1
- package/dist/Application/ApplicationFactory.js +0 -52
- package/dist/Application/ApplicationFactory.js.map +0 -1
- package/dist/Application/ApplicationFactory.test.d.ts +0 -2
- package/dist/Application/ApplicationFactory.test.d.ts.map +0 -1
- package/dist/Application/ApplicationFactory.test.js +0 -8
- package/dist/Application/ApplicationFactory.test.js.map +0 -1
- package/dist/Application/Response.d.ts +0 -4
- package/dist/Application/Response.d.ts.map +0 -1
- package/dist/Application/Response.js +0 -14
- package/dist/Application/Response.js.map +0 -1
- package/dist/Application/Response.test.d.ts +0 -2
- package/dist/Application/Response.test.d.ts.map +0 -1
- package/dist/Application/Response.test.js +0 -40
- package/dist/Application/Response.test.js.map +0 -1
- package/dist/Application/index.d.ts +0 -3
- package/dist/Application/index.d.ts.map +0 -1
- package/dist/Application/index.js +0 -2
- package/dist/Application/index.js.map +0 -1
- package/dist/Application/types.d.ts.map +0 -1
- package/dist/Application/types.js +0 -1
- package/dist/Application/types.js.map +0 -1
- package/dist/Kernel/HttpKernel.d.ts +0 -7
- package/dist/Kernel/HttpKernel.d.ts.map +0 -1
- package/dist/Kernel/HttpKernel.js +0 -15
- package/dist/Kernel/HttpKernel.js.map +0 -1
- package/dist/Kernel/HttpKernel.test.d.ts +0 -2
- package/dist/Kernel/HttpKernel.test.d.ts.map +0 -1
- package/dist/Kernel/HttpKernel.test.js.map +0 -1
- package/dist/Routing/Router.d.ts +0 -5
- package/dist/Routing/Router.d.ts.map +0 -1
- package/dist/Routing/Router.js +0 -40
- package/dist/Routing/Router.js.map +0 -1
- package/dist/Routing/Router.test.d.ts +0 -2
- package/dist/Routing/Router.test.d.ts.map +0 -1
- package/dist/Routing/Router.test.js +0 -121
- package/dist/Routing/Router.test.js.map +0 -1
- package/dist/Routing/index.d.ts +0 -4
- package/dist/Routing/index.d.ts.map +0 -1
- package/dist/Routing/index.js +0 -3
- package/dist/Routing/index.js.map +0 -1
- package/dist/Routing/types.d.ts +0 -22
- package/dist/Routing/types.d.ts.map +0 -1
- package/dist/Routing/types.js +0 -1
- package/dist/Routing/types.js.map +0 -1
package/dist/Config/types.d.ts
CHANGED
|
@@ -1,9 +1,17 @@
|
|
|
1
1
|
import { type HttpMiddleware } from '../Http/index.js';
|
|
2
2
|
import { type StaticFilesOptions } from '../Http/Files/index.js';
|
|
3
3
|
import { type EventSubscriber } from '../Kernel/index.js';
|
|
4
|
+
import type { RouteSource } from '../routing/index.js';
|
|
5
|
+
/**
|
|
6
|
+
* @deprecated Use function-first routes from `@koala-ts/framework/routing` with `KoalaConfig.routes` instead.
|
|
7
|
+
*/
|
|
4
8
|
export type Controller = new (...args: unknown[]) => unknown;
|
|
5
9
|
export interface KoalaConfig {
|
|
10
|
+
/**
|
|
11
|
+
* @deprecated Use `routes` with `Route` from `@koala-ts/framework/routing` instead.
|
|
12
|
+
*/
|
|
6
13
|
controllers: Controller[];
|
|
14
|
+
routes?: RouteSource[];
|
|
7
15
|
globalMiddleware?: HttpMiddleware[];
|
|
8
16
|
staticFiles?: StaticFilesOptions;
|
|
9
17
|
eventSubscribers?: Record<string, EventSubscriber | EventSubscriber[]>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/Config/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAE,MAAM,QAAQ,CAAC;AAC7C,OAAO,EAAE,KAAK,kBAAkB,EAAE,MAAM,cAAc,CAAC;AACvD,OAAO,EAAE,KAAK,eAAe,EAAE,MAAM,UAAU,CAAC;
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/Config/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAE,MAAM,QAAQ,CAAC;AAC7C,OAAO,EAAE,KAAK,kBAAkB,EAAE,MAAM,cAAc,CAAC;AACvD,OAAO,EAAE,KAAK,eAAe,EAAE,MAAM,UAAU,CAAC;AAChD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AAE7C;;GAEG;AACH,MAAM,MAAM,UAAU,GAAG,KAAK,GAAG,IAAI,EAAE,OAAO,EAAE,KAAK,OAAO,CAAC;AAE7D,MAAM,WAAW,WAAW;IAC1B;;OAEG;IACH,WAAW,EAAE,UAAU,EAAE,CAAC;IAC1B,MAAM,CAAC,EAAE,WAAW,EAAE,CAAC;IACvB,gBAAgB,CAAC,EAAE,cAAc,EAAE,CAAC;IACpC,WAAW,CAAC,EAAE,kBAAkB,CAAC;IACjC,gBAAgB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,GAAG,eAAe,EAAE,CAAC,CAAC;CACxE"}
|
|
@@ -12,28 +12,28 @@ describe('createStore', () => {
|
|
|
12
12
|
const store = createStore();
|
|
13
13
|
expect(() => {
|
|
14
14
|
store.set('id', 2);
|
|
15
|
-
}).
|
|
15
|
+
}).toThrow(ScopeStoreError);
|
|
16
16
|
expect(() => {
|
|
17
17
|
store.set('id', 2);
|
|
18
|
-
}).
|
|
18
|
+
}).toThrow('No active scope store found. Make sure to call set() within a run() context.');
|
|
19
19
|
});
|
|
20
20
|
test('get should fail if no active store found', () => {
|
|
21
21
|
const store = createStore();
|
|
22
22
|
expect(() => {
|
|
23
23
|
store.get('id');
|
|
24
|
-
}).
|
|
24
|
+
}).toThrow(ScopeStoreError);
|
|
25
25
|
});
|
|
26
26
|
test('has should fail if no active store found', () => {
|
|
27
27
|
const store = createStore();
|
|
28
28
|
expect(() => {
|
|
29
29
|
store.has('id');
|
|
30
|
-
}).
|
|
30
|
+
}).toThrow(ScopeStoreError);
|
|
31
31
|
});
|
|
32
32
|
test('all should fail if no active store found', () => {
|
|
33
33
|
const store = createStore();
|
|
34
34
|
expect(() => {
|
|
35
35
|
store.all();
|
|
36
|
-
}).
|
|
36
|
+
}).toThrow(ScopeStoreError);
|
|
37
37
|
});
|
|
38
38
|
test('set, get and all should work with active store', () => {
|
|
39
39
|
const store = createStore();
|
|
@@ -114,7 +114,7 @@ describe('createStore', () => {
|
|
|
114
114
|
store.run({ id: 1 }, () => {
|
|
115
115
|
throw new Error('callback error');
|
|
116
116
|
});
|
|
117
|
-
}).
|
|
117
|
+
}).toThrow('callback error');
|
|
118
118
|
});
|
|
119
119
|
test('supports complex state types', () => {
|
|
120
120
|
const store = createStore();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ScopeStoreFactory.test.js","sourceRoot":"","sources":["../../../../src/Http/Scope/State/ScopeStoreFactory.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AACpD,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAE1C,QAAQ,CAAC,aAAa,EAAE,GAAG,EAAE;IAC3B,IAAI,CAAC,sBAAsB,EAAE,GAAG,EAAE;QAChC,MAAM,KAAK,GAAG,WAAW,EAAkB,CAAC;QAC5C,MAAM,QAAQ,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC;QAEzB,KAAK,CAAC,GAAG,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,QAAQ,CAAC,CAAC;QAE/B,MAAM,CAAC,QAAQ,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;IAC5C,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,0CAA0C,EAAE,GAAG,EAAE;QACpD,MAAM,KAAK,GAAG,WAAW,EAAkB,CAAC;QAE5C,MAAM,CAAC,GAAG,EAAE;YACV,KAAK,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;QACrB,CAAC,CAAC,CAAC,
|
|
1
|
+
{"version":3,"file":"ScopeStoreFactory.test.js","sourceRoot":"","sources":["../../../../src/Http/Scope/State/ScopeStoreFactory.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/Http/Scope/index.ts"],"names":[],"mappings":"AAAA,mBAAmB,SAAS,CAAC;AAC7B,cAAc,SAAS,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/Http/Scope/index.ts"],"names":[],"mappings":"AAAA,mBAAmB,SAAS,CAAC;AAC7B,cAAc,oBAAoB,CAAC;AACnC,cAAc,SAAS,CAAC"}
|
package/dist/Http/Scope/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/Http/Scope/index.ts"],"names":[],"mappings":"AACA,cAAc,SAAS,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/Http/Scope/index.ts"],"names":[],"mappings":"AACA,cAAc,oBAAoB,CAAC;AACnC,cAAc,SAAS,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { type Next } from 'koa';
|
|
2
|
+
import { type HttpScope } from './types.js';
|
|
3
|
+
export type ScopeAwareApp = {
|
|
4
|
+
context: HttpScope;
|
|
5
|
+
scope: HttpScope;
|
|
6
|
+
};
|
|
7
|
+
export declare function initializeScope(scope: HttpScope, next: Next): Promise<void>;
|
|
8
|
+
//# sourceMappingURL=initialize-scope.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"initialize-scope.d.ts","sourceRoot":"","sources":["../../../src/Http/Scope/initialize-scope.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,IAAI,EAAE,MAAM,KAAK,CAAC;AAEhC,OAAO,EAAE,KAAK,SAAS,EAAE,MAAM,SAAS,CAAC;AAEzC,MAAM,MAAM,aAAa,GAAG;IAC1B,OAAO,EAAE,SAAS,CAAC;IACnB,KAAK,EAAE,SAAS,CAAC;CAClB,CAAC;AAmBF,wBAAsB,eAAe,CAAC,KAAK,EAAE,SAAS,EAAE,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAejF"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
function setHeader(name, value) {
|
|
2
|
+
const scope = this.ctx;
|
|
3
|
+
scope.set(name, value);
|
|
4
|
+
return this;
|
|
5
|
+
}
|
|
6
|
+
function withHeaders(headers) {
|
|
7
|
+
const scope = this.ctx;
|
|
8
|
+
for (const [name, value] of Object.entries(headers)) {
|
|
9
|
+
scope.set(name, value);
|
|
10
|
+
}
|
|
11
|
+
return this;
|
|
12
|
+
}
|
|
13
|
+
export async function initializeScope(scope, next) {
|
|
14
|
+
const app = scope.app;
|
|
15
|
+
if (app.scope !== app.context) {
|
|
16
|
+
app.scope = app.context;
|
|
17
|
+
}
|
|
18
|
+
if (scope.response.setHeader !== setHeader) {
|
|
19
|
+
scope.response.setHeader = setHeader;
|
|
20
|
+
}
|
|
21
|
+
if (scope.response.withHeaders !== withHeaders) {
|
|
22
|
+
scope.response.withHeaders = withHeaders;
|
|
23
|
+
}
|
|
24
|
+
await next();
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=initialize-scope.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"initialize-scope.js","sourceRoot":"","sources":["../../../src/Http/Scope/initialize-scope.ts"],"names":[],"mappings":"AASA,SAAS,SAAS,CAAqB,IAAY,EAAE,KAAwB;IAC3E,MAAM,KAAK,GAAG,IAAI,CAAC,GAAgB,CAAC;IACpC,KAAK,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;IAEvB,OAAO,IAAI,CAAC;AACd,CAAC;AAED,SAAS,WAAW,CAAqB,OAA0C;IACjF,MAAM,KAAK,GAAG,IAAI,CAAC,GAAgB,CAAC;IAEpC,KAAK,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC;QACpD,KAAK,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;IACzB,CAAC;IAED,OAAO,IAAI,CAAC;AACd,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,eAAe,CAAC,KAAgB,EAAE,IAAU;IAChE,MAAM,GAAG,GAAG,KAAK,CAAC,GAA+B,CAAC;IAClD,IAAI,GAAG,CAAC,KAAK,KAAK,GAAG,CAAC,OAAO,EAAE,CAAC;QAC9B,GAAG,CAAC,KAAK,GAAG,GAAG,CAAC,OAAO,CAAC;IAC1B,CAAC;IAED,IAAI,KAAK,CAAC,QAAQ,CAAC,SAAS,KAAK,SAAS,EAAE,CAAC;QAC3C,KAAK,CAAC,QAAQ,CAAC,SAAS,GAAG,SAAS,CAAC;IACvC,CAAC;IAED,IAAI,KAAK,CAAC,QAAQ,CAAC,WAAW,KAAK,WAAW,EAAE,CAAC;QAC/C,KAAK,CAAC,QAAQ,CAAC,WAAW,GAAG,WAAW,CAAC;IAC3C,CAAC;IAED,MAAM,IAAI,EAAE,CAAC;AACf,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"initialize-scope.test.d.ts","sourceRoot":"","sources":["../../../src/Http/Scope/initialize-scope.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { beforeEach, describe, expect, test, vi } from 'vitest';
|
|
2
|
+
import { initializeScope } from './initialize-scope.js';
|
|
3
|
+
describe('initializeScope', () => {
|
|
4
|
+
let scope;
|
|
5
|
+
let next;
|
|
6
|
+
beforeEach(() => {
|
|
7
|
+
scope = { app: { context: {} }, response: {}, set: vi.fn() };
|
|
8
|
+
scope.response.ctx = scope;
|
|
9
|
+
next = vi.fn();
|
|
10
|
+
});
|
|
11
|
+
test('sets the app scope alias from the application context', async () => {
|
|
12
|
+
await initializeScope(scope, next);
|
|
13
|
+
const app = scope.app;
|
|
14
|
+
expect(app.scope).toBe(app.context);
|
|
15
|
+
});
|
|
16
|
+
test('adds setHeader to the response', async () => {
|
|
17
|
+
await initializeScope(scope, next);
|
|
18
|
+
scope.response.setHeader('Content-Type', 'application/json');
|
|
19
|
+
expect(scope.set).toHaveBeenCalledWith('Content-Type', 'application/json');
|
|
20
|
+
});
|
|
21
|
+
test('returns the response from setHeader', async () => {
|
|
22
|
+
await initializeScope(scope, next);
|
|
23
|
+
const response = scope.response.setHeader('Content-Type', 'application/json');
|
|
24
|
+
expect(response).toBe(scope.response);
|
|
25
|
+
});
|
|
26
|
+
test('adds withHeaders to the response', async () => {
|
|
27
|
+
await initializeScope(scope, next);
|
|
28
|
+
scope.response.withHeaders({
|
|
29
|
+
'Content-Type': 'application/json',
|
|
30
|
+
'X-Custom-Header': 'value',
|
|
31
|
+
});
|
|
32
|
+
expect(scope.set).toHaveBeenCalledWith('Content-Type', 'application/json');
|
|
33
|
+
expect(scope.set).toHaveBeenCalledWith('X-Custom-Header', 'value');
|
|
34
|
+
});
|
|
35
|
+
test('returns the response from withHeaders', async () => {
|
|
36
|
+
await initializeScope(scope, next);
|
|
37
|
+
const response = scope.response.withHeaders({
|
|
38
|
+
'Content-Type': 'application/json',
|
|
39
|
+
'X-Custom-Header': 'value',
|
|
40
|
+
});
|
|
41
|
+
expect(response).toBe(scope.response);
|
|
42
|
+
});
|
|
43
|
+
test('does not replace response helpers when called twice', async () => {
|
|
44
|
+
await initializeScope(scope, next);
|
|
45
|
+
const setHeader = scope.response.setHeader;
|
|
46
|
+
const withHeaders = scope.response.withHeaders;
|
|
47
|
+
await initializeScope(scope, next);
|
|
48
|
+
expect(scope.response.setHeader).toBe(setHeader);
|
|
49
|
+
expect(scope.response.withHeaders).toBe(withHeaders);
|
|
50
|
+
});
|
|
51
|
+
test('does not replace the app scope alias when already initialized', async () => {
|
|
52
|
+
await initializeScope(scope, next);
|
|
53
|
+
const app = scope.app;
|
|
54
|
+
const currentScope = app.scope;
|
|
55
|
+
await initializeScope(scope, next);
|
|
56
|
+
expect(app.scope).toBe(currentScope);
|
|
57
|
+
});
|
|
58
|
+
test('calls next middleware', async () => {
|
|
59
|
+
await initializeScope(scope, next);
|
|
60
|
+
expect(next).toHaveBeenCalledTimes(1);
|
|
61
|
+
});
|
|
62
|
+
});
|
|
63
|
+
//# sourceMappingURL=initialize-scope.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"initialize-scope.test.js","sourceRoot":"","sources":["../../../src/Http/Scope/initialize-scope.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { type HttpRequest, type HttpResponse, type HttpScope, type NextMiddleware, type ScopeStore } from '../../Http/index.js';
|
|
2
|
+
export interface ScopeEventEmitter {
|
|
3
|
+
emit(event: string, ...args: unknown[]): void;
|
|
4
|
+
}
|
|
5
|
+
export interface ScopeStorage {
|
|
6
|
+
eventEmitter: ScopeEventEmitter;
|
|
7
|
+
scope: HttpScope;
|
|
8
|
+
}
|
|
9
|
+
export declare function initializeRequestScopeStorage(scope: HttpScope, next: NextMiddleware, storage?: ScopeStore<ScopeStorage>): Promise<void>;
|
|
10
|
+
export declare function useEmit(storage?: ScopeStore<ScopeStorage>): ScopeEventEmitter;
|
|
11
|
+
export declare function useRequest(storage?: ScopeStore<ScopeStorage>): HttpRequest;
|
|
12
|
+
export declare function useResponse(storage?: ScopeStore<ScopeStorage>): HttpResponse;
|
|
13
|
+
//# sourceMappingURL=request-scope-storage.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"request-scope-storage.d.ts","sourceRoot":"","sources":["../../../src/Http/Scope/request-scope-storage.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,KAAK,WAAW,EAChB,KAAK,YAAY,EACjB,KAAK,SAAS,EACd,KAAK,cAAc,EACnB,KAAK,UAAU,EAChB,MAAM,QAAQ,CAAC;AAEhB,MAAM,WAAW,iBAAiB;IAChC,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;CAC/C;AAED,MAAM,WAAW,YAAY;IAC3B,YAAY,EAAE,iBAAiB,CAAC;IAChC,KAAK,EAAE,SAAS,CAAC;CAClB;AAID,wBAAsB,6BAA6B,CACjD,KAAK,EAAE,SAAS,EAChB,IAAI,EAAE,cAAc,EACpB,OAAO,GAAE,UAAU,CAAC,YAAY,CAAuB,GACtD,OAAO,CAAC,IAAI,CAAC,CAEf;AAED,wBAAgB,OAAO,CAAC,OAAO,GAAE,UAAU,CAAC,YAAY,CAAuB,GAAG,iBAAiB,CAElG;AAED,wBAAgB,UAAU,CAAC,OAAO,GAAE,UAAU,CAAC,YAAY,CAAuB,GAAG,WAAW,CAE/F;AAED,wBAAgB,WAAW,CAAC,OAAO,GAAE,UAAU,CAAC,YAAY,CAAuB,GAAG,YAAY,CAEjG"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { createStore, } from '../../Http/index.js';
|
|
2
|
+
const requestScopeStorage = createStore();
|
|
3
|
+
export async function initializeRequestScopeStorage(scope, next, storage = requestScopeStorage) {
|
|
4
|
+
await storage.run({ eventEmitter: scope.app, scope }, next);
|
|
5
|
+
}
|
|
6
|
+
export function useEmit(storage = requestScopeStorage) {
|
|
7
|
+
return storage.get('eventEmitter');
|
|
8
|
+
}
|
|
9
|
+
export function useRequest(storage = requestScopeStorage) {
|
|
10
|
+
return storage.get('scope').request;
|
|
11
|
+
}
|
|
12
|
+
export function useResponse(storage = requestScopeStorage) {
|
|
13
|
+
return storage.get('scope').response;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=request-scope-storage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"request-scope-storage.js","sourceRoot":"","sources":["../../../src/Http/Scope/request-scope-storage.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,WAAW,GAMZ,MAAM,QAAQ,CAAC;AAWhB,MAAM,mBAAmB,GAAG,WAAW,EAAgB,CAAC;AAExD,MAAM,CAAC,KAAK,UAAU,6BAA6B,CACjD,KAAgB,EAChB,IAAoB,EACpB,UAAoC,mBAAmB;IAEvD,MAAM,OAAO,CAAC,GAAG,CAAC,EAAE,YAAY,EAAE,KAAK,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,IAAI,CAAC,CAAC;AAC9D,CAAC;AAED,MAAM,UAAU,OAAO,CAAC,UAAoC,mBAAmB;IAC7E,OAAO,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;AACrC,CAAC;AAED,MAAM,UAAU,UAAU,CAAC,UAAoC,mBAAmB;IAChF,OAAO,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC;AACtC,CAAC;AAED,MAAM,UAAU,WAAW,CAAC,UAAoC,mBAAmB;IACjF,OAAO,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC;AACvC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"request-scope-storage.test.d.ts","sourceRoot":"","sources":["../../../src/Http/Scope/request-scope-storage.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import { describe, expect, test, vi } from 'vitest';
|
|
2
|
-
import {
|
|
3
|
-
describe('
|
|
2
|
+
import { initializeRequestScopeStorage, useEmit, useRequest, useResponse, } from './request-scope-storage.js';
|
|
3
|
+
describe('request scope storage', () => {
|
|
4
4
|
test('middleware should init storage', async () => {
|
|
5
5
|
const scope = { app: vi.fn() };
|
|
6
6
|
const next = vi.fn();
|
|
7
7
|
const storage = { run: vi.fn() };
|
|
8
|
-
await
|
|
8
|
+
await initializeRequestScopeStorage(scope, next, storage);
|
|
9
9
|
expect(storage.run).toHaveBeenCalledWith({ eventEmitter: scope.app, scope }, next);
|
|
10
10
|
});
|
|
11
11
|
test('useEmit should return emitter from storage', () => {
|
|
@@ -29,4 +29,4 @@ describe('Http Kernel', () => {
|
|
|
29
29
|
expect(res).toBe(response);
|
|
30
30
|
});
|
|
31
31
|
});
|
|
32
|
-
//# sourceMappingURL=
|
|
32
|
+
//# sourceMappingURL=request-scope-storage.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"request-scope-storage.test.js","sourceRoot":"","sources":["../../../src/Http/Scope/request-scope-storage.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAEpD,OAAO,EACL,6BAA6B,EAE7B,OAAO,EACP,UAAU,EACV,WAAW,GACZ,MAAM,yBAAyB,CAAC;AAEjC,QAAQ,CAAC,uBAAuB,EAAE,GAAG,EAAE;IACrC,IAAI,CAAC,gCAAgC,EAAE,KAAK,IAAI,EAAE;QAChD,MAAM,KAAK,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC;QAC/B,MAAM,IAAI,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC;QACrB,MAAM,OAAO,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC;QAEjC,MAAM,6BAA6B,CACjC,KAA6B,EAC7B,IAAI,EACJ,OAA8C,CAC/C,CAAC;QAEF,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,oBAAoB,CAAC,EAAE,YAAY,EAAE,KAAK,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,IAAI,CAAC,CAAC;IACrF,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,4CAA4C,EAAE,GAAG,EAAE;QACtD,MAAM,OAAO,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,eAAe,CAAC,cAAc,CAAC,EAAE,CAAC;QAEjE,MAAM,OAAO,GAAG,OAAO,CAAC,OAA8C,CAAC,CAAC;QAExE,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,oBAAoB,CAAC,cAAc,CAAC,CAAC;QACzD,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,+CAA+C,EAAE,GAAG,EAAE;QACzD,MAAM,OAAO,GAAG,EAAE,OAAO,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE,EAAE,CAAC;QACnD,MAAM,OAAO,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,eAAe,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC;QAE9D,MAAM,GAAG,GAAG,UAAU,CAAC,OAA8C,CAAC,CAAC;QAEvE,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,oBAAoB,CAAC,OAAO,CAAC,CAAC;QAClD,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAC5B,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,iDAAiD,EAAE,GAAG,EAAE;QAC3D,MAAM,QAAQ,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;QAC7C,MAAM,OAAO,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,eAAe,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,CAAC;QAE/D,MAAM,GAAG,GAAG,WAAW,CAAC,OAA8C,CAAC,CAAC;QAExE,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,oBAAoB,CAAC,OAAO,CAAC,CAAC;QAClD,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC7B,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"apply-configured-global-middleware.d.ts","sourceRoot":"","sources":["../../../src/Http/middleware/apply-configured-global-middleware.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAE,MAAM,QAAQ,CAAC;AAE7C,wBAAgB,+BAA+B,CAAC,UAAU,GAAE,cAAc,EAAE,GAAG,SAAc,GAAG,cAAc,CAW7G"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export function applyConfiguredGlobalMiddleware(middleware = []) {
|
|
2
|
+
return async (scope, next) => {
|
|
3
|
+
const pipeline = middleware.reduceRight((stack, current) => {
|
|
4
|
+
return async () => await current(scope, stack);
|
|
5
|
+
}, async () => await next());
|
|
6
|
+
await pipeline();
|
|
7
|
+
};
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=apply-configured-global-middleware.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"apply-configured-global-middleware.js","sourceRoot":"","sources":["../../../src/Http/middleware/apply-configured-global-middleware.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,+BAA+B,CAAC,aAA2C,EAAE;IAC3F,OAAO,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;QAC3B,MAAM,QAAQ,GAAG,UAAU,CAAC,WAAW,CACrC,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE;YACjB,OAAO,KAAK,IAAI,EAAE,CAAC,MAAM,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QACjD,CAAC,EACD,KAAK,IAAI,EAAE,CAAC,MAAM,IAAI,EAAE,CACzB,CAAC;QAEF,MAAM,QAAQ,EAAE,CAAC;IACnB,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"apply-configured-global-middleware.test.d.ts","sourceRoot":"","sources":["../../../src/Http/middleware/apply-configured-global-middleware.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { describe, expect, test, vi } from 'vitest';
|
|
2
|
+
import { applyConfiguredGlobalMiddleware } from './apply-configured-global-middleware.js';
|
|
3
|
+
describe('applyConfiguredGlobalMiddleware', () => {
|
|
4
|
+
test('continues to next middleware when undefined', async () => {
|
|
5
|
+
const middleware = applyConfiguredGlobalMiddleware(undefined);
|
|
6
|
+
const scope = {};
|
|
7
|
+
const next = vi.fn();
|
|
8
|
+
await middleware(scope, next);
|
|
9
|
+
expect(next).toHaveBeenCalledTimes(1);
|
|
10
|
+
});
|
|
11
|
+
test('continues to next middleware when empty', async () => {
|
|
12
|
+
const middleware = applyConfiguredGlobalMiddleware([]);
|
|
13
|
+
const scope = {};
|
|
14
|
+
const next = vi.fn();
|
|
15
|
+
await middleware(scope, next);
|
|
16
|
+
expect(next).toHaveBeenCalledTimes(1);
|
|
17
|
+
});
|
|
18
|
+
test('runs a single middleware', async () => {
|
|
19
|
+
const calls = [];
|
|
20
|
+
const configuredMiddleware = async (_scope, next) => {
|
|
21
|
+
calls.push('configured');
|
|
22
|
+
await next();
|
|
23
|
+
};
|
|
24
|
+
const middleware = applyConfiguredGlobalMiddleware([configuredMiddleware]);
|
|
25
|
+
const scope = {};
|
|
26
|
+
const next = vi.fn(async () => {
|
|
27
|
+
calls.push('next');
|
|
28
|
+
});
|
|
29
|
+
await middleware(scope, next);
|
|
30
|
+
expect(calls).toEqual(['configured', 'next']);
|
|
31
|
+
});
|
|
32
|
+
test('runs configured middleware in order', async () => {
|
|
33
|
+
const calls = [];
|
|
34
|
+
const firstMiddleware = async (_scope, next) => {
|
|
35
|
+
calls.push('first-before');
|
|
36
|
+
await next();
|
|
37
|
+
calls.push('first-after');
|
|
38
|
+
};
|
|
39
|
+
const secondMiddleware = async (_scope, next) => {
|
|
40
|
+
calls.push('second-before');
|
|
41
|
+
await next();
|
|
42
|
+
calls.push('second-after');
|
|
43
|
+
};
|
|
44
|
+
const middleware = applyConfiguredGlobalMiddleware([firstMiddleware, secondMiddleware]);
|
|
45
|
+
const scope = {};
|
|
46
|
+
const next = vi.fn(async () => {
|
|
47
|
+
calls.push('next');
|
|
48
|
+
});
|
|
49
|
+
await middleware(scope, next);
|
|
50
|
+
expect(calls).toEqual(['first-before', 'second-before', 'next', 'second-after', 'first-after']);
|
|
51
|
+
});
|
|
52
|
+
});
|
|
53
|
+
//# sourceMappingURL=apply-configured-global-middleware.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"apply-configured-global-middleware.test.js","sourceRoot":"","sources":["../../../src/Http/middleware/apply-configured-global-middleware.test.ts"],"names":[],"mappings":"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"}
|
package/dist/Kernel/index.d.ts
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
1
|
export * from './types.js';
|
|
2
|
-
export
|
|
2
|
+
export { registerEventSubscribers } from '../Kernel/register-event-subscribers.js';
|
|
3
|
+
export { initializeRequestScopeStorage, useEmit, useRequest, useResponse } from '../Http/Scope/request-scope-storage.js';
|
|
3
4
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/Kernel/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AACxB,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/Kernel/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AACxB,OAAO,EAAE,wBAAwB,EAAE,MAAM,qCAAqC,CAAC;AAC/E,OAAO,EAAE,6BAA6B,EAAE,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,oCAAoC,CAAC"}
|
package/dist/Kernel/index.js
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
1
|
export * from './types.js';
|
|
2
|
-
export
|
|
2
|
+
export { registerEventSubscribers } from '../Kernel/register-event-subscribers.js';
|
|
3
|
+
export { initializeRequestScopeStorage, useEmit, useRequest, useResponse } from '../Http/Scope/request-scope-storage.js';
|
|
3
4
|
//# sourceMappingURL=index.js.map
|
package/dist/Kernel/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/Kernel/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AACxB,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/Kernel/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AACxB,OAAO,EAAE,wBAAwB,EAAE,MAAM,qCAAqC,CAAC;AAC/E,OAAO,EAAE,6BAA6B,EAAE,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,oCAAoC,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { type Application } from '../application/application.js';
|
|
2
|
+
import { type EventSubscriber } from '../Kernel/types.js';
|
|
3
|
+
export declare function registerEventSubscribers(app: Application, map: Record<string, EventSubscriber | EventSubscriber[]> | undefined): void;
|
|
4
|
+
//# sourceMappingURL=register-event-subscribers.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"register-event-subscribers.d.ts","sourceRoot":"","sources":["../../src/Kernel/register-event-subscribers.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,WAAW,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAAE,KAAK,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAEtD,wBAAgB,wBAAwB,CACtC,GAAG,EAAE,WAAW,EAChB,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,GAAG,eAAe,EAAE,CAAC,GAAG,SAAS,GACnE,IAAI,CAQN"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
export function registerEventSubscribers(app, map) {
|
|
2
|
+
if (undefined === map) {
|
|
3
|
+
return;
|
|
4
|
+
}
|
|
5
|
+
for (const [event, subscriber] of normalizeEventSubscribers(map)) {
|
|
6
|
+
app.on(event, subscriber);
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
function normalizeEventSubscribers(map) {
|
|
10
|
+
const subscriptions = [];
|
|
11
|
+
for (const [event, subscribers] of Object.entries(map)) {
|
|
12
|
+
if (Array.isArray(subscribers)) {
|
|
13
|
+
for (const subscriber of subscribers) {
|
|
14
|
+
subscriptions.push([event, subscriber]);
|
|
15
|
+
}
|
|
16
|
+
continue;
|
|
17
|
+
}
|
|
18
|
+
subscriptions.push([event, subscribers]);
|
|
19
|
+
}
|
|
20
|
+
return subscriptions;
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=register-event-subscribers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"register-event-subscribers.js","sourceRoot":"","sources":["../../src/Kernel/register-event-subscribers.ts"],"names":[],"mappings":"AAGA,MAAM,UAAU,wBAAwB,CACtC,GAAgB,EAChB,GAAoE;IAEpE,IAAI,SAAS,KAAK,GAAG,EAAE,CAAC;QACtB,OAAO;IACT,CAAC;IAED,KAAK,MAAM,CAAC,KAAK,EAAE,UAAU,CAAC,IAAI,yBAAyB,CAAC,GAAG,CAAC,EAAE,CAAC;QACjE,GAAG,CAAC,EAAE,CAAC,KAAK,EAAE,UAAqD,CAAC,CAAC;IACvE,CAAC;AACH,CAAC;AAED,SAAS,yBAAyB,CAChC,GAAwD;IAExD,MAAM,aAAa,GAAqC,EAAE,CAAC;IAE3D,KAAK,MAAM,CAAC,KAAK,EAAE,WAAW,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC;QACvD,IAAI,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE,CAAC;YAC/B,KAAK,MAAM,UAAU,IAAI,WAAW,EAAE,CAAC;gBACrC,aAAa,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC,CAAC;YAC1C,CAAC;YAED,SAAS;QACX,CAAC;QAED,aAAa,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC,CAAC;IAC3C,CAAC;IAED,OAAO,aAAa,CAAC;AACvB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"register-event-subscribers.test.d.ts","sourceRoot":"","sources":["../../src/Kernel/register-event-subscribers.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { registerEventSubscribers } from '../Kernel/index.js';
|
|
2
|
+
import { expect, test, vi } from 'vitest';
|
|
3
|
+
test('register a single event subscriber', () => {
|
|
4
|
+
const on = vi.fn();
|
|
5
|
+
const app = { on };
|
|
6
|
+
const subscriber = vi.fn();
|
|
7
|
+
registerEventSubscribers(app, { requestCompleted: subscriber });
|
|
8
|
+
expect(on).toHaveBeenCalledWith('requestCompleted', subscriber);
|
|
9
|
+
});
|
|
10
|
+
test('register multiple event subscribers', () => {
|
|
11
|
+
const on = vi.fn();
|
|
12
|
+
const app = { on };
|
|
13
|
+
const firstSubscriber = vi.fn();
|
|
14
|
+
const secondSubscriber = vi.fn();
|
|
15
|
+
registerEventSubscribers(app, { requestCompleted: [firstSubscriber, secondSubscriber] });
|
|
16
|
+
expect(on).toHaveBeenNthCalledWith(1, 'requestCompleted', firstSubscriber);
|
|
17
|
+
expect(on).toHaveBeenNthCalledWith(2, 'requestCompleted', secondSubscriber);
|
|
18
|
+
});
|
|
19
|
+
//# sourceMappingURL=register-event-subscribers.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"register-event-subscribers.test.js","sourceRoot":"","sources":["../../src/Kernel/register-event-subscribers.test.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,wBAAwB,EAAE,MAAM,UAAU,CAAC;AACpD,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAE1C,IAAI,CAAC,oCAAoC,EAAE,GAAG,EAAE;IAC9C,MAAM,EAAE,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC;IACnB,MAAM,GAAG,GAAG,EAAE,EAAE,EAA4B,CAAC;IAC7C,MAAM,UAAU,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC;IAE3B,wBAAwB,CAAC,GAAG,EAAE,EAAE,gBAAgB,EAAE,UAAU,EAAE,CAAC,CAAC;IAEhE,MAAM,CAAC,EAAE,CAAC,CAAC,oBAAoB,CAAC,kBAAkB,EAAE,UAAU,CAAC,CAAC;AAClE,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,qCAAqC,EAAE,GAAG,EAAE;IAC/C,MAAM,EAAE,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC;IACnB,MAAM,GAAG,GAAG,EAAE,EAAE,EAA4B,CAAC;IAC7C,MAAM,eAAe,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC;IAChC,MAAM,gBAAgB,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC;IAEjC,wBAAwB,CAAC,GAAG,EAAE,EAAE,gBAAgB,EAAE,CAAC,eAAe,EAAE,gBAAgB,CAAC,EAAE,CAAC,CAAC;IAEzF,MAAM,CAAC,EAAE,CAAC,CAAC,uBAAuB,CAAC,CAAC,EAAE,kBAAkB,EAAE,eAAe,CAAC,CAAC;IAC3E,MAAM,CAAC,EAAE,CAAC,CAAC,uBAAuB,CAAC,CAAC,EAAE,kBAAkB,EAAE,gBAAgB,CAAC,CAAC;AAC9E,CAAC,CAAC,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { type TestAgent } from './types.js';
|
|
2
1
|
import { type KoalaConfig } from '../Config/index.js';
|
|
3
2
|
import { type User } from '../Security/types.js';
|
|
3
|
+
import { type TestAgent } from './types.js';
|
|
4
4
|
export declare function createTestAgent(config: KoalaConfig, agentConfig?: {
|
|
5
5
|
actAs?: User;
|
|
6
6
|
}): TestAgent;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TestAgentFactory.d.ts","sourceRoot":"","sources":["../../src/Testing/TestAgentFactory.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,
|
|
1
|
+
{"version":3,"file":"TestAgentFactory.d.ts","sourceRoot":"","sources":["../../src/Testing/TestAgentFactory.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,WAAW,EAAE,MAAM,UAAU,CAAC;AAE5C,OAAO,EAAE,KAAK,IAAI,EAAE,MAAM,kBAAkB,CAAC;AAE7C,OAAO,EAAE,KAAK,SAAS,EAAE,MAAM,SAAS,CAAC;AAEzC,wBAAgB,eAAe,CAAC,MAAM,EAAE,WAAW,EAAE,WAAW,CAAC,EAAE;IAAE,KAAK,CAAC,EAAE,IAAI,CAAA;CAAE,GAAG,SAAS,CAW9F"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
+
import { create } from '../application/create-application.js';
|
|
1
2
|
import supertest from 'supertest';
|
|
2
|
-
import { create } from '../Application/index.js';
|
|
3
3
|
export function createTestAgent(config, agentConfig) {
|
|
4
4
|
const globalMiddleware = config.globalMiddleware ?? [];
|
|
5
5
|
const testConfig = { ...config };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TestAgentFactory.js","sourceRoot":"","sources":["../../src/Testing/TestAgentFactory.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"TestAgentFactory.js","sourceRoot":"","sources":["../../src/Testing/TestAgentFactory.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,kCAAkC,CAAC;AAI1D,OAAO,SAAS,MAAM,WAAW,CAAC;AAGlC,MAAM,UAAU,eAAe,CAAC,MAAmB,EAAE,WAA8B;IACjF,MAAM,gBAAgB,GAAG,MAAM,CAAC,gBAAgB,IAAI,EAAE,CAAC;IACvD,MAAM,UAAU,GAAG,EAAE,GAAG,MAAM,EAAE,CAAC;IAEjC,MAAM,EAAE,KAAK,EAAE,GAAG,WAAW,IAAI,EAAE,CAAC;IAEpC,IAAI,SAAS,KAAK,KAAK,EAAE,CAAC;QACxB,UAAU,CAAC,gBAAgB,GAAG,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,GAAG,gBAAgB,CAAC,CAAC;IACxE,CAAC;IAED,OAAO,SAAS,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC;AAClD,CAAC;AAED,SAAS,SAAS,CAAC,IAAU;IAC3B,OAAO,KAAK,UAAU,mBAAmB,CAAC,KAAgB,EAAE,IAAoB;QAC9E,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC;QAClB,MAAM,IAAI,EAAE,CAAC;IACf,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"application.d.ts","sourceRoot":"","sources":["../../src/application/application.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,GAAG,MAAM,KAAK,CAAC;AAC3B,OAAO,KAAK,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAC;AAElD,MAAM,MAAM,WAAW,CAAC,MAAM,GAAG,QAAQ,EAAE,MAAM,GAAG,SAAS,IAAI,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG;IACrF,KAAK,EAAE,SAAS,CAAC;CAClB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
//# sourceMappingURL=application.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"application.js","sourceRoot":"","sources":["../../src/application/application.ts"],"names":[],"mappings":""}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { type Application } from './types.js';
|
|
2
1
|
import { type KoalaConfig } from '../Config/index.js';
|
|
2
|
+
import { type Application } from './application.js';
|
|
3
3
|
export declare function create(config: KoalaConfig): Application;
|
|
4
|
-
//# sourceMappingURL=
|
|
4
|
+
//# sourceMappingURL=create-application.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-application.d.ts","sourceRoot":"","sources":["../../src/application/create-application.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,WAAW,EAAE,MAAM,UAAU,CAAC;AAU5C,OAAO,EAAE,KAAK,WAAW,EAAE,MAAM,eAAe,CAAC;AAEjD,wBAAgB,MAAM,CAAC,MAAM,EAAE,WAAW,GAAG,WAAW,CAmBvD"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { initializeScope } from '../Http/index.js';
|
|
2
|
+
import { serveStaticFiles } from '../Http/Files/index.js';
|
|
3
|
+
import { applyConfiguredGlobalMiddleware } from '../Http/middleware/apply-configured-global-middleware.js';
|
|
4
|
+
import { initializeRequestScopeStorage } from '../Http/Scope/request-scope-storage.js';
|
|
5
|
+
import { registerEventSubscribers } from '../Kernel/index.js';
|
|
6
|
+
import { registerLegacyRoutes } from '../routing/decorator/legacy-router.js';
|
|
7
|
+
import { registerRoutes } from '../routing/registration/register-routes.js';
|
|
8
|
+
import { verifyRoutingMode } from '../routing/verify-routing-mode.js';
|
|
9
|
+
import Koa from 'koa';
|
|
10
|
+
export function create(config) {
|
|
11
|
+
const app = new Koa();
|
|
12
|
+
const controllers = config.controllers ?? [];
|
|
13
|
+
app.use(initializeScope);
|
|
14
|
+
app.use(initializeRequestScopeStorage);
|
|
15
|
+
app.use(applyConfiguredGlobalMiddleware(config.globalMiddleware));
|
|
16
|
+
app.use(serveStaticFiles(config.staticFiles));
|
|
17
|
+
verifyRoutingMode(config);
|
|
18
|
+
if (config.routes === undefined || controllers.length > 0) {
|
|
19
|
+
registerLegacyRoutes(app);
|
|
20
|
+
}
|
|
21
|
+
registerRoutes(app, config.routes);
|
|
22
|
+
registerEventSubscribers(app, config.eventSubscribers);
|
|
23
|
+
return app;
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=create-application.js.map
|