bootifyjs 0.0.3 → 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.
Files changed (188) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +116 -510
  3. package/dist/api.d.ts +32 -0
  4. package/dist/api.js +149 -0
  5. package/dist/api.js.map +1 -0
  6. package/dist/config/app.config.d.ts +29 -0
  7. package/dist/config/app.config.js +55 -0
  8. package/dist/config/app.config.js.map +1 -0
  9. package/dist/controllers/config.controller.d.ts +16 -0
  10. package/dist/controllers/config.controller.js +66 -0
  11. package/dist/controllers/config.controller.js.map +1 -0
  12. package/dist/controllers/events.controller.d.ts +66 -0
  13. package/dist/controllers/events.controller.js +145 -0
  14. package/dist/controllers/events.controller.js.map +1 -0
  15. package/dist/controllers/health.controller.d.ts +20 -0
  16. package/dist/controllers/health.controller.js +92 -0
  17. package/dist/controllers/health.controller.js.map +1 -0
  18. package/dist/controllers/user.controller.d.ts +13 -0
  19. package/dist/controllers/user.controller.js +209 -0
  20. package/dist/controllers/user.controller.js.map +1 -0
  21. package/dist/core/application.d.ts +21 -0
  22. package/dist/core/application.js +90 -0
  23. package/dist/core/application.js.map +1 -0
  24. package/dist/core/config.d.ts +3 -0
  25. package/dist/core/config.js +78 -0
  26. package/dist/core/config.js.map +1 -0
  27. package/dist/core/container.d.ts +17 -0
  28. package/dist/core/container.js +92 -0
  29. package/dist/core/container.js.map +1 -0
  30. package/dist/core/decorators.d.ts +28 -0
  31. package/dist/core/decorators.js +204 -0
  32. package/dist/core/decorators.js.map +1 -0
  33. package/dist/core/errors.d.ts +18 -0
  34. package/dist/core/errors.js +74 -0
  35. package/dist/core/errors.js.map +1 -0
  36. package/dist/core/middleware.d.ts +8 -0
  37. package/dist/core/middleware.js +23 -0
  38. package/dist/core/middleware.js.map +1 -0
  39. package/dist/core/openapi.d.ts +80 -0
  40. package/dist/core/openapi.js +189 -0
  41. package/dist/core/openapi.js.map +1 -0
  42. package/dist/core/router.d.ts +32 -0
  43. package/dist/core/router.js +266 -0
  44. package/dist/core/router.js.map +1 -0
  45. package/dist/core/utils.d.ts +7 -0
  46. package/dist/core/utils.js +75 -0
  47. package/dist/core/utils.js.map +1 -0
  48. package/dist/core/validation.d.ts +15 -0
  49. package/dist/core/validation.js +161 -0
  50. package/dist/core/validation.js.map +1 -0
  51. package/dist/events/core/event-bus.d.ts +26 -0
  52. package/dist/events/core/event-bus.js +253 -0
  53. package/dist/events/core/event-bus.js.map +1 -0
  54. package/dist/events/core/event-registry.d.ts +31 -0
  55. package/dist/events/core/event-registry.js +170 -0
  56. package/dist/events/core/event-registry.js.map +1 -0
  57. package/dist/events/decorators/event.decorators.d.ts +11 -0
  58. package/dist/events/decorators/event.decorators.js +123 -0
  59. package/dist/events/decorators/event.decorators.js.map +1 -0
  60. package/dist/events/examples/system.events.d.ts +15 -0
  61. package/dist/events/examples/system.events.js +28 -0
  62. package/dist/events/examples/system.events.js.map +1 -0
  63. package/dist/events/examples/user.events.d.ts +68 -0
  64. package/dist/events/examples/user.events.js +73 -0
  65. package/dist/events/examples/user.events.js.map +1 -0
  66. package/dist/events/examples/user.handlers.d.ts +20 -0
  67. package/dist/events/examples/user.handlers.js +157 -0
  68. package/dist/events/examples/user.handlers.js.map +1 -0
  69. package/dist/events/index.d.ts +13 -0
  70. package/dist/events/index.js +71 -0
  71. package/dist/events/index.js.map +1 -0
  72. package/dist/events/middleware/logging.middleware.d.ts +7 -0
  73. package/dist/events/middleware/logging.middleware.js +44 -0
  74. package/dist/events/middleware/logging.middleware.js.map +1 -0
  75. package/dist/events/middleware/metrics.middleware.d.ts +11 -0
  76. package/dist/events/middleware/metrics.middleware.js +87 -0
  77. package/dist/events/middleware/metrics.middleware.js.map +1 -0
  78. package/dist/events/middleware/validation.middleware.d.ts +8 -0
  79. package/dist/events/middleware/validation.middleware.js +63 -0
  80. package/dist/events/middleware/validation.middleware.js.map +1 -0
  81. package/dist/events/store/memory-event-store.d.ts +21 -0
  82. package/dist/events/store/memory-event-store.js +81 -0
  83. package/dist/events/store/memory-event-store.js.map +1 -0
  84. package/dist/events/types/event.types.d.ts +57 -0
  85. package/dist/{decorators/cache/ICacheClient.js → events/types/event.types.js} +1 -1
  86. package/dist/events/types/event.types.js.map +1 -0
  87. package/dist/examples/basic-api.d.ts +1 -0
  88. package/dist/examples/basic-api.js +120 -0
  89. package/dist/examples/basic-api.js.map +1 -0
  90. package/dist/index.d.ts +17 -11
  91. package/dist/index.js +95 -31
  92. package/dist/index.js.map +1 -1
  93. package/dist/logging/config/logging.config.d.ts +5 -0
  94. package/dist/logging/config/logging.config.js +101 -0
  95. package/dist/logging/config/logging.config.js.map +1 -0
  96. package/dist/logging/core/log-context.service.d.ts +11 -0
  97. package/dist/logging/core/log-context.service.js +40 -0
  98. package/dist/logging/core/log-context.service.js.map +1 -0
  99. package/dist/logging/core/logger.service.d.ts +29 -0
  100. package/dist/logging/core/logger.service.js +178 -0
  101. package/dist/logging/core/logger.service.js.map +1 -0
  102. package/dist/logging/core/startup-logger.service.d.ts +17 -0
  103. package/dist/logging/core/startup-logger.service.js +156 -0
  104. package/dist/logging/core/startup-logger.service.js.map +1 -0
  105. package/dist/logging/decorators/log.decorator.d.ts +11 -0
  106. package/dist/logging/decorators/log.decorator.js +80 -0
  107. package/dist/logging/decorators/log.decorator.js.map +1 -0
  108. package/dist/logging/index.d.ts +15 -0
  109. package/dist/logging/index.js +46 -0
  110. package/dist/logging/index.js.map +1 -0
  111. package/dist/logging/middleware/context.middleware.d.ts +2 -0
  112. package/dist/logging/middleware/context.middleware.js +29 -0
  113. package/dist/logging/middleware/context.middleware.js.map +1 -0
  114. package/dist/logging/middleware/request-logging.middleware.d.ts +3 -0
  115. package/dist/logging/middleware/request-logging.middleware.js +78 -0
  116. package/dist/logging/middleware/request-logging.middleware.js.map +1 -0
  117. package/dist/logging/types/logging.types.d.ts +79 -0
  118. package/dist/{decorators/transaction/IDatabaseClient.js → logging/types/logging.types.js} +1 -1
  119. package/dist/logging/types/logging.types.js.map +1 -0
  120. package/dist/middlewares/auth.middleware.d.ts +2 -0
  121. package/dist/middlewares/auth.middleware.js +20 -0
  122. package/dist/middlewares/auth.middleware.js.map +1 -0
  123. package/dist/middlewares/cors.middleware.d.ts +2 -0
  124. package/dist/middlewares/cors.middleware.js +16 -0
  125. package/dist/middlewares/cors.middleware.js.map +1 -0
  126. package/dist/middlewares/swagger.middleware.d.ts +6 -0
  127. package/dist/middlewares/swagger.middleware.js +84 -0
  128. package/dist/middlewares/swagger.middleware.js.map +1 -0
  129. package/dist/repositories/user.repository.d.ts +16 -0
  130. package/dist/repositories/user.repository.js +110 -0
  131. package/dist/repositories/user.repository.js.map +1 -0
  132. package/dist/schemas/user.schemas.d.ts +214 -0
  133. package/dist/schemas/user.schemas.js +71 -0
  134. package/dist/schemas/user.schemas.js.map +1 -0
  135. package/dist/services/config-demo.service.d.ts +10 -0
  136. package/dist/services/config-demo.service.js +88 -0
  137. package/dist/services/config-demo.service.js.map +1 -0
  138. package/dist/services/user.service.d.ts +21 -0
  139. package/dist/services/user.service.js +201 -0
  140. package/dist/services/user.service.js.map +1 -0
  141. package/package.json +49 -14
  142. package/dist/application/Application.d.ts +0 -43
  143. package/dist/application/Application.d.ts.map +0 -1
  144. package/dist/application/Application.js +0 -283
  145. package/dist/application/Application.js.map +0 -1
  146. package/dist/container/container.d.ts +0 -9
  147. package/dist/container/container.d.ts.map +0 -1
  148. package/dist/container/container.js +0 -23
  149. package/dist/container/container.js.map +0 -1
  150. package/dist/decorators/cache/ICacheClient.d.ts +0 -6
  151. package/dist/decorators/cache/ICacheClient.d.ts.map +0 -1
  152. package/dist/decorators/cache/ICacheClient.js.map +0 -1
  153. package/dist/decorators/cache/cache.decorator.d.ts +0 -2
  154. package/dist/decorators/cache/cache.decorator.d.ts.map +0 -1
  155. package/dist/decorators/cache/cache.decorator.js +0 -38
  156. package/dist/decorators/cache/cache.decorator.js.map +0 -1
  157. package/dist/decorators/controller.decorator.d.ts +0 -9
  158. package/dist/decorators/controller.decorator.d.ts.map +0 -1
  159. package/dist/decorators/controller.decorator.js +0 -99
  160. package/dist/decorators/controller.decorator.js.map +0 -1
  161. package/dist/decorators/http.decorator.d.ts +0 -7
  162. package/dist/decorators/http.decorator.d.ts.map +0 -1
  163. package/dist/decorators/http.decorator.js +0 -26
  164. package/dist/decorators/http.decorator.js.map +0 -1
  165. package/dist/decorators/timing.decorator.d.ts +0 -2
  166. package/dist/decorators/timing.decorator.d.ts.map +0 -1
  167. package/dist/decorators/timing.decorator.js +0 -26
  168. package/dist/decorators/timing.decorator.js.map +0 -1
  169. package/dist/decorators/transaction/IDatabaseClient.d.ts +0 -9
  170. package/dist/decorators/transaction/IDatabaseClient.d.ts.map +0 -1
  171. package/dist/decorators/transaction/IDatabaseClient.js.map +0 -1
  172. package/dist/decorators/transaction/transactional.decorator.d.ts +0 -2
  173. package/dist/decorators/transaction/transactional.decorator.d.ts.map +0 -1
  174. package/dist/decorators/transaction/transactional.decorator.js +0 -27
  175. package/dist/decorators/transaction/transactional.decorator.js.map +0 -1
  176. package/dist/index.d.ts.map +0 -1
  177. package/dist/logger/Logger.d.ts +0 -37
  178. package/dist/logger/Logger.d.ts.map +0 -1
  179. package/dist/logger/Logger.js +0 -142
  180. package/dist/logger/Logger.js.map +0 -1
  181. package/dist/middleware/http.d.ts +0 -2
  182. package/dist/middleware/http.d.ts.map +0 -1
  183. package/dist/middleware/http.js +0 -80
  184. package/dist/middleware/http.js.map +0 -1
  185. package/dist/middleware/requestcontext.d.ts +0 -12
  186. package/dist/middleware/requestcontext.d.ts.map +0 -1
  187. package/dist/middleware/requestcontext.js +0 -6
  188. package/dist/middleware/requestcontext.js.map +0 -1
