@futdevpro/nts-dynamo 1.15.68 → 1.15.71

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 (928) 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/__main.mdc +64 -64
  5. package/.cursor/rules/_ag_backend-structure.mdc +85 -85
  6. package/.cursor/rules/_ag_backend.mdc +16 -16
  7. package/.cursor/rules/_ag_debug.mdc +7 -7
  8. package/.cursor/rules/_ag_documentation_writing_rules.mdc +372 -372
  9. package/.cursor/rules/_ag_file-refactoring.mdc +113 -113
  10. package/.cursor/rules/_ag_fixes_rules.mdc +5 -5
  11. package/.cursor/rules/_ag_frontend-structure.mdc +86 -86
  12. package/.cursor/rules/_ag_frontend.mdc +39 -39
  13. package/.cursor/rules/_ag_import-rules.mdc +44 -44
  14. package/.cursor/rules/_ag_naming.mdc +115 -115
  15. package/.cursor/rules/_ag_running_commands.mdc +4 -4
  16. package/.cursor/rules/_ag_server-controller.mdc +5 -5
  17. package/.cursor/rules/_ag_should-be.mdc +6 -6
  18. package/.cursor/rules/_ag_swearing.mdc +47 -47
  19. package/.cursor/rules/ai_development_guide.md +60 -60
  20. package/.cursor/rules/ai_directives.md +114 -114
  21. package/.cursor/rules/cursor-rules.md +160 -160
  22. package/.cursor/rules/default-command.mdc +464 -464
  23. package/.cursor/rules/error_code_pattern.md +39 -39
  24. package/.cursor/rules/saved rule mcp server use.md +15 -15
  25. package/.dynamo/logs/cicd-pipeline/output.log +2782 -0
  26. package/.dynamo/logs/cicd-pipeline/status.json +94 -0
  27. package/.dynamo/pipeline.cicd.config.json +180 -180
  28. package/.dynamo/version-bump.config.json +5 -5
  29. package/.github/workflows/main.yml +438 -438
  30. package/.husky/pre-commit +3 -3
  31. package/.vscode/settings.json +10 -10
  32. package/HOWTO.md +15 -15
  33. package/LICENSE +21 -21
  34. package/README.md +678 -678
  35. package/__documentations/2026-04-28-logs-module.md +49 -49
  36. package/__documentations/2026-05-17-oai-compatible-providers.md +229 -229
  37. package/__documentations/2026-05-17-static-client-serving-howto.md +144 -144
  38. package/__documentations/2026-06-01-fr041-cors-middleware.md +96 -96
  39. package/__documentations/2026-06-01-fr047-p2p3-function-calling.md +81 -81
  40. package/__documentations/2026-06-15-fr193-memory-guard.md +73 -73
  41. package/__documentations/nts-integration-tests-2026-03-17.md +26 -26
  42. package/_specifications/BACKLOG.md +92 -92
  43. package/_specifications/TODO.md +15 -15
  44. package/_specifications/agent.md +138 -138
  45. package/build/_collections/archive.util.d.ts +12 -12
  46. package/build/_collections/archive.util.js +18 -18
  47. package/build/_collections/atlas-default-db-options.const.d.ts +2 -2
  48. package/build/_collections/atlas-default-db-options.const.js +9 -9
  49. package/build/_collections/default-fallback-cache-max-age.const.d.ts +2 -2
  50. package/build/_collections/default-fallback-cache-max-age.const.js +5 -5
  51. package/build/_collections/default-not-found-page.const.d.ts +5 -5
  52. package/build/_collections/default-not-found-page.const.js +24 -24
  53. package/build/_collections/default-socket-path.const.d.ts +2 -2
  54. package/build/_collections/default-socket-path.const.js +5 -5
  55. package/build/_collections/get-environment-settings.util.d.ts +2 -2
  56. package/build/_collections/get-environment-settings.util.js +43 -43
  57. package/build/_collections/global-settings.const.d.ts +6 -6
  58. package/build/_collections/global-settings.const.js +69 -69
  59. package/build/_collections/mongo-reconnect-guard.util.d.ts +73 -73
  60. package/build/_collections/mongo-reconnect-guard.util.js +110 -110
  61. package/build/_collections/star.controller.d.ts +7 -7
  62. package/build/_collections/star.controller.js +97 -97
  63. package/build/_enums/data-model-type.enum.d.ts +13 -13
  64. package/build/_enums/data-model-type.enum.js +17 -17
  65. package/build/_enums/data-service-function.enum.d.ts +18 -18
  66. package/build/_enums/data-service-function.enum.js +24 -24
  67. package/build/_enums/predefined-data-types.enum.d.ts +15 -15
  68. package/build/_enums/predefined-data-types.enum.js +19 -19
  69. package/build/_enums/route-security.enum.d.ts +11 -11
  70. package/build/_enums/route-security.enum.js +15 -15
  71. package/build/_models/control-models/api-call-params.control-model.d.ts +79 -79
  72. package/build/_models/control-models/api-call-params.control-model.js +101 -101
  73. package/build/_models/control-models/app-ext-system-controls.control-model.d.ts +6 -6
  74. package/build/_models/control-models/app-ext-system-controls.control-model.js +10 -10
  75. package/build/_models/control-models/app-params.control-model.d.ts +51 -51
  76. package/build/_models/control-models/app-params.control-model.js +119 -119
  77. package/build/_models/control-models/app-system-controls.control-model.d.ts +7 -7
  78. package/build/_models/control-models/app-system-controls.control-model.js +11 -11
  79. package/build/_models/control-models/endpoint-params.control-model.d.ts +114 -114
  80. package/build/_models/control-models/endpoint-params.control-model.js +442 -442
  81. package/build/_models/control-models/http-settings.control-model.d.ts +17 -17
  82. package/build/_models/control-models/http-settings.control-model.js +34 -34
  83. package/build/_models/control-models/system-control.control-model.d.ts +5 -5
  84. package/build/_models/control-models/system-control.control-model.js +11 -11
  85. package/build/_models/interfaces/certification-settings.interface.d.ts +5 -5
  86. package/build/_models/interfaces/certification-settings.interface.js +2 -2
  87. package/build/_models/interfaces/compare-data-options.interface.d.ts +26 -26
  88. package/build/_models/interfaces/compare-data-options.interface.js +2 -2
  89. package/build/_models/interfaces/compare-data-result.interface.d.ts +12 -12
  90. package/build/_models/interfaces/compare-data-result.interface.js +2 -2
  91. package/build/_models/interfaces/cors-settings.interface.d.ts +51 -51
  92. package/build/_models/interfaces/cors-settings.interface.js +2 -2
  93. package/build/_models/interfaces/environment-settings.interface.d.ts +34 -34
  94. package/build/_models/interfaces/environment-settings.interface.js +2 -2
  95. package/build/_models/interfaces/global-log-settings.interface.d.ts +145 -145
  96. package/build/_models/interfaces/global-log-settings.interface.js +2 -2
  97. package/build/_models/interfaces/global-service-settings.interface.d.ts +30 -30
  98. package/build/_models/interfaces/global-service-settings.interface.js +2 -2
  99. package/build/_models/interfaces/global-settings.interface.d.ts +161 -161
  100. package/build/_models/interfaces/global-settings.interface.js +2 -2
  101. package/build/_models/interfaces/routing-module-settings.interface.d.ts +19 -19
  102. package/build/_models/interfaces/routing-module-settings.interface.js +2 -2
  103. package/build/_models/interfaces/static-client-settings.interface.d.ts +28 -28
  104. package/build/_models/interfaces/static-client-settings.interface.js +2 -2
  105. package/build/_models/types/db-update.type.d.ts +129 -129
  106. package/build/_models/types/db-update.type.js +2 -2
  107. package/build/_modules/admin-auth/_models/admin-api-key-config.interface.d.ts +31 -31
  108. package/build/_modules/admin-auth/_models/admin-api-key-config.interface.js +2 -2
  109. package/build/_modules/admin-auth/admin-api-key.auth-service.d.ts +89 -89
  110. package/build/_modules/admin-auth/admin-api-key.auth-service.js +194 -194
  111. package/build/_modules/admin-auth/index.d.ts +2 -2
  112. package/build/_modules/admin-auth/index.js +5 -5
  113. package/build/_modules/ai/_models/ai-input-interfaces.d.ts +53 -53
  114. package/build/_modules/ai/_models/ai-input-interfaces.js +5 -5
  115. package/build/_modules/ai/_models/ai-test-generation-result.interface.d.ts +16 -16
  116. package/build/_modules/ai/_models/ai-test-generation-result.interface.js +2 -2
  117. package/build/_modules/ai/_models/interfaces/dynts-ai-cost-event-callback.interface.d.ts +13 -13
  118. package/build/_modules/ai/_models/interfaces/dynts-ai-cost-event-callback.interface.js +2 -2
  119. package/build/_modules/ai/_models/interfaces/dynts-ai-cost-event.interface.d.ts +49 -49
  120. package/build/_modules/ai/_models/interfaces/dynts-ai-cost-event.interface.js +2 -2
  121. package/build/_modules/ai/_modules/anthropic/_services/aai-user-key.control-service.d.ts +35 -35
  122. package/build/_modules/ai/_modules/anthropic/_services/aai-user-key.control-service.js +117 -117
  123. package/build/_modules/ai/_modules/anthropic/index.d.ts +2 -2
  124. package/build/_modules/ai/_modules/anthropic/index.js +7 -7
  125. package/build/_modules/ai/_modules/document-ai/_collections/dai-chunking.util.d.ts +84 -84
  126. package/build/_modules/ai/_modules/document-ai/_collections/dai-chunking.util.js +467 -467
  127. package/build/_modules/ai/_modules/document-ai/_collections/dai-code-chunking.util.d.ts +109 -109
  128. package/build/_modules/ai/_modules/document-ai/_collections/dai-code-chunking.util.js +418 -418
  129. package/build/_modules/ai/_modules/document-ai/_collections/dai-document.util.d.ts +28 -28
  130. package/build/_modules/ai/_modules/document-ai/_collections/dai-document.util.js +73 -73
  131. package/build/_modules/ai/_modules/document-ai/_enums/dai-compare-result-type.enum.d.ts +6 -6
  132. package/build/_modules/ai/_modules/document-ai/_enums/dai-compare-result-type.enum.js +10 -10
  133. package/build/_modules/ai/_modules/document-ai/_models/data-models/dai-doc-chunk.data-model.d.ts +51 -51
  134. package/build/_modules/ai/_modules/document-ai/_models/data-models/dai-doc-chunk.data-model.js +132 -132
  135. package/build/_modules/ai/_modules/document-ai/_models/data-models/dai-doc-page.data-model.d.ts +47 -47
  136. package/build/_modules/ai/_modules/document-ai/_models/data-models/dai-doc-page.data-model.js +136 -136
  137. package/build/_modules/ai/_modules/document-ai/_models/data-models/dai-document.data-model.d.ts +17 -17
  138. package/build/_modules/ai/_modules/document-ai/_models/data-models/dai-document.data-model.js +76 -76
  139. package/build/_modules/ai/_modules/document-ai/_models/interfaces/dai-code-chunk.interface.d.ts +49 -49
  140. package/build/_modules/ai/_modules/document-ai/_models/interfaces/dai-code-chunk.interface.js +2 -2
  141. package/build/_modules/ai/_modules/document-ai/_models/interfaces/dai-doc-chunk-compare-result.interface.d.ts +8 -8
  142. package/build/_modules/ai/_modules/document-ai/_models/interfaces/dai-doc-chunk-compare-result.interface.js +2 -2
  143. package/build/_modules/ai/_modules/document-ai/_models/interfaces/dai-doc-page-compare-result.interface.d.ts +11 -11
  144. package/build/_modules/ai/_modules/document-ai/_models/interfaces/dai-doc-page-compare-result.interface.js +2 -2
  145. package/build/_modules/ai/_modules/document-ai/_models/interfaces/dai-document-compare-result.interface.d.ts +12 -12
  146. package/build/_modules/ai/_modules/document-ai/_models/interfaces/dai-document-compare-result.interface.js +2 -2
  147. package/build/_modules/ai/_modules/document-ai/index.d.ts +12 -12
  148. package/build/_modules/ai/_modules/document-ai/index.js +27 -27
  149. package/build/_modules/ai/_modules/fdp-ai/_services/fdpai-user-key.control-service.d.ts +34 -34
  150. package/build/_modules/ai/_modules/fdp-ai/_services/fdpai-user-key.control-service.js +128 -128
  151. package/build/_modules/ai/_modules/fdp-ai/index.d.ts +2 -2
  152. package/build/_modules/ai/_modules/fdp-ai/index.js +7 -7
  153. package/build/_modules/ai/_modules/open-ai/_collections/oai-global-settings.const.d.ts +2 -2
  154. package/build/_modules/ai/_modules/open-ai/_collections/oai-global-settings.const.js +8 -8
  155. package/build/_modules/ai/_modules/open-ai/_collections/oai-llm-predefined-requests-hu.conts.d.ts +2 -2
  156. package/build/_modules/ai/_modules/open-ai/_collections/oai-llm-predefined-requests-hu.conts.js +74 -74
  157. package/build/_modules/ai/_modules/open-ai/_collections/oai-llm-predefined-requests.conts.d.ts +2 -2
  158. package/build/_modules/ai/_modules/open-ai/_collections/oai-llm-predefined-requests.conts.js +67 -67
  159. package/build/_modules/ai/_modules/open-ai/_enums/oai-gpt-message-role.enum.js +42 -42
  160. package/build/_modules/ai/_modules/open-ai/_models/interfaces/oai-global-settings.interface.d.ts +5 -5
  161. package/build/_modules/ai/_modules/open-ai/_models/interfaces/oai-global-settings.interface.js +2 -2
  162. package/build/_modules/ai/_modules/open-ai/_models/interfaces/oai-gpt-message.interface.js +6 -6
  163. package/build/_modules/ai/_modules/open-ai/_models/interfaces/oai-llm-predefined-requests.interface.d.ts +51 -51
  164. package/build/_modules/ai/_modules/open-ai/_models/interfaces/oai-llm-predefined-requests.interface.js +2 -2
  165. package/build/_modules/ai/_modules/open-ai/_services/data-services/oai-doc-chunk-data.service.d.ts +21 -21
  166. package/build/_modules/ai/_modules/open-ai/_services/data-services/oai-doc-chunk-data.service.js +187 -187
  167. package/build/_modules/ai/_modules/open-ai/_services/data-services/oai-doc-page.data-service.d.ts +26 -26
  168. package/build/_modules/ai/_modules/open-ai/_services/data-services/oai-doc-page.data-service.js +278 -278
  169. package/build/_modules/ai/_modules/open-ai/_services/data-services/oai-document.data-service.d.ts +22 -22
  170. package/build/_modules/ai/_modules/open-ai/_services/data-services/oai-document.data-service.js +322 -322
  171. package/build/_modules/ai/_modules/open-ai/_services/data-services/oai-vector-data.service.d.ts +119 -119
  172. package/build/_modules/ai/_modules/open-ai/_services/data-services/oai-vector-data.service.js +480 -480
  173. package/build/_modules/ai/_modules/open-ai/_services/oai-embedding.control-service.d.ts +25 -25
  174. package/build/_modules/ai/_modules/open-ai/_services/oai-embedding.control-service.js +103 -103
  175. package/build/_modules/ai/_modules/open-ai/_services/oai-llm-chat.service-base.d.ts +169 -169
  176. package/build/_modules/ai/_modules/open-ai/_services/oai-llm-chat.service-base.js +479 -479
  177. package/build/_modules/ai/_modules/open-ai/_services/oai-llm.service-base.d.ts +201 -201
  178. package/build/_modules/ai/_modules/open-ai/_services/oai-llm.service-base.js +579 -579
  179. package/build/_modules/ai/_modules/open-ai/_services/oai-user-key.control-service.d.ts +39 -39
  180. package/build/_modules/ai/_modules/open-ai/_services/oai-user-key.control-service.js +110 -110
  181. package/build/_modules/ai/_modules/open-ai/index.d.ts +14 -14
  182. package/build/_modules/ai/_modules/open-ai/index.js +55 -55
  183. package/build/_modules/ai/_services/ai-embedding-mock.service.d.ts +80 -80
  184. package/build/_modules/ai/_services/ai-embedding-mock.service.js +166 -166
  185. package/build/_modules/ai/_services/ai-embedding-provider.registry.d.ts +51 -51
  186. package/build/_modules/ai/_services/ai-embedding-provider.registry.js +78 -78
  187. package/build/_modules/ai/_services/ai-embedding.service-base.d.ts +41 -41
  188. package/build/_modules/ai/_services/ai-embedding.service-base.js +11 -11
  189. package/build/_modules/ai/_services/ai-llm-chat.service-base.d.ts +39 -39
  190. package/build/_modules/ai/_services/ai-llm-chat.service-base.js +11 -11
  191. package/build/_modules/ai/_services/ai-llm.service-base.d.ts +132 -132
  192. package/build/_modules/ai/_services/ai-llm.service-base.js +313 -313
  193. package/build/_modules/ai/_services/ai-provider.service-base.d.ts +46 -46
  194. package/build/_modules/ai/_services/ai-provider.service-base.js +43 -43
  195. package/build/_modules/ai/_services/ai-user-key.service-base.d.ts +44 -44
  196. package/build/_modules/ai/_services/ai-user-key.service-base.js +14 -14
  197. package/build/_modules/ai/_services/lmstudio-embedding.control-service.d.ts +110 -110
  198. package/build/_modules/ai/_services/lmstudio-embedding.control-service.js +297 -297
  199. package/build/_modules/ai/index.d.ts +13 -13
  200. package/build/_modules/ai/index.js +22 -22
  201. package/build/_modules/assistant/_collections/ass-global-settings.const.d.ts +2 -2
  202. package/build/_modules/assistant/_collections/ass-global-settings.const.js +14 -14
  203. package/build/_modules/assistant/_collections/ass.util.d.ts +15 -15
  204. package/build/_modules/assistant/_collections/ass.util.js +42 -42
  205. package/build/_modules/assistant/_models/ass-global-settings.interface.d.ts +13 -13
  206. package/build/_modules/assistant/_models/ass-global-settings.interface.js +2 -2
  207. package/build/_modules/assistant/_services/ass-io.control-service.d.ts +19 -19
  208. package/build/_modules/assistant/_services/ass-io.control-service.js +57 -57
  209. package/build/_modules/assistant/_services/ass-main.control-service.d.ts +32 -32
  210. package/build/_modules/assistant/_services/ass-main.control-service.js +65 -65
  211. package/build/_modules/assistant/index.d.ts +6 -6
  212. package/build/_modules/assistant/index.js +18 -18
  213. package/build/_modules/bot/_collections/bot-default-commands.const.d.ts +2 -2
  214. package/build/_modules/bot/_collections/bot-default-commands.const.js +13 -13
  215. package/build/_modules/bot/_collections/bot-global-settings.const.d.ts +2 -2
  216. package/build/_modules/bot/_collections/bot-global-settings.const.js +31 -31
  217. package/build/_modules/bot/_models/bot-channel-wrapper.interface.d.ts +25 -25
  218. package/build/_modules/bot/_models/bot-channel-wrapper.interface.js +38 -38
  219. package/build/_modules/bot/_models/bot-command.interface.d.ts +7 -7
  220. package/build/_modules/bot/_models/bot-command.interface.js +2 -2
  221. package/build/_modules/bot/_models/bot-global-settings.interface.d.ts +85 -85
  222. package/build/_modules/bot/_models/bot-global-settings.interface.js +2 -2
  223. package/build/_modules/bot/_models/bot-last-mention-date.interface.d.ts +6 -6
  224. package/build/_modules/bot/_models/bot-last-mention-date.interface.js +2 -2
  225. package/build/_modules/bot/_models/bot-last-message-date.interface.d.ts +5 -5
  226. package/build/_modules/bot/_models/bot-last-message-date.interface.js +2 -2
  227. package/build/_modules/bot/_models/bot-message-wrapper.interface.d.ts +37 -37
  228. package/build/_modules/bot/_models/bot-message-wrapper.interface.js +54 -54
  229. package/build/_modules/bot/_models/bot-user-wrapper.interface.d.ts +23 -23
  230. package/build/_modules/bot/_models/bot-user-wrapper.interface.js +28 -28
  231. package/build/_modules/bot/_modules/discord-bot/_models/dib-platform.types.js +10 -10
  232. package/build/_modules/bot/_modules/discord-bot/_services/dib-messaging-provider.control-service.d.ts +69 -69
  233. package/build/_modules/bot/_modules/discord-bot/_services/dib-messaging-provider.control-service.js +497 -497
  234. package/build/_modules/bot/_modules/discord-bot/index.d.ts +1 -1
  235. package/build/_modules/bot/_modules/discord-bot/index.js +12 -12
  236. package/build/_modules/bot/_modules/dynamo-bot/_collections/dyb-operations.util.d.ts +16 -16
  237. package/build/_modules/bot/_modules/dynamo-bot/_collections/dyb-operations.util.js +42 -42
  238. package/build/_modules/bot/_modules/dynamo-bot/_models/dyb-platform.types.d.ts +9 -9
  239. package/build/_modules/bot/_modules/dynamo-bot/_models/dyb-platform.types.js +2 -2
  240. package/build/_modules/bot/_modules/dynamo-bot/_services/dyb-messaging-provider.control-service.d.ts +59 -59
  241. package/build/_modules/bot/_modules/dynamo-bot/_services/dyb-messaging-provider.control-service.js +349 -349
  242. package/build/_modules/bot/_modules/dynamo-bot/index.d.ts +3 -3
  243. package/build/_modules/bot/_modules/dynamo-bot/index.js +15 -15
  244. package/build/_modules/bot/_modules/slack-bot/_models/slb-platform.types.d.ts +6 -6
  245. package/build/_modules/bot/_modules/slack-bot/_models/slb-platform.types.js +2 -2
  246. package/build/_modules/bot/_modules/slack-bot/_services/slb-messaging-provider.control-service.d.ts +56 -56
  247. package/build/_modules/bot/_modules/slack-bot/_services/slb-messaging-provider.control-service.js +137 -137
  248. package/build/_modules/bot/_modules/slack-bot/index.d.ts +2 -2
  249. package/build/_modules/bot/_modules/slack-bot/index.js +12 -12
  250. package/build/_modules/bot/_modules/teams-bot/_models/teb-platform.types.d.ts +6 -6
  251. package/build/_modules/bot/_modules/teams-bot/_models/teb-platform.types.js +2 -2
  252. package/build/_modules/bot/_modules/teams-bot/_services/teb-messaging-provider.control-service.d.ts +56 -56
  253. package/build/_modules/bot/_modules/teams-bot/_services/teb-messaging-provider.control-service.js +137 -137
  254. package/build/_modules/bot/_modules/teams-bot/index.d.ts +2 -2
  255. package/build/_modules/bot/_modules/teams-bot/index.js +12 -12
  256. package/build/_modules/bot/_services/bot-commands.control-service.d.ts +12 -12
  257. package/build/_modules/bot/_services/bot-commands.control-service.js +117 -117
  258. package/build/_modules/bot/_services/bot-io.control-service.d.ts +23 -23
  259. package/build/_modules/bot/_services/bot-io.control-service.js +226 -226
  260. package/build/_modules/bot/_services/bot-main.control-service.d.ts +35 -35
  261. package/build/_modules/bot/_services/bot-main.control-service.js +195 -195
  262. package/build/_modules/bot/_services/bot-messaging-provider.service-base.d.ts +71 -71
  263. package/build/_modules/bot/_services/bot-messaging-provider.service-base.js +15 -15
  264. package/build/_modules/bot/_services/bot-routines.control-service.d.ts +13 -13
  265. package/build/_modules/bot/_services/bot-routines.control-service.js +59 -59
  266. package/build/_modules/bot/index.d.ts +17 -17
  267. package/build/_modules/bot/index.js +36 -36
  268. package/build/_modules/custom-data/custom-data.controller.d.ts +5 -5
  269. package/build/_modules/custom-data/custom-data.controller.js +56 -56
  270. package/build/_modules/custom-data/custom-data.data-service.d.ts +5 -5
  271. package/build/_modules/custom-data/custom-data.data-service.js +11 -11
  272. package/build/_modules/custom-data/get-custom-data-routing-module.util.d.ts +3 -3
  273. package/build/_modules/custom-data/get-custom-data-routing-module.util.js +16 -16
  274. package/build/_modules/custom-data/index.d.ts +4 -4
  275. package/build/_modules/custom-data/index.js +9 -9
  276. package/build/_modules/data-readers/_collections/dynts-sqlite-reader.util.d.ts +58 -58
  277. package/build/_modules/data-readers/_collections/dynts-sqlite-reader.util.js +168 -168
  278. package/build/_modules/data-readers/_models/interfaces/dynts-sqlite-reader.interface.d.ts +31 -31
  279. package/build/_modules/data-readers/_models/interfaces/dynts-sqlite-reader.interface.js +7 -7
  280. package/build/_modules/data-readers/index.d.ts +2 -2
  281. package/build/_modules/data-readers/index.js +10 -10
  282. package/build/_modules/defaults/_collections/default-endpoints.util.d.ts +248 -248
  283. package/build/_modules/defaults/_collections/default-endpoints.util.js +386 -386
  284. package/build/_modules/defaults/_models/default-user.data-model.d.ts +19 -19
  285. package/build/_modules/defaults/_models/default-user.data-model.js +72 -72
  286. package/build/_modules/defaults/_services/default-auth.service.d.ts +50 -50
  287. package/build/_modules/defaults/_services/default-auth.service.js +158 -158
  288. package/build/_modules/defaults/_services/default-socket-events.service.d.ts +23 -23
  289. package/build/_modules/defaults/_services/default-socket-events.service.js +60 -60
  290. package/build/_modules/defaults/_services/default-user.data-service.d.ts +24 -24
  291. package/build/_modules/defaults/_services/default-user.data-service.js +87 -87
  292. package/build/_modules/defaults/index.d.ts +5 -5
  293. package/build/_modules/defaults/index.js +17 -17
  294. package/build/_modules/discord-assistant/_collections/dias-global-settings.const.d.ts +2 -2
  295. package/build/_modules/discord-assistant/_collections/dias-global-settings.const.js +16 -16
  296. package/build/_modules/discord-assistant/_collections/dias.util.d.ts +31 -31
  297. package/build/_modules/discord-assistant/_collections/dias.util.js +85 -85
  298. package/build/_modules/discord-assistant/_models/dias-global-settings.interface.d.ts +17 -17
  299. package/build/_modules/discord-assistant/_models/dias-global-settings.interface.js +2 -2
  300. package/build/_modules/discord-assistant/_models/dias-knowledge.data-model.d.ts +8 -8
  301. package/build/_modules/discord-assistant/_models/dias-knowledge.data-model.js +46 -46
  302. package/build/_modules/discord-assistant/_services/dias-chunk.data-service.d.ts +17 -17
  303. package/build/_modules/discord-assistant/_services/dias-chunk.data-service.js +123 -123
  304. package/build/_modules/discord-assistant/_services/dias-io.control-service.d.ts +10 -10
  305. package/build/_modules/discord-assistant/_services/dias-io.control-service.js +49 -49
  306. package/build/_modules/discord-assistant/_services/dias-main.control-service.d.ts +3 -3
  307. package/build/_modules/discord-assistant/_services/dias-main.control-service.js +7 -7
  308. package/build/_modules/discord-assistant/_services/dias.service-base.d.ts +18 -18
  309. package/build/_modules/discord-assistant/_services/dias.service-base.js +46 -46
  310. package/build/_modules/discord-assistant/index.d.ts +11 -11
  311. package/build/_modules/discord-assistant/index.js +24 -24
  312. package/build/_modules/discord-assistant-voiced/_services/dias-discord-bot.control-service.d.ts +3 -3
  313. package/build/_modules/discord-assistant-voiced/_services/dias-discord-bot.control-service.js +7 -7
  314. package/build/_modules/discord-assistant-voiced/index.d.ts +2 -2
  315. package/build/_modules/discord-assistant-voiced/index.js +28 -28
  316. package/build/_modules/discord-bot/_collections/dibo-default-commands.const.d.ts +2 -2
  317. package/build/_modules/discord-bot/_collections/dibo-default-commands.const.js +12 -12
  318. package/build/_modules/discord-bot/_collections/dibo-global-settings.conts.d.ts +2 -2
  319. package/build/_modules/discord-bot/_collections/dibo-global-settings.conts.js +43 -43
  320. package/build/_modules/discord-bot/_collections/dibo-operations.util.d.ts +22 -22
  321. package/build/_modules/discord-bot/_collections/dibo-operations.util.js +275 -275
  322. package/build/_modules/discord-bot/_models/dibo-command.interface.d.ts +7 -7
  323. package/build/_modules/discord-bot/_models/dibo-command.interface.js +2 -2
  324. package/build/_modules/discord-bot/_models/dibo-global-settings.interface.d.ts +87 -87
  325. package/build/_modules/discord-bot/_models/dibo-global-settings.interface.js +2 -2
  326. package/build/_modules/discord-bot/_models/dibo-last-mention-date.inteface.d.ts +6 -6
  327. package/build/_modules/discord-bot/_models/dibo-last-mention-date.inteface.js +2 -2
  328. package/build/_modules/discord-bot/_models/dibo-last-message-date.interface.d.ts +5 -5
  329. package/build/_modules/discord-bot/_models/dibo-last-message-date.interface.js +2 -2
  330. package/build/_modules/discord-bot/_services/dibo-commands.control-service.d.ts +11 -11
  331. package/build/_modules/discord-bot/_services/dibo-commands.control-service.js +109 -109
  332. package/build/_modules/discord-bot/_services/dibo-io.control-service.d.ts +21 -21
  333. package/build/_modules/discord-bot/_services/dibo-io.control-service.js +218 -218
  334. package/build/_modules/discord-bot/_services/dibo-main.control-service.d.ts +89 -89
  335. package/build/_modules/discord-bot/_services/dibo-main.control-service.js +363 -363
  336. package/build/_modules/discord-bot/_services/dibo-routines.control-service.d.ts +13 -13
  337. package/build/_modules/discord-bot/_services/dibo-routines.control-service.js +73 -73
  338. package/build/_modules/discord-bot/index.d.ts +11 -11
  339. package/build/_modules/discord-bot/index.js +30 -30
  340. package/build/_modules/local-vector-search/_enums/lvs-search-mode.enum.d.ts +34 -34
  341. package/build/_modules/local-vector-search/_enums/lvs-search-mode.enum.js +38 -38
  342. package/build/_modules/local-vector-search/_models/data-models/lvs-vector-persist.data-model.d.ts +35 -35
  343. package/build/_modules/local-vector-search/_models/data-models/lvs-vector-persist.data-model.js +53 -53
  344. package/build/_modules/local-vector-search/_models/lvs-search-result.interface.d.ts +16 -16
  345. package/build/_modules/local-vector-search/_models/lvs-search-result.interface.js +2 -2
  346. package/build/_modules/local-vector-search/_services/lvs-bm25.util.d.ts +88 -88
  347. package/build/_modules/local-vector-search/_services/lvs-bm25.util.js +189 -189
  348. package/build/_modules/local-vector-search/_services/lvs-doc-chunk-data.service.d.ts +26 -26
  349. package/build/_modules/local-vector-search/_services/lvs-doc-chunk-data.service.js +197 -197
  350. package/build/_modules/local-vector-search/_services/lvs-local-vector-search.data-service.d.ts +145 -145
  351. package/build/_modules/local-vector-search/_services/lvs-local-vector-search.data-service.js +294 -294
  352. package/build/_modules/local-vector-search/_services/lvs-persistent-vector-pool.control-service.d.ts +69 -69
  353. package/build/_modules/local-vector-search/_services/lvs-persistent-vector-pool.control-service.js +122 -122
  354. package/build/_modules/local-vector-search/_services/lvs-vector-persist.data-service.d.ts +42 -42
  355. package/build/_modules/local-vector-search/_services/lvs-vector-persist.data-service.js +71 -71
  356. package/build/_modules/local-vector-search/_services/lvs-vector-pool.control-service.d.ts +74 -70
  357. package/build/_modules/local-vector-search/_services/lvs-vector-pool.control-service.d.ts.map +1 -1
  358. package/build/_modules/local-vector-search/_services/lvs-vector-pool.control-service.js +201 -181
  359. package/build/_modules/local-vector-search/_services/lvs-vector-pool.control-service.js.map +1 -1
  360. package/build/_modules/local-vector-search/index.d.ts +8 -8
  361. package/build/_modules/local-vector-search/index.js +15 -15
  362. package/build/_modules/logs/_models/file-log-entry.interface.d.ts +13 -13
  363. package/build/_modules/logs/_models/file-log-entry.interface.js +2 -2
  364. package/build/_modules/logs/_models/file-log-read-result.interface.d.ts +35 -35
  365. package/build/_modules/logs/_models/file-log-read-result.interface.js +2 -2
  366. package/build/_modules/logs/file-log.service.d.ts +132 -132
  367. package/build/_modules/logs/file-log.service.js +444 -444
  368. package/build/_modules/logs/file-logs.controller.d.ts +40 -40
  369. package/build/_modules/logs/file-logs.controller.js +138 -138
  370. package/build/_modules/logs/get-file-logs-routing-module.util.d.ts +31 -31
  371. package/build/_modules/logs/get-file-logs-routing-module.util.js +37 -37
  372. package/build/_modules/logs/get-logs-routing-module.util.d.ts +18 -18
  373. package/build/_modules/logs/get-logs-routing-module.util.js +31 -31
  374. package/build/_modules/logs/index.d.ts +8 -8
  375. package/build/_modules/logs/index.js +15 -15
  376. package/build/_modules/logs/log-buffer.service.d.ts +37 -37
  377. package/build/_modules/logs/log-buffer.service.js +96 -96
  378. package/build/_modules/logs/logs.controller.d.ts +26 -26
  379. package/build/_modules/logs/logs.controller.js +89 -89
  380. package/build/_modules/logs/logs.service.d.ts +39 -39
  381. package/build/_modules/logs/logs.service.js +96 -96
  382. package/build/_modules/mcp/_models/interfaces/dynts-mcp.interface.d.ts +108 -108
  383. package/build/_modules/mcp/_models/interfaces/dynts-mcp.interface.js +13 -13
  384. package/build/_modules/mcp/_services/dynts-mcp-server.service-base.d.ts +70 -70
  385. package/build/_modules/mcp/_services/dynts-mcp-server.service-base.js +98 -98
  386. package/build/_modules/mcp/_services/dynts-mcp.adapter.d.ts +56 -56
  387. package/build/_modules/mcp/_services/dynts-mcp.adapter.js +138 -138
  388. package/build/_modules/mcp/index.d.ts +3 -3
  389. package/build/_modules/mcp/index.js +12 -12
  390. package/build/_modules/messaging/_collections/get-messaging-routing-module.util.d.ts +7 -7
  391. package/build/_modules/messaging/_collections/get-messaging-routing-module.util.js +20 -20
  392. package/build/_modules/messaging/_collections/msg-global-settings.const.d.ts +5 -5
  393. package/build/_modules/messaging/_collections/msg-global-settings.const.js +22 -22
  394. package/build/_modules/messaging/_collections/msg.util.d.ts +24 -24
  395. package/build/_modules/messaging/_collections/msg.util.js +62 -62
  396. package/build/_modules/messaging/_models/msg-global-settings.interface.d.ts +28 -28
  397. package/build/_modules/messaging/_models/msg-global-settings.interface.js +2 -2
  398. package/build/_modules/messaging/_services/msg-conversation.data-service.d.ts +28 -28
  399. package/build/_modules/messaging/_services/msg-conversation.data-service.js +109 -109
  400. package/build/_modules/messaging/_services/msg-events.service.d.ts +61 -61
  401. package/build/_modules/messaging/_services/msg-events.service.js +203 -203
  402. package/build/_modules/messaging/_services/msg-integration.control-service.js +180 -180
  403. package/build/_modules/messaging/_services/msg-main.control-service.d.ts +62 -62
  404. package/build/_modules/messaging/_services/msg-main.control-service.js +428 -428
  405. package/build/_modules/messaging/_services/msg-message.data-service.d.ts +28 -28
  406. package/build/_modules/messaging/_services/msg-message.data-service.js +103 -103
  407. package/build/_modules/messaging/_services/msg.controller.d.ts +12 -12
  408. package/build/_modules/messaging/_services/msg.controller.js +256 -256
  409. package/build/_modules/messaging/index.d.ts +10 -10
  410. package/build/_modules/messaging/index.js +27 -27
  411. package/build/_modules/mock/app-extended-server.mock.d.ts +41 -41
  412. package/build/_modules/mock/app-extended-server.mock.js +169 -169
  413. package/build/_modules/mock/app-integration-test.mock.d.ts +19 -19
  414. package/build/_modules/mock/app-integration-test.mock.js +45 -45
  415. package/build/_modules/mock/app-params.mock.d.ts +2 -2
  416. package/build/_modules/mock/app-params.mock.js +9 -9
  417. package/build/_modules/mock/app-server.mock.d.ts +41 -41
  418. package/build/_modules/mock/app-server.mock.js +148 -148
  419. package/build/_modules/mock/auth-service.mock.d.ts +10 -10
  420. package/build/_modules/mock/auth-service.mock.js +19 -19
  421. package/build/_modules/mock/controller.mock.d.ts +5 -5
  422. package/build/_modules/mock/controller.mock.js +14 -14
  423. package/build/_modules/mock/data-model.mock.d.ts +26 -26
  424. package/build/_modules/mock/data-model.mock.js +72 -72
  425. package/build/_modules/mock/email-service-collection.mock.d.ts +7 -7
  426. package/build/_modules/mock/email-service-collection.mock.js +12 -12
  427. package/build/_modules/mock/email-service.mock.d.ts +4 -4
  428. package/build/_modules/mock/email-service.mock.js +20 -20
  429. package/build/_modules/mock/endpoint.mock.d.ts +8 -8
  430. package/build/_modules/mock/endpoint.mock.js +79 -79
  431. package/build/_modules/mock/socket-client.mock.d.ts +9 -9
  432. package/build/_modules/mock/socket-client.mock.js +38 -38
  433. package/build/_modules/mock/socket-server.mock.d.ts +15 -15
  434. package/build/_modules/mock/socket-server.mock.js +32 -32
  435. package/build/_modules/oauth2/_routes/oauth2.controller.d.ts +16 -16
  436. package/build/_modules/oauth2/_routes/oauth2.controller.js +96 -96
  437. package/build/_modules/oauth2/_services/oauth2.auth-service.d.ts +30 -30
  438. package/build/_modules/oauth2/_services/oauth2.auth-service.js +215 -215
  439. package/build/_modules/oauth2/_services/oauth2.control-service.d.ts +132 -132
  440. package/build/_modules/oauth2/_services/oauth2.control-service.js +576 -576
  441. package/build/_modules/oauth2/index.d.ts +3 -3
  442. package/build/_modules/oauth2/index.js +14 -14
  443. package/build/_modules/rate-limit/_models/rate-limit-config.interface.d.ts +61 -61
  444. package/build/_modules/rate-limit/_models/rate-limit-config.interface.js +2 -2
  445. package/build/_modules/rate-limit/_models/rate-limit-policy.interface.d.ts +15 -15
  446. package/build/_modules/rate-limit/_models/rate-limit-policy.interface.js +2 -2
  447. package/build/_modules/rate-limit/index.d.ts +3 -3
  448. package/build/_modules/rate-limit/index.js +5 -5
  449. package/build/_modules/rate-limit/rate-limit.middleware.d.ts +132 -132
  450. package/build/_modules/rate-limit/rate-limit.middleware.js +289 -289
  451. package/build/_modules/scoped-config/_enums/dynts-scoped-config-level.enum.d.ts +18 -18
  452. package/build/_modules/scoped-config/_enums/dynts-scoped-config-level.enum.js +22 -22
  453. package/build/_modules/scoped-config/_models/data-models/dynts-scoped-config.data-model.d.ts +43 -43
  454. package/build/_modules/scoped-config/_models/data-models/dynts-scoped-config.data-model.js +67 -67
  455. package/build/_modules/scoped-config/_models/interfaces/dynts-scoped-config.interface.d.ts +88 -88
  456. package/build/_modules/scoped-config/_models/interfaces/dynts-scoped-config.interface.js +11 -11
  457. package/build/_modules/scoped-config/_services/dynts-scoped-config.control-service.d.ts +83 -83
  458. package/build/_modules/scoped-config/_services/dynts-scoped-config.control-service.js +219 -219
  459. package/build/_modules/scoped-config/_services/dynts-scoped-config.data-service.d.ts +53 -53
  460. package/build/_modules/scoped-config/_services/dynts-scoped-config.data-service.js +75 -75
  461. package/build/_modules/scoped-config/index.d.ts +5 -5
  462. package/build/_modules/scoped-config/index.js +14 -14
  463. package/build/_modules/server/errors/errors.control-service.d.ts +21 -21
  464. package/build/_modules/server/errors/errors.control-service.js +10 -10
  465. package/build/_modules/server/errors/errors.controller.d.ts +100 -100
  466. package/build/_modules/server/errors/errors.controller.js +355 -355
  467. package/build/_modules/server/errors/errors.data-service.d.ts +64 -64
  468. package/build/_modules/server/errors/errors.data-service.js +628 -628
  469. package/build/_modules/server/index.d.ts +7 -7
  470. package/build/_modules/server/index.js +26 -26
  471. package/build/_modules/server/server-status/server-status-snapshot.control-service.d.ts +4 -4
  472. package/build/_modules/server/server-status/server-status-snapshot.control-service.js +7 -7
  473. package/build/_modules/server/server-status/server-status-snapshot.data-service.d.ts +6 -6
  474. package/build/_modules/server/server-status/server-status-snapshot.data-service.js +22 -22
  475. package/build/_modules/server/server-status/server-status.control-service.d.ts +74 -74
  476. package/build/_modules/server/server-status/server-status.control-service.js +234 -234
  477. package/build/_modules/server/server-status/server-status.controller.d.ts +84 -84
  478. package/build/_modules/server/server-status/server-status.controller.js +172 -172
  479. package/build/_modules/socket/_enums/socket-security.enum.d.ts +10 -10
  480. package/build/_modules/socket/_enums/socket-security.enum.js +14 -14
  481. package/build/_modules/socket/_models/socket-client-service-params.control-model.d.ts +8 -8
  482. package/build/_modules/socket/_models/socket-client-service-params.control-model.js +16 -16
  483. package/build/_modules/socket/_models/socket-presence.control-model.d.ts +25 -25
  484. package/build/_modules/socket/_models/socket-presence.control-model.js +139 -139
  485. package/build/_modules/socket/_models/socket-server-service-params.control-model.d.ts +12 -12
  486. package/build/_modules/socket/_models/socket-server-service-params.control-model.js +20 -20
  487. package/build/_modules/socket/_services/socket-client.service.d.ts +37 -37
  488. package/build/_modules/socket/_services/socket-client.service.js +196 -196
  489. package/build/_modules/socket/_services/socket-server.service.d.ts +94 -94
  490. package/build/_modules/socket/_services/socket-server.service.js +689 -689
  491. package/build/_modules/socket/app-extended.server.d.ts +145 -145
  492. package/build/_modules/socket/app-extended.server.js +506 -506
  493. package/build/_modules/socket/index.d.ts +8 -8
  494. package/build/_modules/socket/index.js +35 -35
  495. package/build/_modules/test/get-test-routing-module.util.d.ts +3 -3
  496. package/build/_modules/test/get-test-routing-module.util.js +16 -16
  497. package/build/_modules/test/index.d.ts +3 -3
  498. package/build/_modules/test/index.js +11 -11
  499. package/build/_modules/test/test.controller.d.ts +5 -5
  500. package/build/_modules/test/test.controller.js +103 -103
  501. package/build/_modules/usage/get-usage-routing-module.util.d.ts +3 -3
  502. package/build/_modules/usage/get-usage-routing-module.util.js +16 -16
  503. package/build/_modules/usage/index.d.ts +4 -4
  504. package/build/_modules/usage/index.js +13 -13
  505. package/build/_modules/usage/usage.controller.d.ts +6 -6
  506. package/build/_modules/usage/usage.controller.js +95 -95
  507. package/build/_modules/usage/usage.data-service.d.ts +17 -17
  508. package/build/_modules/usage/usage.data-service.js +135 -135
  509. package/build/_services/base/api.service-base.d.ts +9 -9
  510. package/build/_services/base/api.service-base.js +46 -46
  511. package/build/_services/base/archive-data.service.d.ts +25 -25
  512. package/build/_services/base/archive-data.service.js +140 -140
  513. package/build/_services/base/data.service.d.ts +381 -381
  514. package/build/_services/base/data.service.js +2068 -2068
  515. package/build/_services/base/db.service.d.ts +393 -393
  516. package/build/_services/base/db.service.js +1256 -1256
  517. package/build/_services/base/singleton.service-base.d.ts +8 -8
  518. package/build/_services/base/singleton.service-base.js +21 -21
  519. package/build/_services/base/singleton.service.d.ts +11 -11
  520. package/build/_services/base/singleton.service.js +31 -31
  521. package/build/_services/core/api.service.d.ts +45 -45
  522. package/build/_services/core/api.service.js +436 -436
  523. package/build/_services/core/auth.service.d.ts +129 -129
  524. package/build/_services/core/auth.service.js +59 -59
  525. package/build/_services/core/email.service.d.ts +77 -77
  526. package/build/_services/core/email.service.js +489 -489
  527. package/build/_services/core/global.service.d.ts +76 -76
  528. package/build/_services/core/global.service.js +370 -370
  529. package/build/_services/core/memory-guard.service.d.ts +110 -110
  530. package/build/_services/core/memory-guard.service.js +197 -197
  531. package/build/_services/core/service-collection.service.d.ts +4 -4
  532. package/build/_services/core/service-collection.service.js +7 -7
  533. package/build/_services/route/controller.service.d.ts +124 -124
  534. package/build/_services/route/controller.service.js +95 -95
  535. package/build/_services/route/routing-module.service.d.ts +80 -80
  536. package/build/_services/route/routing-module.service.js +250 -250
  537. package/build/_services/server/app.server.d.ts +352 -352
  538. package/build/_services/server/app.server.js +1323 -1323
  539. package/build/_services/shared.static-service.d.ts +36 -36
  540. package/build/_services/shared.static-service.js +72 -72
  541. package/build/index.d.ts +43 -43
  542. package/build/index.js +80 -80
  543. package/eslint.config.js +3 -3
  544. package/nodemon.json +24 -24
  545. package/package.json +417 -416
  546. package/pnpm-workspace.yaml +5 -5
  547. package/scripts/run-coverage-tests.js +28 -28
  548. package/spec/support/helpers/spec-reporter-loader.js +359 -359
  549. package/spec/support/helpers/ts-node-helper.js +93 -93
  550. package/spec/support/jasmine.coverage.json +24 -24
  551. package/spec/support/jasmine.json +24 -24
  552. package/src/_collections/archive.util.spec.ts +57 -57
  553. package/src/_collections/archive.util.ts +18 -18
  554. package/src/_collections/atlas-default-db-options.const.ts +9 -9
  555. package/src/_collections/default-fallback-cache-max-age.const.spec.ts +11 -11
  556. package/src/_collections/default-fallback-cache-max-age.const.ts +2 -2
  557. package/src/_collections/default-not-found-page.const.spec.ts +19 -19
  558. package/src/_collections/default-not-found-page.const.ts +22 -22
  559. package/src/_collections/default-socket-path.const.spec.ts +12 -12
  560. package/src/_collections/default-socket-path.const.ts +2 -2
  561. package/src/_collections/get-environment-settings.util.spec.ts +210 -210
  562. package/src/_collections/get-environment-settings.util.ts +48 -48
  563. package/src/_collections/global-settings.const.ts +89 -89
  564. package/src/_collections/mongo-reconnect-guard.util.spec.ts +52 -52
  565. package/src/_collections/mongo-reconnect-guard.util.ts +172 -172
  566. package/src/_collections/sample.env +21 -21
  567. package/src/_collections/star.controller.spec.ts +224 -224
  568. package/src/_collections/star.controller.ts +129 -129
  569. package/src/_enums/data-model-type.enum.ts +14 -14
  570. package/src/_enums/data-service-function.enum.ts +24 -24
  571. package/src/_enums/predefined-data-types.enum.ts +16 -16
  572. package/src/_enums/route-security.enum.ts +12 -12
  573. package/src/_models/control-models/api-call-params.control-model.spec.ts +152 -152
  574. package/src/_models/control-models/api-call-params.control-model.ts +142 -142
  575. package/src/_models/control-models/app-ext-system-controls.control-model.spec.ts +52 -52
  576. package/src/_models/control-models/app-ext-system-controls.control-model.ts +9 -9
  577. package/src/_models/control-models/app-params.control-model.spec.ts +225 -225
  578. package/src/_models/control-models/app-params.control-model.ts +136 -136
  579. package/src/_models/control-models/app-system-controls.control-model.spec.ts +31 -31
  580. package/src/_models/control-models/app-system-controls.control-model.ts +9 -9
  581. package/src/_models/control-models/endpoint-params.control-model.spec.ts +627 -627
  582. package/src/_models/control-models/endpoint-params.control-model.ts +627 -627
  583. package/src/_models/control-models/http-settings.control-model.spec.ts +77 -77
  584. package/src/_models/control-models/http-settings.control-model.ts +37 -37
  585. package/src/_models/control-models/system-control.control-model.spec.ts +27 -27
  586. package/src/_models/control-models/system-control.control-model.ts +12 -12
  587. package/src/_models/interfaces/certification-settings.interface.ts +7 -7
  588. package/src/_models/interfaces/compare-data-options.interface.ts +27 -27
  589. package/src/_models/interfaces/compare-data-result.interface.ts +12 -12
  590. package/src/_models/interfaces/cors-settings.interface.spec.ts +52 -52
  591. package/src/_models/interfaces/cors-settings.interface.ts +56 -56
  592. package/src/_models/interfaces/environment-settings.interface.ts +59 -59
  593. package/src/_models/interfaces/global-log-settings.interface.ts +171 -171
  594. package/src/_models/interfaces/global-service-settings.interface.ts +47 -47
  595. package/src/_models/interfaces/global-settings.interface.ts +185 -185
  596. package/src/_models/interfaces/routing-module-settings.interface.ts +21 -21
  597. package/src/_models/interfaces/static-client-settings.interface.spec.ts +29 -29
  598. package/src/_models/interfaces/static-client-settings.interface.ts +28 -28
  599. package/src/_models/types/db-update.type.ts +100 -100
  600. package/src/_modules/admin-auth/_models/admin-api-key-config.interface.ts +33 -33
  601. package/src/_modules/admin-auth/admin-api-key.auth-service.spec.ts +200 -200
  602. package/src/_modules/admin-auth/admin-api-key.auth-service.ts +220 -220
  603. package/src/_modules/admin-auth/index.ts +2 -2
  604. package/src/_modules/ai/_models/ai-input-interfaces.ts +117 -117
  605. package/src/_modules/ai/_models/ai-test-generation-result.interface.ts +16 -16
  606. package/src/_modules/ai/_models/interfaces/dynts-ai-cost-event-callback.interface.ts +14 -14
  607. package/src/_modules/ai/_models/interfaces/dynts-ai-cost-event.interface.ts +56 -56
  608. package/src/_modules/ai/_modules/anthropic/_services/aai-user-key.control-service.ts +138 -138
  609. package/src/_modules/ai/_modules/anthropic/index.ts +5 -5
  610. package/src/_modules/ai/_modules/document-ai/_collections/dai-chunking.util.spec.ts +242 -242
  611. package/src/_modules/ai/_modules/document-ai/_collections/dai-chunking.util.ts +639 -639
  612. package/src/_modules/ai/_modules/document-ai/_collections/dai-code-chunking.util.spec.ts +295 -295
  613. package/src/_modules/ai/_modules/document-ai/_collections/dai-code-chunking.util.ts +552 -552
  614. package/src/_modules/ai/_modules/document-ai/_collections/dai-document.util.spec.ts +209 -209
  615. package/src/_modules/ai/_modules/document-ai/_collections/dai-document.util.ts +85 -85
  616. package/src/_modules/ai/_modules/document-ai/_enums/dai-compare-result-type.enum.ts +7 -7
  617. package/src/_modules/ai/_modules/document-ai/_models/data-models/dai-doc-chunk.data-model.ts +146 -146
  618. package/src/_modules/ai/_modules/document-ai/_models/data-models/dai-doc-page.data-model.ts +162 -162
  619. package/src/_modules/ai/_modules/document-ai/_models/data-models/dai-document.data-model.ts +99 -99
  620. package/src/_modules/ai/_modules/document-ai/_models/interfaces/dai-code-chunk.interface.ts +68 -68
  621. package/src/_modules/ai/_modules/document-ai/_models/interfaces/dai-doc-chunk-compare-result.interface.ts +18 -18
  622. package/src/_modules/ai/_modules/document-ai/_models/interfaces/dai-doc-page-compare-result.interface.ts +19 -19
  623. package/src/_modules/ai/_modules/document-ai/_models/interfaces/dai-document-compare-result.interface.ts +25 -25
  624. package/src/_modules/ai/_modules/document-ai/index.ts +30 -30
  625. package/src/_modules/ai/_modules/fdp-ai/_services/fdpai-user-key.control-service.ts +189 -189
  626. package/src/_modules/ai/_modules/fdp-ai/index.ts +5 -5
  627. package/src/_modules/ai/_modules/open-ai/_collections/oai-global-settings.const.ts +9 -9
  628. package/src/_modules/ai/_modules/open-ai/_collections/oai-llm-predefined-requests-hu.conts.ts +82 -82
  629. package/src/_modules/ai/_modules/open-ai/_collections/oai-llm-predefined-requests.conts.ts +75 -75
  630. package/src/_modules/ai/_modules/open-ai/_enums/oai-gpt-message-role.enum.ts +45 -45
  631. package/src/_modules/ai/_modules/open-ai/_models/interfaces/oai-global-settings.interface.ts +7 -7
  632. package/src/_modules/ai/_modules/open-ai/_models/interfaces/oai-gpt-message.interface.ts +7 -7
  633. package/src/_modules/ai/_modules/open-ai/_models/interfaces/oai-llm-predefined-requests.interface.ts +57 -57
  634. package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-doc-chunk-data.service.ts +292 -292
  635. package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-doc-page.data-service.ts +572 -572
  636. package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-document.data-service.spec.ts +342 -342
  637. package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-document.data-service.ts +435 -435
  638. package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-vector-data.service.spec.ts +550 -550
  639. package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-vector-data.service.ts +630 -630
  640. package/src/_modules/ai/_modules/open-ai/_services/oai-embedding.control-service.spec.ts +332 -332
  641. package/src/_modules/ai/_modules/open-ai/_services/oai-embedding.control-service.ts +132 -132
  642. package/src/_modules/ai/_modules/open-ai/_services/oai-llm-chat.service-base.spec.ts +462 -462
  643. package/src/_modules/ai/_modules/open-ai/_services/oai-llm-chat.service-base.ts +634 -634
  644. package/src/_modules/ai/_modules/open-ai/_services/oai-llm.service-base.spec.ts +489 -489
  645. package/src/_modules/ai/_modules/open-ai/_services/oai-llm.service-base.tools.spec.ts +173 -173
  646. package/src/_modules/ai/_modules/open-ai/_services/oai-llm.service-base.ts +1033 -1033
  647. package/src/_modules/ai/_modules/open-ai/_services/oai-user-key.control-service.ts +157 -157
  648. package/src/_modules/ai/_modules/open-ai/index.ts +74 -74
  649. package/src/_modules/ai/_services/ai-embedding-mock.service.spec.ts +115 -115
  650. package/src/_modules/ai/_services/ai-embedding-mock.service.ts +233 -233
  651. package/src/_modules/ai/_services/ai-embedding-provider.registry.spec.ts +110 -110
  652. package/src/_modules/ai/_services/ai-embedding-provider.registry.ts +114 -114
  653. package/src/_modules/ai/_services/ai-embedding.service-base.spec.ts +98 -98
  654. package/src/_modules/ai/_services/ai-embedding.service-base.ts +48 -48
  655. package/src/_modules/ai/_services/ai-llm-chat.service-base.spec.ts +229 -229
  656. package/src/_modules/ai/_services/ai-llm-chat.service-base.ts +68 -68
  657. package/src/_modules/ai/_services/ai-llm.service-base.spec.ts +250 -250
  658. package/src/_modules/ai/_services/ai-llm.service-base.ts +519 -519
  659. package/src/_modules/ai/_services/ai-provider.service-base.spec.ts +158 -158
  660. package/src/_modules/ai/_services/ai-provider.service-base.ts +67 -67
  661. package/src/_modules/ai/_services/ai-user-key.service-base.ts +59 -59
  662. package/src/_modules/ai/_services/lmstudio-embedding.control-service.spec.ts +197 -197
  663. package/src/_modules/ai/_services/lmstudio-embedding.control-service.ts +399 -399
  664. package/src/_modules/ai/index.ts +23 -23
  665. package/src/_modules/assistant/_collections/ass-global-settings.const.ts +13 -13
  666. package/src/_modules/assistant/_collections/ass.util.spec.ts +176 -176
  667. package/src/_modules/assistant/_collections/ass.util.ts +50 -50
  668. package/src/_modules/assistant/_models/ass-global-settings.interface.ts +15 -15
  669. package/src/_modules/assistant/_services/ass-io.control-service.spec.ts +140 -140
  670. package/src/_modules/assistant/_services/ass-io.control-service.ts +74 -74
  671. package/src/_modules/assistant/_services/ass-main.control-service.spec.ts +192 -192
  672. package/src/_modules/assistant/_services/ass-main.control-service.ts +107 -107
  673. package/src/_modules/assistant/index.ts +19 -19
  674. package/src/_modules/bot/_collections/bot-default-commands.const.ts +12 -12
  675. package/src/_modules/bot/_collections/bot-global-settings.const.ts +39 -39
  676. package/src/_modules/bot/_models/bot-channel-wrapper.interface.ts +62 -62
  677. package/src/_modules/bot/_models/bot-command.interface.ts +8 -8
  678. package/src/_modules/bot/_models/bot-global-settings.interface.ts +96 -96
  679. package/src/_modules/bot/_models/bot-last-mention-date.interface.ts +6 -6
  680. package/src/_modules/bot/_models/bot-last-message-date.interface.ts +5 -5
  681. package/src/_modules/bot/_models/bot-message-wrapper.interface.ts +90 -90
  682. package/src/_modules/bot/_models/bot-user-wrapper.interface.ts +41 -41
  683. package/src/_modules/bot/_modules/discord-bot/_models/dib-platform.types.ts +9 -9
  684. package/src/_modules/bot/_modules/discord-bot/_services/dib-messaging-provider.control-service.spec.ts +431 -431
  685. package/src/_modules/bot/_modules/discord-bot/_services/dib-messaging-provider.control-service.ts +641 -641
  686. package/src/_modules/bot/_modules/discord-bot/index.ts +12 -12
  687. package/src/_modules/bot/_modules/dynamo-bot/_collections/dyb-operations.util.spec.ts +160 -160
  688. package/src/_modules/bot/_modules/dynamo-bot/_collections/dyb-operations.util.ts +55 -55
  689. package/src/_modules/bot/_modules/dynamo-bot/_models/dyb-platform.types.ts +15 -15
  690. package/src/_modules/bot/_modules/dynamo-bot/_services/dyb-messaging-provider.control-service.spec.ts +374 -374
  691. package/src/_modules/bot/_modules/dynamo-bot/_services/dyb-messaging-provider.control-service.ts +447 -447
  692. package/src/_modules/bot/_modules/dynamo-bot/index.ts +15 -15
  693. package/src/_modules/bot/_modules/slack-bot/_models/slb-platform.types.ts +9 -9
  694. package/src/_modules/bot/_modules/slack-bot/_services/slb-messaging-provider.control-service.spec.ts +344 -344
  695. package/src/_modules/bot/_modules/slack-bot/_services/slb-messaging-provider.control-service.ts +197 -197
  696. package/src/_modules/bot/_modules/slack-bot/index.ts +12 -12
  697. package/src/_modules/bot/_modules/teams-bot/_models/teb-platform.types.ts +9 -9
  698. package/src/_modules/bot/_modules/teams-bot/_services/teb-messaging-provider.control-service.spec.ts +345 -345
  699. package/src/_modules/bot/_modules/teams-bot/_services/teb-messaging-provider.control-service.ts +197 -197
  700. package/src/_modules/bot/_modules/teams-bot/index.ts +11 -11
  701. package/src/_modules/bot/_services/bot-commands.control-service.spec.ts +116 -116
  702. package/src/_modules/bot/_services/bot-commands.control-service.ts +158 -158
  703. package/src/_modules/bot/_services/bot-io.control-service.spec.ts +285 -285
  704. package/src/_modules/bot/_services/bot-io.control-service.ts +329 -329
  705. package/src/_modules/bot/_services/bot-main.control-service.spec.ts +208 -208
  706. package/src/_modules/bot/_services/bot-main.control-service.ts +489 -489
  707. package/src/_modules/bot/_services/bot-messaging-provider.service-base.spec.ts +349 -349
  708. package/src/_modules/bot/_services/bot-messaging-provider.service-base.ts +158 -158
  709. package/src/_modules/bot/_services/bot-routines.control-service.spec.ts +111 -111
  710. package/src/_modules/bot/_services/bot-routines.control-service.ts +78 -78
  711. package/src/_modules/bot/index.ts +37 -37
  712. package/src/_modules/custom-data/custom-data.controller.spec.ts +49 -49
  713. package/src/_modules/custom-data/custom-data.controller.ts +67 -67
  714. package/src/_modules/custom-data/custom-data.data-service.spec.ts +54 -54
  715. package/src/_modules/custom-data/custom-data.data-service.ts +21 -21
  716. package/src/_modules/custom-data/get-custom-data-routing-module.util.spec.ts +28 -28
  717. package/src/_modules/custom-data/get-custom-data-routing-module.util.ts +24 -24
  718. package/src/_modules/custom-data/index.ts +9 -9
  719. package/src/_modules/data-readers/_collections/dynts-sqlite-reader.util.spec.ts +176 -176
  720. package/src/_modules/data-readers/_collections/dynts-sqlite-reader.util.ts +203 -203
  721. package/src/_modules/data-readers/_models/interfaces/dynts-sqlite-reader.interface.ts +33 -33
  722. package/src/_modules/data-readers/index.ts +11 -11
  723. package/src/_modules/defaults/_collections/default-endpoints.util.ts +487 -487
  724. package/src/_modules/defaults/_models/default-user.data-model.ts +72 -72
  725. package/src/_modules/defaults/_services/default-auth.service.spec.ts +269 -269
  726. package/src/_modules/defaults/_services/default-auth.service.ts +177 -177
  727. package/src/_modules/defaults/_services/default-socket-events.service.spec.ts +42 -42
  728. package/src/_modules/defaults/_services/default-socket-events.service.ts +61 -61
  729. package/src/_modules/defaults/_services/default-user.data-service.spec.ts +187 -187
  730. package/src/_modules/defaults/_services/default-user.data-service.ts +98 -98
  731. package/src/_modules/defaults/index.ts +17 -17
  732. package/src/_modules/discord-assistant/_collections/dias-global-settings.const.ts +19 -19
  733. package/src/_modules/discord-assistant/_collections/dias.util.spec.ts +366 -366
  734. package/src/_modules/discord-assistant/_collections/dias.util.ts +132 -132
  735. package/src/_modules/discord-assistant/_models/dias-global-settings.interface.ts +19 -19
  736. package/src/_modules/discord-assistant/_models/dias-knowledge.data-model.ts +52 -52
  737. package/src/_modules/discord-assistant/_services/dias-chunk.data-service.ts +177 -177
  738. package/src/_modules/discord-assistant/_services/dias-io.control-service.spec.ts +108 -108
  739. package/src/_modules/discord-assistant/_services/dias-io.control-service.ts +69 -69
  740. package/src/_modules/discord-assistant/_services/dias-main.control-service.spec.ts +22 -22
  741. package/src/_modules/discord-assistant/_services/dias-main.control-service.ts +27 -27
  742. package/src/_modules/discord-assistant/_services/dias.service-base.spec.ts +195 -195
  743. package/src/_modules/discord-assistant/_services/dias.service-base.ts +76 -76
  744. package/src/_modules/discord-assistant/index.ts +38 -38
  745. package/src/_modules/discord-assistant-voiced/_services/dias-discord-bot.control-service.spec.ts +34 -34
  746. package/src/_modules/discord-assistant-voiced/_services/dias-discord-bot.control-service.ts +11 -11
  747. package/src/_modules/discord-assistant-voiced/index.ts +36 -36
  748. package/src/_modules/discord-bot/_collections/dibo-default-commands.const.ts +16 -16
  749. package/src/_modules/discord-bot/_collections/dibo-global-settings.conts.ts +55 -55
  750. package/src/_modules/discord-bot/_collections/dibo-operations.util.spec.ts +214 -214
  751. package/src/_modules/discord-bot/_collections/dibo-operations.util.ts +387 -387
  752. package/src/_modules/discord-bot/_models/dibo-command.interface.ts +12 -12
  753. package/src/_modules/discord-bot/_models/dibo-global-settings.interface.ts +98 -98
  754. package/src/_modules/discord-bot/_models/dibo-last-mention-date.inteface.ts +7 -7
  755. package/src/_modules/discord-bot/_models/dibo-last-message-date.interface.ts +6 -6
  756. package/src/_modules/discord-bot/_services/dibo-commands.control-service.spec.ts +154 -154
  757. package/src/_modules/discord-bot/_services/dibo-commands.control-service.ts +153 -153
  758. package/src/_modules/discord-bot/_services/dibo-io.control-service.spec.ts +264 -264
  759. package/src/_modules/discord-bot/_services/dibo-io.control-service.ts +306 -306
  760. package/src/_modules/discord-bot/_services/dibo-main.control-service.spec.ts +408 -408
  761. package/src/_modules/discord-bot/_services/dibo-main.control-service.ts +487 -487
  762. package/src/_modules/discord-bot/_services/dibo-routines.control-service.spec.ts +105 -105
  763. package/src/_modules/discord-bot/_services/dibo-routines.control-service.ts +97 -97
  764. package/src/_modules/discord-bot/index.ts +36 -36
  765. package/src/_modules/local-vector-search/_enums/lvs-search-mode.enum.ts +35 -35
  766. package/src/_modules/local-vector-search/_models/data-models/lvs-vector-persist.data-model.ts +60 -60
  767. package/src/_modules/local-vector-search/_models/lvs-search-result.interface.ts +17 -17
  768. package/src/_modules/local-vector-search/_services/lvs-bm25.util.spec.ts +159 -159
  769. package/src/_modules/local-vector-search/_services/lvs-bm25.util.ts +206 -206
  770. package/src/_modules/local-vector-search/_services/lvs-doc-chunk-data.service.spec.ts +418 -418
  771. package/src/_modules/local-vector-search/_services/lvs-doc-chunk-data.service.ts +276 -276
  772. package/src/_modules/local-vector-search/_services/lvs-local-vector-search.data-service.spec.ts +480 -480
  773. package/src/_modules/local-vector-search/_services/lvs-local-vector-search.data-service.ts +416 -416
  774. package/src/_modules/local-vector-search/_services/lvs-persistent-vector-pool.control-service.spec.ts +198 -198
  775. package/src/_modules/local-vector-search/_services/lvs-persistent-vector-pool.control-service.ts +150 -150
  776. package/src/_modules/local-vector-search/_services/lvs-vector-persist.data-service.spec.ts +167 -167
  777. package/src/_modules/local-vector-search/_services/lvs-vector-persist.data-service.ts +108 -108
  778. package/src/_modules/local-vector-search/_services/lvs-vector-pool.control-service.spec.ts +455 -393
  779. package/src/_modules/local-vector-search/_services/lvs-vector-pool.control-service.ts +239 -220
  780. package/src/_modules/local-vector-search/index.ts +16 -16
  781. package/src/_modules/logs/_models/file-log-entry.interface.ts +13 -13
  782. package/src/_modules/logs/_models/file-log-read-result.interface.ts +37 -37
  783. package/src/_modules/logs/file-log.service.spec.ts +341 -341
  784. package/src/_modules/logs/file-log.service.ts +466 -466
  785. package/src/_modules/logs/file-logs.controller.spec.ts +245 -245
  786. package/src/_modules/logs/file-logs.controller.ts +165 -165
  787. package/src/_modules/logs/get-file-logs-routing-module.util.ts +51 -51
  788. package/src/_modules/logs/get-logs-routing-module.util.ts +36 -36
  789. package/src/_modules/logs/index.ts +11 -11
  790. package/src/_modules/logs/log-buffer.service.ts +101 -101
  791. package/src/_modules/logs/logs.controller.ts +109 -109
  792. package/src/_modules/logs/logs.service.ts +100 -100
  793. package/src/_modules/mcp/_models/interfaces/dynts-mcp.interface.ts +111 -111
  794. package/src/_modules/mcp/_services/dynts-mcp-server.service-base.spec.ts +151 -151
  795. package/src/_modules/mcp/_services/dynts-mcp-server.service-base.ts +125 -125
  796. package/src/_modules/mcp/_services/dynts-mcp.adapter.ts +168 -168
  797. package/src/_modules/mcp/index.ts +13 -13
  798. package/src/_modules/messaging/README.md +354 -354
  799. package/src/_modules/messaging/_collections/get-messaging-routing-module.util.ts +26 -26
  800. package/src/_modules/messaging/_collections/msg-global-settings.const.ts +22 -22
  801. package/src/_modules/messaging/_collections/msg.util.spec.ts +226 -226
  802. package/src/_modules/messaging/_collections/msg.util.ts +83 -83
  803. package/src/_modules/messaging/_models/msg-global-settings.interface.ts +37 -37
  804. package/src/_modules/messaging/_services/msg-conversation.data-service.ts +146 -146
  805. package/src/_modules/messaging/_services/msg-events.service.spec.ts +219 -219
  806. package/src/_modules/messaging/_services/msg-events.service.ts +267 -267
  807. package/src/_modules/messaging/_services/msg-integration.control-service.ts +179 -179
  808. package/src/_modules/messaging/_services/msg-main.control-service.spec.ts +147 -147
  809. package/src/_modules/messaging/_services/msg-main.control-service.ts +571 -571
  810. package/src/_modules/messaging/_services/msg-message.data-service.ts +129 -129
  811. package/src/_modules/messaging/_services/msg.controller.spec.ts +201 -201
  812. package/src/_modules/messaging/_services/msg.controller.ts +370 -370
  813. package/src/_modules/messaging/index.ts +30 -30
  814. package/src/_modules/mock/app-extended-server.mock.ts +201 -201
  815. package/src/_modules/mock/app-integration-test.mock.ts +51 -51
  816. package/src/_modules/mock/app-params.mock.spec.ts +21 -21
  817. package/src/_modules/mock/app-params.mock.ts +9 -9
  818. package/src/_modules/mock/app-server.mock.ts +188 -188
  819. package/src/_modules/mock/auth-service.mock.spec.ts +47 -47
  820. package/src/_modules/mock/auth-service.mock.ts +28 -28
  821. package/src/_modules/mock/controller.mock.spec.ts +26 -26
  822. package/src/_modules/mock/controller.mock.ts +16 -16
  823. package/src/_modules/mock/data-model.mock.spec.ts +111 -111
  824. package/src/_modules/mock/data-model.mock.ts +82 -82
  825. package/src/_modules/mock/email-service-collection.mock.spec.ts +24 -24
  826. package/src/_modules/mock/email-service-collection.mock.ts +15 -15
  827. package/src/_modules/mock/email-service.mock.spec.ts +17 -17
  828. package/src/_modules/mock/email-service.mock.ts +20 -20
  829. package/src/_modules/mock/email-template.mock.html +14 -14
  830. package/src/_modules/mock/endpoint.mock.ts +91 -91
  831. package/src/_modules/mock/socket-client.mock.spec.ts +40 -40
  832. package/src/_modules/mock/socket-client.mock.ts +45 -45
  833. package/src/_modules/mock/socket-server.mock.spec.ts +44 -44
  834. package/src/_modules/mock/socket-server.mock.ts +46 -46
  835. package/src/_modules/oauth2/_routes/oauth2.controller.spec.ts +107 -107
  836. package/src/_modules/oauth2/_routes/oauth2.controller.ts +98 -98
  837. package/src/_modules/oauth2/_services/oauth2.auth-service.spec.ts +254 -254
  838. package/src/_modules/oauth2/_services/oauth2.auth-service.ts +232 -232
  839. package/src/_modules/oauth2/_services/oauth2.control-service.spec.ts +585 -585
  840. package/src/_modules/oauth2/_services/oauth2.control-service.ts +653 -653
  841. package/src/_modules/oauth2/index.ts +17 -17
  842. package/src/_modules/rate-limit/_models/rate-limit-config.interface.ts +69 -69
  843. package/src/_modules/rate-limit/_models/rate-limit-policy.interface.ts +16 -16
  844. package/src/_modules/rate-limit/index.ts +3 -3
  845. package/src/_modules/rate-limit/rate-limit.middleware.spec.ts +264 -264
  846. package/src/_modules/rate-limit/rate-limit.middleware.ts +343 -343
  847. package/src/_modules/scoped-config/_enums/dynts-scoped-config-level.enum.ts +22 -22
  848. package/src/_modules/scoped-config/_models/data-models/dynts-scoped-config.data-model.ts +82 -82
  849. package/src/_modules/scoped-config/_models/interfaces/dynts-scoped-config.interface.ts +107 -107
  850. package/src/_modules/scoped-config/_services/dynts-scoped-config.control-service.spec.ts +312 -312
  851. package/src/_modules/scoped-config/_services/dynts-scoped-config.control-service.ts +311 -311
  852. package/src/_modules/scoped-config/_services/dynts-scoped-config.data-service.spec.ts +123 -123
  853. package/src/_modules/scoped-config/_services/dynts-scoped-config.data-service.ts +108 -108
  854. package/src/_modules/scoped-config/index.ts +17 -17
  855. package/src/_modules/server/errors/errors.control-service.spec.ts +246 -246
  856. package/src/_modules/server/errors/errors.control-service.ts +100 -100
  857. package/src/_modules/server/errors/errors.controller.spec.ts +249 -249
  858. package/src/_modules/server/errors/errors.controller.ts +489 -489
  859. package/src/_modules/server/errors/errors.data-service.spec.ts +480 -480
  860. package/src/_modules/server/errors/errors.data-service.ts +816 -816
  861. package/src/_modules/server/index.ts +30 -30
  862. package/src/_modules/server/server-status/server-status-snapshot.control-service.spec.ts +70 -70
  863. package/src/_modules/server/server-status/server-status-snapshot.control-service.ts +17 -17
  864. package/src/_modules/server/server-status/server-status-snapshot.data-service.spec.ts +77 -77
  865. package/src/_modules/server/server-status/server-status-snapshot.data-service.ts +37 -37
  866. package/src/_modules/server/server-status/server-status.control-service.spec.ts +584 -584
  867. package/src/_modules/server/server-status/server-status.control-service.ts +396 -396
  868. package/src/_modules/server/server-status/server-status.controller.spec.ts +248 -248
  869. package/src/_modules/server/server-status/server-status.controller.ts +253 -253
  870. package/src/_modules/socket/_enums/socket-security.enum.ts +11 -11
  871. package/src/_modules/socket/_models/socket-client-service-params.control-model.spec.ts +32 -32
  872. package/src/_modules/socket/_models/socket-client-service-params.control-model.ts +22 -22
  873. package/src/_modules/socket/_models/socket-presence.control-model.spec.ts +164 -164
  874. package/src/_modules/socket/_models/socket-presence.control-model.ts +210 -210
  875. package/src/_modules/socket/_models/socket-server-service-params.control-model.spec.ts +46 -46
  876. package/src/_modules/socket/_models/socket-server-service-params.control-model.ts +22 -22
  877. package/src/_modules/socket/_services/socket-client.service.spec.ts +15 -15
  878. package/src/_modules/socket/_services/socket-client.service.ts +260 -260
  879. package/src/_modules/socket/_services/socket-server.service.spec.ts +11 -11
  880. package/src/_modules/socket/_services/socket-server.service.ts +1068 -1068
  881. package/src/_modules/socket/app-extended.integration.spec.ts +85 -85
  882. package/src/_modules/socket/app-extended.server.ts +630 -630
  883. package/src/_modules/socket/index.ts +42 -42
  884. package/src/_modules/test/get-test-routing-module.util.spec.ts +28 -28
  885. package/src/_modules/test/get-test-routing-module.util.ts +23 -23
  886. package/src/_modules/test/index.ts +11 -11
  887. package/src/_modules/test/test.controller.spec.ts +72 -72
  888. package/src/_modules/test/test.controller.ts +115 -115
  889. package/src/_modules/usage/get-usage-routing-module.util.ts +22 -22
  890. package/src/_modules/usage/index.ts +15 -15
  891. package/src/_modules/usage/usage.controller.spec.ts +81 -81
  892. package/src/_modules/usage/usage.controller.ts +126 -126
  893. package/src/_modules/usage/usage.data-service.spec.ts +332 -332
  894. package/src/_modules/usage/usage.data-service.ts +185 -185
  895. package/src/_services/base/api.service-base.spec.ts +125 -125
  896. package/src/_services/base/api.service-base.ts +74 -74
  897. package/src/_services/base/archive-data.service.spec.ts +196 -196
  898. package/src/_services/base/archive-data.service.ts +216 -216
  899. package/src/_services/base/data.service.spec.ts +674 -674
  900. package/src/_services/base/data.service.ts +2719 -2719
  901. package/src/_services/base/db.service.spec.ts +73 -73
  902. package/src/_services/base/db.service.ts +1575 -1575
  903. package/src/_services/base/singleton.service-base.spec.ts +28 -28
  904. package/src/_services/base/singleton.service-base.ts +24 -24
  905. package/src/_services/base/singleton.service.spec.ts +114 -114
  906. package/src/_services/base/singleton.service.ts +38 -38
  907. package/src/_services/core/api.service.spec.ts +140 -140
  908. package/src/_services/core/api.service.ts +607 -607
  909. package/src/_services/core/auth.service.spec.ts +159 -159
  910. package/src/_services/core/auth.service.ts +174 -174
  911. package/src/_services/core/email.service.spec.ts +85 -85
  912. package/src/_services/core/email.service.ts +742 -742
  913. package/src/_services/core/global.service.spec.ts +292 -292
  914. package/src/_services/core/global.service.ts +475 -475
  915. package/src/_services/core/memory-guard.service.spec.ts +165 -165
  916. package/src/_services/core/memory-guard.service.ts +281 -281
  917. package/src/_services/core/service-collection.service.spec.ts +46 -46
  918. package/src/_services/core/service-collection.service.ts +6 -6
  919. package/src/_services/route/controller.service.spec.ts +53 -53
  920. package/src/_services/route/controller.service.ts +148 -148
  921. package/src/_services/route/routing-module.service.spec.ts +98 -98
  922. package/src/_services/route/routing-module.service.ts +330 -330
  923. package/src/_services/server/app.server.ts +1747 -1747
  924. package/src/_services/shared.static-service.spec.ts +99 -99
  925. package/src/_services/shared.static-service.ts +78 -78
  926. package/src/index.ts +96 -96
  927. package/tsconfig.app.json +12 -12
  928. package/tsconfig.json +42 -42
