@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,142 @@
1
+ import { Scope, Type } from "@venok/core/interfaces";
2
+ import { InjectionToken, OptionalFactoryDependency } from "@venok/core/interfaces/modules";
3
+ /**
4
+ *
5
+ * @publicApi
6
+ */
7
+ export type Provider<T = any> = Type<any> | ClassProvider<T> | ValueProvider<T> | FactoryProvider<T> | ExistingProvider<T>;
8
+ /**
9
+ * Interface defining a *Class* type provider.
10
+ *
11
+ * For example:
12
+ * ```typescript
13
+ * const configServiceProvider = {
14
+ * provide: ConfigService,
15
+ * useClass:
16
+ * process.env.NODE_ENV === 'development'
17
+ * ? DevelopmentConfigService
18
+ * : ProductionConfigService,
19
+ * };
20
+ * ```
21
+ *
22
+ * @publicApi
23
+ */
24
+ export interface ClassProvider<T = any> {
25
+ /**
26
+ * Injection token
27
+ */
28
+ provide: InjectionToken;
29
+ /**
30
+ * Type (class name) of provider (instance to be injected).
31
+ */
32
+ useClass: Type<T>;
33
+ /**
34
+ * Optional enum defining lifetime of the provider that is injected.
35
+ */
36
+ scope?: Scope;
37
+ /**
38
+ * This option is only available on factory providers!
39
+ *
40
+ */
41
+ inject?: never;
42
+ /**
43
+ * Flags provider as durable. This flag can be used in combination with custom context id
44
+ * factory strategy to construct lazy DI subtrees.
45
+ *
46
+ * This flag can be used only in conjunction with scope = Scope.REQUEST.
47
+ */
48
+ durable?: boolean;
49
+ }
50
+ /**
51
+ * Interface defining a *Value* type provider.
52
+ *
53
+ * For example:
54
+ * ```typescript
55
+ * const connectionProvider = {
56
+ * provide: 'CONNECTION',
57
+ * useValue: connection,
58
+ * };
59
+ * ```
60
+ *
61
+ * @publicApi
62
+ */
63
+ export interface ValueProvider<T = any> {
64
+ /**
65
+ * Injection token
66
+ */
67
+ provide: InjectionToken;
68
+ /**
69
+ * Instance of a provider to be injected.
70
+ */
71
+ useValue: T;
72
+ /**
73
+ * This option is only available on factory providers!
74
+ *
75
+ */
76
+ inject?: never;
77
+ }
78
+ /**
79
+ * Interface defining a *Factory* type provider.
80
+ *
81
+ * For example:
82
+ * ```typescript
83
+ * const connectionFactory = {
84
+ * provide: 'CONNECTION',
85
+ * useFactory: (optionsProvider: OptionsProvider) => {
86
+ * const options = optionsProvider.get();
87
+ * return new DatabaseConnection(options);
88
+ * },
89
+ * inject: [OptionsProvider],
90
+ * };
91
+ * ```
92
+ *
93
+ * @publicApi
94
+ */
95
+ export interface FactoryProvider<T = any> {
96
+ /**
97
+ * Injection token
98
+ */
99
+ provide: InjectionToken;
100
+ /**
101
+ * Factory function that returns an instance of the provider to be injected.
102
+ */
103
+ useFactory: (...args: any[]) => T | Promise<T>;
104
+ /**
105
+ * Optional list of providers to be injected into the context of the Factory function.
106
+ */
107
+ inject?: Array<InjectionToken | OptionalFactoryDependency>;
108
+ /**
109
+ * Optional enum defining lifetime of the provider that is returned by the Factory function.
110
+ */
111
+ scope?: Scope;
112
+ /**
113
+ * Flags provider as durable. This flag can be used in combination with custom context id
114
+ * factory strategy to construct lazy DI subtrees.
115
+ *
116
+ * This flag can be used only in conjunction with scope = Scope.REQUEST.
117
+ */
118
+ durable?: boolean;
119
+ }
120
+ /**
121
+ * Interface defining an *Existing* (aliased) type provider.
122
+ *
123
+ * For example:
124
+ * ```typescript
125
+ * const loggerAliasProvider = {
126
+ * provide: 'AliasedLoggerService',
127
+ * useExisting: LoggerService
128
+ * };
129
+ * ```
130
+ *
131
+ * @publicApi
132
+ */
133
+ export interface ExistingProvider<T = any> {
134
+ /**
135
+ * Injection token
136
+ */
137
+ provide: InjectionToken;
138
+ /**
139
+ * Provider to be aliased by the Injection token.
140
+ */
141
+ useExisting: any;
142
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -0,0 +1,35 @@
1
+ /**
2
+ * @publicApi
3
+ */
4
+ export declare enum Scope {
5
+ /**
6
+ * The provider can be shared across multiple classes. The provider lifetime
7
+ * is strictly tied to the application lifecycle. Once the application has
8
+ * bootstrapped, all providers have been instantiated.
9
+ */
10
+ DEFAULT = 0,
11
+ /**
12
+ * A new private instance of the provider is instantiated for every use
13
+ */
14
+ TRANSIENT = 1,
15
+ /**
16
+ * A new instance is instantiated for each request processing pipeline
17
+ */
18
+ REQUEST = 2
19
+ }
20
+ /**
21
+ * @publicApi
22
+ */
23
+ export interface ScopeOptions {
24
+ /**
25
+ * Specifies the lifetime of an injected Provider or Controller.
26
+ */
27
+ scope?: Scope;
28
+ /**
29
+ * Flags provider as durable. This flag can be used in combination with custom context id
30
+ * factory strategy to construct lazy DI subtrees.
31
+ *
32
+ * This flag can be used only in conjunction with scope = Scope.REQUEST.
33
+ */
34
+ durable?: boolean;
35
+ }
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Scope = void 0;
4
+ /**
5
+ * @publicApi
6
+ */
7
+ var Scope;
8
+ (function (Scope) {
9
+ /**
10
+ * The provider can be shared across multiple classes. The provider lifetime
11
+ * is strictly tied to the application lifecycle. Once the application has
12
+ * bootstrapped, all providers have been instantiated.
13
+ */
14
+ Scope[Scope["DEFAULT"] = 0] = "DEFAULT";
15
+ /**
16
+ * A new private instance of the provider is instantiated for every use
17
+ */
18
+ Scope[Scope["TRANSIENT"] = 1] = "TRANSIENT";
19
+ /**
20
+ * A new instance is instantiated for each request processing pipeline
21
+ */
22
+ Scope[Scope["REQUEST"] = 2] = "REQUEST";
23
+ })(Scope || (exports.Scope = Scope = {}));
@@ -0,0 +1,3 @@
1
+ export interface Type<T = any> extends Function {
2
+ new (...args: any[]): T;
3
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -0,0 +1,4 @@
1
+ export declare class MetadataScanner {
2
+ private readonly cachedScannedPrototypes;
3
+ getAllMethodNames(prototype: object | null): string[];
4
+ }
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.MetadataScanner = void 0;
4
+ const shared_helper_1 = require("@venok/core/helpers/shared.helper");
5
+ class MetadataScanner {
6
+ constructor() {
7
+ this.cachedScannedPrototypes = new Map();
8
+ }
9
+ getAllMethodNames(prototype) {
10
+ if (!prototype)
11
+ return [];
12
+ if (this.cachedScannedPrototypes.has(prototype)) {
13
+ return this.cachedScannedPrototypes.get(prototype);
14
+ }
15
+ const visitedNames = new Map();
16
+ const result = [];
17
+ this.cachedScannedPrototypes.set(prototype, result);
18
+ do {
19
+ for (const property of Object.getOwnPropertyNames(prototype)) {
20
+ if (visitedNames.has(property))
21
+ continue;
22
+ visitedNames.set(property, true);
23
+ const descriptor = Object.getOwnPropertyDescriptor(prototype, property);
24
+ if (descriptor?.set || descriptor?.get)
25
+ continue;
26
+ if ((0, shared_helper_1.isConstructor)(property) || !(0, shared_helper_1.isFunction)(prototype[property]))
27
+ continue;
28
+ result.push(property);
29
+ }
30
+ } while ((prototype = Reflect.getPrototypeOf(prototype)) && prototype !== Object.prototype);
31
+ return result;
32
+ }
33
+ }
34
+ exports.MetadataScanner = MetadataScanner;
@@ -0,0 +1,93 @@
1
+ import { DEFAULT_FACTORY_CLASS_METHOD_KEY, DEFAULT_METHOD_KEY } from "@venok/core/module/constants";
2
+ import { DynamicModule } from "@venok/core/interfaces";
3
+ import { Logger } from "@venok/core/services/logger.service";
4
+ import { ConfigurableModuleHost } from "@venok/core/interfaces/modules/configurable";
5
+ /**
6
+ * @publicApi
7
+ */
8
+ export interface ConfigurableModuleBuilderOptions {
9
+ /**
10
+ * Specified what injection token should be used for the module options provider.
11
+ * By default, an auto-generated UUID will be used.
12
+ */
13
+ optionsInjectionToken?: string | symbol;
14
+ /**
15
+ * By default, a UUID will be used as a module options provider token.
16
+ * Explicitly specifying the "moduleName" will instruct the "ConfigurableModuleBuilder"
17
+ * to use a more descriptive provider token.
18
+ *
19
+ * For example, if `moduleName: "Cache"` then auto-generated provider token will be "CACHE_MODULE_OPTIONS".
20
+ */
21
+ moduleName?: string;
22
+ /**
23
+ * Indicates whether module should always be "transient", meaning,
24
+ * every time you call the static method to construct a dynamic module,
25
+ * regardless of what arguments you pass in, a new "unique" module will be created.
26
+ *
27
+ * @default false
28
+ */
29
+ alwaysTransient?: boolean;
30
+ }
31
+ /**
32
+ * Factory that lets you create configurable module and
33
+ * provides a way to reduce the majority of dynamic module boilerplate.
34
+ *
35
+ * @publicApi
36
+ */
37
+ export declare class ConfigurableModuleBuilder<ModuleOptions, StaticMethodKey extends string = typeof DEFAULT_METHOD_KEY, FactoryClassMethodKey extends string = typeof DEFAULT_FACTORY_CLASS_METHOD_KEY, ExtraModuleDefinitionOptions = {}> {
38
+ protected readonly options: ConfigurableModuleBuilderOptions;
39
+ protected staticMethodKey: StaticMethodKey;
40
+ protected factoryClassMethodKey: FactoryClassMethodKey;
41
+ protected extras: ExtraModuleDefinitionOptions;
42
+ protected transformModuleDefinition: (definition: DynamicModule, extraOptions: ExtraModuleDefinitionOptions) => DynamicModule;
43
+ protected readonly logger: Logger;
44
+ constructor(options?: ConfigurableModuleBuilderOptions, parentBuilder?: ConfigurableModuleBuilder<ModuleOptions>);
45
+ /**
46
+ * Registers the "extras" object (a set of extra options that can be used to modify the dynamic module definition).
47
+ * Values you specify within the "extras" object will be used as default values (that can be overridden by module consumers).
48
+ *
49
+ * This method also applies the so-called "module definition transform function" that takes the auto-generated
50
+ * dynamic module object ("DynamicModule") and the actual consumer "extras" object as input parameters.
51
+ * The "extras" object consists of values explicitly specified by module consumers and default values.
52
+ *
53
+ * @example
54
+ * ```typescript
55
+ * .setExtras<{ isGlobal?: boolean }>({ isGlobal: false }, (definition, extras) =>
56
+ * ({ ...definition, global: extras.isGlobal })
57
+ * )
58
+ * ```
59
+ */
60
+ setExtras<ExtraModuleDefinitionOptions>(extras: ExtraModuleDefinitionOptions, transformDefinition?: (definition: DynamicModule, extras: ExtraModuleDefinitionOptions) => DynamicModule): ConfigurableModuleBuilder<ModuleOptions, StaticMethodKey, FactoryClassMethodKey, ExtraModuleDefinitionOptions>;
61
+ /**
62
+ * Dynamic module must expose public static methods that let you pass in
63
+ * configuration parameters (control the module's behavior from the outside).
64
+ * Some frequently used names that you may have seen in other module are:
65
+ * "forRoot", "forFeature", "register", "configure".
66
+ *
67
+ * This method "setClassMethodName" lets you specify the name of the
68
+ * method that will be auto-generated.
69
+ *
70
+ * @param key name of the method
71
+ */
72
+ setClassMethodName<StaticMethodKey extends string>(key: StaticMethodKey): ConfigurableModuleBuilder<ModuleOptions, StaticMethodKey, FactoryClassMethodKey, ExtraModuleDefinitionOptions>;
73
+ /**
74
+ * Asynchronously configured module (that rely on other module, i.e. "ConfigModule")
75
+ * let you pass the configuration factory class that will be registered and instantiated as a provider.
76
+ * This provider then will be used to retrieve the module's configuration. To provide the configuration,
77
+ * the corresponding factory method must be implemented.
78
+ *
79
+ * This method ("setFactoryMethodName") lets you control what method name will have to be
80
+ * implemented by the config factory (default is "create").
81
+ *
82
+ * @param key name of the method
83
+ */
84
+ setFactoryMethodName<FactoryClassMethodKey extends string>(key: FactoryClassMethodKey): ConfigurableModuleBuilder<ModuleOptions, StaticMethodKey, FactoryClassMethodKey, ExtraModuleDefinitionOptions>;
85
+ /**
86
+ * Returns an object consisting of multiple properties that lets you
87
+ * easily construct dynamic configurable module. See "ConfigurableModuleHost" interface for more details.
88
+ */
89
+ build(): ConfigurableModuleHost<ModuleOptions, StaticMethodKey, FactoryClassMethodKey, ExtraModuleDefinitionOptions>;
90
+ private constructInjectionTokenString;
91
+ private createConfigurableModuleCls;
92
+ private createTypeProxy;
93
+ }
@@ -0,0 +1,204 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ConfigurableModuleBuilder = void 0;
4
+ const constants_1 = require("@venok/core/module/constants");
5
+ const logger_service_1 = require("@venok/core/services/logger.service");
6
+ const helpers_1 = require("@venok/core/module/helpers");
7
+ const random_string_generator_helper_1 = require("@venok/core/helpers/random-string-generator.helper");
8
+ /**
9
+ * Factory that lets you create configurable module and
10
+ * provides a way to reduce the majority of dynamic module boilerplate.
11
+ *
12
+ * @publicApi
13
+ */
14
+ class ConfigurableModuleBuilder {
15
+ constructor(options = {}, parentBuilder) {
16
+ this.options = options;
17
+ this.logger = new logger_service_1.Logger(ConfigurableModuleBuilder.name);
18
+ if (parentBuilder) {
19
+ this.staticMethodKey = parentBuilder.staticMethodKey;
20
+ this.factoryClassMethodKey = parentBuilder.factoryClassMethodKey;
21
+ this.transformModuleDefinition = parentBuilder.transformModuleDefinition;
22
+ this.extras = parentBuilder.extras;
23
+ }
24
+ }
25
+ /**
26
+ * Registers the "extras" object (a set of extra options that can be used to modify the dynamic module definition).
27
+ * Values you specify within the "extras" object will be used as default values (that can be overridden by module consumers).
28
+ *
29
+ * This method also applies the so-called "module definition transform function" that takes the auto-generated
30
+ * dynamic module object ("DynamicModule") and the actual consumer "extras" object as input parameters.
31
+ * The "extras" object consists of values explicitly specified by module consumers and default values.
32
+ *
33
+ * @example
34
+ * ```typescript
35
+ * .setExtras<{ isGlobal?: boolean }>({ isGlobal: false }, (definition, extras) =>
36
+ * ({ ...definition, global: extras.isGlobal })
37
+ * )
38
+ * ```
39
+ */
40
+ setExtras(extras, transformDefinition = (def) => def) {
41
+ const builder = new ConfigurableModuleBuilder(this.options, this);
42
+ builder.extras = extras;
43
+ builder.transformModuleDefinition = transformDefinition;
44
+ return builder;
45
+ }
46
+ /**
47
+ * Dynamic module must expose public static methods that let you pass in
48
+ * configuration parameters (control the module's behavior from the outside).
49
+ * Some frequently used names that you may have seen in other module are:
50
+ * "forRoot", "forFeature", "register", "configure".
51
+ *
52
+ * This method "setClassMethodName" lets you specify the name of the
53
+ * method that will be auto-generated.
54
+ *
55
+ * @param key name of the method
56
+ */
57
+ setClassMethodName(key) {
58
+ const builder = new ConfigurableModuleBuilder(this.options, this);
59
+ builder.staticMethodKey = key;
60
+ return builder;
61
+ }
62
+ /**
63
+ * Asynchronously configured module (that rely on other module, i.e. "ConfigModule")
64
+ * let you pass the configuration factory class that will be registered and instantiated as a provider.
65
+ * This provider then will be used to retrieve the module's configuration. To provide the configuration,
66
+ * the corresponding factory method must be implemented.
67
+ *
68
+ * This method ("setFactoryMethodName") lets you control what method name will have to be
69
+ * implemented by the config factory (default is "create").
70
+ *
71
+ * @param key name of the method
72
+ */
73
+ setFactoryMethodName(key) {
74
+ const builder = new ConfigurableModuleBuilder(this.options, this);
75
+ builder.factoryClassMethodKey = key;
76
+ return builder;
77
+ }
78
+ /**
79
+ * Returns an object consisting of multiple properties that lets you
80
+ * easily construct dynamic configurable module. See "ConfigurableModuleHost" interface for more details.
81
+ */
82
+ build() {
83
+ this.staticMethodKey ??= constants_1.DEFAULT_METHOD_KEY;
84
+ this.factoryClassMethodKey ??= constants_1.DEFAULT_FACTORY_CLASS_METHOD_KEY;
85
+ this.options.optionsInjectionToken ??= this.options.moduleName
86
+ ? this.constructInjectionTokenString()
87
+ : (0, helpers_1.generateOptionsInjectionToken)();
88
+ this.transformModuleDefinition ??= (definition) => definition;
89
+ return {
90
+ ConfigurableModuleClass: this.createConfigurableModuleCls(),
91
+ MODULE_OPTIONS_TOKEN: this.options.optionsInjectionToken,
92
+ ASYNC_OPTIONS_TYPE: this.createTypeProxy("ASYNC_OPTIONS_TYPE"),
93
+ OPTIONS_TYPE: this.createTypeProxy("OPTIONS_TYPE"),
94
+ };
95
+ }
96
+ constructInjectionTokenString() {
97
+ const moduleNameInSnakeCase = (this.options.moduleName ?? (0, random_string_generator_helper_1.randomStringGenerator)())
98
+ .trim()
99
+ .split(/(?=[A-Z])/)
100
+ .join("_")
101
+ .toUpperCase();
102
+ return `${moduleNameInSnakeCase}_MODULE_OPTIONS`;
103
+ }
104
+ createConfigurableModuleCls() {
105
+ // eslint-disable-next-line @typescript-eslint/no-this-alias
106
+ const self = this;
107
+ const asyncMethodKey = this.staticMethodKey + constants_1.ASYNC_METHOD_SUFFIX;
108
+ class InternalModuleClass {
109
+ static [self.staticMethodKey](options) {
110
+ const providers = [
111
+ {
112
+ provide: self.options.optionsInjectionToken,
113
+ useValue: this.omitExtras(options, self.extras),
114
+ },
115
+ ];
116
+ if (self.options.alwaysTransient) {
117
+ providers.push({
118
+ provide: constants_1.CONFIGURABLE_MODULE_ID,
119
+ useValue: (0, random_string_generator_helper_1.randomStringGenerator)(),
120
+ });
121
+ }
122
+ return self.transformModuleDefinition({
123
+ module: this,
124
+ providers,
125
+ }, {
126
+ ...self.extras,
127
+ ...options,
128
+ });
129
+ }
130
+ static [asyncMethodKey](options) {
131
+ const providers = this.createAsyncProviders(options);
132
+ if (self.options.alwaysTransient) {
133
+ providers.push({
134
+ provide: constants_1.CONFIGURABLE_MODULE_ID,
135
+ useValue: (0, random_string_generator_helper_1.randomStringGenerator)(),
136
+ });
137
+ }
138
+ return self.transformModuleDefinition({
139
+ module: this,
140
+ imports: options.imports || [],
141
+ providers,
142
+ }, {
143
+ ...self.extras,
144
+ ...options,
145
+ });
146
+ }
147
+ static omitExtras(input, extras) {
148
+ if (!extras)
149
+ return input;
150
+ const moduleOptions = {};
151
+ const extrasKeys = Object.keys(extras);
152
+ Object.keys(input)
153
+ .filter((key) => !extrasKeys.includes(key))
154
+ .forEach((key) => {
155
+ // @ts-ignore
156
+ moduleOptions[key] = input[key];
157
+ });
158
+ return moduleOptions;
159
+ }
160
+ static createAsyncProviders(options) {
161
+ if (options.useExisting || options.useFactory) {
162
+ if (options.inject && options.provideInjectionTokensFrom) {
163
+ return [
164
+ this.createAsyncOptionsProvider(options),
165
+ ...(0, helpers_1.getInjectionProviders)(options.provideInjectionTokensFrom, options.inject),
166
+ ];
167
+ }
168
+ return [this.createAsyncOptionsProvider(options)];
169
+ }
170
+ return [
171
+ this.createAsyncOptionsProvider(options),
172
+ {
173
+ provide: options.useClass,
174
+ useClass: options.useClass,
175
+ },
176
+ ];
177
+ }
178
+ static createAsyncOptionsProvider(options) {
179
+ if (options.useFactory) {
180
+ return {
181
+ provide: self.options.optionsInjectionToken,
182
+ useFactory: options.useFactory,
183
+ inject: options.inject || [],
184
+ };
185
+ }
186
+ return {
187
+ provide: self.options.optionsInjectionToken,
188
+ useFactory: async (optionsFactory) => await optionsFactory[self.factoryClassMethodKey](),
189
+ inject: [options.useExisting || options.useClass],
190
+ };
191
+ }
192
+ }
193
+ return InternalModuleClass;
194
+ }
195
+ createTypeProxy(typeName) {
196
+ const proxy = new Proxy({}, {
197
+ get: () => {
198
+ throw new Error(`"${typeName}" is not supposed to be used as a value.`);
199
+ },
200
+ });
201
+ return proxy;
202
+ }
203
+ }
204
+ exports.ConfigurableModuleBuilder = ConfigurableModuleBuilder;
@@ -0,0 +1,4 @@
1
+ export declare const DEFAULT_METHOD_KEY = "register";
2
+ export declare const DEFAULT_FACTORY_CLASS_METHOD_KEY = "create";
3
+ export declare const ASYNC_METHOD_SUFFIX = "Async";
4
+ export declare const CONFIGURABLE_MODULE_ID = "CONFIGURABLE_MODULE_ID";
@@ -0,0 +1,7 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.CONFIGURABLE_MODULE_ID = exports.ASYNC_METHOD_SUFFIX = exports.DEFAULT_FACTORY_CLASS_METHOD_KEY = exports.DEFAULT_METHOD_KEY = void 0;
4
+ exports.DEFAULT_METHOD_KEY = 'register';
5
+ exports.DEFAULT_FACTORY_CLASS_METHOD_KEY = 'create';
6
+ exports.ASYNC_METHOD_SUFFIX = 'Async';
7
+ exports.CONFIGURABLE_MODULE_ID = 'CONFIGURABLE_MODULE_ID';
@@ -0,0 +1 @@
1
+ export declare function generateOptionsInjectionToken(): string;
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.generateOptionsInjectionToken = void 0;
4
+ const random_string_generator_helper_1 = require("@venok/core/helpers/random-string-generator.helper");
5
+ function generateOptionsInjectionToken() {
6
+ const hash = (0, random_string_generator_helper_1.randomStringGenerator)();
7
+ return `CONFIGURABLE_MODULE_OPTIONS[${hash}]`;
8
+ }
9
+ exports.generateOptionsInjectionToken = generateOptionsInjectionToken;
@@ -0,0 +1,8 @@
1
+ import { FactoryProvider, Provider } from "@venok/core/interfaces";
2
+ /**
3
+ *
4
+ * @param providers List of a module's providers
5
+ * @param tokens Injection tokens needed for a useFactory function (usually the module's options' token)
6
+ * @returns All the providers needed for the tokens' injection (searched recursively)
7
+ */
8
+ export declare function getInjectionProviders(providers: Provider[], tokens: FactoryProvider["inject"]): Provider[];
@@ -0,0 +1,36 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getInjectionProviders = void 0;
4
+ /**
5
+ * check if x is OptionalFactoryDependency, based on prototype presence
6
+ * (to avoid classes with a static 'token' field)
7
+ * @param x
8
+ * @returns x is OptionalFactoryDependency
9
+ */
10
+ function isOptionalFactoryDependency(x) {
11
+ return !!(x?.token && !x?.prototype);
12
+ }
13
+ const mapInjectToTokens = (t) => isOptionalFactoryDependency(t) ? t.token : t;
14
+ /**
15
+ *
16
+ * @param providers List of a module's providers
17
+ * @param tokens Injection tokens needed for a useFactory function (usually the module's options' token)
18
+ * @returns All the providers needed for the tokens' injection (searched recursively)
19
+ */
20
+ function getInjectionProviders(providers, tokens) {
21
+ const result = [];
22
+ let search = tokens.map(mapInjectToTokens);
23
+ while (search.length > 0) {
24
+ const match = (providers ?? []).filter((p) => !result.includes(p) && // this prevents circular loops and duplication
25
+ (search.includes(p) || search.includes(p?.provide)));
26
+ result.push(...match);
27
+ // get injection tokens of the matched providers, if any
28
+ search = match
29
+ .filter((p) => p?.inject)
30
+ .map((p) => p.inject)
31
+ .flat()
32
+ .map(mapInjectToTokens);
33
+ }
34
+ return result;
35
+ }
36
+ exports.getInjectionProviders = getInjectionProviders;
@@ -0,0 +1,2 @@
1
+ export * from "./generate-options-injection-token.helper";
2
+ export * from "./get-injection-providers.helper";
@@ -0,0 +1,18 @@
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("./generate-options-injection-token.helper"), exports);
18
+ __exportStar(require("./get-injection-providers.helper"), exports);
@@ -0,0 +1,2 @@
1
+ export * from "./configurable-module.builder";
2
+ export * from "../interfaces/modules/configurable";