package/package.json CHANGED
@@ -1,24 +1,59 @@
1
1
  {
2
2
  "name": "bootifyjs",
3
- "version": "0.0.3",
4
- "description": "Spring Boot inspired framework fro Node.js built on top of fastify and express",
3
+ "version": "0.1.0",
4
+ "description": "Spring Boot inspired Node.js framework with custom DI",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
7
7
  "scripts": {
8
8
  "build": "tsc",
9
- "dev": "tsc --watch",
10
- "clean": "rm -rf dist"
9
+ "dev": "ts-node src/index.ts",
10
+ "start": "node dist/index.js",
11
+ "test": "vitest run",
12
+ "test:watch": "vitest",
13
+ "test:coverage": "vitest run --coverage",
14
+ "test:benchmark": "ts-node tests/core/router.benchmark.ts",
15
+ "prepublishOnly": "npm run build"
16
+ },
17
+ "files": [
18
+ "dist",
19
+ "README.md",
20
+ "LICENSE"
21
+ ],
22
+ "keywords": [
23
+ "nodejs",
24
+ "framework",
25
+ "spring-boot",
26
+ "dependency-injection",
27
+ "typescript"
28
+ ],
29
+ "author": "BootifyJS",
30
+ "license": "MIT",
31
+ "devDependencies": {
32
+ "@types/node": "^20.0.0",
33
+ "@vitest/coverage-v8": "^3.2.4",
34
+ "ts-node": "^10.9.0",
35
+ "typescript": "^5.0.0",
36
+ "vitest": "^3.2.4"
11
37
  },
12
38
  "dependencies": {
13
- "fastify": "^4.24.3",
14
- "@fastify/cors": "^8.4.2",
15
- "inversify": "^6.0.2",
16
- "reflect-metadata": "^0.2.2",
17
- "pino": "^8.17.1",
18
- "pino-http": "^8.6.1"
39
+ "pino": "^9.7.0",
40
+ "pino-pretty": "^13.0.0",
41
+ "pino-roll": "^3.1.0",
42
+ "reflect-metadata": "^0.1.13",
43
+ "zod": "^3.22.4"
19
44
  },
20
- "devDependencies": {
21
- "@types/node": "^20.10.4",
22
- "typescript": "^5.3.3"
23
- }
45
+ "peerDependencies": {
46
+ "typescript": ">=4.5.0"
47
+ },
48
+ "engines": {
49
+ "node": ">=16.0.0"
50
+ },
51
+ "repository": {
52
+ "type": "git",
53
+ "url": "https://github.com/bootifyjs/bootifyjs.git"
54
+ },
55
+ "bugs": {
56
+ "url": "https://github.com/bootifyjs/bootifyjs/issues"
57
+ },
58
+ "homepage": "https://github.com/bootifyjs/bootifyjs"
24
59
  }
