@futdevpro/nts-dynamo 1.15.13 → 1.15.15

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 +362 -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,337 +1,337 @@
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
-
14
- import { version as _serverVersion } from '../../../../package.json';
15
- import { DyNTS_SingletonService } from '../../../_services/base/singleton.service';
16
- import { DyNTS_global_settings } from '../../../_collections/global-settings.const';
17
- import { DyNTS_Errors_ControlService } from '../errors/errors.control-service';
18
- import { DyNTS_ServerStatusSnapshot_ControlService } from './server-status-snapshot.control-service';
19
- import { DyNTS_GlobalService } from '../../../_services/core/global.service';
20
- import { DyNTS_ApiService_Base } from '../../../_services/base/api.service-base';
21
-
22
- export interface DyNTS_ServerConnection {
23
- name: string,
24
- apiService: DyNTS_ApiService_Base,
25
- accessible?: boolean,
26
- lastCheck?: Date,
27
- }
28
-
29
- export abstract class DyNTS_ServerStatus_ControlService<
30
- T_ServerStatus extends DyFM_ServerStatus,
31
- T_Error extends DyFM_Error,
32
- T_Errors extends DyFM_Errors<T_Error>,
33
- T_Errors_ControlService extends DyNTS_Errors_ControlService<T_Error, T_Errors>,
34
- T_ServerStatusSnapshot extends DyFM_ServerStatus,
35
- T_ServerStatusSnapshot_ControlService extends DyNTS_ServerStatusSnapshot_ControlService<T_ServerStatusSnapshot>
36
- > extends DyNTS_SingletonService {
37
-
38
- protected abstract getErrorControlService?(
39
- set?: { data?: T_Errors, issuer?: string }
40
- ): T_Errors_ControlService;
41
-
42
- protected abstract getServerStatusSnapshotControlService?(
43
- set?: { data?: T_ServerStatus, issuer?: string }
44
- ): T_ServerStatusSnapshot_ControlService;
45
-
46
- protected readonly up: Date = new Date();
47
-
48
- protected readonly _serverVersionNumeric: number = this.getVersionNumeric(_serverVersion);
49
- get serverVersion(): string { return _serverVersion; }
50
- get serverVersionNumeric(): number { return this._serverVersionNumeric; }
51
-
52
- protected _latestClientVersion: string;
53
- protected _latestClientVersionNumeric: number;
54
- get latestClientVersion(): string { return this._latestClientVersion; }
55
- get latestClientVersionNumeric(): number { return this._latestClientVersionNumeric; }
56
-
57
- protected abstract requiredServerConnections: DyNTS_ServerConnection[];
58
- protected connectionMaxCheckFrequency = 15 * minute;
59
-
60
- override readonly defaultErrorUserMsg = 'Something went wrong';
61
-
62
- readonly overseerTickTime = 6 * hour;
63
- overseer: Subscription;
64
-
65
- protected constructor() {
66
- super();
67
-
68
- /* if (DyNTS_global_settings.log_settings.setup) {
69
- DyFM_Log.log(
70
- 'Required server connections:', JSON.stringify(this.requiredServerConnections.map(
71
- (connection: DyNTS_ServerConnection): { name: string, baseUrl: string, testEndpoint: string } => ({
72
- name: connection.name,
73
- baseUrl: connection.apiService.baseUrl,
74
- testEndpoint: connection.apiService.testEndpoint ?? '',
75
- })
76
- ), null, 2)
77
- );
78
- } */
79
-
80
- this.overseer = timer(this.overseerTickTime, this.overseerTickTime).subscribe(async () => {
81
- try {
82
- await this.triggerCreateSnapshot('overseer-system-tick');
83
- } catch (error) {
84
- DyFM_Error.logSimple(' ! Error in overseer (server status):', error);
85
- DyNTS_GlobalService.globalErrorHandler(
86
- new DyFM_Error({
87
- ...this.getDefaultErrorSettings('overseer tick', error, 'overseer-system-tick'),
88
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSCS-OT0`,
89
- })
90
- ).catch();
91
- }
92
- });
93
- }
94
-
95
- async getServerStatus(issuer: string, clientVersion?: string): Promise<DyFM_ServerStatus> {
96
- try {
97
- return {
98
- status: 'ready',
99
-
100
- systemName: DyNTS_global_settings.systemName,
101
- systemShortCode: DyNTS_global_settings.systemShortCodeName,
102
-
103
- clientVersionOk: clientVersion ? this.clientVersionIsLatest(clientVersion) : false,
104
- latestClientVersion: this.latestClientVersion,
105
- latestClientVersionNumeric: this.latestClientVersionNumeric,
106
-
107
- serverVersion: this.serverVersion,
108
- serverNumericVersion: this.serverVersionNumeric,
109
-
110
- uptime: +new Date() - +this.up,
111
-
112
- memoryUsage: process.memoryUsage(),
113
- cpuUsage: process.cpuUsage(),
114
- serverConnections: await this.checkServerConnections(issuer),
115
- }
116
- } catch (error) {
117
- throw new DyFM_Error({
118
- ...this.getDefaultErrorSettings('getServerStatus', error, issuer),
119
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSCS-GSS0`,
120
- });
121
- }
122
- }
123
-
124
- async checkServerConnections(issuer: string): Promise<DyFM_ServerConnectionCheckResult> {
125
- try {
126
- const connections: DyFM_ServerConnectionCheckResult = {};
127
-
128
- await DyFM_Array.asyncForEachAllAtOnce(
129
- this.requiredServerConnections,
130
- async (connection: DyNTS_ServerConnection) => {
131
- if (!connection.accessible || Date.now() - connection.lastCheck.getTime() > this.connectionMaxCheckFrequency) {
132
- await connection.apiService.checkServerAvailability(issuer).catch((error) => {
133
- DyFM_Error.logSimple(
134
- `(checkServerConnections) "${connection.name}" server is not available` +
135
- `\n baseUrl: ${connection.apiService.baseUrl}` +
136
- `\n testEndpoint: ${connection.apiService.testEndpoint ?? ''}`,
137
- error
138
- );
139
- connection.accessible = false;
140
- }).then(() => {
141
- connection.accessible = true;
142
- });
143
- connection.accessible = true;
144
- connection.lastCheck = new Date();
145
- }
146
-
147
- connections[connection.name] = connection.accessible ? DyFM_ServerConnection_Status.accessible : DyFM_ServerConnection_Status.unaccessible;
148
- }
149
- )
150
-
151
- return connections;
152
- } catch (error) {
153
- throw new DyFM_Error({
154
- ...this.getDefaultErrorSettings('checkServerConnections', error, issuer),
155
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSCS-CC0`,
156
- });
157
- }
158
- }
159
-
160
- async getErrorStatistics(
161
- range: DyFM_RelativeDate,
162
- issuer: string
163
- ): Promise<DyFM_Error_Statistics> {
164
- try {
165
- const error_DS: T_Errors_ControlService =
166
- this.getErrorControlService({ issuer: issuer });
167
- /* new DyNTS_Error_DataService({ issuer: issuer }); */
168
-
169
- const from: Date = DyFM_Time.getDateByRelativeDate(range);
170
- const errorsPaged: DyFM_Paged<T_Errors> = await error_DS.getErrorsFromDate(from, issuer);
171
- const errors: T_Errors[] = errorsPaged.items;
172
-
173
- return {
174
- range: range,
175
-
176
- allErrors: errors.length,
177
- allAllErrors: errors.reduce(
178
- (sum: number, error: T_Errors): number => sum + error.count,
179
- 0
180
- ),
181
-
182
- serverErrors:
183
- errors.filter(
184
- (error: T_Errors): boolean => error.source.includes('SERVER')
185
- ).length,
186
- clientErrors:
187
- errors.filter(
188
- (error: T_Errors): boolean => !error.source.includes('SERVER')
189
- ).length,
190
- allServerErrors:
191
- errors.filter(
192
- (error: T_Errors): boolean => error.source.includes('SERVER')
193
- ).reduce(
194
- (sum: number, error: T_Errors): number => sum + error.count, 0
195
- ),
196
- allClientErrors:
197
- errors.filter(
198
- (error: T_Errors): boolean => !error.source.includes('SERVER')
199
- ).reduce(
200
- (sum: number, error: T_Errors): number => sum + error.count, 0
201
- ),
202
-
203
- infoErrors:
204
- errors.filter(
205
- (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.info
206
- ).length,
207
- warningErrors:
208
- errors.filter(
209
- (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.warning
210
- ).length,
211
- errorErrors:
212
- errors.filter(
213
- (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.error
214
- ).length,
215
- criticalErrors:
216
- errors.filter(
217
- (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.critical
218
- ).length,
219
-
220
- allInfoErrors:
221
- errors.filter(
222
- (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.info
223
- ).reduce(
224
- (sum: number, error: T_Errors): number => sum + error.count, 0
225
- ),
226
- allWarningErrors:
227
- errors.filter(
228
- (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.warning
229
- ).reduce(
230
- (sum: number, error: T_Errors): number => sum + error.count, 0
231
- ),
232
- allErrorErrors:
233
- errors.filter(
234
- (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.error
235
- ).reduce(
236
- (sum: number, error: T_Errors): number => sum + error.count, 0
237
- ),
238
- allCriticalErrors:
239
- errors.filter(
240
- (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.critical
241
- ).reduce(
242
- (sum: number, error: T_Errors): number => sum + error.count, 0
243
- ),
244
- } as DyFM_Error_Statistics;
245
- } catch (error) {
246
- throw new DyFM_Error({
247
- ...this.getDefaultErrorSettings(
248
- 'getMatchStatistics',
249
- error?.response?.data ?? error,
250
- issuer
251
- ),
252
-
253
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-GES0`,
254
- });
255
- }
256
- }
257
-
258
- protected getVersionNumeric(version: string): number {
259
- return +version.replace('v', '')
260
- .replace('.', '')
261
- .replace('.', '')
262
- .replace('-alpha', '')
263
- .replace('-beta', '')
264
- .replace('-test', '')
265
- .replace('-dev', '');
266
- }
267
-
268
- protected clientVersionIsLatest(clientVersion: string): boolean {
269
- const thisClientVersionNumeric: number = this.getVersionNumeric(clientVersion);
270
-
271
- if (!this._latestClientVersionNumeric) {
272
- this.setLatestClientVersion(clientVersion, thisClientVersionNumeric);
273
-
274
- return true;
275
-
276
- } else if (thisClientVersionNumeric === this._latestClientVersionNumeric) {
277
- return true;
278
-
279
- } else if (thisClientVersionNumeric < this._latestClientVersionNumeric) {
280
- return false;
281
-
282
- } else if (this._latestClientVersionNumeric < thisClientVersionNumeric) {
283
- this.setLatestClientVersion(clientVersion, thisClientVersionNumeric);
284
-
285
- return true;
286
- }
287
-
288
- DyFM_Log.error(
289
- 'Something went wrong, invalid version:', clientVersion,
290
- thisClientVersionNumeric, _serverVersion, this.serverVersionNumeric
291
- );
292
-
293
- return false;
294
- }
295
-
296
- protected setLatestClientVersion(clientVersion: string, clientVersionNumeric: number): void {
297
- if (!clientVersion.includes('test') && !clientVersion.includes('dev')) {
298
- this._latestClientVersion = clientVersion;
299
- this._latestClientVersionNumeric = clientVersionNumeric;
300
- }
301
- }
302
-
303
- protected async triggerCreateSnapshot(issuer: string): Promise<void> {
304
- try {
305
- const snapshot: T_ServerStatusSnapshot = await this.getServerStatusSnapshot(issuer);
306
- const serverStatusSnapshot_CS: T_ServerStatusSnapshot_ControlService =
307
- this.getServerStatusSnapshotControlService({ issuer: issuer });
308
-
309
- await serverStatusSnapshot_CS.saveSnapshot(snapshot, issuer);
310
-
311
- DyFM_Log.info('ServerStatus snapshot created');
312
- } catch (error) {
313
- throw new DyFM_Error({
314
- ...this.getDefaultErrorSettings('triggerCreateSnapshot', error, 'system-tick'),
315
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSCS-TCS0`,
316
- });
317
- }
318
- }
319
-
320
- async getServerStatusSnapshot(issuer: string): Promise<T_ServerStatusSnapshot> {
321
- try {
322
- return ({
323
- ...(await this.getServerStatus(issuer)),
324
- }) as T_ServerStatusSnapshot;
325
- } catch (error) {
326
- throw new DyFM_Error({
327
- ...this.getDefaultErrorSettings(
328
- 'getServerStatusSnapshot',
329
- error?.response?.data ?? error,
330
- issuer
331
- ),
332
-
333
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSCS-GSS0`,
334
- });
335
- }
336
- }
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
+
14
+ import { version as _serverVersion } from '../../../../package.json';
15
+ import { DyNTS_SingletonService } from '../../../_services/base/singleton.service';
16
+ import { DyNTS_global_settings } from '../../../_collections/global-settings.const';
17
+ import { DyNTS_Errors_ControlService } from '../errors/errors.control-service';
18
+ import { DyNTS_ServerStatusSnapshot_ControlService } from './server-status-snapshot.control-service';
19
+ import { DyNTS_GlobalService } from '../../../_services/core/global.service';
20
+ import { DyNTS_ApiService_Base } from '../../../_services/base/api.service-base';
21
+
22
+ export interface DyNTS_ServerConnection {
23
+ name: string,
24
+ apiService: DyNTS_ApiService_Base,
25
+ accessible?: boolean,
26
+ lastCheck?: Date,
27
+ }
28
+
29
+ export abstract class DyNTS_ServerStatus_ControlService<
30
+ T_ServerStatus extends DyFM_ServerStatus,
31
+ T_Error extends DyFM_Error,
32
+ T_Errors extends DyFM_Errors<T_Error>,
33
+ T_Errors_ControlService extends DyNTS_Errors_ControlService<T_Error, T_Errors>,
34
+ T_ServerStatusSnapshot extends DyFM_ServerStatus,
35
+ T_ServerStatusSnapshot_ControlService extends DyNTS_ServerStatusSnapshot_ControlService<T_ServerStatusSnapshot>
36
+ > extends DyNTS_SingletonService {
37
+
38
+ protected abstract getErrorControlService?(
39
+ set?: { data?: T_Errors, issuer?: string }
40
+ ): T_Errors_ControlService;
41
+
42
+ protected abstract getServerStatusSnapshotControlService?(
43
+ set?: { data?: T_ServerStatus, issuer?: string }
44
+ ): T_ServerStatusSnapshot_ControlService;
45
+
46
+ protected readonly up: Date = new Date();
47
+
48
+ protected readonly _serverVersionNumeric: number = this.getVersionNumeric(_serverVersion);
49
+ get serverVersion(): string { return _serverVersion; }
50
+ get serverVersionNumeric(): number { return this._serverVersionNumeric; }
51
+
52
+ protected _latestClientVersion: string;
53
+ protected _latestClientVersionNumeric: number;
54
+ get latestClientVersion(): string { return this._latestClientVersion; }
55
+ get latestClientVersionNumeric(): number { return this._latestClientVersionNumeric; }
56
+
57
+ protected abstract requiredServerConnections: DyNTS_ServerConnection[];
58
+ protected connectionMaxCheckFrequency = 15 * minute;
59
+
60
+ override readonly defaultErrorUserMsg = 'Something went wrong';
61
+
62
+ readonly overseerTickTime = 6 * hour;
63
+ overseer: Subscription;
64
+
65
+ protected constructor() {
66
+ super();
67
+
68
+ /* if (DyNTS_global_settings.log_settings.setup) {
69
+ DyFM_Log.log(
70
+ 'Required server connections:', JSON.stringify(this.requiredServerConnections.map(
71
+ (connection: DyNTS_ServerConnection): { name: string, baseUrl: string, testEndpoint: string } => ({
72
+ name: connection.name,
73
+ baseUrl: connection.apiService.baseUrl,
74
+ testEndpoint: connection.apiService.testEndpoint ?? '',
75
+ })
76
+ ), null, 2)
77
+ );
78
+ } */
79
+
80
+ this.overseer = timer(this.overseerTickTime, this.overseerTickTime).subscribe(async () => {
81
+ try {
82
+ await this.triggerCreateSnapshot('overseer-system-tick');
83
+ } catch (error) {
84
+ DyFM_Error.logSimple(' ! Error in overseer (server status):', error);
85
+ DyNTS_GlobalService.globalErrorHandler(
86
+ new DyFM_Error({
87
+ ...this.getDefaultErrorSettings('overseer tick', error, 'overseer-system-tick'),
88
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSCS-OT0`,
89
+ })
90
+ ).catch();
91
+ }
92
+ });
93
+ }
94
+
95
+ async getServerStatus(issuer: string, clientVersion?: string): Promise<DyFM_ServerStatus> {
96
+ try {
97
+ return {
98
+ status: 'ready',
99
+
100
+ systemName: DyNTS_global_settings.systemName,
101
+ systemShortCode: DyNTS_global_settings.systemShortCodeName,
102
+
103
+ clientVersionOk: clientVersion ? this.clientVersionIsLatest(clientVersion) : false,
104
+ latestClientVersion: this.latestClientVersion,
105
+ latestClientVersionNumeric: this.latestClientVersionNumeric,
106
+
107
+ serverVersion: this.serverVersion,
108
+ serverNumericVersion: this.serverVersionNumeric,
109
+
110
+ uptime: +new Date() - +this.up,
111
+
112
+ memoryUsage: process.memoryUsage(),
113
+ cpuUsage: process.cpuUsage(),
114
+ serverConnections: await this.checkServerConnections(issuer),
115
+ }
116
+ } catch (error) {
117
+ throw new DyFM_Error({
118
+ ...this.getDefaultErrorSettings('getServerStatus', error, issuer),
119
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSCS-GSS0`,
120
+ });
121
+ }
122
+ }
123
+
124
+ async checkServerConnections(issuer: string): Promise<DyFM_ServerConnectionCheckResult> {
125
+ try {
126
+ const connections: DyFM_ServerConnectionCheckResult = {};
127
+
128
+ await DyFM_Array.asyncForEachAllAtOnce(
129
+ this.requiredServerConnections,
130
+ async (connection: DyNTS_ServerConnection) => {
131
+ if (!connection.accessible || Date.now() - connection.lastCheck.getTime() > this.connectionMaxCheckFrequency) {
132
+ await connection.apiService.checkServerAvailability(issuer).catch((error) => {
133
+ DyFM_Error.logSimple(
134
+ `(checkServerConnections) "${connection.name}" server is not available` +
135
+ `\n baseUrl: ${connection.apiService.baseUrl}` +
136
+ `\n testEndpoint: ${connection.apiService.testEndpoint ?? ''}`,
137
+ error
138
+ );
139
+ connection.accessible = false;
140
+ }).then(() => {
141
+ connection.accessible = true;
142
+ });
143
+ connection.accessible = true;
144
+ connection.lastCheck = new Date();
145
+ }
146
+
147
+ connections[connection.name] = connection.accessible ? DyFM_ServerConnection_Status.accessible : DyFM_ServerConnection_Status.unaccessible;
148
+ }
149
+ )
150
+
151
+ return connections;
152
+ } catch (error) {
153
+ throw new DyFM_Error({
154
+ ...this.getDefaultErrorSettings('checkServerConnections', error, issuer),
155
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSCS-CC0`,
156
+ });
157
+ }
158
+ }
159
+
160
+ async getErrorStatistics(
161
+ range: DyFM_RelativeDate,
162
+ issuer: string
163
+ ): Promise<DyFM_Error_Statistics> {
164
+ try {
165
+ const error_DS: T_Errors_ControlService =
166
+ this.getErrorControlService({ issuer: issuer });
167
+ /* new DyNTS_Error_DataService({ issuer: issuer }); */
168
+
169
+ const from: Date = DyFM_Time.getDateByRelativeDate(range);
170
+ const errorsPaged: DyFM_Paged<T_Errors> = await error_DS.getErrorsFromDate(from, issuer);
171
+ const errors: T_Errors[] = errorsPaged.items;
172
+
173
+ return {
174
+ range: range,
175
+
176
+ allErrors: errors.length,
177
+ allAllErrors: errors.reduce(
178
+ (sum: number, error: T_Errors): number => sum + error.count,
179
+ 0
180
+ ),
181
+
182
+ serverErrors:
183
+ errors.filter(
184
+ (error: T_Errors): boolean => error.source.includes('SERVER')
185
+ ).length,
186
+ clientErrors:
187
+ errors.filter(
188
+ (error: T_Errors): boolean => !error.source.includes('SERVER')
189
+ ).length,
190
+ allServerErrors:
191
+ errors.filter(
192
+ (error: T_Errors): boolean => error.source.includes('SERVER')
193
+ ).reduce(
194
+ (sum: number, error: T_Errors): number => sum + error.count, 0
195
+ ),
196
+ allClientErrors:
197
+ errors.filter(
198
+ (error: T_Errors): boolean => !error.source.includes('SERVER')
199
+ ).reduce(
200
+ (sum: number, error: T_Errors): number => sum + error.count, 0
201
+ ),
202
+
203
+ infoErrors:
204
+ errors.filter(
205
+ (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.info
206
+ ).length,
207
+ warningErrors:
208
+ errors.filter(
209
+ (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.warning
210
+ ).length,
211
+ errorErrors:
212
+ errors.filter(
213
+ (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.error
214
+ ).length,
215
+ criticalErrors:
216
+ errors.filter(
217
+ (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.critical
218
+ ).length,
219
+
220
+ allInfoErrors:
221
+ errors.filter(
222
+ (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.info
223
+ ).reduce(
224
+ (sum: number, error: T_Errors): number => sum + error.count, 0
225
+ ),
226
+ allWarningErrors:
227
+ errors.filter(
228
+ (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.warning
229
+ ).reduce(
230
+ (sum: number, error: T_Errors): number => sum + error.count, 0
231
+ ),
232
+ allErrorErrors:
233
+ errors.filter(
234
+ (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.error
235
+ ).reduce(
236
+ (sum: number, error: T_Errors): number => sum + error.count, 0
237
+ ),
238
+ allCriticalErrors:
239
+ errors.filter(
240
+ (error: T_Errors): boolean => error.level === DyFM_ErrorLevel.critical
241
+ ).reduce(
242
+ (sum: number, error: T_Errors): number => sum + error.count, 0
243
+ ),
244
+ } as DyFM_Error_Statistics;
245
+ } catch (error) {
246
+ throw new DyFM_Error({
247
+ ...this.getDefaultErrorSettings(
248
+ 'getMatchStatistics',
249
+ error?.response?.data ?? error,
250
+ issuer
251
+ ),
252
+
253
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-GES0`,
254
+ });
255
+ }
256
+ }
257
+
258
+ protected getVersionNumeric(version: string): number {
259
+ return +version.replace('v', '')
260
+ .replace('.', '')
261
+ .replace('.', '')
262
+ .replace('-alpha', '')
263
+ .replace('-beta', '')
264
+ .replace('-test', '')
265
+ .replace('-dev', '');
266
+ }
267
+
268
+ protected clientVersionIsLatest(clientVersion: string): boolean {
269
+ const thisClientVersionNumeric: number = this.getVersionNumeric(clientVersion);
270
+
271
+ if (!this._latestClientVersionNumeric) {
272
+ this.setLatestClientVersion(clientVersion, thisClientVersionNumeric);
273
+
274
+ return true;
275
+
276
+ } else if (thisClientVersionNumeric === this._latestClientVersionNumeric) {
277
+ return true;
278
+
279
+ } else if (thisClientVersionNumeric < this._latestClientVersionNumeric) {
280
+ return false;
281
+
282
+ } else if (this._latestClientVersionNumeric < thisClientVersionNumeric) {
283
+ this.setLatestClientVersion(clientVersion, thisClientVersionNumeric);
284
+
285
+ return true;
286
+ }
287
+
288
+ DyFM_Log.error(
289
+ 'Something went wrong, invalid version:', clientVersion,
290
+ thisClientVersionNumeric, _serverVersion, this.serverVersionNumeric
291
+ );
292
+
293
+ return false;
294
+ }
295
+
296
+ protected setLatestClientVersion(clientVersion: string, clientVersionNumeric: number): void {
297
+ if (!clientVersion.includes('test') && !clientVersion.includes('dev')) {
298
+ this._latestClientVersion = clientVersion;
299
+ this._latestClientVersionNumeric = clientVersionNumeric;
300
+ }
301
+ }
302
+
303
+ protected async triggerCreateSnapshot(issuer: string): Promise<void> {
304
+ try {
305
+ const snapshot: T_ServerStatusSnapshot = await this.getServerStatusSnapshot(issuer);
306
+ const serverStatusSnapshot_CS: T_ServerStatusSnapshot_ControlService =
307
+ this.getServerStatusSnapshotControlService({ issuer: issuer });
308
+
309
+ await serverStatusSnapshot_CS.saveSnapshot(snapshot, issuer);
310
+
311
+ DyFM_Log.info('ServerStatus snapshot created');
312
+ } catch (error) {
313
+ throw new DyFM_Error({
314
+ ...this.getDefaultErrorSettings('triggerCreateSnapshot', error, 'system-tick'),
315
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSCS-TCS0`,
316
+ });
317
+ }
318
+ }
319
+
320
+ async getServerStatusSnapshot(issuer: string): Promise<T_ServerStatusSnapshot> {
321
+ try {
322
+ return ({
323
+ ...(await this.getServerStatus(issuer)),
324
+ }) as T_ServerStatusSnapshot;
325
+ } catch (error) {
326
+ throw new DyFM_Error({
327
+ ...this.getDefaultErrorSettings(
328
+ 'getServerStatusSnapshot',
329
+ error?.response?.data ?? error,
330
+ issuer
331
+ ),
332
+
333
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSCS-GSS0`,
334
+ });
335
+ }
336
+ }
337
337
  }