@onroad/core 4.0.0-alpha.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/README.md +670 -0
- package/dist/OnRoadExpress.d.ts +59 -0
- package/dist/OnRoadExpress.d.ts.map +1 -0
- package/dist/OnRoadExpress.js +320 -0
- package/dist/OnRoadExpress.js.map +1 -0
- package/dist/container/Container.d.ts +53 -0
- package/dist/container/Container.d.ts.map +1 -0
- package/dist/container/Container.js +175 -0
- package/dist/container/Container.js.map +1 -0
- package/dist/container/index.d.ts +3 -0
- package/dist/container/index.d.ts.map +1 -0
- package/dist/container/index.js +2 -0
- package/dist/container/index.js.map +1 -0
- package/dist/context/RequestContext.d.ts +10 -0
- package/dist/context/RequestContext.d.ts.map +1 -0
- package/dist/context/RequestContext.js +11 -0
- package/dist/context/RequestContext.js.map +1 -0
- package/dist/core/AbstractController.d.ts +20 -0
- package/dist/core/AbstractController.d.ts.map +1 -0
- package/dist/core/AbstractController.js +17 -0
- package/dist/core/AbstractController.js.map +1 -0
- package/dist/core/AbstractRepository.d.ts +8 -0
- package/dist/core/AbstractRepository.d.ts.map +1 -0
- package/dist/core/AbstractRepository.js +3 -0
- package/dist/core/AbstractRepository.js.map +1 -0
- package/dist/core/AbstractService.d.ts +12 -0
- package/dist/core/AbstractService.d.ts.map +1 -0
- package/dist/core/AbstractService.js +14 -0
- package/dist/core/AbstractService.js.map +1 -0
- package/dist/core/MongooseRepository.d.ts +19 -0
- package/dist/core/MongooseRepository.d.ts.map +1 -0
- package/dist/core/MongooseRepository.js +48 -0
- package/dist/core/MongooseRepository.js.map +1 -0
- package/dist/core/RequestEventBus.d.ts +18 -0
- package/dist/core/RequestEventBus.d.ts.map +1 -0
- package/dist/core/RequestEventBus.js +43 -0
- package/dist/core/RequestEventBus.js.map +1 -0
- package/dist/core/Sentinel.d.ts +19 -0
- package/dist/core/Sentinel.d.ts.map +1 -0
- package/dist/core/Sentinel.js +56 -0
- package/dist/core/Sentinel.js.map +1 -0
- package/dist/core/SequelizeRepository.d.ts +19 -0
- package/dist/core/SequelizeRepository.d.ts.map +1 -0
- package/dist/core/SequelizeRepository.js +48 -0
- package/dist/core/SequelizeRepository.js.map +1 -0
- package/dist/core/index.d.ts +11 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +8 -0
- package/dist/core/index.js.map +1 -0
- package/dist/database/ConnectionManager.d.ts +26 -0
- package/dist/database/ConnectionManager.d.ts.map +1 -0
- package/dist/database/ConnectionManager.js +17 -0
- package/dist/database/ConnectionManager.js.map +1 -0
- package/dist/database/MongoConnectionManager.d.ts +8 -0
- package/dist/database/MongoConnectionManager.d.ts.map +1 -0
- package/dist/database/MongoConnectionManager.js +47 -0
- package/dist/database/MongoConnectionManager.js.map +1 -0
- package/dist/database/SequelizeConnectionManager.d.ts +13 -0
- package/dist/database/SequelizeConnectionManager.d.ts.map +1 -0
- package/dist/database/SequelizeConnectionManager.js +58 -0
- package/dist/database/SequelizeConnectionManager.js.map +1 -0
- package/dist/database/index.d.ts +6 -0
- package/dist/database/index.d.ts.map +1 -0
- package/dist/database/index.js +4 -0
- package/dist/database/index.js.map +1 -0
- package/dist/entity/EntityRegistry.d.ts +9 -0
- package/dist/entity/EntityRegistry.d.ts.map +1 -0
- package/dist/entity/EntityRegistry.js +114 -0
- package/dist/entity/EntityRegistry.js.map +1 -0
- package/dist/entity/decorators.d.ts +62 -0
- package/dist/entity/decorators.d.ts.map +1 -0
- package/dist/entity/decorators.js +103 -0
- package/dist/entity/decorators.js.map +1 -0
- package/dist/entity/index.d.ts +4 -0
- package/dist/entity/index.d.ts.map +1 -0
- package/dist/entity/index.js +3 -0
- package/dist/entity/index.js.map +1 -0
- package/dist/filters/FilterChain.d.ts +34 -0
- package/dist/filters/FilterChain.d.ts.map +1 -0
- package/dist/filters/FilterChain.js +42 -0
- package/dist/filters/FilterChain.js.map +1 -0
- package/dist/filters/builtins/CorsFilter.d.ts +22 -0
- package/dist/filters/builtins/CorsFilter.d.ts.map +1 -0
- package/dist/filters/builtins/CorsFilter.js +41 -0
- package/dist/filters/builtins/CorsFilter.js.map +1 -0
- package/dist/filters/builtins/JwtFilter.d.ts +27 -0
- package/dist/filters/builtins/JwtFilter.d.ts.map +1 -0
- package/dist/filters/builtins/JwtFilter.js +35 -0
- package/dist/filters/builtins/JwtFilter.js.map +1 -0
- package/dist/filters/builtins/RequestContextFilter.d.ts +12 -0
- package/dist/filters/builtins/RequestContextFilter.d.ts.map +1 -0
- package/dist/filters/builtins/RequestContextFilter.js +32 -0
- package/dist/filters/builtins/RequestContextFilter.js.map +1 -0
- package/dist/filters/builtins/RoleFilter.d.ts +27 -0
- package/dist/filters/builtins/RoleFilter.d.ts.map +1 -0
- package/dist/filters/builtins/RoleFilter.js +36 -0
- package/dist/filters/builtins/RoleFilter.js.map +1 -0
- package/dist/filters/builtins/TenantFilter.d.ts +26 -0
- package/dist/filters/builtins/TenantFilter.d.ts.map +1 -0
- package/dist/filters/builtins/TenantFilter.js +29 -0
- package/dist/filters/builtins/TenantFilter.js.map +1 -0
- package/dist/filters/builtins/index.d.ts +11 -0
- package/dist/filters/builtins/index.d.ts.map +1 -0
- package/dist/filters/builtins/index.js +6 -0
- package/dist/filters/builtins/index.js.map +1 -0
- package/dist/filters/index.d.ts +5 -0
- package/dist/filters/index.d.ts.map +1 -0
- package/dist/filters/index.js +4 -0
- package/dist/filters/index.js.map +1 -0
- package/dist/index.d.ts +27 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +31 -0
- package/dist/index.js.map +1 -0
- package/dist/logging/OnRoadLogger.d.ts +8 -0
- package/dist/logging/OnRoadLogger.d.ts.map +1 -0
- package/dist/logging/OnRoadLogger.js +2 -0
- package/dist/logging/OnRoadLogger.js.map +1 -0
- package/dist/logging/PinoLogger.d.ts +16 -0
- package/dist/logging/PinoLogger.d.ts.map +1 -0
- package/dist/logging/PinoLogger.js +33 -0
- package/dist/logging/PinoLogger.js.map +1 -0
- package/dist/logging/index.d.ts +4 -0
- package/dist/logging/index.d.ts.map +1 -0
- package/dist/logging/index.js +2 -0
- package/dist/logging/index.js.map +1 -0
- package/dist/messaging/MatchingObject.d.ts +9 -0
- package/dist/messaging/MatchingObject.d.ts.map +1 -0
- package/dist/messaging/MatchingObject.js +21 -0
- package/dist/messaging/MatchingObject.js.map +1 -0
- package/dist/messaging/index.d.ts +2 -0
- package/dist/messaging/index.d.ts.map +1 -0
- package/dist/messaging/index.js +2 -0
- package/dist/messaging/index.js.map +1 -0
- package/dist/plugins/OnRoadPlugin.d.ts +6 -0
- package/dist/plugins/OnRoadPlugin.d.ts.map +1 -0
- package/dist/plugins/OnRoadPlugin.js +2 -0
- package/dist/plugins/OnRoadPlugin.js.map +1 -0
- package/dist/plugins/index.d.ts +2 -0
- package/dist/plugins/index.d.ts.map +1 -0
- package/dist/plugins/index.js +2 -0
- package/dist/plugins/index.js.map +1 -0
- package/dist/providers/MessagingProvider.d.ts +17 -0
- package/dist/providers/MessagingProvider.d.ts.map +1 -0
- package/dist/providers/MessagingProvider.js +3 -0
- package/dist/providers/MessagingProvider.js.map +1 -0
- package/dist/providers/RealtimeProvider.d.ts +13 -0
- package/dist/providers/RealtimeProvider.d.ts.map +1 -0
- package/dist/providers/RealtimeProvider.js +3 -0
- package/dist/providers/RealtimeProvider.js.map +1 -0
- package/dist/providers/SocketProvider.d.ts +7 -0
- package/dist/providers/SocketProvider.d.ts.map +1 -0
- package/dist/providers/SocketProvider.js +3 -0
- package/dist/providers/SocketProvider.js.map +1 -0
- package/dist/providers/TaskSchedulerProvider.d.ts +19 -0
- package/dist/providers/TaskSchedulerProvider.d.ts.map +1 -0
- package/dist/providers/TaskSchedulerProvider.js +3 -0
- package/dist/providers/TaskSchedulerProvider.js.map +1 -0
- package/dist/providers/index.d.ts +8 -0
- package/dist/providers/index.d.ts.map +1 -0
- package/dist/providers/index.js +5 -0
- package/dist/providers/index.js.map +1 -0
- package/dist/security/decorators.d.ts +5 -0
- package/dist/security/decorators.d.ts.map +1 -0
- package/dist/security/decorators.js +26 -0
- package/dist/security/decorators.js.map +1 -0
- package/dist/security/index.d.ts +2 -0
- package/dist/security/index.d.ts.map +1 -0
- package/dist/security/index.js +2 -0
- package/dist/security/index.js.map +1 -0
- package/dist/storage/StorageProvider.d.ts +7 -0
- package/dist/storage/StorageProvider.d.ts.map +1 -0
- package/dist/storage/StorageProvider.js +3 -0
- package/dist/storage/StorageProvider.js.map +1 -0
- package/dist/storage/index.d.ts +2 -0
- package/dist/storage/index.d.ts.map +1 -0
- package/dist/storage/index.js +2 -0
- package/dist/storage/index.js.map +1 -0
- package/dist/transport/HttpTransport.d.ts +8 -0
- package/dist/transport/HttpTransport.d.ts.map +1 -0
- package/dist/transport/HttpTransport.js +26 -0
- package/dist/transport/HttpTransport.js.map +1 -0
- package/dist/transport/InterServiceTransport.d.ts +15 -0
- package/dist/transport/InterServiceTransport.d.ts.map +1 -0
- package/dist/transport/InterServiceTransport.js +20 -0
- package/dist/transport/InterServiceTransport.js.map +1 -0
- package/dist/transport/MessagingTransport.d.ts +9 -0
- package/dist/transport/MessagingTransport.d.ts.map +1 -0
- package/dist/transport/MessagingTransport.js +21 -0
- package/dist/transport/MessagingTransport.js.map +1 -0
- package/dist/transport/TransportFactory.d.ts +13 -0
- package/dist/transport/TransportFactory.d.ts.map +1 -0
- package/dist/transport/TransportFactory.js +35 -0
- package/dist/transport/TransportFactory.js.map +1 -0
- package/dist/transport/index.d.ts +6 -0
- package/dist/transport/index.d.ts.map +1 -0
- package/dist/transport/index.js +5 -0
- package/dist/transport/index.js.map +1 -0
- package/dist/types/express-augment.d.ts +27 -0
- package/dist/types/express-augment.d.ts.map +1 -0
- package/dist/types/express-augment.js +4 -0
- package/dist/types/express-augment.js.map +1 -0
- package/package.json +134 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/container/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,eAAe,EACf,UAAU,EACV,UAAU,EACV,OAAO,EACP,UAAU,EACV,KAAK,EACL,YAAY,GACb,MAAM,gBAAgB,CAAA;AAEvB,YAAY,EACV,WAAW,EACX,aAAa,EACb,iBAAiB,EACjB,iBAAiB,EACjB,YAAY,GACb,MAAM,gBAAgB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/container/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,eAAe,EACf,UAAU,EACV,UAAU,EACV,OAAO,EACP,UAAU,EACV,KAAK,EACL,YAAY,GACb,MAAM,gBAAgB,CAAA"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { AsyncLocalStorage } from "node:async_hooks";
|
|
2
|
+
import type { OnRoadLogger } from "../logging/OnRoadLogger.js";
|
|
3
|
+
export interface RequestContextStore {
|
|
4
|
+
tenant: string;
|
|
5
|
+
appToken: string;
|
|
6
|
+
logger?: OnRoadLogger;
|
|
7
|
+
}
|
|
8
|
+
export declare const requestContext: AsyncLocalStorage<RequestContextStore>;
|
|
9
|
+
export declare function getRequestContext(): RequestContextStore;
|
|
10
|
+
//# sourceMappingURL=RequestContext.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RequestContext.d.ts","sourceRoot":"","sources":["../../src/context/RequestContext.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAA;AACpD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAA;AAE9D,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE,MAAM,CAAA;IACd,QAAQ,EAAE,MAAM,CAAA;IAChB,MAAM,CAAC,EAAE,YAAY,CAAA;CACtB;AAED,eAAO,MAAM,cAAc,wCAA+C,CAAA;AAE1E,wBAAgB,iBAAiB,IAAI,mBAAmB,CASvD"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { AsyncLocalStorage } from "node:async_hooks";
|
|
2
|
+
export const requestContext = new AsyncLocalStorage();
|
|
3
|
+
export function getRequestContext() {
|
|
4
|
+
const store = requestContext.getStore();
|
|
5
|
+
if (!store) {
|
|
6
|
+
throw new Error("[TypeRoad] No request context found. " +
|
|
7
|
+
"InterServiceTransport must be used within a request handler managed by OnRoadExpress.");
|
|
8
|
+
}
|
|
9
|
+
return store;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=RequestContext.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RequestContext.js","sourceRoot":"","sources":["../../src/context/RequestContext.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAA;AASpD,MAAM,CAAC,MAAM,cAAc,GAAG,IAAI,iBAAiB,EAAuB,CAAA;AAE1E,MAAM,UAAU,iBAAiB;IAC/B,MAAM,KAAK,GAAG,cAAc,CAAC,QAAQ,EAAE,CAAA;IACvC,IAAI,CAAC,KAAK,EAAE,CAAC;QACX,MAAM,IAAI,KAAK,CACb,uCAAuC;YACrC,uFAAuF,CAC1F,CAAA;IACH,CAAC;IACD,OAAO,KAAK,CAAA;AACd,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { Constructor } from "../container/Container.js";
|
|
2
|
+
export interface RouteConfig {
|
|
3
|
+
method: "get" | "post" | "put" | "delete" | "patch";
|
|
4
|
+
path?: string;
|
|
5
|
+
hasMessagingEvent?: boolean;
|
|
6
|
+
afterPropagation?: boolean;
|
|
7
|
+
}
|
|
8
|
+
export interface ControllerConfig<TService> {
|
|
9
|
+
service: Constructor<TService>;
|
|
10
|
+
routes?: Record<string, RouteConfig>;
|
|
11
|
+
}
|
|
12
|
+
export declare abstract class AbstractController<TService = unknown> {
|
|
13
|
+
protected service: TService;
|
|
14
|
+
protected config: ControllerConfig<TService>;
|
|
15
|
+
constructor(config: ControllerConfig<TService>);
|
|
16
|
+
setService(service: TService): void;
|
|
17
|
+
getRoutes(): Record<string, RouteConfig>;
|
|
18
|
+
getServiceClass(): Constructor<TService>;
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=AbstractController.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AbstractController.d.ts","sourceRoot":"","sources":["../../src/core/AbstractController.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAA;AAE5D,MAAM,WAAW,WAAW;IAC1B,MAAM,EAAE,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,QAAQ,GAAG,OAAO,CAAA;IACnD,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,iBAAiB,CAAC,EAAE,OAAO,CAAA;IAC3B,gBAAgB,CAAC,EAAE,OAAO,CAAA;CAC3B;AAED,MAAM,WAAW,gBAAgB,CAAC,QAAQ;IACxC,OAAO,EAAE,WAAW,CAAC,QAAQ,CAAC,CAAA;IAC9B,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,WAAW,CAAC,CAAA;CACrC;AAED,8BAAsB,kBAAkB,CAAC,QAAQ,GAAG,OAAO;IACzD,SAAS,CAAC,OAAO,EAAG,QAAQ,CAAA;IAC5B,SAAS,CAAC,MAAM,EAAE,gBAAgB,CAAC,QAAQ,CAAC,CAAA;gBAEhC,MAAM,EAAE,gBAAgB,CAAC,QAAQ,CAAC;IAI9C,UAAU,CAAC,OAAO,EAAE,QAAQ,GAAG,IAAI;IAInC,SAAS,IAAI,MAAM,CAAC,MAAM,EAAE,WAAW,CAAC;IAIxC,eAAe,IAAI,WAAW,CAAC,QAAQ,CAAC;CAGzC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export class AbstractController {
|
|
2
|
+
service;
|
|
3
|
+
config;
|
|
4
|
+
constructor(config) {
|
|
5
|
+
this.config = config;
|
|
6
|
+
}
|
|
7
|
+
setService(service) {
|
|
8
|
+
this.service = service;
|
|
9
|
+
}
|
|
10
|
+
getRoutes() {
|
|
11
|
+
return this.config.routes ?? {};
|
|
12
|
+
}
|
|
13
|
+
getServiceClass() {
|
|
14
|
+
return this.config.service;
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=AbstractController.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AbstractController.js","sourceRoot":"","sources":["../../src/core/AbstractController.ts"],"names":[],"mappings":"AAcA,MAAM,OAAgB,kBAAkB;IAC5B,OAAO,CAAW;IAClB,MAAM,CAA4B;IAE5C,YAAY,MAAkC;QAC5C,IAAI,CAAC,MAAM,GAAG,MAAM,CAAA;IACtB,CAAC;IAED,UAAU,CAAC,OAAiB;QAC1B,IAAI,CAAC,OAAO,GAAG,OAAO,CAAA;IACxB,CAAC;IAED,SAAS;QACP,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,IAAI,EAAE,CAAA;IACjC,CAAC;IAED,eAAe;QACb,OAAO,IAAI,CAAC,MAAM,CAAC,OAAO,CAAA;IAC5B,CAAC;CACF"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export declare abstract class AbstractRepository {
|
|
2
|
+
abstract findAll(options?: unknown): Promise<unknown[]>;
|
|
3
|
+
abstract findByPk(id: unknown, options?: unknown): Promise<unknown | null>;
|
|
4
|
+
abstract create(data: unknown, options?: unknown): Promise<unknown>;
|
|
5
|
+
abstract update(id: unknown, data: unknown, options?: unknown): Promise<unknown>;
|
|
6
|
+
abstract destroy(id: unknown, options?: unknown): Promise<unknown>;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=AbstractRepository.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AbstractRepository.d.ts","sourceRoot":"","sources":["../../src/core/AbstractRepository.ts"],"names":[],"mappings":"AAAA,8BAAsB,kBAAkB;IACtC,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IACvD,QAAQ,CAAC,QAAQ,CAAC,EAAE,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC;IAC1E,QAAQ,CAAC,MAAM,CAAC,IAAI,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC;IACnE,QAAQ,CAAC,MAAM,CAAC,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC;IAChF,QAAQ,CAAC,OAAO,CAAC,EAAE,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC;CACnE"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AbstractRepository.js","sourceRoot":"","sources":["../../src/core/AbstractRepository.ts"],"names":[],"mappings":"AAAA,MAAM,OAAgB,kBAAkB;CAMvC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { Constructor } from "../container/Container.js";
|
|
2
|
+
export interface ServiceConfig<TRepository> {
|
|
3
|
+
repository: Constructor<TRepository>;
|
|
4
|
+
}
|
|
5
|
+
export declare abstract class AbstractService<TRepository = unknown> {
|
|
6
|
+
protected config: ServiceConfig<TRepository>;
|
|
7
|
+
protected repository: TRepository;
|
|
8
|
+
constructor(config: ServiceConfig<TRepository>);
|
|
9
|
+
setRepository(repository: TRepository): void;
|
|
10
|
+
getRepositoryClass(): Constructor<TRepository>;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=AbstractService.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AbstractService.d.ts","sourceRoot":"","sources":["../../src/core/AbstractService.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAA;AAE5D,MAAM,WAAW,aAAa,CAAC,WAAW;IACxC,UAAU,EAAE,WAAW,CAAC,WAAW,CAAC,CAAA;CACrC;AAED,8BAAsB,eAAe,CAAC,WAAW,GAAG,OAAO;IAG7C,SAAS,CAAC,MAAM,EAAE,aAAa,CAAC,WAAW,CAAC;IAFxD,SAAS,CAAC,UAAU,EAAG,WAAW,CAAA;gBAEZ,MAAM,EAAE,aAAa,CAAC,WAAW,CAAC;IAExD,aAAa,CAAC,UAAU,EAAE,WAAW,GAAG,IAAI;IAI5C,kBAAkB,IAAI,WAAW,CAAC,WAAW,CAAC;CAG/C"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export class AbstractService {
|
|
2
|
+
config;
|
|
3
|
+
repository;
|
|
4
|
+
constructor(config) {
|
|
5
|
+
this.config = config;
|
|
6
|
+
}
|
|
7
|
+
setRepository(repository) {
|
|
8
|
+
this.repository = repository;
|
|
9
|
+
}
|
|
10
|
+
getRepositoryClass() {
|
|
11
|
+
return this.config.repository;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=AbstractService.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AbstractService.js","sourceRoot":"","sources":["../../src/core/AbstractService.ts"],"names":[],"mappings":"AAMA,MAAM,OAAgB,eAAe;IAGb;IAFZ,UAAU,CAAc;IAElC,YAAsB,MAAkC;QAAlC,WAAM,GAAN,MAAM,CAA4B;IAAG,CAAC;IAE5D,aAAa,CAAC,UAAuB;QACnC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAA;IAC9B,CAAC;IAED,kBAAkB;QAChB,OAAO,IAAI,CAAC,MAAM,CAAC,UAAU,CAAA;IAC/B,CAAC;CACF"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { AbstractRepository } from "./AbstractRepository.js";
|
|
2
|
+
import type { ConnectionManager } from "../database/ConnectionManager.js";
|
|
3
|
+
import type { Constructor } from "../container/Container.js";
|
|
4
|
+
export declare abstract class MongooseRepository<_TEntity = unknown> extends AbstractRepository {
|
|
5
|
+
protected connectionManager: ConnectionManager<unknown>;
|
|
6
|
+
protected tenant: string;
|
|
7
|
+
protected entityClass?: Constructor;
|
|
8
|
+
setConnectionManager(manager: ConnectionManager<unknown>): void;
|
|
9
|
+
setTenant(tenant: string): void;
|
|
10
|
+
setEntityClass(entity: Constructor): void;
|
|
11
|
+
protected getConnection(): Promise<unknown>;
|
|
12
|
+
protected getModel(): Promise<any>;
|
|
13
|
+
findAll(options?: unknown): Promise<unknown[]>;
|
|
14
|
+
findByPk(id: unknown, options?: unknown): Promise<unknown | null>;
|
|
15
|
+
create(data: unknown, options?: unknown): Promise<unknown>;
|
|
16
|
+
update(id: unknown, data: unknown, options?: unknown): Promise<unknown>;
|
|
17
|
+
destroy(id: unknown, options?: unknown): Promise<unknown>;
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=MongooseRepository.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MongooseRepository.d.ts","sourceRoot":"","sources":["../../src/core/MongooseRepository.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAA;AAC5D,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAA;AACzE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAA;AAG5D,8BAAsB,kBAAkB,CAAC,QAAQ,GAAG,OAAO,CAAE,SAAQ,kBAAkB;IACrF,SAAS,CAAC,iBAAiB,EAAG,iBAAiB,CAAC,OAAO,CAAC,CAAA;IACxD,SAAS,CAAC,MAAM,EAAG,MAAM,CAAA;IACzB,SAAS,CAAC,WAAW,CAAC,EAAE,WAAW,CAAA;IAEnC,oBAAoB,CAAC,OAAO,EAAE,iBAAiB,CAAC,OAAO,CAAC,GAAG,IAAI;IAI/D,SAAS,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAI/B,cAAc,CAAC,MAAM,EAAE,WAAW,GAAG,IAAI;cAIzB,aAAa,IAAI,OAAO,CAAC,OAAO,CAAC;cAKjC,QAAQ,IAAI,OAAO,CAAC,GAAG,CAAC;IAQlC,OAAO,CAAC,OAAO,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAK9C,QAAQ,CAAC,EAAE,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC;IAKjE,MAAM,CAAC,IAAI,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC;IAK1D,MAAM,CAAC,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC;IAKvE,OAAO,CAAC,EAAE,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC;CAIhE"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { AbstractRepository } from "./AbstractRepository.js";
|
|
2
|
+
import { EntityRegistry } from "../entity/EntityRegistry.js";
|
|
3
|
+
export class MongooseRepository extends AbstractRepository {
|
|
4
|
+
connectionManager;
|
|
5
|
+
tenant;
|
|
6
|
+
entityClass;
|
|
7
|
+
setConnectionManager(manager) {
|
|
8
|
+
this.connectionManager = manager;
|
|
9
|
+
}
|
|
10
|
+
setTenant(tenant) {
|
|
11
|
+
this.tenant = tenant;
|
|
12
|
+
}
|
|
13
|
+
setEntityClass(entity) {
|
|
14
|
+
this.entityClass = entity;
|
|
15
|
+
}
|
|
16
|
+
async getConnection() {
|
|
17
|
+
return this.connectionManager.getConnection(this.tenant);
|
|
18
|
+
}
|
|
19
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
20
|
+
async getModel() {
|
|
21
|
+
if (!this.entityClass) {
|
|
22
|
+
throw new Error("[TypeRoad] No entity class bound to this repository. Use @Repository({ entity: ... })");
|
|
23
|
+
}
|
|
24
|
+
const connection = await this.getConnection();
|
|
25
|
+
return EntityRegistry.getMongooseModel(this.entityClass, connection);
|
|
26
|
+
}
|
|
27
|
+
async findAll(options) {
|
|
28
|
+
const Model = await this.getModel();
|
|
29
|
+
return Model.find(options ?? {});
|
|
30
|
+
}
|
|
31
|
+
async findByPk(id, options) {
|
|
32
|
+
const Model = await this.getModel();
|
|
33
|
+
return Model.findById(id, null, options);
|
|
34
|
+
}
|
|
35
|
+
async create(data, options) {
|
|
36
|
+
const Model = await this.getModel();
|
|
37
|
+
return Model.create(data, options);
|
|
38
|
+
}
|
|
39
|
+
async update(id, data, options) {
|
|
40
|
+
const Model = await this.getModel();
|
|
41
|
+
return Model.findByIdAndUpdate(id, data, { new: true, ...(options ?? {}) });
|
|
42
|
+
}
|
|
43
|
+
async destroy(id, options) {
|
|
44
|
+
const Model = await this.getModel();
|
|
45
|
+
return Model.findByIdAndDelete(id, options);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
//# sourceMappingURL=MongooseRepository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MongooseRepository.js","sourceRoot":"","sources":["../../src/core/MongooseRepository.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAA;AAG5D,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAA;AAE5D,MAAM,OAAgB,kBAAuC,SAAQ,kBAAkB;IAC3E,iBAAiB,CAA6B;IAC9C,MAAM,CAAS;IACf,WAAW,CAAc;IAEnC,oBAAoB,CAAC,OAAmC;QACtD,IAAI,CAAC,iBAAiB,GAAG,OAAO,CAAA;IAClC,CAAC;IAED,SAAS,CAAC,MAAc;QACtB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAA;IACtB,CAAC;IAED,cAAc,CAAC,MAAmB;QAChC,IAAI,CAAC,WAAW,GAAG,MAAM,CAAA;IAC3B,CAAC;IAES,KAAK,CAAC,aAAa;QAC3B,OAAO,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;IAC1D,CAAC;IAED,8DAA8D;IACpD,KAAK,CAAC,QAAQ;QACtB,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACtB,MAAM,IAAI,KAAK,CAAC,uFAAuF,CAAC,CAAA;QAC1G,CAAC;QACD,MAAM,UAAU,GAAG,MAAM,IAAI,CAAC,aAAa,EAAE,CAAA;QAC7C,OAAO,cAAc,CAAC,gBAAgB,CAAC,IAAI,CAAC,WAAW,EAAE,UAAU,CAAC,CAAA;IACtE,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,OAAiB;QAC7B,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAA;QACnC,OAAO,KAAK,CAAC,IAAI,CAAC,OAAO,IAAI,EAAE,CAAC,CAAA;IAClC,CAAC;IAED,KAAK,CAAC,QAAQ,CAAC,EAAW,EAAE,OAAiB;QAC3C,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAA;QACnC,OAAO,KAAK,CAAC,QAAQ,CAAC,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,CAAA;IAC1C,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,IAAa,EAAE,OAAiB;QAC3C,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAA;QACnC,OAAO,KAAK,CAAC,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,CAAA;IACpC,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,EAAW,EAAE,IAAa,EAAE,OAAiB;QACxD,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAA;QACnC,OAAO,KAAK,CAAC,iBAAiB,CAAC,EAAE,EAAE,IAAI,EAAE,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,CAAE,OAAkB,IAAI,EAAE,CAAC,EAAE,CAAC,CAAA;IACzF,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,EAAW,EAAE,OAAiB;QAC1C,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAA;QACnC,OAAO,KAAK,CAAC,iBAAiB,CAAC,EAAE,EAAE,OAAO,CAAC,CAAA;IAC7C,CAAC;CACF"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export type AfterCommitPayload = {
|
|
2
|
+
tenant?: string;
|
|
3
|
+
data: unknown;
|
|
4
|
+
};
|
|
5
|
+
export type AfterCommitHandler = (payload: AfterCommitPayload, buffer: ReadonlyMap<string, unknown[]>) => void | Promise<void>;
|
|
6
|
+
type EventHandler = (...args: unknown[]) => void | Promise<void>;
|
|
7
|
+
export declare class RequestEventBus {
|
|
8
|
+
private listeners;
|
|
9
|
+
private buffer;
|
|
10
|
+
on(event: "afterCommit", handler: AfterCommitHandler): void;
|
|
11
|
+
on(event: string, handler: EventHandler): void;
|
|
12
|
+
emit(event: string, payload: unknown): void;
|
|
13
|
+
private flush;
|
|
14
|
+
getBuffered(event: string): unknown[];
|
|
15
|
+
clear(): void;
|
|
16
|
+
}
|
|
17
|
+
export {};
|
|
18
|
+
//# sourceMappingURL=RequestEventBus.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RequestEventBus.d.ts","sourceRoot":"","sources":["../../src/core/RequestEventBus.ts"],"names":[],"mappings":"AAEA,MAAM,MAAM,kBAAkB,GAAG;IAAE,MAAM,CAAC,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,OAAO,CAAA;CAAE,CAAA;AACnE,MAAM,MAAM,kBAAkB,GAAG,CAAC,OAAO,EAAE,kBAAkB,EAAE,MAAM,EAAE,WAAW,CAAC,MAAM,EAAE,OAAO,EAAE,CAAC,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;AAC9H,KAAK,YAAY,GAAG,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;AAEhE,qBAAa,eAAe;IAC1B,OAAO,CAAC,SAAS,CAAoC;IACrD,OAAO,CAAC,MAAM,CAA+B;IAE7C,EAAE,CAAC,KAAK,EAAE,aAAa,EAAE,OAAO,EAAE,kBAAkB,GAAG,IAAI;IAC3D,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,YAAY,GAAG,IAAI;IAO9C,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,GAAG,IAAI;YAa7B,KAAK;IAiBnB,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,EAAE;IAIrC,KAAK,IAAI,IAAI;CAId"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
// --- RequestEventBus ---
|
|
2
|
+
export class RequestEventBus {
|
|
3
|
+
listeners = new Map();
|
|
4
|
+
buffer = new Map();
|
|
5
|
+
on(event, handler) {
|
|
6
|
+
const handlers = this.listeners.get(event) ?? [];
|
|
7
|
+
handlers.push(handler);
|
|
8
|
+
this.listeners.set(event, handlers);
|
|
9
|
+
}
|
|
10
|
+
emit(event, payload) {
|
|
11
|
+
if (event === "afterCommit") {
|
|
12
|
+
// Fire-and-forget: side effects run after response is already sent.
|
|
13
|
+
// Errors are caught to prevent unhandled rejections.
|
|
14
|
+
void this.flush(payload);
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
const buffered = this.buffer.get(event) ?? [];
|
|
18
|
+
buffered.push(payload);
|
|
19
|
+
this.buffer.set(event, buffered);
|
|
20
|
+
}
|
|
21
|
+
async flush(commitPayload) {
|
|
22
|
+
// Snapshot before clearing so handlers see a stable, immutable view of what was buffered
|
|
23
|
+
const snapshot = new Map(Array.from(this.buffer.entries()).map(([k, v]) => [k, [...v]]));
|
|
24
|
+
this.buffer.clear();
|
|
25
|
+
const handlers = this.listeners.get("afterCommit") ?? [];
|
|
26
|
+
for (const handler of handlers) {
|
|
27
|
+
try {
|
|
28
|
+
await handler(commitPayload, snapshot);
|
|
29
|
+
}
|
|
30
|
+
catch {
|
|
31
|
+
// Swallow per-handler errors — fire-and-forget side effects must not crash the process
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
getBuffered(event) {
|
|
36
|
+
return this.buffer.get(event) ?? [];
|
|
37
|
+
}
|
|
38
|
+
clear() {
|
|
39
|
+
this.listeners.clear();
|
|
40
|
+
this.buffer.clear();
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=RequestEventBus.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RequestEventBus.js","sourceRoot":"","sources":["../../src/core/RequestEventBus.ts"],"names":[],"mappings":"AAAA,0BAA0B;AAM1B,MAAM,OAAO,eAAe;IAClB,SAAS,GAAG,IAAI,GAAG,EAA0B,CAAA;IAC7C,MAAM,GAAG,IAAI,GAAG,EAAqB,CAAA;IAI7C,EAAE,CAAC,KAAa,EAAE,OAA0C;QAC1D,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,EAAE,CAAA;QAChD,QAAQ,CAAC,IAAI,CAAC,OAAuB,CAAC,CAAA;QACtC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAA;IACrC,CAAC;IAED,IAAI,CAAC,KAAa,EAAE,OAAgB;QAClC,IAAI,KAAK,KAAK,aAAa,EAAE,CAAC;YAC5B,oEAAoE;YACpE,qDAAqD;YACrD,KAAK,IAAI,CAAC,KAAK,CAAC,OAA6B,CAAC,CAAA;YAC9C,OAAM;QACR,CAAC;QAED,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,EAAE,CAAA;QAC7C,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;QACtB,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAA;IAClC,CAAC;IAEO,KAAK,CAAC,KAAK,CAAC,aAAiC;QACnD,yFAAyF;QACzF,MAAM,QAAQ,GAAmC,IAAI,GAAG,CACtD,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAC/D,CAAA;QACD,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAA;QAEnB,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,aAAa,CAAC,IAAI,EAAE,CAAA;QACxD,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;YAC/B,IAAI,CAAC;gBACH,MAAM,OAAO,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAA;YACxC,CAAC;YAAC,MAAM,CAAC;gBACP,uFAAuF;YACzF,CAAC;QACH,CAAC;IACH,CAAC;IAED,WAAW,CAAC,KAAa;QACvB,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,EAAE,CAAA;IACrC,CAAC;IAED,KAAK;QACH,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAA;QACtB,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAA;IACrB,CAAC;CACF"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type { Request, Response } from "express";
|
|
2
|
+
import { RequestEventBus } from "./RequestEventBus.js";
|
|
3
|
+
export declare class Sentinel {
|
|
4
|
+
readonly req: Request;
|
|
5
|
+
readonly res: Response;
|
|
6
|
+
readonly errors: Error[];
|
|
7
|
+
readonly eventBus: RequestEventBus;
|
|
8
|
+
transaction: unknown | null;
|
|
9
|
+
session: unknown | null;
|
|
10
|
+
constructor(req: Request, res: Response);
|
|
11
|
+
appendMo(mo: unknown): void;
|
|
12
|
+
appendNotification(notification: unknown): void;
|
|
13
|
+
appendError(error: Error): void;
|
|
14
|
+
hasErrors(): boolean;
|
|
15
|
+
commitAll(): Promise<void>;
|
|
16
|
+
rollbackAll(): Promise<void>;
|
|
17
|
+
finishRequest(data: unknown): Promise<void>;
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=Sentinel.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Sentinel.d.ts","sourceRoot":"","sources":["../../src/core/Sentinel.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAA;AAChD,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AAEtD,qBAAa,QAAQ;IACnB,QAAQ,CAAC,GAAG,EAAE,OAAO,CAAA;IACrB,QAAQ,CAAC,GAAG,EAAE,QAAQ,CAAA;IACtB,QAAQ,CAAC,MAAM,EAAE,KAAK,EAAE,CAAK;IAC7B,QAAQ,CAAC,QAAQ,EAAE,eAAe,CAAA;IAElC,WAAW,EAAE,OAAO,GAAG,IAAI,CAAO;IAClC,OAAO,EAAE,OAAO,GAAG,IAAI,CAAO;gBAElB,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,QAAQ;IAMvC,QAAQ,CAAC,EAAE,EAAE,OAAO,GAAG,IAAI;IAI3B,kBAAkB,CAAC,YAAY,EAAE,OAAO,GAAG,IAAI;IAI/C,WAAW,CAAC,KAAK,EAAE,KAAK,GAAG,IAAI;IAI/B,SAAS,IAAI,OAAO;IAId,SAAS,IAAI,OAAO,CAAC,IAAI,CAAC;IAS1B,WAAW,IAAI,OAAO,CAAC,IAAI,CAAC;IAS5B,aAAa,CAAC,IAAI,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;CAclD"}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { RequestEventBus } from "./RequestEventBus.js";
|
|
2
|
+
export class Sentinel {
|
|
3
|
+
req;
|
|
4
|
+
res;
|
|
5
|
+
errors = [];
|
|
6
|
+
eventBus;
|
|
7
|
+
transaction = null;
|
|
8
|
+
session = null;
|
|
9
|
+
constructor(req, res) {
|
|
10
|
+
this.req = req;
|
|
11
|
+
this.res = res;
|
|
12
|
+
this.eventBus = new RequestEventBus();
|
|
13
|
+
}
|
|
14
|
+
appendMo(mo) {
|
|
15
|
+
this.eventBus.emit("matchingObject", mo);
|
|
16
|
+
}
|
|
17
|
+
appendNotification(notification) {
|
|
18
|
+
this.eventBus.emit("notification", notification);
|
|
19
|
+
}
|
|
20
|
+
appendError(error) {
|
|
21
|
+
this.errors.push(error);
|
|
22
|
+
}
|
|
23
|
+
hasErrors() {
|
|
24
|
+
return this.errors.length > 0;
|
|
25
|
+
}
|
|
26
|
+
async commitAll() {
|
|
27
|
+
if (this.transaction && typeof this.transaction.commit === "function") {
|
|
28
|
+
await this.transaction.commit();
|
|
29
|
+
}
|
|
30
|
+
if (this.session && typeof this.session.commitTransaction === "function") {
|
|
31
|
+
await this.session.commitTransaction();
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
async rollbackAll() {
|
|
35
|
+
if (this.transaction && typeof this.transaction.rollback === "function") {
|
|
36
|
+
await this.transaction.rollback();
|
|
37
|
+
}
|
|
38
|
+
if (this.session && typeof this.session.abortTransaction === "function") {
|
|
39
|
+
await this.session.abortTransaction();
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
async finishRequest(data) {
|
|
43
|
+
if (this.hasErrors()) {
|
|
44
|
+
await this.rollbackAll();
|
|
45
|
+
this.res.status(500).json({ errors: this.errors.map((e) => e.message) });
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
await this.commitAll();
|
|
49
|
+
this.eventBus.emit("afterCommit", {
|
|
50
|
+
tenant: this.req.tenant,
|
|
51
|
+
data,
|
|
52
|
+
});
|
|
53
|
+
this.res.json(data);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
//# sourceMappingURL=Sentinel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Sentinel.js","sourceRoot":"","sources":["../../src/core/Sentinel.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AAEtD,MAAM,OAAO,QAAQ;IACV,GAAG,CAAS;IACZ,GAAG,CAAU;IACb,MAAM,GAAY,EAAE,CAAA;IACpB,QAAQ,CAAiB;IAElC,WAAW,GAAmB,IAAI,CAAA;IAClC,OAAO,GAAmB,IAAI,CAAA;IAE9B,YAAY,GAAY,EAAE,GAAa;QACrC,IAAI,CAAC,GAAG,GAAG,GAAG,CAAA;QACd,IAAI,CAAC,GAAG,GAAG,GAAG,CAAA;QACd,IAAI,CAAC,QAAQ,GAAG,IAAI,eAAe,EAAE,CAAA;IACvC,CAAC;IAED,QAAQ,CAAC,EAAW;QAClB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,gBAAgB,EAAE,EAAE,CAAC,CAAA;IAC1C,CAAC;IAED,kBAAkB,CAAC,YAAqB;QACtC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,cAAc,EAAE,YAAY,CAAC,CAAA;IAClD,CAAC;IAED,WAAW,CAAC,KAAY;QACtB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IACzB,CAAC;IAED,SAAS;QACP,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAA;IAC/B,CAAC;IAED,KAAK,CAAC,SAAS;QACb,IAAI,IAAI,CAAC,WAAW,IAAI,OAAQ,IAAI,CAAC,WAAuC,CAAC,MAAM,KAAK,UAAU,EAAE,CAAC;YACnG,MAAO,IAAI,CAAC,WAA2C,CAAC,MAAM,EAAE,CAAA;QAClE,CAAC;QACD,IAAI,IAAI,CAAC,OAAO,IAAI,OAAQ,IAAI,CAAC,OAAmC,CAAC,iBAAiB,KAAK,UAAU,EAAE,CAAC;YACtG,MAAO,IAAI,CAAC,OAAkD,CAAC,iBAAiB,EAAE,CAAA;QACpF,CAAC;IACH,CAAC;IAED,KAAK,CAAC,WAAW;QACf,IAAI,IAAI,CAAC,WAAW,IAAI,OAAQ,IAAI,CAAC,WAAuC,CAAC,QAAQ,KAAK,UAAU,EAAE,CAAC;YACrG,MAAO,IAAI,CAAC,WAA6C,CAAC,QAAQ,EAAE,CAAA;QACtE,CAAC;QACD,IAAI,IAAI,CAAC,OAAO,IAAI,OAAQ,IAAI,CAAC,OAAmC,CAAC,gBAAgB,KAAK,UAAU,EAAE,CAAC;YACrG,MAAO,IAAI,CAAC,OAAiD,CAAC,gBAAgB,EAAE,CAAA;QAClF,CAAC;IACH,CAAC;IAED,KAAK,CAAC,aAAa,CAAC,IAAa;QAC/B,IAAI,IAAI,CAAC,SAAS,EAAE,EAAE,CAAC;YACrB,MAAM,IAAI,CAAC,WAAW,EAAE,CAAA;YACxB,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAA;YACxE,OAAM;QACR,CAAC;QAED,MAAM,IAAI,CAAC,SAAS,EAAE,CAAA;QACtB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,EAAE;YAChC,MAAM,EAAG,IAAI,CAAC,GAAqC,CAAC,MAAM;YAC1D,IAAI;SACL,CAAC,CAAA;QACF,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IACrB,CAAC;CACF"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { AbstractRepository } from "./AbstractRepository.js";
|
|
2
|
+
import type { ConnectionManager } from "../database/ConnectionManager.js";
|
|
3
|
+
import type { Constructor } from "../container/Container.js";
|
|
4
|
+
export declare abstract class SequelizeRepository<_TEntity = unknown> extends AbstractRepository {
|
|
5
|
+
protected connectionManager: ConnectionManager<unknown>;
|
|
6
|
+
protected tenant: string;
|
|
7
|
+
protected entityClass?: Constructor;
|
|
8
|
+
setConnectionManager(manager: ConnectionManager<unknown>): void;
|
|
9
|
+
setTenant(tenant: string): void;
|
|
10
|
+
setEntityClass(entity: Constructor): void;
|
|
11
|
+
protected getConnection(): Promise<unknown>;
|
|
12
|
+
protected getModel(): Promise<any>;
|
|
13
|
+
findAll(options?: unknown): Promise<unknown[]>;
|
|
14
|
+
findByPk(id: unknown, options?: unknown): Promise<unknown | null>;
|
|
15
|
+
create(data: unknown, options?: unknown): Promise<unknown>;
|
|
16
|
+
update(id: unknown, data: unknown, options?: unknown): Promise<unknown>;
|
|
17
|
+
destroy(id: unknown, options?: unknown): Promise<unknown>;
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=SequelizeRepository.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SequelizeRepository.d.ts","sourceRoot":"","sources":["../../src/core/SequelizeRepository.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAA;AAC5D,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAA;AACzE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAA;AAG5D,8BAAsB,mBAAmB,CAAC,QAAQ,GAAG,OAAO,CAAE,SAAQ,kBAAkB;IACtF,SAAS,CAAC,iBAAiB,EAAG,iBAAiB,CAAC,OAAO,CAAC,CAAA;IACxD,SAAS,CAAC,MAAM,EAAG,MAAM,CAAA;IACzB,SAAS,CAAC,WAAW,CAAC,EAAE,WAAW,CAAA;IAEnC,oBAAoB,CAAC,OAAO,EAAE,iBAAiB,CAAC,OAAO,CAAC,GAAG,IAAI;IAI/D,SAAS,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAI/B,cAAc,CAAC,MAAM,EAAE,WAAW,GAAG,IAAI;cAIzB,aAAa,IAAI,OAAO,CAAC,OAAO,CAAC;cAKjC,QAAQ,IAAI,OAAO,CAAC,GAAG,CAAC;IAQlC,OAAO,CAAC,OAAO,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAK9C,QAAQ,CAAC,EAAE,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC;IAKjE,MAAM,CAAC,IAAI,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC;IAK1D,MAAM,CAAC,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC;IAKvE,OAAO,CAAC,EAAE,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC;CAIhE"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { AbstractRepository } from "./AbstractRepository.js";
|
|
2
|
+
import { EntityRegistry } from "../entity/EntityRegistry.js";
|
|
3
|
+
export class SequelizeRepository extends AbstractRepository {
|
|
4
|
+
connectionManager;
|
|
5
|
+
tenant;
|
|
6
|
+
entityClass;
|
|
7
|
+
setConnectionManager(manager) {
|
|
8
|
+
this.connectionManager = manager;
|
|
9
|
+
}
|
|
10
|
+
setTenant(tenant) {
|
|
11
|
+
this.tenant = tenant;
|
|
12
|
+
}
|
|
13
|
+
setEntityClass(entity) {
|
|
14
|
+
this.entityClass = entity;
|
|
15
|
+
}
|
|
16
|
+
async getConnection() {
|
|
17
|
+
return this.connectionManager.getConnection(this.tenant);
|
|
18
|
+
}
|
|
19
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
20
|
+
async getModel() {
|
|
21
|
+
if (!this.entityClass) {
|
|
22
|
+
throw new Error("[TypeRoad] No entity class bound to this repository. Use @Repository({ entity: ... })");
|
|
23
|
+
}
|
|
24
|
+
const connection = await this.getConnection();
|
|
25
|
+
return EntityRegistry.getSequelizeModel(this.entityClass, connection);
|
|
26
|
+
}
|
|
27
|
+
async findAll(options) {
|
|
28
|
+
const Model = await this.getModel();
|
|
29
|
+
return Model.findAll(options);
|
|
30
|
+
}
|
|
31
|
+
async findByPk(id, options) {
|
|
32
|
+
const Model = await this.getModel();
|
|
33
|
+
return Model.findByPk(id, options);
|
|
34
|
+
}
|
|
35
|
+
async create(data, options) {
|
|
36
|
+
const Model = await this.getModel();
|
|
37
|
+
return Model.create(data, options);
|
|
38
|
+
}
|
|
39
|
+
async update(id, data, options) {
|
|
40
|
+
const Model = await this.getModel();
|
|
41
|
+
return Model.update(data, { where: { id }, ...(options ?? {}) });
|
|
42
|
+
}
|
|
43
|
+
async destroy(id, options) {
|
|
44
|
+
const Model = await this.getModel();
|
|
45
|
+
return Model.destroy({ where: { id }, ...(options ?? {}) });
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
//# sourceMappingURL=SequelizeRepository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SequelizeRepository.js","sourceRoot":"","sources":["../../src/core/SequelizeRepository.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAA;AAG5D,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAA;AAE5D,MAAM,OAAgB,mBAAwC,SAAQ,kBAAkB;IAC5E,iBAAiB,CAA6B;IAC9C,MAAM,CAAS;IACf,WAAW,CAAc;IAEnC,oBAAoB,CAAC,OAAmC;QACtD,IAAI,CAAC,iBAAiB,GAAG,OAAO,CAAA;IAClC,CAAC;IAED,SAAS,CAAC,MAAc;QACtB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAA;IACtB,CAAC;IAED,cAAc,CAAC,MAAmB;QAChC,IAAI,CAAC,WAAW,GAAG,MAAM,CAAA;IAC3B,CAAC;IAES,KAAK,CAAC,aAAa;QAC3B,OAAO,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;IAC1D,CAAC;IAED,8DAA8D;IACpD,KAAK,CAAC,QAAQ;QACtB,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACtB,MAAM,IAAI,KAAK,CAAC,uFAAuF,CAAC,CAAA;QAC1G,CAAC;QACD,MAAM,UAAU,GAAG,MAAM,IAAI,CAAC,aAAa,EAAE,CAAA;QAC7C,OAAO,cAAc,CAAC,iBAAiB,CAAC,IAAI,CAAC,WAAW,EAAE,UAAU,CAAC,CAAA;IACvE,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,OAAiB;QAC7B,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAA;QACnC,OAAO,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,CAAA;IAC/B,CAAC;IAED,KAAK,CAAC,QAAQ,CAAC,EAAW,EAAE,OAAiB;QAC3C,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAA;QACnC,OAAO,KAAK,CAAC,QAAQ,CAAC,EAAE,EAAE,OAAO,CAAC,CAAA;IACpC,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,IAAa,EAAE,OAAiB;QAC3C,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAA;QACnC,OAAO,KAAK,CAAC,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,CAAA;IACpC,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,EAAW,EAAE,IAAa,EAAE,OAAiB;QACxD,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAA;QACnC,OAAO,KAAK,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,CAAE,OAAkB,IAAI,EAAE,CAAC,EAAE,CAAC,CAAA;IAC9E,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,EAAW,EAAE,OAAiB;QAC1C,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAA;QACnC,OAAO,KAAK,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,CAAE,OAAkB,IAAI,EAAE,CAAC,EAAE,CAAC,CAAA;IACzE,CAAC;CACF"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export { AbstractController } from "./AbstractController.js";
|
|
2
|
+
export type { RouteConfig, ControllerConfig } from "./AbstractController.js";
|
|
3
|
+
export { AbstractService } from "./AbstractService.js";
|
|
4
|
+
export type { ServiceConfig } from "./AbstractService.js";
|
|
5
|
+
export { AbstractRepository } from "./AbstractRepository.js";
|
|
6
|
+
export { SequelizeRepository } from "./SequelizeRepository.js";
|
|
7
|
+
export { MongooseRepository } from "./MongooseRepository.js";
|
|
8
|
+
export { Sentinel } from "./Sentinel.js";
|
|
9
|
+
export { RequestEventBus } from "./RequestEventBus.js";
|
|
10
|
+
export type { AfterCommitPayload, AfterCommitHandler } from "./RequestEventBus.js";
|
|
11
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/core/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAA;AAC5D,YAAY,EAAE,WAAW,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAA;AAE5E,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AACtD,YAAY,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AAEzD,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAA;AAC5D,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAA;AAC9D,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAA;AAE5D,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AACxC,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AACtD,YAAY,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAA"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export { AbstractController } from "./AbstractController.js";
|
|
2
|
+
export { AbstractService } from "./AbstractService.js";
|
|
3
|
+
export { AbstractRepository } from "./AbstractRepository.js";
|
|
4
|
+
export { SequelizeRepository } from "./SequelizeRepository.js";
|
|
5
|
+
export { MongooseRepository } from "./MongooseRepository.js";
|
|
6
|
+
export { Sentinel } from "./Sentinel.js";
|
|
7
|
+
export { RequestEventBus } from "./RequestEventBus.js";
|
|
8
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/core/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAA;AAG5D,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AAGtD,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAA;AAC5D,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAA;AAC9D,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAA;AAE5D,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AACxC,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
export interface DatabaseConfig {
|
|
2
|
+
host?: string;
|
|
3
|
+
port?: number;
|
|
4
|
+
user?: string;
|
|
5
|
+
password?: string;
|
|
6
|
+
prefix?: string;
|
|
7
|
+
uri?: string;
|
|
8
|
+
pool?: {
|
|
9
|
+
max?: number;
|
|
10
|
+
min?: number;
|
|
11
|
+
acquire?: number;
|
|
12
|
+
idle?: number;
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
export declare abstract class ConnectionManager<TConnection> {
|
|
16
|
+
protected connections: Map<string, TConnection>;
|
|
17
|
+
protected config: DatabaseConfig;
|
|
18
|
+
constructor(config: DatabaseConfig);
|
|
19
|
+
abstract getConnection(tenant: string, dataSource?: string): Promise<TConnection>;
|
|
20
|
+
abstract closeAll(): Promise<void>;
|
|
21
|
+
abstract isHealthy(tenant: string): Promise<boolean>;
|
|
22
|
+
get engine(): string;
|
|
23
|
+
protected buildKey(tenant: string, dataSource?: string): string;
|
|
24
|
+
protected resolveDatabaseName(tenant: string, dataSource?: string): string;
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=ConnectionManager.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConnectionManager.d.ts","sourceRoot":"","sources":["../../src/database/ConnectionManager.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,cAAc;IAC7B,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,GAAG,CAAC,EAAE,MAAM,CAAA;IACZ,IAAI,CAAC,EAAE;QACL,GAAG,CAAC,EAAE,MAAM,CAAA;QACZ,GAAG,CAAC,EAAE,MAAM,CAAA;QACZ,OAAO,CAAC,EAAE,MAAM,CAAA;QAChB,IAAI,CAAC,EAAE,MAAM,CAAA;KACd,CAAA;CACF;AAED,8BAAsB,iBAAiB,CAAC,WAAW;IACjD,SAAS,CAAC,WAAW,2BAAiC;IACtD,SAAS,CAAC,MAAM,EAAE,cAAc,CAAA;gBAEpB,MAAM,EAAE,cAAc;IAIlC,QAAQ,CAAC,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC;IAEjF,QAAQ,CAAC,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;IAElC,QAAQ,CAAC,SAAS,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAEpD,IAAI,MAAM,IAAI,MAAM,CAEnB;IAED,SAAS,CAAC,QAAQ,CAAC,MAAM,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,MAAM;IAI/D,SAAS,CAAC,mBAAmB,CAAC,MAAM,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,MAAM;CAG3E"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export class ConnectionManager {
|
|
2
|
+
connections = new Map();
|
|
3
|
+
config;
|
|
4
|
+
constructor(config) {
|
|
5
|
+
this.config = config;
|
|
6
|
+
}
|
|
7
|
+
get engine() {
|
|
8
|
+
return this.constructor.name;
|
|
9
|
+
}
|
|
10
|
+
buildKey(tenant, dataSource) {
|
|
11
|
+
return dataSource ? `${tenant}:${dataSource}` : tenant;
|
|
12
|
+
}
|
|
13
|
+
resolveDatabaseName(tenant, dataSource) {
|
|
14
|
+
return dataSource ?? `${this.config.prefix}_${tenant}`;
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=ConnectionManager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConnectionManager.js","sourceRoot":"","sources":["../../src/database/ConnectionManager.ts"],"names":[],"mappings":"AAeA,MAAM,OAAgB,iBAAiB;IAC3B,WAAW,GAAG,IAAI,GAAG,EAAuB,CAAA;IAC5C,MAAM,CAAgB;IAEhC,YAAY,MAAsB;QAChC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAA;IACtB,CAAC;IAQD,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAA;IAC9B,CAAC;IAES,QAAQ,CAAC,MAAc,EAAE,UAAmB;QACpD,OAAO,UAAU,CAAC,CAAC,CAAC,GAAG,MAAM,IAAI,UAAU,EAAE,CAAC,CAAC,CAAC,MAAM,CAAA;IACxD,CAAC;IAES,mBAAmB,CAAC,MAAc,EAAE,UAAmB;QAC/D,OAAO,UAAU,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,IAAI,MAAM,EAAE,CAAA;IACxD,CAAC;CACF"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { ConnectionManager } from "./ConnectionManager.js";
|
|
2
|
+
export declare class MongoConnectionManager extends ConnectionManager<unknown> {
|
|
3
|
+
getConnection(tenant: string, dataSource?: string): Promise<unknown>;
|
|
4
|
+
closeAll(): Promise<void>;
|
|
5
|
+
isHealthy(tenant: string): Promise<boolean>;
|
|
6
|
+
get engine(): string;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=MongoConnectionManager.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MongoConnectionManager.d.ts","sourceRoot":"","sources":["../../src/database/MongoConnectionManager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAA;AAE1D,qBAAa,sBAAuB,SAAQ,iBAAiB,CAAC,OAAO,CAAC;IAC9D,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IA6BpE,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;IASzB,SAAS,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IASjD,IAAa,MAAM,IAAI,MAAM,CAE5B;CACF"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { ConnectionManager } from "./ConnectionManager.js";
|
|
2
|
+
export class MongoConnectionManager extends ConnectionManager {
|
|
3
|
+
async getConnection(tenant, dataSource) {
|
|
4
|
+
const key = this.buildKey(tenant, dataSource);
|
|
5
|
+
if (this.connections.has(key)) {
|
|
6
|
+
return this.connections.get(key);
|
|
7
|
+
}
|
|
8
|
+
const dbName = this.resolveDatabaseName(tenant, dataSource);
|
|
9
|
+
const mongoose = await import("mongoose");
|
|
10
|
+
let uri;
|
|
11
|
+
if (this.config.uri) {
|
|
12
|
+
// Replace database name in URI, preserving query params
|
|
13
|
+
uri = this.config.uri.replace(/\/([^/?]*)(\?|$)/, `/${dbName}$2`);
|
|
14
|
+
}
|
|
15
|
+
else {
|
|
16
|
+
const host = this.config.host ?? "localhost";
|
|
17
|
+
const port = this.config.port ?? 27017;
|
|
18
|
+
const auth = this.config.user && this.config.password
|
|
19
|
+
? `${this.config.user}:${this.config.password}@`
|
|
20
|
+
: "";
|
|
21
|
+
uri = `mongodb://${auth}${host}:${port}/${dbName}`;
|
|
22
|
+
}
|
|
23
|
+
const connection = await mongoose.createConnection(uri).asPromise();
|
|
24
|
+
this.connections.set(key, connection);
|
|
25
|
+
return connection;
|
|
26
|
+
}
|
|
27
|
+
async closeAll() {
|
|
28
|
+
const closing = [...this.connections.entries()].map(async ([key, conn]) => {
|
|
29
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
30
|
+
await conn.close();
|
|
31
|
+
this.connections.delete(key);
|
|
32
|
+
});
|
|
33
|
+
await Promise.all(closing);
|
|
34
|
+
}
|
|
35
|
+
async isHealthy(tenant) {
|
|
36
|
+
const key = this.buildKey(tenant);
|
|
37
|
+
const conn = this.connections.get(key);
|
|
38
|
+
if (!conn)
|
|
39
|
+
return false;
|
|
40
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
41
|
+
return conn.readyState === 1;
|
|
42
|
+
}
|
|
43
|
+
get engine() {
|
|
44
|
+
return "mongoose";
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=MongoConnectionManager.js.map
|