@futdevpro/nts-dynamo 1.15.13 → 1.15.14

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 (352) hide show
  1. package/.c8rc.json +26 -26
  2. package/.copilot/patterns.json +7 -7
  3. package/.cursor/rules/__assistant_guide.mdc +30 -30
  4. package/.cursor/rules/_ag_backend-structure.mdc +85 -85
  5. package/.cursor/rules/_ag_backend.mdc +16 -16
  6. package/.cursor/rules/_ag_frontend-structure.mdc +86 -86
  7. package/.cursor/rules/_ag_frontend.mdc +39 -39
  8. package/.cursor/rules/_ag_import-rules.mdc +44 -44
  9. package/.cursor/rules/_ag_naming.mdc +115 -115
  10. package/.cursor/rules/_ag_should-be.mdc +6 -6
  11. package/.cursor/rules/ai_development_guide.md +60 -60
  12. package/.cursor/rules/cursor-rules.md +160 -160
  13. package/.cursor/rules/default-command.mdc +464 -464
  14. package/.cursor/rules/error_code_pattern.md +39 -39
  15. package/.cursor/rules/saved rule mcp server use.md +15 -15
  16. package/.vscode/settings.json +10 -10
  17. package/HOWTO.md +15 -15
  18. package/LICENSE +21 -21
  19. package/__documentations/nts-integration-tests-2026-03-17.md +26 -26
  20. package/_specifications/BACKLOG.md +50 -22
  21. package/_specifications/TODO.md +15 -15
  22. package/_specifications/agent.md +138 -138
  23. package/build/_collections/global-settings.const.d.ts.map +1 -1
  24. package/build/_collections/global-settings.const.js +4 -0
  25. package/build/_collections/global-settings.const.js.map +1 -1
  26. package/build/_models/interfaces/global-log-settings.interface.d.ts +11 -0
  27. package/build/_models/interfaces/global-log-settings.interface.d.ts.map +1 -1
  28. package/build/_modules/logs/get-logs-routing-module.util.d.ts +19 -0
  29. package/build/_modules/logs/get-logs-routing-module.util.d.ts.map +1 -0
  30. package/build/_modules/logs/get-logs-routing-module.util.js +32 -0
  31. package/build/_modules/logs/get-logs-routing-module.util.js.map +1 -0
  32. package/build/_modules/logs/index.d.ts +4 -0
  33. package/build/_modules/logs/index.d.ts.map +1 -0
  34. package/build/_modules/logs/index.js +10 -0
  35. package/build/_modules/logs/index.js.map +1 -0
  36. package/build/_modules/logs/log-buffer.service.d.ts +38 -0
  37. package/build/_modules/logs/log-buffer.service.d.ts.map +1 -0
  38. package/build/_modules/logs/log-buffer.service.js +97 -0
  39. package/build/_modules/logs/log-buffer.service.js.map +1 -0
  40. package/build/_modules/logs/logs.controller.d.ts +27 -0
  41. package/build/_modules/logs/logs.controller.d.ts.map +1 -0
  42. package/build/_modules/logs/logs.controller.js +90 -0
  43. package/build/_modules/logs/logs.controller.js.map +1 -0
  44. package/build/_modules/logs/logs.service.d.ts +40 -0
  45. package/build/_modules/logs/logs.service.d.ts.map +1 -0
  46. package/build/_modules/logs/logs.service.js +97 -0
  47. package/build/_modules/logs/logs.service.js.map +1 -0
  48. package/build/_modules/server/errors/errors.data-service.d.ts.map +1 -1
  49. package/build/_modules/server/errors/errors.data-service.js +2 -1
  50. package/build/_modules/server/errors/errors.data-service.js.map +1 -1
  51. package/eslint.config.js +3 -3
  52. package/nodemon.json +24 -24
  53. package/package.json +359 -353
  54. package/scripts/run-coverage-tests.js +28 -28
  55. package/spec/support/helpers/spec-reporter-loader.js +359 -359
  56. package/spec/support/helpers/ts-node-helper.js +93 -93
  57. package/spec/support/jasmine.coverage.json +24 -24
  58. package/spec/support/jasmine.json +24 -24
  59. package/src/_collections/archive.util.spec.ts +57 -57
  60. package/src/_collections/archive.util.ts +18 -18
  61. package/src/_collections/atlas-default-db-options.const.ts +9 -9
  62. package/src/_collections/default-fallback-cache-max-age.const.spec.ts +11 -11
  63. package/src/_collections/default-fallback-cache-max-age.const.ts +2 -2
  64. package/src/_collections/default-not-found-page.const.spec.ts +19 -19
  65. package/src/_collections/default-not-found-page.const.ts +22 -22
  66. package/src/_collections/default-socket-path.const.spec.ts +12 -12
  67. package/src/_collections/default-socket-path.const.ts +2 -2
  68. package/src/_collections/get-environment-settings.util.spec.ts +210 -210
  69. package/src/_collections/get-environment-settings.util.ts +48 -48
  70. package/src/_collections/global-settings.const.ts +5 -0
  71. package/src/_collections/sample.env +21 -21
  72. package/src/_collections/star.controller.spec.ts +224 -224
  73. package/src/_collections/star.controller.ts +129 -129
  74. package/src/_enums/data-model-type.enum.ts +14 -14
  75. package/src/_enums/data-service-function.enum.ts +24 -24
  76. package/src/_enums/predefined-data-types.enum.ts +16 -16
  77. package/src/_enums/route-security.enum.ts +12 -12
  78. package/src/_models/control-models/api-call-params.control-model.spec.ts +152 -152
  79. package/src/_models/control-models/api-call-params.control-model.ts +142 -142
  80. package/src/_models/control-models/app-ext-system-controls.control-model.spec.ts +52 -52
  81. package/src/_models/control-models/app-ext-system-controls.control-model.ts +9 -9
  82. package/src/_models/control-models/app-params.control-model.spec.ts +225 -225
  83. package/src/_models/control-models/app-params.control-model.ts +136 -136
  84. package/src/_models/control-models/app-system-controls.control-model.spec.ts +31 -31
  85. package/src/_models/control-models/app-system-controls.control-model.ts +9 -9
  86. package/src/_models/control-models/endpoint-params.control-model.spec.ts +578 -578
  87. package/src/_models/control-models/endpoint-params.control-model.ts +526 -526
  88. package/src/_models/control-models/http-settings.control-model.spec.ts +77 -77
  89. package/src/_models/control-models/http-settings.control-model.ts +37 -37
  90. package/src/_models/control-models/system-control.control-model.spec.ts +27 -27
  91. package/src/_models/control-models/system-control.control-model.ts +12 -12
  92. package/src/_models/interfaces/certification-settings.interface.ts +7 -7
  93. package/src/_models/interfaces/environment-settings.interface.ts +59 -59
  94. package/src/_models/interfaces/global-log-settings.interface.ts +108 -96
  95. package/src/_models/interfaces/global-service-settings.interface.ts +47 -47
  96. package/src/_models/interfaces/routing-module-settings.interface.ts +21 -21
  97. package/src/_models/interfaces/static-client-settings.interface.spec.ts +29 -29
  98. package/src/_models/interfaces/static-client-settings.interface.ts +28 -28
  99. package/src/_models/types/db-update.type.ts +100 -100
  100. package/src/_modules/ai/_models/ai-input-interfaces.ts +117 -117
  101. package/src/_modules/ai/_models/ai-test-generation-result.interface.ts +16 -16
  102. package/src/_modules/ai/_modules/anthropic/_services/aai-user-key.control-service.ts +138 -138
  103. package/src/_modules/ai/_modules/anthropic/index.ts +5 -5
  104. package/src/_modules/ai/_modules/document-ai/_collections/dai-chunking.util.spec.ts +242 -242
  105. package/src/_modules/ai/_modules/document-ai/_collections/dai-chunking.util.ts +639 -639
  106. package/src/_modules/ai/_modules/document-ai/_collections/dai-document.util.spec.ts +209 -209
  107. package/src/_modules/ai/_modules/document-ai/_collections/dai-document.util.ts +85 -85
  108. package/src/_modules/ai/_modules/document-ai/_enums/dai-compare-result-type.enum.ts +7 -7
  109. package/src/_modules/ai/_modules/document-ai/_models/data-models/dai-doc-chunk.data-model.ts +146 -146
  110. package/src/_modules/ai/_modules/document-ai/_models/data-models/dai-doc-page.data-model.ts +162 -162
  111. package/src/_modules/ai/_modules/document-ai/_models/data-models/dai-document.data-model.ts +99 -99
  112. package/src/_modules/ai/_modules/document-ai/_models/interfaces/dai-doc-chunk-compare-result.interface.ts +18 -18
  113. package/src/_modules/ai/_modules/document-ai/_models/interfaces/dai-doc-page-compare-result.interface.ts +19 -19
  114. package/src/_modules/ai/_modules/document-ai/_models/interfaces/dai-document-compare-result.interface.ts +25 -25
  115. package/src/_modules/ai/_modules/document-ai/index.ts +28 -28
  116. package/src/_modules/ai/_modules/fdp-ai/_services/fdpai-user-key.control-service.ts +189 -189
  117. package/src/_modules/ai/_modules/fdp-ai/index.ts +5 -5
  118. package/src/_modules/ai/_modules/open-ai/_collections/oai-global-settings.const.ts +9 -9
  119. package/src/_modules/ai/_modules/open-ai/_collections/oai-llm-predefined-requests-hu.conts.ts +82 -82
  120. package/src/_modules/ai/_modules/open-ai/_collections/oai-llm-predefined-requests.conts.ts +75 -75
  121. package/src/_modules/ai/_modules/open-ai/_enums/oai-gpt-message-role.enum.ts +45 -45
  122. package/src/_modules/ai/_modules/open-ai/_models/interfaces/oai-global-settings.interface.ts +7 -7
  123. package/src/_modules/ai/_modules/open-ai/_models/interfaces/oai-gpt-message.interface.ts +7 -7
  124. package/src/_modules/ai/_modules/open-ai/_models/interfaces/oai-llm-predefined-requests.interface.ts +57 -57
  125. package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-doc-chunk-data.service.ts +292 -292
  126. package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-document.data-service.spec.ts +342 -342
  127. package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-vector-data.service.spec.ts +550 -550
  128. package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-vector-data.service.ts +630 -630
  129. package/src/_modules/ai/_modules/open-ai/_services/oai-embedding.control-service.spec.ts +240 -240
  130. package/src/_modules/ai/_modules/open-ai/_services/oai-embedding.control-service.ts +98 -98
  131. package/src/_modules/ai/_modules/open-ai/_services/oai-llm-chat.service-base.spec.ts +462 -462
  132. package/src/_modules/ai/_modules/open-ai/_services/oai-llm-chat.service-base.ts +615 -615
  133. package/src/_modules/ai/_modules/open-ai/_services/oai-llm.service-base.spec.ts +437 -437
  134. package/src/_modules/ai/_modules/open-ai/_services/oai-llm.service-base.ts +833 -833
  135. package/src/_modules/ai/_modules/open-ai/_services/oai-user-key.control-service.ts +157 -157
  136. package/src/_modules/ai/_services/ai-embedding.service-base.spec.ts +98 -98
  137. package/src/_modules/ai/_services/ai-embedding.service-base.ts +48 -48
  138. package/src/_modules/ai/_services/ai-llm-chat.service-base.spec.ts +229 -229
  139. package/src/_modules/ai/_services/ai-llm-chat.service-base.ts +68 -68
  140. package/src/_modules/ai/_services/ai-llm.service-base.spec.ts +250 -250
  141. package/src/_modules/ai/_services/ai-llm.service-base.ts +332 -332
  142. package/src/_modules/ai/_services/ai-provider.service-base.spec.ts +79 -79
  143. package/src/_modules/ai/_services/ai-provider.service-base.ts +29 -29
  144. package/src/_modules/ai/_services/ai-user-key.service-base.ts +59 -59
  145. package/src/_modules/ai/index.ts +13 -13
  146. package/src/_modules/assistant/_collections/ass-global-settings.const.ts +13 -13
  147. package/src/_modules/assistant/_collections/ass.util.spec.ts +176 -176
  148. package/src/_modules/assistant/_collections/ass.util.ts +50 -50
  149. package/src/_modules/assistant/_models/ass-global-settings.interface.ts +15 -15
  150. package/src/_modules/assistant/_services/ass-io.control-service.spec.ts +140 -140
  151. package/src/_modules/assistant/_services/ass-main.control-service.spec.ts +192 -192
  152. package/src/_modules/assistant/_services/ass-main.control-service.ts +107 -107
  153. package/src/_modules/bot/_collections/bot-default-commands.const.ts +12 -12
  154. package/src/_modules/bot/_collections/bot-global-settings.const.ts +39 -39
  155. package/src/_modules/bot/_models/bot-channel-wrapper.interface.ts +62 -62
  156. package/src/_modules/bot/_models/bot-command.interface.ts +8 -8
  157. package/src/_modules/bot/_models/bot-global-settings.interface.ts +96 -96
  158. package/src/_modules/bot/_models/bot-last-mention-date.interface.ts +6 -6
  159. package/src/_modules/bot/_models/bot-last-message-date.interface.ts +5 -5
  160. package/src/_modules/bot/_models/bot-user-wrapper.interface.ts +41 -41
  161. package/src/_modules/bot/_modules/discord-bot/_models/dib-platform.types.ts +9 -9
  162. package/src/_modules/bot/_modules/discord-bot/_services/dib-messaging-provider.control-service.spec.ts +431 -431
  163. package/src/_modules/bot/_modules/dynamo-bot/_collections/dyb-operations.util.spec.ts +160 -160
  164. package/src/_modules/bot/_modules/dynamo-bot/_collections/dyb-operations.util.ts +55 -55
  165. package/src/_modules/bot/_modules/dynamo-bot/_models/dyb-platform.types.ts +15 -15
  166. package/src/_modules/bot/_modules/dynamo-bot/_services/dyb-messaging-provider.control-service.spec.ts +374 -374
  167. package/src/_modules/bot/_modules/dynamo-bot/_services/dyb-messaging-provider.control-service.ts +447 -447
  168. package/src/_modules/bot/_modules/dynamo-bot/index.ts +15 -15
  169. package/src/_modules/bot/_modules/slack-bot/_models/slb-platform.types.ts +9 -9
  170. package/src/_modules/bot/_modules/slack-bot/_services/slb-messaging-provider.control-service.spec.ts +344 -344
  171. package/src/_modules/bot/_modules/slack-bot/_services/slb-messaging-provider.control-service.ts +197 -197
  172. package/src/_modules/bot/_modules/teams-bot/_models/teb-platform.types.ts +9 -9
  173. package/src/_modules/bot/_modules/teams-bot/_services/teb-messaging-provider.control-service.spec.ts +345 -345
  174. package/src/_modules/bot/_modules/teams-bot/_services/teb-messaging-provider.control-service.ts +197 -197
  175. package/src/_modules/bot/_services/bot-commands.control-service.spec.ts +116 -116
  176. package/src/_modules/bot/_services/bot-io.control-service.spec.ts +285 -285
  177. package/src/_modules/bot/_services/bot-main.control-service.spec.ts +208 -208
  178. package/src/_modules/bot/_services/bot-messaging-provider.service-base.spec.ts +349 -349
  179. package/src/_modules/bot/_services/bot-routines.control-service.spec.ts +111 -111
  180. package/src/_modules/custom-data/custom-data.controller.spec.ts +49 -49
  181. package/src/_modules/custom-data/custom-data.controller.ts +67 -67
  182. package/src/_modules/custom-data/custom-data.data-service.spec.ts +54 -54
  183. package/src/_modules/custom-data/custom-data.data-service.ts +21 -21
  184. package/src/_modules/custom-data/get-custom-data-routing-module.util.spec.ts +28 -28
  185. package/src/_modules/custom-data/get-custom-data-routing-module.util.ts +24 -24
  186. package/src/_modules/custom-data/index.ts +9 -9
  187. package/src/_modules/defaults/_collections/default-endpoints.util.ts +487 -487
  188. package/src/_modules/defaults/_models/default-user.data-model.ts +72 -72
  189. package/src/_modules/defaults/_services/default-auth.service.spec.ts +269 -269
  190. package/src/_modules/defaults/_services/default-auth.service.ts +177 -177
  191. package/src/_modules/defaults/_services/default-socket-events.service.spec.ts +42 -42
  192. package/src/_modules/defaults/_services/default-socket-events.service.ts +61 -61
  193. package/src/_modules/defaults/_services/default-user.data-service.spec.ts +187 -187
  194. package/src/_modules/defaults/_services/default-user.data-service.ts +98 -98
  195. package/src/_modules/defaults/index.ts +17 -17
  196. package/src/_modules/discord-assistant/_collections/dias-global-settings.const.ts +19 -19
  197. package/src/_modules/discord-assistant/_collections/dias.util.spec.ts +366 -366
  198. package/src/_modules/discord-assistant/_collections/dias.util.ts +132 -132
  199. package/src/_modules/discord-assistant/_models/dias-global-settings.interface.ts +19 -19
  200. package/src/_modules/discord-assistant/_models/dias-knowledge.data-model.ts +52 -52
  201. package/src/_modules/discord-assistant/_services/dias-chunk.data-service.ts +177 -177
  202. package/src/_modules/discord-assistant/_services/dias-io.control-service.spec.ts +108 -108
  203. package/src/_modules/discord-assistant/_services/dias-io.control-service.ts +69 -69
  204. package/src/_modules/discord-assistant/_services/dias-main.control-service.spec.ts +22 -22
  205. package/src/_modules/discord-assistant/_services/dias-main.control-service.ts +27 -27
  206. package/src/_modules/discord-assistant/_services/dias.service-base.spec.ts +195 -195
  207. package/src/_modules/discord-assistant/_services/dias.service-base.ts +76 -76
  208. package/src/_modules/discord-assistant/index.ts +38 -38
  209. package/src/_modules/discord-assistant-voiced/_services/dias-discord-bot.control-service.spec.ts +34 -34
  210. package/src/_modules/discord-assistant-voiced/_services/dias-discord-bot.control-service.ts +11 -11
  211. package/src/_modules/discord-assistant-voiced/index.ts +36 -36
  212. package/src/_modules/discord-bot/_collections/dibo-default-commands.const.ts +16 -16
  213. package/src/_modules/discord-bot/_collections/dibo-global-settings.conts.ts +55 -55
  214. package/src/_modules/discord-bot/_collections/dibo-operations.util.spec.ts +214 -214
  215. package/src/_modules/discord-bot/_collections/dibo-operations.util.ts +387 -387
  216. package/src/_modules/discord-bot/_models/dibo-command.interface.ts +12 -12
  217. package/src/_modules/discord-bot/_models/dibo-global-settings.interface.ts +98 -98
  218. package/src/_modules/discord-bot/_models/dibo-last-mention-date.inteface.ts +7 -7
  219. package/src/_modules/discord-bot/_models/dibo-last-message-date.interface.ts +6 -6
  220. package/src/_modules/discord-bot/_services/dibo-commands.control-service.spec.ts +154 -154
  221. package/src/_modules/discord-bot/_services/dibo-commands.control-service.ts +153 -153
  222. package/src/_modules/discord-bot/_services/dibo-io.control-service.spec.ts +264 -264
  223. package/src/_modules/discord-bot/_services/dibo-io.control-service.ts +306 -306
  224. package/src/_modules/discord-bot/_services/dibo-main.control-service.spec.ts +408 -408
  225. package/src/_modules/discord-bot/_services/dibo-main.control-service.ts +487 -487
  226. package/src/_modules/discord-bot/_services/dibo-routines.control-service.spec.ts +105 -105
  227. package/src/_modules/discord-bot/index.ts +36 -36
  228. package/src/_modules/local-vector-search/_enums/lvs-search-mode.enum.ts +19 -19
  229. package/src/_modules/local-vector-search/_models/lvs-search-result.interface.ts +17 -17
  230. package/src/_modules/local-vector-search/_services/lvs-doc-chunk-data.service.spec.ts +418 -418
  231. package/src/_modules/local-vector-search/_services/lvs-doc-chunk-data.service.ts +276 -276
  232. package/src/_modules/local-vector-search/_services/lvs-local-vector-search.data-service.spec.ts +345 -345
  233. package/src/_modules/local-vector-search/_services/lvs-local-vector-search.data-service.ts +330 -330
  234. package/src/_modules/local-vector-search/_services/lvs-vector-pool.control-service.spec.ts +393 -393
  235. package/src/_modules/local-vector-search/_services/lvs-vector-pool.control-service.ts +220 -220
  236. package/src/_modules/local-vector-search/index.ts +11 -11
  237. package/src/_modules/logs/get-logs-routing-module.util.ts +36 -0
  238. package/src/_modules/logs/index.ts +3 -0
  239. package/src/_modules/logs/log-buffer.service.ts +101 -0
  240. package/src/_modules/logs/logs.controller.ts +109 -0
  241. package/src/_modules/logs/logs.service.ts +100 -0
  242. package/src/_modules/messaging/README.md +354 -354
  243. package/src/_modules/messaging/_collections/get-messaging-routing-module.util.ts +26 -26
  244. package/src/_modules/messaging/_collections/msg-global-settings.const.ts +22 -22
  245. package/src/_modules/messaging/_collections/msg.util.spec.ts +226 -226
  246. package/src/_modules/messaging/_models/msg-global-settings.interface.ts +37 -37
  247. package/src/_modules/messaging/_services/msg-conversation.data-service.ts +146 -146
  248. package/src/_modules/messaging/_services/msg-events.service.spec.ts +219 -219
  249. package/src/_modules/messaging/_services/msg-events.service.ts +267 -267
  250. package/src/_modules/messaging/_services/msg-integration.control-service.ts +179 -179
  251. package/src/_modules/messaging/_services/msg-main.control-service.spec.ts +147 -147
  252. package/src/_modules/messaging/_services/msg-main.control-service.ts +571 -571
  253. package/src/_modules/messaging/_services/msg-message.data-service.ts +129 -129
  254. package/src/_modules/messaging/_services/msg.controller.spec.ts +201 -201
  255. package/src/_modules/messaging/index.ts +30 -30
  256. package/src/_modules/mock/app-extended-server.mock.ts +201 -201
  257. package/src/_modules/mock/app-integration-test.mock.ts +51 -51
  258. package/src/_modules/mock/app-params.mock.spec.ts +21 -21
  259. package/src/_modules/mock/app-params.mock.ts +9 -9
  260. package/src/_modules/mock/app-server.mock.ts +188 -188
  261. package/src/_modules/mock/auth-service.mock.spec.ts +47 -47
  262. package/src/_modules/mock/auth-service.mock.ts +28 -28
  263. package/src/_modules/mock/controller.mock.spec.ts +26 -26
  264. package/src/_modules/mock/controller.mock.ts +16 -16
  265. package/src/_modules/mock/data-model.mock.spec.ts +111 -111
  266. package/src/_modules/mock/data-model.mock.ts +82 -82
  267. package/src/_modules/mock/email-service-collection.mock.spec.ts +24 -24
  268. package/src/_modules/mock/email-service-collection.mock.ts +15 -15
  269. package/src/_modules/mock/email-service.mock.spec.ts +17 -17
  270. package/src/_modules/mock/email-service.mock.ts +20 -20
  271. package/src/_modules/mock/email-template.mock.html +14 -14
  272. package/src/_modules/mock/endpoint.mock.ts +91 -91
  273. package/src/_modules/mock/socket-client.mock.spec.ts +40 -40
  274. package/src/_modules/mock/socket-client.mock.ts +45 -45
  275. package/src/_modules/mock/socket-server.mock.spec.ts +44 -44
  276. package/src/_modules/mock/socket-server.mock.ts +46 -46
  277. package/src/_modules/oauth2/_routes/oauth2.controller.spec.ts +107 -107
  278. package/src/_modules/oauth2/_routes/oauth2.controller.ts +98 -98
  279. package/src/_modules/oauth2/_services/oauth2.auth-service.spec.ts +254 -254
  280. package/src/_modules/oauth2/_services/oauth2.auth-service.ts +232 -232
  281. package/src/_modules/oauth2/_services/oauth2.control-service.spec.ts +585 -585
  282. package/src/_modules/oauth2/_services/oauth2.control-service.ts +653 -653
  283. package/src/_modules/oauth2/index.ts +17 -17
  284. package/src/_modules/server/errors/errors.control-service.spec.ts +230 -230
  285. package/src/_modules/server/errors/errors.control-service.ts +69 -69
  286. package/src/_modules/server/errors/errors.controller.spec.ts +165 -165
  287. package/src/_modules/server/errors/errors.controller.ts +270 -270
  288. package/src/_modules/server/errors/errors.data-service.spec.ts +355 -355
  289. package/src/_modules/server/errors/errors.data-service.ts +2 -1
  290. package/src/_modules/server/index.ts +30 -30
  291. package/src/_modules/server/server-status/server-status-snapshot.control-service.spec.ts +70 -70
  292. package/src/_modules/server/server-status/server-status-snapshot.control-service.ts +17 -17
  293. package/src/_modules/server/server-status/server-status-snapshot.data-service.spec.ts +77 -77
  294. package/src/_modules/server/server-status/server-status-snapshot.data-service.ts +37 -37
  295. package/src/_modules/server/server-status/server-status.control-service.spec.ts +516 -516
  296. package/src/_modules/server/server-status/server-status.control-service.ts +336 -336
  297. package/src/_modules/server/server-status/server-status.controller.spec.ts +156 -156
  298. package/src/_modules/server/server-status/server-status.controller.ts +131 -131
  299. package/src/_modules/socket/_enums/socket-security.enum.ts +11 -11
  300. package/src/_modules/socket/_models/socket-client-service-params.control-model.spec.ts +32 -32
  301. package/src/_modules/socket/_models/socket-client-service-params.control-model.ts +22 -22
  302. package/src/_modules/socket/_models/socket-presence.control-model.spec.ts +164 -164
  303. package/src/_modules/socket/_models/socket-presence.control-model.ts +210 -210
  304. package/src/_modules/socket/_models/socket-server-service-params.control-model.spec.ts +46 -46
  305. package/src/_modules/socket/_models/socket-server-service-params.control-model.ts +22 -22
  306. package/src/_modules/socket/_services/socket-client.service.spec.ts +15 -15
  307. package/src/_modules/socket/_services/socket-client.service.ts +260 -260
  308. package/src/_modules/socket/_services/socket-server.service.spec.ts +11 -11
  309. package/src/_modules/socket/app-extended.integration.spec.ts +85 -85
  310. package/src/_modules/socket/app-extended.server.ts +630 -630
  311. package/src/_modules/socket/index.ts +42 -42
  312. package/src/_modules/test/get-test-routing-module.util.spec.ts +28 -28
  313. package/src/_modules/test/get-test-routing-module.util.ts +23 -23
  314. package/src/_modules/test/index.ts +11 -11
  315. package/src/_modules/test/test.controller.spec.ts +72 -72
  316. package/src/_modules/test/test.controller.ts +115 -115
  317. package/src/_modules/usage/get-usage-routing-module.util.ts +22 -22
  318. package/src/_modules/usage/index.ts +15 -15
  319. package/src/_modules/usage/usage.controller.spec.ts +81 -81
  320. package/src/_modules/usage/usage.controller.ts +126 -126
  321. package/src/_modules/usage/usage.data-service.spec.ts +332 -332
  322. package/src/_modules/usage/usage.data-service.ts +185 -185
  323. package/src/_services/base/api.service-base.spec.ts +125 -125
  324. package/src/_services/base/api.service-base.ts +74 -74
  325. package/src/_services/base/archive-data.service.spec.ts +196 -196
  326. package/src/_services/base/archive-data.service.ts +216 -216
  327. package/src/_services/base/data.service.spec.ts +493 -493
  328. package/src/_services/base/data.service.ts +2525 -2525
  329. package/src/_services/base/db.service.spec.ts +73 -73
  330. package/src/_services/base/db.service.ts +1575 -1575
  331. package/src/_services/base/singleton.service-base.spec.ts +28 -28
  332. package/src/_services/base/singleton.service-base.ts +24 -24
  333. package/src/_services/base/singleton.service.spec.ts +114 -114
  334. package/src/_services/base/singleton.service.ts +38 -38
  335. package/src/_services/core/api.service.spec.ts +140 -140
  336. package/src/_services/core/auth.service.spec.ts +159 -159
  337. package/src/_services/core/auth.service.ts +174 -174
  338. package/src/_services/core/email.service.spec.ts +85 -85
  339. package/src/_services/core/email.service.ts +742 -742
  340. package/src/_services/core/global.service.spec.ts +275 -275
  341. package/src/_services/core/global.service.ts +461 -461
  342. package/src/_services/core/service-collection.service.spec.ts +46 -46
  343. package/src/_services/core/service-collection.service.ts +6 -6
  344. package/src/_services/route/controller.service.spec.ts +53 -53
  345. package/src/_services/route/controller.service.ts +148 -148
  346. package/src/_services/route/routing-module.service.spec.ts +98 -98
  347. package/src/_services/route/routing-module.service.ts +330 -330
  348. package/src/_services/shared.static-service.spec.ts +99 -99
  349. package/src/_services/shared.static-service.ts +78 -78
  350. package/src/index.ts +94 -94
  351. package/tsconfig.app.json +12 -12
  352. package/tsconfig.json +42 -42
