@venok/core 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (400) hide show
  1. package/application/config.d.ts +35 -0
  2. package/application/config.js +85 -0
  3. package/application/context.d.ts +198 -0
  4. package/application/context.js +325 -0
  5. package/application/factory.d.ts +43 -0
  6. package/application/factory.js +147 -0
  7. package/constants.d.ts +46 -0
  8. package/constants.js +53 -0
  9. package/context/creator.d.ts +9 -0
  10. package/context/creator.js +32 -0
  11. package/context/execution-host.d.ts +16 -0
  12. package/context/execution-host.js +30 -0
  13. package/context/external/creator.d.ts +63 -0
  14. package/context/external/creator.js +159 -0
  15. package/context/external/proxy.d.ts +5 -0
  16. package/context/external/proxy.js +19 -0
  17. package/decorators/apply.decorator.d.ts +10 -0
  18. package/decorators/apply.decorator.js +24 -0
  19. package/decorators/bind.decorator.d.ts +11 -0
  20. package/decorators/bind.decorator.js +20 -0
  21. package/decorators/catch.decorator.d.ts +17 -0
  22. package/decorators/catch.decorator.js +26 -0
  23. package/decorators/create-param.decorator.d.ts +29 -0
  24. package/decorators/create-param.decorator.js +51 -0
  25. package/decorators/dependencies.decorator.d.ts +6 -0
  26. package/decorators/dependencies.decorator.js +17 -0
  27. package/decorators/exception-filters.decorator.d.ts +21 -0
  28. package/decorators/exception-filters.decorator.js +41 -0
  29. package/decorators/global.decorator.d.ts +10 -0
  30. package/decorators/global.decorator.js +19 -0
  31. package/decorators/index.d.ts +15 -0
  32. package/decorators/index.js +31 -0
  33. package/decorators/inject.decorator.d.ts +26 -0
  34. package/decorators/inject.decorator.js +45 -0
  35. package/decorators/injectable.decorator.d.ts +40 -0
  36. package/decorators/injectable.decorator.js +51 -0
  37. package/decorators/module.decorator.d.ts +14 -0
  38. package/decorators/module.decorator.js +38 -0
  39. package/decorators/optional.decorator.d.ts +14 -0
  40. package/decorators/optional.decorator.js +30 -0
  41. package/decorators/set-metadata.decorator.d.ts +18 -0
  42. package/decorators/set-metadata.decorator.js +30 -0
  43. package/decorators/use-guards.decorator.d.ts +21 -0
  44. package/decorators/use-guards.decorator.js +40 -0
  45. package/decorators/use-interceptors.decorator.d.ts +21 -0
  46. package/decorators/use-interceptors.decorator.js +40 -0
  47. package/decorators/use-pipes.decorator.d.ts +21 -0
  48. package/decorators/use-pipes.decorator.js +39 -0
  49. package/discovery/meta-host-collection.d.ts +32 -0
  50. package/discovery/meta-host-collection.js +79 -0
  51. package/discovery/module.d.ts +5 -0
  52. package/discovery/module.js +24 -0
  53. package/discovery/service.d.ts +68 -0
  54. package/discovery/service.js +90 -0
  55. package/errors/exceptions/circular-dependency.exception.d.ts +4 -0
  56. package/errors/exceptions/circular-dependency.exception.js +11 -0
  57. package/errors/exceptions/index.d.ts +8 -0
  58. package/errors/exceptions/index.js +24 -0
  59. package/errors/exceptions/invalid-class-module.exception.d.ts +4 -0
  60. package/errors/exceptions/invalid-class-module.exception.js +11 -0
  61. package/errors/exceptions/invalid-class-scope.exception.d.ts +5 -0
  62. package/errors/exceptions/invalid-class-scope.exception.js +14 -0
  63. package/errors/exceptions/invalid-class.exception.d.ts +4 -0
  64. package/errors/exceptions/invalid-class.exception.js +11 -0
  65. package/errors/exceptions/invalid-exception-filter.exception.d.ts +4 -0
  66. package/errors/exceptions/invalid-exception-filter.exception.js +11 -0
  67. package/errors/exceptions/invalid-module.exception.d.ts +4 -0
  68. package/errors/exceptions/invalid-module.exception.js +11 -0
  69. package/errors/exceptions/runtime.exception.d.ts +4 -0
  70. package/errors/exceptions/runtime.exception.js +12 -0
  71. package/errors/exceptions/undefined-dependency.exception.d.ts +6 -0
  72. package/errors/exceptions/undefined-dependency.exception.js +11 -0
  73. package/errors/exceptions/undefined-forwardref.exception.d.ts +5 -0
  74. package/errors/exceptions/undefined-forwardref.exception.js +11 -0
  75. package/errors/exceptions/undefined-module.exception.d.ts +4 -0
  76. package/errors/exceptions/undefined-module.exception.js +11 -0
  77. package/errors/exceptions/unknown-dependencies.exception.d.ts +16 -0
  78. package/errors/exceptions/unknown-dependencies.exception.js +15 -0
  79. package/errors/exceptions/unknown-element.exception.d.ts +4 -0
  80. package/errors/exceptions/unknown-element.exception.js +12 -0
  81. package/errors/exceptions/unknown-export.exception.d.ts +4 -0
  82. package/errors/exceptions/unknown-export.exception.js +11 -0
  83. package/errors/exceptions/unknown-module.exception.d.ts +4 -0
  84. package/errors/exceptions/unknown-module.exception.js +10 -0
  85. package/errors/messages.d.ts +15 -0
  86. package/errors/messages.js +126 -0
  87. package/exceptions/external/filter-context.d.ts +10 -0
  88. package/exceptions/external/filter-context.js +37 -0
  89. package/exceptions/external/filter.d.ts +5 -0
  90. package/exceptions/external/filter.js +16 -0
  91. package/exceptions/external/handler.d.ts +9 -0
  92. package/exceptions/external/handler.js +31 -0
  93. package/exceptions/filter-context.d.ts +14 -0
  94. package/exceptions/filter-context.js +55 -0
  95. package/exceptions/select-exception-filter-metadata.d.ts +2 -0
  96. package/exceptions/select-exception-filter-metadata.js +6 -0
  97. package/exceptions/zone/handler.d.ts +5 -0
  98. package/exceptions/zone/handler.js +15 -0
  99. package/exceptions/zone/zone.d.ts +5 -0
  100. package/exceptions/zone/zone.js +32 -0
  101. package/guards/consumer.d.ts +9 -0
  102. package/guards/consumer.js +33 -0
  103. package/guards/context-creator.d.ts +17 -0
  104. package/guards/context-creator.js +69 -0
  105. package/guards/index.d.ts +2 -0
  106. package/guards/index.js +18 -0
  107. package/helpers/color.helper.d.ts +9 -0
  108. package/helpers/color.helper.js +14 -0
  109. package/helpers/context-id-factory.helper.d.ts +2 -0
  110. package/helpers/context-id-factory.helper.js +15 -0
  111. package/helpers/context.helper.d.ts +23 -0
  112. package/helpers/context.helper.js +49 -0
  113. package/helpers/extends-metadata.helper.d.ts +1 -0
  114. package/helpers/extends-metadata.helper.js +9 -0
  115. package/helpers/flatten.helper.d.ts +1 -0
  116. package/helpers/flatten.helper.js +9 -0
  117. package/helpers/messages.helper.d.ts +2 -0
  118. package/helpers/messages.helper.js +7 -0
  119. package/helpers/noop.helper.d.ts +1 -0
  120. package/helpers/noop.helper.js +5 -0
  121. package/helpers/random-string-generator.helper.d.ts +1 -0
  122. package/helpers/random-string-generator.helper.js +6 -0
  123. package/helpers/rethrow.helper.d.ts +1 -0
  124. package/helpers/rethrow.helper.js +7 -0
  125. package/helpers/shared.helper.d.ts +10 -0
  126. package/helpers/shared.helper.js +33 -0
  127. package/helpers/silent.helper.d.ts +10 -0
  128. package/helpers/silent.helper.js +18 -0
  129. package/helpers/transient.helper.d.ts +12 -0
  130. package/helpers/transient.helper.js +26 -0
  131. package/helpers/uuid.helper.d.ts +15 -0
  132. package/helpers/uuid.helper.js +54 -0
  133. package/helpers/validate-each.helper.d.ts +8 -0
  134. package/helpers/validate-each.helper.js +25 -0
  135. package/hooks/before-app-shutdown.hook.d.ts +9 -0
  136. package/hooks/before-app-shutdown.hook.js +45 -0
  137. package/hooks/index.d.ts +5 -0
  138. package/hooks/index.js +21 -0
  139. package/hooks/on-app-bootstrap.hook.d.ts +8 -0
  140. package/hooks/on-app-bootstrap.hook.js +45 -0
  141. package/hooks/on-app-shutdown.hook.d.ts +9 -0
  142. package/hooks/on-app-shutdown.hook.js +46 -0
  143. package/hooks/on-module-destroy.hook.d.ts +8 -0
  144. package/hooks/on-module-destroy.hook.js +45 -0
  145. package/hooks/on-module-init.hook.d.ts +8 -0
  146. package/hooks/on-module-init.hook.js +45 -0
  147. package/index.d.ts +10 -0
  148. package/index.js +32 -0
  149. package/injector/constants.d.ts +2 -0
  150. package/injector/constants.js +7 -0
  151. package/injector/container.d.ts +61 -0
  152. package/injector/container.js +194 -0
  153. package/injector/helpers/class-scope.helper.d.ts +2 -0
  154. package/injector/helpers/class-scope.helper.js +9 -0
  155. package/injector/helpers/classifier.helper.d.ts +4 -0
  156. package/injector/helpers/classifier.helper.js +17 -0
  157. package/injector/helpers/is-durable.helper.d.ts +2 -0
  158. package/injector/helpers/is-durable.helper.js +9 -0
  159. package/injector/index.d.ts +5 -0
  160. package/injector/index.js +20 -0
  161. package/injector/injector.d.ts +87 -0
  162. package/injector/injector.js +452 -0
  163. package/injector/instance/links-host.d.ts +22 -0
  164. package/injector/instance/links-host.js +50 -0
  165. package/injector/instance/loader.d.ts +21 -0
  166. package/injector/instance/loader.js +73 -0
  167. package/injector/instance/resolver.d.ts +16 -0
  168. package/injector/instance/resolver.js +43 -0
  169. package/injector/instance/wrapper.d.ts +90 -0
  170. package/injector/instance/wrapper.js +272 -0
  171. package/injector/internal-core-module/core-providers.d.ts +4 -0
  172. package/injector/internal-core-module/core-providers.js +21 -0
  173. package/injector/internal-core-module/internal-core-module-factory.d.ts +8 -0
  174. package/injector/internal-core-module/internal-core-module-factory.js +42 -0
  175. package/injector/internal-core-module/internal-core-module.d.ts +4 -0
  176. package/injector/internal-core-module/internal-core-module.js +31 -0
  177. package/injector/module/compiler.d.ts +19 -0
  178. package/injector/module/compiler.js +27 -0
  179. package/injector/module/container.d.ts +6 -0
  180. package/injector/module/container.js +24 -0
  181. package/injector/module/lazy/loader.d.ts +21 -0
  182. package/injector/module/lazy/loader.js +49 -0
  183. package/injector/module/lazy/options.d.ts +6 -0
  184. package/injector/module/lazy/options.js +2 -0
  185. package/injector/module/module.d.ts +74 -0
  186. package/injector/module/module.js +383 -0
  187. package/injector/module/ref.d.ts +106 -0
  188. package/injector/module/ref.js +62 -0
  189. package/injector/module/token-factory.d.ts +13 -0
  190. package/injector/module/token-factory.js +71 -0
  191. package/injector/settlement-signal.d.ts +37 -0
  192. package/injector/settlement-signal.js +55 -0
  193. package/inspector/graph-inspector.d.ts +26 -0
  194. package/inspector/graph-inspector.js +163 -0
  195. package/inspector/initialize-on-preview.allowlist.d.ts +6 -0
  196. package/inspector/initialize-on-preview.allowlist.js +13 -0
  197. package/inspector/interfaces/edge.interface.d.ts +28 -0
  198. package/inspector/interfaces/edge.interface.js +2 -0
  199. package/inspector/interfaces/enhancer-metadata-cache-entry.interface.d.ts +12 -0
  200. package/inspector/interfaces/enhancer-metadata-cache-entry.interface.js +2 -0
  201. package/inspector/interfaces/entrypoint.interface.d.ts +10 -0
  202. package/inspector/interfaces/entrypoint.interface.js +2 -0
  203. package/inspector/interfaces/extras.interface.d.ts +18 -0
  204. package/inspector/interfaces/extras.interface.js +2 -0
  205. package/inspector/interfaces/node.interface.d.ts +49 -0
  206. package/inspector/interfaces/node.interface.js +2 -0
  207. package/inspector/interfaces/serialized-graph-json.interface.d.ts +14 -0
  208. package/inspector/interfaces/serialized-graph-json.interface.js +2 -0
  209. package/inspector/interfaces/serialized-graph-metadata.interface.d.ts +10 -0
  210. package/inspector/interfaces/serialized-graph-metadata.interface.js +2 -0
  211. package/inspector/noop-graph-inspector.d.ts +2 -0
  212. package/inspector/noop-graph-inspector.js +8 -0
  213. package/inspector/partial-graph.host.d.ts +7 -0
  214. package/inspector/partial-graph.host.js +15 -0
  215. package/inspector/serialized-graph.d.ts +52 -0
  216. package/inspector/serialized-graph.js +121 -0
  217. package/interceptors/consumer.d.ts +9 -0
  218. package/interceptors/consumer.js +37 -0
  219. package/interceptors/context-creator.d.ts +17 -0
  220. package/interceptors/context-creator.js +67 -0
  221. package/interceptors/index.d.ts +2 -0
  222. package/interceptors/index.js +18 -0
  223. package/interfaces/abstract.interface.d.ts +3 -0
  224. package/interfaces/abstract.interface.js +2 -0
  225. package/interfaces/application/context-options.interface.d.ts +41 -0
  226. package/interfaces/application/context-options.interface.js +9 -0
  227. package/interfaces/application/context.interface.d.ts +162 -0
  228. package/interfaces/application/context.interface.js +2 -0
  229. package/interfaces/application/index.d.ts +1 -0
  230. package/interfaces/application/index.js +17 -0
  231. package/interfaces/context/arguments-host.interface.d.ts +22 -0
  232. package/interfaces/context/arguments-host.interface.js +2 -0
  233. package/interfaces/context/execution.interface.d.ts +18 -0
  234. package/interfaces/context/execution.interface.js +2 -0
  235. package/interfaces/features/exception-filter.interface.d.ts +21 -0
  236. package/interfaces/features/exception-filter.interface.js +2 -0
  237. package/interfaces/features/guards.interface.d.ts +20 -0
  238. package/interfaces/features/guards.interface.js +2 -0
  239. package/interfaces/features/interceptor.interface.d.ts +30 -0
  240. package/interfaces/features/interceptor.interface.js +2 -0
  241. package/interfaces/features/pipes.interface.d.ts +37 -0
  242. package/interfaces/features/pipes.interface.js +2 -0
  243. package/interfaces/helper.interface.d.ts +3 -0
  244. package/interfaces/helper.interface.js +2 -0
  245. package/interfaces/hooks/before-application-shutdown.interface.d.ts +3 -0
  246. package/interfaces/hooks/before-application-shutdown.interface.js +2 -0
  247. package/interfaces/hooks/index.d.ts +5 -0
  248. package/interfaces/hooks/index.js +21 -0
  249. package/interfaces/hooks/on-application-bootstrap.interface.d.ts +9 -0
  250. package/interfaces/hooks/on-application-bootstrap.interface.js +2 -0
  251. package/interfaces/hooks/on-application-shutdown.interface.d.ts +9 -0
  252. package/interfaces/hooks/on-application-shutdown.interface.js +2 -0
  253. package/interfaces/hooks/on-destroy.interface.d.ts +10 -0
  254. package/interfaces/hooks/on-destroy.interface.js +2 -0
  255. package/interfaces/hooks/on-init.interface.d.ts +8 -0
  256. package/interfaces/hooks/on-init.interface.js +2 -0
  257. package/interfaces/index.d.ts +6 -0
  258. package/interfaces/index.js +22 -0
  259. package/interfaces/injectable.interface.d.ts +1 -0
  260. package/interfaces/injectable.interface.js +2 -0
  261. package/interfaces/modules/configurable/async-options.interface.d.ts +42 -0
  262. package/interfaces/modules/configurable/async-options.interface.js +2 -0
  263. package/interfaces/modules/configurable/cls.interface.d.ts +13 -0
  264. package/interfaces/modules/configurable/cls.interface.js +2 -0
  265. package/interfaces/modules/configurable/host.interface.d.ts +62 -0
  266. package/interfaces/modules/configurable/host.interface.js +2 -0
  267. package/interfaces/modules/configurable/index.d.ts +3 -0
  268. package/interfaces/modules/configurable/index.js +19 -0
  269. package/interfaces/modules/definition.interface.d.ts +4 -0
  270. package/interfaces/modules/definition.interface.js +2 -0
  271. package/interfaces/modules/dynamic-module.interface.d.ts +23 -0
  272. package/interfaces/modules/dynamic-module.interface.js +2 -0
  273. package/interfaces/modules/forward-reference.interface.d.ts +3 -0
  274. package/interfaces/modules/forward-reference.interface.js +2 -0
  275. package/interfaces/modules/index.d.ts +9 -0
  276. package/interfaces/modules/index.js +25 -0
  277. package/interfaces/modules/injection-token.interface.d.ts +5 -0
  278. package/interfaces/modules/injection-token.interface.js +2 -0
  279. package/interfaces/modules/introspection-result.interface.d.ts +10 -0
  280. package/interfaces/modules/introspection-result.interface.js +2 -0
  281. package/interfaces/modules/module-metadata.interface.d.ts +24 -0
  282. package/interfaces/modules/module-metadata.interface.js +2 -0
  283. package/interfaces/modules/module.interface.d.ts +2 -0
  284. package/interfaces/modules/module.interface.js +2 -0
  285. package/interfaces/modules/optional-factory-dependency.interface.d.ts +8 -0
  286. package/interfaces/modules/optional-factory-dependency.interface.js +2 -0
  287. package/interfaces/modules/override.interface.d.ts +5 -0
  288. package/interfaces/modules/override.interface.js +2 -0
  289. package/interfaces/modules/provider.interface.d.ts +142 -0
  290. package/interfaces/modules/provider.interface.js +2 -0
  291. package/interfaces/scope.interface.d.ts +35 -0
  292. package/interfaces/scope.interface.js +23 -0
  293. package/interfaces/type.interface.d.ts +3 -0
  294. package/interfaces/type.interface.js +2 -0
  295. package/metadata-scanner.d.ts +4 -0
  296. package/metadata-scanner.js +34 -0
  297. package/module/configurable-module.builder.d.ts +93 -0
  298. package/module/configurable-module.builder.js +204 -0
  299. package/module/constants.d.ts +4 -0
  300. package/module/constants.js +7 -0
  301. package/module/helpers/generate-options-injection-token.helper.d.ts +1 -0
  302. package/module/helpers/generate-options-injection-token.helper.js +9 -0
  303. package/module/helpers/get-injection-providers.helper.d.ts +8 -0
  304. package/module/helpers/get-injection-providers.helper.js +36 -0
  305. package/module/helpers/index.d.ts +2 -0
  306. package/module/helpers/index.js +18 -0
  307. package/module/index.d.ts +2 -0
  308. package/module/index.js +18 -0
  309. package/package.json +35 -0
  310. package/pipes/consumer.d.ts +9 -0
  311. package/pipes/consumer.js +15 -0
  312. package/pipes/context-creator.d.ts +18 -0
  313. package/pipes/context-creator.js +70 -0
  314. package/pipes/index.d.ts +2 -0
  315. package/pipes/index.js +18 -0
  316. package/scanner.d.ts +81 -0
  317. package/scanner.js +374 -0
  318. package/services/console.service.d.ts +86 -0
  319. package/services/console.service.js +233 -0
  320. package/services/index.d.ts +1 -0
  321. package/services/index.js +17 -0
  322. package/services/logger.service.d.ts +157 -0
  323. package/services/logger.service.js +269 -0
  324. package/services/reflector.service.d.ts +110 -0
  325. package/services/reflector.service.js +87 -0
  326. package/test/context/execution-host.spec.d.ts +1 -0
  327. package/test/context/execution-host.spec.js +31 -0
  328. package/test/context/external/creator.spec.d.ts +1 -0
  329. package/test/context/external/creator.spec.js +149 -0
  330. package/test/context/external/proxy.spec.d.ts +1 -0
  331. package/test/context/external/proxy.spec.js +45 -0
  332. package/test/exceptions/external/handler.spec.d.ts +1 -0
  333. package/test/exceptions/external/handler.spec.js +89 -0
  334. package/test/exceptions/filter-context.spec.d.ts +2 -0
  335. package/test/exceptions/filter-context.spec.js +91 -0
  336. package/test/exceptions/messages.spec.d.ts +0 -0
  337. package/test/exceptions/messages.spec.js +201 -0
  338. package/test/exceptions/zona/handler.spec.d.ts +1 -0
  339. package/test/exceptions/zona/handler.spec.js +51 -0
  340. package/test/exceptions/zona/zone.spec.d.ts +1 -0
  341. package/test/exceptions/zona/zone.spec.js +66 -0
  342. package/test/guards/consumer.spec.d.ts +1 -0
  343. package/test/guards/consumer.spec.js +47 -0
  344. package/test/guards/context-creator.spec.d.ts +1 -0
  345. package/test/guards/context-creator.spec.js +138 -0
  346. package/test/helpers/context-id-factory.spec.d.ts +1 -0
  347. package/test/helpers/context-id-factory.spec.js +9 -0
  348. package/test/helpers/shared.spec.d.ts +1 -0
  349. package/test/helpers/shared.spec.js +122 -0
  350. package/test/hooks/before-app-shutdown.hook.spec.d.ts +1 -0
  351. package/test/hooks/before-app-shutdown.hook.spec.js +44 -0
  352. package/test/hooks/on-app-bootstrap.hook.spec.d.ts +1 -0
  353. package/test/hooks/on-app-bootstrap.hook.spec.js +43 -0
  354. package/test/hooks/on-app-shutdown.hook.spec.d.ts +1 -0
  355. package/test/hooks/on-app-shutdown.hook.spec.js +43 -0
  356. package/test/hooks/on-module-destroy.hook.spec.d.ts +1 -0
  357. package/test/hooks/on-module-destroy.hook.spec.js +43 -0
  358. package/test/hooks/on-module-init.hook.spec.d.ts +1 -0
  359. package/test/hooks/on-module-init.hook.spec.js +43 -0
  360. package/test/injector/compiler.spec.d.ts +1 -0
  361. package/test/injector/compiler.spec.js +42 -0
  362. package/test/injector/container.spec.d.ts +1 -0
  363. package/test/injector/container.spec.js +203 -0
  364. package/test/injector/helpers/classifier.spec.d.ts +1 -0
  365. package/test/injector/helpers/classifier.spec.js +102 -0
  366. package/test/injector/injector.spec.d.ts +1 -0
  367. package/test/injector/injector.spec.js +678 -0
  368. package/test/injector/instance/loader.spec.d.ts +1 -0
  369. package/test/injector/instance/loader.spec.js +108 -0
  370. package/test/injector/instance/wrapper.spec.d.ts +1 -0
  371. package/test/injector/instance/wrapper.spec.js +772 -0
  372. package/test/injector/internal-core-module/internal-core-module-factory.spec.d.ts +1 -0
  373. package/test/injector/internal-core-module/internal-core-module-factory.spec.js +27 -0
  374. package/test/injector/module/lazy/loader.spec.d.ts +1 -0
  375. package/test/injector/module/lazy/loader.spec.js +71 -0
  376. package/test/injector/module/module.spec.d.ts +1 -0
  377. package/test/injector/module/module.spec.js +410 -0
  378. package/test/injector/module/token-factory.spec.d.ts +1 -0
  379. package/test/injector/module/token-factory.spec.js +84 -0
  380. package/test/interceptors/consumer.spec.d.ts +1 -0
  381. package/test/interceptors/consumer.spec.js +136 -0
  382. package/test/interceptors/context-creator.spec.d.ts +1 -0
  383. package/test/interceptors/context-creator.spec.js +139 -0
  384. package/test/metadata-scanner.spec.d.ts +1 -0
  385. package/test/metadata-scanner.spec.js +41 -0
  386. package/test/module/configurable-module.builder.spec.d.ts +1 -0
  387. package/test/module/configurable-module.builder.spec.js +102 -0
  388. package/test/module/helpers/get-injection-providers.helper.spec.d.ts +1 -0
  389. package/test/module/helpers/get-injection-providers.helper.spec.js +49 -0
  390. package/test/pipes/consumer.spec.d.ts +1 -0
  391. package/test/pipes/consumer.spec.js +42 -0
  392. package/test/pipes/context-creator.spec.d.ts +1 -0
  393. package/test/pipes/context-creator.spec.js +108 -0
  394. package/test/scanner.spec.d.ts +1 -0
  395. package/test/scanner.spec.js +620 -0
  396. package/test/services/logger.service.spec.d.ts +1 -0
  397. package/test/services/logger.service.spec.js +487 -0
  398. package/test/services/reflector.service.spec.d.ts +1 -0
  399. package/test/services/reflector.service.spec.js +105 -0
  400. package/tsconfig.tsbuildinfo +1 -0