@@ -1,1068 +1,1068 @@
1
-
2
- import * as SocketIO from 'socket.io';
3
-
4
- import {
5
- DyFM_AnyError, DyFM_Array, DyFM_Error, DyFM_Error_Settings, DyFM_errorFlag, DyFM_Log
6
- } from '@futdevpro/fsm-dynamo';
7
-
8
-
9
- import {
10
- DyFM_SocketEvent,
11
- DyFM_SocketEvent_Key, DyFM_SocketEventPreprocessTask, DyFM_SocketEventTask
12
- } from '@futdevpro/fsm-dynamo/socket';
13
-
14
- import { DyNTS_global_settings } from '../../../_collections/global-settings.const';
15
- import { DyNTS_SingletonService } from '../../../_services/base/singleton.service';
16
- import { DyNTS_SocketSecurity } from '../_enums/socket-security.enum';
17
- import {
18
- DyNTS_SocketPresence
19
- } from '../_models/socket-presence.control-model';
20
- import {
21
- DyNTS_SocketServerService_Params
22
- } from '../_models/socket-server-service-params.control-model';
23
-
24
- /** Opciók a setupSocketServer híváshoz: attacholt HTTP szerver esetén ne hívjuk a listen()-t. */
25
- export interface DyNTS_SocketServerSetupOptions {
26
- /** Ha true, a Socket.IO egy már listenelő HTTP/HTTPS szerverre van attacholva – ne hívjuk a listen()-t. */
27
- attachedToExistingServer?: boolean;
28
- /** A tényleges port (pl. defaultolt httpPort/httpsPort) – logokban használjuk. */
29
- effectivePort?: number;
30
- }
31
-
32
- /**
33
- * You need to define the following functions:
34
- * ```ts
35
- * getServiceParams(): DyNTS_SocketServerServiceParams;
36
- *
37
- * getIncomingEvents(): DyFM_SocketEvent<any>[];
38
- *
39
- * getPresenceFromSubscriptionEventContent(
40
- * socketSubscription: T_SubscriptionContent,
41
- * socket: SocketIO.Socket
42
- * ): Promise<T_Presence>;
43
- * ```
44
- */
45
- export abstract class DyNTS_SocketServerService<
46
- T_Presence extends DyNTS_SocketPresence = DyNTS_SocketPresence,
47
- T_SubscriptionContent = any,
48
- T_ErrorContent = any
49
- > extends DyNTS_SingletonService {
50
-
51
- protected params: DyNTS_SocketServerService_Params;
52
- get name(): string { return this.params.name; }
53
- get port(): number | undefined { return this.params.port; }
54
- get security(): DyNTS_SocketSecurity { return this.params.security; }
55
- get activeSubscriptionsCount(): number { return this.presences.length; }
56
-
57
- protected openSocketServer: SocketIO.Server;
58
- protected secureSocketServer: SocketIO.Server;
59
-
60
- /* private connectEvent: DyFM_SocketEvent<SocketIO.Socket>; */
61
- protected incomingEvents: DyFM_SocketEvent<any>[];
62
-
63
- /* private subscriptionEvent: DyFM_SocketEvent<any>; */
64
- /* private unsubscribeEvent: DyFM_SocketEvent<any>; */
65
-
66
- protected presences: T_Presence[] = [];
67
-
68
- get logSetup(): boolean { return DyNTS_global_settings.log_settings.setup; }
69
- get highDetailedLogs(): boolean { return DyNTS_global_settings.log_settings.highDetailedLogs; }
70
-
71
- override readonly defaultErrorUserMsg =
72
- `We encountered an unhandled Socket Server Error, ` +
73
- `\nplease contact the responsible development team.`;
74
-
75
- /* readonly thisLocationStack: string; */
76
-
77
- protected constructor(){
78
- super();
79
-
80
- /* this.thisLocationStack = DyNTS_getStackLocation(); */
81
-
82
- this.asyncConstructor().catch((error: any) => {
83
- DyFM_Log.error(
84
- `Socket Server Service setup failed: "${this.params?.name}" (${this.params?.port})`,
85
- error
86
- );
87
- });
88
- }
89
-
90
- /**
91
- * You need to setup a function that converts subscription event content to presence.
92
- * You should do authentication and authorization here.
93
- */
94
- protected abstract getPresenceFromSubscriptionEventContent(
95
- socketSubscription: T_SubscriptionContent,
96
- socket: SocketIO.Socket
97
- ): Promise<T_Presence>;
98
-
99
- private async asyncConstructor(): Promise<void> {
100
- try {
101
- this.params = this.getServiceParams();
102
- this.incomingEvents = this.getIncomingEvents() ?? [];
103
-
104
- await this.prepareEvents();
105
-
106
- if (this.logSetup) console.log(
107
- `Socket Server Service setup done: "${this.params.name}" (${this.params.port}) ` +
108
- `security: ${this.params.security}\n`
109
- );
110
- } catch (error) {
111
- DyFM_Log.error(
112
- `Socket Server Service setup failed: "${this.params?.name}" (${this.params?.port})`,
113
- error
114
- );
115
-
116
- throw new DyFM_Error({
117
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-GPFSRC0`,
118
- error: error,
119
- });
120
- }
121
- }
122
-
123
- /**
124
- * You must setup events and required services for this function
125
- */
126
- private async prepareEvents(): Promise<void> {
127
- try {
128
- /** Setup connect event */
129
- /* const connectEventIndex = this.incomingEvents.findIndex(
130
- (event: DyFM_SocketEvent<any>) =>
131
- event.eventKey === DyFM_SocketEvent_Key.connection
132
- );
133
-
134
- if (0 <= connectEventIndex) {
135
- this.connectEvent = this.incomingEvents.splice(connectEventIndex)[0];
136
- } else {
137
- this.connectEvent = new DyFM_SocketEvent({
138
- eventKey: DyFM_SocketEvent_Key.connection,
139
- });
140
- }
141
- this.connectEvent.serviceName = this.params.name; */
142
-
143
- if (!this.getPresenceFromSubscriptionEventContent) {
144
- throw new DyFM_Error({
145
- error: new Error('getPresenceFromSubscriptionEventContent must be set'),
146
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-PPE1`,
147
- });
148
- }
149
-
150
- if (!this.getSubscriptionTasks) {
151
- DyFM_Log.warn(
152
- `You should not set the subscription event, ` +
153
- `in case you need additional steps for your subscriptions.`,
154
- `${this.params.name} (${this.params.port})`
155
- );
156
- }
157
-
158
- if (this.incomingEvents.find(
159
- (event: DyFM_SocketEvent<any>) =>
160
- event.eventKey === DyFM_SocketEvent_Key.subscribe
161
- )) {
162
- DyFM_Log.warn(
163
- `You need to use getSubscriptionTasks() ` +
164
- `instead of setting the subscribe event in getIncomingEvents().`,
165
- `${this.params.name} (${this.params.port})`
166
- );
167
- }
168
-
169
- if (!this.incomingEvents.find(
170
- (event: DyFM_SocketEvent<any>) =>
171
- event.eventKey === DyFM_SocketEvent_Key.unsubscribe
172
- )) {
173
- DyFM_Log.warn(
174
- `You should not set the unsubscribe event, ` +
175
- `in case you need additional steps for your unsubscribe.`,
176
- `${this.params.name} (${this.params.port})`
177
- );
178
- }
179
-
180
- if (this.incomingEvents.find(
181
- (event: DyFM_SocketEvent<any>) => !event.eventKey
182
- )) {
183
- throw new DyFM_Error({
184
- error: new Error('eventKey must be set'),
185
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-PPE2`,
186
- });
187
- }
188
-
189
- this.incomingEvents.push(
190
- new DyFM_SocketEvent({
191
- eventKey: DyFM_SocketEvent_Key.disconnect,
192
- tasks: [
193
- async (socket: SocketIO.Socket, issuer: string) =>
194
- this.disconnectBaseTask(socket, issuer),
195
- ],
196
- })
197
- );
198
-
199
- if (this.errorHandling) {
200
- this.incomingEvents.push(new DyFM_SocketEvent<T_ErrorContent>({
201
- serviceName: this.params.name,
202
- eventKey: DyFM_SocketEvent_Key.error,
203
- tasks: [
204
- async (content: any) => this.errorHandling(content),
205
- ],
206
- }));
207
- } else {
208
- DyFM_Log.warn(
209
- `You should not set the error event, ` +
210
- `in case you need additional steps for your error.`,
211
- `${this.params.name} (${this.params.port})`
212
- );
213
-
214
- this.incomingEvents.push(new DyFM_SocketEvent<T_ErrorContent>({
215
- serviceName: this.params.name,
216
- eventKey: DyFM_SocketEvent_Key.error,
217
- tasks: [
218
- async (content: any) => {
219
- if (content instanceof DyFM_Error) {
220
- content.logSimple(`=--> socket-client (${this.params.name}) ERROR`);
221
- } else {
222
- DyFM_Log.error(`=--> socket-client (${this.params.name}) ERROR:`, content);
223
- }
224
- }
225
- ],
226
- }));
227
- }
228
-
229
- // Merge incoming events of the same eventKey
230
- const eventKeys = this.incomingEvents.map(
231
- (event: DyFM_SocketEvent<any>) => event.eventKey
232
- ).filter(
233
- (eventKey: string, index: number, self: string[]) =>
234
- self.indexOf(eventKey) === index
235
- );
236
- const mergedEvents: DyFM_SocketEvent<any>[] = [];
237
- eventKeys.forEach((eventKey: string) => {
238
- const events = this.incomingEvents.filter(
239
- (event: DyFM_SocketEvent<any>) => event.eventKey === eventKey
240
- );
241
-
242
- mergedEvents.push(new DyFM_SocketEvent({
243
- eventKey: eventKey,
244
- preProcesses: events.map((event: DyFM_SocketEvent<any>) => event.preProcesses).flat(),
245
- tasks: events.map((event: DyFM_SocketEvent<any>) => event.tasks).flat(),
246
- }));
247
- });
248
- this.incomingEvents = mergedEvents;
249
-
250
- if (DyNTS_global_settings.log_settings.setup) {
251
- DyFM_Log.log(
252
- `Socket Server Service - Event Preparation setup done: ` +
253
- `"${this.params?.name}" (${this.params?.port})` +
254
- `\nincomingEvents:`, this.incomingEvents.map(
255
- (event: DyFM_SocketEvent<any>) =>
256
- `\n\t"${event.eventKey}": preProcesses: ${event.preProcesses?.length} ` +
257
- `tasks: ${event.tasks?.length}`
258
- )
259
- );
260
- }
261
-
262
- // Set incoming events serviceName
263
- this.incomingEvents.forEach((event: DyFM_SocketEvent<any>) => {
264
- event.serviceName = this.params.name;
265
- });
266
- } catch (error) {
267
- DyFM_Log.error(
268
- `Socket Server Service - Event Preparation setup failed: ` +
269
- `"${this.params?.name}" (${this.params?.port})`,
270
- error
271
- );
272
-
273
- throw error;
274
- }
275
- }
276
-
277
- // eslint-disable-next-line max-lines-per-function
278
- async setupSocketServer(
279
- newSocketServer: SocketIO.Server,
280
- security: DyNTS_SocketSecurity.open | DyNTS_SocketSecurity.secure,
281
- successCallback: () => void,
282
- options?: DyNTS_SocketServerSetupOptions
283
- ): Promise<SocketIO.Server> {
284
- try {
285
- if (this.highDetailedLogs) console.log('\nfn:. setupSocketServer');
286
-
287
- const effectivePort: number | undefined = options?.effectivePort ?? this.params.port;
288
-
289
- newSocketServer.on(DyFM_SocketEvent_Key.incomingNewConnection, async (socket: SocketIO.Socket) => {
290
- try {
291
- let issuer: string;
292
-
293
- /* await this.connectEvent.executeEventTasks(socket); */
294
-
295
- await DyFM_Array.asyncForEach(
296
- this.incomingEvents.filter(
297
- (event: DyFM_SocketEvent<any>) =>
298
- event.eventKey === DyFM_SocketEvent_Key.incomingNewConnection
299
- ),
300
- async (event: DyFM_SocketEvent<any>) => {
301
- await event.executeEventTasks(socket);
302
- }
303
- );
304
-
305
-
306
- if (this.getPresenceFromSubscriptionEventContent) {
307
- socket.on(
308
- DyFM_SocketEvent_Key.subscribe,
309
- async (content: any) => {
310
- let presence: T_Presence;
311
-
312
- try {
313
- /**
314
- * usually socket logs are in event.executeEventTasks(),
315
- * but subscribe event is an exception from this,
316
- * to be able to check content before getPresenceFromSubscriptionEventContent
317
- */
318
- if (DyNTS_global_settings.log_settings.socket_eventContent) {
319
- DyFM_Log.log(
320
- `--=> incoming socket (${this.params.name}) ` +
321
- `event: "${DyFM_SocketEvent_Key.subscribe}";` +
322
- `\ncontent:`, content
323
- );
324
- } else {
325
- DyFM_Log.log(
326
- `--=> incoming socket (${this.params.name}) ` +
327
- `event: "${DyFM_SocketEvent_Key.subscribe}"`
328
- );
329
- }
330
-
331
- presence = await this.getPresenceFromSubscriptionEventContent(
332
- content, socket
333
- );
334
-
335
- presence.serviceName = this.params.name;
336
- issuer = presence.issuerLocalId;
337
-
338
- this.addSocketToPresence(presence);
339
- /* await this.subscriptionEvent.executeEventTasks(content, issuer); */
340
-
341
- if (this.getSubscriptionTasks) {
342
- await DyFM_Array.asyncForEach(
343
- this.getSubscriptionTasks(),
344
- async (task: DyFM_SocketEventTask<T_SubscriptionContent>) => {
345
- await task(content, issuer);
346
- }
347
- );
348
- }
349
-
350
- socket.emit(
351
- DyFM_SocketEvent_Key.subscriptionSuccessful,
352
- 'subscribe was successful',
353
- error => {
354
- DyFM_Log.error(
355
- `Emitting subscriptionSuccessful event failed!` +
356
- `\nerror:`, error
357
- );
358
- }
359
- );
360
-
361
- DyFM_Log.success(
362
- `<-==> socket(${this.params.name}) subscription successful (${issuer})`
363
- );
364
- } catch (error) {
365
- if (error instanceof DyFM_Error) {
366
- error.logShort(
367
- `Socket Subscription failed: "${this.params.name}" ` +
368
- `(${this.params.port}) will disconnect now...`
369
- )
370
- } else if (DyNTS_global_settings.log_settings.socket_eventContent) {
371
- DyFM_Log.error(
372
- `Socket Subscription failed: "${this.params.name}" ` +
373
- `(${this.params.port}) will disconnect now...`,
374
- /* `${this.thisLocationStack}`, */
375
- error
376
- );
377
- } else {
378
- DyFM_Log.error(
379
- `Socket Subscription failed: "${this.params.name}" ` ,
380
- `(${this.params.port}) will disconnect now...`,
381
- /* `${this.thisLocationStack}` */
382
- );
383
- }
384
- await this.closeSocket(socket, issuer, error);
385
- }
386
- }
387
- );
388
-
389
- socket.on(
390
- DyFM_SocketEvent_Key.unsubscribe,
391
- async (issuer: string) => {
392
- try {
393
- /**
394
- * usually socket logs are in event.executeEventTasks(),
395
- * but unsubscribe event is an exception from this,
396
- * to be able to check content before getPresenceFromSubscriptionEventContent
397
- */
398
- if (DyNTS_global_settings.log_settings.socket_eventContent) {
399
- DyFM_Log.log(
400
- `--=> incoming socket (${this.params.name}) ` +
401
- `event: ${DyFM_SocketEvent_Key.unsubscribe};` +
402
- `\ncontent:`, issuer
403
- );
404
- } else {
405
- DyFM_Log.log(
406
- `--=> incoming socket (${this.params.name}) ` +
407
- `event: ${DyFM_SocketEvent_Key.unsubscribe}`
408
- );
409
- }
410
-
411
- /* await this.unsubscribeEvent.executeEventTasks(null, issuer); */
412
- await DyFM_Array.asyncForEach(
413
- this.incomingEvents.filter(
414
- (event: DyFM_SocketEvent<any>) =>
415
- event.eventKey === DyFM_SocketEvent_Key.unsubscribe
416
- ),
417
- async (event: DyFM_SocketEvent<any>) => {
418
- await event.executeEventTasks(null, issuer);
419
- }
420
- );
421
-
422
- this.removeSubscription(socket, issuer);
423
-
424
- socket.emit(
425
- DyFM_SocketEvent_Key.unsubscribeSuccessful,
426
- 'unsubscribe was successful',
427
- error => {
428
- DyFM_Log.error(
429
- `Emitting unsubscribeSuccessful event failed!` +
430
- `\nerror:`, error
431
- );
432
- }
433
- );
434
-
435
- DyFM_Log.success(
436
- `< x > socket(${this.params.name}) unsubscribe successful (${issuer})`
437
- );
438
- } catch (error) {
439
- if (error instanceof DyFM_Error) {
440
- error.logSimple(
441
- `Socket Unsubscription failed: "${this.params.name}" ` +
442
- `(${this.params.port}) will disconnect now...`
443
- )
444
- } else if (DyNTS_global_settings.log_settings.socket_eventContent) {
445
- DyFM_Log.error(
446
- `Socket unsubscribe failed: "${this.params.name}" ` ,
447
- `(${this.params.port}) will disconnect now...`,
448
- error
449
- );
450
- } else {
451
- DyFM_Log.error(
452
- `Socket unsubscribe failed: "${this.params.name}" ` ,
453
- `(${this.params.port}) will disconnect now...`
454
- );
455
- }
456
- socket.emit(DyFM_SocketEvent_Key.error, error);
457
- this.removeSubscription(socket, issuer);
458
- }
459
- }
460
- );
461
- }
462
-
463
- this.incomingEvents.filter(
464
- (event: DyFM_SocketEvent<any>) =>
465
- event.eventKey !== DyFM_SocketEvent_Key.incomingNewConnection &&
466
- event.eventKey !== DyFM_SocketEvent_Key.subscribe &&
467
- event.eventKey !== DyFM_SocketEvent_Key.unsubscribe
468
- ).forEach((event: DyFM_SocketEvent<any>) => {
469
- socket.on(
470
- event.eventKey,
471
- async (content: any) => {
472
- try {
473
- await event.executeEventTasks(content, issuer);
474
- } catch (error) {
475
- if (error instanceof DyFM_Error) {
476
- error.logSimple(
477
- `Socket Event failed: "${this.params.name}" (${this.params.port})`
478
- )
479
- } else {
480
- DyFM_Log.error(
481
- `Socket Event failed: "${this.params.name}" (${this.params.port})`,
482
- error
483
- );
484
- }
485
- socket.emit(DyFM_SocketEvent_Key.error, error);
486
- }
487
- }
488
- );
489
- });
490
-
491
- if (DyNTS_global_settings.log_settings.socket_mainEvents) {
492
- DyFM_Log.success(`< > socket(${this.params.name}): new CONNECTION established`);
493
- }
494
- } catch (error) {
495
- if (error instanceof DyFM_Error) {
496
- error.logSimple(
497
- `Socket Connection failed: "${this.params.name}" ` +
498
- `(${this.params.port}) will disconnect now...`
499
- )
500
- } else {
501
- DyFM_Log.error(
502
- `Socket Connection failed: "${this.params.name}" ` +
503
- `(${this.params.port}) will disconnect now...`,
504
- error
505
- );
506
- }
507
-
508
- await this.closeSocket(socket, `${this.params.name} on connection error`, error);
509
- }
510
- });
511
-
512
- const isAttach: boolean =
513
- options?.attachedToExistingServer === true ||
514
- (this.params.port === undefined && options?.effectivePort !== undefined);
515
-
516
- if (isAttach) {
517
- DyFM_Log.success(
518
- `\nsocket server setup finished: "${this.params.name}"` +
519
- (effectivePort !== undefined ? ` (attached to server on port: ${effectivePort})` : ' (attached to existing server)')
520
- );
521
- successCallback();
522
- } else {
523
- try {
524
- const portToListen: number | undefined = this.params.port ?? options?.effectivePort;
525
- if (portToListen === undefined) {
526
- throw new Error(
527
- `PORT NOT SET: "${this.params.name}". ` +
528
- `Either set port in getServiceParams() or pass effectivePort in setupSocketServer options.`
529
- );
530
- }
531
- newSocketServer.listen(portToListen);
532
-
533
- DyFM_Log.success(
534
- `\nsocket server setup finished: "${this.params.name}"` +
535
- `\nsocket server listening on port: "${portToListen}"`
536
- );
537
- } catch (listenError) {
538
- const portForMsg: number | undefined = this.params.port ?? options?.effectivePort;
539
- const errorMessage = `Failed to bind socket server "${this.params.name}" to port ${portForMsg}. ` +
540
- `This could be due to port already in use or insufficient permissions. ` +
541
- `Please ensure the port is available and try again.`;
542
-
543
- DyFM_Log.error(errorMessage, listenError);
544
- throw new Error(errorMessage);
545
- }
546
-
547
- successCallback();
548
- }
549
-
550
- if (security === DyNTS_SocketSecurity.open) {
551
- this.openSocketServer = newSocketServer;
552
-
553
- return this.openSocketServer;
554
- } else {
555
- this.secureSocketServer = newSocketServer;
556
-
557
- return this.secureSocketServer;
558
- }
559
- } catch (error) {
560
- if (error instanceof DyFM_Error) {
561
- error.logSimple(
562
- `Socket Server Service - Deep Setup failed: "${this.params?.name}" ` +
563
- `(${this.params?.port})`
564
- )
565
- } else {
566
- DyFM_Log.error(
567
- `Socket Server Service - Deep Setup failed: "${this.params?.name}" ` +
568
- `(${this.params?.port})`,
569
- error
570
- );
571
- }
572
-
573
- throw error;
574
- }
575
- }
576
-
577
- protected async addSocketToPresence(newPresence: T_Presence): Promise<void> {
578
- try {
579
- const activePresence: T_Presence = this.presences.find(
580
- (pres: T_Presence) => pres.issuerLocalId === newPresence.issuerLocalId
581
- );
582
-
583
- if (activePresence) {
584
- activePresence.sockets.push(...newPresence.sockets);
585
- } else {
586
- this.presences.push(newPresence);
587
- }
588
- } catch (error) {
589
- if (error instanceof DyFM_Error) {
590
- error.logShort(
591
- `Socket Subscription failed: "${this.params?.name}" (${this.params?.port})`
592
- )
593
- } else if (DyNTS_global_settings.log_settings.socket_eventContent) {
594
- DyFM_Log.error(
595
- `Socket Subscription failed: "${this.params?.name}" (${this.params?.port})`,
596
- /* `${this.thisLocationStack}`, */
597
- error
598
- );
599
- } else {
600
- DyFM_Log.error(
601
- `Socket Subscription failed: "${this.params?.name}" (${this.params?.port})`,
602
- /* `${this.thisLocationStack}` */
603
- );
604
- }
605
-
606
- throw error;
607
- }
608
- }
609
-
610
- protected async closeSocket(socket: SocketIO.Socket, issuer: string, withError?: DyFM_AnyError): Promise<void> {
611
- try {
612
- if (withError) {
613
- socket.emit(DyFM_SocketEvent_Key.error, withError);
614
- }
615
-
616
- await DyFM_Array.asyncForEach(
617
- this.incomingEvents.filter(
618
- (event: DyFM_SocketEvent<any>) =>
619
- event.eventKey === DyFM_SocketEvent_Key.disconnect
620
- ),
621
- async (event: DyFM_SocketEvent<any>) => {
622
- await event.executeEventTasks(null, issuer);
623
- }
624
- );
625
-
626
- /* if (this.getSubscriptionCloseTasks) {
627
- await DyFM_Array.asyncForEach(
628
- this.getSubscriptionCloseTasks(),
629
- async (task: DyFM_SocketEventTask<null>) => {
630
- await task(null, issuer);
631
- }
632
- );
633
- } */
634
-
635
- socket.emit(DyFM_SocketEvent_Key.disconnect);
636
- socket.disconnect();
637
-
638
- await this.removeSocketFromPresence(socket);
639
- } catch (error) {
640
- throw new DyFM_Error({
641
- ...this._getDefaultErrorSettings('closeSocket', error),
642
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-CS0`,
643
- });
644
- }
645
- }
646
-
647
- protected async removeSocketFromPresence(socket: SocketIO.Socket): Promise<void> {
648
- try {
649
- const presence: T_Presence = this.presences.find(
650
- (pres: T_Presence) => pres.sockets.includes(socket)
651
- );
652
-
653
- if (presence) {
654
- const socketIndex: number = presence.sockets.indexOf(socket);
655
-
656
- if (socketIndex !== -1) {
657
- presence.sockets.splice(socketIndex, 1);
658
- }
659
-
660
- if (presence.sockets.length === 0) {
661
- const presenceIndex: number = this.presences.indexOf(presence);
662
-
663
- if (presenceIndex !== -1) {
664
- this.presences.splice(presenceIndex, 1);
665
- }
666
- }
667
- }
668
- } catch (error) {
669
- throw new DyFM_Error({
670
- ...this._getDefaultErrorSettings('removeSocketFromPresence', error),
671
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-RSO0`,
672
- });
673
- }
674
- }
675
-
676
- private async disconnectBaseTask(socket: SocketIO.Socket, issuer: string): Promise<void> {
677
- try {
678
- if (!(socket instanceof SocketIO.Socket)) {
679
- /* throw new DyFM_Error({
680
- ...this._getDefaultErrorSettings(
681
- 'disconnectBaseTask',
682
- new Error('Socket is not a SocketIO.Socket, type: ' + typeof socket),
683
- ),
684
- }); */
685
- DyFM_Log.error(
686
- `Socket is not a SocketIO.Socket, type: ${typeof socket}`,
687
- socket
688
- );
689
- //TODO: remove all presences that have no socket
690
- }
691
-
692
- await this.removeSubscription(socket, issuer).catch(error => {
693
- if (error instanceof DyFM_Error) {
694
- error.logShort(
695
- `Remove Subscription failed: "${this.params.name}" (${this.params.port})`
696
- );
697
- } else {
698
- DyFM_Log.error(`Remove Subscription failed: "${this.params.name}" (${this.params.port})`, error);
699
- }
700
- });
701
-
702
- DyFM_Log.info(`< x > socket(${this.params.name}) disconnected (${issuer})`);
703
- } catch (error) {
704
- throw new DyFM_Error({
705
- ...this._getDefaultErrorSettings(
706
- 'disconnectBaseTask',
707
- error,
708
- issuer
709
- ),
710
-
711
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-DBT0`,
712
- });
713
- }
714
- }
715
-
716
- private async removeSubscription(socket: SocketIO.Socket, issuer?: string): Promise<void> {
717
- try {
718
- if (!this.presences.length) {
719
- throw new DyFM_Error({
720
- ...this._getDefaultErrorSettings(
721
- 'removeSubscription',
722
- new Error(`No presences found (${this.params.name})`),
723
- issuer ?? 'unknown issuer'
724
- ),
725
-
726
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-RS1`,
727
- });
728
- }
729
-
730
- const activePresenceIndex: number = this.presences.findIndex(
731
- (pres: DyNTS_SocketPresence) => pres.sockets.includes(socket)
732
- );
733
-
734
- if (activePresenceIndex === -1) {
735
- throw new DyFM_Error({
736
- ...this._getDefaultErrorSettings(
737
- 'sendEventForId',
738
- new Error(
739
- `closing socket (${this.params.name}) does not match any in the activePresences`
740
- ),
741
- issuer ?? 'unknown issuer'
742
- ),
743
-
744
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-RS2`,
745
- });
746
- }
747
-
748
- const activePresence: DyNTS_SocketPresence = this.presences[activePresenceIndex];
749
-
750
- if (issuer && activePresence.issuerLocalId !== issuer) {
751
- throw new DyFM_Error({
752
- ...this._getDefaultErrorSettings(
753
- 'sendEventForId',
754
- new Error(
755
- `socket unsubscription for "${issuer}" and ` +
756
- `"${activePresence.issuerLocalId}" does not match.`
757
- ),
758
- issuer
759
- ),
760
-
761
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-RS3`,
762
- });
763
- }
764
-
765
- const socketIndex = activePresence.sockets.findIndex((s: SocketIO.Socket) => s === socket);
766
-
767
- if (socketIndex === -1) {
768
- throw new DyFM_Error({
769
- ...this._getDefaultErrorSettings(
770
- 'sendEventForId',
771
- new Error(
772
- `closing socket (${this.params.name}) does not match any in the activePresences`
773
- ),
774
- activePresence.issuerLocalId
775
- ),
776
-
777
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-RS4`,
778
- });
779
- }
780
-
781
- activePresence.sockets.splice(socketIndex);
782
-
783
- await DyFM_Array.asyncForEach(
784
- this.incomingEvents.filter(
785
- (event: DyFM_SocketEvent<any>) =>
786
- event.eventKey === DyFM_SocketEvent_Key.unsubscribeSuccessful
787
- ),
788
- async (event: DyFM_SocketEvent<any>) => {
789
- await event.executeEventTasks(null, issuer);
790
- }
791
- );
792
-
793
- /* if (this.getSubscriptionCloseTasks) {
794
- await DyFM_Array.asyncForEach(
795
- this.getSubscriptionCloseTasks(),
796
- async (task: DyFM_SocketEventTask<null>) => {
797
- await task(null, issuer);
798
- }
799
- );
800
- } */
801
-
802
- if (activePresence.sockets.length === 0) {
803
- this.presences.splice(activePresenceIndex);
804
- }
805
-
806
- socket.emit(DyFM_SocketEvent_Key.unsubscribeSuccessful, 'unsubscribe was successful');
807
- socket.disconnect();
808
- DyFM_Log.info(`<x==> socket (${this.params.name}) unsubscription successful (${issuer})`);
809
- } catch (error) {
810
- throw new DyFM_Error({
811
- ...this._getDefaultErrorSettings(
812
- 'sendEventForId',
813
- error,
814
- issuer ?? 'unknown issuer'
815
- ),
816
-
817
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-RS0`,
818
- message: `socket (${this.params.name}) Subscription Removal failed: "${this.params?.name}"`,
819
- });
820
- }
821
- }
822
-
823
- /* emitServerEvent(event: string, content: any): void {
824
- try {
825
- DyFM_Log.log(` <=-- emitting server socket(${this.params.name}) event: ${event}`);
826
-
827
- this.openSocketServer.emit(event, content, error => {
828
- DyFM_Log.error(`Emitting server event '${event}' failed!\nerror:`, error);
829
- });
830
- } catch (error) {
831
- throw new DyFM_Error({
832
- ...this._getDefaultErrorSettings(
833
- 'emitEvent',
834
- error
835
- ),
836
-
837
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-500',
838
- message: `socket(${this.params.name}) Event Emit (${event}) failed: ${this.params?.name}`,
839
- });
840
- }
841
- } */
842
-
843
- idIsSubscribed(id: string): boolean {
844
- try {
845
- return !!this.presences.find(
846
- (presence: DyNTS_SocketPresence) => presence.issuerLocalId === id
847
- );
848
- } catch (error) {
849
- throw new DyFM_Error({
850
- ...this._getDefaultErrorSettings(
851
- 'idIsSubscribed',
852
- error
853
- ),
854
-
855
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-IIS0`,
856
- message: `socket (${this.params.name}) ID Subscription Check (${id}) failed`,
857
- });
858
- }
859
- }
860
-
861
- async emitError(presenceIssuerId: string, error: any, issuer: string): Promise<void> {
862
- try {
863
- await this.sendEventForId(presenceIssuerId, DyFM_SocketEvent_Key.error, error, issuer);
864
- } catch (error) {
865
- throw new DyFM_Error({
866
- ...this._getDefaultErrorSettings(
867
- 'emitError',
868
- error,
869
- presenceIssuerId
870
- ),
871
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-EE0`,
872
- message: `socket (${this.params.name}) Error Emit (id: ${presenceIssuerId}) failed`,
873
- });
874
- }
875
- }
876
-
877
- async sendEventForId(id: string, event: string, content: any, issuer: string): Promise<void> {
878
- try {
879
- if (!event) {
880
- throw new DyFM_Error({
881
- ...this._getDefaultErrorSettings(
882
- 'sendEventForId',
883
- new Error('No event was provided'),
884
- content?.source
885
- ),
886
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-SEFI1`,
887
- });
888
- }
889
-
890
- if (!id) {
891
- throw new DyFM_Error({
892
- ...this._getDefaultErrorSettings(
893
- 'sendEventForId',
894
- new Error('No ID was provided'),
895
- content?.source
896
- ),
897
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-SEFI2`,
898
- });
899
- }
900
-
901
- const presence: DyNTS_SocketPresence = this.presences.find(
902
- (pres: DyNTS_SocketPresence) => pres.issuerLocalId === id
903
- );
904
-
905
- if (!presence) {
906
- throw new DyFM_Error({
907
- ...this._getDefaultErrorSettings(
908
- 'sendEventForId',
909
- new Error(`No active socket with this specific ID: "${id}"`),
910
- content?.source
911
- ),
912
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-SEFI3`,
913
- });
914
- }
915
-
916
- presence.emitEvent(event, content, issuer);
917
-
918
- if (DyNTS_global_settings.log_settings.socket_eventContent) {
919
- DyFM_Log.success(
920
- ` <--= emitted socket (${this.params.name}) event: "${event}", ` +
921
- `\n presenceId: "${id}", sockets: ${presence.sockets.length}` +
922
- `\n content:`, content
923
- );
924
- } else {
925
- DyFM_Log.success(
926
- ` <--= emitted socket (${this.params.name}) event: "${event}", ` +
927
- `\n presenceId: ${id}, sockets: ${presence.sockets.length}`
928
- );
929
- }
930
- } catch (error) {
931
- try {
932
- if (error?.flag?.includes(DyFM_errorFlag) && error?.additionalInfo?.inactiveSockets) {
933
- const sockets: SocketIO.Socket[] = error.additionalInfo.inactiveSockets;
934
-
935
- await DyFM_Array.asyncForEach(sockets, async (socket: SocketIO.Socket) => {
936
- await this.removeSubscription(socket);
937
- });
938
-
939
- const presence: DyNTS_SocketPresence = this.presences.find(
940
- (pres: DyNTS_SocketPresence) => pres.issuerLocalId === id
941
- );
942
-
943
- if (!presence) {
944
- throw new DyFM_Error({
945
- ...this._getDefaultErrorSettings(
946
- 'sendEventForId',
947
- new Error(`No active socket (${this.params.name}) with this specific ID: "${id}"`),
948
- content?.source
949
- ),
950
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-SEFI4`,
951
- });
952
- }
953
- }
954
- } catch (error) {
955
- throw new DyFM_Error({
956
- ...this._getDefaultErrorSettings('sendEventForId', error, content?.source),
957
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-SEFI5`,
958
- message:
959
- `Error handling of inactive sockets (${this.params.name}) failed!` +
960
- `\n(Socket Event Emit for id (${id}, ${event}) failed)`,
961
- });
962
- }
963
-
964
- throw new DyFM_Error({
965
- ...this._getDefaultErrorSettings('sendEventForId', error, content?.source),
966
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-SEFI0`,
967
- message: `socket (${this.params.name}) Event Emit for id (${id}, ${event}) failed`,
968
- });
969
- }
970
- }
971
-
972
- async broadcastEvent(event: string, content: any, issuer: string): Promise<void> {
973
- try {
974
- DyFM_Log.log(`<=-== broadcasting socket (${this.params.name}) event: "${event}"`);
975
-
976
- this.presences.forEach((presence: DyNTS_SocketPresence) => {
977
- presence.emitEvent(event, content, issuer);
978
- });
979
- } catch (error) {
980
- if (DyNTS_global_settings.log_settings.detailedErrors) {
981
- if (error instanceof DyFM_Error) {
982
- error.logSimple(`socket (${this.params.name}) Event Broadcast (${event}) failed`);
983
- } else {
984
- DyFM_Log.error(`socket (${this.params.name}) Event Broadcast (${event}) failed`, error);
985
- }
986
- }
987
-
988
- throw new DyFM_Error({
989
- ...this._getDefaultErrorSettings('broadcastEvent', error),
990
-
991
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-BE0`,
992
- message: `socket (${this.params.name}) Event Broadcast (${event}) failed`,
993
- });
994
- }
995
- }
996
-
997
- async sendError(error: DyFM_AnyError, issuer: string): Promise<void> {
998
- try {
999
- await this.sendEventForId(issuer, DyFM_SocketEvent_Key.error, error, issuer);
1000
- } catch (error) {
1001
- throw new DyFM_Error({
1002
- ...this._getDefaultErrorSettings('sendError', error, issuer),
1003
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-SE0`,
1004
- message: `socket (${this.params.name}) Error Send (${issuer}) failed`,
1005
- });
1006
- }
1007
- }
1008
-
1009
- private _getDefaultErrorSettings(
1010
- fnName: string,
1011
- error: DyFM_AnyError,
1012
- issuer?: string
1013
- ): DyFM_Error_Settings {
1014
- return {
1015
- status: (error as DyFM_Error)?.___status ?? 500,
1016
- message: (error as Error)?.message ??
1017
- (error as DyFM_Error)?._message ??
1018
- `${fnName} was UNSUCCESSFUL (NTS)`,
1019
- addECToUserMsg: !(error as DyFM_Error)?.__userMessage,
1020
- userMessage: (error as DyFM_Error)?.__userMessage ?? this.defaultErrorUserMsg,
1021
- issuer: issuer,
1022
- issuerService: this.constructor?.name,
1023
- error: error,
1024
- };
1025
- }
1026
-
1027
- /**
1028
- * You must setup params for the service in this function
1029
- */
1030
- protected abstract getServiceParams(): DyNTS_SocketServerService_Params;
1031
-
1032
- /**
1033
- * You must setup events and required services in this function
1034
- */
1035
- protected abstract getIncomingEvents(): DyFM_SocketEvent<any>[];
1036
-
1037
- /**
1038
- * You can setup tasks for the subscription event in this function
1039
- */
1040
- /* protected getSubscriptionCloseTasks?(): DyFM_SocketEventTask<null>[]; */
1041
-
1042
- /**
1043
- * You can setup preprocesses for the subscription event in this function
1044
- */
1045
- /* protected getSubscriptionPreProcesses?(): DyFM_SocketEventPreprocessTask[]; */
1046
-
1047
- /**
1048
- * You can setup tasks for the subscription event in this function
1049
- * This will happen after the presence is created
1050
- * If this throws an error, the socket will be closed
1051
- */
1052
- protected getSubscriptionTasks?(): DyFM_SocketEventTask<T_SubscriptionContent>[];
1053
-
1054
- /**
1055
- * You can setup tasks for the unsubscribe event in this function
1056
- */
1057
- /* protected getUnsubscribeTasks?(): DyFM_SocketEventTask<T_SubscriptionContent>[]; */
1058
-
1059
- /**
1060
- * You can setup preprocesses for the unsubscribe event in this function
1061
- */
1062
- /* protected getUnsubscribePreProcesses?(): DyFM_SocketEventPreprocessTask[]; */
1063
-
1064
- /**
1065
- * You can setup tasks for the error event in this function
1066
- */
1067
- protected errorHandling?: DyFM_SocketEventTask<T_ErrorContent>;
1068
- }
1
+
2
+ import * as SocketIO from 'socket.io';
3
+
4
+ import {
5
+ DyFM_AnyError, DyFM_Array, DyFM_Error, DyFM_Error_Settings, DyFM_errorFlag, DyFM_Log
6
+ } from '@futdevpro/fsm-dynamo';
7
+
8
+
9
+ import {
10
+ DyFM_SocketEvent,
11
+ DyFM_SocketEvent_Key, DyFM_SocketEventPreprocessTask, DyFM_SocketEventTask
12
+ } from '@futdevpro/fsm-dynamo/socket';
13
+
14
+ import { DyNTS_global_settings } from '../../../_collections/global-settings.const';
15
+ import { DyNTS_SingletonService } from '../../../_services/base/singleton.service';
16
+ import { DyNTS_SocketSecurity } from '../_enums/socket-security.enum';
17
+ import {
18
+ DyNTS_SocketPresence
19
+ } from '../_models/socket-presence.control-model';
20
+ import {
21
+ DyNTS_SocketServerService_Params
22
+ } from '../_models/socket-server-service-params.control-model';
23
+
24
+ /** Opciók a setupSocketServer híváshoz: attacholt HTTP szerver esetén ne hívjuk a listen()-t. */
25
+ export interface DyNTS_SocketServerSetupOptions {
26
+ /** Ha true, a Socket.IO egy már listenelő HTTP/HTTPS szerverre van attacholva – ne hívjuk a listen()-t. */
27
+ attachedToExistingServer?: boolean;
28
+ /** A tényleges port (pl. defaultolt httpPort/httpsPort) – logokban használjuk. */
29
+ effectivePort?: number;
30
+ }
31
+
32
+ /**
33
+ * You need to define the following functions:
34
+ * ```ts
35
+ * getServiceParams(): DyNTS_SocketServerServiceParams;
36
+ *
37
+ * getIncomingEvents(): DyFM_SocketEvent<any>[];
38
+ *
39
+ * getPresenceFromSubscriptionEventContent(
40
+ * socketSubscription: T_SubscriptionContent,
41
+ * socket: SocketIO.Socket
42
+ * ): Promise<T_Presence>;
43
+ * ```
44
+ */
45
+ export abstract class DyNTS_SocketServerService<
46
+ T_Presence extends DyNTS_SocketPresence = DyNTS_SocketPresence,
47
+ T_SubscriptionContent = any,
48
+ T_ErrorContent = any
49
+ > extends DyNTS_SingletonService {
50
+
51
+ protected params: DyNTS_SocketServerService_Params;
52
+ get name(): string { return this.params.name; }
53
+ get port(): number | undefined { return this.params.port; }
54
+ get security(): DyNTS_SocketSecurity { return this.params.security; }
55
+ get activeSubscriptionsCount(): number { return this.presences.length; }
56
+
57
+ protected openSocketServer: SocketIO.Server;
58
+ protected secureSocketServer: SocketIO.Server;
59
+
60
+ /* private connectEvent: DyFM_SocketEvent<SocketIO.Socket>; */
61
+ protected incomingEvents: DyFM_SocketEvent<any>[];
62
+
63
+ /* private subscriptionEvent: DyFM_SocketEvent<any>; */
64
+ /* private unsubscribeEvent: DyFM_SocketEvent<any>; */
65
+
66
+ protected presences: T_Presence[] = [];
67
+
68
+ get logSetup(): boolean { return DyNTS_global_settings.log_settings.setup; }
69
+ get highDetailedLogs(): boolean { return DyNTS_global_settings.log_settings.highDetailedLogs; }
70
+
71
+ override readonly defaultErrorUserMsg =
72
+ `We encountered an unhandled Socket Server Error, ` +
73
+ `\nplease contact the responsible development team.`;
74
+
75
+ /* readonly thisLocationStack: string; */
76
+
77
+ protected constructor(){
78
+ super();
79
+
80
+ /* this.thisLocationStack = DyNTS_getStackLocation(); */
81
+
82
+ this.asyncConstructor().catch((error: any) => {
83
+ DyFM_Log.error(
84
+ `Socket Server Service setup failed: "${this.params?.name}" (${this.params?.port})`,
85
+ error
86
+ );
87
+ });
88
+ }
89
+
90
+ /**
91
+ * You need to setup a function that converts subscription event content to presence.
92
+ * You should do authentication and authorization here.
93
+ */
94
+ protected abstract getPresenceFromSubscriptionEventContent(
95
+ socketSubscription: T_SubscriptionContent,
96
+ socket: SocketIO.Socket
97
+ ): Promise<T_Presence>;
98
+
99
+ private async asyncConstructor(): Promise<void> {
100
+ try {
101
+ this.params = this.getServiceParams();
102
+ this.incomingEvents = this.getIncomingEvents() ?? [];
103
+
104
+ await this.prepareEvents();
105
+
106
+ if (this.logSetup) console.log(
107
+ `Socket Server Service setup done: "${this.params.name}" (${this.params.port}) ` +
108
+ `security: ${this.params.security}\n`
109
+ );
110
+ } catch (error) {
111
+ DyFM_Log.error(
112
+ `Socket Server Service setup failed: "${this.params?.name}" (${this.params?.port})`,
113
+ error
114
+ );
115
+
116
+ throw new DyFM_Error({
117
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-GPFSRC0`,
118
+ error: error,
119
+ });
120
+ }
121
+ }
122
+
123
+ /**
124
+ * You must setup events and required services for this function
125
+ */
126
+ private async prepareEvents(): Promise<void> {
127
+ try {
128
+ /** Setup connect event */
129
+ /* const connectEventIndex = this.incomingEvents.findIndex(
130
+ (event: DyFM_SocketEvent<any>) =>
131
+ event.eventKey === DyFM_SocketEvent_Key.connection
132
+ );
133
+
134
+ if (0 <= connectEventIndex) {
135
+ this.connectEvent = this.incomingEvents.splice(connectEventIndex)[0];
136
+ } else {
137
+ this.connectEvent = new DyFM_SocketEvent({
138
+ eventKey: DyFM_SocketEvent_Key.connection,
139
+ });
140
+ }
141
+ this.connectEvent.serviceName = this.params.name; */
142
+
143
+ if (!this.getPresenceFromSubscriptionEventContent) {
144
+ throw new DyFM_Error({
145
+ error: new Error('getPresenceFromSubscriptionEventContent must be set'),
146
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-PPE1`,
147
+ });
148
+ }
149
+
150
+ if (!this.getSubscriptionTasks) {
151
+ DyFM_Log.warn(
152
+ `You should not set the subscription event, ` +
153
+ `in case you need additional steps for your subscriptions.`,
154
+ `${this.params.name} (${this.params.port})`
155
+ );
156
+ }
157
+
158
+ if (this.incomingEvents.find(
159
+ (event: DyFM_SocketEvent<any>) =>
160
+ event.eventKey === DyFM_SocketEvent_Key.subscribe
161
+ )) {
162
+ DyFM_Log.warn(
163
+ `You need to use getSubscriptionTasks() ` +
164
+ `instead of setting the subscribe event in getIncomingEvents().`,
165
+ `${this.params.name} (${this.params.port})`
166
+ );
167
+ }
168
+
169
+ if (!this.incomingEvents.find(
170
+ (event: DyFM_SocketEvent<any>) =>
171
+ event.eventKey === DyFM_SocketEvent_Key.unsubscribe
172
+ )) {
173
+ DyFM_Log.warn(
174
+ `You should not set the unsubscribe event, ` +
175
+ `in case you need additional steps for your unsubscribe.`,
176
+ `${this.params.name} (${this.params.port})`
177
+ );
178
+ }
179
+
180
+ if (this.incomingEvents.find(
181
+ (event: DyFM_SocketEvent<any>) => !event.eventKey
182
+ )) {
183
+ throw new DyFM_Error({
184
+ error: new Error('eventKey must be set'),
185
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-PPE2`,
186
+ });
187
+ }
188
+
189
+ this.incomingEvents.push(
190
+ new DyFM_SocketEvent({
191
+ eventKey: DyFM_SocketEvent_Key.disconnect,
192
+ tasks: [
193
+ async (socket: SocketIO.Socket, issuer: string) =>
194
+ this.disconnectBaseTask(socket, issuer),
195
+ ],
196
+ })
197
+ );
198
+
199
+ if (this.errorHandling) {
200
+ this.incomingEvents.push(new DyFM_SocketEvent<T_ErrorContent>({
201
+ serviceName: this.params.name,
202
+ eventKey: DyFM_SocketEvent_Key.error,
203
+ tasks: [
204
+ async (content: any) => this.errorHandling(content),
205
+ ],
206
+ }));
207
+ } else {
208
+ DyFM_Log.warn(
209
+ `You should not set the error event, ` +
210
+ `in case you need additional steps for your error.`,
211
+ `${this.params.name} (${this.params.port})`
212
+ );
213
+
214
+ this.incomingEvents.push(new DyFM_SocketEvent<T_ErrorContent>({
215
+ serviceName: this.params.name,
216
+ eventKey: DyFM_SocketEvent_Key.error,
217
+ tasks: [
218
+ async (content: any) => {
219
+ if (content instanceof DyFM_Error) {
220
+ content.logSimple(`=--> socket-client (${this.params.name}) ERROR`);
221
+ } else {
222
+ DyFM_Log.error(`=--> socket-client (${this.params.name}) ERROR:`, content);
223
+ }
224
+ }
225
+ ],
226
+ }));
227
+ }
228
+
229
+ // Merge incoming events of the same eventKey
230
+ const eventKeys = this.incomingEvents.map(
231
+ (event: DyFM_SocketEvent<any>) => event.eventKey
232
+ ).filter(
233
+ (eventKey: string, index: number, self: string[]) =>
234
+ self.indexOf(eventKey) === index
235
+ );
236
+ const mergedEvents: DyFM_SocketEvent<any>[] = [];
237
+ eventKeys.forEach((eventKey: string) => {
238
+ const events = this.incomingEvents.filter(
239
+ (event: DyFM_SocketEvent<any>) => event.eventKey === eventKey
240
+ );
241
+
242
+ mergedEvents.push(new DyFM_SocketEvent({
243
+ eventKey: eventKey,
244
+ preProcesses: events.map((event: DyFM_SocketEvent<any>) => event.preProcesses).flat(),
245
+ tasks: events.map((event: DyFM_SocketEvent<any>) => event.tasks).flat(),
246
+ }));
247
+ });
248
+ this.incomingEvents = mergedEvents;
249
+
250
+ if (DyNTS_global_settings.log_settings.setup) {
251
+ DyFM_Log.log(
252
+ `Socket Server Service - Event Preparation setup done: ` +
253
+ `"${this.params?.name}" (${this.params?.port})` +
254
+ `\nincomingEvents:`, this.incomingEvents.map(
255
+ (event: DyFM_SocketEvent<any>) =>
256
+ `\n\t"${event.eventKey}": preProcesses: ${event.preProcesses?.length} ` +
257
+ `tasks: ${event.tasks?.length}`
258
+ )
259
+ );
260
+ }
261
+
262
+ // Set incoming events serviceName
263
+ this.incomingEvents.forEach((event: DyFM_SocketEvent<any>) => {
264
+ event.serviceName = this.params.name;
265
+ });
266
+ } catch (error) {
267
+ DyFM_Log.error(
268
+ `Socket Server Service - Event Preparation setup failed: ` +
269
+ `"${this.params?.name}" (${this.params?.port})`,
270
+ error
271
+ );
272
+
273
+ throw error;
274
+ }
275
+ }
276
+
277
+ // eslint-disable-next-line max-lines-per-function
278
+ async setupSocketServer(
279
+ newSocketServer: SocketIO.Server,
280
+ security: DyNTS_SocketSecurity.open | DyNTS_SocketSecurity.secure,
281
+ successCallback: () => void,
282
+ options?: DyNTS_SocketServerSetupOptions
283
+ ): Promise<SocketIO.Server> {
284
+ try {
285
+ if (this.highDetailedLogs) console.log('\nfn:. setupSocketServer');
286
+
287
+ const effectivePort: number | undefined = options?.effectivePort ?? this.params.port;
288
+
289
+ newSocketServer.on(DyFM_SocketEvent_Key.incomingNewConnection, async (socket: SocketIO.Socket) => {
290
+ try {
291
+ let issuer: string;
292
+
293
+ /* await this.connectEvent.executeEventTasks(socket); */
294
+
295
+ await DyFM_Array.asyncForEach(
296
+ this.incomingEvents.filter(
297
+ (event: DyFM_SocketEvent<any>) =>
298
+ event.eventKey === DyFM_SocketEvent_Key.incomingNewConnection
299
+ ),
300
+ async (event: DyFM_SocketEvent<any>) => {
301
+ await event.executeEventTasks(socket);
302
+ }
303
+ );
304
+
305
+
306
+ if (this.getPresenceFromSubscriptionEventContent) {
307
+ socket.on(
308
+ DyFM_SocketEvent_Key.subscribe,
309
+ async (content: any) => {
310
+ let presence: T_Presence;
311
+
312
+ try {
313
+ /**
314
+ * usually socket logs are in event.executeEventTasks(),
315
+ * but subscribe event is an exception from this,
316
+ * to be able to check content before getPresenceFromSubscriptionEventContent
317
+ */
318
+ if (DyNTS_global_settings.log_settings.socket_eventContent) {
319
+ DyFM_Log.log(
320
+ `--=> incoming socket (${this.params.name}) ` +
321
+ `event: "${DyFM_SocketEvent_Key.subscribe}";` +
322
+ `\ncontent:`, content
323
+ );
324
+ } else {
325
+ DyFM_Log.log(
326
+ `--=> incoming socket (${this.params.name}) ` +
327
+ `event: "${DyFM_SocketEvent_Key.subscribe}"`
328
+ );
329
+ }
330
+
331
+ presence = await this.getPresenceFromSubscriptionEventContent(
332
+ content, socket
333
+ );
334
+
335
+ presence.serviceName = this.params.name;
336
+ issuer = presence.issuerLocalId;
337
+
338
+ this.addSocketToPresence(presence);
339
+ /* await this.subscriptionEvent.executeEventTasks(content, issuer); */
340
+
341
+ if (this.getSubscriptionTasks) {
342
+ await DyFM_Array.asyncForEach(
343
+ this.getSubscriptionTasks(),
344
+ async (task: DyFM_SocketEventTask<T_SubscriptionContent>) => {
345
+ await task(content, issuer);
346
+ }
347
+ );
348
+ }
349
+
350
+ socket.emit(
351
+ DyFM_SocketEvent_Key.subscriptionSuccessful,
352
+ 'subscribe was successful',
353
+ error => {
354
+ DyFM_Log.error(
355
+ `Emitting subscriptionSuccessful event failed!` +
356
+ `\nerror:`, error
357
+ );
358
+ }
359
+ );
360
+
361
+ DyFM_Log.success(
362
+ `<-==> socket(${this.params.name}) subscription successful (${issuer})`
363
+ );
364
+ } catch (error) {
365
+ if (error instanceof DyFM_Error) {
366
+ error.logShort(
367
+ `Socket Subscription failed: "${this.params.name}" ` +
368
+ `(${this.params.port}) will disconnect now...`
369
+ )
370
+ } else if (DyNTS_global_settings.log_settings.socket_eventContent) {
371
+ DyFM_Log.error(
372
+ `Socket Subscription failed: "${this.params.name}" ` +
373
+ `(${this.params.port}) will disconnect now...`,
374
+ /* `${this.thisLocationStack}`, */
375
+ error
376
+ );
377
+ } else {
378
+ DyFM_Log.error(
379
+ `Socket Subscription failed: "${this.params.name}" ` ,
380
+ `(${this.params.port}) will disconnect now...`,
381
+ /* `${this.thisLocationStack}` */
382
+ );
383
+ }
384
+ await this.closeSocket(socket, issuer, error);
385
+ }
386
+ }
387
+ );
388
+
389
+ socket.on(
390
+ DyFM_SocketEvent_Key.unsubscribe,
391
+ async (issuer: string) => {
392
+ try {
393
+ /**
394
+ * usually socket logs are in event.executeEventTasks(),
395
+ * but unsubscribe event is an exception from this,
396
+ * to be able to check content before getPresenceFromSubscriptionEventContent
397
+ */
398
+ if (DyNTS_global_settings.log_settings.socket_eventContent) {
399
+ DyFM_Log.log(
400
+ `--=> incoming socket (${this.params.name}) ` +
401
+ `event: ${DyFM_SocketEvent_Key.unsubscribe};` +
402
+ `\ncontent:`, issuer
403
+ );
404
+ } else {
405
+ DyFM_Log.log(
406
+ `--=> incoming socket (${this.params.name}) ` +
407
+ `event: ${DyFM_SocketEvent_Key.unsubscribe}`
408
+ );
409
+ }
410
+
411
+ /* await this.unsubscribeEvent.executeEventTasks(null, issuer); */
412
+ await DyFM_Array.asyncForEach(
413
+ this.incomingEvents.filter(
414
+ (event: DyFM_SocketEvent<any>) =>
415
+ event.eventKey === DyFM_SocketEvent_Key.unsubscribe
416
+ ),
417
+ async (event: DyFM_SocketEvent<any>) => {
418
+ await event.executeEventTasks(null, issuer);
419
+ }
420
+ );
421
+
422
+ this.removeSubscription(socket, issuer);
423
+
424
+ socket.emit(
425
+ DyFM_SocketEvent_Key.unsubscribeSuccessful,
426
+ 'unsubscribe was successful',
427
+ error => {
428
+ DyFM_Log.error(
429
+ `Emitting unsubscribeSuccessful event failed!` +
430
+ `\nerror:`, error
431
+ );
432
+ }
433
+ );
434
+
435
+ DyFM_Log.success(
436
+ `< x > socket(${this.params.name}) unsubscribe successful (${issuer})`
437
+ );
438
+ } catch (error) {
439
+ if (error instanceof DyFM_Error) {
440
+ error.logSimple(
441
+ `Socket Unsubscription failed: "${this.params.name}" ` +
442
+ `(${this.params.port}) will disconnect now...`
443
+ )
444
+ } else if (DyNTS_global_settings.log_settings.socket_eventContent) {
445
+ DyFM_Log.error(
446
+ `Socket unsubscribe failed: "${this.params.name}" ` ,
447
+ `(${this.params.port}) will disconnect now...`,
448
+ error
449
+ );
450
+ } else {
451
+ DyFM_Log.error(
452
+ `Socket unsubscribe failed: "${this.params.name}" ` ,
453
+ `(${this.params.port}) will disconnect now...`
454
+ );
455
+ }
456
+ socket.emit(DyFM_SocketEvent_Key.error, error);
457
+ this.removeSubscription(socket, issuer);
458
+ }
459
+ }
460
+ );
461
+ }
462
+
463
+ this.incomingEvents.filter(
464
+ (event: DyFM_SocketEvent<any>) =>
465
+ event.eventKey !== DyFM_SocketEvent_Key.incomingNewConnection &&
466
+ event.eventKey !== DyFM_SocketEvent_Key.subscribe &&
467
+ event.eventKey !== DyFM_SocketEvent_Key.unsubscribe
468
+ ).forEach((event: DyFM_SocketEvent<any>) => {
469
+ socket.on(
470
+ event.eventKey,
471
+ async (content: any) => {
472
+ try {
473
+ await event.executeEventTasks(content, issuer);
474
+ } catch (error) {
475
+ if (error instanceof DyFM_Error) {
476
+ error.logSimple(
477
+ `Socket Event failed: "${this.params.name}" (${this.params.port})`
478
+ )
479
+ } else {
480
+ DyFM_Log.error(
481
+ `Socket Event failed: "${this.params.name}" (${this.params.port})`,
482
+ error
483
+ );
484
+ }
485
+ socket.emit(DyFM_SocketEvent_Key.error, error);
486
+ }
487
+ }
488
+ );
489
+ });
490
+
491
+ if (DyNTS_global_settings.log_settings.socket_mainEvents) {
492
+ DyFM_Log.success(`< > socket(${this.params.name}): new CONNECTION established`);
493
+ }
494
+ } catch (error) {
495
+ if (error instanceof DyFM_Error) {
496
+ error.logSimple(
497
+ `Socket Connection failed: "${this.params.name}" ` +
498
+ `(${this.params.port}) will disconnect now...`
499
+ )
500
+ } else {
501
+ DyFM_Log.error(
502
+ `Socket Connection failed: "${this.params.name}" ` +
503
+ `(${this.params.port}) will disconnect now...`,
504
+ error
505
+ );
506
+ }
507
+
508
+ await this.closeSocket(socket, `${this.params.name} on connection error`, error);
509
+ }
510
+ });
511
+
512
+ const isAttach: boolean =
513
+ options?.attachedToExistingServer === true ||
514
+ (this.params.port === undefined && options?.effectivePort !== undefined);
515
+
516
+ if (isAttach) {
517
+ DyFM_Log.success(
518
+ `\nsocket server setup finished: "${this.params.name}"` +
519
+ (effectivePort !== undefined ? ` (attached to server on port: ${effectivePort})` : ' (attached to existing server)')
520
+ );
521
+ successCallback();
522
+ } else {
523
+ try {
524
+ const portToListen: number | undefined = this.params.port ?? options?.effectivePort;
525
+ if (portToListen === undefined) {
526
+ throw new Error(
527
+ `PORT NOT SET: "${this.params.name}". ` +
528
+ `Either set port in getServiceParams() or pass effectivePort in setupSocketServer options.`
529
+ );
530
+ }
531
+ newSocketServer.listen(portToListen);
532
+
533
+ DyFM_Log.success(
534
+ `\nsocket server setup finished: "${this.params.name}"` +
535
+ `\nsocket server listening on port: "${portToListen}"`
536
+ );
537
+ } catch (listenError) {
538
+ const portForMsg: number | undefined = this.params.port ?? options?.effectivePort;
539
+ const errorMessage = `Failed to bind socket server "${this.params.name}" to port ${portForMsg}. ` +
540
+ `This could be due to port already in use or insufficient permissions. ` +
541
+ `Please ensure the port is available and try again.`;
542
+
543
+ DyFM_Log.error(errorMessage, listenError);
544
+ throw new Error(errorMessage);
545
+ }
546
+
547
+ successCallback();
548
+ }
549
+
550
+ if (security === DyNTS_SocketSecurity.open) {
551
+ this.openSocketServer = newSocketServer;
552
+
553
+ return this.openSocketServer;
554
+ } else {
555
+ this.secureSocketServer = newSocketServer;
556
+
557
+ return this.secureSocketServer;
558
+ }
559
+ } catch (error) {
560
+ if (error instanceof DyFM_Error) {
561
+ error.logSimple(
562
+ `Socket Server Service - Deep Setup failed: "${this.params?.name}" ` +
563
+ `(${this.params?.port})`
564
+ )
565
+ } else {
566
+ DyFM_Log.error(
567
+ `Socket Server Service - Deep Setup failed: "${this.params?.name}" ` +
568
+ `(${this.params?.port})`,
569
+ error
570
+ );
571
+ }
572
+
573
+ throw error;
574
+ }
575
+ }
576
+
577
+ protected async addSocketToPresence(newPresence: T_Presence): Promise<void> {
578
+ try {
579
+ const activePresence: T_Presence = this.presences.find(
580
+ (pres: T_Presence) => pres.issuerLocalId === newPresence.issuerLocalId
581
+ );
582
+
583
+ if (activePresence) {
584
+ activePresence.sockets.push(...newPresence.sockets);
585
+ } else {
586
+ this.presences.push(newPresence);
587
+ }
588
+ } catch (error) {
589
+ if (error instanceof DyFM_Error) {
590
+ error.logShort(
591
+ `Socket Subscription failed: "${this.params?.name}" (${this.params?.port})`
592
+ )
593
+ } else if (DyNTS_global_settings.log_settings.socket_eventContent) {
594
+ DyFM_Log.error(
595
+ `Socket Subscription failed: "${this.params?.name}" (${this.params?.port})`,
596
+ /* `${this.thisLocationStack}`, */
597
+ error
598
+ );
599
+ } else {
600
+ DyFM_Log.error(
601
+ `Socket Subscription failed: "${this.params?.name}" (${this.params?.port})`,
602
+ /* `${this.thisLocationStack}` */
603
+ );
604
+ }
605
+
606
+ throw error;
607
+ }
608
+ }
609
+
610
+ protected async closeSocket(socket: SocketIO.Socket, issuer: string, withError?: DyFM_AnyError): Promise<void> {
611
+ try {
612
+ if (withError) {
613
+ socket.emit(DyFM_SocketEvent_Key.error, withError);
614
+ }
615
+
616
+ await DyFM_Array.asyncForEach(
617
+ this.incomingEvents.filter(
618
+ (event: DyFM_SocketEvent<any>) =>
619
+ event.eventKey === DyFM_SocketEvent_Key.disconnect
620
+ ),
621
+ async (event: DyFM_SocketEvent<any>) => {
622
+ await event.executeEventTasks(null, issuer);
623
+ }
624
+ );
625
+
626
+ /* if (this.getSubscriptionCloseTasks) {
627
+ await DyFM_Array.asyncForEach(
628
+ this.getSubscriptionCloseTasks(),
629
+ async (task: DyFM_SocketEventTask<null>) => {
630
+ await task(null, issuer);
631
+ }
632
+ );
633
+ } */
634
+
635
+ socket.emit(DyFM_SocketEvent_Key.disconnect);
636
+ socket.disconnect();
637
+
638
+ await this.removeSocketFromPresence(socket);
639
+ } catch (error) {
640
+ throw new DyFM_Error({
641
+ ...this._getDefaultErrorSettings('closeSocket', error),
642
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-CS0`,
643
+ });
644
+ }
645
+ }
646
+
647
+ protected async removeSocketFromPresence(socket: SocketIO.Socket): Promise<void> {
648
+ try {
649
+ const presence: T_Presence = this.presences.find(
650
+ (pres: T_Presence) => pres.sockets.includes(socket)
651
+ );
652
+
653
+ if (presence) {
654
+ const socketIndex: number = presence.sockets.indexOf(socket);
655
+
656
+ if (socketIndex !== -1) {
657
+ presence.sockets.splice(socketIndex, 1);
658
+ }
659
+
660
+ if (presence.sockets.length === 0) {
661
+ const presenceIndex: number = this.presences.indexOf(presence);
662
+
663
+ if (presenceIndex !== -1) {
664
+ this.presences.splice(presenceIndex, 1);
665
+ }
666
+ }
667
+ }
668
+ } catch (error) {
669
+ throw new DyFM_Error({
670
+ ...this._getDefaultErrorSettings('removeSocketFromPresence', error),
671
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-RSO0`,
672
+ });
673
+ }
674
+ }
675
+
676
+ private async disconnectBaseTask(socket: SocketIO.Socket, issuer: string): Promise<void> {
677
+ try {
678
+ if (!(socket instanceof SocketIO.Socket)) {
679
+ /* throw new DyFM_Error({
680
+ ...this._getDefaultErrorSettings(
681
+ 'disconnectBaseTask',
682
+ new Error('Socket is not a SocketIO.Socket, type: ' + typeof socket),
683
+ ),
684
+ }); */
685
+ DyFM_Log.error(
686
+ `Socket is not a SocketIO.Socket, type: ${typeof socket}`,
687
+ socket
688
+ );
689
+ //TODO: remove all presences that have no socket
690
+ }
691
+
692
+ await this.removeSubscription(socket, issuer).catch(error => {
693
+ if (error instanceof DyFM_Error) {
694
+ error.logShort(
695
+ `Remove Subscription failed: "${this.params.name}" (${this.params.port})`
696
+ );
697
+ } else {
698
+ DyFM_Log.error(`Remove Subscription failed: "${this.params.name}" (${this.params.port})`, error);
699
+ }
700
+ });
701
+
702
+ DyFM_Log.info(`< x > socket(${this.params.name}) disconnected (${issuer})`);
703
+ } catch (error) {
704
+ throw new DyFM_Error({
705
+ ...this._getDefaultErrorSettings(
706
+ 'disconnectBaseTask',
707
+ error,
708
+ issuer
709
+ ),
710
+
711
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-DBT0`,
712
+ });
713
+ }
714
+ }
715
+
716
+ private async removeSubscription(socket: SocketIO.Socket, issuer?: string): Promise<void> {
717
+ try {
718
+ if (!this.presences.length) {
719
+ throw new DyFM_Error({
720
+ ...this._getDefaultErrorSettings(
721
+ 'removeSubscription',
722
+ new Error(`No presences found (${this.params.name})`),
723
+ issuer ?? 'unknown issuer'
724
+ ),
725
+
726
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-RS1`,
727
+ });
728
+ }
729
+
730
+ const activePresenceIndex: number = this.presences.findIndex(
731
+ (pres: DyNTS_SocketPresence) => pres.sockets.includes(socket)
732
+ );
733
+
734
+ if (activePresenceIndex === -1) {
735
+ throw new DyFM_Error({
736
+ ...this._getDefaultErrorSettings(
737
+ 'sendEventForId',
738
+ new Error(
739
+ `closing socket (${this.params.name}) does not match any in the activePresences`
740
+ ),
741
+ issuer ?? 'unknown issuer'
742
+ ),
743
+
744
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-RS2`,
745
+ });
746
+ }
747
+
748
+ const activePresence: DyNTS_SocketPresence = this.presences[activePresenceIndex];
749
+
750
+ if (issuer && activePresence.issuerLocalId !== issuer) {
751
+ throw new DyFM_Error({
752
+ ...this._getDefaultErrorSettings(
753
+ 'sendEventForId',
754
+ new Error(
755
+ `socket unsubscription for "${issuer}" and ` +
756
+ `"${activePresence.issuerLocalId}" does not match.`
757
+ ),
758
+ issuer
759
+ ),
760
+
761
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-RS3`,
762
+ });
763
+ }
764
+
765
+ const socketIndex = activePresence.sockets.findIndex((s: SocketIO.Socket) => s === socket);
766
+
767
+ if (socketIndex === -1) {
768
+ throw new DyFM_Error({
769
+ ...this._getDefaultErrorSettings(
770
+ 'sendEventForId',
771
+ new Error(
772
+ `closing socket (${this.params.name}) does not match any in the activePresences`
773
+ ),
774
+ activePresence.issuerLocalId
775
+ ),
776
+
777
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-RS4`,
778
+ });
779
+ }
780
+
781
+ activePresence.sockets.splice(socketIndex);
782
+
783
+ await DyFM_Array.asyncForEach(
784
+ this.incomingEvents.filter(
785
+ (event: DyFM_SocketEvent<any>) =>
786
+ event.eventKey === DyFM_SocketEvent_Key.unsubscribeSuccessful
787
+ ),
788
+ async (event: DyFM_SocketEvent<any>) => {
789
+ await event.executeEventTasks(null, issuer);
790
+ }
791
+ );
792
+
793
+ /* if (this.getSubscriptionCloseTasks) {
794
+ await DyFM_Array.asyncForEach(
795
+ this.getSubscriptionCloseTasks(),
796
+ async (task: DyFM_SocketEventTask<null>) => {
797
+ await task(null, issuer);
798
+ }
799
+ );
800
+ } */
801
+
802
+ if (activePresence.sockets.length === 0) {
803
+ this.presences.splice(activePresenceIndex);
804
+ }
805
+
806
+ socket.emit(DyFM_SocketEvent_Key.unsubscribeSuccessful, 'unsubscribe was successful');
807
+ socket.disconnect();
808
+ DyFM_Log.info(`<x==> socket (${this.params.name}) unsubscription successful (${issuer})`);
809
+ } catch (error) {
810
+ throw new DyFM_Error({
811
+ ...this._getDefaultErrorSettings(
812
+ 'sendEventForId',
813
+ error,
814
+ issuer ?? 'unknown issuer'
815
+ ),
816
+
817
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-RS0`,
818
+ message: `socket (${this.params.name}) Subscription Removal failed: "${this.params?.name}"`,
819
+ });
820
+ }
821
+ }
822
+
823
+ /* emitServerEvent(event: string, content: any): void {
824
+ try {
825
+ DyFM_Log.log(` <=-- emitting server socket(${this.params.name}) event: ${event}`);
826
+
827
+ this.openSocketServer.emit(event, content, error => {
828
+ DyFM_Log.error(`Emitting server event '${event}' failed!\nerror:`, error);
829
+ });
830
+ } catch (error) {
831
+ throw new DyFM_Error({
832
+ ...this._getDefaultErrorSettings(
833
+ 'emitEvent',
834
+ error
835
+ ),
836
+
837
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-500',
838
+ message: `socket(${this.params.name}) Event Emit (${event}) failed: ${this.params?.name}`,
839
+ });
840
+ }
841
+ } */
842
+
843
+ idIsSubscribed(id: string): boolean {
844
+ try {
845
+ return !!this.presences.find(
846
+ (presence: DyNTS_SocketPresence) => presence.issuerLocalId === id
847
+ );
848
+ } catch (error) {
849
+ throw new DyFM_Error({
850
+ ...this._getDefaultErrorSettings(
851
+ 'idIsSubscribed',
852
+ error
853
+ ),
854
+
855
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-IIS0`,
856
+ message: `socket (${this.params.name}) ID Subscription Check (${id}) failed`,
857
+ });
858
+ }
859
+ }
860
+
861
+ async emitError(presenceIssuerId: string, error: any, issuer: string): Promise<void> {
862
+ try {
863
+ await this.sendEventForId(presenceIssuerId, DyFM_SocketEvent_Key.error, error, issuer);
864
+ } catch (error) {
865
+ throw new DyFM_Error({
866
+ ...this._getDefaultErrorSettings(
867
+ 'emitError',
868
+ error,
869
+ presenceIssuerId
870
+ ),
871
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-EE0`,
872
+ message: `socket (${this.params.name}) Error Emit (id: ${presenceIssuerId}) failed`,
873
+ });
874
+ }
875
+ }
876
+
877
+ async sendEventForId(id: string, event: string, content: any, issuer: string): Promise<void> {
878
+ try {
879
+ if (!event) {
880
+ throw new DyFM_Error({
881
+ ...this._getDefaultErrorSettings(
882
+ 'sendEventForId',
883
+ new Error('No event was provided'),
884
+ content?.source
885
+ ),
886
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-SEFI1`,
887
+ });
888
+ }
889
+
890
+ if (!id) {
891
+ throw new DyFM_Error({
892
+ ...this._getDefaultErrorSettings(
893
+ 'sendEventForId',
894
+ new Error('No ID was provided'),
895
+ content?.source
896
+ ),
897
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-SEFI2`,
898
+ });
899
+ }
900
+
901
+ const presence: DyNTS_SocketPresence = this.presences.find(
902
+ (pres: DyNTS_SocketPresence) => pres.issuerLocalId === id
903
+ );
904
+
905
+ if (!presence) {
906
+ throw new DyFM_Error({
907
+ ...this._getDefaultErrorSettings(
908
+ 'sendEventForId',
909
+ new Error(`No active socket with this specific ID: "${id}"`),
910
+ content?.source
911
+ ),
912
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-SEFI3`,
913
+ });
914
+ }
915
+
916
+ presence.emitEvent(event, content, issuer);
917
+
918
+ if (DyNTS_global_settings.log_settings.socket_eventContent) {
919
+ DyFM_Log.success(
920
+ ` <--= emitted socket (${this.params.name}) event: "${event}", ` +
921
+ `\n presenceId: "${id}", sockets: ${presence.sockets.length}` +
922
+ `\n content:`, content
923
+ );
924
+ } else {
925
+ DyFM_Log.success(
926
+ ` <--= emitted socket (${this.params.name}) event: "${event}", ` +
927
+ `\n presenceId: ${id}, sockets: ${presence.sockets.length}`
928
+ );
929
+ }
930
+ } catch (error) {
931
+ try {
932
+ if (error?.flag?.includes(DyFM_errorFlag) && error?.additionalInfo?.inactiveSockets) {
933
+ const sockets: SocketIO.Socket[] = error.additionalInfo.inactiveSockets;
934
+
935
+ await DyFM_Array.asyncForEach(sockets, async (socket: SocketIO.Socket) => {
936
+ await this.removeSubscription(socket);
937
+ });
938
+
939
+ const presence: DyNTS_SocketPresence = this.presences.find(
940
+ (pres: DyNTS_SocketPresence) => pres.issuerLocalId === id
941
+ );
942
+
943
+ if (!presence) {
944
+ throw new DyFM_Error({
945
+ ...this._getDefaultErrorSettings(
946
+ 'sendEventForId',
947
+ new Error(`No active socket (${this.params.name}) with this specific ID: "${id}"`),
948
+ content?.source
949
+ ),
950
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-SEFI4`,
951
+ });
952
+ }
953
+ }
954
+ } catch (error) {
955
+ throw new DyFM_Error({
956
+ ...this._getDefaultErrorSettings('sendEventForId', error, content?.source),
957
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-SEFI5`,
958
+ message:
959
+ `Error handling of inactive sockets (${this.params.name}) failed!` +
960
+ `\n(Socket Event Emit for id (${id}, ${event}) failed)`,
961
+ });
962
+ }
963
+
964
+ throw new DyFM_Error({
965
+ ...this._getDefaultErrorSettings('sendEventForId', error, content?.source),
966
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-SEFI0`,
967
+ message: `socket (${this.params.name}) Event Emit for id (${id}, ${event}) failed`,
968
+ });
969
+ }
970
+ }
971
+
972
+ async broadcastEvent(event: string, content: any, issuer: string): Promise<void> {
973
+ try {
974
+ DyFM_Log.log(`<=-== broadcasting socket (${this.params.name}) event: "${event}"`);
975
+
976
+ this.presences.forEach((presence: DyNTS_SocketPresence) => {
977
+ presence.emitEvent(event, content, issuer);
978
+ });
979
+ } catch (error) {
980
+ if (DyNTS_global_settings.log_settings.detailedErrors) {
981
+ if (error instanceof DyFM_Error) {
982
+ error.logSimple(`socket (${this.params.name}) Event Broadcast (${event}) failed`);
983
+ } else {
984
+ DyFM_Log.error(`socket (${this.params.name}) Event Broadcast (${event}) failed`, error);
985
+ }
986
+ }
987
+
988
+ throw new DyFM_Error({
989
+ ...this._getDefaultErrorSettings('broadcastEvent', error),
990
+
991
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-BE0`,
992
+ message: `socket (${this.params.name}) Event Broadcast (${event}) failed`,
993
+ });
994
+ }
995
+ }
996
+
997
+ async sendError(error: DyFM_AnyError, issuer: string): Promise<void> {
998
+ try {
999
+ await this.sendEventForId(issuer, DyFM_SocketEvent_Key.error, error, issuer);
1000
+ } catch (error) {
1001
+ throw new DyFM_Error({
1002
+ ...this._getDefaultErrorSettings('sendError', error, issuer),
1003
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-SSS-SE0`,
1004
+ message: `socket (${this.params.name}) Error Send (${issuer}) failed`,
1005
+ });
1006
+ }
1007
+ }
1008
+
1009
+ private _getDefaultErrorSettings(
1010
+ fnName: string,
1011
+ error: DyFM_AnyError,
1012
+ issuer?: string
1013
+ ): DyFM_Error_Settings {
1014
+ return {
1015
+ status: (error as DyFM_Error)?.___status ?? 500,
1016
+ message: (error as Error)?.message ??
1017
+ (error as DyFM_Error)?._message ??
1018
+ `${fnName} was UNSUCCESSFUL (NTS)`,
1019
+ addECToUserMsg: !(error as DyFM_Error)?.__userMessage,
1020
+ userMessage: (error as DyFM_Error)?.__userMessage ?? this.defaultErrorUserMsg,
1021
+ issuer: issuer,
1022
+ issuerService: this.constructor?.name,
1023
+ error: error,
1024
+ };
1025
+ }
1026
+
1027
+ /**
1028
+ * You must setup params for the service in this function
1029
+ */
1030
+ protected abstract getServiceParams(): DyNTS_SocketServerService_Params;
1031
+
1032
+ /**
1033
+ * You must setup events and required services in this function
1034
+ */
1035
+ protected abstract getIncomingEvents(): DyFM_SocketEvent<any>[];
1036
+
1037
+ /**
1038
+ * You can setup tasks for the subscription event in this function
1039
+ */
1040
+ /* protected getSubscriptionCloseTasks?(): DyFM_SocketEventTask<null>[]; */
1041
+
1042
+ /**
1043
+ * You can setup preprocesses for the subscription event in this function
1044
+ */
1045
+ /* protected getSubscriptionPreProcesses?(): DyFM_SocketEventPreprocessTask[]; */
1046
+
1047
+ /**
1048
+ * You can setup tasks for the subscription event in this function
1049
+ * This will happen after the presence is created
1050
+ * If this throws an error, the socket will be closed
1051
+ */
1052
+ protected getSubscriptionTasks?(): DyFM_SocketEventTask<T_SubscriptionContent>[];
1053
+
1054
+ /**
1055
+ * You can setup tasks for the unsubscribe event in this function
1056
+ */
1057
+ /* protected getUnsubscribeTasks?(): DyFM_SocketEventTask<T_SubscriptionContent>[]; */
1058
+
1059
+ /**
1060
+ * You can setup preprocesses for the unsubscribe event in this function
1061
+ */
1062
+ /* protected getUnsubscribePreProcesses?(): DyFM_SocketEventPreprocessTask[]; */
1063
+
1064
+ /**
1065
+ * You can setup tasks for the error event in this function
1066
+ */
1067
+ protected errorHandling?: DyFM_SocketEventTask<T_ErrorContent>;
1068
+ }