@@ -1,461 +1,461 @@
1
-
2
-
3
-
4
- import {
5
- DyFM_AnyError,
6
- DyFM_Array,
7
- DyFM_DataModel_Params,
8
- DyFM_Error,
9
- DyFM_Error_Settings,
10
- DyFM_global_settings,
11
- DyFM_Log,
12
- DyFM_Metadata
13
- } from '@futdevpro/fsm-dynamo';
14
- import { DyNTS_App_Params } from '../../_models/control-models/app-params.control-model';
15
-
16
- import {
17
- DyNTS_GlobalErrorHandlerFn,
18
- DyNTS_GlobalService_Settings
19
- } from '../../_models/interfaces/global-service-settings.interface';
20
-
21
- import { DyNTS_AuthService } from './auth.service';
22
- /* import { DyNTS_DBServiceCollection } from './db-service-collection.service'; */
23
- import { DyNTS_DBService } from '../base/db.service';
24
- import { DyNTS_EmailService } from './email.service';
25
- import { DyNTS_Service_Collection } from './service-collection.service';
26
- /* import { DyNTS_EmailServiceCollection } from './email-service-collection.service'; */
27
- import { DyNTS_global_settings } from '../../_collections/global-settings.const';
28
- import { DyNTS_SingletonService } from '../base/singleton.service';
29
- /* import { DyNTS_archiveFlag } from '../../_collections/archive-flag.const'; */
30
- import { DyNTS_getArchivedDBName } from '../../_collections/archive.util';
31
-
32
- /**
33
- * This is the main Global/Core Service Collection used by DynamoNTS,
34
- * you also can use this to access main services as
35
- * dbServices, emailServices, or authService
36
- */
37
- export class DyNTS_GlobalService extends DyNTS_SingletonService {
38
-
39
- static getInstance(): DyNTS_GlobalService {
40
- return DyNTS_GlobalService.getSingletonInstance();
41
- }
42
-
43
- private static _params: DyNTS_App_Params;
44
- static get params(): DyNTS_App_Params {
45
- return this._params;
46
- }
47
-
48
- private static readonly _upSince: Date = new Date();
49
- static get upSince(): Date {
50
- return this._upSince;
51
- }
52
- static get upTime(): number {
53
- return +new Date() - +this._upSince;
54
- }
55
-
56
- authService: DyNTS_AuthService;
57
- dbServiceCollection: DyNTS_Service_Collection<DyNTS_DBService<any>>;
58
- /* dataServiceCollection: DyNTS_Service_Collection<any>; */
59
- emailServiceCollection: DyNTS_Service_Collection<DyNTS_EmailService>;
60
-
61
- static readonly defaultErrorUserMsg: string =
62
- `We encountered an unhandled Control Service Error, ` +
63
- `\nplease contact the responsible development team.`;
64
-
65
- static globalErrorHandler: DyNTS_GlobalErrorHandlerFn =
66
- async (error: DyFM_AnyError): Promise<void> => {
67
- DyFM_Log.error(`Global Error Handler not set!\nError:`, error);
68
- }
69
-
70
- /**
71
- * You need to setup global Services through this function
72
- */
73
- static async setServices(set: DyNTS_GlobalService_Settings): Promise<void> {
74
- this.getInstance();
75
-
76
- try {
77
- await this.setDBServices(set?.dbModels);
78
-
79
- await this.setAuthService(set?.authService);
80
-
81
- await this.setEmailServices(set?.emailServiceCollection);
82
-
83
- await this.setErrorHandler(set?.errorHandler);
84
- } catch (error) {
85
- throw new DyFM_Error({
86
- ...this.getDefaultErrorSettings('setServices', error, 'DyNTS_GlobalService'),
87
-
88
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-GS0-SS0`,
89
- });
90
- }
91
- }
92
-
93
- private static async setDBServices(dbModels?: DyFM_DataModel_Params<any>[]): Promise<void> {
94
- try {
95
- this.instance.dbServiceCollection = {};
96
-
97
- dbModels?.forEach((dbModel: DyFM_DataModel_Params<any>): void => {
98
- if (!dbModel) {
99
- throw new DyFM_Error({
100
- ...this.getDefaultErrorSettings(
101
- 'setDBServices',
102
- new Error(`given dbModel is empty!`),
103
- 'DyNTS_GlobalService'
104
- ),
105
-
106
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-GS0-SDBS2`,
107
- additionalContent: {
108
- dbModels: dbModels,
109
- dbModelNames: dbModels.map((dbModel: DyFM_DataModel_Params<any>) => dbModel.dataName),
110
- },
111
- });
112
- }
113
-
114
- if (dbModel.addArchive) {
115
- const archiveModel: DyFM_DataModel_Params<any> = new DyFM_DataModel_Params<any>({
116
- ...dbModel,
117
- dataName: DyNTS_getArchivedDBName(dbModel.dataName),
118
- properties: {
119
- ...dbModel.properties,
120
- },
121
- });
122
-
123
- dbModels.push(archiveModel);
124
- }
125
- });
126
-
127
- dbModels?.forEach((dbModel: DyFM_DataModel_Params<any>): void => {
128
- this.createDBService(dbModel);
129
- });
130
-
131
- if (DyFM_global_settings.log_settings.dbSetup) {
132
- DyFM_Log.info(
133
- `DB Services setup complete. DB Models:`,
134
- `\n ${Object.keys(this.instance.dbServiceCollection).join('\n ')}`
135
- );
136
- }
137
- } catch (error) {
138
- throw new DyFM_Error({
139
- ...this.getDefaultErrorSettings('setDBServices', error, 'DyNTS_GlobalService'),
140
-
141
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-GS0-SDBS0`,
142
- });
143
- }
144
- }
145
-
146
- static createDBService(dbModel: DyFM_DataModel_Params<any>): void {
147
- try {
148
- if (!dbModel.constructed) {
149
- throw new DyFM_Error({
150
- ...this.getDefaultErrorSettings(
151
- 'setDBServices',
152
- new Error(
153
- `"${dbModel.dataName}" dbModel is not constructed!` +
154
- `\n use new DyFM_DataModel_Params() to properly construct it.`
155
- ),
156
- 'DyNTS_GlobalService'
157
- ),
158
-
159
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-GS0-CDBS1`,
160
- additionalContent: {
161
- dbModel: dbModel,
162
- },
163
- });
164
- }
165
-
166
- if (this.instance.dbServiceCollection[dbModel.dataName]) {
167
- return;
168
- }
169
-
170
- try {
171
- this.instance.dbServiceCollection[dbModel.dataName] = new DyNTS_DBService(dbModel);
172
- } catch (error) {
173
- if (error instanceof DyFM_Error && !DyFM_global_settings.log_settings.highDetailedLogs) {
174
- error.logSimple(`Failed to create DyNTS_DBService (${dbModel.dataName}).`);
175
- } else {
176
- DyFM_Log.error(`Failed to create DyNTS_DBService (${dbModel.dataName}).`, error);
177
- }
178
-
179
- throw new DyFM_Error({
180
- ...this.getDefaultErrorSettings('setDBServices', error, 'DyNTS_GlobalService'),
181
-
182
- additionalContent: {
183
- dbModel: dbModel,
184
- },
185
- });
186
- }
187
- } catch (error) {
188
- throw new DyFM_Error({
189
- ...this.getDefaultErrorSettings('createDBService', error, 'DyNTS_GlobalService'),
190
-
191
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-GS0-SDBS0`,
192
- });
193
- }
194
- }
195
-
196
- static unmountDBService(dbModel: DyFM_DataModel_Params<any>): void {
197
- try {
198
- if (!this.instance.dbServiceCollection[dbModel.dataName]) {
199
- return;
200
- }
201
-
202
- delete this.instance.dbServiceCollection[dbModel.dataName];
203
- } catch (error) {
204
- throw new DyFM_Error({
205
- ...this.getDefaultErrorSettings('unmountDBService', error, 'DyNTS_GlobalService'),
206
-
207
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-GS0-UDBS0`,
208
- });
209
- }
210
- }
211
-
212
- private static async setAuthService(authService?: DyNTS_AuthService): Promise<void> {
213
- try {
214
- if (!authService) {
215
- DyFM_Log.warn(`Authentication Service missing!`);
216
- } else {
217
- this.instance.authService = authService;
218
- }
219
- } catch (error) {
220
- throw new DyFM_Error({
221
- ...this.getDefaultErrorSettings('setAuthService', error, 'DyNTS_GlobalService'),
222
-
223
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-GS0-SAS0`,
224
- });
225
- }
226
- }
227
-
228
- private static async setEmailServices(
229
- emailServiceCollection?: DyNTS_Service_Collection<DyNTS_EmailService>
230
- ): Promise<void> {
231
- try {
232
- this.instance.emailServiceCollection = emailServiceCollection ?? {};
233
-
234
- await DyFM_Array.asyncForEach(
235
- Object.keys(this.instance.emailServiceCollection),
236
- async (key: string): Promise<void> => {
237
- await (
238
- this.instance.emailServiceCollection[key] as DyNTS_EmailService
239
- ).asyncPostConstruct();
240
- }
241
- );
242
- } catch (error) {
243
- throw new DyFM_Error({
244
- ...this.getDefaultErrorSettings('setEmailServices', error, 'DyNTS_GlobalService'),
245
-
246
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-GS0-SS4`,
247
- });
248
- }
249
- }
250
-
251
- private static async setErrorHandler(errorHandler?: DyNTS_GlobalErrorHandlerFn): Promise<void> {
252
- try {
253
- DyNTS_GlobalService.globalErrorHandler = (async (error: any): Promise<void> => {
254
- try {
255
- if (errorHandler) {
256
- await errorHandler(error);
257
-
258
- return;
259
- }
260
-
261
- DyFM_Log.warn(
262
- `globalErrorHandler not set! (set in app.getGlobalServiceCollection)`,
263
- '\nwill use default-logging',
264
- '\n(If you set the globalErrorHandler, ' +
265
- 'please check if it is using the same node_modules as the app)'
266
- );
267
-
268
- DyFM_Error.logSimple(`Error caught by globalErrorHandler.`, error);
269
- } catch (error) {
270
- if (error instanceof DyFM_Error) {
271
- error.logSimple(
272
- `NTS GLOBAL MULTILEVEL ERROR: ` +
273
- `\nFailed to handle error on globalErrorHandler.`,
274
- );
275
- } else {
276
- DyFM_Log.error(
277
- `NTS GLOBAL MULTILEVEL ERROR: ` +
278
- `\nFailed to handle error on globalErrorHandler.`,
279
- (error as DyFM_Error)?.getErrorSimplified?.() ?? error
280
- );
281
- }
282
- }
283
- });
284
- } catch (error) {
285
- throw new DyFM_Error({
286
- ...this.getDefaultErrorSettings('setErrorHandler', error, 'DyNTS_GlobalService'),
287
-
288
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-GS0-SEH0`,
289
- });
290
- }
291
- }
292
-
293
- static setParams(params: DyNTS_App_Params): void {
294
- this._params = params;
295
- }
296
-
297
- /**
298
- *
299
- * @returns
300
- */
301
- static getAuthService(): DyNTS_AuthService {
302
- if (!this.instance?.authService) {
303
- throw new Error(
304
- `\n Unique Authentication Service missing!` +
305
- `\n Please create a Unique Authentication Service extending DyNTS_AuthService, ` +
306
- `\n and Setup with DyNTS_GlobalServiceC.setServices(...)` +
307
- '\n (If you set the globalErrorHandler, ' +
308
- 'please check if it is using the same node_modules as the app)',
309
- );
310
- }
311
-
312
- return this.instance.authService;
313
- }
314
-
315
- /**
316
- *
317
- * @returns
318
- */
319
- static getDBServiceCollection(): DyNTS_Service_Collection<DyNTS_DBService<any>> {
320
- if (!(this.instance as DyNTS_GlobalService)?.dbServiceCollection) {
321
- throw new Error(
322
- `\n Unique DataBase Service Collection missing!` +
323
- `\n Please create a Unique DataBase Service Collection extending ` +
324
- `DyNTS_DBServiceCollection, ` +
325
- `\n and Setup with DyNTS_GlobalServiceC.setServices(...)` +
326
- '\n (If you set the globalErrorHandler, ' +
327
- 'please check if it is using the same node_modules as the app)\n',
328
- );
329
- }
330
-
331
- return this.instance.dbServiceCollection;
332
- }
333
-
334
- /**
335
- *
336
- * @param dataParams
337
- * @returns
338
- */
339
- static getDBService<T extends DyFM_Metadata>(
340
- dataParams: DyFM_DataModel_Params<T>
341
- ): DyNTS_DBService<T> {
342
- return this.getDBServiceByKey<T>(dataParams.dataName);
343
- }
344
-
345
- /**
346
- *
347
- * @param key
348
- * @returns
349
- */
350
- static getDBServiceByKey<T extends DyFM_Metadata>(key: string): DyNTS_DBService<T> {
351
- const collection = this.getDBServiceCollection();
352
-
353
- if (collection[key]) {
354
- return collection[key] as DyNTS_DBService<T>;
355
- } else {
356
- throw new Error(
357
- `\n DyNTS_GlobalService.getDBService failed, ERROR: ` +
358
- `\n no dbService on collection with this key: "${key}"!` +
359
- '\n (If you set the globalErrorHandler, ' +
360
- 'please check if it is using the same node_modules as the app)' +
361
- `\n The available dbServices on collection:` +
362
- `\n ${Object.keys(collection).join(', ')}\n`
363
- );
364
- }
365
- }
366
-
367
- /**
368
- *
369
- * @returns
370
- */
371
- static getEmailServiceCollection(): DyNTS_Service_Collection<DyNTS_EmailService> {
372
- if (!this.instance.emailServiceCollection) {
373
- throw new Error(
374
- `\n Unique Email Service Collection missing!` +
375
- `\n Please create a Unique Email Service Collection extending ` +
376
- `DyNTS_EmailServiceCollection, ` +
377
- '\n (If you set the globalErrorHandler, ' +
378
- 'please check if it is using the same node_modules as the app)' +
379
- `\n and Setup with DyNTS_GlobalServiceC.setServices(...)\n` +
380
- `\n available emailServiceCollection: ` +
381
- `${Object().keys(this.instance.emailServiceCollection).join(', ')}\n`
382
- );
383
- }
384
-
385
- return this.instance.emailServiceCollection;
386
- }
387
-
388
- /**
389
- *
390
- * @returns
391
- */
392
- /* static getSocketServiceCollection(): DyNTS_SocketServiceCollection {
393
- if (!this.instance?.socketServiceCollection) {
394
- throw new Error(
395
- `\nUnique Socket Service Collection missing!` +
396
- `\nSocket Service Collection will only be created if there are Socket Services properly setted up ` +
397
- `in the setupModules in the App using DyNTS_AppExtended, ` +
398
- `and Setup with "DyNTS_GlobalServiceC.setServices(...)"`);
399
- }
400
-
401
- return this.instance.socketServiceCollection;
402
- } */
403
-
404
- /**
405
- *
406
- * @param name
407
- * @returns
408
- */
409
- /* static getSocketServiceByName(name: string): DyNTS_SocketService<any> {
410
- const collection: DyNTS_SocketServiceCollection = this.getSocketServiceCollection();
411
- if (collection[name]) {
412
- return collection[name];
413
- } else {
414
- let names: string = `${Object.keys(collection)}`;
415
- names = names.replace(/,/g, '\n ');
416
-
417
- throw new Error(
418
- `\nDyNTS_GlobalService.getSocketServiceByName failed, ERROR:
419
- no socketService on collection with this name: ${name}!
420
- The available socketServices on collection:
421
- ${names}\n`);
422
- }
423
- }
424
-
425
- static attachNewSocketService(service: DyNTS_SocketService<any>): void {
426
- const collection: DyNTS_SocketServiceCollection = this.getSocketServiceCollection();
427
- if (!collection[service.name]) {
428
- collection[service.name] = service;
429
- } else {
430
- let names: string = `${Object.keys(collection)}`;
431
- names = names.replace(/,/g, '\n ');
432
-
433
- throw new Error(
434
- `\nDyNTS_GlobalService.attachNewSocketService failed, ERROR:
435
- socketService name is already taken on collection with this name: ${service.name}!
436
- The available socketServices on collection:
437
- ${names}\n`);
438
- }
439
- } */
440
-
441
- protected static getDefaultErrorSettings(
442
- fnName: string,
443
- error: DyFM_AnyError,
444
- issuer: string,
445
- /** @deprecated we wont support the separate user message in the future, use the message instead */
446
- useMessageAsUserMessage: boolean = true,
447
- ): DyFM_Error_Settings {
448
- return {
449
- status: (error as DyFM_Error)?.___status ?? 500,
450
- message: (error as Error)?.message ??
451
- (error as DyFM_Error)?._message ??
452
- `${fnName} was UNSUCCESSFUL (${DyNTS_global_settings.systemShortCodeName})`,
453
- addECToUserMsg: !(error as DyFM_Error)?.__userMessage,
454
- userMessage: (error as DyFM_Error)?.__userMessage ??
455
- (useMessageAsUserMessage ? (error as Error)?.message : this.defaultErrorUserMsg),
456
- issuer: issuer,
457
- issuerService: this.constructor?.name,
458
- error: error,
459
- };
460
- }
461
- }
1
+
2
+
3
+
4
+ import {
5
+ DyFM_AnyError,
6
+ DyFM_Array,
7
+ DyFM_DataModel_Params,
8
+ DyFM_Error,
9
+ DyFM_Error_Settings,
10
+ DyFM_global_settings,
11
+ DyFM_Log,
12
+ DyFM_Metadata
13
+ } from '@futdevpro/fsm-dynamo';
14
+ import { DyNTS_App_Params } from '../../_models/control-models/app-params.control-model';
15
+
16
+ import {
17
+ DyNTS_GlobalErrorHandlerFn,
18
+ DyNTS_GlobalService_Settings
19
+ } from '../../_models/interfaces/global-service-settings.interface';
20
+
21
+ import { DyNTS_AuthService } from './auth.service';
22
+ /* import { DyNTS_DBServiceCollection } from './db-service-collection.service'; */
23
+ import { DyNTS_DBService } from '../base/db.service';
24
+ import { DyNTS_EmailService } from './email.service';
25
+ import { DyNTS_Service_Collection } from './service-collection.service';
26
+ /* import { DyNTS_EmailServiceCollection } from './email-service-collection.service'; */
27
+ import { DyNTS_global_settings } from '../../_collections/global-settings.const';
28
+ import { DyNTS_SingletonService } from '../base/singleton.service';
29
+ /* import { DyNTS_archiveFlag } from '../../_collections/archive-flag.const'; */
30
+ import { DyNTS_getArchivedDBName } from '../../_collections/archive.util';
31
+
32
+ /**
33
+ * This is the main Global/Core Service Collection used by DynamoNTS,
34
+ * you also can use this to access main services as
35
+ * dbServices, emailServices, or authService
36
+ */
37
+ export class DyNTS_GlobalService extends DyNTS_SingletonService {
38
+
39
+ static getInstance(): DyNTS_GlobalService {
40
+ return DyNTS_GlobalService.getSingletonInstance();
41
+ }
42
+
43
+ private static _params: DyNTS_App_Params;
44
+ static get params(): DyNTS_App_Params {
45
+ return this._params;
46
+ }
47
+
48
+ private static readonly _upSince: Date = new Date();
49
+ static get upSince(): Date {
50
+ return this._upSince;
51
+ }
52
+ static get upTime(): number {
53
+ return +new Date() - +this._upSince;
54
+ }
55
+
56
+ authService: DyNTS_AuthService;
57
+ dbServiceCollection: DyNTS_Service_Collection<DyNTS_DBService<any>>;
58
+ /* dataServiceCollection: DyNTS_Service_Collection<any>; */
59
+ emailServiceCollection: DyNTS_Service_Collection<DyNTS_EmailService>;
60
+
61
+ static readonly defaultErrorUserMsg: string =
62
+ `We encountered an unhandled Control Service Error, ` +
63
+ `\nplease contact the responsible development team.`;
64
+
65
+ static globalErrorHandler: DyNTS_GlobalErrorHandlerFn =
66
+ async (error: DyFM_AnyError): Promise<void> => {
67
+ DyFM_Log.error(`Global Error Handler not set!\nError:`, error);
68
+ }
69
+
70
+ /**
71
+ * You need to setup global Services through this function
72
+ */
73
+ static async setServices(set: DyNTS_GlobalService_Settings): Promise<void> {
74
+ this.getInstance();
75
+
76
+ try {
77
+ await this.setDBServices(set?.dbModels);
78
+
79
+ await this.setAuthService(set?.authService);
80
+
81
+ await this.setEmailServices(set?.emailServiceCollection);
82
+
83
+ await this.setErrorHandler(set?.errorHandler);
84
+ } catch (error) {
85
+ throw new DyFM_Error({
86
+ ...this.getDefaultErrorSettings('setServices', error, 'DyNTS_GlobalService'),
87
+
88
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-GS0-SS0`,
89
+ });
90
+ }
91
+ }
92
+
93
+ private static async setDBServices(dbModels?: DyFM_DataModel_Params<any>[]): Promise<void> {
94
+ try {
95
+ this.instance.dbServiceCollection = {};
96
+
97
+ dbModels?.forEach((dbModel: DyFM_DataModel_Params<any>): void => {
98
+ if (!dbModel) {
99
+ throw new DyFM_Error({
100
+ ...this.getDefaultErrorSettings(
101
+ 'setDBServices',
102
+ new Error(`given dbModel is empty!`),
103
+ 'DyNTS_GlobalService'
104
+ ),
105
+
106
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-GS0-SDBS2`,
107
+ additionalContent: {
108
+ dbModels: dbModels,
109
+ dbModelNames: dbModels.map((dbModel: DyFM_DataModel_Params<any>) => dbModel.dataName),
110
+ },
111
+ });
112
+ }
113
+
114
+ if (dbModel.addArchive) {
115
+ const archiveModel: DyFM_DataModel_Params<any> = new DyFM_DataModel_Params<any>({
116
+ ...dbModel,
117
+ dataName: DyNTS_getArchivedDBName(dbModel.dataName),
118
+ properties: {
119
+ ...dbModel.properties,
120
+ },
121
+ });
122
+
123
+ dbModels.push(archiveModel);
124
+ }
125
+ });
126
+
127
+ dbModels?.forEach((dbModel: DyFM_DataModel_Params<any>): void => {
128
+ this.createDBService(dbModel);
129
+ });
130
+
131
+ if (DyFM_global_settings.log_settings.dbSetup) {
132
+ DyFM_Log.info(
133
+ `DB Services setup complete. DB Models:`,
134
+ `\n ${Object.keys(this.instance.dbServiceCollection).join('\n ')}`
135
+ );
136
+ }
137
+ } catch (error) {
138
+ throw new DyFM_Error({
139
+ ...this.getDefaultErrorSettings('setDBServices', error, 'DyNTS_GlobalService'),
140
+
141
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-GS0-SDBS0`,
142
+ });
143
+ }
144
+ }
145
+
146
+ static createDBService(dbModel: DyFM_DataModel_Params<any>): void {
147
+ try {
148
+ if (!dbModel.constructed) {
149
+ throw new DyFM_Error({
150
+ ...this.getDefaultErrorSettings(
151
+ 'setDBServices',
152
+ new Error(
153
+ `"${dbModel.dataName}" dbModel is not constructed!` +
154
+ `\n use new DyFM_DataModel_Params() to properly construct it.`
155
+ ),
156
+ 'DyNTS_GlobalService'
157
+ ),
158
+
159
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-GS0-CDBS1`,
160
+ additionalContent: {
161
+ dbModel: dbModel,
162
+ },
163
+ });
164
+ }
165
+
166
+ if (this.instance.dbServiceCollection[dbModel.dataName]) {
167
+ return;
168
+ }
169
+
170
+ try {
171
+ this.instance.dbServiceCollection[dbModel.dataName] = new DyNTS_DBService(dbModel);
172
+ } catch (error) {
173
+ if (error instanceof DyFM_Error && !DyFM_global_settings.log_settings.highDetailedLogs) {
174
+ error.logSimple(`Failed to create DyNTS_DBService (${dbModel.dataName}).`);
175
+ } else {
176
+ DyFM_Log.error(`Failed to create DyNTS_DBService (${dbModel.dataName}).`, error);
177
+ }
178
+
179
+ throw new DyFM_Error({
180
+ ...this.getDefaultErrorSettings('setDBServices', error, 'DyNTS_GlobalService'),
181
+
182
+ additionalContent: {
183
+ dbModel: dbModel,
184
+ },
185
+ });
186
+ }
187
+ } catch (error) {
188
+ throw new DyFM_Error({
189
+ ...this.getDefaultErrorSettings('createDBService', error, 'DyNTS_GlobalService'),
190
+
191
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-GS0-SDBS0`,
192
+ });
193
+ }
194
+ }
195
+
196
+ static unmountDBService(dbModel: DyFM_DataModel_Params<any>): void {
197
+ try {
198
+ if (!this.instance.dbServiceCollection[dbModel.dataName]) {
199
+ return;
200
+ }
201
+
202
+ delete this.instance.dbServiceCollection[dbModel.dataName];
203
+ } catch (error) {
204
+ throw new DyFM_Error({
205
+ ...this.getDefaultErrorSettings('unmountDBService', error, 'DyNTS_GlobalService'),
206
+
207
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-GS0-UDBS0`,
208
+ });
209
+ }
210
+ }
211
+
212
+ private static async setAuthService(authService?: DyNTS_AuthService): Promise<void> {
213
+ try {
214
+ if (!authService) {
215
+ DyFM_Log.warn(`Authentication Service missing!`);
216
+ } else {
217
+ this.instance.authService = authService;
218
+ }
219
+ } catch (error) {
220
+ throw new DyFM_Error({
221
+ ...this.getDefaultErrorSettings('setAuthService', error, 'DyNTS_GlobalService'),
222
+
223
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-GS0-SAS0`,
224
+ });
225
+ }
226
+ }
227
+
228
+ private static async setEmailServices(
229
+ emailServiceCollection?: DyNTS_Service_Collection<DyNTS_EmailService>
230
+ ): Promise<void> {
231
+ try {
232
+ this.instance.emailServiceCollection = emailServiceCollection ?? {};
233
+
234
+ await DyFM_Array.asyncForEach(
235
+ Object.keys(this.instance.emailServiceCollection),
236
+ async (key: string): Promise<void> => {
237
+ await (
238
+ this.instance.emailServiceCollection[key] as DyNTS_EmailService
239
+ ).asyncPostConstruct();
240
+ }
241
+ );
242
+ } catch (error) {
243
+ throw new DyFM_Error({
244
+ ...this.getDefaultErrorSettings('setEmailServices', error, 'DyNTS_GlobalService'),
245
+
246
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-GS0-SS4`,
247
+ });
248
+ }
249
+ }
250
+
251
+ private static async setErrorHandler(errorHandler?: DyNTS_GlobalErrorHandlerFn): Promise<void> {
252
+ try {
253
+ DyNTS_GlobalService.globalErrorHandler = (async (error: any): Promise<void> => {
254
+ try {
255
+ if (errorHandler) {
256
+ await errorHandler(error);
257
+
258
+ return;
259
+ }
260
+
261
+ DyFM_Log.warn(
262
+ `globalErrorHandler not set! (set in app.getGlobalServiceCollection)`,
263
+ '\nwill use default-logging',
264
+ '\n(If you set the globalErrorHandler, ' +
265
+ 'please check if it is using the same node_modules as the app)'
266
+ );
267
+
268
+ DyFM_Error.logSimple(`Error caught by globalErrorHandler.`, error);
269
+ } catch (error) {
270
+ if (error instanceof DyFM_Error) {
271
+ error.logSimple(
272
+ `NTS GLOBAL MULTILEVEL ERROR: ` +
273
+ `\nFailed to handle error on globalErrorHandler.`,
274
+ );
275
+ } else {
276
+ DyFM_Log.error(
277
+ `NTS GLOBAL MULTILEVEL ERROR: ` +
278
+ `\nFailed to handle error on globalErrorHandler.`,
279
+ (error as DyFM_Error)?.getErrorSimplified?.() ?? error
280
+ );
281
+ }
282
+ }
283
+ });
284
+ } catch (error) {
285
+ throw new DyFM_Error({
286
+ ...this.getDefaultErrorSettings('setErrorHandler', error, 'DyNTS_GlobalService'),
287
+
288
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-GS0-SEH0`,
289
+ });
290
+ }
291
+ }
292
+
293
+ static setParams(params: DyNTS_App_Params): void {
294
+ this._params = params;
295
+ }
296
+
297
+ /**
298
+ *
299
+ * @returns
300
+ */
301
+ static getAuthService(): DyNTS_AuthService {
302
+ if (!this.instance?.authService) {
303
+ throw new Error(
304
+ `\n Unique Authentication Service missing!` +
305
+ `\n Please create a Unique Authentication Service extending DyNTS_AuthService, ` +
306
+ `\n and Setup with DyNTS_GlobalServiceC.setServices(...)` +
307
+ '\n (If you set the globalErrorHandler, ' +
308
+ 'please check if it is using the same node_modules as the app)',
309
+ );
310
+ }
311
+
312
+ return this.instance.authService;
313
+ }
314
+
315
+ /**
316
+ *
317
+ * @returns
318
+ */
319
+ static getDBServiceCollection(): DyNTS_Service_Collection<DyNTS_DBService<any>> {
320
+ if (!(this.instance as DyNTS_GlobalService)?.dbServiceCollection) {
321
+ throw new Error(
322
+ `\n Unique DataBase Service Collection missing!` +
323
+ `\n Please create a Unique DataBase Service Collection extending ` +
324
+ `DyNTS_DBServiceCollection, ` +
325
+ `\n and Setup with DyNTS_GlobalServiceC.setServices(...)` +
326
+ '\n (If you set the globalErrorHandler, ' +
327
+ 'please check if it is using the same node_modules as the app)\n',
328
+ );
329
+ }
330
+
331
+ return this.instance.dbServiceCollection;
332
+ }
333
+
334
+ /**
335
+ *
336
+ * @param dataParams
337
+ * @returns
338
+ */
339
+ static getDBService<T extends DyFM_Metadata>(
340
+ dataParams: DyFM_DataModel_Params<T>
341
+ ): DyNTS_DBService<T> {
342
+ return this.getDBServiceByKey<T>(dataParams.dataName);
343
+ }
344
+
345
+ /**
346
+ *
347
+ * @param key
348
+ * @returns
349
+ */
350
+ static getDBServiceByKey<T extends DyFM_Metadata>(key: string): DyNTS_DBService<T> {
351
+ const collection = this.getDBServiceCollection();
352
+
353
+ if (collection[key]) {
354
+ return collection[key] as DyNTS_DBService<T>;
355
+ } else {
356
+ throw new Error(
357
+ `\n DyNTS_GlobalService.getDBService failed, ERROR: ` +
358
+ `\n no dbService on collection with this key: "${key}"!` +
359
+ '\n (If you set the globalErrorHandler, ' +
360
+ 'please check if it is using the same node_modules as the app)' +
361
+ `\n The available dbServices on collection:` +
362
+ `\n ${Object.keys(collection).join(', ')}\n`
363
+ );
364
+ }
365
+ }
366
+
367
+ /**
368
+ *
369
+ * @returns
370
+ */
371
+ static getEmailServiceCollection(): DyNTS_Service_Collection<DyNTS_EmailService> {
372
+ if (!this.instance.emailServiceCollection) {
373
+ throw new Error(
374
+ `\n Unique Email Service Collection missing!` +
375
+ `\n Please create a Unique Email Service Collection extending ` +
376
+ `DyNTS_EmailServiceCollection, ` +
377
+ '\n (If you set the globalErrorHandler, ' +
378
+ 'please check if it is using the same node_modules as the app)' +
379
+ `\n and Setup with DyNTS_GlobalServiceC.setServices(...)\n` +
380
+ `\n available emailServiceCollection: ` +
381
+ `${Object().keys(this.instance.emailServiceCollection).join(', ')}\n`
382
+ );
383
+ }
384
+
385
+ return this.instance.emailServiceCollection;
386
+ }
387
+
388
+ /**
389
+ *
390
+ * @returns
391
+ */
392
+ /* static getSocketServiceCollection(): DyNTS_SocketServiceCollection {
393
+ if (!this.instance?.socketServiceCollection) {
394
+ throw new Error(
395
+ `\nUnique Socket Service Collection missing!` +
396
+ `\nSocket Service Collection will only be created if there are Socket Services properly setted up ` +
397
+ `in the setupModules in the App using DyNTS_AppExtended, ` +
398
+ `and Setup with "DyNTS_GlobalServiceC.setServices(...)"`);
399
+ }
400
+
401
+ return this.instance.socketServiceCollection;
402
+ } */
403
+
404
+ /**
405
+ *
406
+ * @param name
407
+ * @returns
408
+ */
409
+ /* static getSocketServiceByName(name: string): DyNTS_SocketService<any> {
410
+ const collection: DyNTS_SocketServiceCollection = this.getSocketServiceCollection();
411
+ if (collection[name]) {
412
+ return collection[name];
413
+ } else {
414
+ let names: string = `${Object.keys(collection)}`;
415
+ names = names.replace(/,/g, '\n ');
416
+
417
+ throw new Error(
418
+ `\nDyNTS_GlobalService.getSocketServiceByName failed, ERROR:
419
+ no socketService on collection with this name: ${name}!
420
+ The available socketServices on collection:
421
+ ${names}\n`);
422
+ }
423
+ }
424
+
425
+ static attachNewSocketService(service: DyNTS_SocketService<any>): void {
426
+ const collection: DyNTS_SocketServiceCollection = this.getSocketServiceCollection();
427
+ if (!collection[service.name]) {
428
+ collection[service.name] = service;
429
+ } else {
430
+ let names: string = `${Object.keys(collection)}`;
431
+ names = names.replace(/,/g, '\n ');
432
+
433
+ throw new Error(
434
+ `\nDyNTS_GlobalService.attachNewSocketService failed, ERROR:
435
+ socketService name is already taken on collection with this name: ${service.name}!
436
+ The available socketServices on collection:
437
+ ${names}\n`);
438
+ }
439
+ } */
440
+
441
+ protected static getDefaultErrorSettings(
442
+ fnName: string,
443
+ error: DyFM_AnyError,
444
+ issuer: string,
445
+ /** @deprecated we wont support the separate user message in the future, use the message instead */
446
+ useMessageAsUserMessage: boolean = true,
447
+ ): DyFM_Error_Settings {
448
+ return {
449
+ status: (error as DyFM_Error)?.___status ?? 500,
450
+ message: (error as Error)?.message ??
451
+ (error as DyFM_Error)?._message ??
452
+ `${fnName} was UNSUCCESSFUL (${DyNTS_global_settings.systemShortCodeName})`,
453
+ addECToUserMsg: !(error as DyFM_Error)?.__userMessage,
454
+ userMessage: (error as DyFM_Error)?.__userMessage ??
455
+ (useMessageAsUserMessage ? (error as Error)?.message : this.defaultErrorUserMsg),
456
+ issuer: issuer,
457
+ issuerService: this.constructor?.name,
458
+ error: error,
459
+ };
460
+ }
461
+ }