@futdevpro/nts-dynamo 1.15.53 → 1.15.55

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 (330) 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/.dynamo/pipeline.cicd.config.json +19 -1
  17. package/.github/workflows/main.yml +432 -432
  18. package/.vscode/settings.json +10 -10
  19. package/HOWTO.md +15 -15
  20. package/LICENSE +21 -21
  21. package/__documentations/nts-integration-tests-2026-03-17.md +26 -26
  22. package/_specifications/BACKLOG.md +92 -92
  23. package/_specifications/TODO.md +15 -15
  24. package/_specifications/agent.md +138 -138
  25. package/build/_models/interfaces/global-log-settings.interface.d.ts +26 -0
  26. package/build/_models/interfaces/global-log-settings.interface.d.ts.map +1 -1
  27. package/build/_services/server/app.server.d.ts +16 -0
  28. package/build/_services/server/app.server.d.ts.map +1 -1
  29. package/build/_services/server/app.server.js +24 -0
  30. package/build/_services/server/app.server.js.map +1 -1
  31. package/eslint.config.js +3 -3
  32. package/nodemon.json +24 -24
  33. package/package.json +361 -361
  34. package/pnpm-workspace.yaml +4 -4
  35. package/scripts/run-coverage-tests.js +28 -28
  36. package/spec/support/helpers/spec-reporter-loader.js +359 -359
  37. package/spec/support/helpers/ts-node-helper.js +93 -93
  38. package/spec/support/jasmine.coverage.json +24 -24
  39. package/spec/support/jasmine.json +24 -24
  40. package/src/_collections/archive.util.spec.ts +57 -57
  41. package/src/_collections/archive.util.ts +18 -18
  42. package/src/_collections/atlas-default-db-options.const.ts +9 -9
  43. package/src/_collections/default-fallback-cache-max-age.const.spec.ts +11 -11
  44. package/src/_collections/default-fallback-cache-max-age.const.ts +2 -2
  45. package/src/_collections/default-not-found-page.const.spec.ts +19 -19
  46. package/src/_collections/default-not-found-page.const.ts +22 -22
  47. package/src/_collections/default-socket-path.const.spec.ts +12 -12
  48. package/src/_collections/default-socket-path.const.ts +2 -2
  49. package/src/_collections/get-environment-settings.util.spec.ts +210 -210
  50. package/src/_collections/get-environment-settings.util.ts +48 -48
  51. package/src/_collections/global-settings.const.ts +70 -70
  52. package/src/_collections/sample.env +21 -21
  53. package/src/_collections/star.controller.spec.ts +224 -224
  54. package/src/_collections/star.controller.ts +129 -129
  55. package/src/_enums/data-model-type.enum.ts +14 -14
  56. package/src/_enums/data-service-function.enum.ts +24 -24
  57. package/src/_enums/predefined-data-types.enum.ts +16 -16
  58. package/src/_enums/route-security.enum.ts +12 -12
  59. package/src/_models/control-models/api-call-params.control-model.spec.ts +152 -152
  60. package/src/_models/control-models/api-call-params.control-model.ts +142 -142
  61. package/src/_models/control-models/app-ext-system-controls.control-model.spec.ts +52 -52
  62. package/src/_models/control-models/app-ext-system-controls.control-model.ts +9 -9
  63. package/src/_models/control-models/app-params.control-model.spec.ts +225 -225
  64. package/src/_models/control-models/app-params.control-model.ts +136 -136
  65. package/src/_models/control-models/app-system-controls.control-model.spec.ts +31 -31
  66. package/src/_models/control-models/app-system-controls.control-model.ts +9 -9
  67. package/src/_models/control-models/endpoint-params.control-model.spec.ts +627 -627
  68. package/src/_models/control-models/endpoint-params.control-model.ts +627 -627
  69. package/src/_models/control-models/http-settings.control-model.spec.ts +77 -77
  70. package/src/_models/control-models/http-settings.control-model.ts +37 -37
  71. package/src/_models/control-models/system-control.control-model.spec.ts +27 -27
  72. package/src/_models/control-models/system-control.control-model.ts +12 -12
  73. package/src/_models/interfaces/certification-settings.interface.ts +7 -7
  74. package/src/_models/interfaces/environment-settings.interface.ts +59 -59
  75. package/src/_models/interfaces/global-log-settings.interface.ts +171 -144
  76. package/src/_models/interfaces/global-service-settings.interface.ts +47 -47
  77. package/src/_models/interfaces/routing-module-settings.interface.ts +21 -21
  78. package/src/_models/interfaces/static-client-settings.interface.spec.ts +29 -29
  79. package/src/_models/interfaces/static-client-settings.interface.ts +28 -28
  80. package/src/_models/types/db-update.type.ts +100 -100
  81. package/src/_modules/ai/_models/ai-input-interfaces.ts +117 -117
  82. package/src/_modules/ai/_models/ai-test-generation-result.interface.ts +16 -16
  83. package/src/_modules/ai/_modules/anthropic/_services/aai-user-key.control-service.ts +138 -138
  84. package/src/_modules/ai/_modules/anthropic/index.ts +5 -5
  85. package/src/_modules/ai/_modules/document-ai/_collections/dai-chunking.util.spec.ts +242 -242
  86. package/src/_modules/ai/_modules/document-ai/_collections/dai-chunking.util.ts +639 -639
  87. package/src/_modules/ai/_modules/document-ai/_collections/dai-document.util.spec.ts +209 -209
  88. package/src/_modules/ai/_modules/document-ai/_collections/dai-document.util.ts +85 -85
  89. package/src/_modules/ai/_modules/document-ai/_enums/dai-compare-result-type.enum.ts +7 -7
  90. package/src/_modules/ai/_modules/document-ai/_models/data-models/dai-doc-chunk.data-model.ts +146 -146
  91. package/src/_modules/ai/_modules/document-ai/_models/data-models/dai-doc-page.data-model.ts +162 -162
  92. package/src/_modules/ai/_modules/document-ai/_models/data-models/dai-document.data-model.ts +99 -99
  93. package/src/_modules/ai/_modules/document-ai/_models/interfaces/dai-doc-chunk-compare-result.interface.ts +18 -18
  94. package/src/_modules/ai/_modules/document-ai/_models/interfaces/dai-doc-page-compare-result.interface.ts +19 -19
  95. package/src/_modules/ai/_modules/document-ai/_models/interfaces/dai-document-compare-result.interface.ts +25 -25
  96. package/src/_modules/ai/_modules/document-ai/index.ts +28 -28
  97. package/src/_modules/ai/_modules/fdp-ai/_services/fdpai-user-key.control-service.ts +189 -189
  98. package/src/_modules/ai/_modules/fdp-ai/index.ts +5 -5
  99. package/src/_modules/ai/_modules/open-ai/_collections/oai-global-settings.const.ts +9 -9
  100. package/src/_modules/ai/_modules/open-ai/_collections/oai-llm-predefined-requests-hu.conts.ts +82 -82
  101. package/src/_modules/ai/_modules/open-ai/_collections/oai-llm-predefined-requests.conts.ts +75 -75
  102. package/src/_modules/ai/_modules/open-ai/_enums/oai-gpt-message-role.enum.ts +45 -45
  103. package/src/_modules/ai/_modules/open-ai/_models/interfaces/oai-global-settings.interface.ts +7 -7
  104. package/src/_modules/ai/_modules/open-ai/_models/interfaces/oai-gpt-message.interface.ts +7 -7
  105. package/src/_modules/ai/_modules/open-ai/_models/interfaces/oai-llm-predefined-requests.interface.ts +57 -57
  106. package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-doc-chunk-data.service.ts +292 -292
  107. package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-document.data-service.spec.ts +342 -342
  108. package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-vector-data.service.spec.ts +550 -550
  109. package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-vector-data.service.ts +630 -630
  110. package/src/_modules/ai/_modules/open-ai/_services/oai-embedding.control-service.spec.ts +332 -332
  111. package/src/_modules/ai/_modules/open-ai/_services/oai-llm-chat.service-base.spec.ts +462 -462
  112. package/src/_modules/ai/_modules/open-ai/_services/oai-llm-chat.service-base.ts +634 -634
  113. package/src/_modules/ai/_modules/open-ai/_services/oai-llm.service-base.spec.ts +489 -489
  114. package/src/_modules/ai/_modules/open-ai/_services/oai-llm.service-base.tools.spec.ts +173 -173
  115. package/src/_modules/ai/_modules/open-ai/_services/oai-llm.service-base.ts +1033 -1033
  116. package/src/_modules/ai/_modules/open-ai/_services/oai-user-key.control-service.ts +157 -157
  117. package/src/_modules/ai/_services/ai-embedding.service-base.spec.ts +98 -98
  118. package/src/_modules/ai/_services/ai-embedding.service-base.ts +48 -48
  119. package/src/_modules/ai/_services/ai-llm-chat.service-base.spec.ts +229 -229
  120. package/src/_modules/ai/_services/ai-llm-chat.service-base.ts +68 -68
  121. package/src/_modules/ai/_services/ai-llm.service-base.spec.ts +250 -250
  122. package/src/_modules/ai/_services/ai-llm.service-base.ts +519 -519
  123. package/src/_modules/ai/_services/ai-provider.service-base.spec.ts +158 -158
  124. package/src/_modules/ai/_services/ai-user-key.service-base.ts +59 -59
  125. package/src/_modules/ai/index.ts +13 -13
  126. package/src/_modules/assistant/_collections/ass-global-settings.const.ts +13 -13
  127. package/src/_modules/assistant/_collections/ass.util.spec.ts +176 -176
  128. package/src/_modules/assistant/_collections/ass.util.ts +50 -50
  129. package/src/_modules/assistant/_models/ass-global-settings.interface.ts +15 -15
  130. package/src/_modules/assistant/_services/ass-io.control-service.spec.ts +140 -140
  131. package/src/_modules/assistant/_services/ass-main.control-service.spec.ts +192 -192
  132. package/src/_modules/assistant/_services/ass-main.control-service.ts +107 -107
  133. package/src/_modules/bot/_collections/bot-default-commands.const.ts +12 -12
  134. package/src/_modules/bot/_collections/bot-global-settings.const.ts +39 -39
  135. package/src/_modules/bot/_models/bot-channel-wrapper.interface.ts +62 -62
  136. package/src/_modules/bot/_models/bot-command.interface.ts +8 -8
  137. package/src/_modules/bot/_models/bot-global-settings.interface.ts +96 -96
  138. package/src/_modules/bot/_models/bot-last-mention-date.interface.ts +6 -6
  139. package/src/_modules/bot/_models/bot-last-message-date.interface.ts +5 -5
  140. package/src/_modules/bot/_models/bot-user-wrapper.interface.ts +41 -41
  141. package/src/_modules/bot/_modules/discord-bot/_models/dib-platform.types.ts +9 -9
  142. package/src/_modules/bot/_modules/discord-bot/_services/dib-messaging-provider.control-service.spec.ts +431 -431
  143. package/src/_modules/bot/_modules/dynamo-bot/_collections/dyb-operations.util.spec.ts +160 -160
  144. package/src/_modules/bot/_modules/dynamo-bot/_collections/dyb-operations.util.ts +55 -55
  145. package/src/_modules/bot/_modules/dynamo-bot/_models/dyb-platform.types.ts +15 -15
  146. package/src/_modules/bot/_modules/dynamo-bot/_services/dyb-messaging-provider.control-service.spec.ts +374 -374
  147. package/src/_modules/bot/_modules/dynamo-bot/_services/dyb-messaging-provider.control-service.ts +447 -447
  148. package/src/_modules/bot/_modules/dynamo-bot/index.ts +15 -15
  149. package/src/_modules/bot/_modules/slack-bot/_models/slb-platform.types.ts +9 -9
  150. package/src/_modules/bot/_modules/slack-bot/_services/slb-messaging-provider.control-service.spec.ts +344 -344
  151. package/src/_modules/bot/_modules/slack-bot/_services/slb-messaging-provider.control-service.ts +197 -197
  152. package/src/_modules/bot/_modules/teams-bot/_models/teb-platform.types.ts +9 -9
  153. package/src/_modules/bot/_modules/teams-bot/_services/teb-messaging-provider.control-service.spec.ts +345 -345
  154. package/src/_modules/bot/_modules/teams-bot/_services/teb-messaging-provider.control-service.ts +197 -197
  155. package/src/_modules/bot/_services/bot-commands.control-service.spec.ts +116 -116
  156. package/src/_modules/bot/_services/bot-io.control-service.spec.ts +285 -285
  157. package/src/_modules/bot/_services/bot-main.control-service.spec.ts +208 -208
  158. package/src/_modules/bot/_services/bot-messaging-provider.service-base.spec.ts +349 -349
  159. package/src/_modules/bot/_services/bot-routines.control-service.spec.ts +111 -111
  160. package/src/_modules/custom-data/custom-data.controller.spec.ts +49 -49
  161. package/src/_modules/custom-data/custom-data.controller.ts +67 -67
  162. package/src/_modules/custom-data/custom-data.data-service.spec.ts +54 -54
  163. package/src/_modules/custom-data/custom-data.data-service.ts +21 -21
  164. package/src/_modules/custom-data/get-custom-data-routing-module.util.spec.ts +28 -28
  165. package/src/_modules/custom-data/get-custom-data-routing-module.util.ts +24 -24
  166. package/src/_modules/custom-data/index.ts +9 -9
  167. package/src/_modules/defaults/_collections/default-endpoints.util.ts +487 -487
  168. package/src/_modules/defaults/_models/default-user.data-model.ts +72 -72
  169. package/src/_modules/defaults/_services/default-auth.service.spec.ts +269 -269
  170. package/src/_modules/defaults/_services/default-auth.service.ts +177 -177
  171. package/src/_modules/defaults/_services/default-socket-events.service.spec.ts +42 -42
  172. package/src/_modules/defaults/_services/default-socket-events.service.ts +61 -61
  173. package/src/_modules/defaults/_services/default-user.data-service.spec.ts +187 -187
  174. package/src/_modules/defaults/_services/default-user.data-service.ts +98 -98
  175. package/src/_modules/defaults/index.ts +17 -17
  176. package/src/_modules/discord-assistant/_collections/dias-global-settings.const.ts +19 -19
  177. package/src/_modules/discord-assistant/_collections/dias.util.spec.ts +366 -366
  178. package/src/_modules/discord-assistant/_collections/dias.util.ts +132 -132
  179. package/src/_modules/discord-assistant/_models/dias-global-settings.interface.ts +19 -19
  180. package/src/_modules/discord-assistant/_models/dias-knowledge.data-model.ts +52 -52
  181. package/src/_modules/discord-assistant/_services/dias-chunk.data-service.ts +177 -177
  182. package/src/_modules/discord-assistant/_services/dias-io.control-service.spec.ts +108 -108
  183. package/src/_modules/discord-assistant/_services/dias-io.control-service.ts +69 -69
  184. package/src/_modules/discord-assistant/_services/dias-main.control-service.spec.ts +22 -22
  185. package/src/_modules/discord-assistant/_services/dias-main.control-service.ts +27 -27
  186. package/src/_modules/discord-assistant/_services/dias.service-base.spec.ts +195 -195
  187. package/src/_modules/discord-assistant/_services/dias.service-base.ts +76 -76
  188. package/src/_modules/discord-assistant/index.ts +38 -38
  189. package/src/_modules/discord-assistant-voiced/_services/dias-discord-bot.control-service.spec.ts +34 -34
  190. package/src/_modules/discord-assistant-voiced/_services/dias-discord-bot.control-service.ts +11 -11
  191. package/src/_modules/discord-assistant-voiced/index.ts +36 -36
  192. package/src/_modules/discord-bot/_collections/dibo-default-commands.const.ts +16 -16
  193. package/src/_modules/discord-bot/_collections/dibo-global-settings.conts.ts +55 -55
  194. package/src/_modules/discord-bot/_collections/dibo-operations.util.spec.ts +214 -214
  195. package/src/_modules/discord-bot/_collections/dibo-operations.util.ts +387 -387
  196. package/src/_modules/discord-bot/_models/dibo-command.interface.ts +12 -12
  197. package/src/_modules/discord-bot/_models/dibo-global-settings.interface.ts +98 -98
  198. package/src/_modules/discord-bot/_models/dibo-last-mention-date.inteface.ts +7 -7
  199. package/src/_modules/discord-bot/_models/dibo-last-message-date.interface.ts +6 -6
  200. package/src/_modules/discord-bot/_services/dibo-commands.control-service.spec.ts +154 -154
  201. package/src/_modules/discord-bot/_services/dibo-commands.control-service.ts +153 -153
  202. package/src/_modules/discord-bot/_services/dibo-io.control-service.spec.ts +264 -264
  203. package/src/_modules/discord-bot/_services/dibo-io.control-service.ts +306 -306
  204. package/src/_modules/discord-bot/_services/dibo-main.control-service.spec.ts +408 -408
  205. package/src/_modules/discord-bot/_services/dibo-main.control-service.ts +487 -487
  206. package/src/_modules/discord-bot/_services/dibo-routines.control-service.spec.ts +105 -105
  207. package/src/_modules/discord-bot/index.ts +36 -36
  208. package/src/_modules/local-vector-search/_enums/lvs-search-mode.enum.ts +35 -35
  209. package/src/_modules/local-vector-search/_models/lvs-search-result.interface.ts +17 -17
  210. package/src/_modules/local-vector-search/_services/lvs-doc-chunk-data.service.spec.ts +418 -418
  211. package/src/_modules/local-vector-search/_services/lvs-doc-chunk-data.service.ts +276 -276
  212. package/src/_modules/local-vector-search/_services/lvs-local-vector-search.data-service.spec.ts +480 -480
  213. package/src/_modules/local-vector-search/_services/lvs-local-vector-search.data-service.ts +416 -416
  214. package/src/_modules/local-vector-search/_services/lvs-vector-pool.control-service.spec.ts +393 -393
  215. package/src/_modules/local-vector-search/_services/lvs-vector-pool.control-service.ts +220 -220
  216. package/src/_modules/local-vector-search/index.ts +11 -11
  217. package/src/_modules/logs/index.ts +11 -11
  218. package/src/_modules/messaging/README.md +354 -354
  219. package/src/_modules/messaging/_collections/get-messaging-routing-module.util.ts +26 -26
  220. package/src/_modules/messaging/_collections/msg-global-settings.const.ts +22 -22
  221. package/src/_modules/messaging/_collections/msg.util.spec.ts +226 -226
  222. package/src/_modules/messaging/_models/msg-global-settings.interface.ts +37 -37
  223. package/src/_modules/messaging/_services/msg-conversation.data-service.ts +146 -146
  224. package/src/_modules/messaging/_services/msg-events.service.spec.ts +219 -219
  225. package/src/_modules/messaging/_services/msg-events.service.ts +267 -267
  226. package/src/_modules/messaging/_services/msg-integration.control-service.ts +179 -179
  227. package/src/_modules/messaging/_services/msg-main.control-service.spec.ts +147 -147
  228. package/src/_modules/messaging/_services/msg-main.control-service.ts +571 -571
  229. package/src/_modules/messaging/_services/msg-message.data-service.ts +129 -129
  230. package/src/_modules/messaging/_services/msg.controller.spec.ts +201 -201
  231. package/src/_modules/messaging/index.ts +30 -30
  232. package/src/_modules/mock/app-extended-server.mock.ts +201 -201
  233. package/src/_modules/mock/app-integration-test.mock.ts +51 -51
  234. package/src/_modules/mock/app-params.mock.spec.ts +21 -21
  235. package/src/_modules/mock/app-params.mock.ts +9 -9
  236. package/src/_modules/mock/app-server.mock.ts +188 -188
  237. package/src/_modules/mock/auth-service.mock.spec.ts +47 -47
  238. package/src/_modules/mock/auth-service.mock.ts +28 -28
  239. package/src/_modules/mock/controller.mock.spec.ts +26 -26
  240. package/src/_modules/mock/controller.mock.ts +16 -16
  241. package/src/_modules/mock/data-model.mock.spec.ts +111 -111
  242. package/src/_modules/mock/data-model.mock.ts +82 -82
  243. package/src/_modules/mock/email-service-collection.mock.spec.ts +24 -24
  244. package/src/_modules/mock/email-service-collection.mock.ts +15 -15
  245. package/src/_modules/mock/email-service.mock.spec.ts +17 -17
  246. package/src/_modules/mock/email-service.mock.ts +20 -20
  247. package/src/_modules/mock/email-template.mock.html +14 -14
  248. package/src/_modules/mock/endpoint.mock.ts +91 -91
  249. package/src/_modules/mock/socket-client.mock.spec.ts +40 -40
  250. package/src/_modules/mock/socket-client.mock.ts +45 -45
  251. package/src/_modules/mock/socket-server.mock.spec.ts +44 -44
  252. package/src/_modules/mock/socket-server.mock.ts +46 -46
  253. package/src/_modules/oauth2/_routes/oauth2.controller.spec.ts +107 -107
  254. package/src/_modules/oauth2/_routes/oauth2.controller.ts +98 -98
  255. package/src/_modules/oauth2/_services/oauth2.auth-service.spec.ts +254 -254
  256. package/src/_modules/oauth2/_services/oauth2.auth-service.ts +232 -232
  257. package/src/_modules/oauth2/_services/oauth2.control-service.spec.ts +585 -585
  258. package/src/_modules/oauth2/_services/oauth2.control-service.ts +653 -653
  259. package/src/_modules/oauth2/index.ts +17 -17
  260. package/src/_modules/server/errors/errors.control-service.spec.ts +238 -238
  261. package/src/_modules/server/errors/errors.control-service.ts +85 -85
  262. package/src/_modules/server/errors/errors.controller.spec.ts +241 -241
  263. package/src/_modules/server/errors/errors.controller.ts +431 -431
  264. package/src/_modules/server/errors/errors.data-service.spec.ts +361 -361
  265. package/src/_modules/server/index.ts +30 -30
  266. package/src/_modules/server/server-status/server-status-snapshot.control-service.spec.ts +70 -70
  267. package/src/_modules/server/server-status/server-status-snapshot.control-service.ts +17 -17
  268. package/src/_modules/server/server-status/server-status-snapshot.data-service.spec.ts +77 -77
  269. package/src/_modules/server/server-status/server-status-snapshot.data-service.ts +37 -37
  270. package/src/_modules/server/server-status/server-status.control-service.spec.ts +576 -576
  271. package/src/_modules/server/server-status/server-status.control-service.ts +396 -396
  272. package/src/_modules/server/server-status/server-status.controller.spec.ts +240 -240
  273. package/src/_modules/server/server-status/server-status.controller.ts +253 -253
  274. package/src/_modules/socket/_enums/socket-security.enum.ts +11 -11
  275. package/src/_modules/socket/_models/socket-client-service-params.control-model.spec.ts +32 -32
  276. package/src/_modules/socket/_models/socket-client-service-params.control-model.ts +22 -22
  277. package/src/_modules/socket/_models/socket-presence.control-model.spec.ts +164 -164
  278. package/src/_modules/socket/_models/socket-presence.control-model.ts +210 -210
  279. package/src/_modules/socket/_models/socket-server-service-params.control-model.spec.ts +46 -46
  280. package/src/_modules/socket/_models/socket-server-service-params.control-model.ts +22 -22
  281. package/src/_modules/socket/_services/socket-client.service.spec.ts +15 -15
  282. package/src/_modules/socket/_services/socket-client.service.ts +260 -260
  283. package/src/_modules/socket/_services/socket-server.service.spec.ts +11 -11
  284. package/src/_modules/socket/app-extended.integration.spec.ts +85 -85
  285. package/src/_modules/socket/app-extended.server.ts +630 -630
  286. package/src/_modules/socket/index.ts +42 -42
  287. package/src/_modules/test/get-test-routing-module.util.spec.ts +28 -28
  288. package/src/_modules/test/get-test-routing-module.util.ts +23 -23
  289. package/src/_modules/test/index.ts +11 -11
  290. package/src/_modules/test/test.controller.spec.ts +72 -72
  291. package/src/_modules/test/test.controller.ts +115 -115
  292. package/src/_modules/usage/get-usage-routing-module.util.ts +22 -22
  293. package/src/_modules/usage/index.ts +15 -15
  294. package/src/_modules/usage/usage.controller.spec.ts +81 -81
  295. package/src/_modules/usage/usage.controller.ts +126 -126
  296. package/src/_modules/usage/usage.data-service.spec.ts +332 -332
  297. package/src/_modules/usage/usage.data-service.ts +185 -185
  298. package/src/_services/base/api.service-base.spec.ts +125 -125
  299. package/src/_services/base/api.service-base.ts +74 -74
  300. package/src/_services/base/archive-data.service.spec.ts +196 -196
  301. package/src/_services/base/archive-data.service.ts +216 -216
  302. package/src/_services/base/data.service.spec.ts +674 -674
  303. package/src/_services/base/data.service.ts +2719 -2719
  304. package/src/_services/base/db.service.spec.ts +73 -73
  305. package/src/_services/base/db.service.ts +1575 -1575
  306. package/src/_services/base/singleton.service-base.spec.ts +28 -28
  307. package/src/_services/base/singleton.service-base.ts +24 -24
  308. package/src/_services/base/singleton.service.spec.ts +114 -114
  309. package/src/_services/base/singleton.service.ts +38 -38
  310. package/src/_services/core/api.service.spec.ts +140 -140
  311. package/src/_services/core/auth.service.spec.ts +159 -159
  312. package/src/_services/core/auth.service.ts +174 -174
  313. package/src/_services/core/email.service.spec.ts +85 -85
  314. package/src/_services/core/email.service.ts +742 -742
  315. package/src/_services/core/global.service.spec.ts +275 -275
  316. package/src/_services/core/global.service.ts +461 -461
  317. package/src/_services/core/service-collection.service.spec.ts +46 -46
  318. package/src/_services/core/service-collection.service.ts +6 -6
  319. package/src/_services/route/controller.service.spec.ts +53 -53
  320. package/src/_services/route/controller.service.ts +148 -148
  321. package/src/_services/route/routing-module.service.spec.ts +98 -98
  322. package/src/_services/route/routing-module.service.ts +330 -330
  323. package/src/_services/server/app.server.ts +1713 -1672
  324. package/src/_services/shared.static-service.spec.ts +99 -99
  325. package/src/_services/shared.static-service.ts +78 -78
  326. package/src/index.ts +95 -95
  327. package/tsconfig.app.json +12 -12
  328. package/tsconfig.json +42 -42
  329. package/.dynamo/logs/cicd-pipeline/output.log +0 -2682
  330. package/.dynamo/logs/cicd-pipeline/status.json +0 -351
