@expressots/core 2.9.0 → 2.10.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.
Files changed (95) hide show
  1. package/lib/CHANGELOG.md +133 -85
  2. package/lib/cjs/application/app-container.js +93 -94
  3. package/lib/cjs/application/application-factory.js +74 -74
  4. package/lib/cjs/application/index.js +7 -7
  5. package/lib/cjs/common/color-service.provider.js +46 -47
  6. package/lib/cjs/common/index.js +2 -2
  7. package/lib/cjs/common/package-resolver.provider.js +35 -35
  8. package/lib/cjs/common/project-config.provider.js +2 -2
  9. package/lib/cjs/console/console.js +60 -61
  10. package/lib/cjs/console/index.js +5 -5
  11. package/lib/cjs/container-module/container-module.js +111 -111
  12. package/lib/cjs/container-module/index.js +6 -6
  13. package/lib/cjs/controller/base-controller.js +74 -75
  14. package/lib/cjs/controller/index.js +5 -5
  15. package/lib/cjs/decorator/index.js +17 -17
  16. package/lib/cjs/decorator/scope-binding.js +44 -44
  17. package/lib/cjs/error/app-error.js +26 -26
  18. package/lib/cjs/error/error-handler-middleware.js +28 -28
  19. package/lib/cjs/error/index.js +9 -9
  20. package/lib/cjs/error/report.js +53 -54
  21. package/lib/cjs/error/status-code.js +89 -89
  22. package/lib/cjs/index.js +26 -26
  23. package/lib/cjs/middleware/index.js +32 -32
  24. package/lib/cjs/middleware/interfaces/body-parser.interface.js +2 -2
  25. package/lib/cjs/middleware/interfaces/compression.interface.js +2 -2
  26. package/lib/cjs/middleware/interfaces/cookie-parser.interface.js +2 -2
  27. package/lib/cjs/middleware/interfaces/cookie-session/cookie-session.interface.js +2 -2
  28. package/lib/cjs/middleware/interfaces/cookie-session/keygrip.interface.js +2 -2
  29. package/lib/cjs/middleware/interfaces/cors.interface.js +2 -2
  30. package/lib/cjs/middleware/interfaces/express-rate-limit.interface.js +2 -2
  31. package/lib/cjs/middleware/interfaces/express-session.interface.js +2 -2
  32. package/lib/cjs/middleware/interfaces/helmet.interface.js +2 -2
  33. package/lib/cjs/middleware/interfaces/morgan.interface.js +2 -2
  34. package/lib/cjs/middleware/interfaces/multer.interface.js +2 -2
  35. package/lib/cjs/middleware/interfaces/serve-favicon.interface.js +2 -2
  36. package/lib/cjs/middleware/interfaces/serve-static.interface.js +2 -2
  37. package/lib/cjs/middleware/middleware-resolver.js +72 -72
  38. package/lib/cjs/middleware/middleware-service.js +480 -481
  39. package/lib/cjs/provider/db-in-memory/db-in-memory.provider.js +82 -82
  40. package/lib/cjs/provider/dto-validator/dto-validator.provider.js +53 -53
  41. package/lib/cjs/provider/environment/env-validator.provider.js +98 -98
  42. package/lib/cjs/provider/index.js +13 -13
  43. package/lib/cjs/provider/logger/logger.provider.js +117 -117
  44. package/lib/cjs/provider/provider-manager.js +49 -50
  45. package/lib/cjs/render/handlebars.interface.js +2 -2
  46. package/lib/cjs/render/index.js +2 -2
  47. package/lib/cjs/render/render.type.js +2 -2
  48. package/lib/cjs/types/application/app-container.d.ts +62 -62
  49. package/lib/cjs/types/application/application-factory.d.ts +34 -34
  50. package/lib/cjs/types/application/index.d.ts +2 -2
  51. package/lib/cjs/types/common/color-service.provider.d.ts +29 -29
  52. package/lib/cjs/types/common/index.d.ts +1 -1
  53. package/lib/cjs/types/common/package-resolver.provider.d.ts +8 -8
  54. package/lib/cjs/types/common/project-config.provider.d.ts +56 -47
  55. package/lib/cjs/types/console/console.d.ts +27 -27
  56. package/lib/cjs/types/console/index.d.ts +1 -1
  57. package/lib/cjs/types/container-module/container-module.d.ts +28 -28
  58. package/lib/cjs/types/container-module/index.d.ts +1 -1
  59. package/lib/cjs/types/controller/base-controller.d.ts +48 -48
  60. package/lib/cjs/types/controller/index.d.ts +1 -1
  61. package/lib/cjs/types/decorator/index.d.ts +1 -1
  62. package/lib/cjs/types/decorator/scope-binding.d.ts +33 -33
  63. package/lib/cjs/types/error/app-error.d.ts +29 -29
  64. package/lib/cjs/types/error/error-handler-middleware.d.ts +11 -11
  65. package/lib/cjs/types/error/index.d.ts +3 -3
  66. package/lib/cjs/types/error/report.d.ts +25 -25
  67. package/lib/cjs/types/error/status-code.d.ts +136 -136
  68. package/lib/cjs/types/index.d.ts +10 -10
  69. package/lib/cjs/types/middleware/index.d.ts +13 -13
  70. package/lib/cjs/types/middleware/interfaces/body-parser.interface.d.ts +33 -33
  71. package/lib/cjs/types/middleware/interfaces/compression.interface.d.ts +98 -98
  72. package/lib/cjs/types/middleware/interfaces/cookie-parser.interface.d.ts +9 -9
  73. package/lib/cjs/types/middleware/interfaces/cookie-session/cookie-session.interface.d.ts +57 -57
  74. package/lib/cjs/types/middleware/interfaces/cookie-session/keygrip.interface.d.ts +27 -27
  75. package/lib/cjs/types/middleware/interfaces/cors.interface.d.ts +57 -57
  76. package/lib/cjs/types/middleware/interfaces/express-rate-limit.interface.d.ts +292 -292
  77. package/lib/cjs/types/middleware/interfaces/express-session.interface.d.ts +207 -207
  78. package/lib/cjs/types/middleware/interfaces/helmet.interface.d.ts +210 -210
  79. package/lib/cjs/types/middleware/interfaces/morgan.interface.d.ts +40 -40
  80. package/lib/cjs/types/middleware/interfaces/multer.interface.d.ts +255 -255
  81. package/lib/cjs/types/middleware/interfaces/serve-favicon.interface.d.ts +11 -11
  82. package/lib/cjs/types/middleware/interfaces/serve-static.interface.d.ts +70 -70
  83. package/lib/cjs/types/middleware/middleware-resolver.d.ts +11 -11
  84. package/lib/cjs/types/middleware/middleware-service.d.ts +368 -368
  85. package/lib/cjs/types/provider/db-in-memory/db-in-memory.provider.d.ts +43 -43
  86. package/lib/cjs/types/provider/dto-validator/dto-validator.provider.d.ts +11 -11
  87. package/lib/cjs/types/provider/environment/env-validator.provider.d.ts +35 -35
  88. package/lib/cjs/types/provider/index.d.ts +5 -5
  89. package/lib/cjs/types/provider/logger/logger.provider.d.ts +54 -54
  90. package/lib/cjs/types/provider/provider-manager.d.ts +16 -16
  91. package/lib/cjs/types/render/handlebars.interface.d.ts +46 -46
  92. package/lib/cjs/types/render/index.d.ts +2 -2
  93. package/lib/cjs/types/render/render.type.d.ts +12 -12
  94. package/lib/package.json +16 -17
  95. package/package.json +16 -17