@@ -0,0 +1,86 @@
1
+ import { LoggerService, LogLevel } from "@venok/core/services/logger.service";
2
+ export interface ConsoleLoggerOptions {
3
+ /**
4
+ * Enabled log levels.
5
+ */
6
+ logLevels?: LogLevel[];
7
+ /**
8
+ * If enabled, will print timestamp (time difference) between current and previous log message.
9
+ */
10
+ timestamp?: boolean;
11
+ }
12
+ export declare class ConsoleLogger implements LoggerService {
13
+ protected context?: string | undefined;
14
+ protected options: ConsoleLoggerOptions;
15
+ private static lastTimestampAt?;
16
+ private originalContext?;
17
+ constructor();
18
+ constructor(context: string);
19
+ constructor(context: string, options: ConsoleLoggerOptions);
20
+ /**
21
+ * Write a 'log' level log, if the configured level allows for it.
22
+ * Prints to `stdout` with newline.
23
+ */
24
+ log(message: any, context?: string): void;
25
+ log(message: any, ...optionalParams: [...any, string?]): void;
26
+ /**
27
+ * Write an 'error' level log, if the configured level allows for it.
28
+ * Prints to `stderr` with newline.
29
+ */
30
+ error(message: any, stackOrContext?: string): void;
31
+ error(message: any, stack?: string, context?: string): void;
32
+ error(message: any, ...optionalParams: [...any, string?, string?]): void;
33
+ /**
34
+ * Write a 'warn' level log, if the configured level allows for it.
35
+ * Prints to `stdout` with newline.
36
+ */
37
+ warn(message: any, context?: string): void;
38
+ warn(message: any, ...optionalParams: [...any, string?]): void;
39
+ /**
40
+ * Write a 'debug' level log, if the configured level allows for it.
41
+ * Prints to `stdout` with newline.
42
+ */
43
+ debug(message: any, context?: string): void;
44
+ debug(message: any, ...optionalParams: [...any, string?]): void;
45
+ /**
46
+ * Write a 'verbose' level log, if the configured level allows for it.
47
+ * Prints to `stdout` with newline.
48
+ */
49
+ verbose(message: any, context?: string): void;
50
+ verbose(message: any, ...optionalParams: [...any, string?]): void;
51
+ /**
52
+ * Write a 'fatal' level log, if the configured level allows for it.
53
+ * Prints to `stdout` with newline.
54
+ */
55
+ fatal(message: any, context?: string): void;
56
+ fatal(message: any, ...optionalParams: [...any, string?]): void;
57
+ /**
58
+ * Set log levels
59
+ * @param levels log levels
60
+ */
61
+ setLogLevels(levels: LogLevel[]): void;
62
+ /**
63
+ * Set logger context
64
+ * @param context context
65
+ */
66
+ setContext(context: string): void;
67
+ /**
68
+ * Resets the logger context to the value that was passed in the constructor.
69
+ */
70
+ resetContext(): void;
71
+ isLevelEnabled(level: LogLevel): boolean;
72
+ protected getTimestamp(): string;
73
+ protected printMessages(messages: unknown[], context?: string, logLevel?: LogLevel, writeStreamType?: "stdout" | "stderr"): void;
74
+ protected formatPid(pid: number): string;
75
+ protected formatContext(context: string): string;
76
+ protected formatMessage(logLevel: LogLevel, message: unknown, pidMessage: string, formattedLogLevel: string, contextMessage: string, timestampDiff: string): string;
77
+ protected stringifyMessage(message: unknown, logLevel: LogLevel): string;
78
+ protected colorize(message: string, logLevel: LogLevel): string;
79
+ protected printStackTrace(stack: string): void;
80
+ protected updateAndGetTimestampDiff(): string;
81
+ protected formatTimestampDiff(timestampDiff: number): string;
82
+ private getContextAndMessagesToPrint;
83
+ private getContextAndStackAndMessagesToPrint;
84
+ private isStackFormat;
85
+ private getColorByLogLevel;
86
+ }
@@ -0,0 +1,233 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var __param = (this && this.__param) || function (paramIndex, decorator) {
12
+ return function (target, key) { decorator(target, key, paramIndex); }
13
+ };
14
+ var ConsoleLogger_1;
15
+ Object.defineProperty(exports, "__esModule", { value: true });
16
+ exports.ConsoleLogger = void 0;
17
+ const logger_service_1 = require("@venok/core/services/logger.service");
18
+ const injectable_decorator_1 = require("@venok/core/decorators/injectable.decorator");
19
+ const optional_decorator_1 = require("@venok/core/decorators/optional.decorator");
20
+ const color_helper_1 = require("@venok/core/helpers/color.helper");
21
+ const shared_helper_1 = require("@venok/core/helpers/shared.helper");
22
+ const DEFAULT_LOG_LEVELS = ["log", "error", "warn", "debug", "verbose", "fatal"];
23
+ const dateTimeFormatter = new Intl.DateTimeFormat(undefined, {
24
+ year: "numeric",
25
+ hour: "numeric",
26
+ minute: "numeric",
27
+ second: "numeric",
28
+ day: "2-digit",
29
+ month: "2-digit",
30
+ });
31
+ let ConsoleLogger = ConsoleLogger_1 = class ConsoleLogger {
32
+ constructor(context, options = {}) {
33
+ this.context = context;
34
+ this.options = options;
35
+ if (!options.logLevels) {
36
+ options.logLevels = DEFAULT_LOG_LEVELS;
37
+ }
38
+ if (context) {
39
+ this.originalContext = context;
40
+ }
41
+ }
42
+ log(message, ...optionalParams) {
43
+ if (!this.isLevelEnabled("log")) {
44
+ return;
45
+ }
46
+ const { messages, context } = this.getContextAndMessagesToPrint([message, ...optionalParams]);
47
+ this.printMessages(messages, context, "log");
48
+ }
49
+ error(message, ...optionalParams) {
50
+ if (!this.isLevelEnabled("error")) {
51
+ return;
52
+ }
53
+ const { messages, context, stack } = this.getContextAndStackAndMessagesToPrint([message, ...optionalParams]);
54
+ this.printMessages(messages, context, "error", "stderr");
55
+ if ((0, shared_helper_1.isUndefined)(stack))
56
+ return false;
57
+ this.printStackTrace(stack);
58
+ }
59
+ warn(message, ...optionalParams) {
60
+ if (!this.isLevelEnabled("warn")) {
61
+ return;
62
+ }
63
+ const { messages, context } = this.getContextAndMessagesToPrint([message, ...optionalParams]);
64
+ this.printMessages(messages, context, "warn");
65
+ }
66
+ debug(message, ...optionalParams) {
67
+ if (!this.isLevelEnabled("debug")) {
68
+ return;
69
+ }
70
+ const { messages, context } = this.getContextAndMessagesToPrint([message, ...optionalParams]);
71
+ this.printMessages(messages, context, "debug");
72
+ }
73
+ verbose(message, ...optionalParams) {
74
+ if (!this.isLevelEnabled("verbose")) {
75
+ return;
76
+ }
77
+ const { messages, context } = this.getContextAndMessagesToPrint([message, ...optionalParams]);
78
+ this.printMessages(messages, context, "verbose");
79
+ }
80
+ fatal(message, ...optionalParams) {
81
+ if (!this.isLevelEnabled("fatal")) {
82
+ return;
83
+ }
84
+ const { messages, context } = this.getContextAndMessagesToPrint([message, ...optionalParams]);
85
+ this.printMessages(messages, context, "fatal");
86
+ }
87
+ /**
88
+ * Set log levels
89
+ * @param levels log levels
90
+ */
91
+ setLogLevels(levels) {
92
+ if (!this.options) {
93
+ this.options = {};
94
+ }
95
+ this.options.logLevels = levels;
96
+ }
97
+ /**
98
+ * Set logger context
99
+ * @param context context
100
+ */
101
+ setContext(context) {
102
+ this.context = context;
103
+ }
104
+ /**
105
+ * Resets the logger context to the value that was passed in the constructor.
106
+ */
107
+ resetContext() {
108
+ this.context = this.originalContext;
109
+ }
110
+ isLevelEnabled(level) {
111
+ const logLevels = this.options?.logLevels;
112
+ return (0, logger_service_1.isLogLevelEnabled)(level, logLevels);
113
+ }
114
+ getTimestamp() {
115
+ return dateTimeFormatter.format(Date.now());
116
+ }
117
+ printMessages(messages, context = "", logLevel = "log", writeStreamType) {
118
+ messages.forEach((message) => {
119
+ const pidMessage = this.formatPid(process.pid);
120
+ const contextMessage = this.formatContext(context);
121
+ const timestampDiff = this.updateAndGetTimestampDiff();
122
+ const formattedLogLevel = logLevel.toUpperCase().padStart(7, " ");
123
+ const formattedMessage = this.formatMessage(logLevel, message, pidMessage, formattedLogLevel, contextMessage, timestampDiff);
124
+ process[writeStreamType ?? "stdout"].write(formattedMessage);
125
+ });
126
+ }
127
+ formatPid(pid) {
128
+ return `[Venok] ${pid} - `;
129
+ }
130
+ formatContext(context) {
131
+ return context ? (0, color_helper_1.yellow)(`[${context}] `) : "";
132
+ }
133
+ formatMessage(logLevel, message, pidMessage, formattedLogLevel, contextMessage, timestampDiff) {
134
+ const output = this.stringifyMessage(message, logLevel);
135
+ pidMessage = this.colorize(pidMessage, logLevel);
136
+ formattedLogLevel = this.colorize(formattedLogLevel, logLevel);
137
+ return `${pidMessage}${this.getTimestamp()} ${formattedLogLevel} ${contextMessage}${output}${timestampDiff}\n`;
138
+ }
139
+ stringifyMessage(message, logLevel) {
140
+ // If the message is a function, call it and re-resolve its value.
141
+ return (0, shared_helper_1.isFunction)(message)
142
+ ? this.stringifyMessage(message(), logLevel)
143
+ : (0, shared_helper_1.isPlainObject)(message) || Array.isArray(message)
144
+ ? `${this.colorize("Object:", logLevel)}\n${JSON.stringify(message, (key, value) => (typeof value === "bigint" ? value.toString() : value), 2)}\n`
145
+ : this.colorize(message, logLevel);
146
+ }
147
+ colorize(message, logLevel) {
148
+ const color = this.getColorByLogLevel(logLevel);
149
+ return color(message);
150
+ }
151
+ printStackTrace(stack) {
152
+ if (!stack)
153
+ return;
154
+ process.stderr.write(`${stack}\n`);
155
+ }
156
+ updateAndGetTimestampDiff() {
157
+ const includeTimestamp = ConsoleLogger_1.lastTimestampAt && this.options?.timestamp;
158
+ const ts = typeof ConsoleLogger_1.lastTimestampAt !== "undefined" ? ConsoleLogger_1.lastTimestampAt : 0;
159
+ const result = includeTimestamp ? this.formatTimestampDiff(Date.now() - ts) : "";
160
+ ConsoleLogger_1.lastTimestampAt = Date.now();
161
+ return result;
162
+ }
163
+ formatTimestampDiff(timestampDiff) {
164
+ return (0, color_helper_1.yellow)(` +${timestampDiff}ms`);
165
+ }
166
+ getContextAndMessagesToPrint(args) {
167
+ if (args?.length <= 1)
168
+ return { messages: args, context: this.context };
169
+ const lastElement = args[args.length - 1];
170
+ const isContext = (0, shared_helper_1.isString)(lastElement);
171
+ if (!isContext)
172
+ return { messages: args, context: this.context };
173
+ return {
174
+ context: lastElement,
175
+ messages: args.slice(0, args.length - 1),
176
+ };
177
+ }
178
+ getContextAndStackAndMessagesToPrint(args) {
179
+ if (args.length === 2) {
180
+ return this.isStackFormat(args[1])
181
+ ? {
182
+ messages: [args[0]],
183
+ stack: args[1],
184
+ context: this.context,
185
+ }
186
+ : {
187
+ messages: [args[0]],
188
+ context: args[1],
189
+ };
190
+ }
191
+ const { messages, context } = this.getContextAndMessagesToPrint(args);
192
+ if (messages?.length <= 1)
193
+ return { messages, context };
194
+ const lastElement = messages[messages.length - 1];
195
+ const isStack = (0, shared_helper_1.isString)(lastElement);
196
+ // https://github.com/nestjs/nest/issues/11074#issuecomment-1421680060
197
+ if (!isStack && !(0, shared_helper_1.isUndefined)(lastElement))
198
+ return { messages, context };
199
+ return {
200
+ stack: lastElement,
201
+ messages: messages.slice(0, messages.length - 1),
202
+ context,
203
+ };
204
+ }
205
+ isStackFormat(stack) {
206
+ if (!(0, shared_helper_1.isString)(stack))
207
+ return false;
208
+ return /^(.)+\n\s+at .+:\d+:\d+$/.test(stack);
209
+ }
210
+ getColorByLogLevel(level) {
211
+ switch (level) {
212
+ case "debug":
213
+ return color_helper_1.colors.magentaBright;
214
+ case "warn":
215
+ return color_helper_1.colors.yellow;
216
+ case "error":
217
+ return color_helper_1.colors.red;
218
+ case "verbose":
219
+ return color_helper_1.colors.cyanBright;
220
+ case "fatal":
221
+ return color_helper_1.colors.bold;
222
+ default:
223
+ return color_helper_1.colors.green;
224
+ }
225
+ }
226
+ };
227
+ exports.ConsoleLogger = ConsoleLogger;
228
+ exports.ConsoleLogger = ConsoleLogger = ConsoleLogger_1 = __decorate([
229
+ (0, injectable_decorator_1.Injectable)(),
230
+ __param(0, (0, optional_decorator_1.Optional)()),
231
+ __param(1, (0, optional_decorator_1.Optional)()),
232
+ __metadata("design:paramtypes", [String, Object])
233
+ ], ConsoleLogger);
@@ -0,0 +1 @@
1
+ export * from "./reflector.service";
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./reflector.service"), exports);
@@ -0,0 +1,157 @@
1
+ /**
2
+ * @publicApi
3
+ */
4
+ export type LogLevel = "log" | "error" | "warn" | "debug" | "verbose" | "fatal";
5
+ /**
6
+ * Checks if target level is enabled.
7
+ * @param targetLevel target level
8
+ * @param logLevels array of enabled log levels
9
+ */
10
+ export declare function isLogLevelEnabled(targetLevel: LogLevel, logLevels: LogLevel[] | undefined): boolean;
11
+ /**
12
+ * @publicApi
13
+ */
14
+ export interface LoggerService {
15
+ /**
16
+ * Write a 'log' level log.
17
+ */
18
+ log(message: any, ...optionalParams: any[]): any;
19
+ /**
20
+ * Write an 'error' level log.
21
+ */
22
+ error(message: any, ...optionalParams: any[]): any;
23
+ /**
24
+ * Write a 'warn' level log.
25
+ */
26
+ warn(message: any, ...optionalParams: any[]): any;
27
+ /**
28
+ * Write a 'debug' level log.
29
+ */
30
+ debug?(message: any, ...optionalParams: any[]): any;
31
+ /**
32
+ * Write a 'verbose' level log.
33
+ */
34
+ verbose?(message: any, ...optionalParams: any[]): any;
35
+ /**
36
+ * Write a 'fatal' level log.
37
+ */
38
+ fatal?(message: any, ...optionalParams: any[]): any;
39
+ /**
40
+ * Set log levels.
41
+ * @param levels log levels
42
+ */
43
+ setLogLevels?(levels: LogLevel[]): any;
44
+ }
45
+ interface LogBufferRecord {
46
+ /**
47
+ * Method to execute.
48
+ */
49
+ methodRef: Function;
50
+ /**
51
+ * Arguments to pass to the method.
52
+ */
53
+ arguments: unknown[];
54
+ }
55
+ /**
56
+ * @publicApi
57
+ */
58
+ export declare class Logger implements LoggerService {
59
+ protected context?: string | undefined;
60
+ protected options: {
61
+ timestamp?: boolean;
62
+ };
63
+ protected static logBuffer: LogBufferRecord[];
64
+ protected static staticInstanceRef: LoggerService;
65
+ protected static logLevels?: LogLevel[];
66
+ private static isBufferAttached;
67
+ protected localInstanceRef?: LoggerService;
68
+ private static WrapBuffer;
69
+ constructor();
70
+ constructor(context: string);
71
+ constructor(context: string, options?: {
72
+ timestamp?: boolean;
73
+ });
74
+ get localInstance(): LoggerService;
75
+ /**
76
+ * Write an 'error' level log.
77
+ */
78
+ error(message: any, stack?: string, context?: string): void;
79
+ error(message: any, ...optionalParams: [...any, string?, string?]): void;
80
+ /**
81
+ * Write a 'log' level log.
82
+ */
83
+ log(message: any, context?: string): void;
84
+ log(message: any, ...optionalParams: [...any, string?]): void;
85
+ /**
86
+ * Write a 'warn' level log.
87
+ */
88
+ warn(message: any, context?: string): void;
89
+ warn(message: any, ...optionalParams: [...any, string?]): void;
90
+ /**
91
+ * Write a 'debug' level log.
92
+ */
93
+ debug(message: any, context?: string): void;
94
+ debug(message: any, ...optionalParams: [...any, string?]): void;
95
+ /**
96
+ * Write a 'verbose' level log.
97
+ */
98
+ verbose(message: any, context?: string): void;
99
+ verbose(message: any, ...optionalParams: [...any, string?]): void;
100
+ /**
101
+ * Write a 'fatal' level log.
102
+ */
103
+ fatal(message: any, context?: string): void;
104
+ fatal(message: any, ...optionalParams: [...any, string?]): void;
105
+ /**
106
+ * Write an 'error' level log.
107
+ */
108
+ static error(message: any, stackOrContext?: string): void;
109
+ static error(message: any, context?: string): void;
110
+ static error(message: any, stack?: string, context?: string): void;
111
+ static error(message: any, ...optionalParams: [...any, string?, string?]): void;
112
+ /**
113
+ * Write a 'log' level log.
114
+ */
115
+ static log(message: any, context?: string): void;
116
+ static log(message: any, ...optionalParams: [...any, string?]): void;
117
+ /**
118
+ * Write a 'warn' level log.
119
+ */
120
+ static warn(message: any, context?: string): void;
121
+ static warn(message: any, ...optionalParams: [...any, string?]): void;
122
+ /**
123
+ * Write a 'debug' level log, if the configured level allows for it.
124
+ * Prints to `stdout` with newline.
125
+ */
126
+ static debug(message: any, context?: string): void;
127
+ static debug(message: any, ...optionalParams: [...any, string?]): void;
128
+ /**
129
+ * Write a 'verbose' level log.
130
+ */
131
+ static verbose(message: any, context?: string): void;
132
+ static verbose(message: any, ...optionalParams: [...any, string?]): void;
133
+ /**
134
+ * Write a 'fatal' level log.
135
+ */
136
+ static fatal(message: any, context?: string): void;
137
+ static fatal(message: any, ...optionalParams: [...any, string?]): void;
138
+ /**
139
+ * Print buffered logs and detach buffer.
140
+ */
141
+ static flush(): void;
142
+ /**
143
+ * Attach buffer.
144
+ * Turns on initialization logs buffering.
145
+ */
146
+ static attachBuffer(): void;
147
+ /**
148
+ * Detach buffer.
149
+ * Turns off initialization logs buffering.
150
+ */
151
+ static detachBuffer(): void;
152
+ static getTimestamp(): string;
153
+ static overrideLogger(logger: LoggerService | LogLevel[] | boolean): any;
154
+ static isLevelEnabled(level: LogLevel): boolean;
155
+ private registerLocalInstanceRef;
156
+ }
157
+ export {};