@@ -1,43 +0,0 @@
1
- import { FastifyInstance, FastifyPluginAsync, FastifyPluginCallback } from 'fastify';
2
- interface FastifyServerConfig {
3
- port?: number;
4
- host?: string;
5
- route?: FastifyPluginCallback | FastifyPluginAsync;
6
- enableCors?: boolean;
7
- enableSwagger?: boolean;
8
- enableLogging?: boolean;
9
- enableErrorHandling?: boolean;
10
- enableDatabase?: boolean;
11
- enableRedis?: boolean;
12
- corsOptions?: {
13
- origin?: string | string[];
14
- methods?: string[];
15
- credentials?: boolean;
16
- };
17
- swaggerOptions?: {
18
- routePrefix?: string;
19
- swaggerDoc?: any;
20
- };
21
- enableMetrics?: boolean;
22
- enableCookie?: boolean;
23
- enableAuth?: boolean;
24
- }
25
- export declare class Application {
26
- private server;
27
- private config;
28
- constructor(config?: FastifyServerConfig);
29
- private setupServer;
30
- private globalErrorHandler;
31
- private addCommonSchemas;
32
- private setupLogging;
33
- private setupRouteLogging;
34
- private printFastifyRoutes;
35
- private colorMethod;
36
- registerControllers(controllers: Function[]): void;
37
- start(port?: number, host?: string): Promise<void>;
38
- private setupGracefulShutdown;
39
- getServer(): FastifyInstance;
40
- updateConfig(newConfig: Partial<FastifyServerConfig>): void;
41
- }
42
- export {};
43
- //# sourceMappingURL=Application.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Application.d.ts","sourceRoot":"","sources":["../../src/application/Application.ts"],"names":[],"mappings":"AAAA,OAAgB,EACd,eAAe,EACf,kBAAkB,EAClB,qBAAqB,EAEtB,MAAM,SAAS,CAAC;AAMjB,UAAU,mBAAmB;IAC3B,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,qBAAqB,GAAG,kBAAkB,CAAC;IACnD,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,WAAW,CAAC,EAAE;QACZ,MAAM,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;QAC3B,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;QACnB,WAAW,CAAC,EAAE,OAAO,CAAC;KACvB,CAAC;IACF,cAAc,CAAC,EAAE;QACf,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,UAAU,CAAC,EAAE,GAAG,CAAC;KAClB,CAAC;IACF,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,UAAU,CAAC,EAAE,OAAO,CAAC;CACtB;AAED,qBAAa,WAAW;IACtB,OAAO,CAAC,MAAM,CAAkB;IAChC,OAAO,CAAC,MAAM,CAAsB;gBAExB,MAAM,GAAE,mBAAwB;YAiD9B,WAAW;IA0DzB,OAAO,CAAC,kBAAkB,CAWxB;IAEF,OAAO,CAAC,gBAAgB;IAsBxB,OAAO,CAAC,YAAY;IA+CpB,OAAO,CAAC,iBAAiB;IAazB,OAAO,CAAC,kBAAkB;IAsB1B,OAAO,CAAC,WAAW;IAwBZ,mBAAmB,CAAC,WAAW,EAAE,QAAQ,EAAE;IAIrC,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM;IAiC/C,OAAO,CAAC,qBAAqB;IAuBtB,SAAS,IAAI,eAAe;IAI5B,YAAY,CAAC,SAAS,EAAE,OAAO,CAAC,mBAAmB,CAAC;CAG5D"}
@@ -1,283 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.Application = void 0;
7
- const fastify_1 = __importDefault(require("fastify"));
8
- const controller_decorator_1 = require("../decorators/controller.decorator");
9
- const Logger_1 = __importDefault(require("../logger/Logger"));
10
- const requestcontext_1 = require("../middleware/requestcontext");
11
- const http_1 = require("../middleware/http");
12
- class Application {
13
- constructor(config = {}) {
14
- this.globalErrorHandler = (error, request, reply) => {
15
- Logger_1.default.error('Global error handler:', error);
16
- const statusCode = error.statusCode || 500;
17
- const message = error.message || 'Internal Server Error';
18
- reply.status(statusCode).send({
19
- statusCode,
20
- error: error.name || 'Error',
21
- message,
22
- });
23
- };
24
- this.config = {
25
- port: 3000,
26
- host: '0.0.0.0',
27
- enableCors: true,
28
- enableSwagger: false,
29
- enableLogging: true,
30
- enableErrorHandling: true,
31
- enableDatabase: false,
32
- enableRedis: false,
33
- enableCookie: false,
34
- enableAuth: false,
35
- enableMetrics: false,
36
- corsOptions: {
37
- origin: [
38
- 'http://localhost:4000',
39
- 'http://localhost:3000',
40
- 'http://localhost:5173',
41
- ],
42
- methods: ['GET', 'PUT', 'PATCH', 'POST', 'DELETE'],
43
- credentials: true,
44
- },
45
- swaggerOptions: {
46
- routePrefix: '/docs',
47
- swaggerDoc: {
48
- info: {
49
- title: 'API Documentation',
50
- version: '1.0.0',
51
- },
52
- },
53
- },
54
- ...config,
55
- };
56
- this.server = (0, fastify_1.default)({
57
- ajv: {
58
- customOptions: {
59
- strict: false,
60
- },
61
- },
62
- genReqId: (req) => {
63
- const requestId = req.headers['x-request-id'];
64
- return Array.isArray(requestId) ? requestId[0] : requestId || crypto.randomUUID();
65
- },
66
- });
67
- this.setupServer();
68
- }
69
- async setupServer() {
70
- try {
71
- // Register CORS
72
- // if (this.config.enableCors) {
73
- // Logger.info('Registering CORS');
74
- // await this.server.register(require('@fastify/cors'), this.config.corsOptions);
75
- // }
76
- // Register Swagger
77
- // if (this.config.enableSwagger) {
78
- // await this.server.register(require('@fastify/swagger'), this.config.swaggerOptions?.swaggerDoc);
79
- // await this.server.register(require('@fastify/swagger-ui'), {
80
- // routePrefix: this.config.swaggerOptions?.routePrefix,
81
- // });
82
- // }
83
- // Register Cookie support
84
- // if (this.config.enableCookie) {
85
- // await this.server.register(require('@fastify/cookie'), {
86
- // hook: 'onRequest',
87
- // parseOptions: {},
88
- // });
89
- // }
90
- // Register Metrics
91
- // if (this.config.enableMetrics) {
92
- // await this.server.register(require('fastify-metrics'), {
93
- // endpoint: '/metrics',
94
- // });
95
- // }
96
- // Register error handling
97
- if (this.config.enableErrorHandling) {
98
- this.server.setErrorHandler(this.globalErrorHandler);
99
- }
100
- // Add common schemas
101
- this.addCommonSchemas();
102
- // Add logging hooks
103
- if (this.config.enableLogging) {
104
- this.setupLogging();
105
- }
106
- // Setup route logging
107
- this.setupRouteLogging();
108
- // Register custom routes
109
- if (this.config.route) {
110
- await this.server.register(this.config.route);
111
- }
112
- }
113
- catch (error) {
114
- Logger_1.default.error('Failed to setup server:', error);
115
- throw error;
116
- }
117
- }
118
- addCommonSchemas() {
119
- this.server.addSchema({
120
- $id: 'errorResponseSchema',
121
- type: 'object',
122
- description: 'Error Response',
123
- properties: {
124
- statusCode: { type: 'number' },
125
- error: { type: 'string' },
126
- message: { type: 'string' },
127
- },
128
- });
129
- this.server.addSchema({
130
- $id: 'messageResponseSchema',
131
- type: 'object',
132
- description: 'Message Response',
133
- properties: {
134
- message: { type: 'string' },
135
- },
136
- });
137
- }
138
- setupLogging() {
139
- // requestContext.run
140
- this.server.addHook('preHandler', (request, reply, done) => {
141
- request.raw.id = request.id;
142
- reply.header('x-request-id', request.id);
143
- (0, http_1.httpLoggerMiddleware)(request.raw, reply.raw);
144
- // console.log('Request ID:', request.id)
145
- // console.log('User ID:', request.user)
146
- requestcontext_1.requestContext.run({ requestId: request.id, userId: "pxpxpx", username: "priyadarship4@gmail.com" }, () => {
147
- done();
148
- });
149
- });
150
- // this.server.addHook('onRequest', async (request, reply) => {
151
- // const startTime = Date.now();
152
- // request.raw.startTime = startTime;
153
- // reply.header('x-request-id', request.id);
154
- // Logger.info({
155
- // requestId: request.id,
156
- // method: request.method,
157
- // url: request.url,
158
- // userAgent: request.headers['user-agent'],
159
- // ip: request.ip,
160
- // message: 'Incoming request'
161
- // });
162
- // });
163
- // this.server.addHook('onResponse', async (request, reply) => {
164
- // const duration = Date.now() - (request.raw.startTime || Date.now());
165
- // Logger.info({
166
- // requestId: request.id,
167
- // method: request.method,
168
- // url: request.url,
169
- // statusCode: reply.statusCode,
170
- // duration: `${duration}ms`,
171
- // message: 'Request completed'
172
- // });
173
- // });
174
- }
175
- setupRouteLogging() {
176
- const routeOptions = [];
177
- this.server.addHook('onRoute', (routeOption) => {
178
- routeOptions.push(routeOption);
179
- });
180
- this.server.addHook('onReady', (done) => {
181
- this.printFastifyRoutes(routeOptions, { colors: true });
182
- done();
183
- });
184
- }
185
- printFastifyRoutes(routeOptions, opts) {
186
- const { colors } = opts;
187
- if (routeOptions.length === 0) {
188
- return;
189
- }
190
- routeOptions.sort((a, b) => a.url.localeCompare(b.url));
191
- const logEntries = [];
192
- logEntries.push("Available routes:");
193
- for (const routeOption of routeOptions) {
194
- const { method, url } = routeOption;
195
- if (method === "HEAD")
196
- continue;
197
- const formattedMethod = colors ? this.colorMethod(method) : method;
198
- logEntries.push(`${formattedMethod}\t${url}`);
199
- }
200
- Logger_1.default.info(logEntries.join("\n"));
201
- }
202
- colorMethod(method) {
203
- const COLORS = {
204
- yellow: 33,
205
- green: 32,
206
- blue: 34,
207
- red: 31,
208
- grey: 90,
209
- clear: 39,
210
- };
211
- const colorText = (color, string) => {
212
- return `\u001b[${color}m${string}\u001b[${COLORS.clear}m`;
213
- };
214
- switch (method) {
215
- case "POST": return colorText(COLORS.yellow, method);
216
- case "GET": return colorText(COLORS.green, method);
217
- case "PUT": return colorText(COLORS.blue, method);
218
- case "DELETE": return colorText(COLORS.red, method);
219
- case "PATCH": return colorText(COLORS.grey, method);
220
- default: return method;
221
- }
222
- }
223
- registerControllers(controllers) {
224
- (0, controller_decorator_1.registerControllers)(this.server, controllers);
225
- }
226
- async start(port, host) {
227
- const serverPort = port || this.config.port || 3000;
228
- const serverHost = host || this.config.host || '0.0.0.0';
229
- try {
230
- // Initialize Redis if enabled
231
- if (this.config.enableRedis) {
232
- Logger_1.default.info('Connecting to Redis...');
233
- // Add Redis initialization logic here
234
- Logger_1.default.info('Redis connected');
235
- }
236
- // Initialize Database if enabled
237
- if (this.config.enableDatabase) {
238
- Logger_1.default.info('Connecting to database...');
239
- // Add Database initialization logic here
240
- Logger_1.default.info('Database connected');
241
- }
242
- Logger_1.default.info(`Starting server at http://${serverHost}:${serverPort}`);
243
- await this.server.listen({ port: serverPort, host: serverHost });
244
- Logger_1.default.info(`Server listening on http://${serverHost}:${serverPort}`);
245
- // Setup graceful shutdown
246
- this.setupGracefulShutdown();
247
- }
248
- catch (err) {
249
- // Logger.error(err)
250
- Logger_1.default.error('Failed to start server:', err);
251
- process.exit(1);
252
- }
253
- }
254
- setupGracefulShutdown() {
255
- const signals = ['SIGINT', 'SIGTERM'];
256
- signals.forEach((signal) => {
257
- process.on(signal, async () => {
258
- try {
259
- await this.server.close();
260
- Logger_1.default.info(`Closed application on ${signal}`);
261
- process.exit(0);
262
- }
263
- catch (err) {
264
- Logger_1.default.error(`Error closing application on ${signal}`, err);
265
- process.exit(1);
266
- }
267
- });
268
- });
269
- process.on('unhandledRejection', (err) => {
270
- // Logger.error(err)
271
- Logger_1.default.error('Unhandled Rejection:', err);
272
- process.exit(1);
273
- });
274
- }
275
- getServer() {
276
- return this.server;
277
- }
278
- updateConfig(newConfig) {
279
- this.config = { ...this.config, ...newConfig };
280
- }
281
- }
282
- exports.Application = Application;
283
- //# sourceMappingURL=Application.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Application.js","sourceRoot":"","sources":["../../src/application/Application.ts"],"names":[],"mappings":"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"}
@@ -1,9 +0,0 @@
1
- import { Container } from "inversify";
2
- declare const container: Container;
3
- interface BeanOptions {
4
- scope?: 'singleton' | 'transient';
5
- bindTo?: Function[];
6
- }
7
- export declare function Bean(options: BeanOptions): (target: any) => void;
8
- export default container;
9
- //# sourceMappingURL=container.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"container.d.ts","sourceRoot":"","sources":["../../src/container/container.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAc,MAAM,WAAW,CAAC;AAClD,QAAA,MAAM,SAAS,WAAkB,CAAC;AAElC,UAAU,WAAW;IACjB,KAAK,CAAC,EAAE,WAAW,GAAG,WAAW,CAAC;IAClC,MAAM,CAAC,EAAE,QAAQ,EAAE,CAAC;CACvB;AACD,wBAAgB,IAAI,CAAC,OAAO,EAAE,WAAW,IACpB,QAAQ,GAAG,UAiB/B;AAED,eAAe,SAAS,CAAC"}
@@ -1,23 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Bean = Bean;
4
- const inversify_1 = require("inversify");
5
- const container = new inversify_1.Container();
6
- function Bean(options) {
7
- return function (target) {
8
- const { scope = 'singleton', bindTo = [] } = options || {};
9
- (0, inversify_1.injectable)()(target);
10
- // Bind to self (class constructor)
11
- const binding = container.bind(target).toSelf();
12
- scope === 'singleton' ? binding.inSingletonScope() : binding.inTransientScope();
13
- // Bind to each specified interface
14
- bindTo.forEach(intrfc => {
15
- const interfaceBinding = container.bind(intrfc).to(target);
16
- scope === 'singleton'
17
- ? interfaceBinding.inSingletonScope()
18
- : interfaceBinding.inTransientScope();
19
- });
20
- };
21
- }
22
- exports.default = container;
23
- //# sourceMappingURL=container.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"container.js","sourceRoot":"","sources":["../../src/container/container.ts"],"names":[],"mappings":";;AAOA,oBAkBC;AAzBD,yCAAkD;AAClD,MAAM,SAAS,GAAG,IAAI,qBAAS,EAAE,CAAC;AAMlC,SAAgB,IAAI,CAAC,OAAoB;IACrC,OAAO,UAAU,MAAW;QACxB,MAAM,EAAE,KAAK,GAAG,WAAW,EAAE,MAAM,GAAG,EAAE,EAAE,GAAG,OAAO,IAAI,EAAE,CAAC;QAE3D,IAAA,sBAAU,GAAE,CAAC,MAAM,CAAC,CAAC;QAErB,mCAAmC;QACnC,MAAM,OAAO,GAAG,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,CAAC;QAChD,KAAK,KAAK,WAAW,CAAC,CAAC,CAAC,OAAO,CAAC,gBAAgB,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,gBAAgB,EAAE,CAAC;QAEhF,mCAAmC;QACnC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YACpB,MAAM,gBAAgB,GAAG,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC;YAC3D,KAAK,KAAK,WAAW;gBACjB,CAAC,CAAC,gBAAgB,CAAC,gBAAgB,EAAE;gBACrC,CAAC,CAAC,gBAAgB,CAAC,gBAAgB,EAAE,CAAC;QAC9C,CAAC,CAAC,CAAC;IACP,CAAC,CAAC;AACN,CAAC;AAED,kBAAe,SAAS,CAAC"}
@@ -1,6 +0,0 @@
1
- export interface ICacheClient {
2
- get(key: string): Promise<string | null>;
3
- set(key: string, value: string, ttlSeconds?: number): Promise<void>;
4
- del(key: string): Promise<void>;
5
- }
6
- //# sourceMappingURL=ICacheClient.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ICacheClient.d.ts","sourceRoot":"","sources":["../../../src/decorators/cache/ICacheClient.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,YAAY;IACzB,GAAG,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC;IACzC,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACpE,GAAG,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CACnC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"ICacheClient.js","sourceRoot":"","sources":["../../../src/decorators/cache/ICacheClient.ts"],"names":[],"mappings":""}
@@ -1,2 +0,0 @@
1
- export declare function Cache(ttlSeconds?: number, keyGenerator?: (...args: any[]) => string): MethodDecorator;
2
- //# sourceMappingURL=cache.decorator.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"cache.decorator.d.ts","sourceRoot":"","sources":["../../../src/decorators/cache/cache.decorator.ts"],"names":[],"mappings":"AAGA,wBAAgB,KAAK,CAAC,UAAU,GAAE,MAAW,EAAE,YAAY,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,MAAM,GAAG,eAAe,CAgCzG"}
@@ -1,38 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.Cache = Cache;
7
- const container_1 = __importDefault(require("../../container/container"));
8
- function Cache(ttlSeconds = 60, keyGenerator) {
9
- return (target, propertyKey, descriptor) => {
10
- const originalMethod = descriptor.value;
11
- const className = target.constructor.name;
12
- const methodName = String(propertyKey);
13
- descriptor.value = async function (...args) {
14
- const cacheClient = container_1.default.get('CacheClient');
15
- const cacheKey = keyGenerator
16
- ? keyGenerator(...args)
17
- : `cache:${className}:${methodName}:${JSON.stringify(args)}`;
18
- try {
19
- const cached = await cacheClient.get(cacheKey);
20
- if (cached)
21
- return JSON.parse(cached);
22
- }
23
- catch (err) {
24
- console.error('Cache read error:', err);
25
- }
26
- const result = await originalMethod.apply(this, args);
27
- try {
28
- await cacheClient.set(cacheKey, JSON.stringify(result), ttlSeconds);
29
- }
30
- catch (err) {
31
- console.error('Cache write error:', err);
32
- }
33
- return result;
34
- };
35
- return descriptor;
36
- };
37
- }
38
- //# sourceMappingURL=cache.decorator.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"cache.decorator.js","sourceRoot":"","sources":["../../../src/decorators/cache/cache.decorator.ts"],"names":[],"mappings":";;;;;AAGA,sBAgCC;AAnCD,0EAAkD;AAGlD,SAAgB,KAAK,CAAC,aAAqB,EAAE,EAAE,YAAyC;IACpF,OAAO,CAAC,MAAM,EAAE,WAAW,EAAE,UAAU,EAAE,EAAE;QACvC,MAAM,cAAc,GAAG,UAAU,CAAC,KAAgC,CAAC;QACnE,MAAM,SAAS,GAAG,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC;QAC1C,MAAM,UAAU,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;QAEvC,UAAU,CAAC,KAAK,GAAG,KAAK,WAAsB,GAAG,IAAW;YACxD,MAAM,WAAW,GAAG,mBAAS,CAAC,GAAG,CAAe,aAAa,CAAC,CAAC;YAC/D,MAAM,QAAQ,GAAG,YAAY;gBACzB,CAAC,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC;gBACvB,CAAC,CAAC,SAAS,SAAS,IAAI,UAAU,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC;YAEjE,IAAI,CAAC;gBACD,MAAM,MAAM,GAAG,MAAM,WAAW,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;gBAC/C,IAAI,MAAM;oBAAE,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YAC1C,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACX,OAAO,CAAC,KAAK,CAAC,mBAAmB,EAAE,GAAG,CAAC,CAAC;YAC5C,CAAC;YAED,MAAM,MAAM,GAAG,MAAM,cAAc,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YAEtD,IAAI,CAAC;gBACD,MAAM,WAAW,CAAC,GAAG,CAAC,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,UAAU,CAAC,CAAC;YACxE,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACX,OAAO,CAAC,KAAK,CAAC,oBAAoB,EAAE,GAAG,CAAC,CAAC;YAC7C,CAAC;YAED,OAAO,MAAM,CAAC;QAClB,CAAQ,CAAC;QAET,OAAO,UAAU,CAAC;IACtB,CAAC,CAAC;AACN,CAAC"}
@@ -1,9 +0,0 @@
1
- import 'reflect-metadata';
2
- import { FastifyInstance } from 'fastify';
3
- export declare const ROUTE_METADATA = "route:metadata";
4
- export declare function Controller(prefix?: string): ClassDecorator;
5
- export declare function registerControllers(fastify: FastifyInstance, controllers: Function[]): void;
6
- export declare function printFastifyRoutes(routeOptions: any[], opts: {
7
- colors: boolean;
8
- }): void;
9
- //# sourceMappingURL=controller.decorator.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"controller.decorator.d.ts","sourceRoot":"","sources":["../../src/decorators/controller.decorator.ts"],"names":[],"mappings":"AAAA,OAAO,kBAAkB,CAAC;AAC1B,OAAO,EAAE,eAAe,EAA8C,MAAM,SAAS,CAAC;AAKtF,eAAO,MAAM,cAAc,mBAAmB,CAAC;AAW/C,wBAAgB,UAAU,CAAC,MAAM,GAAE,MAAW,GAAG,cAAc,CAI9D;AAED,wBAAgB,mBAAmB,CAAC,OAAO,EAAE,eAAe,EAAE,WAAW,EAAE,QAAQ,EAAE,QAgDpF;AAED,wBAAgB,kBAAkB,CAAC,YAAY,EAAE,GAAG,EAAE,EAAE,IAAI,EAAE;IAAE,MAAM,EAAE,OAAO,CAAA;CAAE,QAoBhF"}
@@ -1,99 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.ROUTE_METADATA = void 0;
7
- exports.Controller = Controller;
8
- exports.registerControllers = registerControllers;
9
- exports.printFastifyRoutes = printFastifyRoutes;
10
- require("reflect-metadata");
11
- const container_1 = __importDefault(require("../container/container"));
12
- const Logger_1 = __importDefault(require("../logger/Logger"));
13
- const CONTROLLER_METADATA = 'controller:metadata';
14
- exports.ROUTE_METADATA = 'route:metadata';
15
- function Controller(prefix = '') {
16
- return (target) => {
17
- Reflect.defineMetadata(CONTROLLER_METADATA, { prefix }, target);
18
- };
19
- }
20
- function registerControllers(fastify, controllers) {
21
- const routeOptions = [];
22
- const fastifyWithHooks = fastify;
23
- fastifyWithHooks.addHook("onRoute", (routeOption) => {
24
- routeOptions.push(routeOption);
25
- });
26
- fastifyWithHooks.addHook("onReady", (done) => {
27
- printFastifyRoutes(routeOptions, { colors: true });
28
- done();
29
- });
30
- controllers.forEach(Controller => {
31
- const controllerMetadata = Reflect.getMetadata(CONTROLLER_METADATA, Controller);
32
- const routes = Reflect.getMetadata(exports.ROUTE_METADATA, Controller) || [];
33
- const controllerInstance = container_1.default.get(Controller);
34
- const prefix = controllerMetadata?.prefix || '';
35
- routes.forEach(route => {
36
- const fullPath = `${prefix}${route.path}`.replace(/\/\//g, '/');
37
- const handler = async (request, reply) => {
38
- try {
39
- const result = await controllerInstance[route.handlerName](request, reply);
40
- if (result !== undefined)
41
- return result;
42
- }
43
- catch (error) {
44
- Logger_1.default.error('Controller error:', error);
45
- const statusCode = error.statusCode || 500;
46
- const message = error.message || 'Internal Server Error';
47
- reply.status(statusCode).send({ error: message });
48
- }
49
- };
50
- const routeConfig = {
51
- ...route.options,
52
- handler,
53
- url: fullPath,
54
- method: route.method
55
- };
56
- fastify.route(routeConfig);
57
- });
58
- });
59
- }
60
- function printFastifyRoutes(routeOptions, opts) {
61
- const { colors } = opts;
62
- if (routeOptions.length === 0) {
63
- return;
64
- }
65
- routeOptions.sort((a, b) => a.url.localeCompare(b.url));
66
- const logEntries = [];
67
- logEntries.push("Available routes:");
68
- for (const routeOption of routeOptions) {
69
- const { method, url } = routeOption;
70
- if (method === "HEAD")
71
- continue;
72
- const formattedMethod = colors ? colorMethod(method) : method;
73
- logEntries.push(`${formattedMethod}\t${url}`);
74
- }
75
- Logger_1.default.info(logEntries.join("\n"));
76
- }
77
- const COLORS = {
78
- yellow: 33,
79
- green: 32,
80
- blue: 34,
81
- red: 31,
82
- grey: 90,
83
- magenta: 35,
84
- clear: 39,
85
- };
86
- function colorText(color, string) {
87
- return `\u001b[${color}m${string}\u001b[${COLORS.clear}m`;
88
- }
89
- function colorMethod(method) {
90
- switch (method) {
91
- case "POST": return colorText(COLORS.yellow, method);
92
- case "GET": return colorText(COLORS.green, method);
93
- case "PUT": return colorText(COLORS.blue, method);
94
- case "DELETE": return colorText(COLORS.red, method);
95
- case "PATCH": return colorText(COLORS.grey, method);
96
- default: return method;
97
- }
98
- }
99
- //# sourceMappingURL=controller.decorator.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"controller.decorator.js","sourceRoot":"","sources":["../../src/decorators/controller.decorator.ts"],"names":[],"mappings":"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"}