@@ -1,47 +1,46 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.bgColorCodes = exports.colorCodes = exports.ColorStyle = void 0;
4
- /**
5
- * Mapping of text color codes.
6
- *
7
- * @remarks
8
- * Defines the ANSI escape codes for the corresponding colors in the terminal.
9
- */
10
- const colorCodes = {
11
- red: "\x1b[31m",
12
- green: "\x1b[32m",
13
- yellow: "\x1b[33m",
14
- blue: "\x1b[34m",
15
- white: "\x1b[37m",
16
- black: "\x1b[30m",
17
- none: "\x1b[0m",
18
- };
19
- exports.colorCodes = colorCodes;
20
- /**
21
- * ANSI escape color codes mapping for different background colors.
22
- */
23
- const bgColorCodes = {
24
- red: "\x1b[41m",
25
- green: "\x1b[42m",
26
- yellow: "\x1b[43m",
27
- blue: "\x1b[44m",
28
- white: "\x1b[47m",
29
- black: "\x1b[40m",
30
- none: "\x1b[0m",
31
- };
32
- exports.bgColorCodes = bgColorCodes;
33
- /**
34
- * Enum representing possible color styles for console output.
35
- *
36
- * @remarks
37
- * Enum values correspond to the string representations of colors.
38
- */
39
- var ColorStyle;
40
- (function (ColorStyle) {
41
- ColorStyle["None"] = "none";
42
- ColorStyle["Yellow"] = "yellow";
43
- ColorStyle["Blue"] = "blue";
44
- ColorStyle["Green"] = "green";
45
- ColorStyle["Red"] = "red";
46
- })(ColorStyle || (ColorStyle = {}));
47
- exports.ColorStyle = ColorStyle;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.bgColorCodes = exports.colorCodes = exports.ColorStyle = void 0;
4
+ /**
5
+ * Mapping of text color codes.
6
+ *
7
+ * @remarks
8
+ * Defines the ANSI escape codes for the corresponding colors in the terminal.
9
+ */
10
+ const colorCodes = {
11
+ red: "\x1b[31m",
12
+ green: "\x1b[32m",
13
+ yellow: "\x1b[33m",
14
+ blue: "\x1b[34m",
15
+ white: "\x1b[37m",
16
+ black: "\x1b[30m",
17
+ none: "\x1b[0m",
18
+ };
19
+ exports.colorCodes = colorCodes;
20
+ /**
21
+ * ANSI escape color codes mapping for different background colors.
22
+ */
23
+ const bgColorCodes = {
24
+ red: "\x1b[41m",
25
+ green: "\x1b[42m",
26
+ yellow: "\x1b[43m",
27
+ blue: "\x1b[44m",
28
+ white: "\x1b[47m",
29
+ black: "\x1b[40m",
30
+ none: "\x1b[0m",
31
+ };
32
+ exports.bgColorCodes = bgColorCodes;
33
+ /**
34
+ * Enum representing possible color styles for console output.
35
+ *
36
+ * @remarks
37
+ * Enum values correspond to the string representations of colors.
38
+ */
39
+ var ColorStyle;
40
+ (function (ColorStyle) {
41
+ ColorStyle["None"] = "none";
42
+ ColorStyle["Yellow"] = "yellow";
43
+ ColorStyle["Blue"] = "blue";
44
+ ColorStyle["Green"] = "green";
45
+ ColorStyle["Red"] = "red";
46
+ })(ColorStyle || (exports.ColorStyle = ColorStyle = {}));
@@ -1,2 +1,2 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -1,35 +1,35 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.packageResolver = void 0;
4
- /* eslint-disable @typescript-eslint/no-explicit-any */
5
- const logger_provider_1 = require("../provider/logger/logger.provider");
6
- /**
7
- * Resolve package from the current working directory.
8
- * @param packageName
9
- * @param options
10
- * @returns
11
- */
12
- function packageResolver(packageName, ...options) {
13
- const logger = new logger_provider_1.Logger();
14
- try {
15
- const hasPackage = require.resolve(packageName, {
16
- paths: [process.cwd()],
17
- });
18
- if (hasPackage) {
19
- // eslint-disable-next-line @typescript-eslint/no-var-requires
20
- const packageResolved = require(hasPackage);
21
- if (typeof packageResolved === "function") {
22
- return packageResolved(...options);
23
- }
24
- if (packageResolved.default &&
25
- typeof packageResolved.default === "function") {
26
- return packageResolved.default(...options);
27
- }
28
- return packageResolved;
29
- }
30
- }
31
- catch (error) {
32
- logger.warn(`Package [${packageName}] not installed. Please install it using your package manager.`, "package-resolver");
33
- }
34
- }
35
- exports.packageResolver = packageResolver;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.packageResolver = void 0;
4
+ /* eslint-disable @typescript-eslint/no-explicit-any */
5
+ const logger_provider_1 = require("../provider/logger/logger.provider");
6
+ /**
7
+ * Resolve package from the current working directory.
8
+ * @param packageName
9
+ * @param options
10
+ * @returns
11
+ */
12
+ function packageResolver(packageName, ...options) {
13
+ const logger = new logger_provider_1.Logger();
14
+ try {
15
+ const hasPackage = require.resolve(packageName, {
16
+ paths: [process.cwd()],
17
+ });
18
+ if (hasPackage) {
19
+ // eslint-disable-next-line @typescript-eslint/no-var-requires
20
+ const packageResolved = require(hasPackage);
21
+ if (typeof packageResolved === "function") {
22
+ return packageResolved(...options);
23
+ }
24
+ if (packageResolved.default &&
25
+ typeof packageResolved.default === "function") {
26
+ return packageResolved.default(...options);
27
+ }
28
+ return packageResolved;
29
+ }
30
+ }
31
+ catch (error) {
32
+ logger.warn(`Package [${packageName}] not installed. Please install it using your package manager.`, "package-resolver");
33
+ }
34
+ }
35
+ exports.packageResolver = packageResolver;
@@ -1,2 +1,2 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -1,61 +1,60 @@
1
- "use strict";
2
- var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
- else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
- return c > 3 && r && Object.defineProperty(target, key, r), r;
7
- };
8
- var Console_1;
9
- Object.defineProperty(exports, "__esModule", { value: true });
10
- exports.Console = void 0;
11
- const inversify_binding_decorators_1 = require("inversify-binding-decorators");
12
- const color_service_provider_1 = require("../common/color-service.provider");
13
- /**
14
- * The Console class provides methods for displaying styled messages in the console.
15
- * @provide Console
16
- */
17
- let Console = Console_1 = class Console {
18
- /**
19
- * Print a message to the console with the specified color style.
20
- * @param message - The message to be printed.
21
- * @param colorStyle - The color style for the message.
22
- */
23
- async printColor(message, colorStyle) {
24
- const textColor = "black";
25
- const bgColor = colorStyle;
26
- console.log(`${color_service_provider_1.bgColorCodes[bgColor]}${color_service_provider_1.colorCodes[textColor]}${message}\x1b[0m`);
27
- }
28
- /**
29
- * Display a message in the console with details about the running server.
30
- * @param port - The port number the server is running on.
31
- * @param environment - The server environment.
32
- * @param consoleMessage - Optional application message details for console output.
33
- */
34
- async messageServer(port, environment, consoleMessage) {
35
- const appConsoleMessage = {
36
- appName: consoleMessage?.appName || "Application",
37
- appVersion: consoleMessage?.appVersion || "not provided",
38
- };
39
- let terminalColor = color_service_provider_1.ColorStyle.None;
40
- switch (environment.toLowerCase()) {
41
- case "development":
42
- terminalColor = color_service_provider_1.ColorStyle.Yellow;
43
- break;
44
- case "staging":
45
- terminalColor = color_service_provider_1.ColorStyle.Blue;
46
- break;
47
- case "production":
48
- terminalColor = color_service_provider_1.ColorStyle.Green;
49
- break;
50
- default:
51
- terminalColor = color_service_provider_1.ColorStyle.Red;
52
- break;
53
- }
54
- this.printColor(`${appConsoleMessage.appName} version ${appConsoleMessage.appVersion} is running on ` +
55
- `port ${port} - Environment: ${environment}`, terminalColor);
56
- }
57
- };
58
- Console = Console_1 = __decorate([
59
- (0, inversify_binding_decorators_1.provide)(Console_1)
60
- ], Console);
61
- exports.Console = Console;
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.Console = void 0;
10
+ const inversify_binding_decorators_1 = require("inversify-binding-decorators");
11
+ const color_service_provider_1 = require("../common/color-service.provider");
12
+ /**
13
+ * The Console class provides methods for displaying styled messages in the console.
14
+ * @provide Console
15
+ */
16
+ let Console = class Console {
17
+ /**
18
+ * Print a message to the console with the specified color style.
19
+ * @param message - The message to be printed.
20
+ * @param colorStyle - The color style for the message.
21
+ */
22
+ async printColor(message, colorStyle) {
23
+ const textColor = "black";
24
+ const bgColor = colorStyle;
25
+ console.log(`${color_service_provider_1.bgColorCodes[bgColor]}${color_service_provider_1.colorCodes[textColor]}${message}\x1b[0m`);
26
+ }
27
+ /**
28
+ * Display a message in the console with details about the running server.
29
+ * @param port - The port number the server is running on.
30
+ * @param environment - The server environment.
31
+ * @param consoleMessage - Optional application message details for console output.
32
+ */
33
+ async messageServer(port, environment, consoleMessage) {
34
+ const appConsoleMessage = {
35
+ appName: consoleMessage?.appName || "Application",
36
+ appVersion: consoleMessage?.appVersion || "not provided",
37
+ };
38
+ let terminalColor = color_service_provider_1.ColorStyle.None;
39
+ switch (environment.toLowerCase()) {
40
+ case "development":
41
+ terminalColor = color_service_provider_1.ColorStyle.Yellow;
42
+ break;
43
+ case "staging":
44
+ terminalColor = color_service_provider_1.ColorStyle.Blue;
45
+ break;
46
+ case "production":
47
+ terminalColor = color_service_provider_1.ColorStyle.Green;
48
+ break;
49
+ default:
50
+ terminalColor = color_service_provider_1.ColorStyle.Red;
51
+ break;
52
+ }
53
+ this.printColor(`${appConsoleMessage.appName} version ${appConsoleMessage.appVersion} is running on ` +
54
+ `port ${port} - Environment: ${environment}`, terminalColor);
55
+ }
56
+ };
57
+ exports.Console = Console;
58
+ exports.Console = Console = __decorate([
59
+ (0, inversify_binding_decorators_1.provide)(Console)
60
+ ], Console);
@@ -1,5 +1,5 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Console = void 0;
4
- var console_1 = require("./console");
5
- Object.defineProperty(exports, "Console", { enumerable: true, get: function () { return console_1.Console; } });
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Console = void 0;
4
+ var console_1 = require("./console");
5
+ Object.defineProperty(exports, "Console", { enumerable: true, get: function () { return console_1.Console; } });
@@ -1,111 +1,111 @@
1
- "use strict";
2
- var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
- else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
- return c > 3 && r && Object.defineProperty(target, key, r), r;
7
- };
8
- var BaseModule_1;
9
- Object.defineProperty(exports, "__esModule", { value: true });
10
- exports.scope = exports.CreateModule = void 0;
11
- /* eslint-disable @typescript-eslint/explicit-function-return-type */
12
- /* eslint-disable @typescript-eslint/no-explicit-any */
13
- const inversify_1 = require("inversify");
14
- const inversify_binding_decorators_1 = require("inversify-binding-decorators");
15
- const decorator_1 = require("../decorator");
16
- /**
17
- * Key to be used for storing and retrieving binding type metadata.
18
- */
19
- const BINDING_TYPE_METADATA_KEY = "binding-type";
20
- /**
21
- * The scope decorator is a higher order function that can be used to decorate a class with a binding type.
22
- * @param binding An instance of interfaces.BindingScope which represents the binding type.
23
- * @returns A decorator function that can be used to decorate a class with a binding type.
24
- */
25
- const scope = (binding) => {
26
- return function (target) {
27
- if (!Reflect.hasMetadata(BINDING_TYPE_METADATA_KEY, target)) {
28
- Reflect.defineMetadata(BINDING_TYPE_METADATA_KEY, binding, target);
29
- switch (binding) {
30
- case inversify_1.BindingScopeEnum.Singleton:
31
- (0, decorator_1.provideSingleton)(target);
32
- break;
33
- case inversify_1.BindingScopeEnum.Transient:
34
- (0, decorator_1.provideTransient)(target);
35
- break;
36
- default:
37
- (0, inversify_binding_decorators_1.provide)(target);
38
- break;
39
- }
40
- }
41
- };
42
- };
43
- exports.scope = scope;
44
- /**
45
- * The BaseModule class provides methods for creating InversifyJS container modules.
46
- * @provide BaseModule
47
- */
48
- let BaseModule = BaseModule_1 = class BaseModule {
49
- /**
50
- * Create a map of symbols for the provided controllers.
51
- * @param controllers - An array of controller classes.
52
- * @returns A map of symbols mapped to controller constructor functions.
53
- */
54
- static createSymbols(controllers) {
55
- const symbols = new Map();
56
- for (const controller of controllers) {
57
- const target = controller;
58
- const symbol = Symbol.for(target.name);
59
- symbols.set(symbol, target);
60
- }
61
- return symbols;
62
- }
63
- /**
64
- * Create an InversifyJS ContainerModule for the provided controllers.
65
- * @param controllers - An array of controller classes.
66
- * @param scope - An optional binding scope to be used for all controllers.
67
- * @returns A ContainerModule with the controller bindings.
68
- */
69
- static createContainerModule(controllers, scope) {
70
- const symbols = BaseModule_1.createSymbols(controllers);
71
- return new inversify_1.ContainerModule((bind) => {
72
- for (const [symbol, target] of symbols) {
73
- if (scope) {
74
- switch (scope) {
75
- case inversify_1.BindingScopeEnum.Singleton:
76
- bind(symbol).to(target).inSingletonScope();
77
- break;
78
- case inversify_1.BindingScopeEnum.Transient:
79
- bind(symbol).to(target).inTransientScope();
80
- break;
81
- case inversify_1.BindingScopeEnum.Request:
82
- bind(symbol).to(target).inRequestScope();
83
- break;
84
- }
85
- }
86
- else {
87
- const bindingType = Reflect.getMetadata(BINDING_TYPE_METADATA_KEY, target);
88
- switch (bindingType) {
89
- case inversify_1.BindingScopeEnum.Singleton:
90
- bind(symbol).to(target).inSingletonScope();
91
- break;
92
- case inversify_1.BindingScopeEnum.Transient:
93
- bind(symbol).to(target).inTransientScope();
94
- break;
95
- case inversify_1.BindingScopeEnum.Request:
96
- bind(symbol).to(target).inRequestScope();
97
- break;
98
- default:
99
- bind(symbol).to(target).inRequestScope();
100
- break;
101
- }
102
- }
103
- }
104
- });
105
- }
106
- };
107
- BaseModule = BaseModule_1 = __decorate([
108
- (0, inversify_binding_decorators_1.provide)(BaseModule_1)
109
- ], BaseModule);
110
- const CreateModule = BaseModule.createContainerModule;
111
- exports.CreateModule = CreateModule;
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var BaseModule_1;
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ exports.scope = exports.CreateModule = void 0;
11
+ /* eslint-disable @typescript-eslint/explicit-function-return-type */
12
+ /* eslint-disable @typescript-eslint/no-explicit-any */
13
+ const inversify_1 = require("inversify");
14
+ const inversify_binding_decorators_1 = require("inversify-binding-decorators");
15
+ const decorator_1 = require("../decorator");
16
+ /**
17
+ * Key to be used for storing and retrieving binding type metadata.
18
+ */
19
+ const BINDING_TYPE_METADATA_KEY = "binding-type";
20
+ /**
21
+ * The scope decorator is a higher order function that can be used to decorate a class with a binding type.
22
+ * @param binding An instance of interfaces.BindingScope which represents the binding type.
23
+ * @returns A decorator function that can be used to decorate a class with a binding type.
24
+ */
25
+ const scope = (binding) => {
26
+ return function (target) {
27
+ if (!Reflect.hasMetadata(BINDING_TYPE_METADATA_KEY, target)) {
28
+ Reflect.defineMetadata(BINDING_TYPE_METADATA_KEY, binding, target);
29
+ switch (binding) {
30
+ case inversify_1.BindingScopeEnum.Singleton:
31
+ (0, decorator_1.provideSingleton)(target);
32
+ break;
33
+ case inversify_1.BindingScopeEnum.Transient:
34
+ (0, decorator_1.provideTransient)(target);
35
+ break;
36
+ default:
37
+ (0, inversify_binding_decorators_1.provide)(target);
38
+ break;
39
+ }
40
+ }
41
+ };
42
+ };
43
+ exports.scope = scope;
44
+ /**
45
+ * The BaseModule class provides methods for creating InversifyJS container modules.
46
+ * @provide BaseModule
47
+ */
48
+ let BaseModule = BaseModule_1 = class BaseModule {
49
+ /**
50
+ * Create a map of symbols for the provided controllers.
51
+ * @param controllers - An array of controller classes.
52
+ * @returns A map of symbols mapped to controller constructor functions.
53
+ */
54
+ static createSymbols(controllers) {
55
+ const symbols = new Map();
56
+ for (const controller of controllers) {
57
+ const target = controller;
58
+ const symbol = Symbol.for(target.name);
59
+ symbols.set(symbol, target);
60
+ }
61
+ return symbols;
62
+ }
63
+ /**
64
+ * Create an InversifyJS ContainerModule for the provided controllers.
65
+ * @param controllers - An array of controller classes.
66
+ * @param scope - An optional binding scope to be used for all controllers.
67
+ * @returns A ContainerModule with the controller bindings.
68
+ */
69
+ static createContainerModule(controllers, scope) {
70
+ const symbols = BaseModule_1.createSymbols(controllers);
71
+ return new inversify_1.ContainerModule((bind) => {
72
+ for (const [symbol, target] of symbols) {
73
+ if (scope) {
74
+ switch (scope) {
75
+ case inversify_1.BindingScopeEnum.Singleton:
76
+ bind(symbol).to(target).inSingletonScope();
77
+ break;
78
+ case inversify_1.BindingScopeEnum.Transient:
79
+ bind(symbol).to(target).inTransientScope();
80
+ break;
81
+ case inversify_1.BindingScopeEnum.Request:
82
+ bind(symbol).to(target).inRequestScope();
83
+ break;
84
+ }
85
+ }
86
+ else {
87
+ const bindingType = Reflect.getMetadata(BINDING_TYPE_METADATA_KEY, target);
88
+ switch (bindingType) {
89
+ case inversify_1.BindingScopeEnum.Singleton:
90
+ bind(symbol).to(target).inSingletonScope();
91
+ break;
92
+ case inversify_1.BindingScopeEnum.Transient:
93
+ bind(symbol).to(target).inTransientScope();
94
+ break;
95
+ case inversify_1.BindingScopeEnum.Request:
96
+ bind(symbol).to(target).inRequestScope();
97
+ break;
98
+ default:
99
+ bind(symbol).to(target).inRequestScope();
100
+ break;
101
+ }
102
+ }
103
+ }
104
+ });
105
+ }
106
+ };
107
+ BaseModule = BaseModule_1 = __decorate([
108
+ (0, inversify_binding_decorators_1.provide)(BaseModule)
109
+ ], BaseModule);
110
+ const CreateModule = BaseModule.createContainerModule;
111
+ exports.CreateModule = CreateModule;
@@ -1,6 +1,6 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.scope = exports.CreateModule = void 0;
4
- var container_module_1 = require("./container-module");
5
- Object.defineProperty(exports, "CreateModule", { enumerable: true, get: function () { return container_module_1.CreateModule; } });
6
- Object.defineProperty(exports, "scope", { enumerable: true, get: function () { return container_module_1.scope; } });
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.scope = exports.CreateModule = void 0;
4
+ var container_module_1 = require("./container-module");
5
+ Object.defineProperty(exports, "CreateModule", { enumerable: true, get: function () { return container_module_1.CreateModule; } });
6
+ Object.defineProperty(exports, "scope", { enumerable: true, get: function () { return container_module_1.scope; } });