@expressots/core 3.0.0 → 4.0.0-preview.3

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 (1107) hide show
  1. package/LICENSE.md +21 -21
  2. package/README.md +66 -118
  3. package/lib/CHANGELOG.md +774 -739
  4. package/lib/README.md +66 -118
  5. package/lib/cjs/application/application-container.js +467 -33
  6. package/lib/cjs/application/application-factory.js +111 -5
  7. package/lib/cjs/application/application.types.js +32 -2
  8. package/lib/cjs/application/bootstrap.js +716 -0
  9. package/lib/cjs/application/index.js +10 -7
  10. package/lib/cjs/authorization/authorization-config.interface.js +2 -0
  11. package/lib/cjs/authorization/decorators/convenience.js +80 -0
  12. package/lib/cjs/authorization/guard-constants.js +12 -0
  13. package/lib/cjs/authorization/guard-decorators.js +159 -0
  14. package/lib/cjs/authorization/guard-executor.js +101 -0
  15. package/lib/cjs/authorization/guard-registry.js +133 -0
  16. package/lib/cjs/authorization/guard.interface.js +75 -0
  17. package/lib/cjs/authorization/guards/attribute-based.guard.js +109 -0
  18. package/lib/cjs/authorization/guards/authenticated.guard.js +49 -0
  19. package/lib/cjs/authorization/guards/composition.guard.js +67 -0
  20. package/lib/cjs/authorization/guards/conditional.guard.js +41 -0
  21. package/lib/cjs/authorization/guards/index.js +24 -0
  22. package/lib/cjs/authorization/guards/permission.guard.js +82 -0
  23. package/lib/cjs/authorization/guards/resource-owner.guard.js +61 -0
  24. package/lib/cjs/authorization/guards/role.guard.js +64 -0
  25. package/lib/cjs/authorization/index.js +40 -0
  26. package/lib/cjs/authorization/services/guard-cache.interface.js +2 -0
  27. package/lib/cjs/authorization/services/guard-cache.js +56 -0
  28. package/lib/cjs/authorization/services/permission-hierarchy.interface.js +2 -0
  29. package/lib/cjs/authorization/services/permission-hierarchy.js +54 -0
  30. package/lib/cjs/authorization/services/permission-service.interface.js +2 -0
  31. package/lib/cjs/authorization/services/permission-service.js +58 -0
  32. package/lib/cjs/authorization/services/security-context.interface.js +2 -0
  33. package/lib/cjs/authorization/services/security-context.js +75 -0
  34. package/lib/cjs/authorization/setup.js +141 -0
  35. package/lib/cjs/config/config-resolver.js +719 -0
  36. package/lib/cjs/config/config.interfaces.js +14 -0
  37. package/lib/cjs/config/define-config.js +495 -0
  38. package/lib/cjs/config/env-field-builders.js +449 -0
  39. package/lib/cjs/config/index.js +89 -0
  40. package/lib/cjs/config/secret-value.js +201 -0
  41. package/lib/cjs/console/color-codes.js +4 -0
  42. package/lib/cjs/console/console.js +72 -9
  43. package/lib/cjs/console/index.js +2 -2
  44. package/lib/cjs/container-module/container-module.js +257 -26
  45. package/lib/cjs/container-module/index.js +6 -4
  46. package/lib/cjs/decorator/index.js +1 -1
  47. package/lib/cjs/decorator/scope-binding.js +307 -16
  48. package/lib/cjs/di/annotation/decorator_utils.js +4 -4
  49. package/lib/cjs/di/annotation/inject.js +3 -3
  50. package/lib/cjs/di/annotation/inject_base.js +5 -5
  51. package/lib/cjs/di/annotation/injectable.js +2 -2
  52. package/lib/cjs/di/annotation/multi_inject.js +3 -3
  53. package/lib/cjs/di/annotation/named.js +4 -4
  54. package/lib/cjs/di/annotation/optional.js +4 -4
  55. package/lib/cjs/di/annotation/post_construct.js +4 -4
  56. package/lib/cjs/di/annotation/pre_destroy.js +4 -4
  57. package/lib/cjs/di/annotation/property_event_decorator.js +2 -2
  58. package/lib/cjs/di/annotation/tagged.js +3 -3
  59. package/lib/cjs/di/annotation/target_name.js +5 -5
  60. package/lib/cjs/di/annotation/unmanaged.js +5 -5
  61. package/lib/cjs/di/binding-decorator/constants.js +3 -0
  62. package/lib/cjs/di/binding-decorator/decorator/fluent_provide.js +7 -7
  63. package/lib/cjs/di/binding-decorator/decorator/provide.js +7 -7
  64. package/lib/cjs/di/binding-decorator/factory/module_factory.js +23 -4
  65. package/lib/cjs/di/binding-decorator/index.js +11 -9
  66. package/lib/cjs/di/binding-decorator/syntax/provide_done_syntax.js +7 -7
  67. package/lib/cjs/di/binding-decorator/syntax/provide_in_syntax.js +19 -12
  68. package/lib/cjs/di/binding-decorator/syntax/provide_in_when_on_syntax.js +3 -0
  69. package/lib/cjs/di/binding-decorator/syntax/provide_on_syntax.js +4 -4
  70. package/lib/cjs/di/binding-decorator/syntax/provide_when_syntax.js +30 -30
  71. package/lib/cjs/di/binding-decorator/utils/auto_wire.js +4 -4
  72. package/lib/cjs/di/bindings/binding.js +5 -6
  73. package/lib/cjs/di/constants/error_msgs.js +6 -2
  74. package/lib/cjs/di/constants/literal_types.js +3 -3
  75. package/lib/cjs/di/container/container.js +44 -44
  76. package/lib/cjs/di/container/container_module.js +3 -3
  77. package/lib/cjs/di/container/lookup.js +3 -3
  78. package/lib/cjs/di/container/module_activation_store.js +3 -3
  79. package/lib/cjs/di/container-introspection.js +42 -0
  80. package/lib/cjs/di/inversify.js +85 -52
  81. package/lib/cjs/di/planning/context.js +2 -2
  82. package/lib/cjs/di/planning/metadata.js +1 -1
  83. package/lib/cjs/di/planning/metadata_reader.js +1 -1
  84. package/lib/cjs/di/planning/planner.js +37 -37
  85. package/lib/cjs/di/planning/reflection_utils.js +12 -12
  86. package/lib/cjs/di/planning/request.js +2 -2
  87. package/lib/cjs/di/planning/target.js +10 -10
  88. package/lib/cjs/di/resolution/instantiation.js +13 -13
  89. package/lib/cjs/di/resolution/resolver.js +22 -22
  90. package/lib/cjs/di/scope/scope-registry.js +115 -0
  91. package/lib/cjs/di/scope/scope.js +38 -8
  92. package/lib/cjs/di/syntax/binding_in_syntax.js +18 -8
  93. package/lib/cjs/di/syntax/binding_in_when_on_syntax.js +9 -6
  94. package/lib/cjs/di/syntax/binding_on_syntax.js +3 -3
  95. package/lib/cjs/di/syntax/binding_to_syntax.js +27 -27
  96. package/lib/cjs/di/syntax/binding_when_on_syntax.js +4 -4
  97. package/lib/cjs/di/syntax/binding_when_syntax.js +30 -30
  98. package/lib/cjs/di/syntax/constraint_helpers.js +3 -3
  99. package/lib/cjs/di/utils/binding_utils.js +18 -18
  100. package/lib/cjs/di/utils/exceptions.js +1 -1
  101. package/lib/cjs/di/utils/serialization.js +1 -1
  102. package/lib/cjs/error/app-error.js +152 -8
  103. package/lib/cjs/error/base-exception-filter.js +135 -0
  104. package/lib/cjs/error/error-handler-middleware.js +7 -7
  105. package/lib/cjs/error/exception-filter-constants.js +12 -0
  106. package/lib/cjs/error/exception-filter-decorators.js +161 -0
  107. package/lib/cjs/error/exception-filter-registry.js +163 -0
  108. package/lib/cjs/error/exception-filter.interface.js +2 -0
  109. package/lib/cjs/error/exception-handler-middleware.js +378 -0
  110. package/lib/cjs/error/filters/app-error.filter.js +31 -0
  111. package/lib/cjs/error/filters/global-exception.filter.js +39 -0
  112. package/lib/cjs/error/filters/not-found.filter.js +35 -0
  113. package/lib/cjs/error/filters/validation-error.filter.js +35 -0
  114. package/lib/cjs/error/index.js +28 -7
  115. package/lib/cjs/error/not-found.error.js +17 -0
  116. package/lib/cjs/error/report.js +104 -9
  117. package/lib/cjs/error/status-code.js +20 -0
  118. package/lib/cjs/error/utils.js +247 -33
  119. package/lib/cjs/error/validation.error.js +18 -0
  120. package/lib/cjs/event/event-decorators.js +280 -0
  121. package/lib/cjs/event/event-emitter.js +373 -0
  122. package/lib/cjs/event/event-flow-tracker.js +236 -0
  123. package/lib/cjs/event/event-recorder.js +289 -0
  124. package/lib/cjs/event/event-registry.js +207 -0
  125. package/lib/cjs/event/event.interfaces.js +54 -0
  126. package/lib/cjs/event/index.js +80 -0
  127. package/lib/cjs/framework-version.js +10 -0
  128. package/lib/cjs/index.js +29 -8
  129. package/lib/cjs/interceptor/conditional-interceptor.js +108 -0
  130. package/lib/cjs/interceptor/execution-context.js +66 -0
  131. package/lib/cjs/interceptor/index.js +64 -0
  132. package/lib/cjs/interceptor/interceptor-composition.js +130 -0
  133. package/lib/cjs/interceptor/interceptor-constants.js +20 -0
  134. package/lib/cjs/interceptor/interceptor-decorators.js +155 -0
  135. package/lib/cjs/interceptor/interceptor-executor.js +140 -0
  136. package/lib/cjs/interceptor/interceptor-registry.js +159 -0
  137. package/lib/cjs/interceptor/interceptor.interface.js +20 -0
  138. package/lib/cjs/interceptor/interceptors/index.js +22 -0
  139. package/lib/cjs/interceptor/interceptors/logging.interceptor.js +70 -0
  140. package/lib/cjs/interceptor/interceptors/performance.interceptor.js +251 -0
  141. package/lib/cjs/interceptor/interceptors/timeout.interceptor.js +66 -0
  142. package/lib/cjs/lazy-loading/index.js +77 -0
  143. package/lib/cjs/lazy-loading/lazy-load-metrics.js +355 -0
  144. package/lib/cjs/lazy-loading/lazy-module-helpers.js +49 -0
  145. package/lib/cjs/lazy-loading/lazy-module-loader.js +311 -0
  146. package/lib/cjs/lazy-loading/lazy-module-manager.js +244 -0
  147. package/lib/cjs/lazy-loading/lazy-module-warmup.js +294 -0
  148. package/lib/cjs/lazy-loading/lazy-module.js +380 -0
  149. package/lib/cjs/lazy-loading/lazy.interfaces.js +18 -0
  150. package/lib/cjs/lifecycle/index.js +15 -0
  151. package/lib/cjs/lifecycle/lifecycle-registry.js +301 -0
  152. package/lib/cjs/lifecycle/lifecycle.interface.js +37 -0
  153. package/lib/cjs/middleware/content-negotiation/accept-header-parser.js +110 -0
  154. package/lib/cjs/middleware/content-negotiation/content-negotiation-service.js +288 -0
  155. package/lib/cjs/middleware/content-negotiation/formatter-registry.js +168 -0
  156. package/lib/cjs/middleware/content-negotiation/formatters/csv-formatter.js +114 -0
  157. package/lib/cjs/middleware/content-negotiation/formatters/index.js +16 -0
  158. package/lib/cjs/middleware/content-negotiation/formatters/json-formatter.js +34 -0
  159. package/lib/cjs/middleware/content-negotiation/formatters/plain-text-formatter.js +44 -0
  160. package/lib/cjs/middleware/content-negotiation/formatters/xml-formatter.js +124 -0
  161. package/lib/cjs/middleware/content-negotiation/formatters/yaml-formatter.js +134 -0
  162. package/lib/cjs/middleware/content-negotiation/index.js +27 -0
  163. package/lib/cjs/middleware/index.js +58 -30
  164. package/lib/cjs/middleware/interfaces/content-negotiation.interface.js +7 -0
  165. package/lib/cjs/middleware/middleware-config.js +10 -0
  166. package/lib/cjs/middleware/middleware-profiler.js +310 -0
  167. package/lib/cjs/middleware/middleware-registry.js +160 -0
  168. package/lib/cjs/middleware/middleware-resolver.js +318 -57
  169. package/lib/cjs/middleware/middleware-service.js +1692 -308
  170. package/lib/cjs/middleware/middleware-utils.js +280 -0
  171. package/lib/cjs/middleware/presets-standalone.js +93 -0
  172. package/lib/cjs/middleware/upload-registry.js +91 -0
  173. package/lib/cjs/path-resolver/index.js +252 -0
  174. package/lib/cjs/provider/db-in-memory/adapter/adapter.interface.js +10 -0
  175. package/lib/cjs/provider/db-in-memory/adapter/in-memory.adapter.js +688 -0
  176. package/lib/cjs/provider/db-in-memory/adapter/index.js +10 -0
  177. package/lib/cjs/provider/db-in-memory/base-repo.repository.js +4 -4
  178. package/lib/cjs/provider/db-in-memory/db-in-memory.provider.js +14 -18
  179. package/lib/cjs/provider/db-in-memory/db.provider.js +402 -0
  180. package/lib/cjs/provider/db-in-memory/index.js +125 -9
  181. package/lib/cjs/provider/db-in-memory/query/index.js +24 -0
  182. package/lib/cjs/provider/db-in-memory/query/query-engine.js +601 -0
  183. package/lib/cjs/provider/db-in-memory/query/query.types.js +10 -0
  184. package/lib/cjs/provider/db-in-memory/schema/decorators.js +420 -0
  185. package/lib/cjs/provider/db-in-memory/schema/entity.interface.js +9 -0
  186. package/lib/cjs/provider/db-in-memory/schema/index.js +21 -0
  187. package/lib/cjs/provider/db-in-memory/storage/index.js +16 -0
  188. package/lib/cjs/provider/db-in-memory/storage/memory-store.js +777 -0
  189. package/lib/cjs/provider/dto-validator/dto-validator.provider.js +8 -8
  190. package/lib/cjs/provider/dto-validator/package-resolver.js +2 -2
  191. package/lib/cjs/provider/index.js +14 -10
  192. package/lib/cjs/provider/logger/decorators/index.js +17 -0
  193. package/lib/cjs/provider/logger/decorators/log-performance.decorator.js +178 -0
  194. package/lib/cjs/provider/logger/index.js +35 -0
  195. package/lib/cjs/provider/logger/logger.banner.js +482 -0
  196. package/lib/cjs/provider/logger/logger.config.js +32 -0
  197. package/lib/cjs/provider/logger/logger.context.js +341 -0
  198. package/lib/cjs/provider/logger/logger.flow.js +255 -0
  199. package/lib/cjs/provider/logger/logger.formatter.js +697 -0
  200. package/lib/cjs/provider/logger/logger.grouping.js +319 -0
  201. package/lib/cjs/provider/logger/logger.health.js +295 -0
  202. package/lib/cjs/provider/logger/logger.metrics-collector.js +184 -0
  203. package/lib/cjs/provider/logger/logger.metrics.js +91 -0
  204. package/lib/cjs/provider/logger/logger.performance.js +300 -0
  205. package/lib/cjs/provider/logger/logger.provider.js +746 -73
  206. package/lib/cjs/provider/logger/logger.query.js +532 -0
  207. package/lib/cjs/provider/logger/logger.redaction.js +456 -0
  208. package/lib/cjs/provider/logger/logger.suggestions.js +480 -0
  209. package/lib/cjs/provider/logger/transports/console.transport.js +141 -0
  210. package/lib/cjs/provider/logger/transports/file.transport.js +296 -0
  211. package/lib/cjs/provider/logger/transports/http-server.js +141 -0
  212. package/lib/cjs/provider/logger/transports/http.transport.js +151 -0
  213. package/lib/cjs/provider/logger/transports/index.js +21 -0
  214. package/lib/cjs/provider/logger/transports/transport.interface.js +2 -0
  215. package/lib/cjs/provider/logger/utils/index.js +18 -0
  216. package/lib/cjs/provider/logger/utils/log-entry.js +26 -0
  217. package/lib/cjs/provider/logger/utils/log-levels.js +107 -0
  218. package/lib/cjs/provider/provider-manager.js +209 -16
  219. package/lib/cjs/provider/provider-registry.js +414 -0
  220. package/lib/cjs/provider/provider.interface.js +49 -0
  221. package/lib/cjs/provider/validation/adapters/class-validator.adapter.js +264 -0
  222. package/lib/cjs/provider/validation/adapters/index.js +21 -0
  223. package/lib/cjs/provider/validation/adapters/yup.adapter.js +118 -0
  224. package/lib/cjs/provider/validation/adapters/zod.adapter.js +137 -0
  225. package/lib/cjs/provider/validation/helpful-error-formatter.js +228 -0
  226. package/lib/cjs/provider/validation/index.js +39 -0
  227. package/lib/cjs/provider/validation/smart-field-detector.js +543 -0
  228. package/lib/cjs/provider/validation/type-inference.js +192 -0
  229. package/lib/cjs/provider/validation/validation-registry.js +220 -0
  230. package/lib/cjs/provider/validation/validation.interface.js +9 -0
  231. package/lib/cjs/render/adapters/base-adapter.js +134 -0
  232. package/lib/cjs/render/adapters/ejs-adapter.js +172 -0
  233. package/lib/cjs/render/adapters/handlebars-adapter.js +191 -0
  234. package/lib/cjs/render/adapters/index.js +20 -0
  235. package/lib/cjs/render/adapters/pug-adapter.js +164 -0
  236. package/lib/cjs/render/adapters/react-adapter.js +336 -0
  237. package/lib/cjs/render/features/auto-detection.js +228 -0
  238. package/lib/cjs/render/features/hot-reload.js +155 -0
  239. package/lib/cjs/render/features/index.js +20 -0
  240. package/lib/cjs/render/features/streaming.js +106 -0
  241. package/lib/cjs/render/features/type-generator.js +221 -0
  242. package/lib/cjs/render/features/view-debugger.js +194 -0
  243. package/lib/cjs/render/index.js +80 -0
  244. package/lib/cjs/render/presets/index.js +216 -0
  245. package/lib/cjs/render/render-config.js +10 -0
  246. package/lib/cjs/render/render-interface.js +2 -0
  247. package/lib/cjs/render/render-registry.js +130 -0
  248. package/lib/cjs/render/render-service.js +418 -0
  249. package/lib/cjs/render/utils/cache-manager.js +199 -0
  250. package/lib/cjs/render/utils/index.js +20 -0
  251. package/lib/cjs/render/utils/package-resolver.js +121 -0
  252. package/lib/cjs/render/utils/view-scanner.js +208 -0
  253. package/lib/cjs/testing/create-test-app.js +366 -0
  254. package/lib/cjs/testing/create-test-database.js +416 -0
  255. package/lib/cjs/testing/fluent-request.js +461 -0
  256. package/lib/cjs/testing/index.js +142 -0
  257. package/lib/cjs/testing/load-test.js +484 -0
  258. package/lib/cjs/testing/matchers.js +444 -0
  259. package/lib/cjs/testing/mock-context.js +406 -0
  260. package/lib/cjs/testing/mock-provider.js +339 -0
  261. package/lib/cjs/testing/snapshot-request.js +380 -0
  262. package/lib/cjs/testing/testing.interfaces.js +10 -0
  263. package/lib/cjs/types/application/application-container.d.ts +320 -20
  264. package/lib/cjs/types/application/application-factory.d.ts +105 -3
  265. package/lib/cjs/types/application/application.types.d.ts +177 -2
  266. package/lib/cjs/types/application/bootstrap.d.ts +656 -0
  267. package/lib/cjs/types/application/index.d.ts +4 -3
  268. package/lib/cjs/types/authorization/authorization-config.interface.d.ts +45 -0
  269. package/lib/cjs/types/authorization/decorators/convenience.d.ts +64 -0
  270. package/lib/cjs/types/authorization/guard-constants.d.ts +9 -0
  271. package/lib/cjs/types/authorization/guard-decorators.d.ts +128 -0
  272. package/lib/cjs/types/authorization/guard-executor.d.ts +26 -0
  273. package/lib/cjs/types/authorization/guard-registry.d.ts +35 -0
  274. package/lib/cjs/types/authorization/guard.interface.d.ts +335 -0
  275. package/lib/cjs/types/authorization/guards/attribute-based.guard.d.ts +60 -0
  276. package/lib/cjs/types/authorization/guards/authenticated.guard.d.ts +26 -0
  277. package/lib/cjs/types/authorization/guards/composition.guard.d.ts +42 -0
  278. package/lib/cjs/types/authorization/guards/conditional.guard.d.ts +21 -0
  279. package/lib/cjs/types/authorization/guards/index.d.ts +7 -0
  280. package/lib/cjs/types/authorization/guards/permission.guard.d.ts +29 -0
  281. package/lib/cjs/types/authorization/guards/resource-owner.guard.d.ts +29 -0
  282. package/lib/cjs/types/authorization/guards/role.guard.d.ts +28 -0
  283. package/lib/cjs/types/authorization/index.d.ts +18 -0
  284. package/lib/cjs/types/authorization/services/guard-cache.d.ts +26 -0
  285. package/lib/cjs/types/authorization/services/guard-cache.interface.d.ts +29 -0
  286. package/lib/cjs/types/authorization/services/permission-hierarchy.d.ts +21 -0
  287. package/lib/cjs/types/authorization/services/permission-hierarchy.interface.d.ts +22 -0
  288. package/lib/cjs/types/authorization/services/permission-service.d.ts +21 -0
  289. package/lib/cjs/types/authorization/services/permission-service.interface.d.ts +19 -0
  290. package/lib/cjs/types/authorization/services/security-context.d.ts +32 -0
  291. package/lib/cjs/types/authorization/services/security-context.interface.d.ts +25 -0
  292. package/lib/cjs/types/authorization/setup.d.ts +84 -0
  293. package/lib/cjs/types/config/config-resolver.d.ts +40 -0
  294. package/lib/cjs/types/config/config.interfaces.d.ts +576 -0
  295. package/lib/cjs/types/config/define-config.d.ts +109 -0
  296. package/lib/cjs/types/config/env-field-builders.d.ts +327 -0
  297. package/lib/cjs/types/config/index.d.ts +61 -0
  298. package/lib/cjs/types/config/secret-value.d.ts +99 -0
  299. package/lib/cjs/types/console/color-codes.d.ts +1 -1
  300. package/lib/cjs/types/console/console.d.ts +65 -2
  301. package/lib/cjs/types/console/index.d.ts +1 -1
  302. package/lib/cjs/types/container-module/container-module.d.ts +215 -8
  303. package/lib/cjs/types/container-module/index.d.ts +1 -1
  304. package/lib/cjs/types/decorator/index.d.ts +1 -1
  305. package/lib/cjs/types/decorator/scope-binding.d.ts +339 -11
  306. package/lib/cjs/types/di/annotation/decorator_utils.d.ts +1 -1
  307. package/lib/cjs/types/di/annotation/inject.d.ts +1 -1
  308. package/lib/cjs/types/di/annotation/inject_base.d.ts +2 -2
  309. package/lib/cjs/types/di/annotation/lazy_service_identifier.d.ts +1 -1
  310. package/lib/cjs/types/di/annotation/multi_inject.d.ts +1 -1
  311. package/lib/cjs/types/di/annotation/named.d.ts +1 -1
  312. package/lib/cjs/types/di/annotation/target_name.d.ts +1 -1
  313. package/lib/cjs/types/di/annotation/unmanaged.d.ts +1 -1
  314. package/lib/cjs/types/di/binding-decorator/constants.d.ts +3 -0
  315. package/lib/cjs/types/di/binding-decorator/decorator/fluent_provide.d.ts +2 -2
  316. package/lib/cjs/types/di/binding-decorator/decorator/provide.d.ts +1 -1
  317. package/lib/cjs/types/di/binding-decorator/factory/module_factory.d.ts +20 -1
  318. package/lib/cjs/types/di/binding-decorator/index.d.ts +6 -4
  319. package/lib/cjs/types/di/binding-decorator/interfaces/interfaces.d.ts +2 -1
  320. package/lib/cjs/types/di/binding-decorator/syntax/provide_done_syntax.d.ts +1 -1
  321. package/lib/cjs/types/di/binding-decorator/syntax/provide_in_syntax.d.ts +3 -2
  322. package/lib/cjs/types/di/binding-decorator/syntax/provide_in_when_on_syntax.d.ts +3 -2
  323. package/lib/cjs/types/di/binding-decorator/syntax/provide_on_syntax.d.ts +2 -2
  324. package/lib/cjs/types/di/binding-decorator/syntax/provide_when_on_syntax.d.ts +2 -2
  325. package/lib/cjs/types/di/binding-decorator/syntax/provide_when_syntax.d.ts +2 -2
  326. package/lib/cjs/types/di/binding-decorator/utils/auto_wire.d.ts +1 -1
  327. package/lib/cjs/types/di/bindings/binding.d.ts +1 -1
  328. package/lib/cjs/types/di/constants/literal_types.d.ts +3 -3
  329. package/lib/cjs/types/di/container/container.d.ts +1 -1
  330. package/lib/cjs/types/di/container/container_module.d.ts +1 -1
  331. package/lib/cjs/types/di/container/container_snapshot.d.ts +1 -1
  332. package/lib/cjs/types/di/container/lookup.d.ts +1 -1
  333. package/lib/cjs/types/di/container/module_activation_store.d.ts +1 -1
  334. package/lib/cjs/types/di/container-introspection.d.ts +25 -0
  335. package/lib/cjs/types/di/interfaces/interfaces.d.ts +4 -3
  336. package/lib/cjs/types/di/inversify.d.ts +53 -24
  337. package/lib/cjs/types/di/planning/context.d.ts +1 -1
  338. package/lib/cjs/types/di/planning/metadata.d.ts +1 -1
  339. package/lib/cjs/types/di/planning/metadata_reader.d.ts +1 -1
  340. package/lib/cjs/types/di/planning/plan.d.ts +1 -1
  341. package/lib/cjs/types/di/planning/planner.d.ts +1 -1
  342. package/lib/cjs/types/di/planning/queryable_string.d.ts +1 -1
  343. package/lib/cjs/types/di/planning/reflection_utils.d.ts +2 -2
  344. package/lib/cjs/types/di/planning/request.d.ts +1 -1
  345. package/lib/cjs/types/di/planning/target.d.ts +2 -2
  346. package/lib/cjs/types/di/resolution/instantiation.d.ts +1 -1
  347. package/lib/cjs/types/di/resolution/resolver.d.ts +1 -1
  348. package/lib/cjs/types/di/scope/scope-registry.d.ts +91 -0
  349. package/lib/cjs/types/di/scope/scope.d.ts +1 -1
  350. package/lib/cjs/types/di/syntax/binding_in_syntax.d.ts +2 -1
  351. package/lib/cjs/types/di/syntax/binding_in_when_on_syntax.d.ts +2 -1
  352. package/lib/cjs/types/di/syntax/binding_on_syntax.d.ts +1 -1
  353. package/lib/cjs/types/di/syntax/binding_to_syntax.d.ts +2 -2
  354. package/lib/cjs/types/di/syntax/binding_when_on_syntax.d.ts +1 -1
  355. package/lib/cjs/types/di/syntax/binding_when_syntax.d.ts +1 -1
  356. package/lib/cjs/types/di/syntax/constraint_helpers.d.ts +1 -1
  357. package/lib/cjs/types/di/utils/binding_utils.d.ts +1 -1
  358. package/lib/cjs/types/di/utils/clonable.d.ts +1 -1
  359. package/lib/cjs/types/di/utils/serialization.d.ts +1 -1
  360. package/lib/cjs/types/error/app-error.d.ts +155 -7
  361. package/lib/cjs/types/error/base-exception-filter.d.ts +73 -0
  362. package/lib/cjs/types/error/exception-filter-constants.d.ts +9 -0
  363. package/lib/cjs/types/error/exception-filter-decorators.d.ts +126 -0
  364. package/lib/cjs/types/error/exception-filter-registry.d.ts +38 -0
  365. package/lib/cjs/types/error/exception-filter.interface.d.ts +82 -0
  366. package/lib/cjs/types/error/exception-handler-middleware.d.ts +35 -0
  367. package/lib/cjs/types/error/filters/app-error.filter.d.ts +10 -0
  368. package/lib/cjs/types/error/filters/global-exception.filter.d.ts +9 -0
  369. package/lib/cjs/types/error/filters/not-found.filter.d.ts +10 -0
  370. package/lib/cjs/types/error/filters/validation-error.filter.d.ts +10 -0
  371. package/lib/cjs/types/error/index.d.ts +14 -3
  372. package/lib/cjs/types/error/not-found.error.d.ts +7 -0
  373. package/lib/cjs/types/error/report.d.ts +84 -6
  374. package/lib/cjs/types/error/status-code.d.ts +20 -0
  375. package/lib/cjs/types/error/utils.d.ts +16 -0
  376. package/lib/cjs/types/error/validation.error.d.ts +8 -0
  377. package/lib/cjs/types/event/event-decorators.d.ts +199 -0
  378. package/lib/cjs/types/event/event-emitter.d.ts +109 -0
  379. package/lib/cjs/types/event/event-flow-tracker.d.ts +88 -0
  380. package/lib/cjs/types/event/event-recorder.d.ts +121 -0
  381. package/lib/cjs/types/event/event-registry.d.ts +84 -0
  382. package/lib/cjs/types/event/event.interfaces.d.ts +528 -0
  383. package/lib/cjs/types/event/index.d.ts +55 -0
  384. package/lib/cjs/types/framework-version.d.ts +7 -0
  385. package/lib/cjs/types/index.d.ts +27 -8
  386. package/lib/cjs/types/interceptor/conditional-interceptor.d.ts +91 -0
  387. package/lib/cjs/types/interceptor/execution-context.d.ts +41 -0
  388. package/lib/cjs/types/interceptor/index.d.ts +41 -0
  389. package/lib/cjs/types/interceptor/interceptor-composition.d.ts +115 -0
  390. package/lib/cjs/types/interceptor/interceptor-constants.d.ts +17 -0
  391. package/lib/cjs/types/interceptor/interceptor-decorators.d.ts +124 -0
  392. package/lib/cjs/types/interceptor/interceptor-executor.d.ts +46 -0
  393. package/lib/cjs/types/interceptor/interceptor-registry.d.ts +65 -0
  394. package/lib/cjs/types/interceptor/interceptor.interface.d.ts +281 -0
  395. package/lib/cjs/types/interceptor/interceptors/index.d.ts +6 -0
  396. package/lib/cjs/types/interceptor/interceptors/logging.interceptor.d.ts +28 -0
  397. package/lib/cjs/types/interceptor/interceptors/performance.interceptor.d.ts +197 -0
  398. package/lib/cjs/types/interceptor/interceptors/timeout.interceptor.d.ts +42 -0
  399. package/lib/cjs/types/lazy-loading/index.d.ts +43 -0
  400. package/lib/cjs/types/lazy-loading/lazy-load-metrics.d.ts +139 -0
  401. package/lib/cjs/types/lazy-loading/lazy-module-helpers.d.ts +42 -0
  402. package/lib/cjs/types/lazy-loading/lazy-module-loader.d.ts +169 -0
  403. package/lib/cjs/types/lazy-loading/lazy-module-manager.d.ts +148 -0
  404. package/lib/cjs/types/lazy-loading/lazy-module-warmup.d.ts +130 -0
  405. package/lib/cjs/types/lazy-loading/lazy-module.d.ts +168 -0
  406. package/lib/cjs/types/lazy-loading/lazy.interfaces.d.ts +480 -0
  407. package/lib/cjs/types/lifecycle/index.d.ts +9 -0
  408. package/lib/cjs/types/lifecycle/lifecycle-registry.d.ts +213 -0
  409. package/lib/cjs/types/lifecycle/lifecycle.interface.d.ts +191 -0
  410. package/lib/cjs/types/middleware/content-negotiation/accept-header-parser.d.ts +26 -0
  411. package/lib/cjs/types/middleware/content-negotiation/content-negotiation-service.d.ts +64 -0
  412. package/lib/cjs/types/middleware/content-negotiation/formatter-registry.d.ts +60 -0
  413. package/lib/cjs/types/middleware/content-negotiation/formatters/csv-formatter.d.ts +34 -0
  414. package/lib/cjs/types/middleware/content-negotiation/formatters/index.d.ts +8 -0
  415. package/lib/cjs/types/middleware/content-negotiation/formatters/json-formatter.d.ts +14 -0
  416. package/lib/cjs/types/middleware/content-negotiation/formatters/plain-text-formatter.d.ts +12 -0
  417. package/lib/cjs/types/middleware/content-negotiation/formatters/xml-formatter.d.ts +26 -0
  418. package/lib/cjs/types/middleware/content-negotiation/formatters/yaml-formatter.d.ts +26 -0
  419. package/lib/cjs/types/middleware/content-negotiation/index.d.ts +7 -0
  420. package/lib/cjs/types/middleware/index.d.ts +25 -15
  421. package/lib/cjs/types/middleware/interfaces/content-negotiation.interface.d.ts +142 -0
  422. package/lib/cjs/types/middleware/interfaces/cookie-session/cookie-session.interface.d.ts +1 -1
  423. package/lib/cjs/types/middleware/middleware-config.d.ts +574 -0
  424. package/lib/cjs/types/middleware/middleware-interface.d.ts +594 -88
  425. package/lib/cjs/types/middleware/middleware-profiler.d.ts +199 -0
  426. package/lib/cjs/types/middleware/middleware-registry.d.ts +103 -0
  427. package/lib/cjs/types/middleware/middleware-resolver.d.ts +156 -8
  428. package/lib/cjs/types/middleware/middleware-service.d.ts +654 -111
  429. package/lib/cjs/types/middleware/middleware-utils.d.ts +145 -0
  430. package/lib/cjs/types/middleware/presets-standalone.d.ts +75 -0
  431. package/lib/cjs/types/middleware/upload-registry.d.ts +50 -0
  432. package/lib/cjs/types/path-resolver/index.d.ts +80 -0
  433. package/lib/cjs/types/provider/db-in-memory/adapter/adapter.interface.d.ts +222 -0
  434. package/lib/cjs/types/provider/db-in-memory/adapter/in-memory.adapter.d.ts +241 -0
  435. package/lib/cjs/types/provider/db-in-memory/adapter/index.d.ts +6 -0
  436. package/lib/cjs/types/provider/db-in-memory/base-repo.repository.d.ts +1 -1
  437. package/lib/cjs/types/provider/db-in-memory/db-in-memory.interface.d.ts +1 -1
  438. package/lib/cjs/types/provider/db-in-memory/db-in-memory.provider.d.ts +8 -2
  439. package/lib/cjs/types/provider/db-in-memory/db.provider.d.ts +281 -0
  440. package/lib/cjs/types/provider/db-in-memory/index.d.ts +71 -4
  441. package/lib/cjs/types/provider/db-in-memory/query/index.d.ts +6 -0
  442. package/lib/cjs/types/provider/db-in-memory/query/query-engine.d.ts +114 -0
  443. package/lib/cjs/types/provider/db-in-memory/query/query.types.d.ts +318 -0
  444. package/lib/cjs/types/provider/db-in-memory/schema/decorators.d.ts +328 -0
  445. package/lib/cjs/types/provider/db-in-memory/schema/entity.interface.d.ts +60 -0
  446. package/lib/cjs/types/provider/db-in-memory/schema/index.d.ts +6 -0
  447. package/lib/cjs/types/provider/db-in-memory/storage/index.d.ts +5 -0
  448. package/lib/cjs/types/provider/db-in-memory/storage/memory-store.d.ts +360 -0
  449. package/lib/cjs/types/provider/index.d.ts +7 -5
  450. package/lib/cjs/types/provider/logger/decorators/index.d.ts +1 -0
  451. package/lib/cjs/types/provider/logger/decorators/log-performance.decorator.d.ts +49 -0
  452. package/lib/cjs/types/provider/logger/index.d.ts +17 -0
  453. package/lib/cjs/types/provider/logger/logger.banner.d.ts +94 -0
  454. package/lib/cjs/types/provider/logger/logger.config.d.ts +62 -0
  455. package/lib/cjs/types/provider/logger/logger.context.d.ts +189 -0
  456. package/lib/cjs/types/provider/logger/logger.flow.d.ts +165 -0
  457. package/lib/cjs/types/provider/logger/logger.formatter.d.ts +54 -0
  458. package/lib/cjs/types/provider/logger/logger.grouping.d.ts +124 -0
  459. package/lib/cjs/types/provider/logger/logger.health.d.ts +123 -0
  460. package/lib/cjs/types/provider/logger/logger.metrics-collector.d.ts +44 -0
  461. package/lib/cjs/types/provider/logger/logger.metrics.d.ts +162 -0
  462. package/lib/cjs/types/provider/logger/logger.performance.d.ts +179 -0
  463. package/lib/cjs/types/provider/logger/logger.provider.d.ts +332 -28
  464. package/lib/cjs/types/provider/logger/logger.query.d.ts +232 -0
  465. package/lib/cjs/types/provider/logger/logger.redaction.d.ts +169 -0
  466. package/lib/cjs/types/provider/logger/logger.suggestions.d.ts +124 -0
  467. package/lib/cjs/types/provider/logger/transports/console.transport.d.ts +56 -0
  468. package/lib/cjs/types/provider/logger/transports/file.transport.d.ts +87 -0
  469. package/lib/cjs/types/provider/logger/transports/http-server.d.ts +88 -0
  470. package/lib/cjs/types/provider/logger/transports/http.transport.d.ts +74 -0
  471. package/lib/cjs/types/provider/logger/transports/index.d.ts +5 -0
  472. package/lib/cjs/types/provider/logger/transports/transport.interface.d.ts +31 -0
  473. package/lib/cjs/types/provider/logger/utils/index.d.ts +2 -0
  474. package/lib/cjs/types/provider/logger/utils/log-entry.d.ts +82 -0
  475. package/lib/cjs/types/provider/logger/utils/log-levels.d.ts +53 -0
  476. package/lib/cjs/types/provider/provider-manager.d.ts +165 -13
  477. package/lib/cjs/types/provider/provider-registry.d.ts +192 -0
  478. package/lib/cjs/types/provider/provider.interface.d.ts +337 -0
  479. package/lib/cjs/types/provider/validation/adapters/class-validator.adapter.d.ts +68 -0
  480. package/lib/cjs/types/provider/validation/adapters/index.d.ts +13 -0
  481. package/lib/cjs/types/provider/validation/adapters/yup.adapter.d.ts +65 -0
  482. package/lib/cjs/types/provider/validation/adapters/zod.adapter.d.ts +84 -0
  483. package/lib/cjs/types/provider/validation/helpful-error-formatter.d.ts +110 -0
  484. package/lib/cjs/types/provider/validation/index.d.ts +19 -0
  485. package/lib/cjs/types/provider/validation/smart-field-detector.d.ts +91 -0
  486. package/lib/cjs/types/provider/validation/type-inference.d.ts +81 -0
  487. package/lib/cjs/types/provider/validation/validation-registry.d.ts +105 -0
  488. package/lib/cjs/types/provider/validation/validation.interface.d.ts +178 -0
  489. package/lib/cjs/types/render/adapters/base-adapter.d.ts +95 -0
  490. package/lib/cjs/types/render/adapters/ejs-adapter.d.ts +57 -0
  491. package/lib/cjs/types/render/adapters/handlebars-adapter.d.ts +74 -0
  492. package/lib/cjs/types/render/adapters/index.d.ts +12 -0
  493. package/lib/cjs/types/render/adapters/pug-adapter.d.ts +57 -0
  494. package/lib/cjs/types/render/adapters/react-adapter.d.ts +99 -0
  495. package/lib/cjs/types/render/features/auto-detection.d.ts +58 -0
  496. package/lib/cjs/types/render/features/hot-reload.d.ts +65 -0
  497. package/lib/cjs/types/render/features/index.d.ts +12 -0
  498. package/lib/cjs/types/render/features/streaming.d.ts +39 -0
  499. package/lib/cjs/types/render/features/type-generator.d.ts +64 -0
  500. package/lib/cjs/types/render/features/view-debugger.d.ts +52 -0
  501. package/lib/cjs/types/render/index.d.ts +50 -0
  502. package/lib/cjs/types/render/presets/index.d.ts +119 -0
  503. package/lib/cjs/types/render/render-config.d.ts +213 -0
  504. package/lib/cjs/types/render/render-interface.d.ts +126 -0
  505. package/lib/cjs/types/render/render-registry.d.ts +86 -0
  506. package/lib/cjs/types/render/render-service.d.ts +157 -0
  507. package/lib/cjs/types/render/utils/cache-manager.d.ts +106 -0
  508. package/lib/cjs/types/render/utils/index.d.ts +11 -0
  509. package/lib/cjs/types/render/utils/package-resolver.d.ts +57 -0
  510. package/lib/cjs/types/render/utils/view-scanner.d.ts +74 -0
  511. package/lib/cjs/types/testing/create-test-app.d.ts +71 -0
  512. package/lib/cjs/types/testing/create-test-database.d.ts +100 -0
  513. package/lib/cjs/types/testing/fluent-request.d.ts +37 -0
  514. package/lib/cjs/types/testing/index.d.ts +93 -0
  515. package/lib/cjs/types/testing/load-test.d.ts +139 -0
  516. package/lib/cjs/types/testing/matchers.d.ts +184 -0
  517. package/lib/cjs/types/testing/mock-context.d.ts +117 -0
  518. package/lib/cjs/types/testing/mock-provider.d.ts +93 -0
  519. package/lib/cjs/types/testing/snapshot-request.d.ts +46 -0
  520. package/lib/cjs/types/testing/testing.interfaces.d.ts +973 -0
  521. package/lib/cjs/types/utils/node-require.d.ts +11 -0
  522. package/lib/cjs/utils/node-require.js +59 -0
  523. package/lib/esm/application/application-container.js +526 -0
  524. package/lib/esm/application/application-factory.js +140 -0
  525. package/lib/esm/application/application.types.js +41 -0
  526. package/lib/esm/application/bootstrap.js +709 -0
  527. package/lib/esm/application/index.js +4 -0
  528. package/lib/esm/authorization/authorization-config.interface.js +1 -0
  529. package/lib/esm/authorization/decorators/convenience.js +74 -0
  530. package/lib/esm/authorization/guard-constants.js +9 -0
  531. package/lib/esm/authorization/guard-decorators.js +155 -0
  532. package/lib/esm/authorization/guard-executor.js +101 -0
  533. package/lib/esm/authorization/guard-registry.js +132 -0
  534. package/lib/esm/authorization/guard.interface.js +73 -0
  535. package/lib/esm/authorization/guards/attribute-based.guard.js +106 -0
  536. package/lib/esm/authorization/guards/authenticated.guard.js +45 -0
  537. package/lib/esm/authorization/guards/composition.guard.js +63 -0
  538. package/lib/esm/authorization/guards/conditional.guard.js +38 -0
  539. package/lib/esm/authorization/guards/index.js +8 -0
  540. package/lib/esm/authorization/guards/permission.guard.js +80 -0
  541. package/lib/esm/authorization/guards/resource-owner.guard.js +58 -0
  542. package/lib/esm/authorization/guards/role.guard.js +61 -0
  543. package/lib/esm/authorization/index.js +24 -0
  544. package/lib/esm/authorization/services/guard-cache.interface.js +1 -0
  545. package/lib/esm/authorization/services/guard-cache.js +51 -0
  546. package/lib/esm/authorization/services/permission-hierarchy.interface.js +1 -0
  547. package/lib/esm/authorization/services/permission-hierarchy.js +49 -0
  548. package/lib/esm/authorization/services/permission-service.interface.js +1 -0
  549. package/lib/esm/authorization/services/permission-service.js +56 -0
  550. package/lib/esm/authorization/services/security-context.interface.js +1 -0
  551. package/lib/esm/authorization/services/security-context.js +74 -0
  552. package/lib/esm/authorization/setup.js +137 -0
  553. package/lib/esm/config/config-resolver.js +714 -0
  554. package/lib/esm/config/config.interfaces.js +13 -0
  555. package/lib/esm/config/define-config.js +492 -0
  556. package/lib/esm/config/env-field-builders.js +440 -0
  557. package/lib/esm/config/index.js +72 -0
  558. package/lib/esm/config/secret-value.js +175 -0
  559. package/lib/esm/console/color-codes.js +46 -0
  560. package/lib/esm/console/console.js +107 -0
  561. package/lib/esm/console/index.js +1 -0
  562. package/lib/esm/container-module/container-module.js +322 -0
  563. package/lib/esm/container-module/index.js +1 -0
  564. package/lib/esm/decorator/index.js +1 -0
  565. package/lib/esm/decorator/scope-binding.js +344 -0
  566. package/lib/esm/di/annotation/decorator_utils.js +93 -0
  567. package/lib/esm/di/annotation/inject.js +18 -0
  568. package/lib/esm/di/annotation/inject_base.js +14 -0
  569. package/lib/esm/di/annotation/injectable.js +19 -0
  570. package/lib/esm/di/annotation/lazy_service_identifier.js +9 -0
  571. package/lib/esm/di/annotation/multi_inject.js +4 -0
  572. package/lib/esm/di/annotation/named.js +9 -0
  573. package/lib/esm/di/annotation/optional.js +7 -0
  574. package/lib/esm/di/annotation/post_construct.js +5 -0
  575. package/lib/esm/di/annotation/pre_destroy.js +5 -0
  576. package/lib/esm/di/annotation/property_event_decorator.js +13 -0
  577. package/lib/esm/di/annotation/tagged.js +7 -0
  578. package/lib/esm/di/annotation/target_name.js +10 -0
  579. package/lib/esm/di/annotation/unmanaged.js +10 -0
  580. package/lib/esm/di/binding-decorator/constants.js +7 -0
  581. package/lib/esm/di/binding-decorator/decorator/fluent_provide.js +15 -0
  582. package/lib/esm/di/binding-decorator/decorator/provide.js +35 -0
  583. package/lib/esm/di/binding-decorator/factory/module_factory.js +34 -0
  584. package/lib/esm/di/binding-decorator/index.js +10 -0
  585. package/lib/esm/di/binding-decorator/interfaces/interfaces.js +1 -0
  586. package/lib/esm/di/binding-decorator/syntax/provide_done_syntax.js +41 -0
  587. package/lib/esm/di/binding-decorator/syntax/provide_in_syntax.js +37 -0
  588. package/lib/esm/di/binding-decorator/syntax/provide_in_when_on_syntax.js +68 -0
  589. package/lib/esm/di/binding-decorator/syntax/provide_on_syntax.js +19 -0
  590. package/lib/esm/di/binding-decorator/syntax/provide_when_on_syntax.js +57 -0
  591. package/lib/esm/di/binding-decorator/syntax/provide_when_syntax.js +86 -0
  592. package/lib/esm/di/binding-decorator/utils/auto_wire.js +13 -0
  593. package/lib/esm/di/bindings/binding.js +64 -0
  594. package/lib/esm/di/bindings/binding_count.js +5 -0
  595. package/lib/esm/di/constants/error_msgs.js +54 -0
  596. package/lib/esm/di/constants/literal_types.js +21 -0
  597. package/lib/esm/di/constants/metadata_keys.js +35 -0
  598. package/lib/esm/di/container/container.js +505 -0
  599. package/lib/esm/di/container/container_module.js +17 -0
  600. package/lib/esm/di/container/container_snapshot.js +17 -0
  601. package/lib/esm/di/container/lookup.js +108 -0
  602. package/lib/esm/di/container/module_activation_store.js +43 -0
  603. package/lib/esm/di/container-introspection.js +38 -0
  604. package/lib/esm/di/interfaces/interfaces.js +1 -0
  605. package/lib/esm/di/inversify.js +53 -0
  606. package/lib/esm/di/planning/context.js +18 -0
  607. package/lib/esm/di/planning/metadata.js +18 -0
  608. package/lib/esm/di/planning/metadata_reader.js +19 -0
  609. package/lib/esm/di/planning/plan.js +9 -0
  610. package/lib/esm/di/planning/planner.js +159 -0
  611. package/lib/esm/di/planning/queryable_string.js +25 -0
  612. package/lib/esm/di/planning/reflection_utils.js +150 -0
  613. package/lib/esm/di/planning/request.js +28 -0
  614. package/lib/esm/di/planning/target.js +89 -0
  615. package/lib/esm/di/resolution/instantiation.js +125 -0
  616. package/lib/esm/di/resolution/resolver.js +163 -0
  617. package/lib/esm/di/scope/scope-registry.js +109 -0
  618. package/lib/esm/di/scope/scope.js +75 -0
  619. package/lib/esm/di/syntax/binding_in_syntax.js +31 -0
  620. package/lib/esm/di/syntax/binding_in_when_on_syntax.js +79 -0
  621. package/lib/esm/di/syntax/binding_on_syntax.js +16 -0
  622. package/lib/esm/di/syntax/binding_to_syntax.js +89 -0
  623. package/lib/esm/di/syntax/binding_when_on_syntax.js +64 -0
  624. package/lib/esm/di/syntax/binding_when_syntax.js +82 -0
  625. package/lib/esm/di/syntax/constraint_helpers.js +39 -0
  626. package/lib/esm/di/utils/async.js +12 -0
  627. package/lib/esm/di/utils/binding_utils.js +48 -0
  628. package/lib/esm/di/utils/clonable.js +7 -0
  629. package/lib/esm/di/utils/exceptions.js +18 -0
  630. package/lib/esm/di/utils/factory_type.js +6 -0
  631. package/lib/esm/di/utils/id.js +5 -0
  632. package/lib/esm/di/utils/js.js +12 -0
  633. package/lib/esm/di/utils/serialization.js +102 -0
  634. package/lib/esm/error/app-error.js +209 -0
  635. package/lib/esm/error/base-exception-filter.js +134 -0
  636. package/lib/esm/error/error-handler-middleware.js +34 -0
  637. package/lib/esm/error/exception-filter-constants.js +9 -0
  638. package/lib/esm/error/exception-filter-decorators.js +157 -0
  639. package/lib/esm/error/exception-filter-registry.js +162 -0
  640. package/lib/esm/error/exception-filter.interface.js +1 -0
  641. package/lib/esm/error/exception-handler-middleware.js +378 -0
  642. package/lib/esm/error/filters/app-error.filter.js +28 -0
  643. package/lib/esm/error/filters/global-exception.filter.js +36 -0
  644. package/lib/esm/error/filters/not-found.filter.js +32 -0
  645. package/lib/esm/error/filters/validation-error.filter.js +32 -0
  646. package/lib/esm/error/index.js +13 -0
  647. package/lib/esm/error/not-found.error.js +13 -0
  648. package/lib/esm/error/report.js +153 -0
  649. package/lib/esm/error/status-code.js +106 -0
  650. package/lib/esm/error/utils.js +252 -0
  651. package/lib/esm/error/validation.error.js +15 -0
  652. package/lib/esm/event/event-decorators.js +268 -0
  653. package/lib/esm/event/event-emitter.js +376 -0
  654. package/lib/esm/event/event-flow-tracker.js +230 -0
  655. package/lib/esm/event/event-recorder.js +286 -0
  656. package/lib/esm/event/event-registry.js +201 -0
  657. package/lib/esm/event/event.interfaces.js +51 -0
  658. package/lib/esm/event/index.js +58 -0
  659. package/lib/esm/framework-version.js +7 -0
  660. package/lib/esm/index.mjs +27 -0
  661. package/lib/esm/interceptor/conditional-interceptor.js +104 -0
  662. package/lib/esm/interceptor/execution-context.js +66 -0
  663. package/lib/esm/interceptor/index.js +48 -0
  664. package/lib/esm/interceptor/interceptor-composition.js +126 -0
  665. package/lib/esm/interceptor/interceptor-constants.js +17 -0
  666. package/lib/esm/interceptor/interceptor-decorators.js +151 -0
  667. package/lib/esm/interceptor/interceptor-executor.js +139 -0
  668. package/lib/esm/interceptor/interceptor-registry.js +158 -0
  669. package/lib/esm/interceptor/interceptor.interface.js +16 -0
  670. package/lib/esm/interceptor/interceptors/index.js +6 -0
  671. package/lib/esm/interceptor/interceptors/logging.interceptor.js +68 -0
  672. package/lib/esm/interceptor/interceptors/performance.interceptor.js +253 -0
  673. package/lib/esm/interceptor/interceptors/timeout.interceptor.js +65 -0
  674. package/lib/esm/lazy-loading/index.js +58 -0
  675. package/lib/esm/lazy-loading/lazy-load-metrics.js +352 -0
  676. package/lib/esm/lazy-loading/lazy-module-helpers.js +45 -0
  677. package/lib/esm/lazy-loading/lazy-module-loader.js +305 -0
  678. package/lib/esm/lazy-loading/lazy-module-manager.js +241 -0
  679. package/lib/esm/lazy-loading/lazy-module-warmup.js +291 -0
  680. package/lib/esm/lazy-loading/lazy-module.js +352 -0
  681. package/lib/esm/lazy-loading/lazy.interfaces.js +17 -0
  682. package/lib/esm/lifecycle/index.js +9 -0
  683. package/lib/esm/lifecycle/lifecycle-registry.js +298 -0
  684. package/lib/esm/lifecycle/lifecycle.interface.js +33 -0
  685. package/lib/esm/middleware/content-negotiation/accept-header-parser.js +106 -0
  686. package/lib/esm/middleware/content-negotiation/content-negotiation-service.js +286 -0
  687. package/lib/esm/middleware/content-negotiation/formatter-registry.js +165 -0
  688. package/lib/esm/middleware/content-negotiation/formatters/csv-formatter.js +111 -0
  689. package/lib/esm/middleware/content-negotiation/formatters/index.js +8 -0
  690. package/lib/esm/middleware/content-negotiation/formatters/json-formatter.js +30 -0
  691. package/lib/esm/middleware/content-negotiation/formatters/plain-text-formatter.js +40 -0
  692. package/lib/esm/middleware/content-negotiation/formatters/xml-formatter.js +121 -0
  693. package/lib/esm/middleware/content-negotiation/formatters/yaml-formatter.js +131 -0
  694. package/lib/esm/middleware/content-negotiation/index.js +7 -0
  695. package/lib/esm/middleware/index.js +20 -0
  696. package/lib/esm/middleware/interfaces/body-parser.interface.js +1 -0
  697. package/lib/esm/middleware/interfaces/compression.interface.js +1 -0
  698. package/lib/esm/middleware/interfaces/content-negotiation.interface.js +6 -0
  699. package/lib/esm/middleware/interfaces/cookie-parser.interface.js +1 -0
  700. package/lib/esm/middleware/interfaces/cookie-session/cookie-session.interface.js +1 -0
  701. package/lib/esm/middleware/interfaces/cookie-session/keygrip.interface.js +1 -0
  702. package/lib/esm/middleware/interfaces/cors.interface.js +1 -0
  703. package/lib/esm/middleware/interfaces/express-rate-limit.interface.js +1 -0
  704. package/lib/esm/middleware/interfaces/express-session.interface.js +1 -0
  705. package/lib/esm/middleware/interfaces/helmet.interface.js +1 -0
  706. package/lib/esm/middleware/interfaces/morgan.interface.js +1 -0
  707. package/lib/esm/middleware/interfaces/multer.interface.js +1 -0
  708. package/lib/esm/middleware/interfaces/serve-favicon.interface.js +1 -0
  709. package/lib/esm/middleware/interfaces/serve-static.interface.js +1 -0
  710. package/lib/esm/middleware/interfaces/url-encoded.interface.js +1 -0
  711. package/lib/esm/middleware/middleware-config.js +9 -0
  712. package/lib/esm/middleware/middleware-interface.js +1 -0
  713. package/lib/esm/middleware/middleware-profiler.js +307 -0
  714. package/lib/esm/middleware/middleware-registry.js +152 -0
  715. package/lib/esm/middleware/middleware-resolver.js +320 -0
  716. package/lib/esm/middleware/middleware-service.js +1853 -0
  717. package/lib/esm/middleware/middleware-utils.js +273 -0
  718. package/lib/esm/middleware/presets-standalone.js +87 -0
  719. package/lib/esm/middleware/upload-registry.js +84 -0
  720. package/lib/esm/package.json +3 -0
  721. package/lib/esm/path-resolver/index.js +224 -0
  722. package/lib/esm/provider/db-in-memory/adapter/adapter.interface.js +9 -0
  723. package/lib/esm/provider/db-in-memory/adapter/in-memory.adapter.js +690 -0
  724. package/lib/esm/provider/db-in-memory/adapter/index.js +5 -0
  725. package/lib/esm/provider/db-in-memory/base-repo.repository.js +54 -0
  726. package/lib/esm/provider/db-in-memory/db-in-memory.interface.js +1 -0
  727. package/lib/esm/provider/db-in-memory/db-in-memory.provider.js +104 -0
  728. package/lib/esm/provider/db-in-memory/db-in-memory.types.js +20 -0
  729. package/lib/esm/provider/db-in-memory/db.provider.js +405 -0
  730. package/lib/esm/provider/db-in-memory/index.js +98 -0
  731. package/lib/esm/provider/db-in-memory/query/index.js +6 -0
  732. package/lib/esm/provider/db-in-memory/query/query-engine.js +598 -0
  733. package/lib/esm/provider/db-in-memory/query/query.types.js +9 -0
  734. package/lib/esm/provider/db-in-memory/schema/decorators.js +405 -0
  735. package/lib/esm/provider/db-in-memory/schema/entity.interface.js +8 -0
  736. package/lib/esm/provider/db-in-memory/schema/index.js +5 -0
  737. package/lib/esm/provider/db-in-memory/storage/index.js +5 -0
  738. package/lib/esm/provider/db-in-memory/storage/memory-store.js +784 -0
  739. package/lib/esm/provider/dto-validator/dto-validator.provider.js +49 -0
  740. package/lib/esm/provider/dto-validator/package-resolver.js +30 -0
  741. package/lib/esm/provider/index.js +7 -0
  742. package/lib/esm/provider/logger/decorators/index.js +1 -0
  743. package/lib/esm/provider/logger/decorators/log-performance.decorator.js +175 -0
  744. package/lib/esm/provider/logger/index.js +17 -0
  745. package/lib/esm/provider/logger/logger.banner.js +480 -0
  746. package/lib/esm/provider/logger/logger.config.js +29 -0
  747. package/lib/esm/provider/logger/logger.context.js +334 -0
  748. package/lib/esm/provider/logger/logger.flow.js +248 -0
  749. package/lib/esm/provider/logger/logger.formatter.js +691 -0
  750. package/lib/esm/provider/logger/logger.grouping.js +314 -0
  751. package/lib/esm/provider/logger/logger.health.js +291 -0
  752. package/lib/esm/provider/logger/logger.metrics-collector.js +180 -0
  753. package/lib/esm/provider/logger/logger.metrics.js +85 -0
  754. package/lib/esm/provider/logger/logger.performance.js +299 -0
  755. package/lib/esm/provider/logger/logger.provider.js +797 -0
  756. package/lib/esm/provider/logger/logger.query.js +529 -0
  757. package/lib/esm/provider/logger/logger.redaction.js +450 -0
  758. package/lib/esm/provider/logger/logger.suggestions.js +471 -0
  759. package/lib/esm/provider/logger/transports/console.transport.js +144 -0
  760. package/lib/esm/provider/logger/transports/file.transport.js +300 -0
  761. package/lib/esm/provider/logger/transports/http-server.js +141 -0
  762. package/lib/esm/provider/logger/transports/http.transport.js +157 -0
  763. package/lib/esm/provider/logger/transports/index.js +5 -0
  764. package/lib/esm/provider/logger/transports/transport.interface.js +1 -0
  765. package/lib/esm/provider/logger/utils/index.js +2 -0
  766. package/lib/esm/provider/logger/utils/log-entry.js +23 -0
  767. package/lib/esm/provider/logger/utils/log-levels.js +101 -0
  768. package/lib/esm/provider/provider-manager.js +283 -0
  769. package/lib/esm/provider/provider-registry.js +411 -0
  770. package/lib/esm/provider/provider.interface.js +44 -0
  771. package/lib/esm/provider/validation/adapters/class-validator.adapter.js +258 -0
  772. package/lib/esm/provider/validation/adapters/index.js +13 -0
  773. package/lib/esm/provider/validation/adapters/yup.adapter.js +111 -0
  774. package/lib/esm/provider/validation/adapters/zod.adapter.js +130 -0
  775. package/lib/esm/provider/validation/helpful-error-formatter.js +225 -0
  776. package/lib/esm/provider/validation/index.js +21 -0
  777. package/lib/esm/provider/validation/smart-field-detector.js +539 -0
  778. package/lib/esm/provider/validation/type-inference.js +183 -0
  779. package/lib/esm/provider/validation/validation-registry.js +214 -0
  780. package/lib/esm/provider/validation/validation.interface.js +8 -0
  781. package/lib/esm/render/adapters/base-adapter.js +131 -0
  782. package/lib/esm/render/adapters/ejs-adapter.js +142 -0
  783. package/lib/esm/render/adapters/handlebars-adapter.js +161 -0
  784. package/lib/esm/render/adapters/index.js +12 -0
  785. package/lib/esm/render/adapters/pug-adapter.js +134 -0
  786. package/lib/esm/render/adapters/react-adapter.js +303 -0
  787. package/lib/esm/render/features/auto-detection.js +202 -0
  788. package/lib/esm/render/features/hot-reload.js +153 -0
  789. package/lib/esm/render/features/index.js +12 -0
  790. package/lib/esm/render/features/streaming.js +103 -0
  791. package/lib/esm/render/features/type-generator.js +195 -0
  792. package/lib/esm/render/features/view-debugger.js +192 -0
  793. package/lib/esm/render/index.js +54 -0
  794. package/lib/esm/render/presets/index.js +207 -0
  795. package/lib/esm/render/render-config.js +9 -0
  796. package/lib/esm/render/render-interface.js +1 -0
  797. package/lib/esm/render/render-registry.js +124 -0
  798. package/lib/esm/render/render-service.js +394 -0
  799. package/lib/esm/render/utils/cache-manager.js +196 -0
  800. package/lib/esm/render/utils/index.js +10 -0
  801. package/lib/esm/render/utils/package-resolver.js +118 -0
  802. package/lib/esm/render/utils/view-scanner.js +178 -0
  803. package/lib/esm/testing/create-test-app.js +365 -0
  804. package/lib/esm/testing/create-test-database.js +411 -0
  805. package/lib/esm/testing/fluent-request.js +459 -0
  806. package/lib/esm/testing/index.js +102 -0
  807. package/lib/esm/testing/load-test.js +479 -0
  808. package/lib/esm/testing/matchers.js +440 -0
  809. package/lib/esm/testing/mock-context.js +400 -0
  810. package/lib/esm/testing/mock-provider.js +333 -0
  811. package/lib/esm/testing/snapshot-request.js +358 -0
  812. package/lib/esm/testing/testing.interfaces.js +9 -0
  813. package/lib/esm/types/application/application-container.d.ts +352 -0
  814. package/lib/esm/types/application/application-factory.d.ts +124 -0
  815. package/lib/esm/types/application/application.types.d.ts +185 -0
  816. package/lib/esm/types/application/bootstrap.d.ts +656 -0
  817. package/lib/esm/types/application/index.d.ts +4 -0
  818. package/lib/esm/types/authorization/authorization-config.interface.d.ts +45 -0
  819. package/lib/esm/types/authorization/decorators/convenience.d.ts +64 -0
  820. package/lib/esm/types/authorization/guard-constants.d.ts +9 -0
  821. package/lib/esm/types/authorization/guard-decorators.d.ts +128 -0
  822. package/lib/esm/types/authorization/guard-executor.d.ts +26 -0
  823. package/lib/esm/types/authorization/guard-registry.d.ts +35 -0
  824. package/lib/esm/types/authorization/guard.interface.d.ts +335 -0
  825. package/lib/esm/types/authorization/guards/attribute-based.guard.d.ts +60 -0
  826. package/lib/esm/types/authorization/guards/authenticated.guard.d.ts +26 -0
  827. package/lib/esm/types/authorization/guards/composition.guard.d.ts +42 -0
  828. package/lib/esm/types/authorization/guards/conditional.guard.d.ts +21 -0
  829. package/lib/esm/types/authorization/guards/index.d.ts +7 -0
  830. package/lib/esm/types/authorization/guards/permission.guard.d.ts +29 -0
  831. package/lib/esm/types/authorization/guards/resource-owner.guard.d.ts +29 -0
  832. package/lib/esm/types/authorization/guards/role.guard.d.ts +28 -0
  833. package/lib/esm/types/authorization/index.d.ts +18 -0
  834. package/lib/esm/types/authorization/services/guard-cache.d.ts +26 -0
  835. package/lib/esm/types/authorization/services/guard-cache.interface.d.ts +29 -0
  836. package/lib/esm/types/authorization/services/permission-hierarchy.d.ts +21 -0
  837. package/lib/esm/types/authorization/services/permission-hierarchy.interface.d.ts +22 -0
  838. package/lib/esm/types/authorization/services/permission-service.d.ts +21 -0
  839. package/lib/esm/types/authorization/services/permission-service.interface.d.ts +19 -0
  840. package/lib/esm/types/authorization/services/security-context.d.ts +32 -0
  841. package/lib/esm/types/authorization/services/security-context.interface.d.ts +25 -0
  842. package/lib/esm/types/authorization/setup.d.ts +84 -0
  843. package/lib/esm/types/config/config-resolver.d.ts +40 -0
  844. package/lib/esm/types/config/config.interfaces.d.ts +576 -0
  845. package/lib/esm/types/config/define-config.d.ts +109 -0
  846. package/lib/esm/types/config/env-field-builders.d.ts +327 -0
  847. package/lib/esm/types/config/index.d.ts +61 -0
  848. package/lib/esm/types/config/secret-value.d.ts +99 -0
  849. package/lib/esm/types/console/color-codes.d.ts +29 -0
  850. package/lib/esm/types/console/console.d.ts +83 -0
  851. package/lib/esm/types/console/index.d.ts +2 -0
  852. package/lib/esm/types/container-module/container-module.d.ts +242 -0
  853. package/lib/esm/types/container-module/index.d.ts +1 -0
  854. package/lib/esm/types/decorator/index.d.ts +1 -0
  855. package/lib/esm/types/decorator/scope-binding.d.ts +374 -0
  856. package/lib/esm/types/di/annotation/decorator_utils.d.ts +16 -0
  857. package/lib/esm/types/di/annotation/inject.d.ts +16 -0
  858. package/lib/esm/types/di/annotation/inject_base.d.ts +3 -0
  859. package/lib/esm/types/di/annotation/injectable.d.ts +7 -0
  860. package/lib/esm/types/di/annotation/lazy_service_identifier.d.ts +7 -0
  861. package/lib/esm/types/di/annotation/multi_inject.d.ts +2 -0
  862. package/lib/esm/types/di/annotation/named.d.ts +2 -0
  863. package/lib/esm/types/di/annotation/optional.d.ts +2 -0
  864. package/lib/esm/types/di/annotation/post_construct.d.ts +4 -0
  865. package/lib/esm/types/di/annotation/pre_destroy.d.ts +4 -0
  866. package/lib/esm/types/di/annotation/property_event_decorator.d.ts +4 -0
  867. package/lib/esm/types/di/annotation/tagged.d.ts +2 -0
  868. package/lib/esm/types/di/annotation/target_name.d.ts +3 -0
  869. package/lib/esm/types/di/annotation/unmanaged.d.ts +3 -0
  870. package/lib/esm/types/di/binding-decorator/constants.d.ts +7 -0
  871. package/lib/esm/types/di/binding-decorator/decorator/fluent_provide.d.ts +4 -0
  872. package/lib/esm/types/di/binding-decorator/decorator/provide.d.ts +4 -0
  873. package/lib/esm/types/di/binding-decorator/factory/module_factory.d.ts +23 -0
  874. package/lib/esm/types/di/binding-decorator/index.d.ts +10 -0
  875. package/lib/esm/types/di/binding-decorator/interfaces/interfaces.d.ts +40 -0
  876. package/lib/esm/types/di/binding-decorator/syntax/provide_done_syntax.d.ts +7 -0
  877. package/lib/esm/types/di/binding-decorator/syntax/provide_in_syntax.d.ts +12 -0
  878. package/lib/esm/types/di/binding-decorator/syntax/provide_in_when_on_syntax.d.ts +28 -0
  879. package/lib/esm/types/di/binding-decorator/syntax/provide_on_syntax.d.ts +10 -0
  880. package/lib/esm/types/di/binding-decorator/syntax/provide_when_on_syntax.d.ts +24 -0
  881. package/lib/esm/types/di/binding-decorator/syntax/provide_when_syntax.d.ts +23 -0
  882. package/lib/esm/types/di/binding-decorator/utils/auto_wire.d.ts +3 -0
  883. package/lib/esm/types/di/bindings/binding.d.ts +20 -0
  884. package/lib/esm/types/di/bindings/binding_count.d.ts +5 -0
  885. package/lib/esm/types/di/constants/error_msgs.d.ts +32 -0
  886. package/lib/esm/types/di/constants/literal_types.d.ts +5 -0
  887. package/lib/esm/types/di/constants/metadata_keys.d.ts +13 -0
  888. package/lib/esm/types/di/container/container.d.ts +73 -0
  889. package/lib/esm/types/di/container/container_module.d.ts +11 -0
  890. package/lib/esm/types/di/container/container_snapshot.d.ts +10 -0
  891. package/lib/esm/types/di/container/lookup.d.ts +16 -0
  892. package/lib/esm/types/di/container/module_activation_store.d.ts +10 -0
  893. package/lib/esm/types/di/container-introspection.d.ts +25 -0
  894. package/lib/esm/types/di/interfaces/interfaces.d.ts +300 -0
  895. package/lib/esm/types/di/inversify.d.ts +54 -0
  896. package/lib/esm/types/di/planning/context.d.ts +11 -0
  897. package/lib/esm/types/di/planning/metadata.d.ts +8 -0
  898. package/lib/esm/types/di/planning/metadata_reader.d.ts +6 -0
  899. package/lib/esm/types/di/planning/plan.d.ts +7 -0
  900. package/lib/esm/types/di/planning/planner.d.ts +5 -0
  901. package/lib/esm/types/di/planning/queryable_string.d.ts +11 -0
  902. package/lib/esm/types/di/planning/reflection_utils.d.ts +5 -0
  903. package/lib/esm/types/di/planning/request.d.ts +14 -0
  904. package/lib/esm/types/di/planning/target.d.ts +23 -0
  905. package/lib/esm/types/di/resolution/instantiation.d.ts +3 -0
  906. package/lib/esm/types/di/resolution/resolver.d.ts +3 -0
  907. package/lib/esm/types/di/scope/scope-registry.d.ts +91 -0
  908. package/lib/esm/types/di/scope/scope.d.ts +3 -0
  909. package/lib/esm/types/di/syntax/binding_in_syntax.d.ts +10 -0
  910. package/lib/esm/types/di/syntax/binding_in_when_on_syntax.d.ts +30 -0
  911. package/lib/esm/types/di/syntax/binding_on_syntax.d.ts +8 -0
  912. package/lib/esm/types/di/syntax/binding_to_syntax.d.ts +18 -0
  913. package/lib/esm/types/di/syntax/binding_when_on_syntax.d.ts +25 -0
  914. package/lib/esm/types/di/syntax/binding_when_syntax.d.ts +21 -0
  915. package/lib/esm/types/di/syntax/constraint_helpers.d.ts +6 -0
  916. package/lib/esm/types/di/utils/async.d.ts +3 -0
  917. package/lib/esm/types/di/utils/binding_utils.d.ts +4 -0
  918. package/lib/esm/types/di/utils/clonable.d.ts +3 -0
  919. package/lib/esm/types/di/utils/exceptions.d.ts +2 -0
  920. package/lib/esm/types/di/utils/factory_type.d.ts +5 -0
  921. package/lib/esm/types/di/utils/id.d.ts +2 -0
  922. package/lib/esm/types/di/utils/js.d.ts +1 -0
  923. package/lib/esm/types/di/utils/serialization.d.ts +10 -0
  924. package/lib/esm/types/error/app-error.d.ts +177 -0
  925. package/lib/esm/types/error/base-exception-filter.d.ts +73 -0
  926. package/lib/esm/types/error/error-handler-middleware.d.ts +11 -0
  927. package/lib/esm/types/error/exception-filter-constants.d.ts +9 -0
  928. package/lib/esm/types/error/exception-filter-decorators.d.ts +126 -0
  929. package/lib/esm/types/error/exception-filter-registry.d.ts +38 -0
  930. package/lib/esm/types/error/exception-filter.interface.d.ts +82 -0
  931. package/lib/esm/types/error/exception-handler-middleware.d.ts +35 -0
  932. package/lib/esm/types/error/filters/app-error.filter.d.ts +10 -0
  933. package/lib/esm/types/error/filters/global-exception.filter.d.ts +9 -0
  934. package/lib/esm/types/error/filters/not-found.filter.d.ts +10 -0
  935. package/lib/esm/types/error/filters/validation-error.filter.d.ts +10 -0
  936. package/lib/esm/types/error/index.d.ts +14 -0
  937. package/lib/esm/types/error/not-found.error.d.ts +7 -0
  938. package/lib/esm/types/error/report.d.ts +105 -0
  939. package/lib/esm/types/error/status-code.d.ts +156 -0
  940. package/lib/esm/types/error/utils.d.ts +17 -0
  941. package/lib/esm/types/error/validation.error.d.ts +8 -0
  942. package/lib/esm/types/event/event-decorators.d.ts +199 -0
  943. package/lib/esm/types/event/event-emitter.d.ts +109 -0
  944. package/lib/esm/types/event/event-flow-tracker.d.ts +88 -0
  945. package/lib/esm/types/event/event-recorder.d.ts +121 -0
  946. package/lib/esm/types/event/event-registry.d.ts +84 -0
  947. package/lib/esm/types/event/event.interfaces.d.ts +528 -0
  948. package/lib/esm/types/event/index.d.ts +55 -0
  949. package/lib/esm/types/framework-version.d.ts +7 -0
  950. package/lib/esm/types/index.d.ts +27 -0
  951. package/lib/esm/types/interceptor/conditional-interceptor.d.ts +91 -0
  952. package/lib/esm/types/interceptor/execution-context.d.ts +41 -0
  953. package/lib/esm/types/interceptor/index.d.ts +41 -0
  954. package/lib/esm/types/interceptor/interceptor-composition.d.ts +115 -0
  955. package/lib/esm/types/interceptor/interceptor-constants.d.ts +17 -0
  956. package/lib/esm/types/interceptor/interceptor-decorators.d.ts +124 -0
  957. package/lib/esm/types/interceptor/interceptor-executor.d.ts +46 -0
  958. package/lib/esm/types/interceptor/interceptor-registry.d.ts +65 -0
  959. package/lib/esm/types/interceptor/interceptor.interface.d.ts +281 -0
  960. package/lib/esm/types/interceptor/interceptors/index.d.ts +6 -0
  961. package/lib/esm/types/interceptor/interceptors/logging.interceptor.d.ts +28 -0
  962. package/lib/esm/types/interceptor/interceptors/performance.interceptor.d.ts +197 -0
  963. package/lib/esm/types/interceptor/interceptors/timeout.interceptor.d.ts +42 -0
  964. package/lib/esm/types/lazy-loading/index.d.ts +43 -0
  965. package/lib/esm/types/lazy-loading/lazy-load-metrics.d.ts +139 -0
  966. package/lib/esm/types/lazy-loading/lazy-module-helpers.d.ts +42 -0
  967. package/lib/esm/types/lazy-loading/lazy-module-loader.d.ts +169 -0
  968. package/lib/esm/types/lazy-loading/lazy-module-manager.d.ts +148 -0
  969. package/lib/esm/types/lazy-loading/lazy-module-warmup.d.ts +130 -0
  970. package/lib/esm/types/lazy-loading/lazy-module.d.ts +168 -0
  971. package/lib/esm/types/lazy-loading/lazy.interfaces.d.ts +480 -0
  972. package/lib/esm/types/lifecycle/index.d.ts +9 -0
  973. package/lib/esm/types/lifecycle/lifecycle-registry.d.ts +213 -0
  974. package/lib/esm/types/lifecycle/lifecycle.interface.d.ts +191 -0
  975. package/lib/esm/types/middleware/content-negotiation/accept-header-parser.d.ts +26 -0
  976. package/lib/esm/types/middleware/content-negotiation/content-negotiation-service.d.ts +64 -0
  977. package/lib/esm/types/middleware/content-negotiation/formatter-registry.d.ts +60 -0
  978. package/lib/esm/types/middleware/content-negotiation/formatters/csv-formatter.d.ts +34 -0
  979. package/lib/esm/types/middleware/content-negotiation/formatters/index.d.ts +8 -0
  980. package/lib/esm/types/middleware/content-negotiation/formatters/json-formatter.d.ts +14 -0
  981. package/lib/esm/types/middleware/content-negotiation/formatters/plain-text-formatter.d.ts +12 -0
  982. package/lib/esm/types/middleware/content-negotiation/formatters/xml-formatter.d.ts +26 -0
  983. package/lib/esm/types/middleware/content-negotiation/formatters/yaml-formatter.d.ts +26 -0
  984. package/lib/esm/types/middleware/content-negotiation/index.d.ts +7 -0
  985. package/lib/esm/types/middleware/index.d.ts +25 -0
  986. package/lib/esm/types/middleware/interfaces/body-parser.interface.d.ts +31 -0
  987. package/lib/esm/types/middleware/interfaces/compression.interface.d.ts +98 -0
  988. package/lib/esm/types/middleware/interfaces/content-negotiation.interface.d.ts +142 -0
  989. package/lib/esm/types/middleware/interfaces/cookie-parser.interface.d.ts +9 -0
  990. package/lib/esm/types/middleware/interfaces/cookie-session/cookie-session.interface.d.ts +57 -0
  991. package/lib/esm/types/middleware/interfaces/cookie-session/keygrip.interface.d.ts +27 -0
  992. package/lib/esm/types/middleware/interfaces/cors.interface.d.ts +57 -0
  993. package/lib/esm/types/middleware/interfaces/express-rate-limit.interface.d.ts +292 -0
  994. package/lib/esm/types/middleware/interfaces/express-session.interface.d.ts +207 -0
  995. package/lib/esm/types/middleware/interfaces/helmet.interface.d.ts +210 -0
  996. package/lib/esm/types/middleware/interfaces/morgan.interface.d.ts +39 -0
  997. package/lib/esm/types/middleware/interfaces/multer.interface.d.ts +253 -0
  998. package/lib/esm/types/middleware/interfaces/serve-favicon.interface.d.ts +11 -0
  999. package/lib/esm/types/middleware/interfaces/serve-static.interface.d.ts +69 -0
  1000. package/lib/esm/types/middleware/interfaces/url-encoded.interface.d.ts +37 -0
  1001. package/lib/esm/types/middleware/middleware-config.d.ts +574 -0
  1002. package/lib/esm/types/middleware/middleware-interface.d.ts +691 -0
  1003. package/lib/esm/types/middleware/middleware-profiler.d.ts +199 -0
  1004. package/lib/esm/types/middleware/middleware-registry.d.ts +103 -0
  1005. package/lib/esm/types/middleware/middleware-resolver.d.ts +159 -0
  1006. package/lib/esm/types/middleware/middleware-service.d.ts +788 -0
  1007. package/lib/esm/types/middleware/middleware-utils.d.ts +145 -0
  1008. package/lib/esm/types/middleware/presets-standalone.d.ts +75 -0
  1009. package/lib/esm/types/middleware/upload-registry.d.ts +50 -0
  1010. package/lib/esm/types/path-resolver/index.d.ts +80 -0
  1011. package/lib/esm/types/provider/db-in-memory/adapter/adapter.interface.d.ts +222 -0
  1012. package/lib/esm/types/provider/db-in-memory/adapter/in-memory.adapter.d.ts +241 -0
  1013. package/lib/esm/types/provider/db-in-memory/adapter/index.d.ts +6 -0
  1014. package/lib/esm/types/provider/db-in-memory/base-repo.repository.d.ts +18 -0
  1015. package/lib/esm/types/provider/db-in-memory/db-in-memory.interface.d.ts +43 -0
  1016. package/lib/esm/types/provider/db-in-memory/db-in-memory.provider.d.ts +39 -0
  1017. package/lib/esm/types/provider/db-in-memory/db-in-memory.types.d.ts +14 -0
  1018. package/lib/esm/types/provider/db-in-memory/db.provider.d.ts +281 -0
  1019. package/lib/esm/types/provider/db-in-memory/index.d.ts +71 -0
  1020. package/lib/esm/types/provider/db-in-memory/query/index.d.ts +6 -0
  1021. package/lib/esm/types/provider/db-in-memory/query/query-engine.d.ts +114 -0
  1022. package/lib/esm/types/provider/db-in-memory/query/query.types.d.ts +318 -0
  1023. package/lib/esm/types/provider/db-in-memory/schema/decorators.d.ts +328 -0
  1024. package/lib/esm/types/provider/db-in-memory/schema/entity.interface.d.ts +60 -0
  1025. package/lib/esm/types/provider/db-in-memory/schema/index.d.ts +6 -0
  1026. package/lib/esm/types/provider/db-in-memory/storage/index.d.ts +5 -0
  1027. package/lib/esm/types/provider/db-in-memory/storage/memory-store.d.ts +360 -0
  1028. package/lib/esm/types/provider/dto-validator/dto-validator.provider.d.ts +10 -0
  1029. package/lib/esm/types/provider/dto-validator/package-resolver.d.ts +7 -0
  1030. package/lib/esm/types/provider/index.d.ts +7 -0
  1031. package/lib/esm/types/provider/logger/decorators/index.d.ts +1 -0
  1032. package/lib/esm/types/provider/logger/decorators/log-performance.decorator.d.ts +49 -0
  1033. package/lib/esm/types/provider/logger/index.d.ts +17 -0
  1034. package/lib/esm/types/provider/logger/logger.banner.d.ts +94 -0
  1035. package/lib/esm/types/provider/logger/logger.config.d.ts +62 -0
  1036. package/lib/esm/types/provider/logger/logger.context.d.ts +189 -0
  1037. package/lib/esm/types/provider/logger/logger.flow.d.ts +165 -0
  1038. package/lib/esm/types/provider/logger/logger.formatter.d.ts +54 -0
  1039. package/lib/esm/types/provider/logger/logger.grouping.d.ts +124 -0
  1040. package/lib/esm/types/provider/logger/logger.health.d.ts +123 -0
  1041. package/lib/esm/types/provider/logger/logger.metrics-collector.d.ts +44 -0
  1042. package/lib/esm/types/provider/logger/logger.metrics.d.ts +162 -0
  1043. package/lib/esm/types/provider/logger/logger.performance.d.ts +179 -0
  1044. package/lib/esm/types/provider/logger/logger.provider.d.ts +363 -0
  1045. package/lib/esm/types/provider/logger/logger.query.d.ts +232 -0
  1046. package/lib/esm/types/provider/logger/logger.redaction.d.ts +169 -0
  1047. package/lib/esm/types/provider/logger/logger.suggestions.d.ts +124 -0
  1048. package/lib/esm/types/provider/logger/transports/console.transport.d.ts +56 -0
  1049. package/lib/esm/types/provider/logger/transports/file.transport.d.ts +87 -0
  1050. package/lib/esm/types/provider/logger/transports/http-server.d.ts +88 -0
  1051. package/lib/esm/types/provider/logger/transports/http.transport.d.ts +74 -0
  1052. package/lib/esm/types/provider/logger/transports/index.d.ts +5 -0
  1053. package/lib/esm/types/provider/logger/transports/transport.interface.d.ts +31 -0
  1054. package/lib/esm/types/provider/logger/utils/index.d.ts +2 -0
  1055. package/lib/esm/types/provider/logger/utils/log-entry.d.ts +82 -0
  1056. package/lib/esm/types/provider/logger/utils/log-levels.d.ts +53 -0
  1057. package/lib/esm/types/provider/provider-manager.d.ts +208 -0
  1058. package/lib/esm/types/provider/provider-registry.d.ts +192 -0
  1059. package/lib/esm/types/provider/provider.interface.d.ts +337 -0
  1060. package/lib/esm/types/provider/validation/adapters/class-validator.adapter.d.ts +68 -0
  1061. package/lib/esm/types/provider/validation/adapters/index.d.ts +13 -0
  1062. package/lib/esm/types/provider/validation/adapters/yup.adapter.d.ts +65 -0
  1063. package/lib/esm/types/provider/validation/adapters/zod.adapter.d.ts +84 -0
  1064. package/lib/esm/types/provider/validation/helpful-error-formatter.d.ts +110 -0
  1065. package/lib/esm/types/provider/validation/index.d.ts +19 -0
  1066. package/lib/esm/types/provider/validation/smart-field-detector.d.ts +91 -0
  1067. package/lib/esm/types/provider/validation/type-inference.d.ts +81 -0
  1068. package/lib/esm/types/provider/validation/validation-registry.d.ts +105 -0
  1069. package/lib/esm/types/provider/validation/validation.interface.d.ts +178 -0
  1070. package/lib/esm/types/render/adapters/base-adapter.d.ts +95 -0
  1071. package/lib/esm/types/render/adapters/ejs-adapter.d.ts +57 -0
  1072. package/lib/esm/types/render/adapters/handlebars-adapter.d.ts +74 -0
  1073. package/lib/esm/types/render/adapters/index.d.ts +12 -0
  1074. package/lib/esm/types/render/adapters/pug-adapter.d.ts +57 -0
  1075. package/lib/esm/types/render/adapters/react-adapter.d.ts +99 -0
  1076. package/lib/esm/types/render/features/auto-detection.d.ts +58 -0
  1077. package/lib/esm/types/render/features/hot-reload.d.ts +65 -0
  1078. package/lib/esm/types/render/features/index.d.ts +12 -0
  1079. package/lib/esm/types/render/features/streaming.d.ts +39 -0
  1080. package/lib/esm/types/render/features/type-generator.d.ts +64 -0
  1081. package/lib/esm/types/render/features/view-debugger.d.ts +52 -0
  1082. package/lib/esm/types/render/index.d.ts +50 -0
  1083. package/lib/esm/types/render/presets/index.d.ts +119 -0
  1084. package/lib/esm/types/render/render-config.d.ts +213 -0
  1085. package/lib/esm/types/render/render-interface.d.ts +126 -0
  1086. package/lib/esm/types/render/render-registry.d.ts +86 -0
  1087. package/lib/esm/types/render/render-service.d.ts +157 -0
  1088. package/lib/esm/types/render/utils/cache-manager.d.ts +106 -0
  1089. package/lib/esm/types/render/utils/index.d.ts +11 -0
  1090. package/lib/esm/types/render/utils/package-resolver.d.ts +57 -0
  1091. package/lib/esm/types/render/utils/view-scanner.d.ts +74 -0
  1092. package/lib/esm/types/testing/create-test-app.d.ts +71 -0
  1093. package/lib/esm/types/testing/create-test-database.d.ts +100 -0
  1094. package/lib/esm/types/testing/fluent-request.d.ts +37 -0
  1095. package/lib/esm/types/testing/index.d.ts +93 -0
  1096. package/lib/esm/types/testing/load-test.d.ts +139 -0
  1097. package/lib/esm/types/testing/matchers.d.ts +184 -0
  1098. package/lib/esm/types/testing/mock-context.d.ts +117 -0
  1099. package/lib/esm/types/testing/mock-provider.d.ts +93 -0
  1100. package/lib/esm/types/testing/snapshot-request.d.ts +46 -0
  1101. package/lib/esm/types/testing/testing.interfaces.d.ts +973 -0
  1102. package/lib/esm/types/utils/node-require.d.ts +11 -0
  1103. package/lib/esm/utils/node-require.js +56 -0
  1104. package/lib/package.json +167 -151
  1105. package/package.json +167 -151
  1106. package/lib/cjs/provider/environment/env-validator.provider.js +0 -100
  1107. package/lib/cjs/types/provider/environment/env-validator.provider.d.ts +0 -39