@@ -1,397 +1,397 @@
1
-
2
-
3
- import {
4
- DyFM_Metadata, DyFM_RelativeDate, DyFM_Time, DyFM_ServerStatus, DyFM_ErrorLevel, DyFM_Log,
5
- DyFM_Error, DyFM_Error_Statistics, DyFM_Errors,
6
- DyFM_Paged,
7
- hour, minute,
8
- DyFM_ServerConnectionCheckResult,
9
- DyFM_ServerConnection_Status,
10
- DyFM_Array
11
- } from '@futdevpro/fsm-dynamo';
12
- import { Subscription, timer } from 'rxjs';
13
- import * as mongoose from 'mongoose';
14
-
15
- import { version as _serverVersion } from '../../../../package.json';
16
- import { DyNTS_SingletonService } from '../../../_services/base/singleton.service';
17
- import { DyNTS_global_settings } from '../../../_collections/global-settings.const';
18
- import { DyNTS_Errors_ControlService } from '../errors/errors.control-service';
19
- import { DyNTS_ServerStatusSnapshot_ControlService } from './server-status-snapshot.control-service';
20
- import { DyNTS_GlobalService } from '../../../_services/core/global.service';
21
- import { DyNTS_ApiService_Base } from '../../../_services/base/api.service-base';
22
-
23
- export interface DyNTS_ServerConnection {
24
- name: string,
25
- apiService: DyNTS_ApiService_Base,
26
- accessible?: boolean,
27
- lastCheck?: Date,
28
- }
29
-
30
- /**
31
- * A readiness-probe ({@link DyNTS_ServerStatus_ControlService.checkDbReadiness}) eredménye.
32
- * `ready=true` CSAK ha a DB-connection él (readyState=1) ÉS a valós ping round-trip sikerült.
33
- */
34
- export interface DyNTS_DbReadiness {
35
- /** ready: a DB elérhető (readyState=1 + sikeres ping). Erre adjon az endpoint 200-at, különben 503-at. */
36
- ready: boolean;
37
- /** mongoose connection.readyState: 0=disconnected, 1=connected, 2=connecting, 3=disconnecting. */
38
- dbReadyState: number;
39
- /** Sikerült-e a valós DB ping round-trip (csak readyState=1-nél próbáljuk). */
40
- dbPingOk: boolean;
41
- /** A szerver uptime ms-ban. */
42
- uptime: number;
43
- /** A szerver verziója. */
44
- serverVersion: string;
45
- }
46
-
47
- export abstract class DyNTS_ServerStatus_ControlService<
48
- T_ServerStatus extends DyFM_ServerStatus,
49
- T_Error extends DyFM_Error,
50
- T_Errors extends DyFM_Errors<T_Error>,
51
- T_Errors_ControlService extends DyNTS_Errors_ControlService<T_Error, T_Errors>,
52
- T_ServerStatusSnapshot extends DyFM_ServerStatus,
53
- T_ServerStatusSnapshot_ControlService extends DyNTS_ServerStatusSnapshot_ControlService<T_ServerStatusSnapshot>
54
- > extends DyNTS_SingletonService {
55
-
56
- protected abstract getErrorControlService?(
57
- set?: { data?: T_Errors, issuer?: string }
58
- ): T_Errors_ControlService;
59
-
60
- protected abstract getServerStatusSnapshotControlService?(
61
- set?: { data?: T_ServerStatus, issuer?: string }
62
- ): T_ServerStatusSnapshot_ControlService;
63
-
64
- protected readonly up: Date = new Date();
65
-
66
- protected readonly _serverVersionNumeric: number = this.getVersionNumeric(_serverVersion);
67
- get serverVersion(): string { return _serverVersion; }
68
- get serverVersionNumeric(): number { return this._serverVersionNumeric; }
69
-
70
- protected _latestClientVersion: string;
71
- protected _latestClientVersionNumeric: number;
72
- get latestClientVersion(): string { return this._latestClientVersion; }
73
- get latestClientVersionNumeric(): number { return this._latestClientVersionNumeric; }
74
-
75
- protected abstract requiredServerConnections: DyNTS_ServerConnection[];
76
- protected connectionMaxCheckFrequency = 15 * minute;
77
-
78
- override readonly defaultErrorUserMsg = 'Something went wrong';
79
-
80
- readonly overseerTickTime = 6 * hour;
81
- overseer: Subscription;
82
-
83
- protected constructor() {
84
- super();
85
-
86
- /* if (DyNTS_global_settings.log_settings.setup) {
87
- DyFM_Log.log(
88
- 'Required server connections:', JSON.stringify(this.requiredServerConnections.map(
89
- (connection: DyNTS_ServerConnection): { name: string, baseUrl: string, testEndpoint: string } => ({
90
- name: connection.name,
91
- baseUrl: connection.apiService.baseUrl,
92
- testEndpoint: connection.apiService.testEndpoint ?? '',
93
- })
94
- ), null, 2)
95
- );
96
- } */
97
-
98
- this.overseer = timer(this.overseerTickTime, this.overseerTickTime).subscribe(async () => {
99
- try {
100
- await this.triggerCreateSnapshot('overseer-system-tick');
101
- } catch (error) {
102
- DyFM_Error.logSimple(' ! Error in overseer (server status):', error);
103
- DyNTS_GlobalService.globalErrorHandler(
104
- new DyFM_Error({
105
- ...this.getDefaultErrorSettings('overseer tick', error, 'overseer-system-tick'),
106
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSCS-OT0`,
107
- })
108
- ).catch();
109
- }
110
- });
111
- }
112
-
113
- async getServerStatus(issuer: string, clientVersion?: string): Promise<DyFM_ServerStatus> {
114
- try {
115
- return {
116
- status: 'ready',
117
-
118
- systemName: DyNTS_global_settings.systemName,
119
- systemShortCode: DyNTS_global_settings.systemShortCodeName,
120
-
121
- clientVersionOk: clientVersion ? this.clientVersionIsLatest(clientVersion) : false,
122
- latestClientVersion: this.latestClientVersion,
123
- latestClientVersionNumeric: this.latestClientVersionNumeric,
124
-
125
- serverVersion: this.serverVersion,
126
- serverNumericVersion: this.serverVersionNumeric,
127
-
128
- uptime: +new Date() - +this.up,
129
-
130
- memoryUsage: process.memoryUsage(),
131
- cpuUsage: process.cpuUsage(),
132
- serverConnections: await this.checkServerConnections(issuer),
133
- }
134
- } catch (error) {
135
- throw new DyFM_Error({
136
- ...this.getDefaultErrorSettings('getServerStatus', error, issuer),
137
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSCS-GSS0`,
138
- });
139
- }
140
- }
141
-
142
- async checkServerConnections(issuer: string): Promise<DyFM_ServerConnectionCheckResult> {
143
- try {
144
- const connections: DyFM_ServerConnectionCheckResult = {};
145
-
146
- await DyFM_Array.asyncForEachAllAtOnce(
147
- this.requiredServerConnections,
148
- async (connection: DyNTS_ServerConnection) => {
149
- if (!connection.accessible || Date.now() - connection.lastCheck.getTime() > this.connectionMaxCheckFrequency) {
150
- await connection.apiService.checkServerAvailability(issuer).catch((error) => {
151
- DyFM_Error.logSimple(
152
- `(checkServerConnections) "${connection.name}" server is not available` +
153
- `\n baseUrl: ${connection.apiService.baseUrl}` +
154
- `\n testEndpoint: ${connection.apiService.testEndpoint ?? ''}`,
155
- error
156
- );
157
- connection.accessible = false;
158
- }).then(() => {
159
- connection.accessible = true;
160
- });
161
- connection.accessible = true;
162
- connection.lastCheck = new Date();
163
- }
164
-
165
- connections[connection.name] = connection.accessible ? DyFM_ServerConnection_Status.accessible : DyFM_ServerConnection_Status.unaccessible;
166
- }
167
- )
168
-
169
- return connections;
170
- } catch (error) {
171
- throw new DyFM_Error({
172
- ...this.getDefaultErrorSettings('checkServerConnections', error, issuer),
173
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSCS-CC0`,
174
- });
175
- }
176
- }
177
-
178
- /**
179
- * A mongoose default-connection. Külön metódus = teszt-seam (spy-jal felülírható, hogy a
180
- * {@link checkDbReadiness} DB nélkül is tesztelhető legyen).
181
- */
182
- protected getMongooseConnection(): mongoose.Connection {
183
- return mongoose.connection;
184
- }
185
-
186
- /**
187
- * Readiness-probe: a `/health` (liveness — "a process fut + kiszolgál") MELLETT a DB-elérhetőséget
188
- * ellenőrzi. A readyState (mongoose driver-állapot) + egy valós `ping` round-trip → így a "connected
189
- * de a DB nem válaszol" eset is kibukik. **Sosem dob** (a probe-nak determinisztikusan kell válaszolnia);
190
- * hiba esetén `ready=false`. Az endpoint 503-at adjon, ha nem ready → az orchestrátor (k8s/docker/LB)
191
- * ne irányítson forgalmat a DB-vesztett instance-ra.
192
- */
193
- async checkDbReadiness(): Promise<DyNTS_DbReadiness> {
194
- let dbReadyState: number = 0;
195
- let dbPingOk: boolean = false;
196
-
197
- try {
198
- const connection: mongoose.Connection = this.getMongooseConnection();
199
- // readyState: 0=disconnected, 1=connected, 2=connecting, 3=disconnecting
200
- dbReadyState = connection?.readyState ?? 0;
201
-
202
- if (dbReadyState === 1) {
203
- await connection.db?.admin().ping();
204
- dbPingOk = true;
205
- }
206
- } catch (error) {
207
- DyFM_Log.warn('(checkDbReadiness) DB readiness check failed', error);
208
- dbPingOk = false;
209
- }
210
-
211
- return {
212
- ready: dbReadyState === 1 && dbPingOk,
213
- dbReadyState: dbReadyState,
214
- dbPingOk: dbPingOk,
215
- uptime: +new Date() - +this.up,
216
- serverVersion: this.serverVersion,
217
- };
218
- }
219
-
220
- async getErrorStatistics(
221
- range: DyFM_RelativeDate,
222
- issuer: string
223
- ): Promise<DyFM_Error_Statistics> {
224
- try {
225
- const error_DS: T_Errors_ControlService =
226
- this.getErrorControlService({ issuer: issuer });
227
- /* new DyNTS_Error_DataService({ issuer: issuer }); */
228
-
229
- const from: Date = DyFM_Time.getDateByRelativeDate(range);
230
- const errorsPaged: DyFM_Paged<T_Errors> = await error_DS.getErrorsFromDate(from, issuer);
231
- const errors: T_Errors[] = errorsPaged.items;
232
-
233
- return {
234
- range: range,
235
-
236
- allErrors: errors.length,
237
- allAllErrors: errors.reduce(
238
- (sum: number, error: T_Errors): number => sum + error.count,
239
- 0
240
- ),
241
-
242
- serverErrors:
243
- errors.filter(
244
- (error: T_Errors): boolean => error.source.includes('SERVER')
245
- ).length,
246
- clientErrors:
247
- errors.filter(
248
- (error: T_Errors): boolean => !error.source.includes('SERVER')
249
- ).length,
250
- allServerErrors:
251
- errors.filter(
252
- (error: T_Errors): boolean => error.source.includes('SERVER')
253
- ).reduce(
254
- (sum: number, error: T_Errors): number => sum + error.count, 0
255
- ),
256
- allClientErrors:
257
- errors.filter(
258
- (error: T_Errors): boolean => !error.source.includes('SERVER')
259
- ).reduce(
260
- (sum: number, error: T_Errors): number => sum + error.count, 0
261
- ),
262
-
263
- infoErrors:
264
- errors.filter(
265
- (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.info
266
- ).length,
267
- warningErrors:
268
- errors.filter(
269
- (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.warning
270
- ).length,
271
- errorErrors:
272
- errors.filter(
273
- (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.error
274
- ).length,
275
- criticalErrors:
276
- errors.filter(
277
- (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.critical
278
- ).length,
279
-
280
- allInfoErrors:
281
- errors.filter(
282
- (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.info
283
- ).reduce(
284
- (sum: number, error: T_Errors): number => sum + error.count, 0
285
- ),
286
- allWarningErrors:
287
- errors.filter(
288
- (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.warning
289
- ).reduce(
290
- (sum: number, error: T_Errors): number => sum + error.count, 0
291
- ),
292
- allErrorErrors:
293
- errors.filter(
294
- (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.error
295
- ).reduce(
296
- (sum: number, error: T_Errors): number => sum + error.count, 0
297
- ),
298
- allCriticalErrors:
299
- errors.filter(
300
- (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.critical
301
- ).reduce(
302
- (sum: number, error: T_Errors): number => sum + error.count, 0
303
- ),
304
- } as DyFM_Error_Statistics;
305
- } catch (error) {
306
- throw new DyFM_Error({
307
- ...this.getDefaultErrorSettings(
308
- 'getMatchStatistics',
309
- error?.response?.data ?? error,
310
- issuer
311
- ),
312
-
313
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-GES0`,
314
- });
315
- }
316
- }
317
-
318
- protected getVersionNumeric(version: string): number {
319
- return +version.replace('v', '')
320
- .replace('.', '')
321
- .replace('.', '')
322
- .replace('-alpha', '')
323
- .replace('-beta', '')
324
- .replace('-test', '')
325
- .replace('-dev', '');
326
- }
327
-
328
- protected clientVersionIsLatest(clientVersion: string): boolean {
329
- const thisClientVersionNumeric: number = this.getVersionNumeric(clientVersion);
330
-
331
- if (!this._latestClientVersionNumeric) {
332
- this.setLatestClientVersion(clientVersion, thisClientVersionNumeric);
333
-
334
- return true;
335
-
336
- } else if (thisClientVersionNumeric === this._latestClientVersionNumeric) {
337
- return true;
338
-
339
- } else if (thisClientVersionNumeric < this._latestClientVersionNumeric) {
340
- return false;
341
-
342
- } else if (this._latestClientVersionNumeric < thisClientVersionNumeric) {
343
- this.setLatestClientVersion(clientVersion, thisClientVersionNumeric);
344
-
345
- return true;
346
- }
347
-
348
- DyFM_Log.error(
349
- 'Something went wrong, invalid version:', clientVersion,
350
- thisClientVersionNumeric, _serverVersion, this.serverVersionNumeric
351
- );
352
-
353
- return false;
354
- }
355
-
356
- protected setLatestClientVersion(clientVersion: string, clientVersionNumeric: number): void {
357
- if (!clientVersion.includes('test') && !clientVersion.includes('dev')) {
358
- this._latestClientVersion = clientVersion;
359
- this._latestClientVersionNumeric = clientVersionNumeric;
360
- }
361
- }
362
-
363
- protected async triggerCreateSnapshot(issuer: string): Promise<void> {
364
- try {
365
- const snapshot: T_ServerStatusSnapshot = await this.getServerStatusSnapshot(issuer);
366
- const serverStatusSnapshot_CS: T_ServerStatusSnapshot_ControlService =
367
- this.getServerStatusSnapshotControlService({ issuer: issuer });
368
-
369
- await serverStatusSnapshot_CS.saveSnapshot(snapshot, issuer);
370
-
371
- DyFM_Log.info('ServerStatus snapshot created');
372
- } catch (error) {
373
- throw new DyFM_Error({
374
- ...this.getDefaultErrorSettings('triggerCreateSnapshot', error, 'system-tick'),
375
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSCS-TCS0`,
376
- });
377
- }
378
- }
379
-
380
- async getServerStatusSnapshot(issuer: string): Promise<T_ServerStatusSnapshot> {
381
- try {
382
- return ({
383
- ...(await this.getServerStatus(issuer)),
384
- }) as T_ServerStatusSnapshot;
385
- } catch (error) {
386
- throw new DyFM_Error({
387
- ...this.getDefaultErrorSettings(
388
- 'getServerStatusSnapshot',
389
- error?.response?.data ?? error,
390
- issuer
391
- ),
392
-
393
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSCS-GSS0`,
394
- });
395
- }
396
- }
1
+
2
+
3
+ import {
4
+ DyFM_Metadata, DyFM_RelativeDate, DyFM_Time, DyFM_ServerStatus, DyFM_ErrorLevel, DyFM_Log,
5
+ DyFM_Error, DyFM_Error_Statistics, DyFM_Errors,
6
+ DyFM_Paged,
7
+ hour, minute,
8
+ DyFM_ServerConnectionCheckResult,
9
+ DyFM_ServerConnection_Status,
10
+ DyFM_Array
11
+ } from '@futdevpro/fsm-dynamo';
12
+ import { Subscription, timer } from 'rxjs';
13
+ import * as mongoose from 'mongoose';
14
+
15
+ import { version as _serverVersion } from '../../../../package.json';
16
+ import { DyNTS_SingletonService } from '../../../_services/base/singleton.service';
17
+ import { DyNTS_global_settings } from '../../../_collections/global-settings.const';
18
+ import { DyNTS_Errors_ControlService } from '../errors/errors.control-service';
19
+ import { DyNTS_ServerStatusSnapshot_ControlService } from './server-status-snapshot.control-service';
20
+ import { DyNTS_GlobalService } from '../../../_services/core/global.service';
21
+ import { DyNTS_ApiService_Base } from '../../../_services/base/api.service-base';
22
+
23
+ export interface DyNTS_ServerConnection {
24
+ name: string,
25
+ apiService: DyNTS_ApiService_Base,
26
+ accessible?: boolean,
27
+ lastCheck?: Date,
28
+ }
29
+
30
+ /**
31
+ * A readiness-probe ({@link DyNTS_ServerStatus_ControlService.checkDbReadiness}) eredménye.
32
+ * `ready=true` CSAK ha a DB-connection él (readyState=1) ÉS a valós ping round-trip sikerült.
33
+ */
34
+ export interface DyNTS_DbReadiness {
35
+ /** ready: a DB elérhető (readyState=1 + sikeres ping). Erre adjon az endpoint 200-at, különben 503-at. */
36
+ ready: boolean;
37
+ /** mongoose connection.readyState: 0=disconnected, 1=connected, 2=connecting, 3=disconnecting. */
38
+ dbReadyState: number;
39
+ /** Sikerült-e a valós DB ping round-trip (csak readyState=1-nél próbáljuk). */
40
+ dbPingOk: boolean;
41
+ /** A szerver uptime ms-ban. */
42
+ uptime: number;
43
+ /** A szerver verziója. */
44
+ serverVersion: string;
45
+ }
46
+
47
+ export abstract class DyNTS_ServerStatus_ControlService<
48
+ T_ServerStatus extends DyFM_ServerStatus,
49
+ T_Error extends DyFM_Error,
50
+ T_Errors extends DyFM_Errors<T_Error>,
51
+ T_Errors_ControlService extends DyNTS_Errors_ControlService<T_Error, T_Errors>,
52
+ T_ServerStatusSnapshot extends DyFM_ServerStatus,
53
+ T_ServerStatusSnapshot_ControlService extends DyNTS_ServerStatusSnapshot_ControlService<T_ServerStatusSnapshot>
54
+ > extends DyNTS_SingletonService {
55
+
56
+ protected abstract getErrorControlService?(
57
+ set?: { data?: T_Errors, issuer?: string }
58
+ ): T_Errors_ControlService;
59
+
60
+ protected abstract getServerStatusSnapshotControlService?(
61
+ set?: { data?: T_ServerStatus, issuer?: string }
62
+ ): T_ServerStatusSnapshot_ControlService;
63
+
64
+ protected readonly up: Date = new Date();
65
+
66
+ protected readonly _serverVersionNumeric: number = this.getVersionNumeric(_serverVersion);
67
+ get serverVersion(): string { return _serverVersion; }
68
+ get serverVersionNumeric(): number { return this._serverVersionNumeric; }
69
+
70
+ protected _latestClientVersion: string;
71
+ protected _latestClientVersionNumeric: number;
72
+ get latestClientVersion(): string { return this._latestClientVersion; }
73
+ get latestClientVersionNumeric(): number { return this._latestClientVersionNumeric; }
74
+
75
+ protected abstract requiredServerConnections: DyNTS_ServerConnection[];
76
+ protected connectionMaxCheckFrequency = 15 * minute;
77
+
78
+ override readonly defaultErrorUserMsg = 'Something went wrong';
79
+
80
+ readonly overseerTickTime = 6 * hour;
81
+ overseer: Subscription;
82
+
83
+ protected constructor() {
84
+ super();
85
+
86
+ /* if (DyNTS_global_settings.log_settings.setup) {
87
+ DyFM_Log.log(
88
+ 'Required server connections:', JSON.stringify(this.requiredServerConnections.map(
89
+ (connection: DyNTS_ServerConnection): { name: string, baseUrl: string, testEndpoint: string } => ({
90
+ name: connection.name,
91
+ baseUrl: connection.apiService.baseUrl,
92
+ testEndpoint: connection.apiService.testEndpoint ?? '',
93
+ })
94
+ ), null, 2)
95
+ );
96
+ } */
97
+
98
+ this.overseer = timer(this.overseerTickTime, this.overseerTickTime).subscribe(async () => {
99
+ try {
100
+ await this.triggerCreateSnapshot('overseer-system-tick');
101
+ } catch (error) {
102
+ DyFM_Error.logSimple(' ! Error in overseer (server status):', error);
103
+ DyNTS_GlobalService.globalErrorHandler(
104
+ new DyFM_Error({
105
+ ...this.getDefaultErrorSettings('overseer tick', error, 'overseer-system-tick'),
106
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSCS-OT0`,
107
+ })
108
+ ).catch();
109
+ }
110
+ });
111
+ }
112
+
113
+ async getServerStatus(issuer: string, clientVersion?: string): Promise<DyFM_ServerStatus> {
114
+ try {
115
+ return {
116
+ status: 'ready',
117
+
118
+ systemName: DyNTS_global_settings.systemName,
119
+ systemShortCode: DyNTS_global_settings.systemShortCodeName,
120
+
121
+ clientVersionOk: clientVersion ? this.clientVersionIsLatest(clientVersion) : false,
122
+ latestClientVersion: this.latestClientVersion,
123
+ latestClientVersionNumeric: this.latestClientVersionNumeric,
124
+
125
+ serverVersion: this.serverVersion,
126
+ serverNumericVersion: this.serverVersionNumeric,
127
+
128
+ uptime: +new Date() - +this.up,
129
+
130
+ memoryUsage: process.memoryUsage(),
131
+ cpuUsage: process.cpuUsage(),
132
+ serverConnections: await this.checkServerConnections(issuer),
133
+ }
134
+ } catch (error) {
135
+ throw new DyFM_Error({
136
+ ...this.getDefaultErrorSettings('getServerStatus', error, issuer),
137
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSCS-GSS0`,
138
+ });
139
+ }
140
+ }
141
+
142
+ async checkServerConnections(issuer: string): Promise<DyFM_ServerConnectionCheckResult> {
143
+ try {
144
+ const connections: DyFM_ServerConnectionCheckResult = {};
145
+
146
+ await DyFM_Array.asyncForEachAllAtOnce(
147
+ this.requiredServerConnections,
148
+ async (connection: DyNTS_ServerConnection) => {
149
+ if (!connection.accessible || Date.now() - connection.lastCheck.getTime() > this.connectionMaxCheckFrequency) {
150
+ await connection.apiService.checkServerAvailability(issuer).catch((error) => {
151
+ DyFM_Error.logSimple(
152
+ `(checkServerConnections) "${connection.name}" server is not available` +
153
+ `\n baseUrl: ${connection.apiService.baseUrl}` +
154
+ `\n testEndpoint: ${connection.apiService.testEndpoint ?? ''}`,
155
+ error
156
+ );
157
+ connection.accessible = false;
158
+ }).then(() => {
159
+ connection.accessible = true;
160
+ });
161
+ connection.accessible = true;
162
+ connection.lastCheck = new Date();
163
+ }
164
+
165
+ connections[connection.name] = connection.accessible ? DyFM_ServerConnection_Status.accessible : DyFM_ServerConnection_Status.unaccessible;
166
+ }
167
+ )
168
+
169
+ return connections;
170
+ } catch (error) {
171
+ throw new DyFM_Error({
172
+ ...this.getDefaultErrorSettings('checkServerConnections', error, issuer),
173
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSCS-CC0`,
174
+ });
175
+ }
176
+ }
177
+
178
+ /**
179
+ * A mongoose default-connection. Külön metódus = teszt-seam (spy-jal felülírható, hogy a
180
+ * {@link checkDbReadiness} DB nélkül is tesztelhető legyen).
181
+ */
182
+ protected getMongooseConnection(): mongoose.Connection {
183
+ return mongoose.connection;
184
+ }
185
+
186
+ /**
187
+ * Readiness-probe: a `/health` (liveness — "a process fut + kiszolgál") MELLETT a DB-elérhetőséget
188
+ * ellenőrzi. A readyState (mongoose driver-állapot) + egy valós `ping` round-trip → így a "connected
189
+ * de a DB nem válaszol" eset is kibukik. **Sosem dob** (a probe-nak determinisztikusan kell válaszolnia);
190
+ * hiba esetén `ready=false`. Az endpoint 503-at adjon, ha nem ready → az orchestrátor (k8s/docker/LB)
191
+ * ne irányítson forgalmat a DB-vesztett instance-ra.
192
+ */
193
+ async checkDbReadiness(): Promise<DyNTS_DbReadiness> {
194
+ let dbReadyState: number = 0;
195
+ let dbPingOk: boolean = false;
196
+
197
+ try {
198
+ const connection: mongoose.Connection = this.getMongooseConnection();
199
+ // readyState: 0=disconnected, 1=connected, 2=connecting, 3=disconnecting
200
+ dbReadyState = connection?.readyState ?? 0;
201
+
202
+ if (dbReadyState === 1) {
203
+ await connection.db?.admin().ping();
204
+ dbPingOk = true;
205
+ }
206
+ } catch (error) {
207
+ DyFM_Log.warn('(checkDbReadiness) DB readiness check failed', error);
208
+ dbPingOk = false;
209
+ }
210
+
211
+ return {
212
+ ready: dbReadyState === 1 && dbPingOk,
213
+ dbReadyState: dbReadyState,
214
+ dbPingOk: dbPingOk,
215
+ uptime: +new Date() - +this.up,
216
+ serverVersion: this.serverVersion,
217
+ };
218
+ }
219
+
220
+ async getErrorStatistics(
221
+ range: DyFM_RelativeDate,
222
+ issuer: string
223
+ ): Promise<DyFM_Error_Statistics> {
224
+ try {
225
+ const error_DS: T_Errors_ControlService =
226
+ this.getErrorControlService({ issuer: issuer });
227
+ /* new DyNTS_Error_DataService({ issuer: issuer }); */
228
+
229
+ const from: Date = DyFM_Time.getDateByRelativeDate(range);
230
+ const errorsPaged: DyFM_Paged<T_Errors> = await error_DS.getErrorsFromDate(from, issuer);
231
+ const errors: T_Errors[] = errorsPaged.items;
232
+
233
+ return {
234
+ range: range,
235
+
236
+ allErrors: errors.length,
237
+ allAllErrors: errors.reduce(
238
+ (sum: number, error: T_Errors): number => sum + error.count,
239
+ 0
240
+ ),
241
+
242
+ serverErrors:
243
+ errors.filter(
244
+ (error: T_Errors): boolean => error.source.includes('SERVER')
245
+ ).length,
246
+ clientErrors:
247
+ errors.filter(
248
+ (error: T_Errors): boolean => !error.source.includes('SERVER')
249
+ ).length,
250
+ allServerErrors:
251
+ errors.filter(
252
+ (error: T_Errors): boolean => error.source.includes('SERVER')
253
+ ).reduce(
254
+ (sum: number, error: T_Errors): number => sum + error.count, 0
255
+ ),
256
+ allClientErrors:
257
+ errors.filter(
258
+ (error: T_Errors): boolean => !error.source.includes('SERVER')
259
+ ).reduce(
260
+ (sum: number, error: T_Errors): number => sum + error.count, 0
261
+ ),
262
+
263
+ infoErrors:
264
+ errors.filter(
265
+ (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.info
266
+ ).length,
267
+ warningErrors:
268
+ errors.filter(
269
+ (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.warning
270
+ ).length,
271
+ errorErrors:
272
+ errors.filter(
273
+ (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.error
274
+ ).length,
275
+ criticalErrors:
276
+ errors.filter(
277
+ (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.critical
278
+ ).length,
279
+
280
+ allInfoErrors:
281
+ errors.filter(
282
+ (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.info
283
+ ).reduce(
284
+ (sum: number, error: T_Errors): number => sum + error.count, 0
285
+ ),
286
+ allWarningErrors:
287
+ errors.filter(
288
+ (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.warning
289
+ ).reduce(
290
+ (sum: number, error: T_Errors): number => sum + error.count, 0
291
+ ),
292
+ allErrorErrors:
293
+ errors.filter(
294
+ (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.error
295
+ ).reduce(
296
+ (sum: number, error: T_Errors): number => sum + error.count, 0
297
+ ),
298
+ allCriticalErrors:
299
+ errors.filter(
300
+ (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.critical
301
+ ).reduce(
302
+ (sum: number, error: T_Errors): number => sum + error.count, 0
303
+ ),
304
+ } as DyFM_Error_Statistics;
305
+ } catch (error) {
306
+ throw new DyFM_Error({
307
+ ...this.getDefaultErrorSettings(
308
+ 'getMatchStatistics',
309
+ error?.response?.data ?? error,
310
+ issuer
311
+ ),
312
+
313
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-GES0`,
314
+ });
315
+ }
316
+ }
317
+
318
+ protected getVersionNumeric(version: string): number {
319
+ return +version.replace('v', '')
320
+ .replace('.', '')
321
+ .replace('.', '')
322
+ .replace('-alpha', '')
323
+ .replace('-beta', '')
324
+ .replace('-test', '')
325
+ .replace('-dev', '');
326
+ }
327
+
328
+ protected clientVersionIsLatest(clientVersion: string): boolean {
329
+ const thisClientVersionNumeric: number = this.getVersionNumeric(clientVersion);
330
+
331
+ if (!this._latestClientVersionNumeric) {
332
+ this.setLatestClientVersion(clientVersion, thisClientVersionNumeric);
333
+
334
+ return true;
335
+
336
+ } else if (thisClientVersionNumeric === this._latestClientVersionNumeric) {
337
+ return true;
338
+
339
+ } else if (thisClientVersionNumeric < this._latestClientVersionNumeric) {
340
+ return false;
341
+
342
+ } else if (this._latestClientVersionNumeric < thisClientVersionNumeric) {
343
+ this.setLatestClientVersion(clientVersion, thisClientVersionNumeric);
344
+
345
+ return true;
346
+ }
347
+
348
+ DyFM_Log.error(
349
+ 'Something went wrong, invalid version:', clientVersion,
350
+ thisClientVersionNumeric, _serverVersion, this.serverVersionNumeric
351
+ );
352
+
353
+ return false;
354
+ }
355
+
356
+ protected setLatestClientVersion(clientVersion: string, clientVersionNumeric: number): void {
357
+ if (!clientVersion.includes('test') && !clientVersion.includes('dev')) {
358
+ this._latestClientVersion = clientVersion;
359
+ this._latestClientVersionNumeric = clientVersionNumeric;
360
+ }
361
+ }
362
+
363
+ protected async triggerCreateSnapshot(issuer: string): Promise<void> {
364
+ try {
365
+ const snapshot: T_ServerStatusSnapshot = await this.getServerStatusSnapshot(issuer);
366
+ const serverStatusSnapshot_CS: T_ServerStatusSnapshot_ControlService =
367
+ this.getServerStatusSnapshotControlService({ issuer: issuer });
368
+
369
+ await serverStatusSnapshot_CS.saveSnapshot(snapshot, issuer);
370
+
371
+ DyFM_Log.info('ServerStatus snapshot created');
372
+ } catch (error) {
373
+ throw new DyFM_Error({
374
+ ...this.getDefaultErrorSettings('triggerCreateSnapshot', error, 'system-tick'),
375
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSCS-TCS0`,
376
+ });
377
+ }
378
+ }
379
+
380
+ async getServerStatusSnapshot(issuer: string): Promise<T_ServerStatusSnapshot> {
381
+ try {
382
+ return ({
383
+ ...(await this.getServerStatus(issuer)),
384
+ }) as T_ServerStatusSnapshot;
385
+ } catch (error) {
386
+ throw new DyFM_Error({
387
+ ...this.getDefaultErrorSettings(
388
+ 'getServerStatusSnapshot',
389
+ error?.response?.data ?? error,
390
+ issuer
391
+ ),
392
+
393
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSCS-GSS0`,
394
+ });
395
+ }
396
+ }
397
397
  }