bootifyjs 0.1.1 → 1.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 (261) hide show
  1. package/dist/api.d.ts +8 -27
  2. package/dist/api.d.ts.map +1 -0
  3. package/dist/api.js +68 -134
  4. package/dist/api.js.map +1 -1
  5. package/dist/cache/bootstrap.d.ts +6 -0
  6. package/dist/cache/bootstrap.d.ts.map +1 -0
  7. package/dist/cache/bootstrap.js +23 -0
  8. package/dist/cache/bootstrap.js.map +1 -0
  9. package/dist/cache/cache.service.d.ts +9 -0
  10. package/dist/cache/cache.service.d.ts.map +1 -0
  11. package/dist/cache/cache.service.js +40 -0
  12. package/dist/cache/cache.service.js.map +1 -0
  13. package/dist/cache/cache.types.d.ts +14 -0
  14. package/dist/cache/cache.types.d.ts.map +1 -0
  15. package/dist/cache/cache.types.js +8 -0
  16. package/dist/cache/cache.types.js.map +1 -0
  17. package/dist/cache/decorators.d.ts +12 -0
  18. package/dist/cache/decorators.d.ts.map +1 -0
  19. package/dist/cache/decorators.js +53 -0
  20. package/dist/cache/decorators.js.map +1 -0
  21. package/dist/cache/in-memory-cache.store.d.ts +8 -0
  22. package/dist/cache/in-memory-cache.store.d.ts.map +1 -0
  23. package/dist/cache/in-memory-cache.store.js +39 -0
  24. package/dist/cache/in-memory-cache.store.js.map +1 -0
  25. package/dist/cache/index.d.ts +5 -0
  26. package/dist/cache/index.d.ts.map +1 -0
  27. package/dist/cache/index.js +21 -0
  28. package/dist/cache/index.js.map +1 -0
  29. package/dist/core/component-registry.d.ts +7 -0
  30. package/dist/core/component-registry.d.ts.map +1 -0
  31. package/dist/core/component-registry.js +9 -0
  32. package/dist/core/component-registry.js.map +1 -0
  33. package/dist/core/decorators.d.ts +38 -22
  34. package/dist/core/decorators.d.ts.map +1 -0
  35. package/dist/core/decorators.js +155 -174
  36. package/dist/core/decorators.js.map +1 -1
  37. package/dist/core/di-container.d.ts +31 -0
  38. package/dist/core/di-container.d.ts.map +1 -0
  39. package/dist/core/di-container.js +219 -0
  40. package/dist/core/di-container.js.map +1 -0
  41. package/dist/core/index.d.ts +5 -0
  42. package/dist/core/index.d.ts.map +1 -0
  43. package/dist/core/index.js +21 -0
  44. package/dist/core/index.js.map +1 -0
  45. package/dist/core/request-context.service.d.ts +24 -0
  46. package/dist/core/request-context.service.d.ts.map +1 -0
  47. package/dist/core/request-context.service.js +52 -0
  48. package/dist/core/request-context.service.js.map +1 -0
  49. package/dist/core/router.d.ts +4 -32
  50. package/dist/core/router.d.ts.map +1 -0
  51. package/dist/core/router.js +81 -258
  52. package/dist/core/router.js.map +1 -1
  53. package/dist/events/bootstrap.d.ts +8 -0
  54. package/dist/events/bootstrap.d.ts.map +1 -0
  55. package/dist/events/bootstrap.js +37 -0
  56. package/dist/events/bootstrap.js.map +1 -0
  57. package/dist/events/decorators.d.ts +16 -0
  58. package/dist/events/decorators.d.ts.map +1 -0
  59. package/dist/events/decorators.js +37 -0
  60. package/dist/events/decorators.js.map +1 -0
  61. package/dist/events/event-bus.service.d.ts +21 -0
  62. package/dist/events/event-bus.service.d.ts.map +1 -0
  63. package/dist/events/event-bus.service.js +78 -0
  64. package/dist/events/event-bus.service.js.map +1 -0
  65. package/dist/events/event.types.d.ts +17 -0
  66. package/dist/events/event.types.d.ts.map +1 -0
  67. package/dist/events/event.types.js.map +1 -0
  68. package/dist/events/index.d.ts +5 -13
  69. package/dist/events/index.d.ts.map +1 -0
  70. package/dist/events/index.js +4 -54
  71. package/dist/events/index.js.map +1 -1
  72. package/dist/examples/controllers/health.controller.d.ts +7 -0
  73. package/dist/examples/controllers/health.controller.d.ts.map +1 -0
  74. package/dist/{events/examples/system.events.js → examples/controllers/health.controller.js} +16 -15
  75. package/dist/examples/controllers/health.controller.js.map +1 -0
  76. package/dist/examples/controllers/todo.controller.d.ts +31 -0
  77. package/dist/examples/controllers/todo.controller.d.ts.map +1 -0
  78. package/dist/examples/controllers/todo.controller.js +102 -0
  79. package/dist/examples/controllers/todo.controller.js.map +1 -0
  80. package/dist/examples/events/TodoEventHandler.d.ts +2 -0
  81. package/dist/examples/events/TodoEventHandler.d.ts.map +1 -0
  82. package/dist/examples/events/TodoEventHandler.js +31 -0
  83. package/dist/examples/events/TodoEventHandler.js.map +1 -0
  84. package/dist/examples/events/todo.events.d.ts +16 -0
  85. package/dist/examples/events/todo.events.d.ts.map +1 -0
  86. package/dist/examples/events/todo.events.js +13 -0
  87. package/dist/examples/events/todo.events.js.map +1 -0
  88. package/dist/examples/index.d.ts +2 -0
  89. package/dist/examples/index.d.ts.map +1 -0
  90. package/dist/examples/index.js +35 -0
  91. package/dist/examples/index.js.map +1 -0
  92. package/dist/examples/repositories/todo.repository.d.ts +20 -0
  93. package/dist/examples/repositories/todo.repository.d.ts.map +1 -0
  94. package/dist/examples/repositories/todo.repository.js +33 -0
  95. package/dist/examples/repositories/todo.repository.js.map +1 -0
  96. package/dist/examples/services/todo.service.d.ts +33 -0
  97. package/dist/examples/services/todo.service.d.ts.map +1 -0
  98. package/dist/examples/services/todo.service.js +80 -0
  99. package/dist/examples/services/todo.service.js.map +1 -0
  100. package/dist/examples/todos/schema.d.ts +54 -0
  101. package/dist/examples/todos/schema.d.ts.map +1 -0
  102. package/dist/examples/todos/schema.js +20 -0
  103. package/dist/examples/todos/schema.js.map +1 -0
  104. package/dist/index.d.ts +7 -17
  105. package/dist/index.d.ts.map +1 -0
  106. package/dist/index.js +20 -95
  107. package/dist/index.js.map +1 -1
  108. package/dist/logging/config/logging.config.d.ts +31 -3
  109. package/dist/logging/config/logging.config.d.ts.map +1 -0
  110. package/dist/logging/config/logging.config.js +43 -93
  111. package/dist/logging/config/logging.config.js.map +1 -1
  112. package/dist/logging/core/decorators.d.ts +16 -0
  113. package/dist/logging/core/decorators.d.ts.map +1 -0
  114. package/dist/logging/core/decorators.js +74 -0
  115. package/dist/logging/core/decorators.js.map +1 -0
  116. package/dist/logging/core/logger.provider.d.ts +4 -0
  117. package/dist/logging/core/logger.provider.d.ts.map +1 -0
  118. package/dist/logging/core/logger.provider.js +68 -0
  119. package/dist/logging/core/logger.provider.js.map +1 -0
  120. package/dist/logging/core/logger.service.d.ts +9 -27
  121. package/dist/logging/core/logger.service.d.ts.map +1 -0
  122. package/dist/logging/core/logger.service.js +34 -164
  123. package/dist/logging/core/logger.service.js.map +1 -1
  124. package/dist/logging/core/{startup-logger.service.d.ts → startup.logger.d.ts} +4 -6
  125. package/dist/logging/core/startup.logger.d.ts.map +1 -0
  126. package/dist/logging/core/{startup-logger.service.js → startup.logger.js} +36 -42
  127. package/dist/logging/core/startup.logger.js.map +1 -0
  128. package/dist/logging/index.d.ts +7 -14
  129. package/dist/logging/index.d.ts.map +1 -0
  130. package/dist/logging/index.js +17 -28
  131. package/dist/logging/index.js.map +1 -1
  132. package/dist/middleware/auth.middleware.d.ts +3 -0
  133. package/dist/middleware/auth.middleware.d.ts.map +1 -0
  134. package/dist/middleware/auth.middleware.js +18 -0
  135. package/dist/middleware/auth.middleware.js.map +1 -0
  136. package/dist/middleware/context.middleware.d.ts +7 -0
  137. package/dist/middleware/context.middleware.d.ts.map +1 -0
  138. package/dist/middleware/context.middleware.js +25 -0
  139. package/dist/middleware/context.middleware.js.map +1 -0
  140. package/dist/middleware/index.d.ts +4 -0
  141. package/dist/middleware/index.d.ts.map +1 -0
  142. package/dist/middleware/index.js +20 -0
  143. package/dist/middleware/index.js.map +1 -0
  144. package/dist/middleware/request-logger.middleware.d.ts +4 -0
  145. package/dist/middleware/request-logger.middleware.d.ts.map +1 -0
  146. package/dist/middleware/request-logger.middleware.js +18 -0
  147. package/dist/middleware/request-logger.middleware.js.map +1 -0
  148. package/package.json +52 -47
  149. package/LICENSE +0 -21
  150. package/README.md +0 -423
  151. package/dist/config/app.config.d.ts +0 -29
  152. package/dist/config/app.config.js +0 -55
  153. package/dist/config/app.config.js.map +0 -1
  154. package/dist/controllers/config.controller.d.ts +0 -16
  155. package/dist/controllers/config.controller.js +0 -66
  156. package/dist/controllers/config.controller.js.map +0 -1
  157. package/dist/controllers/events.controller.d.ts +0 -66
  158. package/dist/controllers/events.controller.js +0 -145
  159. package/dist/controllers/events.controller.js.map +0 -1
  160. package/dist/controllers/health.controller.d.ts +0 -20
  161. package/dist/controllers/health.controller.js +0 -92
  162. package/dist/controllers/health.controller.js.map +0 -1
  163. package/dist/controllers/user.controller.d.ts +0 -13
  164. package/dist/controllers/user.controller.js +0 -209
  165. package/dist/controllers/user.controller.js.map +0 -1
  166. package/dist/core/application.d.ts +0 -21
  167. package/dist/core/application.js +0 -90
  168. package/dist/core/application.js.map +0 -1
  169. package/dist/core/config.d.ts +0 -3
  170. package/dist/core/config.js +0 -78
  171. package/dist/core/config.js.map +0 -1
  172. package/dist/core/container.d.ts +0 -17
  173. package/dist/core/container.js +0 -92
  174. package/dist/core/container.js.map +0 -1
  175. package/dist/core/errors.d.ts +0 -18
  176. package/dist/core/errors.js +0 -74
  177. package/dist/core/errors.js.map +0 -1
  178. package/dist/core/middleware.d.ts +0 -8
  179. package/dist/core/middleware.js +0 -23
  180. package/dist/core/middleware.js.map +0 -1
  181. package/dist/core/openapi.d.ts +0 -80
  182. package/dist/core/openapi.js +0 -189
  183. package/dist/core/openapi.js.map +0 -1
  184. package/dist/core/utils.d.ts +0 -7
  185. package/dist/core/utils.js +0 -75
  186. package/dist/core/utils.js.map +0 -1
  187. package/dist/core/validation.d.ts +0 -15
  188. package/dist/core/validation.js +0 -161
  189. package/dist/core/validation.js.map +0 -1
  190. package/dist/events/core/event-bus.d.ts +0 -26
  191. package/dist/events/core/event-bus.js +0 -253
  192. package/dist/events/core/event-bus.js.map +0 -1
  193. package/dist/events/core/event-registry.d.ts +0 -31
  194. package/dist/events/core/event-registry.js +0 -170
  195. package/dist/events/core/event-registry.js.map +0 -1
  196. package/dist/events/decorators/event.decorators.d.ts +0 -11
  197. package/dist/events/decorators/event.decorators.js +0 -123
  198. package/dist/events/decorators/event.decorators.js.map +0 -1
  199. package/dist/events/examples/system.events.d.ts +0 -15
  200. package/dist/events/examples/system.events.js.map +0 -1
  201. package/dist/events/examples/user.events.d.ts +0 -68
  202. package/dist/events/examples/user.events.js +0 -73
  203. package/dist/events/examples/user.events.js.map +0 -1
  204. package/dist/events/examples/user.handlers.d.ts +0 -20
  205. package/dist/events/examples/user.handlers.js +0 -157
  206. package/dist/events/examples/user.handlers.js.map +0 -1
  207. package/dist/events/middleware/logging.middleware.d.ts +0 -7
  208. package/dist/events/middleware/logging.middleware.js +0 -44
  209. package/dist/events/middleware/logging.middleware.js.map +0 -1
  210. package/dist/events/middleware/metrics.middleware.d.ts +0 -11
  211. package/dist/events/middleware/metrics.middleware.js +0 -87
  212. package/dist/events/middleware/metrics.middleware.js.map +0 -1
  213. package/dist/events/middleware/validation.middleware.d.ts +0 -8
  214. package/dist/events/middleware/validation.middleware.js +0 -63
  215. package/dist/events/middleware/validation.middleware.js.map +0 -1
  216. package/dist/events/store/memory-event-store.d.ts +0 -21
  217. package/dist/events/store/memory-event-store.js +0 -81
  218. package/dist/events/store/memory-event-store.js.map +0 -1
  219. package/dist/events/types/event.types.d.ts +0 -57
  220. package/dist/events/types/event.types.js.map +0 -1
  221. package/dist/examples/basic-api.d.ts +0 -1
  222. package/dist/examples/basic-api.js +0 -120
  223. package/dist/examples/basic-api.js.map +0 -1
  224. package/dist/logging/core/log-context.service.d.ts +0 -11
  225. package/dist/logging/core/log-context.service.js +0 -40
  226. package/dist/logging/core/log-context.service.js.map +0 -1
  227. package/dist/logging/core/startup-logger.service.js.map +0 -1
  228. package/dist/logging/decorators/log.decorator.d.ts +0 -11
  229. package/dist/logging/decorators/log.decorator.js +0 -80
  230. package/dist/logging/decorators/log.decorator.js.map +0 -1
  231. package/dist/logging/middleware/context.middleware.d.ts +0 -2
  232. package/dist/logging/middleware/context.middleware.js +0 -29
  233. package/dist/logging/middleware/context.middleware.js.map +0 -1
  234. package/dist/logging/middleware/request-logging.middleware.d.ts +0 -3
  235. package/dist/logging/middleware/request-logging.middleware.js +0 -78
  236. package/dist/logging/middleware/request-logging.middleware.js.map +0 -1
  237. package/dist/logging/types/logging.types.d.ts +0 -79
  238. package/dist/logging/types/logging.types.js +0 -3
  239. package/dist/logging/types/logging.types.js.map +0 -1
  240. package/dist/middlewares/auth.middleware.d.ts +0 -2
  241. package/dist/middlewares/auth.middleware.js +0 -20
  242. package/dist/middlewares/auth.middleware.js.map +0 -1
  243. package/dist/middlewares/cors.middleware.d.ts +0 -2
  244. package/dist/middlewares/cors.middleware.js +0 -16
  245. package/dist/middlewares/cors.middleware.js.map +0 -1
  246. package/dist/middlewares/swagger.middleware.d.ts +0 -6
  247. package/dist/middlewares/swagger.middleware.js +0 -84
  248. package/dist/middlewares/swagger.middleware.js.map +0 -1
  249. package/dist/repositories/user.repository.d.ts +0 -16
  250. package/dist/repositories/user.repository.js +0 -110
  251. package/dist/repositories/user.repository.js.map +0 -1
  252. package/dist/schemas/user.schemas.d.ts +0 -214
  253. package/dist/schemas/user.schemas.js +0 -71
  254. package/dist/schemas/user.schemas.js.map +0 -1
  255. package/dist/services/config-demo.service.d.ts +0 -10
  256. package/dist/services/config-demo.service.js +0 -88
  257. package/dist/services/config-demo.service.js.map +0 -1
  258. package/dist/services/user.service.d.ts +0 -21
  259. package/dist/services/user.service.js +0 -201
  260. package/dist/services/user.service.js.map +0 -1
  261. /package/dist/events/{types/event.types.js → event.types.js} +0 -0