@@ -0,0 +1,797 @@
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ 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;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ var __metadata = (this && this.__metadata) || function (k, v) {
8
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
9
+ };
10
+ var Logger_1;
11
+ import { provideSingleton } from "../../decorator/scope-binding.js";
12
+ import { LogLevel, parseLogLevel, shouldLog, } from "./utils/log-levels.js";
13
+ import { createLogEntry } from "./utils/log-entry.js";
14
+ import { getDefaultLoggerConfig } from "./logger.config.js";
15
+ import { ConsoleTransport } from "./transports/console.transport.js";
16
+ import { formatDev, formatGroupedDev, formatGroupedProd, } from "./logger.formatter.js";
17
+ import { ContextManager } from "./logger.context.js";
18
+ import { Timer, PerformanceMetricsCollector, measurePerformance, measurePerformanceSync, } from "./logger.performance.js";
19
+ import { LogGroupingManager } from "./logger.grouping.js";
20
+ import { HealthMonitor, collectHealthStatus, } from "./logger.health.js";
21
+ import { LogQueryManager, LogQuery, exportToMarkdown, } from "./logger.query.js";
22
+ /**
23
+ * Enhanced Logger provider with structured logging, multiple levels, and pluggable transports.
24
+ * Features:
25
+ * - Automatic context detection (class/method names)
26
+ * - Request-scoped context via AsyncLocalStorage
27
+ * - Child logger creation with inherited context
28
+ * - Multiple log levels (ALL, DEBUG, INFO, WARN, ERROR, FATAL, SILENT)
29
+ * - Pluggable transports (console, file, HTTP)
30
+ * @public API
31
+ */
32
+ let Logger = class Logger {
33
+ static { Logger_1 = this; }
34
+ pid;
35
+ config;
36
+ transports = [];
37
+ currentContext;
38
+ contextObject;
39
+ autoDetectContext = true;
40
+ groupingManager = null;
41
+ healthMonitor = null;
42
+ queryManager = null;
43
+ /**
44
+ * Module-level overrides applied by `Logger.configure(...)` on top of the
45
+ * built-in defaults. Used by the constructor of every future `Logger`
46
+ * instance so application-wide config (e.g. log level, transports) can be
47
+ * set once before bootstrap, before any DI container exists.
48
+ */
49
+ static defaultOverrides = {};
50
+ name = "Logger Provider";
51
+ version = "4.1.0";
52
+ author = "Richard Zampieri";
53
+ repo = "https://github.com/expressots/expressots";
54
+ constructor() {
55
+ this.pid = process.pid;
56
+ // Merge module-level overrides on top of the built-in defaults so values
57
+ // set via Logger.configure(...) before container creation propagate to
58
+ // every instance. Caller-supplied transports replace the defaults, level
59
+ // is forwarded to the auto-installed console transport below.
60
+ const baseConfig = getDefaultLoggerConfig();
61
+ this.config = {
62
+ ...baseConfig,
63
+ ...Logger_1.defaultOverrides,
64
+ };
65
+ // Initialize with default console transport if none provided.
66
+ // Aligning the transport's level with the resolved logger level
67
+ // (which already honours `process.env.LOG_LEVEL`) keeps both
68
+ // filters consistent for messages emitted before any explicit
69
+ // `logger.configure({ level })` call.
70
+ if (this.config.transports.length === 0) {
71
+ const isDevelopment = process.env.NODE_ENV !== "production";
72
+ const transport = isDevelopment
73
+ ? ConsoleTransport.forDevelopment()
74
+ : ConsoleTransport.forProduction();
75
+ transport.level = parseLogLevel(this.config.level);
76
+ this.config.transports = [transport];
77
+ }
78
+ this.transports = this.config.transports;
79
+ // Initialize grouping manager with default config
80
+ this.groupingManager = new LogGroupingManager(this.config.grouping);
81
+ // Initialize query manager with default config
82
+ this.queryManager = new LogQueryManager(this.config.query);
83
+ }
84
+ /**
85
+ * Configure the default LoggerConfig used by every future `Logger`
86
+ * instance constructed in this process.
87
+ *
88
+ * Use this from application config files **before** bootstrap so the DI
89
+ * container's Logger picks up the correct level / transports / grouping /
90
+ * health / redaction settings without needing to inject and reconfigure it.
91
+ * Calls are merged: later calls override earlier ones, but unspecified
92
+ * keys keep their previously-set values.
93
+ *
94
+ * Already-constructed Logger instances are NOT mutated by this call —
95
+ * use the instance method `logger.configure(...)` to update a live one.
96
+ *
97
+ * @param config - Partial configuration to merge with the defaults.
98
+ * @public API
99
+ */
100
+ static configure(config) {
101
+ Logger_1.defaultOverrides = {
102
+ ...Logger_1.defaultOverrides,
103
+ ...config,
104
+ };
105
+ }
106
+ /**
107
+ * Reset the module-level overrides set by `Logger.configure`. Useful in
108
+ * tests to undo cross-test pollution.
109
+ *
110
+ * @public API
111
+ */
112
+ static resetConfigure() {
113
+ Logger_1.defaultOverrides = {};
114
+ }
115
+ /**
116
+ * Configure the logger.
117
+ * @param config - Partial configuration to merge with defaults
118
+ * @public API
119
+ */
120
+ configure(config) {
121
+ // Merge with existing config
122
+ this.config = {
123
+ ...this.config,
124
+ ...config,
125
+ };
126
+ // Update level if provided
127
+ if (config.level !== undefined) {
128
+ const newLevel = parseLogLevel(config.level);
129
+ this.config.level = newLevel;
130
+ // Update all existing transports to use the new level
131
+ // This ensures transports respect the logger's configured level
132
+ // Only update transports that were created with default levels (DEBUG/INFO)
133
+ // to avoid overriding explicit transport configurations
134
+ for (const transport of this.transports) {
135
+ const currentLevel = transport.level;
136
+ // Update if it's a default level (DEBUG for dev, INFO for prod)
137
+ // This allows dynamic level changes while preserving custom transport configs
138
+ if (currentLevel === LogLevel.DEBUG || currentLevel === LogLevel.INFO) {
139
+ transport.level = newLevel;
140
+ }
141
+ }
142
+ }
143
+ // Update transports if provided
144
+ if (config.transports !== undefined) {
145
+ this.transports = config.transports;
146
+ this.config.transports = config.transports;
147
+ }
148
+ // Initialize or update health monitor if health config is provided
149
+ if (config.health !== undefined) {
150
+ if (this.healthMonitor) {
151
+ // Stop existing monitor
152
+ this.healthMonitor.stop();
153
+ }
154
+ // Create new monitor with updated config
155
+ this.healthMonitor = new HealthMonitor(this, config.health);
156
+ // Start monitoring if enabled
157
+ if (config.health.enabled !== false) {
158
+ this.healthMonitor.start();
159
+ }
160
+ }
161
+ // Initialize or update query manager if query config is provided
162
+ if (config.query !== undefined) {
163
+ if (this.queryManager) {
164
+ this.queryManager.configure(config.query);
165
+ }
166
+ else {
167
+ this.queryManager = new LogQueryManager(config.query);
168
+ }
169
+ }
170
+ }
171
+ /**
172
+ * Get the current logger configuration.
173
+ * @returns Current logger configuration
174
+ * @public API
175
+ */
176
+ getConfig() {
177
+ return this.config;
178
+ }
179
+ /**
180
+ * Log a trace message (ultra-detailed diagnostic).
181
+ * @param message - The message to log
182
+ * @param data - Optional structured data
183
+ * @public API
184
+ */
185
+ trace(message, data) {
186
+ this.log(LogLevel.ALL, message, { data });
187
+ }
188
+ /**
189
+ * Log a debug message (detailed diagnostic).
190
+ * @param message - The message to log
191
+ * @param data - Optional structured data
192
+ * @public API
193
+ */
194
+ debug(message, data) {
195
+ this.log(LogLevel.DEBUG, message, { data });
196
+ }
197
+ /**
198
+ * Log an informational message.
199
+ * @param message - The message to log
200
+ * @param module - Optional module/context name (legacy API)
201
+ * @param data - Optional structured data (new API)
202
+ * @public API
203
+ */
204
+ info(message, module, data) {
205
+ // Support both legacy (module) and new (data) API
206
+ if (module && typeof module === "string" && data === undefined) {
207
+ // Legacy API: info(message, module)
208
+ this.log(LogLevel.INFO, message, { context: module });
209
+ }
210
+ else {
211
+ // New API: info(message, data) or info(message, module, data)
212
+ const context = typeof module === "string" ? module : this.currentContext;
213
+ this.log(LogLevel.INFO, message, {
214
+ context,
215
+ data: typeof module === "object" ? module : data,
216
+ });
217
+ }
218
+ }
219
+ /**
220
+ * Log a warning message.
221
+ * @param message - The message to log
222
+ * @param module - Optional module/context name (legacy API)
223
+ * @param data - Optional structured data (new API)
224
+ * @public API
225
+ */
226
+ warn(message, module, data) {
227
+ // Support both legacy (module) and new (data) API
228
+ if (module && typeof module === "string" && data === undefined) {
229
+ // Legacy API: warn(message, module)
230
+ this.log(LogLevel.WARN, message, { context: module });
231
+ }
232
+ else {
233
+ // New API: warn(message, data) or warn(message, module, data)
234
+ const context = typeof module === "string" ? module : this.currentContext;
235
+ this.log(LogLevel.WARN, message, {
236
+ context,
237
+ data: typeof module === "object" ? module : data,
238
+ });
239
+ }
240
+ }
241
+ /**
242
+ * Log an error message.
243
+ * @param message - The message to log
244
+ * @param module - Optional module/context name (legacy API)
245
+ * @param error - Optional error object (new API)
246
+ * @public API
247
+ */
248
+ error(message, module, error) {
249
+ // Support both legacy (module) and new (error) API
250
+ if (module && typeof module === "string" && error === undefined) {
251
+ // Legacy API: error(message, module)
252
+ this.log(LogLevel.ERROR, message, { context: module });
253
+ }
254
+ else {
255
+ // New API: error(message, error) or error(message, module, error)
256
+ // Handle case where module might be an Error object (new API: error(message, error))
257
+ let context;
258
+ let errorObj;
259
+ if (typeof module === "string") {
260
+ // module is a string, error is the error object
261
+ context = module;
262
+ errorObj = error;
263
+ }
264
+ else if (module && typeof module === "object" && module !== null) {
265
+ // module is actually an error object (new API: error(message, error))
266
+ context = this.currentContext;
267
+ errorObj = module;
268
+ }
269
+ else {
270
+ // module is undefined, use current context
271
+ context = this.currentContext;
272
+ errorObj = error;
273
+ }
274
+ this.log(LogLevel.ERROR, message, {
275
+ context,
276
+ error: errorObj,
277
+ });
278
+ }
279
+ }
280
+ /**
281
+ * Log a fatal error message.
282
+ * @param message - The message to log
283
+ * @param error - Optional error object
284
+ * @public API
285
+ */
286
+ fatal(message, error) {
287
+ this.log(LogLevel.FATAL, message, { error });
288
+ }
289
+ /**
290
+ * Log a generic message (legacy API - maps to INFO).
291
+ * @param message - The message to log
292
+ * @param module - Optional module name
293
+ * @public API
294
+ */
295
+ msg(message, module) {
296
+ this.log(LogLevel.INFO, message, { context: module });
297
+ }
298
+ /**
299
+ * Create a child logger with inherited context.
300
+ * @param context - Context name for the child logger
301
+ * @returns New Logger instance with context
302
+ * @public API
303
+ */
304
+ child(context) {
305
+ const childLogger = new Logger_1();
306
+ childLogger.configure(this.config);
307
+ childLogger.currentContext = context;
308
+ childLogger.contextObject = { ...this.contextObject, label: context };
309
+ childLogger.autoDetectContext = this.autoDetectContext;
310
+ return childLogger;
311
+ }
312
+ /**
313
+ * Set context for subsequent logs.
314
+ * @param context - Context name, object, or LogContext
315
+ * @returns Logger instance for chaining
316
+ * @public API
317
+ *
318
+ * @example
319
+ * // String context
320
+ * logger.withContext("UserService").info("User created");
321
+ *
322
+ * @example
323
+ * // Object context
324
+ * logger.withContext({ className: "UserService", methodName: "create" }).info("User created");
325
+ *
326
+ * @example
327
+ * // Request context (typically set by middleware)
328
+ * logger.withContext({ requestId: "req_123", userId: "user_456" }).info("Processing request");
329
+ */
330
+ withContext(context) {
331
+ // Create a new logger instance to avoid mutating the original
332
+ const contextLogger = new Logger_1();
333
+ contextLogger.configure(this.config);
334
+ contextLogger.transports = this.transports;
335
+ contextLogger.autoDetectContext = this.autoDetectContext;
336
+ if (typeof context === "string") {
337
+ contextLogger.currentContext = context;
338
+ contextLogger.contextObject = { ...this.contextObject, label: context };
339
+ }
340
+ else {
341
+ // Merge context objects
342
+ contextLogger.contextObject = { ...this.contextObject, ...context };
343
+ contextLogger.currentContext =
344
+ context.className || context.label || this.currentContext;
345
+ }
346
+ return contextLogger;
347
+ }
348
+ /**
349
+ * Disable automatic context detection for this logger.
350
+ * @returns Logger instance for chaining
351
+ * @public API
352
+ */
353
+ noAutoContext() {
354
+ this.autoDetectContext = false;
355
+ return this;
356
+ }
357
+ /**
358
+ * Enable automatic context detection for this logger.
359
+ * @returns Logger instance for chaining
360
+ * @public API
361
+ */
362
+ enableAutoContext() {
363
+ this.autoDetectContext = true;
364
+ return this;
365
+ }
366
+ /**
367
+ * Run a function with request-scoped context.
368
+ * All logs within the function (including async operations) will include this context.
369
+ * @param context - Context to use for the duration of the function
370
+ * @param fn - Function to run
371
+ * @returns Result of the function
372
+ * @public API
373
+ *
374
+ * @example
375
+ * await logger.runWithContext({ requestId: "req_123" }, async () => {
376
+ * logger.info("Processing..."); // Will include requestId
377
+ * await someAsyncOperation(); // Nested logs also include requestId
378
+ * });
379
+ */
380
+ runWithContext(context, fn) {
381
+ const fullContext = { ...this.contextObject, ...context };
382
+ return ContextManager.runWithContext(fullContext, fn);
383
+ }
384
+ /**
385
+ * Core logging method.
386
+ * Supports automatic context detection, request-scoped context, and manual context.
387
+ * @param level - Log level
388
+ * @param message - Log message
389
+ * @param options - Additional options
390
+ */
391
+ log(level, message, options) {
392
+ const configuredLevel = parseLogLevel(this.config.level);
393
+ if (!shouldLog(level, configuredLevel)) {
394
+ return;
395
+ }
396
+ // Build context from multiple sources (in priority order):
397
+ // 1. Explicit context in options (highest priority)
398
+ // 2. Manual context set via withContext()
399
+ // 3. Request-scoped context from AsyncLocalStorage
400
+ // 4. Auto-detected context from call stack (lowest priority)
401
+ let finalContext = options?.context || this.currentContext;
402
+ // Get request-scoped context if available
403
+ const requestContext = ContextManager.getCurrentContext();
404
+ let mergedContextObject = { ...this.contextObject };
405
+ if (requestContext) {
406
+ mergedContextObject = { ...mergedContextObject, ...requestContext };
407
+ if (!finalContext && requestContext.className) {
408
+ finalContext = requestContext.className;
409
+ }
410
+ }
411
+ // Auto-detect context if enabled and no manual context is set
412
+ if (this.autoDetectContext && !finalContext) {
413
+ const autoContext = ContextManager.autoDetectContext();
414
+ if (autoContext.className) {
415
+ finalContext = autoContext.className;
416
+ mergedContextObject = { ...mergedContextObject, ...autoContext };
417
+ }
418
+ }
419
+ // Apply filters
420
+ if (this.config.filters && finalContext) {
421
+ if (this.config.filters.exclude?.includes(finalContext)) {
422
+ return;
423
+ }
424
+ if (this.config.filters.include &&
425
+ this.config.filters.include.length > 0) {
426
+ if (!this.config.filters.include.includes(finalContext)) {
427
+ return;
428
+ }
429
+ }
430
+ }
431
+ // Extract flow from data if present (for backward compatibility)
432
+ let flowData = options?.flow;
433
+ let dataWithoutFlow = options?.data;
434
+ if (!flowData &&
435
+ typeof options?.data === "object" &&
436
+ options.data !== null &&
437
+ !Array.isArray(options.data) &&
438
+ "flow" in options.data) {
439
+ // Extract flow from data object
440
+ const dataObj = options.data;
441
+ flowData = dataObj.flow;
442
+ // Remove flow from data object
443
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
444
+ const { flow: _, ...rest } = dataObj;
445
+ dataWithoutFlow = Object.keys(rest).length > 0 ? rest : undefined;
446
+ }
447
+ // Merge all data sources
448
+ // Preserve arrays as arrays, don't convert to objects
449
+ let finalData = dataWithoutFlow;
450
+ if (Array.isArray(dataWithoutFlow)) {
451
+ // Keep arrays as arrays
452
+ finalData = dataWithoutFlow;
453
+ }
454
+ else if (dataWithoutFlow || Object.keys(mergedContextObject).length > 0) {
455
+ finalData = {
456
+ ...(typeof dataWithoutFlow === "object" && dataWithoutFlow !== null
457
+ ? dataWithoutFlow
458
+ : {}),
459
+ // Include request context metadata if present
460
+ ...(mergedContextObject.requestId
461
+ ? { requestId: mergedContextObject.requestId }
462
+ : {}),
463
+ ...(mergedContextObject.userId
464
+ ? { userId: mergedContextObject.userId }
465
+ : {}),
466
+ ...(mergedContextObject.tenantId
467
+ ? { tenantId: mergedContextObject.tenantId }
468
+ : {}),
469
+ ...(mergedContextObject.correlationId
470
+ ? { correlationId: mergedContextObject.correlationId }
471
+ : {}),
472
+ };
473
+ // Only use merged object if it has keys
474
+ if (Object.keys(finalData).length === 0) {
475
+ finalData = undefined;
476
+ }
477
+ }
478
+ const entry = createLogEntry(level, message, {
479
+ context: finalContext,
480
+ data: finalData,
481
+ error: options?.error,
482
+ trace: options?.trace,
483
+ performance: options?.performance,
484
+ flow: flowData,
485
+ pid: this.pid,
486
+ });
487
+ // Add entry to query buffer BEFORE grouping (so all entries are captured)
488
+ if (this.queryManager) {
489
+ this.queryManager.addEntry(entry);
490
+ }
491
+ // Process through grouping manager if enabled
492
+ if (this.groupingManager) {
493
+ const processed = this.groupingManager.processEntry(entry);
494
+ // If it's a grouped entry, format and send it
495
+ if (this.isGroupedLogEntry(processed)) {
496
+ this.sendGroupedEntry(processed);
497
+ return; // Don't send individual entry
498
+ }
499
+ // If it's not grouped yet (count < minOccurrences), send as normal
500
+ // The grouping manager will track it and group it later
501
+ }
502
+ // Send to all enabled transports
503
+ this.sendEntry(entry);
504
+ }
505
+ /**
506
+ * Check if a log entry is a grouped entry.
507
+ * @param entry - Log entry or grouped entry
508
+ * @returns True if grouped entry
509
+ */
510
+ isGroupedLogEntry(entry) {
511
+ return (typeof entry === "object" &&
512
+ entry !== null &&
513
+ "count" in entry &&
514
+ "representative" in entry &&
515
+ "firstOccurrence" in entry &&
516
+ "lastOccurrence" in entry);
517
+ }
518
+ /**
519
+ * Send a grouped log entry to transports.
520
+ * Formats grouped entries and writes them directly to stdout/stderr.
521
+ * @param groupedEntry - Grouped log entry
522
+ */
523
+ sendGroupedEntry(groupedEntry) {
524
+ const isStructured = this.config.structured ?? process.env.NODE_ENV === "production";
525
+ const formatOptions = {
526
+ redact: this.config.redaction?.enabled ?? process.env.NODE_ENV === "production",
527
+ };
528
+ const formatted = isStructured
529
+ ? formatGroupedProd(groupedEntry, formatOptions)
530
+ : formatGroupedDev(groupedEntry, formatOptions);
531
+ // Write formatted grouped entry directly to stdout/stderr
532
+ // This bypasses normal transport formatting since grouped entries are already formatted
533
+ const stream = groupedEntry.representative.level >= LogLevel.ERROR
534
+ ? process.stderr
535
+ : process.stdout;
536
+ stream.write(formatted);
537
+ }
538
+ /**
539
+ * Send a regular log entry to transports.
540
+ * @param entry - Log entry
541
+ */
542
+ sendEntry(entry) {
543
+ // Note: Entry is already added to query buffer before grouping
544
+ // This method only sends to transports
545
+ for (const transport of this.transports) {
546
+ if (transport.enabled) {
547
+ try {
548
+ const result = transport.log(entry);
549
+ if (result instanceof Promise) {
550
+ // Fire and forget for async transports
551
+ result.catch((err) => {
552
+ // Silently fail to avoid log loops
553
+ console.error(`[Logger] Transport ${transport.name} failed:`, err);
554
+ });
555
+ }
556
+ }
557
+ catch (err) {
558
+ // Silently fail to avoid log loops
559
+ console.error(`[Logger] Transport ${transport.name} failed:`, err);
560
+ }
561
+ }
562
+ }
563
+ }
564
+ /**
565
+ * Start a high-resolution timer.
566
+ * @param label - Label for this timer
567
+ * @param logLevel - Log level when timer ends (default: "debug")
568
+ * @returns Timer object with end() method
569
+ * @public API
570
+ *
571
+ * @example
572
+ * ```typescript
573
+ * const timer = logger.startTimer("database-query");
574
+ * // ... do work ...
575
+ * timer.end(); // Logs: "Timer 'database-query' completed in 45.23ms"
576
+ * ```
577
+ */
578
+ startTimer(label, logLevel = "debug") {
579
+ return new Timer(label, this, logLevel);
580
+ }
581
+ /**
582
+ * Get a metrics collector for tracking multiple operations.
583
+ * @returns PerformanceMetricsCollector instance
584
+ * @public API
585
+ *
586
+ * @example
587
+ * ```typescript
588
+ * const metrics = logger.metrics();
589
+ * metrics.start("db-query").end("db-query");
590
+ * metrics.start("api-call").end("api-call");
591
+ * metrics.summary(); // Logs detailed breakdown
592
+ * ```
593
+ */
594
+ metrics() {
595
+ return new PerformanceMetricsCollector(this);
596
+ }
597
+ /**
598
+ * Measure performance of an async function.
599
+ * @param fn - Async function to measure
600
+ * @param label - Label for this measurement
601
+ * @returns Promise with result and performance data
602
+ * @public API
603
+ *
604
+ * @example
605
+ * ```typescript
606
+ * const { result, performance } = await logger.measure(
607
+ * async () => await fetchData(),
608
+ * "fetch-data"
609
+ * );
610
+ * // Logs: "fetch-data took 123.45ms"
611
+ * ```
612
+ */
613
+ async measure(fn, label) {
614
+ return measurePerformance(fn, label, this);
615
+ }
616
+ /**
617
+ * Measure performance of a synchronous function.
618
+ * @param fn - Function to measure
619
+ * @param label - Label for this measurement
620
+ * @returns Result and performance data
621
+ * @public API
622
+ *
623
+ * @example
624
+ * ```typescript
625
+ * const { result, performance } = logger.measureSync(
626
+ * () => processData(),
627
+ * "process-data"
628
+ * );
629
+ * ```
630
+ */
631
+ measureSync(fn, label) {
632
+ return measurePerformanceSync(fn, label, this);
633
+ }
634
+ /**
635
+ * Flush all transports.
636
+ * @returns Promise that resolves when all transports are flushed
637
+ * @public API
638
+ */
639
+ async flush() {
640
+ const flushPromises = this.transports.map((transport) => {
641
+ if (transport.enabled && transport.flush) {
642
+ return transport.flush();
643
+ }
644
+ return Promise.resolve();
645
+ });
646
+ await Promise.all(flushPromises);
647
+ }
648
+ /**
649
+ * Close all transports.
650
+ * @returns Promise that resolves when all transports are closed
651
+ * @public API
652
+ */
653
+ async close() {
654
+ // Stop health monitoring
655
+ if (this.healthMonitor) {
656
+ this.healthMonitor.stop();
657
+ this.healthMonitor = null;
658
+ }
659
+ const closePromises = this.transports.map((transport) => {
660
+ if (transport.enabled && transport.close) {
661
+ return transport.close();
662
+ }
663
+ return Promise.resolve();
664
+ });
665
+ await Promise.all(closePromises);
666
+ }
667
+ /**
668
+ * Get current health status.
669
+ * @returns Current health status
670
+ * @public API
671
+ */
672
+ async getHealth() {
673
+ if (this.healthMonitor) {
674
+ return await this.healthMonitor.getCurrentHealth();
675
+ }
676
+ // If health monitor not initialized, collect status directly
677
+ return await collectHealthStatus();
678
+ }
679
+ /**
680
+ * Query logs from the in-memory buffer.
681
+ * @param options - Query options
682
+ * @returns Array of matching log entries
683
+ * @public API
684
+ */
685
+ queryLogs(options = {}) {
686
+ if (!this.queryManager) {
687
+ return [];
688
+ }
689
+ return this.queryManager.query(options);
690
+ }
691
+ /**
692
+ * Create a chainable query builder for logs.
693
+ * @returns LogQuery instance
694
+ * @public API
695
+ */
696
+ query() {
697
+ if (!this.queryManager) {
698
+ // Return empty query if query manager not enabled
699
+ return new LogQuery([]);
700
+ }
701
+ return this.queryManager.createQuery();
702
+ }
703
+ /**
704
+ * Get all logs from the buffer.
705
+ * @returns Array of all log entries
706
+ * @public API
707
+ */
708
+ getAllLogs() {
709
+ if (!this.queryManager) {
710
+ return [];
711
+ }
712
+ return this.queryManager.getAll();
713
+ }
714
+ /**
715
+ * Get statistics about logs in the buffer.
716
+ * @returns Log statistics
717
+ * @public API
718
+ */
719
+ getLogStats() {
720
+ if (!this.queryManager) {
721
+ return {
722
+ total: 0,
723
+ byLevel: {},
724
+ byContext: {},
725
+ oldest: null,
726
+ newest: null,
727
+ };
728
+ }
729
+ return this.queryManager.getStats();
730
+ }
731
+ /**
732
+ * Clear all logs from the query buffer.
733
+ * @public API
734
+ */
735
+ clearLogs() {
736
+ if (this.queryManager) {
737
+ this.queryManager.clear();
738
+ }
739
+ }
740
+ /**
741
+ * Export logs to markdown format.
742
+ * @param options - Export options
743
+ * @returns Markdown string
744
+ * @public API
745
+ */
746
+ exportLogsToMarkdown(options = {}) {
747
+ const entries = options.query
748
+ ? this.queryLogs(options.query)
749
+ : this.getAllLogs();
750
+ return exportToMarkdown(entries, {
751
+ title: options.title,
752
+ includeStats: options.includeStats,
753
+ groupBy: options.groupBy,
754
+ });
755
+ }
756
+ /**
757
+ * Start health monitoring (if configured).
758
+ * @public API
759
+ */
760
+ startHealthMonitoring() {
761
+ if (this.healthMonitor) {
762
+ this.healthMonitor.start();
763
+ }
764
+ }
765
+ /**
766
+ * Stop health monitoring.
767
+ * @public API
768
+ */
769
+ stopHealthMonitoring() {
770
+ if (this.healthMonitor) {
771
+ this.healthMonitor.stop();
772
+ this.healthMonitor = null;
773
+ }
774
+ }
775
+ /**
776
+ * Legacy formatMessage method for backward compatibility.
777
+ * @deprecated Use the new structured logging API instead
778
+ * @param logLevel - The level of the log
779
+ * @param message - The main log message
780
+ * @param module - Optional module name
781
+ * @returns The formatted log message
782
+ */
783
+ formatMessage(logLevel = "NONE", message, module) {
784
+ const level = parseLogLevel(logLevel);
785
+ const entry = createLogEntry(level, message, {
786
+ context: module,
787
+ pid: this.pid,
788
+ });
789
+ // Use dev formatter for legacy format
790
+ return formatDev(entry);
791
+ }
792
+ };
793
+ Logger = Logger_1 = __decorate([
794
+ provideSingleton(Logger, "builtin"),
795
+ __metadata("design:paramtypes", [])
796
+ ], Logger);
797
+ export { Logger };