@haskou/ddd-kernel 0.1.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/LICENSE +21 -0
- package/README.md +143 -0
- package/dist/Constructor-fyZLLIh8.d.cts +5 -0
- package/dist/Constructor-fyZLLIh8.d.ts +5 -0
- package/dist/Consumer-CC8ZRCsd.d.cts +17 -0
- package/dist/Consumer-CeT0Wbxb.d.ts +17 -0
- package/dist/DomainEvent-mXWEtr_J.d.cts +26 -0
- package/dist/DomainEvent-mXWEtr_J.d.ts +26 -0
- package/dist/DomainEventConsumer-3WBMSSr2.d.cts +7 -0
- package/dist/DomainEventConsumer-B4hkIUmP.d.ts +7 -0
- package/dist/DomainEventPublisher-8G0lvmdy.d.cts +7 -0
- package/dist/DomainEventPublisher-DhGgM3f2.d.ts +7 -0
- package/dist/HandlerContext-DUUExVo3.d.ts +20 -0
- package/dist/HandlerContext-Lm89pSeG.d.cts +20 -0
- package/dist/Kernel-BWUOUWWI.d.cts +70 -0
- package/dist/Kernel-CUaqHa1s.d.ts +70 -0
- package/dist/KernelLogger-BESOFrpW.d.cts +8 -0
- package/dist/KernelLogger-BESOFrpW.d.ts +8 -0
- package/dist/Log-36L3Z84a.d.cts +8 -0
- package/dist/Log-36L3Z84a.d.ts +8 -0
- package/dist/NoFailedMessagesError-0YJKRWPF.d.ts +45 -0
- package/dist/NoFailedMessagesError-Kz7CYWpT.d.cts +45 -0
- package/dist/Repository-D9CuAyCV.d.cts +7 -0
- package/dist/Repository-D9CuAyCV.d.ts +7 -0
- package/dist/Scheduler-oigqNOUJ.d.cts +27 -0
- package/dist/Scheduler-oigqNOUJ.d.ts +27 -0
- package/dist/ServiceClass-BmNw8fJj.d.cts +37 -0
- package/dist/ServiceClass-C7NCKdSS.d.ts +37 -0
- package/dist/ServiceResolver-D2Jz-l_Z.d.cts +5 -0
- package/dist/ServiceResolver-D2Jz-l_Z.d.ts +5 -0
- package/dist/ShutdownHook-BGskq2-q.d.ts +9 -0
- package/dist/ShutdownHook-Dib5uNKB.d.cts +9 -0
- package/dist/Subscription-Bwkb_did.d.ts +9 -0
- package/dist/Subscription-P9WROD_6.d.cts +9 -0
- package/dist/adapters/db/in-memory/index.cjs +46 -0
- package/dist/adapters/db/in-memory/index.cjs.map +1 -0
- package/dist/adapters/db/in-memory/index.d.cts +12 -0
- package/dist/adapters/db/in-memory/index.d.ts +12 -0
- package/dist/adapters/db/in-memory/index.js +19 -0
- package/dist/adapters/db/in-memory/index.js.map +1 -0
- package/dist/adapters/db/index.cjs +80 -0
- package/dist/adapters/db/index.cjs.map +1 -0
- package/dist/adapters/db/index.d.cts +4 -0
- package/dist/adapters/db/index.d.ts +4 -0
- package/dist/adapters/db/index.js +52 -0
- package/dist/adapters/db/index.js.map +1 -0
- package/dist/adapters/db/mongo/index.cjs +62 -0
- package/dist/adapters/db/mongo/index.cjs.map +1 -0
- package/dist/adapters/db/mongo/index.d.cts +22 -0
- package/dist/adapters/db/mongo/index.d.ts +22 -0
- package/dist/adapters/db/mongo/index.js +35 -0
- package/dist/adapters/db/mongo/index.js.map +1 -0
- package/dist/adapters/index.cjs +651 -0
- package/dist/adapters/index.cjs.map +1 -0
- package/dist/adapters/index.d.cts +26 -0
- package/dist/adapters/index.d.ts +26 -0
- package/dist/adapters/index.js +609 -0
- package/dist/adapters/index.js.map +1 -0
- package/dist/adapters/kernel/console/index.cjs +46 -0
- package/dist/adapters/kernel/console/index.cjs.map +1 -0
- package/dist/adapters/kernel/console/index.d.cts +10 -0
- package/dist/adapters/kernel/console/index.d.ts +10 -0
- package/dist/adapters/kernel/console/index.js +19 -0
- package/dist/adapters/kernel/console/index.js.map +1 -0
- package/dist/adapters/kernel/index.cjs +46 -0
- package/dist/adapters/kernel/index.cjs.map +1 -0
- package/dist/adapters/kernel/index.d.cts +2 -0
- package/dist/adapters/kernel/index.d.ts +2 -0
- package/dist/adapters/kernel/index.js +19 -0
- package/dist/adapters/kernel/index.js.map +1 -0
- package/dist/adapters/pubsub/amqp/index.cjs +724 -0
- package/dist/adapters/pubsub/amqp/index.cjs.map +1 -0
- package/dist/adapters/pubsub/amqp/index.d.cts +42 -0
- package/dist/adapters/pubsub/amqp/index.d.ts +42 -0
- package/dist/adapters/pubsub/amqp/index.js +691 -0
- package/dist/adapters/pubsub/amqp/index.js.map +1 -0
- package/dist/adapters/pubsub/in-memory/index.cjs +79 -0
- package/dist/adapters/pubsub/in-memory/index.cjs.map +1 -0
- package/dist/adapters/pubsub/in-memory/index.d.cts +21 -0
- package/dist/adapters/pubsub/in-memory/index.d.ts +21 -0
- package/dist/adapters/pubsub/in-memory/index.js +51 -0
- package/dist/adapters/pubsub/in-memory/index.js.map +1 -0
- package/dist/adapters/pubsub/index.cjs +492 -0
- package/dist/adapters/pubsub/index.cjs.map +1 -0
- package/dist/adapters/pubsub/index.d.cts +11 -0
- package/dist/adapters/pubsub/index.d.ts +11 -0
- package/dist/adapters/pubsub/index.js +456 -0
- package/dist/adapters/pubsub/index.js.map +1 -0
- package/dist/adapters/ui/express/index.cjs +126 -0
- package/dist/adapters/ui/express/index.cjs.map +1 -0
- package/dist/adapters/ui/express/index.d.cts +49 -0
- package/dist/adapters/ui/express/index.d.ts +49 -0
- package/dist/adapters/ui/express/index.js +98 -0
- package/dist/adapters/ui/express/index.js.map +1 -0
- package/dist/adapters/ui/index.cjs +489 -0
- package/dist/adapters/ui/index.cjs.map +1 -0
- package/dist/adapters/ui/index.d.cts +14 -0
- package/dist/adapters/ui/index.d.ts +14 -0
- package/dist/adapters/ui/index.js +455 -0
- package/dist/adapters/ui/index.js.map +1 -0
- package/dist/adapters/ui/routes/index.cjs +393 -0
- package/dist/adapters/ui/routes/index.cjs.map +1 -0
- package/dist/adapters/ui/routes/index.d.cts +5 -0
- package/dist/adapters/ui/routes/index.d.ts +5 -0
- package/dist/adapters/ui/routes/index.js +361 -0
- package/dist/adapters/ui/routes/index.js.map +1 -0
- package/dist/contracts/db/index.cjs +19 -0
- package/dist/contracts/db/index.cjs.map +1 -0
- package/dist/contracts/db/index.d.cts +7 -0
- package/dist/contracts/db/index.d.ts +7 -0
- package/dist/contracts/db/index.js +1 -0
- package/dist/contracts/db/index.js.map +1 -0
- package/dist/contracts/index.cjs +49 -0
- package/dist/contracts/index.cjs.map +1 -0
- package/dist/contracts/index.d.cts +11 -0
- package/dist/contracts/index.d.ts +11 -0
- package/dist/contracts/index.js +22 -0
- package/dist/contracts/index.js.map +1 -0
- package/dist/contracts/kernel/index.cjs +19 -0
- package/dist/contracts/kernel/index.cjs.map +1 -0
- package/dist/contracts/kernel/index.d.cts +9 -0
- package/dist/contracts/kernel/index.d.ts +9 -0
- package/dist/contracts/kernel/index.js +1 -0
- package/dist/contracts/kernel/index.js.map +1 -0
- package/dist/contracts/pubsub/index.cjs +19 -0
- package/dist/contracts/pubsub/index.cjs.map +1 -0
- package/dist/contracts/pubsub/index.d.cts +26 -0
- package/dist/contracts/pubsub/index.d.ts +26 -0
- package/dist/contracts/pubsub/index.js +1 -0
- package/dist/contracts/pubsub/index.js.map +1 -0
- package/dist/contracts/ui/index.cjs +49 -0
- package/dist/contracts/ui/index.cjs.map +1 -0
- package/dist/contracts/ui/index.d.cts +29 -0
- package/dist/contracts/ui/index.d.ts +29 -0
- package/dist/contracts/ui/index.js +22 -0
- package/dist/contracts/ui/index.js.map +1 -0
- package/dist/domain/index.cjs +121 -0
- package/dist/domain/index.cjs.map +1 -0
- package/dist/domain/index.d.cts +26 -0
- package/dist/domain/index.d.ts +26 -0
- package/dist/domain/index.js +89 -0
- package/dist/domain/index.js.map +1 -0
- package/dist/errors/index.cjs +58 -0
- package/dist/errors/index.cjs.map +1 -0
- package/dist/errors/index.d.cts +13 -0
- package/dist/errors/index.d.ts +13 -0
- package/dist/errors/index.js +29 -0
- package/dist/errors/index.js.map +1 -0
- package/dist/index.cjs +442 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +19 -0
- package/dist/index.d.ts +19 -0
- package/dist/index.js +405 -0
- package/dist/index.js.map +1 -0
- package/dist/infrastructure/dependency-injection/index.cjs +169 -0
- package/dist/infrastructure/dependency-injection/index.cjs.map +1 -0
- package/dist/infrastructure/dependency-injection/index.d.cts +30 -0
- package/dist/infrastructure/dependency-injection/index.d.ts +30 -0
- package/dist/infrastructure/dependency-injection/index.js +137 -0
- package/dist/infrastructure/dependency-injection/index.js.map +1 -0
- package/dist/infrastructure/express/index.cjs +126 -0
- package/dist/infrastructure/express/index.cjs.map +1 -0
- package/dist/infrastructure/express/index.d.cts +14 -0
- package/dist/infrastructure/express/index.d.ts +14 -0
- package/dist/infrastructure/express/index.js +98 -0
- package/dist/infrastructure/express/index.js.map +1 -0
- package/dist/infrastructure/lifecycle/index.cjs +19 -0
- package/dist/infrastructure/lifecycle/index.cjs.map +1 -0
- package/dist/infrastructure/lifecycle/index.d.cts +9 -0
- package/dist/infrastructure/lifecycle/index.d.ts +9 -0
- package/dist/infrastructure/lifecycle/index.js +1 -0
- package/dist/infrastructure/lifecycle/index.js.map +1 -0
- package/dist/infrastructure/logs/index.cjs +144 -0
- package/dist/infrastructure/logs/index.cjs.map +1 -0
- package/dist/infrastructure/logs/index.d.cts +30 -0
- package/dist/infrastructure/logs/index.d.ts +30 -0
- package/dist/infrastructure/logs/index.js +107 -0
- package/dist/infrastructure/logs/index.js.map +1 -0
- package/dist/infrastructure/scheduler/index.cjs +461 -0
- package/dist/infrastructure/scheduler/index.cjs.map +1 -0
- package/dist/infrastructure/scheduler/index.d.cts +17 -0
- package/dist/infrastructure/scheduler/index.d.ts +17 -0
- package/dist/infrastructure/scheduler/index.js +426 -0
- package/dist/infrastructure/scheduler/index.js.map +1 -0
- package/dist/infrastructure/websocket/index.cjs +131 -0
- package/dist/infrastructure/websocket/index.cjs.map +1 -0
- package/dist/infrastructure/websocket/index.d.cts +56 -0
- package/dist/infrastructure/websocket/index.d.ts +56 -0
- package/dist/infrastructure/websocket/index.js +103 -0
- package/dist/infrastructure/websocket/index.js.map +1 -0
- package/package.json +248 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/adapters/ui/express/index.ts","../../../../src/adapters/ui/express/ExpressKernelServer.ts","../../../../src/adapters/ui/express/RoutePrefix.ts"],"sourcesContent":["export * from './ExpressKernelServer.js';\nexport * from './ExpressKernelServerOptions.js';\nexport * from './HttpApp.js';\nexport * from './HttpServer.js';\nexport * from './RoutePrefix.js';\n","import type { ErrorRequestHandler } from 'express';\n\nimport { createExpressServer } from 'routing-controllers';\n\nimport type { ExpressKernelServerOptions } from './ExpressKernelServerOptions.js';\nimport type { HttpApp } from './HttpApp.js';\nimport type { HttpServer } from './HttpServer.js';\n\nexport class ExpressKernelServer {\n private appInstance: HttpApp | undefined;\n private serverInstance: HttpServer | undefined;\n\n constructor(private readonly options: ExpressKernelServerOptions) {}\n\n private registerErrorHandlers(app: HttpApp): void {\n const handlers = this.options.errorHandlers ?? [this.defaultErrorHandler()];\n\n for (const handler of handlers) {\n app.use(handler);\n }\n }\n\n private defaultErrorHandler(): ErrorRequestHandler {\n return (error, request, response) => {\n void request;\n\n response.status(500).json({\n error: error instanceof Error ? error.message : String(error),\n });\n };\n }\n\n public get app(): HttpApp {\n if (!this.appInstance) {\n throw new Error('HTTP server is not running.');\n }\n\n return this.appInstance;\n }\n\n public get server(): HttpServer {\n if (!this.serverInstance) {\n throw new Error('HTTP server is not running.');\n }\n\n return this.serverInstance;\n }\n\n public close(): Promise<void> {\n if (!this.serverInstance) {\n return Promise.resolve();\n }\n\n return new Promise((resolve, reject) => {\n this.serverInstance?.close((error?: Error) => {\n if (error) {\n reject(error);\n\n return;\n }\n\n this.serverInstance = undefined;\n this.appInstance = undefined;\n resolve();\n });\n });\n }\n\n public run(): Promise<void> {\n const app = createExpressServer({\n controllers: this.options.kernel.getRoutes(),\n routePrefix: this.options.routePrefix,\n }) as HttpApp;\n\n for (const middleware of this.options.middlewares ?? []) {\n app.use(middleware);\n }\n\n this.registerErrorHandlers(app);\n this.appInstance = app;\n\n return new Promise((resolve) => {\n this.serverInstance = app.listen(this.options.port ?? 3000, () => {\n resolve();\n });\n });\n }\n}\n","export class RoutePrefix {\n private readonly value: string;\n\n public static fromEnvironment(value: string | undefined): RoutePrefix {\n return new RoutePrefix(value);\n }\n\n constructor(value: string | undefined) {\n if (!value || value === '/') {\n this.value = '';\n\n return;\n }\n\n const normalizedPrefix = value\n .trim()\n .replace(/^\\/+/, '')\n .replace(/\\/+$/, '');\n\n this.value = normalizedPrefix ? `/${normalizedPrefix}` : '';\n }\n\n public includes(requestPath: string): boolean {\n return (\n this.value.length > 0 &&\n (requestPath === this.value || requestPath.startsWith(`${this.value}/`))\n );\n }\n\n public isEmpty(): boolean {\n return this.value.length === 0;\n }\n\n public toString(): string {\n return this.value;\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACEA,iCAAoC;AAM7B,IAAM,sBAAN,MAA0B;AAAA,EAI/B,YAA6B,SAAqC;AAArC;AAAA,EAAsC;AAAA,EAAtC;AAAA,EAHrB;AAAA,EACA;AAAA,EAIA,sBAAsB,KAAoB;AAChD,UAAM,WAAW,KAAK,QAAQ,iBAAiB,CAAC,KAAK,oBAAoB,CAAC;AAE1E,eAAW,WAAW,UAAU;AAC9B,UAAI,IAAI,OAAO;AAAA,IACjB;AAAA,EACF;AAAA,EAEQ,sBAA2C;AACjD,WAAO,CAAC,OAAO,SAAS,aAAa;AACnC,WAAK;AAEL,eAAS,OAAO,GAAG,EAAE,KAAK;AAAA,QACxB,OAAO,iBAAiB,QAAQ,MAAM,UAAU,OAAO,KAAK;AAAA,MAC9D,CAAC;AAAA,IACH;AAAA,EACF;AAAA,EAEA,IAAW,MAAe;AACxB,QAAI,CAAC,KAAK,aAAa;AACrB,YAAM,IAAI,MAAM,6BAA6B;AAAA,IAC/C;AAEA,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,IAAW,SAAqB;AAC9B,QAAI,CAAC,KAAK,gBAAgB;AACxB,YAAM,IAAI,MAAM,6BAA6B;AAAA,IAC/C;AAEA,WAAO,KAAK;AAAA,EACd;AAAA,EAEO,QAAuB;AAC5B,QAAI,CAAC,KAAK,gBAAgB;AACxB,aAAO,QAAQ,QAAQ;AAAA,IACzB;AAEA,WAAO,IAAI,QAAQ,CAAC,SAAS,WAAW;AACtC,WAAK,gBAAgB,MAAM,CAAC,UAAkB;AAC5C,YAAI,OAAO;AACT,iBAAO,KAAK;AAEZ;AAAA,QACF;AAEA,aAAK,iBAAiB;AACtB,aAAK,cAAc;AACnB,gBAAQ;AAAA,MACV,CAAC;AAAA,IACH,CAAC;AAAA,EACH;AAAA,EAEO,MAAqB;AAC1B,UAAM,UAAM,gDAAoB;AAAA,MAC9B,aAAa,KAAK,QAAQ,OAAO,UAAU;AAAA,MAC3C,aAAa,KAAK,QAAQ;AAAA,IAC5B,CAAC;AAED,eAAW,cAAc,KAAK,QAAQ,eAAe,CAAC,GAAG;AACvD,UAAI,IAAI,UAAU;AAAA,IACpB;AAEA,SAAK,sBAAsB,GAAG;AAC9B,SAAK,cAAc;AAEnB,WAAO,IAAI,QAAQ,CAAC,YAAY;AAC9B,WAAK,iBAAiB,IAAI,OAAO,KAAK,QAAQ,QAAQ,KAAM,MAAM;AAChE,gBAAQ;AAAA,MACV,CAAC;AAAA,IACH,CAAC;AAAA,EACH;AACF;;;ACvFO,IAAM,cAAN,MAAM,aAAY;AAAA,EACN;AAAA,EAEjB,OAAc,gBAAgB,OAAwC;AACpE,WAAO,IAAI,aAAY,KAAK;AAAA,EAC9B;AAAA,EAEA,YAAY,OAA2B;AACrC,QAAI,CAAC,SAAS,UAAU,KAAK;AAC3B,WAAK,QAAQ;AAEb;AAAA,IACF;AAEA,UAAM,mBAAmB,MACtB,KAAK,EACL,QAAQ,QAAQ,EAAE,EAClB,QAAQ,QAAQ,EAAE;AAErB,SAAK,QAAQ,mBAAmB,IAAI,gBAAgB,KAAK;AAAA,EAC3D;AAAA,EAEO,SAAS,aAA8B;AAC5C,WACE,KAAK,MAAM,SAAS,MACnB,gBAAgB,KAAK,SAAS,YAAY,WAAW,GAAG,KAAK,KAAK,GAAG;AAAA,EAE1E;AAAA,EAEO,UAAmB;AACxB,WAAO,KAAK,MAAM,WAAW;AAAA,EAC/B;AAAA,EAEO,WAAmB;AACxB,WAAO,KAAK;AAAA,EACd;AACF;","names":[]}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import '../routes/index.cjs';
|
|
2
|
+
import { ErrorRequestHandler, RequestHandler, Application } from 'express';
|
|
3
|
+
import { K as Kernel } from '../../../Kernel-BWUOUWWI.cjs';
|
|
4
|
+
import { Server } from 'node:http';
|
|
5
|
+
import '../../../Consumer-CC8ZRCsd.cjs';
|
|
6
|
+
import '../../../DomainEventConsumer-3WBMSSr2.cjs';
|
|
7
|
+
import '../../../DomainEvent-mXWEtr_J.cjs';
|
|
8
|
+
import '../../../ShutdownHook-Dib5uNKB.cjs';
|
|
9
|
+
import '../../../KernelLogger-BESOFrpW.cjs';
|
|
10
|
+
import '../../../ServiceClass-BmNw8fJj.cjs';
|
|
11
|
+
import '../../../ServiceResolver-D2Jz-l_Z.cjs';
|
|
12
|
+
import '../../../infrastructure/lifecycle/index.cjs';
|
|
13
|
+
import '../../../Scheduler-oigqNOUJ.cjs';
|
|
14
|
+
|
|
15
|
+
interface ExpressKernelServerOptions {
|
|
16
|
+
readonly errorHandlers?: ErrorRequestHandler[];
|
|
17
|
+
readonly kernel: Kernel;
|
|
18
|
+
readonly middlewares?: RequestHandler[];
|
|
19
|
+
readonly port?: number;
|
|
20
|
+
readonly routePrefix?: string;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
type HttpApp = Application;
|
|
24
|
+
|
|
25
|
+
type HttpServer = Server;
|
|
26
|
+
|
|
27
|
+
declare class ExpressKernelServer {
|
|
28
|
+
private readonly options;
|
|
29
|
+
private appInstance;
|
|
30
|
+
private serverInstance;
|
|
31
|
+
constructor(options: ExpressKernelServerOptions);
|
|
32
|
+
private registerErrorHandlers;
|
|
33
|
+
private defaultErrorHandler;
|
|
34
|
+
get app(): HttpApp;
|
|
35
|
+
get server(): HttpServer;
|
|
36
|
+
close(): Promise<void>;
|
|
37
|
+
run(): Promise<void>;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
declare class RoutePrefix {
|
|
41
|
+
private readonly value;
|
|
42
|
+
static fromEnvironment(value: string | undefined): RoutePrefix;
|
|
43
|
+
constructor(value: string | undefined);
|
|
44
|
+
includes(requestPath: string): boolean;
|
|
45
|
+
isEmpty(): boolean;
|
|
46
|
+
toString(): string;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
export { ExpressKernelServer, type ExpressKernelServerOptions, type HttpApp, type HttpServer, RoutePrefix };
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import '../routes/index.js';
|
|
2
|
+
import { ErrorRequestHandler, RequestHandler, Application } from 'express';
|
|
3
|
+
import { K as Kernel } from '../../../Kernel-CUaqHa1s.js';
|
|
4
|
+
import { Server } from 'node:http';
|
|
5
|
+
import '../../../Consumer-CeT0Wbxb.js';
|
|
6
|
+
import '../../../DomainEventConsumer-B4hkIUmP.js';
|
|
7
|
+
import '../../../DomainEvent-mXWEtr_J.js';
|
|
8
|
+
import '../../../ShutdownHook-BGskq2-q.js';
|
|
9
|
+
import '../../../KernelLogger-BESOFrpW.js';
|
|
10
|
+
import '../../../ServiceClass-C7NCKdSS.js';
|
|
11
|
+
import '../../../ServiceResolver-D2Jz-l_Z.js';
|
|
12
|
+
import '../../../infrastructure/lifecycle/index.js';
|
|
13
|
+
import '../../../Scheduler-oigqNOUJ.js';
|
|
14
|
+
|
|
15
|
+
interface ExpressKernelServerOptions {
|
|
16
|
+
readonly errorHandlers?: ErrorRequestHandler[];
|
|
17
|
+
readonly kernel: Kernel;
|
|
18
|
+
readonly middlewares?: RequestHandler[];
|
|
19
|
+
readonly port?: number;
|
|
20
|
+
readonly routePrefix?: string;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
type HttpApp = Application;
|
|
24
|
+
|
|
25
|
+
type HttpServer = Server;
|
|
26
|
+
|
|
27
|
+
declare class ExpressKernelServer {
|
|
28
|
+
private readonly options;
|
|
29
|
+
private appInstance;
|
|
30
|
+
private serverInstance;
|
|
31
|
+
constructor(options: ExpressKernelServerOptions);
|
|
32
|
+
private registerErrorHandlers;
|
|
33
|
+
private defaultErrorHandler;
|
|
34
|
+
get app(): HttpApp;
|
|
35
|
+
get server(): HttpServer;
|
|
36
|
+
close(): Promise<void>;
|
|
37
|
+
run(): Promise<void>;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
declare class RoutePrefix {
|
|
41
|
+
private readonly value;
|
|
42
|
+
static fromEnvironment(value: string | undefined): RoutePrefix;
|
|
43
|
+
constructor(value: string | undefined);
|
|
44
|
+
includes(requestPath: string): boolean;
|
|
45
|
+
isEmpty(): boolean;
|
|
46
|
+
toString(): string;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
export { ExpressKernelServer, type ExpressKernelServerOptions, type HttpApp, type HttpServer, RoutePrefix };
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
// src/adapters/ui/express/ExpressKernelServer.ts
|
|
2
|
+
import { createExpressServer } from "routing-controllers";
|
|
3
|
+
var ExpressKernelServer = class {
|
|
4
|
+
constructor(options) {
|
|
5
|
+
this.options = options;
|
|
6
|
+
}
|
|
7
|
+
options;
|
|
8
|
+
appInstance;
|
|
9
|
+
serverInstance;
|
|
10
|
+
registerErrorHandlers(app) {
|
|
11
|
+
const handlers = this.options.errorHandlers ?? [this.defaultErrorHandler()];
|
|
12
|
+
for (const handler of handlers) {
|
|
13
|
+
app.use(handler);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
defaultErrorHandler() {
|
|
17
|
+
return (error, request, response) => {
|
|
18
|
+
void request;
|
|
19
|
+
response.status(500).json({
|
|
20
|
+
error: error instanceof Error ? error.message : String(error)
|
|
21
|
+
});
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
get app() {
|
|
25
|
+
if (!this.appInstance) {
|
|
26
|
+
throw new Error("HTTP server is not running.");
|
|
27
|
+
}
|
|
28
|
+
return this.appInstance;
|
|
29
|
+
}
|
|
30
|
+
get server() {
|
|
31
|
+
if (!this.serverInstance) {
|
|
32
|
+
throw new Error("HTTP server is not running.");
|
|
33
|
+
}
|
|
34
|
+
return this.serverInstance;
|
|
35
|
+
}
|
|
36
|
+
close() {
|
|
37
|
+
if (!this.serverInstance) {
|
|
38
|
+
return Promise.resolve();
|
|
39
|
+
}
|
|
40
|
+
return new Promise((resolve, reject) => {
|
|
41
|
+
this.serverInstance?.close((error) => {
|
|
42
|
+
if (error) {
|
|
43
|
+
reject(error);
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
this.serverInstance = void 0;
|
|
47
|
+
this.appInstance = void 0;
|
|
48
|
+
resolve();
|
|
49
|
+
});
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
run() {
|
|
53
|
+
const app = createExpressServer({
|
|
54
|
+
controllers: this.options.kernel.getRoutes(),
|
|
55
|
+
routePrefix: this.options.routePrefix
|
|
56
|
+
});
|
|
57
|
+
for (const middleware of this.options.middlewares ?? []) {
|
|
58
|
+
app.use(middleware);
|
|
59
|
+
}
|
|
60
|
+
this.registerErrorHandlers(app);
|
|
61
|
+
this.appInstance = app;
|
|
62
|
+
return new Promise((resolve) => {
|
|
63
|
+
this.serverInstance = app.listen(this.options.port ?? 3e3, () => {
|
|
64
|
+
resolve();
|
|
65
|
+
});
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
};
|
|
69
|
+
|
|
70
|
+
// src/adapters/ui/express/RoutePrefix.ts
|
|
71
|
+
var RoutePrefix = class _RoutePrefix {
|
|
72
|
+
value;
|
|
73
|
+
static fromEnvironment(value) {
|
|
74
|
+
return new _RoutePrefix(value);
|
|
75
|
+
}
|
|
76
|
+
constructor(value) {
|
|
77
|
+
if (!value || value === "/") {
|
|
78
|
+
this.value = "";
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
81
|
+
const normalizedPrefix = value.trim().replace(/^\/+/, "").replace(/\/+$/, "");
|
|
82
|
+
this.value = normalizedPrefix ? `/${normalizedPrefix}` : "";
|
|
83
|
+
}
|
|
84
|
+
includes(requestPath) {
|
|
85
|
+
return this.value.length > 0 && (requestPath === this.value || requestPath.startsWith(`${this.value}/`));
|
|
86
|
+
}
|
|
87
|
+
isEmpty() {
|
|
88
|
+
return this.value.length === 0;
|
|
89
|
+
}
|
|
90
|
+
toString() {
|
|
91
|
+
return this.value;
|
|
92
|
+
}
|
|
93
|
+
};
|
|
94
|
+
export {
|
|
95
|
+
ExpressKernelServer,
|
|
96
|
+
RoutePrefix
|
|
97
|
+
};
|
|
98
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/adapters/ui/express/ExpressKernelServer.ts","../../../../src/adapters/ui/express/RoutePrefix.ts"],"sourcesContent":["import type { ErrorRequestHandler } from 'express';\n\nimport { createExpressServer } from 'routing-controllers';\n\nimport type { ExpressKernelServerOptions } from './ExpressKernelServerOptions.js';\nimport type { HttpApp } from './HttpApp.js';\nimport type { HttpServer } from './HttpServer.js';\n\nexport class ExpressKernelServer {\n private appInstance: HttpApp | undefined;\n private serverInstance: HttpServer | undefined;\n\n constructor(private readonly options: ExpressKernelServerOptions) {}\n\n private registerErrorHandlers(app: HttpApp): void {\n const handlers = this.options.errorHandlers ?? [this.defaultErrorHandler()];\n\n for (const handler of handlers) {\n app.use(handler);\n }\n }\n\n private defaultErrorHandler(): ErrorRequestHandler {\n return (error, request, response) => {\n void request;\n\n response.status(500).json({\n error: error instanceof Error ? error.message : String(error),\n });\n };\n }\n\n public get app(): HttpApp {\n if (!this.appInstance) {\n throw new Error('HTTP server is not running.');\n }\n\n return this.appInstance;\n }\n\n public get server(): HttpServer {\n if (!this.serverInstance) {\n throw new Error('HTTP server is not running.');\n }\n\n return this.serverInstance;\n }\n\n public close(): Promise<void> {\n if (!this.serverInstance) {\n return Promise.resolve();\n }\n\n return new Promise((resolve, reject) => {\n this.serverInstance?.close((error?: Error) => {\n if (error) {\n reject(error);\n\n return;\n }\n\n this.serverInstance = undefined;\n this.appInstance = undefined;\n resolve();\n });\n });\n }\n\n public run(): Promise<void> {\n const app = createExpressServer({\n controllers: this.options.kernel.getRoutes(),\n routePrefix: this.options.routePrefix,\n }) as HttpApp;\n\n for (const middleware of this.options.middlewares ?? []) {\n app.use(middleware);\n }\n\n this.registerErrorHandlers(app);\n this.appInstance = app;\n\n return new Promise((resolve) => {\n this.serverInstance = app.listen(this.options.port ?? 3000, () => {\n resolve();\n });\n });\n }\n}\n","export class RoutePrefix {\n private readonly value: string;\n\n public static fromEnvironment(value: string | undefined): RoutePrefix {\n return new RoutePrefix(value);\n }\n\n constructor(value: string | undefined) {\n if (!value || value === '/') {\n this.value = '';\n\n return;\n }\n\n const normalizedPrefix = value\n .trim()\n .replace(/^\\/+/, '')\n .replace(/\\/+$/, '');\n\n this.value = normalizedPrefix ? `/${normalizedPrefix}` : '';\n }\n\n public includes(requestPath: string): boolean {\n return (\n this.value.length > 0 &&\n (requestPath === this.value || requestPath.startsWith(`${this.value}/`))\n );\n }\n\n public isEmpty(): boolean {\n return this.value.length === 0;\n }\n\n public toString(): string {\n return this.value;\n }\n}\n"],"mappings":";AAEA,SAAS,2BAA2B;AAM7B,IAAM,sBAAN,MAA0B;AAAA,EAI/B,YAA6B,SAAqC;AAArC;AAAA,EAAsC;AAAA,EAAtC;AAAA,EAHrB;AAAA,EACA;AAAA,EAIA,sBAAsB,KAAoB;AAChD,UAAM,WAAW,KAAK,QAAQ,iBAAiB,CAAC,KAAK,oBAAoB,CAAC;AAE1E,eAAW,WAAW,UAAU;AAC9B,UAAI,IAAI,OAAO;AAAA,IACjB;AAAA,EACF;AAAA,EAEQ,sBAA2C;AACjD,WAAO,CAAC,OAAO,SAAS,aAAa;AACnC,WAAK;AAEL,eAAS,OAAO,GAAG,EAAE,KAAK;AAAA,QACxB,OAAO,iBAAiB,QAAQ,MAAM,UAAU,OAAO,KAAK;AAAA,MAC9D,CAAC;AAAA,IACH;AAAA,EACF;AAAA,EAEA,IAAW,MAAe;AACxB,QAAI,CAAC,KAAK,aAAa;AACrB,YAAM,IAAI,MAAM,6BAA6B;AAAA,IAC/C;AAEA,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,IAAW,SAAqB;AAC9B,QAAI,CAAC,KAAK,gBAAgB;AACxB,YAAM,IAAI,MAAM,6BAA6B;AAAA,IAC/C;AAEA,WAAO,KAAK;AAAA,EACd;AAAA,EAEO,QAAuB;AAC5B,QAAI,CAAC,KAAK,gBAAgB;AACxB,aAAO,QAAQ,QAAQ;AAAA,IACzB;AAEA,WAAO,IAAI,QAAQ,CAAC,SAAS,WAAW;AACtC,WAAK,gBAAgB,MAAM,CAAC,UAAkB;AAC5C,YAAI,OAAO;AACT,iBAAO,KAAK;AAEZ;AAAA,QACF;AAEA,aAAK,iBAAiB;AACtB,aAAK,cAAc;AACnB,gBAAQ;AAAA,MACV,CAAC;AAAA,IACH,CAAC;AAAA,EACH;AAAA,EAEO,MAAqB;AAC1B,UAAM,MAAM,oBAAoB;AAAA,MAC9B,aAAa,KAAK,QAAQ,OAAO,UAAU;AAAA,MAC3C,aAAa,KAAK,QAAQ;AAAA,IAC5B,CAAC;AAED,eAAW,cAAc,KAAK,QAAQ,eAAe,CAAC,GAAG;AACvD,UAAI,IAAI,UAAU;AAAA,IACpB;AAEA,SAAK,sBAAsB,GAAG;AAC9B,SAAK,cAAc;AAEnB,WAAO,IAAI,QAAQ,CAAC,YAAY;AAC9B,WAAK,iBAAiB,IAAI,OAAO,KAAK,QAAQ,QAAQ,KAAM,MAAM;AAChE,gBAAQ;AAAA,MACV,CAAC;AAAA,IACH,CAAC;AAAA,EACH;AACF;;;ACvFO,IAAM,cAAN,MAAM,aAAY;AAAA,EACN;AAAA,EAEjB,OAAc,gBAAgB,OAAwC;AACpE,WAAO,IAAI,aAAY,KAAK;AAAA,EAC9B;AAAA,EAEA,YAAY,OAA2B;AACrC,QAAI,CAAC,SAAS,UAAU,KAAK;AAC3B,WAAK,QAAQ;AAEb;AAAA,IACF;AAEA,UAAM,mBAAmB,MACtB,KAAK,EACL,QAAQ,QAAQ,EAAE,EAClB,QAAQ,QAAQ,EAAE;AAErB,SAAK,QAAQ,mBAAmB,IAAI,gBAAgB,KAAK;AAAA,EAC3D;AAAA,EAEO,SAAS,aAA8B;AAC5C,WACE,KAAK,MAAM,SAAS,MACnB,gBAAgB,KAAK,SAAS,YAAY,WAAW,GAAG,KAAK,KAAK,GAAG;AAAA,EAE1E;AAAA,EAEO,UAAmB;AACxB,WAAO,KAAK,MAAM,WAAW;AAAA,EAC/B;AAAA,EAEO,WAAmB;AACxB,WAAO,KAAK;AAAA,EACd;AACF;","names":[]}
|