@@ -1,80 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Log = Log;
4
- exports.Logger = Logger;
5
- const logger_service_1 = require("../core/logger.service");
6
- function Log(options = {}) {
7
- return function (target, propertyKey, descriptor) {
8
- const originalMethod = descriptor.value;
9
- const className = target.constructor.name;
10
- const methodName = String(propertyKey);
11
- descriptor.value = async function (...args) {
12
- const logger = logger_service_1.LoggerService.getInstance();
13
- const startTime = Date.now();
14
- // Skip logging if condition is met
15
- if (options.skipIf && options.skipIf(args)) {
16
- return originalMethod.apply(this, args);
17
- }
18
- const logData = {
19
- component: options.component || className,
20
- class: className,
21
- method: methodName
22
- };
23
- if (options.logArgs && logger.getConfig().enableComponentLogs) {
24
- logData.arguments = args;
25
- }
26
- const message = options.message || `${className}.${methodName} called`;
27
- try {
28
- logger[options.level || 'debug'](`${message} - started`, logData);
29
- const result = await originalMethod.apply(this, args);
30
- const duration = Date.now() - startTime;
31
- const successData = { ...logData };
32
- if (options.logResult && logger.getConfig().enableComponentLogs) {
33
- successData.result = result;
34
- }
35
- if (options.logDuration) {
36
- successData.duration = duration;
37
- }
38
- logger[options.level || 'debug'](`${message} - completed`, successData);
39
- // Log performance if enabled and method is slow
40
- if (logger.getConfig().enablePerformanceLogs && duration > (logger.getConfig().performance?.slowThreshold || 1000)) {
41
- logger.performance({
42
- operation: `${className}.${methodName}`,
43
- duration,
44
- metadata: { slow: true }
45
- });
46
- }
47
- return result;
48
- }
49
- catch (error) {
50
- const duration = Date.now() - startTime;
51
- logger.error(`${message} - failed`, error, {
52
- ...logData,
53
- duration,
54
- error: error instanceof Error ? error.message : String(error)
55
- });
56
- throw error;
57
- }
58
- };
59
- return descriptor;
60
- };
61
- }
62
- // Class-level logger injection
63
- function Logger(name) {
64
- return function (target) {
65
- const loggerName = name || target.name;
66
- // Add lazy logger property to the class
67
- Object.defineProperty(target.prototype, 'logger', {
68
- get: function () {
69
- // Lazy initialization - only create logger when first accessed
70
- if (!this._logger) {
71
- this._logger = logger_service_1.LoggerService.getInstance().child({ component: loggerName });
72
- }
73
- return this._logger;
74
- },
75
- enumerable: false,
76
- configurable: false
77
- });
78
- };
79
- }
80
- //# sourceMappingURL=log.decorator.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"log.decorator.js","sourceRoot":"","sources":["../../../src/logging/decorators/log.decorator.ts"],"names":[],"mappings":"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"}
@@ -1,2 +0,0 @@
1
- import { Middleware } from '../../core/middleware';
2
- export declare const contextMiddleware: Middleware;
@@ -1,29 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.contextMiddleware = void 0;
4
- const log_context_service_1 = require("../core/log-context.service");
5
- const contextMiddleware = async (req, res, next) => {
6
- const requestId = log_context_service_1.LogContextService.generateRequestId();
7
- const traceId = log_context_service_1.LogContextService.generateTraceId();
8
- // Set response header
9
- res.setHeader('x-request-id', requestId);
10
- // Extract user info if available (from auth middleware)
11
- const user = req.user;
12
- const context = {
13
- requestId,
14
- traceId,
15
- spanId: log_context_service_1.LogContextService.generateSpanId(),
16
- userId: user?.id,
17
- username: user?.username,
18
- userAgent: req.headers['user-agent'],
19
- ip: req.headers['x-forwarded-for'] || req.socket.remoteAddress,
20
- method: req.method,
21
- url: req.url,
22
- startTime: Date.now()
23
- };
24
- log_context_service_1.LogContextService.run(context, async () => {
25
- await next();
26
- });
27
- };
28
- exports.contextMiddleware = contextMiddleware;
29
- //# sourceMappingURL=context.middleware.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"context.middleware.js","sourceRoot":"","sources":["../../../src/logging/middleware/context.middleware.ts"],"names":[],"mappings":";;;AACA,qEAAgE;AAGzD,MAAM,iBAAiB,GAAe,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;IACpE,MAAM,SAAS,GAAG,uCAAiB,CAAC,iBAAiB,EAAE,CAAC;IACxD,MAAM,OAAO,GAAG,uCAAiB,CAAC,eAAe,EAAE,CAAC;IAEpD,sBAAsB;IACtB,GAAG,CAAC,SAAS,CAAC,cAAc,EAAE,SAAS,CAAC,CAAC;IAEzC,wDAAwD;IACxD,MAAM,IAAI,GAAI,GAAW,CAAC,IAAI,CAAC;IAE/B,MAAM,OAAO,GAAe;QAC1B,SAAS;QACT,OAAO;QACP,MAAM,EAAE,uCAAiB,CAAC,cAAc,EAAE;QAC1C,MAAM,EAAE,IAAI,EAAE,EAAE;QAChB,QAAQ,EAAE,IAAI,EAAE,QAAQ;QACxB,SAAS,EAAE,GAAG,CAAC,OAAO,CAAC,YAAY,CAAC;QACpC,EAAE,EAAE,GAAG,CAAC,OAAO,CAAC,iBAAiB,CAAW,IAAI,GAAG,CAAC,MAAM,CAAC,aAAa;QACxE,MAAM,EAAE,GAAG,CAAC,MAAM;QAClB,GAAG,EAAE,GAAG,CAAC,GAAG;QACZ,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;KACtB,CAAC;IAEF,uCAAiB,CAAC,GAAG,CAAC,OAAO,EAAE,KAAK,IAAI,EAAE;QACxC,MAAM,IAAI,EAAE,CAAC;IACf,CAAC,CAAC,CAAC;AACL,CAAC,CAAC;AA1BW,QAAA,iBAAiB,qBA0B5B"}
@@ -1,3 +0,0 @@
1
- import { Middleware } from '../../core/middleware';
2
- import { RequestLoggingOptions } from '../types/logging.types';
3
- export declare const createRequestLoggingMiddleware: (options?: RequestLoggingOptions) => Middleware;
@@ -1,78 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.createRequestLoggingMiddleware = void 0;
4
- const logger_service_1 = require("../core/logger.service");
5
- const log_context_service_1 = require("../core/log-context.service");
6
- const createRequestLoggingMiddleware = (options = {}) => {
7
- return async (req, res, next) => {
8
- const logger = logger_service_1.LoggerService.getInstance();
9
- const startTime = Date.now();
10
- const context = log_context_service_1.LogContextService.getContext();
11
- // Skip logging for certain paths
12
- if (options.skipPaths?.some(path => req.url?.startsWith(path))) {
13
- await next();
14
- return;
15
- }
16
- const requestData = {
17
- component: 'HTTP',
18
- method: req.method,
19
- url: req.url,
20
- userAgent: req.headers['user-agent'],
21
- ip: req.headers['x-forwarded-for'] || req.socket.remoteAddress
22
- };
23
- if (options.logHeaders && logger.getConfig().logHeaders) {
24
- requestData.headers = req.headers;
25
- }
26
- if (options.logQuery && req.url?.includes('?')) {
27
- try {
28
- const url = new URL(req.url, `http://${req.headers.host}`);
29
- requestData.query = Object.fromEntries(url.searchParams);
30
- }
31
- catch (error) {
32
- // Ignore URL parsing errors
33
- }
34
- }
35
- logger.debug('HTTP Request started', requestData);
36
- // Override res.end to log response
37
- const originalEnd = res.end;
38
- res.end = function (chunk, encoding) {
39
- const duration = Date.now() - startTime;
40
- const responseData = {
41
- component: 'HTTP',
42
- statusCode: res.statusCode,
43
- duration,
44
- contentLength: res.getHeader('content-length')
45
- };
46
- // Log slow requests
47
- if (options.slowThreshold && duration > options.slowThreshold) {
48
- logger.warn('Slow HTTP Request', {
49
- ...requestData,
50
- ...responseData,
51
- slow: true
52
- });
53
- }
54
- else {
55
- const level = res.statusCode >= 400 ? 'warn' : 'info';
56
- logger[level]('HTTP Request completed', {
57
- ...requestData,
58
- ...responseData
59
- });
60
- }
61
- // Log performance metrics
62
- if (context && logger.getConfig().enablePerformanceLogs) {
63
- logger.performance({
64
- operation: `${req.method} ${req.url}`,
65
- duration,
66
- metadata: {
67
- statusCode: res.statusCode,
68
- contentLength: res.getHeader('content-length')
69
- }
70
- });
71
- }
72
- return originalEnd.call(this, chunk, encoding);
73
- };
74
- await next();
75
- };
76
- };
77
- exports.createRequestLoggingMiddleware = createRequestLoggingMiddleware;
78
- //# sourceMappingURL=request-logging.middleware.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"request-logging.middleware.js","sourceRoot":"","sources":["../../../src/logging/middleware/request-logging.middleware.ts"],"names":[],"mappings":"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"}
@@ -1,79 +0,0 @@
1
- export interface LogContext {
2
- requestId: string;
3
- userId?: string;
4
- username?: string;
5
- traceId?: string;
6
- spanId?: string;
7
- correlationId?: string;
8
- sessionId?: string;
9
- userAgent?: string;
10
- ip?: string;
11
- method?: string;
12
- url?: string;
13
- startTime?: number;
14
- additionalContext?: Record<string, any>;
15
- }
16
- export interface LogPayload {
17
- message: string;
18
- [key: string]: any;
19
- }
20
- export interface AuditLogPayload {
21
- action: string;
22
- resource: string;
23
- resourceId?: string;
24
- oldValues?: Record<string, any>;
25
- newValues?: Record<string, any>;
26
- metadata?: Record<string, any>;
27
- }
28
- export interface EventLogPayload {
29
- eventName: string;
30
- eventType: 'business' | 'system' | 'security' | 'performance';
31
- status: 'success' | 'failure' | 'pending' | 'cancelled';
32
- duration?: number;
33
- metadata?: Record<string, any>;
34
- }
35
- export interface PerformanceLogPayload {
36
- operation: string;
37
- duration: number;
38
- memoryUsage?: NodeJS.MemoryUsage;
39
- metadata?: Record<string, any>;
40
- }
41
- export interface StartupLogPayload {
42
- component: string;
43
- phase: 'starting' | 'completed' | 'failed';
44
- duration?: number;
45
- details?: Record<string, any>;
46
- }
47
- export interface LoggingConfig {
48
- level: 'trace' | 'debug' | 'info' | 'warn' | 'error' | 'fatal';
49
- serviceName: string;
50
- serviceVersion: string;
51
- environment: string;
52
- logHeaders: boolean;
53
- logStackTrace: boolean;
54
- enableStartupLogs: boolean;
55
- enableComponentLogs: boolean;
56
- enablePerformanceLogs: boolean;
57
- transports?: any[];
58
- rotation?: {
59
- enabled: boolean;
60
- maxFiles: number;
61
- maxSize: string;
62
- datePattern: string;
63
- };
64
- correlation?: {
65
- enabled: boolean;
66
- headerName: string;
67
- };
68
- performance?: {
69
- enabled: boolean;
70
- slowThreshold: number;
71
- };
72
- }
73
- export interface RequestLoggingOptions {
74
- logBody?: boolean;
75
- logHeaders?: boolean;
76
- logQuery?: boolean;
77
- skipPaths?: string[];
78
- slowThreshold?: number;
79
- }
@@ -1,3 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=logging.types.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"logging.types.js","sourceRoot":"","sources":["../../../src/logging/types/logging.types.ts"],"names":[],"mappings":""}
@@ -1,2 +0,0 @@
1
- import { Middleware } from '../core/middleware';
2
- export declare const authMiddleware: Middleware;
@@ -1,20 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.authMiddleware = void 0;
4
- const errors_1 = require("../core/errors");
5
- const authMiddleware = async (req, res, next) => {
6
- const authHeader = req.headers.authorization;
7
- if (!authHeader || !authHeader.startsWith('Bearer ')) {
8
- throw new errors_1.UnauthorizedError('Authorization header is required');
9
- }
10
- const token = authHeader.substring(7); // Remove 'Bearer ' prefix
11
- // Simple token validation (in real app, verify JWT)
12
- if (token !== 'valid-token') {
13
- throw new errors_1.UnauthorizedError('Invalid token');
14
- }
15
- // Add user info to request (in real app, decode from JWT)
16
- req.user = { id: '1', email: 'john@example.com' };
17
- await next();
18
- };
19
- exports.authMiddleware = authMiddleware;
20
- //# sourceMappingURL=auth.middleware.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"auth.middleware.js","sourceRoot":"","sources":["../../src/middlewares/auth.middleware.ts"],"names":[],"mappings":";;;AACA,2CAAmD;AAE5C,MAAM,cAAc,GAAe,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;IACjE,MAAM,UAAU,GAAG,GAAG,CAAC,OAAO,CAAC,aAAa,CAAC;IAE7C,IAAI,CAAC,UAAU,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;QACrD,MAAM,IAAI,0BAAiB,CAAC,kCAAkC,CAAC,CAAC;IAClE,CAAC;IAED,MAAM,KAAK,GAAG,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,0BAA0B;IAEjE,oDAAoD;IACpD,IAAI,KAAK,KAAK,aAAa,EAAE,CAAC;QAC5B,MAAM,IAAI,0BAAiB,CAAC,eAAe,CAAC,CAAC;IAC/C,CAAC;IAED,0DAA0D;IACzD,GAAW,CAAC,IAAI,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,KAAK,EAAE,kBAAkB,EAAE,CAAC;IAE3D,MAAM,IAAI,EAAE,CAAC;AACf,CAAC,CAAC;AAlBW,QAAA,cAAc,kBAkBzB"}
@@ -1,2 +0,0 @@
1
- import { Middleware } from '../core/middleware';
2
- export declare const corsMiddleware: Middleware;
@@ -1,16 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.corsMiddleware = void 0;
4
- const corsMiddleware = async (req, res, next) => {
5
- res.setHeader('Access-Control-Allow-Origin', '*');
6
- res.setHeader('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE, OPTIONS');
7
- res.setHeader('Access-Control-Allow-Headers', 'Content-Type, Authorization');
8
- if (req.method === 'OPTIONS') {
9
- res.writeHead(200);
10
- res.end();
11
- return;
12
- }
13
- await next();
14
- };
15
- exports.corsMiddleware = corsMiddleware;
16
- //# sourceMappingURL=cors.middleware.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"cors.middleware.js","sourceRoot":"","sources":["../../src/middlewares/cors.middleware.ts"],"names":[],"mappings":";;;AAEO,MAAM,cAAc,GAAe,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;IACjE,GAAG,CAAC,SAAS,CAAC,6BAA6B,EAAE,GAAG,CAAC,CAAC;IAClD,GAAG,CAAC,SAAS,CAAC,8BAA8B,EAAE,iCAAiC,CAAC,CAAC;IACjF,GAAG,CAAC,SAAS,CAAC,8BAA8B,EAAE,6BAA6B,CAAC,CAAC;IAE7E,IAAI,GAAG,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;QAC7B,GAAG,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;QACnB,GAAG,CAAC,GAAG,EAAE,CAAC;QACV,OAAO;IACT,CAAC;IAED,MAAM,IAAI,EAAE,CAAC;AACf,CAAC,CAAC;AAZW,QAAA,cAAc,kBAYzB"}
@@ -1,6 +0,0 @@
1
- import { Middleware } from '../core/middleware';
2
- import { OpenAPISpec } from '../core/openapi';
3
- export declare const swaggerMiddleware: (spec: OpenAPISpec, options?: {
4
- path?: string;
5
- title?: string;
6
- }) => Middleware;
@@ -1,84 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.swaggerMiddleware = void 0;
4
- const swaggerMiddleware = (spec, options = {}) => {
5
- const swaggerPath = options.path || '/api-docs';
6
- const title = options.title || 'API Documentation';
7
- return async (req, res, next) => {
8
- const url = req.url || '';
9
- if (url === swaggerPath) {
10
- // Serve Swagger UI HTML
11
- const html = generateSwaggerHTML(swaggerPath, title);
12
- res.writeHead(200, { 'Content-Type': 'text/html' });
13
- res.end(html);
14
- return;
15
- }
16
- if (url === `${swaggerPath}/swagger.json`) {
17
- // Serve OpenAPI spec JSON
18
- res.writeHead(200, { 'Content-Type': 'application/json' });
19
- res.end(JSON.stringify(spec, null, 2));
20
- return;
21
- }
22
- await next();
23
- };
24
- };
25
- exports.swaggerMiddleware = swaggerMiddleware;
26
- function generateSwaggerHTML(swaggerPath, title) {
27
- return `
28
- <!DOCTYPE html>
29
- <html lang="en">
30
- <head>
31
- <meta charset="UTF-8">
32
- <meta name="viewport" content="width=device-width, initial-scale=1.0">
33
- <title>${title}</title>
34
- <link rel="stylesheet" type="text/css" href="https://unpkg.com/swagger-ui-dist@4.15.5/swagger-ui.css" />
35
- <style>
36
- html {
37
- box-sizing: border-box;
38
- overflow: -moz-scrollbars-vertical;
39
- overflow-y: scroll;
40
- }
41
- *, *:before, *:after {
42
- box-sizing: inherit;
43
- }
44
- body {
45
- margin:0;
46
- background: #fafafa;
47
- }
48
- </style>
49
- </head>
50
- <body>
51
- <div id="swagger-ui"></div>
52
- <script src="https://unpkg.com/swagger-ui-dist@4.15.5/swagger-ui-bundle.js"></script>
53
- <script src="https://unpkg.com/swagger-ui-dist@4.15.5/swagger-ui-standalone-preset.js"></script>
54
- <script>
55
- window.onload = function() {
56
- const ui = SwaggerUIBundle({
57
- url: '${swaggerPath}/swagger.json',
58
- dom_id: '#swagger-ui',
59
- deepLinking: true,
60
- presets: [
61
- SwaggerUIBundle.presets.apis,
62
- SwaggerUIStandalonePreset
63
- ],
64
- plugins: [
65
- SwaggerUIBundle.plugins.DownloadUrl
66
- ],
67
- layout: "StandaloneLayout",
68
- validatorUrl: null,
69
- tryItOutEnabled: true,
70
- supportedSubmitMethods: ['get', 'post', 'put', 'delete', 'patch'],
71
- onComplete: function() {
72
- console.log('Swagger UI loaded successfully');
73
- },
74
- onFailure: function(data) {
75
- console.error('Failed to load Swagger UI:', data);
76
- }
77
- });
78
- };
79
- </script>
80
- </body>
81
- </html>
82
- `;
83
- }
84
- //# sourceMappingURL=swagger.middleware.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"swagger.middleware.js","sourceRoot":"","sources":["../../src/middlewares/swagger.middleware.ts"],"names":[],"mappings":";;;AAGO,MAAM,iBAAiB,GAAG,CAAC,IAAiB,EAAE,UAGjD,EAAE,EAAc,EAAE;IACpB,MAAM,WAAW,GAAG,OAAO,CAAC,IAAI,IAAI,WAAW,CAAC;IAChD,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,IAAI,mBAAmB,CAAC;IAEnD,OAAO,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;QAC9B,MAAM,GAAG,GAAG,GAAG,CAAC,GAAG,IAAI,EAAE,CAAC;QAE1B,IAAI,GAAG,KAAK,WAAW,EAAE,CAAC;YACxB,wBAAwB;YACxB,MAAM,IAAI,GAAG,mBAAmB,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC;YACrD,GAAG,CAAC,SAAS,CAAC,GAAG,EAAE,EAAE,cAAc,EAAE,WAAW,EAAE,CAAC,CAAC;YACpD,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YACd,OAAO;QACT,CAAC;QAED,IAAI,GAAG,KAAK,GAAG,WAAW,eAAe,EAAE,CAAC;YAC1C,0BAA0B;YAC1B,GAAG,CAAC,SAAS,CAAC,GAAG,EAAE,EAAE,cAAc,EAAE,kBAAkB,EAAE,CAAC,CAAC;YAC3D,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;YACvC,OAAO;QACT,CAAC;QAED,MAAM,IAAI,EAAE,CAAC;IACf,CAAC,CAAC;AACJ,CAAC,CAAC;AA3BW,QAAA,iBAAiB,qBA2B5B;AAEF,SAAS,mBAAmB,CAAC,WAAmB,EAAE,KAAa;IAC7D,OAAO;;;;;;WAME,KAAK;;;;;;;;;;;;;;;;;;;;;;;;gBAwBA,WAAW;;;;;;;;;;;;;;;;;;;;;;;;;GAyBxB,CAAC;AACJ,CAAC"}
@@ -1,16 +0,0 @@
1
- export interface User {
2
- id: string;
3
- email: string;
4
- name: string;
5
- createdAt: Date;
6
- }
7
- export declare class UserRepository {
8
- private logger;
9
- private users;
10
- findAll(): User[];
11
- findById(id: string): User | undefined;
12
- findByEmail(email: string): User | undefined;
13
- create(userData: Omit<User, 'id' | 'createdAt'>): User;
14
- update(id: string, userData: Partial<Omit<User, 'id' | 'createdAt'>>): User | undefined;
15
- delete(id: string): boolean;
16
- }
@@ -1,110 +0,0 @@
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 __metadata = (this && this.__metadata) || function (k, v) {
9
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
- };
11
- Object.defineProperty(exports, "__esModule", { value: true });
12
- exports.UserRepository = void 0;
13
- const decorators_1 = require("../core/decorators");
14
- const logging_1 = require("../logging");
15
- let UserRepository = class UserRepository {
16
- constructor() {
17
- this.users = [
18
- {
19
- id: '1',
20
- email: 'john@example.com',
21
- name: 'John Doe',
22
- createdAt: new Date('2023-01-01')
23
- },
24
- {
25
- id: '2',
26
- email: 'jane@example.com',
27
- name: 'Jane Smith',
28
- createdAt: new Date('2023-01-02')
29
- }
30
- ];
31
- }
32
- findAll() {
33
- this.logger.debug('Fetching all users', { count: this.users.length });
34
- return this.users;
35
- }
36
- findById(id) {
37
- return this.users.find(user => user.id === id);
38
- }
39
- findByEmail(email) {
40
- return this.users.find(user => user.email === email);
41
- }
42
- create(userData) {
43
- const newUser = {
44
- id: Date.now().toString(),
45
- createdAt: new Date(),
46
- ...userData
47
- };
48
- this.users.push(newUser);
49
- this.logger.debug('User created in repository', { userId: newUser.id });
50
- return newUser;
51
- }
52
- update(id, userData) {
53
- const userIndex = this.users.findIndex(user => user.id === id);
54
- if (userIndex === -1)
55
- return undefined;
56
- this.users[userIndex] = { ...this.users[userIndex], ...userData };
57
- this.logger.debug('User updated in repository', { userId: id });
58
- return this.users[userIndex];
59
- }
60
- delete(id) {
61
- const userIndex = this.users.findIndex(user => user.id === id);
62
- if (userIndex === -1)
63
- return false;
64
- this.users.splice(userIndex, 1);
65
- this.logger.debug('User deleted from repository', { userId: id });
66
- return true;
67
- }
68
- };
69
- exports.UserRepository = UserRepository;
70
- __decorate([
71
- (0, logging_1.Log)({ logDuration: true, level: 'debug' }),
72
- __metadata("design:type", Function),
73
- __metadata("design:paramtypes", []),
74
- __metadata("design:returntype", Array)
75
- ], UserRepository.prototype, "findAll", null);
76
- __decorate([
77
- (0, logging_1.Log)({ logArgs: true, logDuration: true, level: 'debug' }),
78
- __metadata("design:type", Function),
79
- __metadata("design:paramtypes", [String]),
80
- __metadata("design:returntype", Object)
81
- ], UserRepository.prototype, "findById", null);
82
- __decorate([
83
- (0, logging_1.Log)({ logArgs: true, logDuration: true, level: 'debug' }),
84
- __metadata("design:type", Function),
85
- __metadata("design:paramtypes", [String]),
86
- __metadata("design:returntype", Object)
87
- ], UserRepository.prototype, "findByEmail", null);
88
- __decorate([
89
- (0, logging_1.Log)({ logArgs: true, logDuration: true, level: 'debug' }),
90
- __metadata("design:type", Function),
91
- __metadata("design:paramtypes", [Object]),
92
- __metadata("design:returntype", Object)
93
- ], UserRepository.prototype, "create", null);
94
- __decorate([
95
- (0, logging_1.Log)({ logArgs: true, logDuration: true, level: 'debug' }),
96
- __metadata("design:type", Function),
97
- __metadata("design:paramtypes", [String, Object]),
98
- __metadata("design:returntype", Object)
99
- ], UserRepository.prototype, "update", null);
100
- __decorate([
101
- (0, logging_1.Log)({ logArgs: true, logDuration: true, level: 'debug' }),
102
- __metadata("design:type", Function),
103
- __metadata("design:paramtypes", [String]),
104
- __metadata("design:returntype", Boolean)
105
- ], UserRepository.prototype, "delete", null);
106
- exports.UserRepository = UserRepository = __decorate([
107
- (0, decorators_1.Repository)(),
108
- (0, logging_1.Logger)('UserRepository')
109
- ], UserRepository);
110
- //# sourceMappingURL=user.repository.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"user.repository.js","sourceRoot":"","sources":["../../src/repositories/user.repository.ts"],"names":[],"mappings":"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"}