@futdevpro/nts-dynamo 1.15.68 → 1.15.70

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 +2805 -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 +70 -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 +187 -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 +409 -393
  779. package/src/_modules/local-vector-search/_services/lvs-vector-pool.control-service.ts +224 -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,1747 +1,1747 @@
1
-
2
- import Mongoose = require('mongoose');
3
- import Express = require('express');
4
- /* import Mongoose from 'mongoose';
5
- import Express from 'express'; */
6
-
7
- import * as BodyParser from 'body-parser';
8
- import * as FileSystem from 'fs';
9
- import * as Http from 'http';
10
- import * as Https from 'https';
11
- import * as Path from 'path';
12
- import * as dotenv from 'dotenv'
13
-
14
- /* import { version } from '../../../package.json'; */
15
-
16
- import {
17
- DyFM_AnyError,
18
- DyFM_Array,
19
- DyFM_Async,
20
- DyFM_Error,
21
- DyFM_error_defaults,
22
- DyFM_Error_Settings,
23
- DyFM_ErrorLevel,
24
- DyFM_Log,
25
- megabyte,
26
- second
27
- } from '@futdevpro/fsm-dynamo';
28
-
29
- import { DyNTS_defaultFallbackCacheMaxAge } from '../../_collections/default-fallback-cache-max-age.const';
30
- import { DyNTS_defaultNotFoundPageHtml } from '../../_collections/default-not-found-page.const';
31
- import { DyNTS_global_settings } from '../../_collections/global-settings.const';
32
- import { startMongoReconnectGuard } from '../../_collections/mongo-reconnect-guard.util';
33
- import { DyNTS_RouteSecurity } from '../../_enums/route-security.enum';
34
- import { DyNTS_App_Params } from '../../_models/control-models/app-params.control-model';
35
- import {
36
- DyNTS_AppSystemControls
37
- } from '../../_models/control-models/app-system-controls.control-model';
38
- import {
39
- DyNTS_Endpoint_Params
40
- } from '../../_models/control-models/endpoint-params.control-model';
41
- import { DyNTS_Http_Settings } from '../../_models/control-models/http-settings.control-model';
42
- import {
43
- DyNTS_Certification_Settings
44
- } from '../../_models/interfaces/certification-settings.interface';
45
- import {
46
- DyNTS_GlobalService_Settings
47
- } from '../../_models/interfaces/global-service-settings.interface';
48
- import {
49
- DyNTS_StaticClient_Settings
50
- } from '../../_models/interfaces/static-client-settings.interface';
51
- import {
52
- DyNTS_Cors_Settings
53
- } from '../../_models/interfaces/cors-settings.interface';
54
- import { DyNTS_SingletonService } from '../base/singleton.service';
55
- import { DyNTS_GlobalService } from '../core/global.service';
56
- import { DyNTS_MemoryGuard } from '../core/memory-guard.service';
57
- import { DyNTS_RoutingModule } from '../route/routing-module.service';
58
- import { DyNTS_getStarRoute } from '../../_collections/star.controller';
59
-
60
- /**
61
- *
62
- * function MyDecorator(config: any) {
63
- return function (target: Function) {
64
- // attach metadata or modify target
65
- target.prototype.myMeta = config;
66
- };
67
- }
68
-
69
- @MyDecorator({ role: 'admin' })
70
- class User {
71
- printRole() {
72
- console.log((this as any).myMeta.role); // → "admin"
73
- }
74
- }
75
-
76
- */
77
-
78
- /**
79
- * This will be the MAIN service of our server project,
80
- * follow the types and type instructions while setting up your project
81
- *
82
- * In this service, there are abstract functions that you will need to implement,
83
- * where you need to set up the main params for your application.
84
- *
85
- * (after the example, you can find the list of services you can/should setup)
86
- *
87
- * @example
88
- * export class App extends DyNTS_AppExtended {
89
- *
90
- * ...
91
- *
92
- * // Setting up App params, and preparing project global settings
93
- * setupAppParams(): void {
94
- * this.params = new DyNTS_AppParams({
95
- * name: 'Warbots Server',
96
- * title: warbotsTitleLog,
97
- * version: version,
98
- * dbName: 'warbots',
99
- * });
100
- *
101
- * // dynamoNTS_GlobalSettings.logRequestsContent = false;
102
- * }
103
- *
104
- * ...
105
- *
106
- * // Setting up DBServices
107
- * setGlobalServiceCollection(): void {
108
- * DyNTS_GlobalService.setServices({
109
- * authService: AuthService.getInstance(),
110
- * emailServiceCollection: EmailServiceCollectionService.getInstance(),
111
- * dbModels: [
112
- * userModelParams,
113
- * userDataModelParams,
114
- * userOptionsModelParams,
115
- * userStatisticsModelParams,
116
- * userAchievementsModelParams,
117
- * userNotificationsModelParams,
118
- *
119
- * matchStatisticsModelParams,
120
- * matchDataModelParams,
121
-
122
- * DyFM_usageSession_dataParams,
123
- * DyFM_customData_dataParams,
124
- * ]
125
- * });
126
- * }
127
- *
128
- * ...
129
- *
130
- * // Setting up Routes
131
- * setupRoutingModules(): void {
132
- * this.httpPort = env.port;
133
-
134
- * this.routingModules = [
135
- * new DyNTS_RoutingModule({
136
- * route: '/user',
137
- * controllers: [
138
- * UserController.getInstance(),
139
- * UserDataController.getInstance(),
140
- * UserOptionsController.getInstance(),
141
- * UserStatisticsController.getInstance(),
142
- * UserAchievementsController.getInstance(),
143
- * UserNotificationsController.getInstance()
144
- * ]
145
- * }),
146
- * new DyNTS_RoutingModule({
147
- * route: '/match',
148
- * controllers: [
149
- * MatchController.getInstance(),
150
- * MatchDistributionController.getInstance(),
151
- * MatchStatisticsController.getInstance(),
152
- * ]
153
- * }),
154
- * new DyNTS_RoutingModule({
155
- * route: '/server',
156
- * controllers: [
157
- * ServerController.getInstance(),
158
- * ]
159
- * }),
160
-
161
- * getTestRoutingModule(),
162
- * getUsageRoutingModule()
163
- * ];
164
- * }
165
- * }
166
- *
167
- * //
168
- * // The Services available
169
- * //
170
- * // Authentication Service
171
- * // A commonly used basic service,
172
- * // which is necessary fur certain functions (such as registering call issuers)
173
- * //
174
- * // This will handle Authentication Token checking/refreshing,
175
- * // checking issuer's identifier and routeParams,
176
- * // handling JWT Token, or maybe with OAuth2 or other commonly used security procedures
177
- * //
178
- * // You can create one with this Dynamo Object:
179
- * //
180
- *
181
- * @example
182
- * // follow the instructions on the abstract class (DyNTS_AuthService)
183
- * export class AuthService extends DyNTS_AuthService {}
184
- *
185
- *
186
- *
187
- * //
188
- */
189
-
190
- /**
191
- * This will be the MAIN service of our server project,
192
- * follow the types and type instructions while setting up your project
193
- *
194
- * In this service, there are abstract functions that you will need to implement,
195
- * where you need to set up the main params for your application.
196
- *
197
- * (after the example, you can find the list of services you can/should setup)
198
- *
199
- * You need to setup the following functions:
200
- * ```ts
201
- * // this is where you set up the main params for your application
202
- * getAppParams(): DyNTS_AppParams
203
- *
204
- * // this is where you connect your main services
205
- * getGlobalServiceSettings(): DyNTS_GlobalService_Settings
206
- *
207
- * // this is where you set up your ports
208
- * getPorts(): DyNTS_PortSettings
209
- *
210
- * // this is where you set up your routes
211
- * getRoutingModules(): DyNTS_RoutingModule[]
212
- *
213
- *
214
- *
215
- * ```
216
- * optionally you can setup the following functions:
217
- * ```ts
218
- * // this is where you set up your certifications
219
- * getCertificationSettings(): DyNTS_CertificationSettings
220
- *
221
- * // this is where you set up additional root services
222
- * getRootServices(): DyNTS_SingletonService[]
223
- *
224
- * // this is where you set up your initial db entries
225
- * createEntries(): void
226
- *
227
- * // this is where you can define post setup processes
228
- * postProcess(): void
229
- *
230
- *
231
- *
232
- * ```
233
- *
234
- */
235
- export abstract class DyNTS_App extends DyNTS_SingletonService {
236
-
237
- protected systemControls: DyNTS_AppSystemControls = new DyNTS_AppSystemControls();
238
- get started(): boolean {
239
- return this.systemControls.app.started;
240
- }
241
- protected get superStarted(): boolean {
242
- return this.systemControls.app.started;
243
- }
244
- protected constructErrors: (Error | DyFM_Error)[] = [];
245
-
246
- /* removed since cant use version from package.json
247
- private readonly _ntsVersion: string = 'v01.07.18';
248
- protected get ntsVersion(): string {
249
- return this._ntsVersion;
250
- } */
251
-
252
- get serverName(): string {
253
- return this.params.name;
254
- }
255
-
256
- private _params: DyNTS_App_Params;
257
- protected get params(): DyNTS_App_Params {
258
- return this._params;
259
- }
260
-
261
- protected mongoose = Mongoose;
262
-
263
- private _security: DyNTS_RouteSecurity;
264
- protected get security(): DyNTS_RouteSecurity {
265
- return this._security;
266
- }
267
-
268
- protected _portSettings: DyNTS_Http_Settings = new DyNTS_Http_Settings();
269
- protected get portSettings(): DyNTS_Http_Settings {
270
- return this._portSettings;
271
- }
272
-
273
- private _cert?: DyNTS_Certification_Settings;
274
- protected get cert(): DyNTS_Certification_Settings {
275
- return this._cert;
276
- }
277
-
278
- protected openExpress: Express.Application;
279
- protected secureExpress: Express.Application;
280
- protected httpsServer: Https.Server;
281
- protected httpServer: Http.Server;
282
-
283
- private globalService: DyNTS_GlobalService;
284
- private _rootServices: DyNTS_SingletonService[] = [];
285
-
286
- private _routingModules: DyNTS_RoutingModule[] = [];
287
-
288
- protected readonly defaultReadyTimeout: number = 30 * second;
289
-
290
- override readonly defaultErrorUserMsg =
291
- `We encountered an unhandled Server Error, ` +
292
- `\nplease contact the responsible development team.` +
293
- `\n(Internal Server error)`;
294
-
295
- get logSetup(): boolean {
296
- return DyNTS_global_settings.log_settings.setup;
297
- }
298
- get deepLog(): boolean {
299
- return DyNTS_global_settings.log_settings.deep;
300
- }
301
- get fnLogs(): boolean {
302
- return DyNTS_global_settings.log_settings.functions;
303
- }
304
- debugLog: boolean = DyNTS_global_settings.log_settings.server_debug;
305
-
306
- constructor(/* extended?: boolean */){
307
- super();
308
-
309
- /* dotenv.config() */
310
-
311
- process.on(
312
- 'unhandledRejection',
313
- (reason_theError: object, p_passWhatIsThis_maybeThePromise: any): void => {
314
- if (reason_theError instanceof DyFM_Error) {
315
- reason_theError.logSimple('Unhandled Rejection');
316
- } else {
317
- DyFM_Log.H_error(
318
- 'Unhandled Rejection:', (p_passWhatIsThis_maybeThePromise as Promise<any>)?.toString(),
319
- '\n Rejection reason:', (reason_theError as Error)?.stack?.split('at')?.[0],
320
- /* '\n ErrorCode:', (reason as any)?.code, */
321
- '\n\n Stack:',
322
- (reason_theError as Error)?.stack?.replaceAll?.('\n at', '\n at'),
323
- );
324
- }
325
-
326
- try {
327
- DyNTS_GlobalService.globalErrorHandler?.(
328
- new DyFM_Error({
329
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-BASE-UR`,
330
- message:
331
- `Unhandled Rejection!: "${(reason_theError as Error)?.stack?.split('at')?.[0]}"`,
332
- userMessage: this.defaultErrorUserMsg,
333
- addECToUserMsg: true,
334
- error: reason_theError as Error,
335
- additionalContent: {
336
- reason: reason_theError,
337
- rejectedPromise: p_passWhatIsThis_maybeThePromise,
338
- },
339
- systemVersion: DyNTS_global_settings.systemVersion,
340
- level: DyFM_ErrorLevel.critical,
341
- })
342
- );
343
- } catch (error) {
344
- DyFM_Log.error('globalErrorHandler (MULTILEVEL) ERROR:', error);
345
- }
346
- }
347
- );
348
-
349
- this.asyncConstruct(/* extended */).catch((error: any): void => {
350
- if (error instanceof DyFM_Error) {
351
- if (error.additionalContent?.constructErrors?.length) {
352
- error.additionalContent.constructErrors.forEach((errorItem: DyFM_Error): void => {
353
- DyFM_Error.logSimple('(constructor asyncConstruct.catch) error:', errorItem);
354
- /* if (errorItem instanceof DyFM_Error) {
355
- errorItem.logSimple(`(constructor asyncConstruct.catch) error:\n`);
356
- } else {
357
- DyFM_Log.H_warn(
358
- '(constructor asyncConstruct.catch) additional error content:\n',
359
- errorItem
360
- );
361
- } */
362
- });
363
- } else {
364
- DyFM_Log.H_warn(
365
- '(constructor asyncConstruct.catch) additional error content:\n',
366
- error?.additionalContent
367
- );
368
- }
369
- }
370
-
371
- DyFM_Error.logSimple('(constructor asyncConstruct.catch) error:', error);
372
- /* if (
373
- !DyNTS_global_settings.log_settings.highDetailedLogs &&
374
- (error instanceof DyFM_Error)
375
- ) {
376
- error.logSimple(
377
- `Application: "${this.params?.name}" start failed. (constructor asyncConstruct.catch)` +
378
- '\n all error messages (from this stack):\n\n"' +
379
- error._messages.join('"\n\n"') + '"\n\n'
380
- );
381
- } else if (error instanceof DyFM_Error) {
382
- DyFM_Log.H_error(
383
- `Application: "${this.params?.name}" start failed. (constructor asyncConstruct.catch)`,
384
- `\n ERROR:`, error
385
- );
386
- } */
387
-
388
- const message: string =
389
- (error as DyFM_Error)?.additionalContent?.constructErrors?.flatMap(
390
- (errorItem: DyFM_Error): string[] => {
391
- return errorItem?._messages ?? [];
392
- }
393
- )?.join?.('\n') ??
394
- (error as DyFM_Error)?.errors?.flatMap(
395
- (errorItem: DyFM_AnyError): string[] =>
396
- (errorItem as DyFM_Error)?._messages ?? [ (errorItem as Error)?.message ]
397
- )?.join?.('\n') ??
398
- error?.message ??
399
- 'UNKNOWN';
400
-
401
- DyFM_Log.testError('Application start failed:\n', message);
402
-
403
- process.exit(1);
404
- });
405
- }
406
-
407
- protected async asyncConstruct(extended?: boolean): Promise<void> {
408
- if (this.fnLogs && this.deepLog) DyFM_Log.log('\nfn:. asyncConstruct');
409
-
410
- try {
411
- this.systemControls.app.init = true;
412
- this._params = this.getAppParams();
413
- DyFM_Log.log(
414
- `\n\n\n\n\n\n\n\n\n\n` +
415
- `Starting ${this._params?.name}... ` +
416
- /* `v${version}` + */
417
- `\n\n\n\n\n\n\n\n\n\n`
418
- );
419
-
420
- if (!this._params) {
421
- throw new Error('getAppParams() must return a DyNTS_AppParams object!');
422
- }
423
-
424
- if (this.params.systemShortCodeName) {
425
- DyNTS_global_settings.systemShortCodeName = this.params.systemShortCodeName;
426
- }
427
-
428
- if (this.params.systemName) {
429
- DyNTS_global_settings.systemName = this.params.systemName;
430
- DyFM_error_defaults.issuerSystem = this.params.systemName;
431
- }
432
-
433
- if (this.params.version) {
434
- DyNTS_global_settings.systemVersion = this.params.version;
435
- DyFM_error_defaults.systemVersion = this.params.version;
436
- }
437
-
438
- process.stdout.write(
439
- String.fromCharCode(27) + ']0;' +
440
- this._params?.name +
441
- String.fromCharCode(7)
442
- );
443
-
444
- DyFM_error_defaults.issuerSystem = this._params.systemName;
445
-
446
- this.overrideDynamoNTSGlobalSettings?.();
447
-
448
- if (DyNTS_global_settings.log_settings.setup) {
449
- DyFM_Log.S_info(`env settings;\n`, {
450
- systemName: DyNTS_global_settings.systemName,
451
- systemShortCodeName: DyNTS_global_settings.systemShortCodeName,
452
- systemVersion: DyNTS_global_settings.systemVersion,
453
- environment: DyNTS_global_settings.env_settings.environment,
454
- /* log_settings: DyNTS_global_settings.log_settings,
455
- env_settings: DyNTS_global_settings.env_settings, */
456
- });
457
- }
458
-
459
- this.globalService = DyNTS_GlobalService.getInstance();
460
- await DyNTS_GlobalService.setServices(this.getGlobalServiceCollection());
461
- DyNTS_GlobalService.setParams(this.params);
462
-
463
- if (this.getPortSettings) {
464
- this._portSettings = this.getPortSettings();
465
- }
466
-
467
- if (this.getCertificationSettings) {
468
- this._cert = this.getCertificationSettings();
469
- }
470
-
471
- if (this.getApiBasePath) {
472
- DyNTS_global_settings.baseUrl = this.getApiBasePath();
473
- }
474
-
475
- if (this.getRoutingModules) {
476
- this._routingModules = this.getRoutingModules();
477
-
478
- // ezt egyelőre csak tesztelem, nem kerül be
479
- /* if (
480
- !DyNTS_global_settings.dontCreateDefaultRoute &&
481
- !this._routingModules.some((routingModule: DyNTS_RoutingModule): boolean => routingModule.route === '/*')
482
- ) {
483
- this._routingModules.push(
484
- DyNTS_getStarRoute()
485
- );
486
- } */
487
- }
488
-
489
- if (this._params.dbUri) {
490
- await this.startDB();
491
-
492
- // createEntries csak akkor fut, ha a DB tényleg fel-jött.
493
- // Ha a startDB jelezte a hibát, de továbbment, akkor a started flag false marad,
494
- // és nem próbálunk meg írni egy nem létező kapcsolatra.
495
- if (this.createEntries && this.systemControls.mongoose.started) {
496
- await this.createEntries();
497
- }
498
- } else {
499
- DyFM_Log.log(
500
- `\nNo database connection created.`,
501
- );
502
- }
503
-
504
- if (this._routingModules?.length) {
505
- if (this.logSetup) DyFM_Log.log('\nsetting up express routes...');
506
-
507
- this.setSecurity();
508
-
509
- await this.initExpresses();
510
- await this.startExpresses();
511
-
512
- if (this._security !== DyNTS_RouteSecurity.secure) {
513
- await this.mountOpenRoutes();
514
- }
515
-
516
- if (this._security !== DyNTS_RouteSecurity.open && this._cert) {
517
- await this.mountSecureRoutes();
518
- }
519
-
520
- // Generikus, auth-agnosztikus extension-point: custom middleware az API
521
- // route-ok UTÁN, de a SPA static catch-all (mountStaticClient) ELŐTT.
522
- await this.mountCustomMiddleware();
523
-
524
- await this.mountStaticClient();
525
-
526
- if (this.logSetup) {
527
- DyFM_Log.log(`\nRoutes mounted.... server using security: ${this._security}`);
528
- }
529
- } else {
530
- DyFM_Log.warn(
531
- `\nNo routes mounted!`,
532
- );
533
- }
534
-
535
- if (this.getRootServices) {
536
- this._rootServices = await this.getRootServices();
537
- }
538
-
539
- if (this.postProcess) {
540
- await this.postProcess().catch((error: any): void => {
541
- DyFM_Error.logSimple(`"${this._params.name}" postProcess failed:`, error);
542
- DyNTS_GlobalService.globalErrorHandler?.(error);
543
- });
544
- }
545
-
546
- // FR-193 — bedrock OOM korai-figyelmeztetés: feltelepítjük a heap-watchdogot, ha
547
- // engedélyezve (DyNTS_global_settings.memoryGuard.enabled, default true). Biztonságos:
548
- // a guard egy könnyű setInterval, ami SOHA nem dob; csak near-OOM küszöböknél hagy
549
- // tartós nyomot az error-sinkbe, mielőtt a fatal heap-OOM megölné a process-t.
550
- try {
551
- if (DyNTS_global_settings.memoryGuard?.enabled) {
552
- DyNTS_MemoryGuard.getInstance().install();
553
- }
554
- } catch (memoryGuardError: unknown) {
555
- DyFM_Log.warn('[DyNTS_MemoryGuard] auto-install skipped (non-fatal):', memoryGuardError);
556
- }
557
-
558
- if (!extended) {
559
- await this.ready();
560
-
561
- if (this.params.title) {
562
- DyFM_Log.success(this.params.title);
563
- }
564
- DyFM_Log.info(`Version: ${this.params.version}`);
565
- /* DyFM_Log.info(`NTS Version: ${this.ntsVersion}`); */
566
- DyFM_Log.H_success(`${this.params.name} started successfully.`);
567
- }
568
- } catch (error) {
569
- this.constructErrors.push(error);
570
-
571
- if (this.deepLog) {
572
- if (DyNTS_global_settings.log_settings.highDetailedLogs) {
573
- DyFM_Log.H_error(
574
- `"${this._params.name}" start failed (in asyncConstruct (highDetailedLog)). `,
575
- `\n\n construct ERRORS:`, this.constructErrors,
576
- '\n\nlast error:', error
577
- );
578
- } else {
579
- DyFM_Log.H_error(
580
- `"${this._params.name}" start failed (in asyncConstruct). `,
581
- `\n\n construct ERRORS:`, this.getSimplifiedConstructErrors(),
582
- '\n\nlast error:', error instanceof DyFM_Error ? error.getErrorSimplified() : error
583
- );
584
- }
585
- }
586
-
587
- throw new DyFM_Error({
588
- ...this._getDefaultErrorSettings('asyncConstruct', error),
589
-
590
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-001`,
591
- additionalContent: {
592
- constructErrors: this.constructErrors,
593
- systemControls: this.systemControls,
594
- systemReadies: {
595
- app: this.systemControls.app.getIsReady(),
596
- mongoose: this.systemControls.mongoose.getIsReady(),
597
- httpServer: this.systemControls.httpServer.getIsReady(),
598
- httpsServer: this.systemControls.httpsServer.getIsReady(),
599
- },
600
- },
601
- });
602
- }
603
- }
604
-
605
- async ready(timeout: number = this.defaultReadyTimeout): Promise<void> {
606
- try {
607
- if (this.fnLogs) DyFM_Log.log('\nfn:. ready');
608
-
609
- await DyFM_Async.delay(100);
610
-
611
- let ready: boolean = false;
612
- const start: number = +new Date();
613
-
614
- if (this.constructErrors.length) {
615
- if (this.deepLog) {
616
- if (DyNTS_global_settings.log_settings.highDetailedLogs) {
617
- DyFM_Log.H_error(
618
- `"${this._params.name}" start failed. (ready; constructErrors check 1)`,
619
- `\n construct ERRORS:`, this.constructErrors
620
- );
621
- } else {
622
- DyFM_Log.H_error(
623
- `"${this._params.name}" start failed. (ready; constructErrors check 1)`,
624
- `\n construct ERRORS:`, this.getSimplifiedConstructErrors(),
625
- );
626
- }
627
- }
628
-
629
- throw new DyFM_Error({
630
- ...this._getDefaultErrorSettings(
631
- 'ready',
632
- new Error(`"${this._params.name}" start failed.`)
633
- ),
634
-
635
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-R01`,
636
- additionalContent:
637
- this.constructErrors.length === 1 ?
638
- { error: this.constructErrors[0] } :
639
- { errors: this.constructErrors },
640
- });
641
- }
642
-
643
- while (!ready && +new Date() - start < timeout) {
644
- if (this.systemControls.app.init) {
645
- ready = (
646
- this.systemControls.mongoose.getIsReady() &&
647
- this.systemControls.httpServer.getIsReady() &&
648
- this.systemControls.httpsServer.getIsReady()
649
- );
650
- } else {
651
- DyFM_Log.error(`"${this._params.name}" APP NOT INITIALIZED while trying to get ready.`);
652
- }
653
-
654
- if (!ready) {
655
- await DyFM_Async.wait(100);
656
- }
657
- }
658
-
659
- if (timeout < +new Date() - start) {
660
- if (this.deepLog) {
661
- if (DyNTS_global_settings.log_settings.highDetailedLogs) {
662
- DyFM_Log.H_error(
663
- `"${this._params.name}" start failed. (ready; TIMEOUT check)`,
664
- `\n construct ERRORS:`, this.constructErrors
665
- );
666
- } else {
667
- DyFM_Log.H_error(
668
- `"${this._params.name}" start failed. (ready; TIMEOUT check)`,
669
- `\n construct ERRORS:`, this.getSimplifiedConstructErrors(),
670
- );
671
- }
672
- }
673
-
674
- throw new DyFM_Error({
675
- ...this._getDefaultErrorSettings(
676
- 'ready',
677
- new Error(`"${this._params.name}" start failed. TIMEOUT`)
678
- ),
679
-
680
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-R02`,
681
- additionalContent: {
682
- constructErrors: this.constructErrors,
683
- systemControls: this.systemControls,
684
- systemReadies: {
685
- mongoose: this.systemControls.mongoose.getIsReady(),
686
- httpServer: this.systemControls.httpServer.getIsReady(),
687
- httpsServer: this.systemControls.httpsServer.getIsReady(),
688
- },
689
- },
690
- });
691
- }
692
-
693
- if (this.constructErrors.length) {
694
- if (this.deepLog) {
695
- if (DyNTS_global_settings.log_settings.highDetailedLogs) {
696
- DyFM_Log.H_error(
697
- `"${this._params.name}" start failed. (ready; constructErrors check 2)`,
698
- `\n construct ERRORS:`, this.constructErrors
699
- );
700
- } else {
701
- DyFM_Log.H_error(
702
- `"${this._params.name}" start failed. (ready; constructErrors check 2)`,
703
- `\n construct ERRORS:`, this.getSimplifiedConstructErrors(),
704
- );
705
- }
706
- }
707
-
708
- throw new DyFM_Error({
709
- ...this._getDefaultErrorSettings(
710
- 'ready',
711
- new Error(`"${this._params.name}" start failed.`)
712
- ),
713
-
714
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-R03`,
715
- additionalContent: this.constructErrors,
716
- });
717
- }
718
-
719
- if (ready) {
720
- this.systemControls.app.started = true;
721
-
722
- if (this.fnLogs && this.deepLog) DyFM_Log.log('\nfn:. ready: return');
723
-
724
- return;
725
- }
726
-
727
- this.systemControls.app.started = false;
728
-
729
- let msg: string = `"${this._params.name}" start failed. UNKNOWN`;
730
-
731
- if (this.systemControls.mongoose.init && !this.systemControls.mongoose.started) {
732
- msg += `\nMongoose start failed.`;
733
- }
734
-
735
- if (this.systemControls.httpServer.init && !this.systemControls.httpServer.started) {
736
- msg += `\nHTTP Server start failed.`;
737
- }
738
-
739
- if (this.systemControls.httpsServer.init && !this.systemControls.httpsServer.started) {
740
- msg += `\nHTTPS Server start failed.`;
741
- }
742
-
743
- DyFM_Log.error(msg, this.constructErrors);
744
-
745
- throw new DyFM_Error({
746
- ...this._getDefaultErrorSettings('ready', new Error(msg)),
747
-
748
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-R04`,
749
- additionalContent: {
750
- constructErrors: this.constructErrors,
751
- systemControls: this.systemControls,
752
- systemReadies: {
753
- app: this.systemControls.app.getIsReady(),
754
- mongoose: this.systemControls.mongoose.getIsReady(),
755
- httpServer: this.systemControls.httpServer.getIsReady(),
756
- httpsServer: this.systemControls.httpsServer.getIsReady(),
757
- },
758
- },
759
- error: this.constructErrors?.[0] ?? new Error(),
760
- });
761
- } catch (error) {
762
- throw new DyFM_Error({
763
- ...this._getDefaultErrorSettings('ready', error),
764
-
765
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-READY0`,
766
- });
767
- }
768
- }
769
-
770
- protected getSimplifiedConstructErrors(): string[] {
771
- return this.constructErrors.map((error: any): any => {
772
- if (error instanceof DyFM_Error) {
773
- return error.getErrorSimplified();
774
- } else {
775
- return error;
776
- }
777
- });
778
- }
779
-
780
- async stop(dontLog?: boolean): Promise<void> {
781
- try {
782
- DyFM_Log.info('\nstopping server...\n');
783
-
784
- await this.ready();
785
-
786
- if (this.started) {
787
-
788
- if (this.systemControls.mongoose.init) {
789
- DyFM_Log.info(`\nstopping Mongoose....`);
790
-
791
- let tryCount: number = 0;
792
-
793
- while (
794
- !this.systemControls.mongoose.started &&
795
- !this.constructErrors.length &&
796
- tryCount++ < 10
797
- ) {
798
- DyFM_Log.warn(`Mongoose not even started yet....`);
799
- await DyFM_Async.wait(second);
800
- }
801
- this.systemControls.mongoose.started = false;
802
-
803
- if (this.mongoose) {
804
- await DyFM_Array.asyncForEach(
805
- Object.keys(this.mongoose.models),
806
- async (modelName): Promise<void> => {
807
- this.mongoose.deleteModel(modelName);
808
- }
809
- );
810
-
811
- const disconnect: Promise<void> = new Promise((resolve): void => {
812
- this.mongoose.connection.on('disconnecting', (): void => {
813
- resolve();
814
- });
815
- });
816
-
817
- await this.mongoose.disconnect();
818
- await this.mongoose.connection.close();
819
- await disconnect;
820
-
821
- this.mongoose.connection.removeAllListeners();
822
-
823
- while (
824
- this.mongoose.connection.readyState !== 0 &&
825
- !this.constructErrors.length
826
- ) {
827
- DyFM_Log.warn(`\nMongoose still not disconnected....`);
828
- await DyFM_Async.wait(second);
829
- }
830
- } else {
831
- DyFM_Log.error(`\nMongoose not found.`);
832
- }
833
- this.systemControls.mongoose.init = false;
834
- }
835
-
836
- if (this.systemControls.httpServer.init) {
837
- this.systemControls.httpServer.started = false;
838
-
839
- if (this.httpServer) {
840
- await new Promise((resolve): void => {
841
- this.httpServer.close(resolve);
842
- });
843
- } else {
844
- DyFM_Log.error(`\nHTTP Server not found.`);
845
- }
846
- this.systemControls.httpServer.init = false;
847
- }
848
-
849
- if (this.systemControls.httpsServer.init) {
850
- this.systemControls.httpsServer.started = false;
851
-
852
- if (this.httpsServer) {
853
- await new Promise((resolve): void => {
854
- this.httpsServer.close(resolve);
855
- });
856
- } else {
857
- DyFM_Log.error(`\nHTTPS Server not found.`);
858
- }
859
- this.systemControls.httpsServer.init = false;
860
- }
861
-
862
- await DyFM_Async.wait(second);
863
-
864
- if (!dontLog) {
865
- DyFM_Log.H_log(`"${this._params.name}" stopped successfully.`);
866
- }
867
- }
868
- } catch (error) {
869
- throw new DyFM_Error({
870
- ...this._getDefaultErrorSettings('stop', error),
871
-
872
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-STOP0`,
873
- });
874
- }
875
- }
876
-
877
- /**
878
- *
879
- */
880
- private async startDB(): Promise<void> {
881
- if (this.fnLogs && this.deepLog) DyFM_Log.log('\nfn:. startDB');
882
- else if (this.logSetup) DyFM_Log.log('\nstarting DB connection...');
883
-
884
- if (!this._params.dbUri) {
885
- throw new DyFM_Error({
886
- ...this._getDefaultErrorSettings('startDB', new Error('DB URI is not set.')),
887
-
888
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-SDB0`,
889
- });
890
- }
891
-
892
- if (!this._params.dbOptions) {
893
- throw new DyFM_Error({
894
- ...this._getDefaultErrorSettings('startDB', new Error('DB OPTIONS are not set.')),
895
-
896
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-SDB0`,
897
- });
898
- }
899
-
900
- if (this.systemControls.mongoose.init || this.systemControls.mongoose.started) {
901
- throw new DyFM_Error({
902
- ...this._getDefaultErrorSettings('startDB', new Error('Mongoose is already initialized.')),
903
-
904
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-SDB0`,
905
- });
906
- }
907
-
908
- try {
909
- await new Promise<void>(
910
- (resolve, reject): void => {
911
- this.systemControls.mongoose.init = true;
912
-
913
- this.mongoose.connection
914
- .once('open', (): void => {
915
- this.systemControls.mongoose.started = true;
916
- DyFM_Log.success(`\nConnected to MongoDB (${this._params.dbUri})\n`);
917
-
918
- resolve();
919
- })
920
- .on('error', (error): void => {
921
- if (!this.systemControls.mongoose.started) {
922
- // Initial DB-csatlakozás sikertelen:
923
- // jelezzük a hibát (log + globalErrorHandler), de NEM szakítjuk meg az
924
- // App startup-ot (nincs constructErrors push, nincs reject).
925
- // A mongoose.init-et resetteljük, hogy a ready() ne várjon a DB-re.
926
- // Ha a mongoose később mégis tudna csatlakozni, az 'open' event
927
- // beállítja a started flag-et, így a runtime DB-műveletek elindulnak.
928
- this.systemControls.mongoose.init = false;
929
-
930
- const d_error: DyFM_Error = new DyFM_Error({
931
- ...this._getDefaultErrorSettings('startDB', error),
932
-
933
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-SDB1`,
934
- message: `Unable to connect to MongoDB server (${this._params.dbUri}), ` +
935
- `ERROR: ${error}`,
936
- level: DyFM_ErrorLevel.serious,
937
- });
938
-
939
- DyFM_Log.H_error(
940
- `\nUnable to connect to MongoDB server (${this._params.dbUri}).` +
941
- `\nServer will continue WITHOUT DB connection.` +
942
- `\nDB-using endpoints will fail at runtime until connection recovers.`
943
- );
944
-
945
- if (this.debugLog) DyFM_Log.S_error(
946
- `\nMongoDB connect ERROR: `,
947
- error
948
- );
949
-
950
- DyNTS_GlobalService.globalErrorHandler?.(d_error);
951
-
952
- resolve();
953
-
954
- } else {
955
- if (this.debugLog) DyFM_Log.error('\nMongoDB ERROR: ', error);
956
-
957
- const d_error: DyFM_Error = new DyFM_Error({
958
- ...this._getDefaultErrorSettings('mongoose.connection.on(error)', error),
959
-
960
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-SDB2`,
961
- message: `MongoDB ERROR: ${error}`,
962
- level: DyFM_ErrorLevel.critical,
963
- });
964
-
965
- DyNTS_GlobalService.globalErrorHandler?.(d_error);
966
- }
967
- });
968
-
969
- try {
970
- this.mongoose.connect(
971
- this._params.dbUri,
972
- this._params.dbOptions
973
- /* {
974
- directConnection: true,
975
- } */
976
- );
977
- } catch (error) {
978
- throw new DyFM_Error({
979
- ...this._getDefaultErrorSettings('startDB', error),
980
-
981
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-SDB3`,
982
- });
983
- }
984
- }
985
- );
986
- } catch (error) {
987
- throw new DyFM_Error({
988
- ...this._getDefaultErrorSettings('startDB', error),
989
-
990
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-SDB0`,
991
- });
992
- }
993
-
994
- // 2026-06-20 — Mongo reconnect-guard. A MongoDB-driver a hostnevet connect-kor EGYSZER
995
- // resolválja + cache-eli az IP-t; ha a Mongo-konténert recreate-elik (új docker-network IP),
996
- // a driver a HALOTT IP-n ragad → ECONNREFUSED + buffering-timeout, és a service magától SOHA
997
- // nem áll vissza. A guard sustained-disconnect (readyState !== 1) esetén — a driver saját
998
- // grace-e UTÁN — TELJES disconnect()+connect()-et csinál → ÚJ MongoClient → ÚJ DNS-resolve →
999
- // új IP → reconnect. Best-effort, always-on, healthy connection-t (===1) SOHA nem bánt; csak
1000
- // konténer-IP-frissítés, nem ír adatot. Lásd: mongo-reconnect-guard.util.ts.
1001
- try {
1002
- startMongoReconnectGuard({
1003
- getReadyState: (): number => this.mongoose.connection.readyState,
1004
- reconnect: async (): Promise<void> => {
1005
- await this.mongoose.disconnect().catch((): void => undefined);
1006
- await this.mongoose.connect(this._params.dbUri, this._params.dbOptions);
1007
- },
1008
- log: (msg: string): void => DyFM_Log.warn(msg),
1009
- });
1010
- } catch (guardErr) {
1011
- DyFM_Log.warn(`[mongo-reconnect-guard] failed to start (non-fatal): ${guardErr instanceof Error ? guardErr.message : String(guardErr)}`);
1012
- }
1013
- }
1014
-
1015
- /**
1016
- *
1017
- */
1018
- private async initExpresses(): Promise<void> {
1019
- if (this.fnLogs && this.deepLog) DyFM_Log.log('\nfn:. initExpresses');
1020
-
1021
- try {
1022
- if (this._security && this._security !== DyNTS_RouteSecurity.secure) {
1023
- if (this._portSettings.httpPort === undefined || this._portSettings.httpPort === null) {
1024
- let errorMsg: string =
1025
- `\nYou have open routes, but httpPort is not set!` +
1026
- `\nThere are ${this._routingModules.filter(
1027
- m => m.security != DyNTS_RouteSecurity.secure
1028
- ).length} open/both routes` +
1029
- `\nroot security: ${this._security}` +
1030
- `\nset httpPort in DynamoBEServer - setupRoutingModules() to enable secure routes.`;
1031
-
1032
- errorMsg += '\n\nThe routes setted to use open server:';
1033
- this._routingModules.forEach((module: DyNTS_RoutingModule): void => {
1034
- if (module.security != DyNTS_RouteSecurity.secure) {
1035
- errorMsg += `\n ${module.route} (security: ${module.security})`;
1036
- errorMsg += `\n subroutes using open sever:`;
1037
- module.endpoints.forEach((endpoint: DyNTS_Endpoint_Params): void => {
1038
- if (endpoint.security != DyNTS_RouteSecurity.secure) {
1039
- errorMsg += `\n ${endpoint.endpoint} (security: ${endpoint.security})`;
1040
- }
1041
- });
1042
- }
1043
- });
1044
-
1045
- const error = new Error(`Open routes cannot be established!\n${errorMsg}`);
1046
- const errorStack: string[] = error.stack.split('\n');
1047
-
1048
- errorStack.splice(1, 2);
1049
- error.stack = errorStack.join('\n');
1050
-
1051
- DyFM_Log.error(errorMsg);
1052
-
1053
- throw error;
1054
- }
1055
-
1056
- await this.initOpenExpress();
1057
- }
1058
-
1059
- if (this._security && this._security !== DyNTS_RouteSecurity.open) {
1060
- if (!this._cert || !this._portSettings.httpsPort) {
1061
- let errorMsg: string =
1062
- `\nYou have secure routes, but the certification paths or httpsPort are not set!` +
1063
- `\nThere are ${this._routingModules.filter(
1064
- m => m.security && m.security !== DyNTS_RouteSecurity.open
1065
- ).length} secure routes` +
1066
- `\nroot security: ${this._security}` +
1067
- `\nset...` +
1068
- `\n(missing exact howto...)` +
1069
- /* `\n httpsPort and` +
1070
- `\n cert: {` +
1071
- `\n keyPath: FileSystem.PathLike,` +
1072
- `\n certPath: FileSystem.PathLike,` +
1073
- `\n }` + */
1074
- `\nin DynamoBEServer - getRoutingModules() to enable secure routes.`;
1075
-
1076
- errorMsg += '\n\nThe routes setted to use secure server:';
1077
- this._routingModules.forEach((module: DyNTS_RoutingModule): void => {
1078
- if (module.security && module.security !== DyNTS_RouteSecurity.open) {
1079
- errorMsg += `\n ${module.route} (security: ${module.security})`;
1080
- errorMsg += `\n location: ${module.stackLocation}`;
1081
- errorMsg += `\n subroutes using secure sever:`;
1082
- module.endpoints.forEach((endpoint: DyNTS_Endpoint_Params): void => {
1083
- if (endpoint.security && endpoint.security !== DyNTS_RouteSecurity.open) {
1084
- errorMsg += `\n ${endpoint.endpoint} (security: ${endpoint.security})`;
1085
- errorMsg += `\n location: ${endpoint.stackLocation}`;
1086
- }
1087
- });
1088
- }
1089
- });
1090
-
1091
- const error = new Error(`Secure routes cannot be established!\n${errorMsg}`);
1092
- const errorStack: string[] = error.stack.split('\n');
1093
-
1094
- errorStack.splice(1, 2);
1095
- error.stack = errorStack.join('\n');
1096
-
1097
- DyFM_Log.error(errorMsg);
1098
-
1099
- throw error;
1100
- }
1101
-
1102
- await this.initSecureExpress();
1103
- }
1104
- } catch (error) {
1105
- throw new DyFM_Error({
1106
- ...this._getDefaultErrorSettings('initExpresses', error),
1107
-
1108
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-IE0`,
1109
- });
1110
- }
1111
- }
1112
-
1113
- /**
1114
- *
1115
- */
1116
- protected async initOpenExpress(): Promise<void> {
1117
- if (this.fnLogs) DyFM_Log.log('\nfn:. initOpenExpress');
1118
- this.openExpress = Express();
1119
- this.openExpress.set('maxHeaderSize', 10 * megabyte); // 1024 * 1024 * 10, // 10MB
1120
- this.openExpress.use(BodyParser.urlencoded(this._portSettings.httpUrlencoded));
1121
- this.openExpress.use(BodyParser.json(this._portSettings.httpJson));
1122
- // FR-041 — CORS allowlist enforcement. No-op if getCorsSettings() is not overridden.
1123
- this.mountCors(this.openExpress);
1124
- }
1125
-
1126
- /**
1127
- *
1128
- */
1129
- protected async initSecureExpress(): Promise<void> {
1130
- if (this.fnLogs) DyFM_Log.log('\nfn:. initSecureExpress');
1131
- this.secureExpress = Express();
1132
- this.secureExpress.use(BodyParser.urlencoded(this._portSettings.httpsUrlencoded));
1133
- this.secureExpress.use(BodyParser.json(this._portSettings.httpsJson));
1134
- // FR-041 — CORS allowlist enforcement (same as open express).
1135
- this.mountCors(this.secureExpress);
1136
-
1137
- const options = {
1138
- key: FileSystem.readFileSync(this._cert.keyPath),
1139
- cert: FileSystem.readFileSync(this._cert.certPath),
1140
- maxHeaderSize: 10 * megabyte, // 1024 * 1024 * 10, // 10MB
1141
- };
1142
-
1143
- this.httpsServer = Https.createServer(options, this.secureExpress);
1144
- }
1145
-
1146
- /**
1147
- *
1148
- */
1149
- private async startExpresses(): Promise<void> {
1150
- if (this.fnLogs && this.deepLog) DyFM_Log.log('\nfn:. startExpresses');
1151
-
1152
- try {
1153
- if (this._security && this._security !== DyNTS_RouteSecurity.open) {
1154
- await new Promise<void>((resolve, reject): void => {
1155
- this.systemControls.httpsServer.init = true;
1156
- this.httpsServer
1157
- .listen(
1158
- this._portSettings.httpsPort,
1159
- this.params.secureHost,
1160
- this.params.expressBacklog,
1161
- (): void => {
1162
- this.systemControls.httpsServer.started = true;
1163
- DyFM_Log.success(
1164
- `\nHTTPS (secure) server is listening on port: ` +
1165
- `${this.params.secureHost}:${this._portSettings.httpsPort}`
1166
- );
1167
-
1168
- resolve();
1169
- })
1170
- .on('error', (error): void => {
1171
- if (this.debugLog) DyFM_Log.error(`\nHTTPS (secure) server ERROR`, error);
1172
-
1173
- if (!this.systemControls.httpsServer.started) {
1174
- const d_error: DyFM_Error = new DyFM_Error({
1175
- ...this._getDefaultErrorSettings('startExpresses', error),
1176
-
1177
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-SE1`,
1178
- message: `HTTPS (secure) start server ERROR`,
1179
- });
1180
-
1181
- this.constructErrors.push(d_error);
1182
- DyNTS_GlobalService.globalErrorHandler?.(d_error);
1183
-
1184
- reject(d_error);
1185
-
1186
- } else {
1187
- const d_error: DyFM_Error = new DyFM_Error({
1188
- ...this._getDefaultErrorSettings('httpsServer.on(error)', error),
1189
-
1190
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-SE2`,
1191
- message: `HTTPS (secure) server ERROR`,
1192
- level: DyFM_ErrorLevel.serious,
1193
- });
1194
-
1195
- DyNTS_GlobalService.globalErrorHandler?.(d_error);
1196
- }
1197
- })
1198
- .on('uncaughtException', (exception): void => {
1199
- const d_error: DyFM_Error = new DyFM_Error({
1200
- ...this._getDefaultErrorSettings('httpsServer.on(uncaughtException)', exception),
1201
-
1202
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-SE3`,
1203
- message: `HTTPS (secure) server uncaughtException`,
1204
- level: DyFM_ErrorLevel.critical,
1205
- });
1206
-
1207
- if (this.debugLog) DyFM_Log.warn(
1208
- `\nHTTPS (secure) server uncaughtException`,
1209
- d_error
1210
- );
1211
-
1212
- DyNTS_GlobalService.globalErrorHandler?.(d_error);
1213
- });
1214
- });
1215
- }
1216
-
1217
- if (this._security && this._security !== DyNTS_RouteSecurity.secure) {
1218
- this.systemControls.httpServer.init = true;
1219
- await new Promise<void>((resolve, reject): void => {
1220
- this.httpServer = this.openExpress
1221
- .listen(
1222
- this._portSettings.httpPort,
1223
- this.params.openHost,
1224
- this.params.expressBacklog,
1225
- (): void => {
1226
- this.systemControls.httpServer.started = true;
1227
-
1228
- const resolvedPort: number = this.httpServer?.address?.()?.['port'] ?? this._portSettings.httpPort;
1229
-
1230
- if (this._portSettings.httpPort === 0) {
1231
- DyFM_Log.H_warn(
1232
- `\nHTTP (open) server is using a randomly selected port by the OS: ${resolvedPort}` +
1233
- `\n (httpPort was set to 0 — this is intended for testing only)`
1234
- );
1235
- }
1236
-
1237
- DyFM_Log.success(
1238
- `\nHTTP (open) server is listening on port: ` +
1239
- `${this.params.openHost}:${resolvedPort}`
1240
- );
1241
-
1242
- resolve();
1243
- }
1244
- )
1245
- .on('error', (error): void => {
1246
- if (this.debugLog) DyFM_Log.error(`\nHTTP (open) server ERROR`, error);
1247
-
1248
- if (!this.systemControls.httpServer.started) {
1249
- const d_error: DyFM_Error = new DyFM_Error({
1250
- ...this._getDefaultErrorSettings('startExpresses', error),
1251
-
1252
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-SE3`,
1253
- message: `HTTP (open) start server ERROR`,
1254
- });
1255
-
1256
- this.constructErrors.push(d_error);
1257
- DyNTS_GlobalService.globalErrorHandler?.(d_error);
1258
-
1259
- reject(d_error);
1260
-
1261
- } else {
1262
- const d_error: DyFM_Error = new DyFM_Error({
1263
- ...this._getDefaultErrorSettings('httpServer.on(error)', error),
1264
-
1265
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-SE4`,
1266
- message: `HTTP (open) server ERROR`,
1267
- level: DyFM_ErrorLevel.serious,
1268
- });
1269
-
1270
- DyNTS_GlobalService.globalErrorHandler?.(d_error);
1271
- }
1272
- })
1273
- .on('uncaughtException', (exception): void => {
1274
- const d_error: DyFM_Error = new DyFM_Error({
1275
- ...this._getDefaultErrorSettings('httpServer.on(uncaughtException)', exception),
1276
-
1277
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-SE5`,
1278
- message: `HTTP (open) server uncaughtException`,
1279
- level: DyFM_ErrorLevel.critical,
1280
- });
1281
-
1282
- if (this.debugLog) {
1283
- DyFM_Log.warn(`\nHTTP (open) server uncaughtException`, d_error);
1284
- }
1285
-
1286
- DyNTS_GlobalService.globalErrorHandler?.(d_error);
1287
- });
1288
- });
1289
- }
1290
- } catch (error) {
1291
- throw new DyFM_Error({
1292
- ...this._getDefaultErrorSettings('startExpresses', error),
1293
-
1294
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-SE0`,
1295
- });
1296
- }
1297
- }
1298
-
1299
- /**
1300
- *
1301
- */
1302
- private async expressErrorHandling(error, req, res, next): Promise<void> {
1303
- try {
1304
- if (error) {
1305
- const d_error: DyFM_Error = new DyFM_Error({
1306
- ...this._getDefaultErrorSettings('expressErrorHandling', error),
1307
-
1308
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-EEH1`,
1309
- message: `Express ERROR`,
1310
- additionalContent: {
1311
- req,
1312
- res,
1313
- },
1314
- level: DyFM_ErrorLevel.error,
1315
- });
1316
-
1317
- await DyNTS_GlobalService.globalErrorHandler?.(d_error, req, res);
1318
-
1319
- res.send(error)
1320
- } else {
1321
- DyFM_Log.H_error(
1322
- 'WTF??? express error; without error?...' +
1323
- '\nerr:', error,
1324
- '\nreq:', req,
1325
- '\nres:', res
1326
- );
1327
- }
1328
- } catch (error) {
1329
- DyFM_Log.H_error(
1330
- 'MULTILEVEL ERROR (expressErrorHandling)....' +
1331
- '\n', error
1332
- );
1333
- }
1334
- }
1335
-
1336
- /**
1337
- *
1338
- */
1339
- private async mountSecureRoutes (): Promise<void> {
1340
- try {
1341
- if (this.fnLogs && this.deepLog) DyFM_Log.log('\nfn:. mountSecureRoutes');
1342
-
1343
- if (!this.secureExpress) {
1344
- throw new Error(
1345
- 'secureExpress was not initialized. ' +
1346
- 'Secure routes require getCertificationSettings and httpsPort, and cert files must exist.' +
1347
- '\n\nYou need to set security to secure or both in any route and set httpsPort in getPortSettings.' +
1348
- '\n\nYou need to set cert files in getCertificationSettings.'
1349
- );
1350
- }
1351
-
1352
- this.secureExpress.use(
1353
- (error, req, res, next): Promise<void> => this.expressErrorHandling(error, req, res, next)
1354
- );
1355
-
1356
- await DyFM_Array.asyncForEach(
1357
- this._routingModules,
1358
- async (module: DyNTS_RoutingModule): Promise<void> => {
1359
- if (module.security !== DyNTS_RouteSecurity.open) {
1360
- if (this.logSetup) {
1361
- DyFM_Log.log(`route mount (secure): ${module.route}`);
1362
- }
1363
-
1364
- const existingRoutes: DyNTS_RoutingModule[] = this._routingModules.filter(
1365
- (mod: DyNTS_RoutingModule): boolean => mod.route === module.route
1366
- );
1367
-
1368
- if (1 < existingRoutes.length) {
1369
- const error: Error = new Error(`ROUTE DUPLICATION: ${module.route}`);
1370
- /* const errorStack: string[] = error.stack.split('\n');
1371
-
1372
- errorStack.splice(1, 4);
1373
- error.stack = errorStack.join('\n'); */
1374
- error.stack = module.stackLocation;
1375
-
1376
- DyFM_Log.S_error(`ROUTE DUPLICATION: ${module.route}`, error);
1377
-
1378
- throw new DyFM_Error({
1379
- ...this._getDefaultErrorSettings('mountSecureRoutes', error),
1380
-
1381
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-MSR1`,
1382
- message: `ROUTE DUPLICATION: ${module.route}`,
1383
- });
1384
- }
1385
-
1386
- this.secureExpress.use(module.route, module.secureRouter);
1387
- }
1388
- }
1389
- );
1390
- } catch (error) {
1391
- throw new DyFM_Error({
1392
- ...this._getDefaultErrorSettings('mountSecureRoutes', error),
1393
-
1394
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-MSR0`,
1395
- });
1396
- }
1397
- }
1398
-
1399
- /**
1400
- *
1401
- */
1402
- private async mountOpenRoutes(): Promise<void> {
1403
- try {
1404
- if (this.fnLogs && this.deepLog) DyFM_Log.log('\nfn:. mountOpenRoutes');
1405
-
1406
- if (!this.openExpress) {
1407
- throw new Error(
1408
- 'openExpress was not initialized. Open routes require getOpenExpress and httpPort.' +
1409
- '\n\nYou need to set security to open or both in any route and set httpPort in getPortSettings.'
1410
- );
1411
- }
1412
-
1413
- this.openExpress.use(
1414
- (error, req, res, next): Promise<void> => this.expressErrorHandling(error, req, res, next)
1415
- );
1416
-
1417
- await DyFM_Array.asyncForEach(
1418
- this._routingModules,
1419
- async (module: DyNTS_RoutingModule): Promise<void> => {
1420
- if (module.security !== DyNTS_RouteSecurity.secure) {
1421
- if (this.logSetup) {
1422
- DyFM_Log.log(`route mount (open): ${module.route}`);
1423
- }
1424
-
1425
- const existingRoutes: DyNTS_RoutingModule[] = this._routingModules.filter(
1426
- (mod: DyNTS_RoutingModule): boolean => mod.route === module.route
1427
- );
1428
-
1429
- if (1 < existingRoutes.length) {
1430
- const error: Error = new Error(`ROUTE DUPLICATION: ${module.route}`);
1431
- /* const errorStack: string[] = error.stack.split('\n');
1432
-
1433
- errorStack.splice(1, 4);
1434
- error.stack = errorStack.join('\n'); */
1435
- error.stack = module.stackLocation;
1436
-
1437
- DyFM_Log.S_error(`ROUTE DUPLICATION: ${module.route}`, error);
1438
-
1439
- throw new DyFM_Error({
1440
- ...this._getDefaultErrorSettings('mountOpenRoutes', error),
1441
-
1442
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-MOR1`,
1443
- message: `ROUTE DUPLICATION: ${module.route}`,
1444
- });
1445
- }
1446
-
1447
- this.openExpress.use(module.route, module.openRouter);
1448
- }
1449
- }
1450
- );
1451
- } catch (error) {
1452
- throw new DyFM_Error({
1453
- ...this._getDefaultErrorSettings('mountOpenRoutes', error),
1454
-
1455
- errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-MOR0`,
1456
- });
1457
- }
1458
- }
1459
-
1460
- /**
1461
- * FR-041 — CORS middleware. Echoes a matching `Access-Control-Allow-Origin`
1462
- * for any request whose Origin header is in `getCorsSettings().allowedOrigins`,
1463
- * adds the canonical `Access-Control-*` companion headers, and short-circuits
1464
- * the OPTIONS preflight with a 204.
1465
- *
1466
- * No-op when the subclass does NOT override `getCorsSettings()` — preserves
1467
- * back-compat for apps that have always been same-origin and never needed
1468
- * CORS (the typical pre-FR-041 case).
1469
- *
1470
- * Why hand-rolled instead of the `cors` npm package:
1471
- * - ~30 lines, zero new dependency.
1472
- * - Full control over Vary/credentials/preflight semantics.
1473
- * - Aligns with FDP "no unnecessary deps" philosophy.
1474
- */
1475
- protected mountCors(express: Express.Application): void {
1476
- const settings: DyNTS_Cors_Settings | undefined = this.getCorsSettings?.();
1477
- if (!settings) {
1478
- return;
1479
- }
1480
-
1481
- const allowCreds: boolean = settings.allowCredentials !== false;
1482
- const methods: string[] = settings.allowedMethods ?? [
1483
- 'GET', 'POST', 'PUT', 'DELETE', 'PATCH', 'OPTIONS',
1484
- ];
1485
- const headers: string[] = settings.allowedHeaders ?? [
1486
- 'Authorization', 'Content-Type', 'X-Admin-Key', 'X-Requested-With',
1487
- ];
1488
- const exposed: string[] = settings.exposedHeaders ?? [
1489
- 'Content-Length', 'Content-Type',
1490
- ];
1491
- const maxAge: number = settings.maxAgeSeconds ?? 86400;
1492
-
1493
- const isAllowed: (origin: string) => boolean = (origin: string): boolean => {
1494
- if (settings.allowedOrigins === '*') return true;
1495
- if (typeof settings.allowedOrigins === 'function') {
1496
- return settings.allowedOrigins(origin);
1497
- }
1498
- return settings.allowedOrigins.includes(origin);
1499
- };
1500
-
1501
- express.use((req: Express.Request, res: Express.Response, next: Express.NextFunction): void => {
1502
- const origin: string | undefined = req.headers.origin;
1503
- if (origin && isAllowed(origin)) {
1504
- // Echo the matching origin (NOT wildcard) because credentials require it.
1505
- res.setHeader('Access-Control-Allow-Origin', origin);
1506
- if (allowCreds) {
1507
- res.setHeader('Access-Control-Allow-Credentials', 'true');
1508
- }
1509
- res.setHeader('Access-Control-Allow-Methods', methods.join(', '));
1510
- res.setHeader('Access-Control-Allow-Headers', headers.join(', '));
1511
- res.setHeader('Access-Control-Expose-Headers', exposed.join(', '));
1512
- res.setHeader('Access-Control-Max-Age', String(maxAge));
1513
- res.setHeader('Vary', 'Origin');
1514
- }
1515
- if (req.method === 'OPTIONS') {
1516
- res.status(204).end();
1517
- return;
1518
- }
1519
- next();
1520
- });
1521
- }
1522
-
1523
- /**
1524
- * Generikus, auth-agnosztikus extension-point orchestrator. A `registerCustomMiddleware`
1525
- * hookot hívja (ha a subclass override-olja) minden AKTÍV Express instance-ra
1526
- * (open + secure), az API route-ok UTÁN, de a SPA static catch-all (`app.get('*')`)
1527
- * ELŐTT — ez az EGYETLEN korrekt pont egy sub-path middleware-hez (pl. reverse-proxy),
1528
- * mert a catch-all minden utána mountolt route-ot elnyel. No-op ha nincs override (back-compat).
1529
- */
1530
- private async mountCustomMiddleware(): Promise<void> {
1531
- if (!this.registerCustomMiddleware) {
1532
- return;
1533
- }
1534
-
1535
- if (this.openExpress) {
1536
- await this.registerCustomMiddleware(this.openExpress, DyNTS_RouteSecurity.open);
1537
- }
1538
-
1539
- if (this.secureExpress) {
1540
- await this.registerCustomMiddleware(this.secureExpress, DyNTS_RouteSecurity.secure);
1541
- }
1542
-
1543
- if (this.logSetup) {
1544
- DyFM_Log.log('\nCustom middleware registered (pre-static).');
1545
- }
1546
- }
1547
-
1548
- /**
1549
- * Ha getStaticClientSettings() visszaad beállításokat, a client static fájlok a '/' alatt
1550
- * lesznek kiszolgálva (API route-ok után). SPA fallback opcionális (fallbackPath).
1551
- * Asset cache (assetCacheMaxAge, assetCacheImmutable) és fallback cache (fallbackCacheMaxAge)
1552
- * opcionálisak; ha nincs megadva fallbackCacheMaxAge, DyNTS_defaultFallbackCacheMaxAge (0) marad.
1553
- */
1554
- private async mountStaticClient(): Promise<void> {
1555
- const settings: DyNTS_StaticClient_Settings | undefined = this.getStaticClientSettings?.();
1556
- if (!settings) {
1557
- return;
1558
- }
1559
-
1560
- const absoluteRoot: string = Path.isAbsolute(settings.root)
1561
- ? settings.root
1562
- : Path.resolve(process.cwd(), settings.root);
1563
-
1564
- const hasAssetCache: boolean =
1565
- settings.assetCacheMaxAge !== undefined || settings.assetCacheImmutable === true;
1566
- const staticOptions: { setHeaders: (res: Express.Response) => void } | undefined =
1567
- hasAssetCache && settings.assetCacheMaxAge !== undefined
1568
- ? {
1569
- setHeaders: (res: Express.Response): void => {
1570
- const maxAge: number = settings.assetCacheMaxAge!;
1571
- const immutable: string =
1572
- settings.assetCacheImmutable === true ? ', immutable' : '';
1573
- res.setHeader('Cache-Control', `max-age=${maxAge}${immutable}`);
1574
- },
1575
- }
1576
- : undefined;
1577
-
1578
- const staticMiddleware: Express.Handler =
1579
- staticOptions
1580
- ? Express.static(absoluteRoot, staticOptions)
1581
- : Express.static(absoluteRoot);
1582
-
1583
- const fallbackMaxAge: number =
1584
- settings.fallbackCacheMaxAge ?? DyNTS_defaultFallbackCacheMaxAge;
1585
-
1586
- if (this.openExpress) {
1587
- this.openExpress.use('/', staticMiddleware);
1588
- if (settings.fallbackPath) {
1589
- this.openExpress.get('*', (req: Express.Request, res: Express.Response): void => {
1590
- res.setHeader('Cache-Control', `max-age=${fallbackMaxAge}`);
1591
- res.sendFile(settings.fallbackPath!, { root: absoluteRoot });
1592
- });
1593
- } else {
1594
- this.openExpress.get('*', (req: Express.Request, res: Express.Response): void => {
1595
- res.status(404).type('html').send(DyNTS_defaultNotFoundPageHtml);
1596
- });
1597
- }
1598
- }
1599
-
1600
- if (this.secureExpress) {
1601
- this.secureExpress.use('/', staticMiddleware);
1602
- if (settings.fallbackPath) {
1603
- this.secureExpress.get('*', (req: Express.Request, res: Express.Response): void => {
1604
- res.setHeader('Cache-Control', `max-age=${fallbackMaxAge}`);
1605
- res.sendFile(settings.fallbackPath!, { root: absoluteRoot });
1606
- });
1607
- } else {
1608
- this.secureExpress.get('*', (req: Express.Request, res: Express.Response): void => {
1609
- res.status(404).type('html').send(DyNTS_defaultNotFoundPageHtml);
1610
- });
1611
- }
1612
- }
1613
-
1614
- if (this.logSetup) {
1615
- DyFM_Log.log(`\nStatic client mounted at / (root: ${absoluteRoot})`);
1616
- }
1617
- }
1618
-
1619
- /**
1620
- *
1621
- */
1622
- private setSecurity(): void {
1623
- if (this.fnLogs && this.deepLog) DyFM_Log.log('\nfn:. setSecurity');
1624
- this._routingModules.forEach((module: DyNTS_RoutingModule): void => {
1625
- if (!module.security) {
1626
- DyFM_Log.warn(`RoutingModule security is not set for ${module.route}\n`);
1627
-
1628
- } else if (!this._security) {
1629
- this._security = module.security;
1630
-
1631
- } else if (this._security !== module.security) {
1632
- this._security = DyNTS_RouteSecurity.both;
1633
- }
1634
- });
1635
-
1636
- if (!this._security) {
1637
- let msg = `Could not set security for the server! (${this.security})`;
1638
-
1639
- msg += '\n RoutingModules:';
1640
- this._routingModules.forEach((module: DyNTS_RoutingModule): void => {
1641
- msg += `\n ${module.route} (security: ${module.security})`;
1642
- });
1643
-
1644
- if (this._routingModules.length === 0) {
1645
- msg += '\n - no RoutingModule found -\n';
1646
- }
1647
- DyFM_Log.warn(msg);
1648
- }
1649
- }
1650
-
1651
- private _getDefaultErrorSettings(
1652
- fnName: string,
1653
- error: DyFM_AnyError
1654
- ): DyFM_Error_Settings {
1655
- return {
1656
- status: (error as DyFM_Error)?.___status ?? 500,
1657
- message: (error as Error)?.message ??
1658
- (error as DyFM_Error)?._message ??
1659
- `${fnName} was UNSUCCESSFUL (NTS)`,
1660
- userMessage: (error as DyFM_Error)?.__userMessage ?? this.defaultErrorUserMsg,
1661
- addECToUserMsg: !(error as DyFM_Error)?.__userMessage,
1662
- issuerService: `${this?.constructor?.name}-DyNTS_App`,
1663
- level: DyFM_ErrorLevel.fatal,
1664
- error: error,
1665
- systemVersion: DyNTS_global_settings.systemVersion,
1666
- };
1667
- }
1668
-
1669
- /**
1670
- * MISSING Description (TODO)
1671
- */
1672
- abstract getAppParams(): DyNTS_App_Params;
1673
-
1674
- /**
1675
- * MISSING Description (TODO)
1676
- */
1677
- abstract getGlobalServiceCollection(): DyNTS_GlobalService_Settings;
1678
-
1679
- /**
1680
- * MISSING Description (TODO)
1681
- */
1682
- abstract getPortSettings(): DyNTS_Http_Settings;
1683
-
1684
- /**
1685
- * MISSING Description (TODO)
1686
- */
1687
- overrideDynamoNTSGlobalSettings?(): void;
1688
-
1689
- /**
1690
- * Ha megadva, a visszaadott értéket használjuk a route prefix-ként
1691
- * (DyNTS_global_settings.baseUrl felülírása erre az app-ra).
1692
- */
1693
- getApiBasePath?(): string;
1694
-
1695
- /**
1696
- * MISSING Description (TODO)
1697
- */
1698
- getRoutingModules?(): DyNTS_RoutingModule[];
1699
-
1700
- /**
1701
- * MISSING Description (TODO)
1702
- */
1703
- getRootServices?(): Promise<any[]>;
1704
-
1705
- /**
1706
- * MISSING Description (TODO)
1707
- */
1708
- getCertificationSettings?(): DyNTS_Certification_Settings;
1709
-
1710
- /**
1711
- * Ha megadva, a client static fájlok a '/' alatt lesznek kiszolgálva (API route-ok után).
1712
- * Opcionális fallbackPath pl. SPA index.html-hez.
1713
- */
1714
- getStaticClientSettings?(): DyNTS_StaticClient_Settings | undefined;
1715
-
1716
- /**
1717
- * FR-041 — Ha megadva, CORS middleware mount-olódik mindkét Express instance-ra
1718
- * (open + secure). Az `allowedOrigins` listán szereplő Origin-eket echo-zza vissza,
1719
- * `Access-Control-Allow-Credentials: true`-val (default) együtt a Bearer JWT
1720
- * cross-domain auth flow miatt. OPTIONS preflight 204-gyel rövidre záródik.
1721
- * Ha undefined → no CORS headers, no preflight handling — back-compat.
1722
- */
1723
- getCorsSettings?(): DyNTS_Cors_Settings | undefined;
1724
-
1725
- /**
1726
- * Opcionális generikus hook: custom Express middleware regisztrálása az API route-ok
1727
- * UTÁN és a SPA static catch-all ELŐTT. Auth-AGNOSZTIKUS framework extension-point —
1728
- * a subclass (pl. FDP base App) ezen keresztül mount-olhat reverse-proxyt egy sub-path-re
1729
- * (pl. `/auth-api`), ami a `app.get('*')` catch-all elé kell kerüljön. A hívási időzítést
1730
- * lásd: `mountCustomMiddleware`. Undefined → no-op (back-compat).
1731
- */
1732
- registerCustomMiddleware?(
1733
- express: Express.Application,
1734
- security: DyNTS_RouteSecurity,
1735
- ): void | Promise<void>;
1736
-
1737
- /**
1738
- * MISSING Description (TODO)
1739
- */
1740
- createEntries?(): Promise<void>;
1741
-
1742
- /**
1743
- * MISSING Description (TODO)
1744
- */
1745
- postProcess?(): Promise<void>;
1746
-
1747
- }
1
+
2
+ import Mongoose = require('mongoose');
3
+ import Express = require('express');
4
+ /* import Mongoose from 'mongoose';
5
+ import Express from 'express'; */
6
+
7
+ import * as BodyParser from 'body-parser';
8
+ import * as FileSystem from 'fs';
9
+ import * as Http from 'http';
10
+ import * as Https from 'https';
11
+ import * as Path from 'path';
12
+ import * as dotenv from 'dotenv'
13
+
14
+ /* import { version } from '../../../package.json'; */
15
+
16
+ import {
17
+ DyFM_AnyError,
18
+ DyFM_Array,
19
+ DyFM_Async,
20
+ DyFM_Error,
21
+ DyFM_error_defaults,
22
+ DyFM_Error_Settings,
23
+ DyFM_ErrorLevel,
24
+ DyFM_Log,
25
+ megabyte,
26
+ second
27
+ } from '@futdevpro/fsm-dynamo';
28
+
29
+ import { DyNTS_defaultFallbackCacheMaxAge } from '../../_collections/default-fallback-cache-max-age.const';
30
+ import { DyNTS_defaultNotFoundPageHtml } from '../../_collections/default-not-found-page.const';
31
+ import { DyNTS_global_settings } from '../../_collections/global-settings.const';
32
+ import { startMongoReconnectGuard } from '../../_collections/mongo-reconnect-guard.util';
33
+ import { DyNTS_RouteSecurity } from '../../_enums/route-security.enum';
34
+ import { DyNTS_App_Params } from '../../_models/control-models/app-params.control-model';
35
+ import {
36
+ DyNTS_AppSystemControls
37
+ } from '../../_models/control-models/app-system-controls.control-model';
38
+ import {
39
+ DyNTS_Endpoint_Params
40
+ } from '../../_models/control-models/endpoint-params.control-model';
41
+ import { DyNTS_Http_Settings } from '../../_models/control-models/http-settings.control-model';
42
+ import {
43
+ DyNTS_Certification_Settings
44
+ } from '../../_models/interfaces/certification-settings.interface';
45
+ import {
46
+ DyNTS_GlobalService_Settings
47
+ } from '../../_models/interfaces/global-service-settings.interface';
48
+ import {
49
+ DyNTS_StaticClient_Settings
50
+ } from '../../_models/interfaces/static-client-settings.interface';
51
+ import {
52
+ DyNTS_Cors_Settings
53
+ } from '../../_models/interfaces/cors-settings.interface';
54
+ import { DyNTS_SingletonService } from '../base/singleton.service';
55
+ import { DyNTS_GlobalService } from '../core/global.service';
56
+ import { DyNTS_MemoryGuard } from '../core/memory-guard.service';
57
+ import { DyNTS_RoutingModule } from '../route/routing-module.service';
58
+ import { DyNTS_getStarRoute } from '../../_collections/star.controller';
59
+
60
+ /**
61
+ *
62
+ * function MyDecorator(config: any) {
63
+ return function (target: Function) {
64
+ // attach metadata or modify target
65
+ target.prototype.myMeta = config;
66
+ };
67
+ }
68
+
69
+ @MyDecorator({ role: 'admin' })
70
+ class User {
71
+ printRole() {
72
+ console.log((this as any).myMeta.role); // → "admin"
73
+ }
74
+ }
75
+
76
+ */
77
+
78
+ /**
79
+ * This will be the MAIN service of our server project,
80
+ * follow the types and type instructions while setting up your project
81
+ *
82
+ * In this service, there are abstract functions that you will need to implement,
83
+ * where you need to set up the main params for your application.
84
+ *
85
+ * (after the example, you can find the list of services you can/should setup)
86
+ *
87
+ * @example
88
+ * export class App extends DyNTS_AppExtended {
89
+ *
90
+ * ...
91
+ *
92
+ * // Setting up App params, and preparing project global settings
93
+ * setupAppParams(): void {
94
+ * this.params = new DyNTS_AppParams({
95
+ * name: 'Warbots Server',
96
+ * title: warbotsTitleLog,
97
+ * version: version,
98
+ * dbName: 'warbots',
99
+ * });
100
+ *
101
+ * // dynamoNTS_GlobalSettings.logRequestsContent = false;
102
+ * }
103
+ *
104
+ * ...
105
+ *
106
+ * // Setting up DBServices
107
+ * setGlobalServiceCollection(): void {
108
+ * DyNTS_GlobalService.setServices({
109
+ * authService: AuthService.getInstance(),
110
+ * emailServiceCollection: EmailServiceCollectionService.getInstance(),
111
+ * dbModels: [
112
+ * userModelParams,
113
+ * userDataModelParams,
114
+ * userOptionsModelParams,
115
+ * userStatisticsModelParams,
116
+ * userAchievementsModelParams,
117
+ * userNotificationsModelParams,
118
+ *
119
+ * matchStatisticsModelParams,
120
+ * matchDataModelParams,
121
+
122
+ * DyFM_usageSession_dataParams,
123
+ * DyFM_customData_dataParams,
124
+ * ]
125
+ * });
126
+ * }
127
+ *
128
+ * ...
129
+ *
130
+ * // Setting up Routes
131
+ * setupRoutingModules(): void {
132
+ * this.httpPort = env.port;
133
+
134
+ * this.routingModules = [
135
+ * new DyNTS_RoutingModule({
136
+ * route: '/user',
137
+ * controllers: [
138
+ * UserController.getInstance(),
139
+ * UserDataController.getInstance(),
140
+ * UserOptionsController.getInstance(),
141
+ * UserStatisticsController.getInstance(),
142
+ * UserAchievementsController.getInstance(),
143
+ * UserNotificationsController.getInstance()
144
+ * ]
145
+ * }),
146
+ * new DyNTS_RoutingModule({
147
+ * route: '/match',
148
+ * controllers: [
149
+ * MatchController.getInstance(),
150
+ * MatchDistributionController.getInstance(),
151
+ * MatchStatisticsController.getInstance(),
152
+ * ]
153
+ * }),
154
+ * new DyNTS_RoutingModule({
155
+ * route: '/server',
156
+ * controllers: [
157
+ * ServerController.getInstance(),
158
+ * ]
159
+ * }),
160
+
161
+ * getTestRoutingModule(),
162
+ * getUsageRoutingModule()
163
+ * ];
164
+ * }
165
+ * }
166
+ *
167
+ * //
168
+ * // The Services available
169
+ * //
170
+ * // Authentication Service
171
+ * // A commonly used basic service,
172
+ * // which is necessary fur certain functions (such as registering call issuers)
173
+ * //
174
+ * // This will handle Authentication Token checking/refreshing,
175
+ * // checking issuer's identifier and routeParams,
176
+ * // handling JWT Token, or maybe with OAuth2 or other commonly used security procedures
177
+ * //
178
+ * // You can create one with this Dynamo Object:
179
+ * //
180
+ *
181
+ * @example
182
+ * // follow the instructions on the abstract class (DyNTS_AuthService)
183
+ * export class AuthService extends DyNTS_AuthService {}
184
+ *
185
+ *
186
+ *
187
+ * //
188
+ */
189
+
190
+ /**
191
+ * This will be the MAIN service of our server project,
192
+ * follow the types and type instructions while setting up your project
193
+ *
194
+ * In this service, there are abstract functions that you will need to implement,
195
+ * where you need to set up the main params for your application.
196
+ *
197
+ * (after the example, you can find the list of services you can/should setup)
198
+ *
199
+ * You need to setup the following functions:
200
+ * ```ts
201
+ * // this is where you set up the main params for your application
202
+ * getAppParams(): DyNTS_AppParams
203
+ *
204
+ * // this is where you connect your main services
205
+ * getGlobalServiceSettings(): DyNTS_GlobalService_Settings
206
+ *
207
+ * // this is where you set up your ports
208
+ * getPorts(): DyNTS_PortSettings
209
+ *
210
+ * // this is where you set up your routes
211
+ * getRoutingModules(): DyNTS_RoutingModule[]
212
+ *
213
+ *
214
+ *
215
+ * ```
216
+ * optionally you can setup the following functions:
217
+ * ```ts
218
+ * // this is where you set up your certifications
219
+ * getCertificationSettings(): DyNTS_CertificationSettings
220
+ *
221
+ * // this is where you set up additional root services
222
+ * getRootServices(): DyNTS_SingletonService[]
223
+ *
224
+ * // this is where you set up your initial db entries
225
+ * createEntries(): void
226
+ *
227
+ * // this is where you can define post setup processes
228
+ * postProcess(): void
229
+ *
230
+ *
231
+ *
232
+ * ```
233
+ *
234
+ */
235
+ export abstract class DyNTS_App extends DyNTS_SingletonService {
236
+
237
+ protected systemControls: DyNTS_AppSystemControls = new DyNTS_AppSystemControls();
238
+ get started(): boolean {
239
+ return this.systemControls.app.started;
240
+ }
241
+ protected get superStarted(): boolean {
242
+ return this.systemControls.app.started;
243
+ }
244
+ protected constructErrors: (Error | DyFM_Error)[] = [];
245
+
246
+ /* removed since cant use version from package.json
247
+ private readonly _ntsVersion: string = 'v01.07.18';
248
+ protected get ntsVersion(): string {
249
+ return this._ntsVersion;
250
+ } */
251
+
252
+ get serverName(): string {
253
+ return this.params.name;
254
+ }
255
+
256
+ private _params: DyNTS_App_Params;
257
+ protected get params(): DyNTS_App_Params {
258
+ return this._params;
259
+ }
260
+
261
+ protected mongoose = Mongoose;
262
+
263
+ private _security: DyNTS_RouteSecurity;
264
+ protected get security(): DyNTS_RouteSecurity {
265
+ return this._security;
266
+ }
267
+
268
+ protected _portSettings: DyNTS_Http_Settings = new DyNTS_Http_Settings();
269
+ protected get portSettings(): DyNTS_Http_Settings {
270
+ return this._portSettings;
271
+ }
272
+
273
+ private _cert?: DyNTS_Certification_Settings;
274
+ protected get cert(): DyNTS_Certification_Settings {
275
+ return this._cert;
276
+ }
277
+
278
+ protected openExpress: Express.Application;
279
+ protected secureExpress: Express.Application;
280
+ protected httpsServer: Https.Server;
281
+ protected httpServer: Http.Server;
282
+
283
+ private globalService: DyNTS_GlobalService;
284
+ private _rootServices: DyNTS_SingletonService[] = [];
285
+
286
+ private _routingModules: DyNTS_RoutingModule[] = [];
287
+
288
+ protected readonly defaultReadyTimeout: number = 30 * second;
289
+
290
+ override readonly defaultErrorUserMsg =
291
+ `We encountered an unhandled Server Error, ` +
292
+ `\nplease contact the responsible development team.` +
293
+ `\n(Internal Server error)`;
294
+
295
+ get logSetup(): boolean {
296
+ return DyNTS_global_settings.log_settings.setup;
297
+ }
298
+ get deepLog(): boolean {
299
+ return DyNTS_global_settings.log_settings.deep;
300
+ }
301
+ get fnLogs(): boolean {
302
+ return DyNTS_global_settings.log_settings.functions;
303
+ }
304
+ debugLog: boolean = DyNTS_global_settings.log_settings.server_debug;
305
+
306
+ constructor(/* extended?: boolean */){
307
+ super();
308
+
309
+ /* dotenv.config() */
310
+
311
+ process.on(
312
+ 'unhandledRejection',
313
+ (reason_theError: object, p_passWhatIsThis_maybeThePromise: any): void => {
314
+ if (reason_theError instanceof DyFM_Error) {
315
+ reason_theError.logSimple('Unhandled Rejection');
316
+ } else {
317
+ DyFM_Log.H_error(
318
+ 'Unhandled Rejection:', (p_passWhatIsThis_maybeThePromise as Promise<any>)?.toString(),
319
+ '\n Rejection reason:', (reason_theError as Error)?.stack?.split('at')?.[0],
320
+ /* '\n ErrorCode:', (reason as any)?.code, */
321
+ '\n\n Stack:',
322
+ (reason_theError as Error)?.stack?.replaceAll?.('\n at', '\n at'),
323
+ );
324
+ }
325
+
326
+ try {
327
+ DyNTS_GlobalService.globalErrorHandler?.(
328
+ new DyFM_Error({
329
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-BASE-UR`,
330
+ message:
331
+ `Unhandled Rejection!: "${(reason_theError as Error)?.stack?.split('at')?.[0]}"`,
332
+ userMessage: this.defaultErrorUserMsg,
333
+ addECToUserMsg: true,
334
+ error: reason_theError as Error,
335
+ additionalContent: {
336
+ reason: reason_theError,
337
+ rejectedPromise: p_passWhatIsThis_maybeThePromise,
338
+ },
339
+ systemVersion: DyNTS_global_settings.systemVersion,
340
+ level: DyFM_ErrorLevel.critical,
341
+ })
342
+ );
343
+ } catch (error) {
344
+ DyFM_Log.error('globalErrorHandler (MULTILEVEL) ERROR:', error);
345
+ }
346
+ }
347
+ );
348
+
349
+ this.asyncConstruct(/* extended */).catch((error: any): void => {
350
+ if (error instanceof DyFM_Error) {
351
+ if (error.additionalContent?.constructErrors?.length) {
352
+ error.additionalContent.constructErrors.forEach((errorItem: DyFM_Error): void => {
353
+ DyFM_Error.logSimple('(constructor asyncConstruct.catch) error:', errorItem);
354
+ /* if (errorItem instanceof DyFM_Error) {
355
+ errorItem.logSimple(`(constructor asyncConstruct.catch) error:\n`);
356
+ } else {
357
+ DyFM_Log.H_warn(
358
+ '(constructor asyncConstruct.catch) additional error content:\n',
359
+ errorItem
360
+ );
361
+ } */
362
+ });
363
+ } else {
364
+ DyFM_Log.H_warn(
365
+ '(constructor asyncConstruct.catch) additional error content:\n',
366
+ error?.additionalContent
367
+ );
368
+ }
369
+ }
370
+
371
+ DyFM_Error.logSimple('(constructor asyncConstruct.catch) error:', error);
372
+ /* if (
373
+ !DyNTS_global_settings.log_settings.highDetailedLogs &&
374
+ (error instanceof DyFM_Error)
375
+ ) {
376
+ error.logSimple(
377
+ `Application: "${this.params?.name}" start failed. (constructor asyncConstruct.catch)` +
378
+ '\n all error messages (from this stack):\n\n"' +
379
+ error._messages.join('"\n\n"') + '"\n\n'
380
+ );
381
+ } else if (error instanceof DyFM_Error) {
382
+ DyFM_Log.H_error(
383
+ `Application: "${this.params?.name}" start failed. (constructor asyncConstruct.catch)`,
384
+ `\n ERROR:`, error
385
+ );
386
+ } */
387
+
388
+ const message: string =
389
+ (error as DyFM_Error)?.additionalContent?.constructErrors?.flatMap(
390
+ (errorItem: DyFM_Error): string[] => {
391
+ return errorItem?._messages ?? [];
392
+ }
393
+ )?.join?.('\n') ??
394
+ (error as DyFM_Error)?.errors?.flatMap(
395
+ (errorItem: DyFM_AnyError): string[] =>
396
+ (errorItem as DyFM_Error)?._messages ?? [ (errorItem as Error)?.message ]
397
+ )?.join?.('\n') ??
398
+ error?.message ??
399
+ 'UNKNOWN';
400
+
401
+ DyFM_Log.testError('Application start failed:\n', message);
402
+
403
+ process.exit(1);
404
+ });
405
+ }
406
+
407
+ protected async asyncConstruct(extended?: boolean): Promise<void> {
408
+ if (this.fnLogs && this.deepLog) DyFM_Log.log('\nfn:. asyncConstruct');
409
+
410
+ try {
411
+ this.systemControls.app.init = true;
412
+ this._params = this.getAppParams();
413
+ DyFM_Log.log(
414
+ `\n\n\n\n\n\n\n\n\n\n` +
415
+ `Starting ${this._params?.name}... ` +
416
+ /* `v${version}` + */
417
+ `\n\n\n\n\n\n\n\n\n\n`
418
+ );
419
+
420
+ if (!this._params) {
421
+ throw new Error('getAppParams() must return a DyNTS_AppParams object!');
422
+ }
423
+
424
+ if (this.params.systemShortCodeName) {
425
+ DyNTS_global_settings.systemShortCodeName = this.params.systemShortCodeName;
426
+ }
427
+
428
+ if (this.params.systemName) {
429
+ DyNTS_global_settings.systemName = this.params.systemName;
430
+ DyFM_error_defaults.issuerSystem = this.params.systemName;
431
+ }
432
+
433
+ if (this.params.version) {
434
+ DyNTS_global_settings.systemVersion = this.params.version;
435
+ DyFM_error_defaults.systemVersion = this.params.version;
436
+ }
437
+
438
+ process.stdout.write(
439
+ String.fromCharCode(27) + ']0;' +
440
+ this._params?.name +
441
+ String.fromCharCode(7)
442
+ );
443
+
444
+ DyFM_error_defaults.issuerSystem = this._params.systemName;
445
+
446
+ this.overrideDynamoNTSGlobalSettings?.();
447
+
448
+ if (DyNTS_global_settings.log_settings.setup) {
449
+ DyFM_Log.S_info(`env settings;\n`, {
450
+ systemName: DyNTS_global_settings.systemName,
451
+ systemShortCodeName: DyNTS_global_settings.systemShortCodeName,
452
+ systemVersion: DyNTS_global_settings.systemVersion,
453
+ environment: DyNTS_global_settings.env_settings.environment,
454
+ /* log_settings: DyNTS_global_settings.log_settings,
455
+ env_settings: DyNTS_global_settings.env_settings, */
456
+ });
457
+ }
458
+
459
+ this.globalService = DyNTS_GlobalService.getInstance();
460
+ await DyNTS_GlobalService.setServices(this.getGlobalServiceCollection());
461
+ DyNTS_GlobalService.setParams(this.params);
462
+
463
+ if (this.getPortSettings) {
464
+ this._portSettings = this.getPortSettings();
465
+ }
466
+
467
+ if (this.getCertificationSettings) {
468
+ this._cert = this.getCertificationSettings();
469
+ }
470
+
471
+ if (this.getApiBasePath) {
472
+ DyNTS_global_settings.baseUrl = this.getApiBasePath();
473
+ }
474
+
475
+ if (this.getRoutingModules) {
476
+ this._routingModules = this.getRoutingModules();
477
+
478
+ // ezt egyelőre csak tesztelem, nem kerül be
479
+ /* if (
480
+ !DyNTS_global_settings.dontCreateDefaultRoute &&
481
+ !this._routingModules.some((routingModule: DyNTS_RoutingModule): boolean => routingModule.route === '/*')
482
+ ) {
483
+ this._routingModules.push(
484
+ DyNTS_getStarRoute()
485
+ );
486
+ } */
487
+ }
488
+
489
+ if (this._params.dbUri) {
490
+ await this.startDB();
491
+
492
+ // createEntries csak akkor fut, ha a DB tényleg fel-jött.
493
+ // Ha a startDB jelezte a hibát, de továbbment, akkor a started flag false marad,
494
+ // és nem próbálunk meg írni egy nem létező kapcsolatra.
495
+ if (this.createEntries && this.systemControls.mongoose.started) {
496
+ await this.createEntries();
497
+ }
498
+ } else {
499
+ DyFM_Log.log(
500
+ `\nNo database connection created.`,
501
+ );
502
+ }
503
+
504
+ if (this._routingModules?.length) {
505
+ if (this.logSetup) DyFM_Log.log('\nsetting up express routes...');
506
+
507
+ this.setSecurity();
508
+
509
+ await this.initExpresses();
510
+ await this.startExpresses();
511
+
512
+ if (this._security !== DyNTS_RouteSecurity.secure) {
513
+ await this.mountOpenRoutes();
514
+ }
515
+
516
+ if (this._security !== DyNTS_RouteSecurity.open && this._cert) {
517
+ await this.mountSecureRoutes();
518
+ }
519
+
520
+ // Generikus, auth-agnosztikus extension-point: custom middleware az API
521
+ // route-ok UTÁN, de a SPA static catch-all (mountStaticClient) ELŐTT.
522
+ await this.mountCustomMiddleware();
523
+
524
+ await this.mountStaticClient();
525
+
526
+ if (this.logSetup) {
527
+ DyFM_Log.log(`\nRoutes mounted.... server using security: ${this._security}`);
528
+ }
529
+ } else {
530
+ DyFM_Log.warn(
531
+ `\nNo routes mounted!`,
532
+ );
533
+ }
534
+
535
+ if (this.getRootServices) {
536
+ this._rootServices = await this.getRootServices();
537
+ }
538
+
539
+ if (this.postProcess) {
540
+ await this.postProcess().catch((error: any): void => {
541
+ DyFM_Error.logSimple(`"${this._params.name}" postProcess failed:`, error);
542
+ DyNTS_GlobalService.globalErrorHandler?.(error);
543
+ });
544
+ }
545
+
546
+ // FR-193 — bedrock OOM korai-figyelmeztetés: feltelepítjük a heap-watchdogot, ha
547
+ // engedélyezve (DyNTS_global_settings.memoryGuard.enabled, default true). Biztonságos:
548
+ // a guard egy könnyű setInterval, ami SOHA nem dob; csak near-OOM küszöböknél hagy
549
+ // tartós nyomot az error-sinkbe, mielőtt a fatal heap-OOM megölné a process-t.
550
+ try {
551
+ if (DyNTS_global_settings.memoryGuard?.enabled) {
552
+ DyNTS_MemoryGuard.getInstance().install();
553
+ }
554
+ } catch (memoryGuardError: unknown) {
555
+ DyFM_Log.warn('[DyNTS_MemoryGuard] auto-install skipped (non-fatal):', memoryGuardError);
556
+ }
557
+
558
+ if (!extended) {
559
+ await this.ready();
560
+
561
+ if (this.params.title) {
562
+ DyFM_Log.success(this.params.title);
563
+ }
564
+ DyFM_Log.info(`Version: ${this.params.version}`);
565
+ /* DyFM_Log.info(`NTS Version: ${this.ntsVersion}`); */
566
+ DyFM_Log.H_success(`${this.params.name} started successfully.`);
567
+ }
568
+ } catch (error) {
569
+ this.constructErrors.push(error);
570
+
571
+ if (this.deepLog) {
572
+ if (DyNTS_global_settings.log_settings.highDetailedLogs) {
573
+ DyFM_Log.H_error(
574
+ `"${this._params.name}" start failed (in asyncConstruct (highDetailedLog)). `,
575
+ `\n\n construct ERRORS:`, this.constructErrors,
576
+ '\n\nlast error:', error
577
+ );
578
+ } else {
579
+ DyFM_Log.H_error(
580
+ `"${this._params.name}" start failed (in asyncConstruct). `,
581
+ `\n\n construct ERRORS:`, this.getSimplifiedConstructErrors(),
582
+ '\n\nlast error:', error instanceof DyFM_Error ? error.getErrorSimplified() : error
583
+ );
584
+ }
585
+ }
586
+
587
+ throw new DyFM_Error({
588
+ ...this._getDefaultErrorSettings('asyncConstruct', error),
589
+
590
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-001`,
591
+ additionalContent: {
592
+ constructErrors: this.constructErrors,
593
+ systemControls: this.systemControls,
594
+ systemReadies: {
595
+ app: this.systemControls.app.getIsReady(),
596
+ mongoose: this.systemControls.mongoose.getIsReady(),
597
+ httpServer: this.systemControls.httpServer.getIsReady(),
598
+ httpsServer: this.systemControls.httpsServer.getIsReady(),
599
+ },
600
+ },
601
+ });
602
+ }
603
+ }
604
+
605
+ async ready(timeout: number = this.defaultReadyTimeout): Promise<void> {
606
+ try {
607
+ if (this.fnLogs) DyFM_Log.log('\nfn:. ready');
608
+
609
+ await DyFM_Async.delay(100);
610
+
611
+ let ready: boolean = false;
612
+ const start: number = +new Date();
613
+
614
+ if (this.constructErrors.length) {
615
+ if (this.deepLog) {
616
+ if (DyNTS_global_settings.log_settings.highDetailedLogs) {
617
+ DyFM_Log.H_error(
618
+ `"${this._params.name}" start failed. (ready; constructErrors check 1)`,
619
+ `\n construct ERRORS:`, this.constructErrors
620
+ );
621
+ } else {
622
+ DyFM_Log.H_error(
623
+ `"${this._params.name}" start failed. (ready; constructErrors check 1)`,
624
+ `\n construct ERRORS:`, this.getSimplifiedConstructErrors(),
625
+ );
626
+ }
627
+ }
628
+
629
+ throw new DyFM_Error({
630
+ ...this._getDefaultErrorSettings(
631
+ 'ready',
632
+ new Error(`"${this._params.name}" start failed.`)
633
+ ),
634
+
635
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-R01`,
636
+ additionalContent:
637
+ this.constructErrors.length === 1 ?
638
+ { error: this.constructErrors[0] } :
639
+ { errors: this.constructErrors },
640
+ });
641
+ }
642
+
643
+ while (!ready && +new Date() - start < timeout) {
644
+ if (this.systemControls.app.init) {
645
+ ready = (
646
+ this.systemControls.mongoose.getIsReady() &&
647
+ this.systemControls.httpServer.getIsReady() &&
648
+ this.systemControls.httpsServer.getIsReady()
649
+ );
650
+ } else {
651
+ DyFM_Log.error(`"${this._params.name}" APP NOT INITIALIZED while trying to get ready.`);
652
+ }
653
+
654
+ if (!ready) {
655
+ await DyFM_Async.wait(100);
656
+ }
657
+ }
658
+
659
+ if (timeout < +new Date() - start) {
660
+ if (this.deepLog) {
661
+ if (DyNTS_global_settings.log_settings.highDetailedLogs) {
662
+ DyFM_Log.H_error(
663
+ `"${this._params.name}" start failed. (ready; TIMEOUT check)`,
664
+ `\n construct ERRORS:`, this.constructErrors
665
+ );
666
+ } else {
667
+ DyFM_Log.H_error(
668
+ `"${this._params.name}" start failed. (ready; TIMEOUT check)`,
669
+ `\n construct ERRORS:`, this.getSimplifiedConstructErrors(),
670
+ );
671
+ }
672
+ }
673
+
674
+ throw new DyFM_Error({
675
+ ...this._getDefaultErrorSettings(
676
+ 'ready',
677
+ new Error(`"${this._params.name}" start failed. TIMEOUT`)
678
+ ),
679
+
680
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-R02`,
681
+ additionalContent: {
682
+ constructErrors: this.constructErrors,
683
+ systemControls: this.systemControls,
684
+ systemReadies: {
685
+ mongoose: this.systemControls.mongoose.getIsReady(),
686
+ httpServer: this.systemControls.httpServer.getIsReady(),
687
+ httpsServer: this.systemControls.httpsServer.getIsReady(),
688
+ },
689
+ },
690
+ });
691
+ }
692
+
693
+ if (this.constructErrors.length) {
694
+ if (this.deepLog) {
695
+ if (DyNTS_global_settings.log_settings.highDetailedLogs) {
696
+ DyFM_Log.H_error(
697
+ `"${this._params.name}" start failed. (ready; constructErrors check 2)`,
698
+ `\n construct ERRORS:`, this.constructErrors
699
+ );
700
+ } else {
701
+ DyFM_Log.H_error(
702
+ `"${this._params.name}" start failed. (ready; constructErrors check 2)`,
703
+ `\n construct ERRORS:`, this.getSimplifiedConstructErrors(),
704
+ );
705
+ }
706
+ }
707
+
708
+ throw new DyFM_Error({
709
+ ...this._getDefaultErrorSettings(
710
+ 'ready',
711
+ new Error(`"${this._params.name}" start failed.`)
712
+ ),
713
+
714
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-R03`,
715
+ additionalContent: this.constructErrors,
716
+ });
717
+ }
718
+
719
+ if (ready) {
720
+ this.systemControls.app.started = true;
721
+
722
+ if (this.fnLogs && this.deepLog) DyFM_Log.log('\nfn:. ready: return');
723
+
724
+ return;
725
+ }
726
+
727
+ this.systemControls.app.started = false;
728
+
729
+ let msg: string = `"${this._params.name}" start failed. UNKNOWN`;
730
+
731
+ if (this.systemControls.mongoose.init && !this.systemControls.mongoose.started) {
732
+ msg += `\nMongoose start failed.`;
733
+ }
734
+
735
+ if (this.systemControls.httpServer.init && !this.systemControls.httpServer.started) {
736
+ msg += `\nHTTP Server start failed.`;
737
+ }
738
+
739
+ if (this.systemControls.httpsServer.init && !this.systemControls.httpsServer.started) {
740
+ msg += `\nHTTPS Server start failed.`;
741
+ }
742
+
743
+ DyFM_Log.error(msg, this.constructErrors);
744
+
745
+ throw new DyFM_Error({
746
+ ...this._getDefaultErrorSettings('ready', new Error(msg)),
747
+
748
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-R04`,
749
+ additionalContent: {
750
+ constructErrors: this.constructErrors,
751
+ systemControls: this.systemControls,
752
+ systemReadies: {
753
+ app: this.systemControls.app.getIsReady(),
754
+ mongoose: this.systemControls.mongoose.getIsReady(),
755
+ httpServer: this.systemControls.httpServer.getIsReady(),
756
+ httpsServer: this.systemControls.httpsServer.getIsReady(),
757
+ },
758
+ },
759
+ error: this.constructErrors?.[0] ?? new Error(),
760
+ });
761
+ } catch (error) {
762
+ throw new DyFM_Error({
763
+ ...this._getDefaultErrorSettings('ready', error),
764
+
765
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-READY0`,
766
+ });
767
+ }
768
+ }
769
+
770
+ protected getSimplifiedConstructErrors(): string[] {
771
+ return this.constructErrors.map((error: any): any => {
772
+ if (error instanceof DyFM_Error) {
773
+ return error.getErrorSimplified();
774
+ } else {
775
+ return error;
776
+ }
777
+ });
778
+ }
779
+
780
+ async stop(dontLog?: boolean): Promise<void> {
781
+ try {
782
+ DyFM_Log.info('\nstopping server...\n');
783
+
784
+ await this.ready();
785
+
786
+ if (this.started) {
787
+
788
+ if (this.systemControls.mongoose.init) {
789
+ DyFM_Log.info(`\nstopping Mongoose....`);
790
+
791
+ let tryCount: number = 0;
792
+
793
+ while (
794
+ !this.systemControls.mongoose.started &&
795
+ !this.constructErrors.length &&
796
+ tryCount++ < 10
797
+ ) {
798
+ DyFM_Log.warn(`Mongoose not even started yet....`);
799
+ await DyFM_Async.wait(second);
800
+ }
801
+ this.systemControls.mongoose.started = false;
802
+
803
+ if (this.mongoose) {
804
+ await DyFM_Array.asyncForEach(
805
+ Object.keys(this.mongoose.models),
806
+ async (modelName): Promise<void> => {
807
+ this.mongoose.deleteModel(modelName);
808
+ }
809
+ );
810
+
811
+ const disconnect: Promise<void> = new Promise((resolve): void => {
812
+ this.mongoose.connection.on('disconnecting', (): void => {
813
+ resolve();
814
+ });
815
+ });
816
+
817
+ await this.mongoose.disconnect();
818
+ await this.mongoose.connection.close();
819
+ await disconnect;
820
+
821
+ this.mongoose.connection.removeAllListeners();
822
+
823
+ while (
824
+ this.mongoose.connection.readyState !== 0 &&
825
+ !this.constructErrors.length
826
+ ) {
827
+ DyFM_Log.warn(`\nMongoose still not disconnected....`);
828
+ await DyFM_Async.wait(second);
829
+ }
830
+ } else {
831
+ DyFM_Log.error(`\nMongoose not found.`);
832
+ }
833
+ this.systemControls.mongoose.init = false;
834
+ }
835
+
836
+ if (this.systemControls.httpServer.init) {
837
+ this.systemControls.httpServer.started = false;
838
+
839
+ if (this.httpServer) {
840
+ await new Promise((resolve): void => {
841
+ this.httpServer.close(resolve);
842
+ });
843
+ } else {
844
+ DyFM_Log.error(`\nHTTP Server not found.`);
845
+ }
846
+ this.systemControls.httpServer.init = false;
847
+ }
848
+
849
+ if (this.systemControls.httpsServer.init) {
850
+ this.systemControls.httpsServer.started = false;
851
+
852
+ if (this.httpsServer) {
853
+ await new Promise((resolve): void => {
854
+ this.httpsServer.close(resolve);
855
+ });
856
+ } else {
857
+ DyFM_Log.error(`\nHTTPS Server not found.`);
858
+ }
859
+ this.systemControls.httpsServer.init = false;
860
+ }
861
+
862
+ await DyFM_Async.wait(second);
863
+
864
+ if (!dontLog) {
865
+ DyFM_Log.H_log(`"${this._params.name}" stopped successfully.`);
866
+ }
867
+ }
868
+ } catch (error) {
869
+ throw new DyFM_Error({
870
+ ...this._getDefaultErrorSettings('stop', error),
871
+
872
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-STOP0`,
873
+ });
874
+ }
875
+ }
876
+
877
+ /**
878
+ *
879
+ */
880
+ private async startDB(): Promise<void> {
881
+ if (this.fnLogs && this.deepLog) DyFM_Log.log('\nfn:. startDB');
882
+ else if (this.logSetup) DyFM_Log.log('\nstarting DB connection...');
883
+
884
+ if (!this._params.dbUri) {
885
+ throw new DyFM_Error({
886
+ ...this._getDefaultErrorSettings('startDB', new Error('DB URI is not set.')),
887
+
888
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-SDB0`,
889
+ });
890
+ }
891
+
892
+ if (!this._params.dbOptions) {
893
+ throw new DyFM_Error({
894
+ ...this._getDefaultErrorSettings('startDB', new Error('DB OPTIONS are not set.')),
895
+
896
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-SDB0`,
897
+ });
898
+ }
899
+
900
+ if (this.systemControls.mongoose.init || this.systemControls.mongoose.started) {
901
+ throw new DyFM_Error({
902
+ ...this._getDefaultErrorSettings('startDB', new Error('Mongoose is already initialized.')),
903
+
904
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-SDB0`,
905
+ });
906
+ }
907
+
908
+ try {
909
+ await new Promise<void>(
910
+ (resolve, reject): void => {
911
+ this.systemControls.mongoose.init = true;
912
+
913
+ this.mongoose.connection
914
+ .once('open', (): void => {
915
+ this.systemControls.mongoose.started = true;
916
+ DyFM_Log.success(`\nConnected to MongoDB (${this._params.dbUri})\n`);
917
+
918
+ resolve();
919
+ })
920
+ .on('error', (error): void => {
921
+ if (!this.systemControls.mongoose.started) {
922
+ // Initial DB-csatlakozás sikertelen:
923
+ // jelezzük a hibát (log + globalErrorHandler), de NEM szakítjuk meg az
924
+ // App startup-ot (nincs constructErrors push, nincs reject).
925
+ // A mongoose.init-et resetteljük, hogy a ready() ne várjon a DB-re.
926
+ // Ha a mongoose később mégis tudna csatlakozni, az 'open' event
927
+ // beállítja a started flag-et, így a runtime DB-műveletek elindulnak.
928
+ this.systemControls.mongoose.init = false;
929
+
930
+ const d_error: DyFM_Error = new DyFM_Error({
931
+ ...this._getDefaultErrorSettings('startDB', error),
932
+
933
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-SDB1`,
934
+ message: `Unable to connect to MongoDB server (${this._params.dbUri}), ` +
935
+ `ERROR: ${error}`,
936
+ level: DyFM_ErrorLevel.serious,
937
+ });
938
+
939
+ DyFM_Log.H_error(
940
+ `\nUnable to connect to MongoDB server (${this._params.dbUri}).` +
941
+ `\nServer will continue WITHOUT DB connection.` +
942
+ `\nDB-using endpoints will fail at runtime until connection recovers.`
943
+ );
944
+
945
+ if (this.debugLog) DyFM_Log.S_error(
946
+ `\nMongoDB connect ERROR: `,
947
+ error
948
+ );
949
+
950
+ DyNTS_GlobalService.globalErrorHandler?.(d_error);
951
+
952
+ resolve();
953
+
954
+ } else {
955
+ if (this.debugLog) DyFM_Log.error('\nMongoDB ERROR: ', error);
956
+
957
+ const d_error: DyFM_Error = new DyFM_Error({
958
+ ...this._getDefaultErrorSettings('mongoose.connection.on(error)', error),
959
+
960
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-SDB2`,
961
+ message: `MongoDB ERROR: ${error}`,
962
+ level: DyFM_ErrorLevel.critical,
963
+ });
964
+
965
+ DyNTS_GlobalService.globalErrorHandler?.(d_error);
966
+ }
967
+ });
968
+
969
+ try {
970
+ this.mongoose.connect(
971
+ this._params.dbUri,
972
+ this._params.dbOptions
973
+ /* {
974
+ directConnection: true,
975
+ } */
976
+ );
977
+ } catch (error) {
978
+ throw new DyFM_Error({
979
+ ...this._getDefaultErrorSettings('startDB', error),
980
+
981
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-SDB3`,
982
+ });
983
+ }
984
+ }
985
+ );
986
+ } catch (error) {
987
+ throw new DyFM_Error({
988
+ ...this._getDefaultErrorSettings('startDB', error),
989
+
990
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-SDB0`,
991
+ });
992
+ }
993
+
994
+ // 2026-06-20 — Mongo reconnect-guard. A MongoDB-driver a hostnevet connect-kor EGYSZER
995
+ // resolválja + cache-eli az IP-t; ha a Mongo-konténert recreate-elik (új docker-network IP),
996
+ // a driver a HALOTT IP-n ragad → ECONNREFUSED + buffering-timeout, és a service magától SOHA
997
+ // nem áll vissza. A guard sustained-disconnect (readyState !== 1) esetén — a driver saját
998
+ // grace-e UTÁN — TELJES disconnect()+connect()-et csinál → ÚJ MongoClient → ÚJ DNS-resolve →
999
+ // új IP → reconnect. Best-effort, always-on, healthy connection-t (===1) SOHA nem bánt; csak
1000
+ // konténer-IP-frissítés, nem ír adatot. Lásd: mongo-reconnect-guard.util.ts.
1001
+ try {
1002
+ startMongoReconnectGuard({
1003
+ getReadyState: (): number => this.mongoose.connection.readyState,
1004
+ reconnect: async (): Promise<void> => {
1005
+ await this.mongoose.disconnect().catch((): void => undefined);
1006
+ await this.mongoose.connect(this._params.dbUri, this._params.dbOptions);
1007
+ },
1008
+ log: (msg: string): void => DyFM_Log.warn(msg),
1009
+ });
1010
+ } catch (guardErr) {
1011
+ DyFM_Log.warn(`[mongo-reconnect-guard] failed to start (non-fatal): ${guardErr instanceof Error ? guardErr.message : String(guardErr)}`);
1012
+ }
1013
+ }
1014
+
1015
+ /**
1016
+ *
1017
+ */
1018
+ private async initExpresses(): Promise<void> {
1019
+ if (this.fnLogs && this.deepLog) DyFM_Log.log('\nfn:. initExpresses');
1020
+
1021
+ try {
1022
+ if (this._security && this._security !== DyNTS_RouteSecurity.secure) {
1023
+ if (this._portSettings.httpPort === undefined || this._portSettings.httpPort === null) {
1024
+ let errorMsg: string =
1025
+ `\nYou have open routes, but httpPort is not set!` +
1026
+ `\nThere are ${this._routingModules.filter(
1027
+ m => m.security != DyNTS_RouteSecurity.secure
1028
+ ).length} open/both routes` +
1029
+ `\nroot security: ${this._security}` +
1030
+ `\nset httpPort in DynamoBEServer - setupRoutingModules() to enable secure routes.`;
1031
+
1032
+ errorMsg += '\n\nThe routes setted to use open server:';
1033
+ this._routingModules.forEach((module: DyNTS_RoutingModule): void => {
1034
+ if (module.security != DyNTS_RouteSecurity.secure) {
1035
+ errorMsg += `\n ${module.route} (security: ${module.security})`;
1036
+ errorMsg += `\n subroutes using open sever:`;
1037
+ module.endpoints.forEach((endpoint: DyNTS_Endpoint_Params): void => {
1038
+ if (endpoint.security != DyNTS_RouteSecurity.secure) {
1039
+ errorMsg += `\n ${endpoint.endpoint} (security: ${endpoint.security})`;
1040
+ }
1041
+ });
1042
+ }
1043
+ });
1044
+
1045
+ const error = new Error(`Open routes cannot be established!\n${errorMsg}`);
1046
+ const errorStack: string[] = error.stack.split('\n');
1047
+
1048
+ errorStack.splice(1, 2);
1049
+ error.stack = errorStack.join('\n');
1050
+
1051
+ DyFM_Log.error(errorMsg);
1052
+
1053
+ throw error;
1054
+ }
1055
+
1056
+ await this.initOpenExpress();
1057
+ }
1058
+
1059
+ if (this._security && this._security !== DyNTS_RouteSecurity.open) {
1060
+ if (!this._cert || !this._portSettings.httpsPort) {
1061
+ let errorMsg: string =
1062
+ `\nYou have secure routes, but the certification paths or httpsPort are not set!` +
1063
+ `\nThere are ${this._routingModules.filter(
1064
+ m => m.security && m.security !== DyNTS_RouteSecurity.open
1065
+ ).length} secure routes` +
1066
+ `\nroot security: ${this._security}` +
1067
+ `\nset...` +
1068
+ `\n(missing exact howto...)` +
1069
+ /* `\n httpsPort and` +
1070
+ `\n cert: {` +
1071
+ `\n keyPath: FileSystem.PathLike,` +
1072
+ `\n certPath: FileSystem.PathLike,` +
1073
+ `\n }` + */
1074
+ `\nin DynamoBEServer - getRoutingModules() to enable secure routes.`;
1075
+
1076
+ errorMsg += '\n\nThe routes setted to use secure server:';
1077
+ this._routingModules.forEach((module: DyNTS_RoutingModule): void => {
1078
+ if (module.security && module.security !== DyNTS_RouteSecurity.open) {
1079
+ errorMsg += `\n ${module.route} (security: ${module.security})`;
1080
+ errorMsg += `\n location: ${module.stackLocation}`;
1081
+ errorMsg += `\n subroutes using secure sever:`;
1082
+ module.endpoints.forEach((endpoint: DyNTS_Endpoint_Params): void => {
1083
+ if (endpoint.security && endpoint.security !== DyNTS_RouteSecurity.open) {
1084
+ errorMsg += `\n ${endpoint.endpoint} (security: ${endpoint.security})`;
1085
+ errorMsg += `\n location: ${endpoint.stackLocation}`;
1086
+ }
1087
+ });
1088
+ }
1089
+ });
1090
+
1091
+ const error = new Error(`Secure routes cannot be established!\n${errorMsg}`);
1092
+ const errorStack: string[] = error.stack.split('\n');
1093
+
1094
+ errorStack.splice(1, 2);
1095
+ error.stack = errorStack.join('\n');
1096
+
1097
+ DyFM_Log.error(errorMsg);
1098
+
1099
+ throw error;
1100
+ }
1101
+
1102
+ await this.initSecureExpress();
1103
+ }
1104
+ } catch (error) {
1105
+ throw new DyFM_Error({
1106
+ ...this._getDefaultErrorSettings('initExpresses', error),
1107
+
1108
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-IE0`,
1109
+ });
1110
+ }
1111
+ }
1112
+
1113
+ /**
1114
+ *
1115
+ */
1116
+ protected async initOpenExpress(): Promise<void> {
1117
+ if (this.fnLogs) DyFM_Log.log('\nfn:. initOpenExpress');
1118
+ this.openExpress = Express();
1119
+ this.openExpress.set('maxHeaderSize', 10 * megabyte); // 1024 * 1024 * 10, // 10MB
1120
+ this.openExpress.use(BodyParser.urlencoded(this._portSettings.httpUrlencoded));
1121
+ this.openExpress.use(BodyParser.json(this._portSettings.httpJson));
1122
+ // FR-041 — CORS allowlist enforcement. No-op if getCorsSettings() is not overridden.
1123
+ this.mountCors(this.openExpress);
1124
+ }
1125
+
1126
+ /**
1127
+ *
1128
+ */
1129
+ protected async initSecureExpress(): Promise<void> {
1130
+ if (this.fnLogs) DyFM_Log.log('\nfn:. initSecureExpress');
1131
+ this.secureExpress = Express();
1132
+ this.secureExpress.use(BodyParser.urlencoded(this._portSettings.httpsUrlencoded));
1133
+ this.secureExpress.use(BodyParser.json(this._portSettings.httpsJson));
1134
+ // FR-041 — CORS allowlist enforcement (same as open express).
1135
+ this.mountCors(this.secureExpress);
1136
+
1137
+ const options = {
1138
+ key: FileSystem.readFileSync(this._cert.keyPath),
1139
+ cert: FileSystem.readFileSync(this._cert.certPath),
1140
+ maxHeaderSize: 10 * megabyte, // 1024 * 1024 * 10, // 10MB
1141
+ };
1142
+
1143
+ this.httpsServer = Https.createServer(options, this.secureExpress);
1144
+ }
1145
+
1146
+ /**
1147
+ *
1148
+ */
1149
+ private async startExpresses(): Promise<void> {
1150
+ if (this.fnLogs && this.deepLog) DyFM_Log.log('\nfn:. startExpresses');
1151
+
1152
+ try {
1153
+ if (this._security && this._security !== DyNTS_RouteSecurity.open) {
1154
+ await new Promise<void>((resolve, reject): void => {
1155
+ this.systemControls.httpsServer.init = true;
1156
+ this.httpsServer
1157
+ .listen(
1158
+ this._portSettings.httpsPort,
1159
+ this.params.secureHost,
1160
+ this.params.expressBacklog,
1161
+ (): void => {
1162
+ this.systemControls.httpsServer.started = true;
1163
+ DyFM_Log.success(
1164
+ `\nHTTPS (secure) server is listening on port: ` +
1165
+ `${this.params.secureHost}:${this._portSettings.httpsPort}`
1166
+ );
1167
+
1168
+ resolve();
1169
+ })
1170
+ .on('error', (error): void => {
1171
+ if (this.debugLog) DyFM_Log.error(`\nHTTPS (secure) server ERROR`, error);
1172
+
1173
+ if (!this.systemControls.httpsServer.started) {
1174
+ const d_error: DyFM_Error = new DyFM_Error({
1175
+ ...this._getDefaultErrorSettings('startExpresses', error),
1176
+
1177
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-SE1`,
1178
+ message: `HTTPS (secure) start server ERROR`,
1179
+ });
1180
+
1181
+ this.constructErrors.push(d_error);
1182
+ DyNTS_GlobalService.globalErrorHandler?.(d_error);
1183
+
1184
+ reject(d_error);
1185
+
1186
+ } else {
1187
+ const d_error: DyFM_Error = new DyFM_Error({
1188
+ ...this._getDefaultErrorSettings('httpsServer.on(error)', error),
1189
+
1190
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-SE2`,
1191
+ message: `HTTPS (secure) server ERROR`,
1192
+ level: DyFM_ErrorLevel.serious,
1193
+ });
1194
+
1195
+ DyNTS_GlobalService.globalErrorHandler?.(d_error);
1196
+ }
1197
+ })
1198
+ .on('uncaughtException', (exception): void => {
1199
+ const d_error: DyFM_Error = new DyFM_Error({
1200
+ ...this._getDefaultErrorSettings('httpsServer.on(uncaughtException)', exception),
1201
+
1202
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-SE3`,
1203
+ message: `HTTPS (secure) server uncaughtException`,
1204
+ level: DyFM_ErrorLevel.critical,
1205
+ });
1206
+
1207
+ if (this.debugLog) DyFM_Log.warn(
1208
+ `\nHTTPS (secure) server uncaughtException`,
1209
+ d_error
1210
+ );
1211
+
1212
+ DyNTS_GlobalService.globalErrorHandler?.(d_error);
1213
+ });
1214
+ });
1215
+ }
1216
+
1217
+ if (this._security && this._security !== DyNTS_RouteSecurity.secure) {
1218
+ this.systemControls.httpServer.init = true;
1219
+ await new Promise<void>((resolve, reject): void => {
1220
+ this.httpServer = this.openExpress
1221
+ .listen(
1222
+ this._portSettings.httpPort,
1223
+ this.params.openHost,
1224
+ this.params.expressBacklog,
1225
+ (): void => {
1226
+ this.systemControls.httpServer.started = true;
1227
+
1228
+ const resolvedPort: number = this.httpServer?.address?.()?.['port'] ?? this._portSettings.httpPort;
1229
+
1230
+ if (this._portSettings.httpPort === 0) {
1231
+ DyFM_Log.H_warn(
1232
+ `\nHTTP (open) server is using a randomly selected port by the OS: ${resolvedPort}` +
1233
+ `\n (httpPort was set to 0 — this is intended for testing only)`
1234
+ );
1235
+ }
1236
+
1237
+ DyFM_Log.success(
1238
+ `\nHTTP (open) server is listening on port: ` +
1239
+ `${this.params.openHost}:${resolvedPort}`
1240
+ );
1241
+
1242
+ resolve();
1243
+ }
1244
+ )
1245
+ .on('error', (error): void => {
1246
+ if (this.debugLog) DyFM_Log.error(`\nHTTP (open) server ERROR`, error);
1247
+
1248
+ if (!this.systemControls.httpServer.started) {
1249
+ const d_error: DyFM_Error = new DyFM_Error({
1250
+ ...this._getDefaultErrorSettings('startExpresses', error),
1251
+
1252
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-SE3`,
1253
+ message: `HTTP (open) start server ERROR`,
1254
+ });
1255
+
1256
+ this.constructErrors.push(d_error);
1257
+ DyNTS_GlobalService.globalErrorHandler?.(d_error);
1258
+
1259
+ reject(d_error);
1260
+
1261
+ } else {
1262
+ const d_error: DyFM_Error = new DyFM_Error({
1263
+ ...this._getDefaultErrorSettings('httpServer.on(error)', error),
1264
+
1265
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-SE4`,
1266
+ message: `HTTP (open) server ERROR`,
1267
+ level: DyFM_ErrorLevel.serious,
1268
+ });
1269
+
1270
+ DyNTS_GlobalService.globalErrorHandler?.(d_error);
1271
+ }
1272
+ })
1273
+ .on('uncaughtException', (exception): void => {
1274
+ const d_error: DyFM_Error = new DyFM_Error({
1275
+ ...this._getDefaultErrorSettings('httpServer.on(uncaughtException)', exception),
1276
+
1277
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-SE5`,
1278
+ message: `HTTP (open) server uncaughtException`,
1279
+ level: DyFM_ErrorLevel.critical,
1280
+ });
1281
+
1282
+ if (this.debugLog) {
1283
+ DyFM_Log.warn(`\nHTTP (open) server uncaughtException`, d_error);
1284
+ }
1285
+
1286
+ DyNTS_GlobalService.globalErrorHandler?.(d_error);
1287
+ });
1288
+ });
1289
+ }
1290
+ } catch (error) {
1291
+ throw new DyFM_Error({
1292
+ ...this._getDefaultErrorSettings('startExpresses', error),
1293
+
1294
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-SE0`,
1295
+ });
1296
+ }
1297
+ }
1298
+
1299
+ /**
1300
+ *
1301
+ */
1302
+ private async expressErrorHandling(error, req, res, next): Promise<void> {
1303
+ try {
1304
+ if (error) {
1305
+ const d_error: DyFM_Error = new DyFM_Error({
1306
+ ...this._getDefaultErrorSettings('expressErrorHandling', error),
1307
+
1308
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-EEH1`,
1309
+ message: `Express ERROR`,
1310
+ additionalContent: {
1311
+ req,
1312
+ res,
1313
+ },
1314
+ level: DyFM_ErrorLevel.error,
1315
+ });
1316
+
1317
+ await DyNTS_GlobalService.globalErrorHandler?.(d_error, req, res);
1318
+
1319
+ res.send(error)
1320
+ } else {
1321
+ DyFM_Log.H_error(
1322
+ 'WTF??? express error; without error?...' +
1323
+ '\nerr:', error,
1324
+ '\nreq:', req,
1325
+ '\nres:', res
1326
+ );
1327
+ }
1328
+ } catch (error) {
1329
+ DyFM_Log.H_error(
1330
+ 'MULTILEVEL ERROR (expressErrorHandling)....' +
1331
+ '\n', error
1332
+ );
1333
+ }
1334
+ }
1335
+
1336
+ /**
1337
+ *
1338
+ */
1339
+ private async mountSecureRoutes (): Promise<void> {
1340
+ try {
1341
+ if (this.fnLogs && this.deepLog) DyFM_Log.log('\nfn:. mountSecureRoutes');
1342
+
1343
+ if (!this.secureExpress) {
1344
+ throw new Error(
1345
+ 'secureExpress was not initialized. ' +
1346
+ 'Secure routes require getCertificationSettings and httpsPort, and cert files must exist.' +
1347
+ '\n\nYou need to set security to secure or both in any route and set httpsPort in getPortSettings.' +
1348
+ '\n\nYou need to set cert files in getCertificationSettings.'
1349
+ );
1350
+ }
1351
+
1352
+ this.secureExpress.use(
1353
+ (error, req, res, next): Promise<void> => this.expressErrorHandling(error, req, res, next)
1354
+ );
1355
+
1356
+ await DyFM_Array.asyncForEach(
1357
+ this._routingModules,
1358
+ async (module: DyNTS_RoutingModule): Promise<void> => {
1359
+ if (module.security !== DyNTS_RouteSecurity.open) {
1360
+ if (this.logSetup) {
1361
+ DyFM_Log.log(`route mount (secure): ${module.route}`);
1362
+ }
1363
+
1364
+ const existingRoutes: DyNTS_RoutingModule[] = this._routingModules.filter(
1365
+ (mod: DyNTS_RoutingModule): boolean => mod.route === module.route
1366
+ );
1367
+
1368
+ if (1 < existingRoutes.length) {
1369
+ const error: Error = new Error(`ROUTE DUPLICATION: ${module.route}`);
1370
+ /* const errorStack: string[] = error.stack.split('\n');
1371
+
1372
+ errorStack.splice(1, 4);
1373
+ error.stack = errorStack.join('\n'); */
1374
+ error.stack = module.stackLocation;
1375
+
1376
+ DyFM_Log.S_error(`ROUTE DUPLICATION: ${module.route}`, error);
1377
+
1378
+ throw new DyFM_Error({
1379
+ ...this._getDefaultErrorSettings('mountSecureRoutes', error),
1380
+
1381
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-MSR1`,
1382
+ message: `ROUTE DUPLICATION: ${module.route}`,
1383
+ });
1384
+ }
1385
+
1386
+ this.secureExpress.use(module.route, module.secureRouter);
1387
+ }
1388
+ }
1389
+ );
1390
+ } catch (error) {
1391
+ throw new DyFM_Error({
1392
+ ...this._getDefaultErrorSettings('mountSecureRoutes', error),
1393
+
1394
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-MSR0`,
1395
+ });
1396
+ }
1397
+ }
1398
+
1399
+ /**
1400
+ *
1401
+ */
1402
+ private async mountOpenRoutes(): Promise<void> {
1403
+ try {
1404
+ if (this.fnLogs && this.deepLog) DyFM_Log.log('\nfn:. mountOpenRoutes');
1405
+
1406
+ if (!this.openExpress) {
1407
+ throw new Error(
1408
+ 'openExpress was not initialized. Open routes require getOpenExpress and httpPort.' +
1409
+ '\n\nYou need to set security to open or both in any route and set httpPort in getPortSettings.'
1410
+ );
1411
+ }
1412
+
1413
+ this.openExpress.use(
1414
+ (error, req, res, next): Promise<void> => this.expressErrorHandling(error, req, res, next)
1415
+ );
1416
+
1417
+ await DyFM_Array.asyncForEach(
1418
+ this._routingModules,
1419
+ async (module: DyNTS_RoutingModule): Promise<void> => {
1420
+ if (module.security !== DyNTS_RouteSecurity.secure) {
1421
+ if (this.logSetup) {
1422
+ DyFM_Log.log(`route mount (open): ${module.route}`);
1423
+ }
1424
+
1425
+ const existingRoutes: DyNTS_RoutingModule[] = this._routingModules.filter(
1426
+ (mod: DyNTS_RoutingModule): boolean => mod.route === module.route
1427
+ );
1428
+
1429
+ if (1 < existingRoutes.length) {
1430
+ const error: Error = new Error(`ROUTE DUPLICATION: ${module.route}`);
1431
+ /* const errorStack: string[] = error.stack.split('\n');
1432
+
1433
+ errorStack.splice(1, 4);
1434
+ error.stack = errorStack.join('\n'); */
1435
+ error.stack = module.stackLocation;
1436
+
1437
+ DyFM_Log.S_error(`ROUTE DUPLICATION: ${module.route}`, error);
1438
+
1439
+ throw new DyFM_Error({
1440
+ ...this._getDefaultErrorSettings('mountOpenRoutes', error),
1441
+
1442
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-MOR1`,
1443
+ message: `ROUTE DUPLICATION: ${module.route}`,
1444
+ });
1445
+ }
1446
+
1447
+ this.openExpress.use(module.route, module.openRouter);
1448
+ }
1449
+ }
1450
+ );
1451
+ } catch (error) {
1452
+ throw new DyFM_Error({
1453
+ ...this._getDefaultErrorSettings('mountOpenRoutes', error),
1454
+
1455
+ errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-AS0-MOR0`,
1456
+ });
1457
+ }
1458
+ }
1459
+
1460
+ /**
1461
+ * FR-041 — CORS middleware. Echoes a matching `Access-Control-Allow-Origin`
1462
+ * for any request whose Origin header is in `getCorsSettings().allowedOrigins`,
1463
+ * adds the canonical `Access-Control-*` companion headers, and short-circuits
1464
+ * the OPTIONS preflight with a 204.
1465
+ *
1466
+ * No-op when the subclass does NOT override `getCorsSettings()` — preserves
1467
+ * back-compat for apps that have always been same-origin and never needed
1468
+ * CORS (the typical pre-FR-041 case).
1469
+ *
1470
+ * Why hand-rolled instead of the `cors` npm package:
1471
+ * - ~30 lines, zero new dependency.
1472
+ * - Full control over Vary/credentials/preflight semantics.
1473
+ * - Aligns with FDP "no unnecessary deps" philosophy.
1474
+ */
1475
+ protected mountCors(express: Express.Application): void {
1476
+ const settings: DyNTS_Cors_Settings | undefined = this.getCorsSettings?.();
1477
+ if (!settings) {
1478
+ return;
1479
+ }
1480
+
1481
+ const allowCreds: boolean = settings.allowCredentials !== false;
1482
+ const methods: string[] = settings.allowedMethods ?? [
1483
+ 'GET', 'POST', 'PUT', 'DELETE', 'PATCH', 'OPTIONS',
1484
+ ];
1485
+ const headers: string[] = settings.allowedHeaders ?? [
1486
+ 'Authorization', 'Content-Type', 'X-Admin-Key', 'X-Requested-With',
1487
+ ];
1488
+ const exposed: string[] = settings.exposedHeaders ?? [
1489
+ 'Content-Length', 'Content-Type',
1490
+ ];
1491
+ const maxAge: number = settings.maxAgeSeconds ?? 86400;
1492
+
1493
+ const isAllowed: (origin: string) => boolean = (origin: string): boolean => {
1494
+ if (settings.allowedOrigins === '*') return true;
1495
+ if (typeof settings.allowedOrigins === 'function') {
1496
+ return settings.allowedOrigins(origin);
1497
+ }
1498
+ return settings.allowedOrigins.includes(origin);
1499
+ };
1500
+
1501
+ express.use((req: Express.Request, res: Express.Response, next: Express.NextFunction): void => {
1502
+ const origin: string | undefined = req.headers.origin;
1503
+ if (origin && isAllowed(origin)) {
1504
+ // Echo the matching origin (NOT wildcard) because credentials require it.
1505
+ res.setHeader('Access-Control-Allow-Origin', origin);
1506
+ if (allowCreds) {
1507
+ res.setHeader('Access-Control-Allow-Credentials', 'true');
1508
+ }
1509
+ res.setHeader('Access-Control-Allow-Methods', methods.join(', '));
1510
+ res.setHeader('Access-Control-Allow-Headers', headers.join(', '));
1511
+ res.setHeader('Access-Control-Expose-Headers', exposed.join(', '));
1512
+ res.setHeader('Access-Control-Max-Age', String(maxAge));
1513
+ res.setHeader('Vary', 'Origin');
1514
+ }
1515
+ if (req.method === 'OPTIONS') {
1516
+ res.status(204).end();
1517
+ return;
1518
+ }
1519
+ next();
1520
+ });
1521
+ }
1522
+
1523
+ /**
1524
+ * Generikus, auth-agnosztikus extension-point orchestrator. A `registerCustomMiddleware`
1525
+ * hookot hívja (ha a subclass override-olja) minden AKTÍV Express instance-ra
1526
+ * (open + secure), az API route-ok UTÁN, de a SPA static catch-all (`app.get('*')`)
1527
+ * ELŐTT — ez az EGYETLEN korrekt pont egy sub-path middleware-hez (pl. reverse-proxy),
1528
+ * mert a catch-all minden utána mountolt route-ot elnyel. No-op ha nincs override (back-compat).
1529
+ */
1530
+ private async mountCustomMiddleware(): Promise<void> {
1531
+ if (!this.registerCustomMiddleware) {
1532
+ return;
1533
+ }
1534
+
1535
+ if (this.openExpress) {
1536
+ await this.registerCustomMiddleware(this.openExpress, DyNTS_RouteSecurity.open);
1537
+ }
1538
+
1539
+ if (this.secureExpress) {
1540
+ await this.registerCustomMiddleware(this.secureExpress, DyNTS_RouteSecurity.secure);
1541
+ }
1542
+
1543
+ if (this.logSetup) {
1544
+ DyFM_Log.log('\nCustom middleware registered (pre-static).');
1545
+ }
1546
+ }
1547
+
1548
+ /**
1549
+ * Ha getStaticClientSettings() visszaad beállításokat, a client static fájlok a '/' alatt
1550
+ * lesznek kiszolgálva (API route-ok után). SPA fallback opcionális (fallbackPath).
1551
+ * Asset cache (assetCacheMaxAge, assetCacheImmutable) és fallback cache (fallbackCacheMaxAge)
1552
+ * opcionálisak; ha nincs megadva fallbackCacheMaxAge, DyNTS_defaultFallbackCacheMaxAge (0) marad.
1553
+ */
1554
+ private async mountStaticClient(): Promise<void> {
1555
+ const settings: DyNTS_StaticClient_Settings | undefined = this.getStaticClientSettings?.();
1556
+ if (!settings) {
1557
+ return;
1558
+ }
1559
+
1560
+ const absoluteRoot: string = Path.isAbsolute(settings.root)
1561
+ ? settings.root
1562
+ : Path.resolve(process.cwd(), settings.root);
1563
+
1564
+ const hasAssetCache: boolean =
1565
+ settings.assetCacheMaxAge !== undefined || settings.assetCacheImmutable === true;
1566
+ const staticOptions: { setHeaders: (res: Express.Response) => void } | undefined =
1567
+ hasAssetCache && settings.assetCacheMaxAge !== undefined
1568
+ ? {
1569
+ setHeaders: (res: Express.Response): void => {
1570
+ const maxAge: number = settings.assetCacheMaxAge!;
1571
+ const immutable: string =
1572
+ settings.assetCacheImmutable === true ? ', immutable' : '';
1573
+ res.setHeader('Cache-Control', `max-age=${maxAge}${immutable}`);
1574
+ },
1575
+ }
1576
+ : undefined;
1577
+
1578
+ const staticMiddleware: Express.Handler =
1579
+ staticOptions
1580
+ ? Express.static(absoluteRoot, staticOptions)
1581
+ : Express.static(absoluteRoot);
1582
+
1583
+ const fallbackMaxAge: number =
1584
+ settings.fallbackCacheMaxAge ?? DyNTS_defaultFallbackCacheMaxAge;
1585
+
1586
+ if (this.openExpress) {
1587
+ this.openExpress.use('/', staticMiddleware);
1588
+ if (settings.fallbackPath) {
1589
+ this.openExpress.get('*', (req: Express.Request, res: Express.Response): void => {
1590
+ res.setHeader('Cache-Control', `max-age=${fallbackMaxAge}`);
1591
+ res.sendFile(settings.fallbackPath!, { root: absoluteRoot });
1592
+ });
1593
+ } else {
1594
+ this.openExpress.get('*', (req: Express.Request, res: Express.Response): void => {
1595
+ res.status(404).type('html').send(DyNTS_defaultNotFoundPageHtml);
1596
+ });
1597
+ }
1598
+ }
1599
+
1600
+ if (this.secureExpress) {
1601
+ this.secureExpress.use('/', staticMiddleware);
1602
+ if (settings.fallbackPath) {
1603
+ this.secureExpress.get('*', (req: Express.Request, res: Express.Response): void => {
1604
+ res.setHeader('Cache-Control', `max-age=${fallbackMaxAge}`);
1605
+ res.sendFile(settings.fallbackPath!, { root: absoluteRoot });
1606
+ });
1607
+ } else {
1608
+ this.secureExpress.get('*', (req: Express.Request, res: Express.Response): void => {
1609
+ res.status(404).type('html').send(DyNTS_defaultNotFoundPageHtml);
1610
+ });
1611
+ }
1612
+ }
1613
+
1614
+ if (this.logSetup) {
1615
+ DyFM_Log.log(`\nStatic client mounted at / (root: ${absoluteRoot})`);
1616
+ }
1617
+ }
1618
+
1619
+ /**
1620
+ *
1621
+ */
1622
+ private setSecurity(): void {
1623
+ if (this.fnLogs && this.deepLog) DyFM_Log.log('\nfn:. setSecurity');
1624
+ this._routingModules.forEach((module: DyNTS_RoutingModule): void => {
1625
+ if (!module.security) {
1626
+ DyFM_Log.warn(`RoutingModule security is not set for ${module.route}\n`);
1627
+
1628
+ } else if (!this._security) {
1629
+ this._security = module.security;
1630
+
1631
+ } else if (this._security !== module.security) {
1632
+ this._security = DyNTS_RouteSecurity.both;
1633
+ }
1634
+ });
1635
+
1636
+ if (!this._security) {
1637
+ let msg = `Could not set security for the server! (${this.security})`;
1638
+
1639
+ msg += '\n RoutingModules:';
1640
+ this._routingModules.forEach((module: DyNTS_RoutingModule): void => {
1641
+ msg += `\n ${module.route} (security: ${module.security})`;
1642
+ });
1643
+
1644
+ if (this._routingModules.length === 0) {
1645
+ msg += '\n - no RoutingModule found -\n';
1646
+ }
1647
+ DyFM_Log.warn(msg);
1648
+ }
1649
+ }
1650
+
1651
+ private _getDefaultErrorSettings(
1652
+ fnName: string,
1653
+ error: DyFM_AnyError
1654
+ ): DyFM_Error_Settings {
1655
+ return {
1656
+ status: (error as DyFM_Error)?.___status ?? 500,
1657
+ message: (error as Error)?.message ??
1658
+ (error as DyFM_Error)?._message ??
1659
+ `${fnName} was UNSUCCESSFUL (NTS)`,
1660
+ userMessage: (error as DyFM_Error)?.__userMessage ?? this.defaultErrorUserMsg,
1661
+ addECToUserMsg: !(error as DyFM_Error)?.__userMessage,
1662
+ issuerService: `${this?.constructor?.name}-DyNTS_App`,
1663
+ level: DyFM_ErrorLevel.fatal,
1664
+ error: error,
1665
+ systemVersion: DyNTS_global_settings.systemVersion,
1666
+ };
1667
+ }
1668
+
1669
+ /**
1670
+ * MISSING Description (TODO)
1671
+ */
1672
+ abstract getAppParams(): DyNTS_App_Params;
1673
+
1674
+ /**
1675
+ * MISSING Description (TODO)
1676
+ */
1677
+ abstract getGlobalServiceCollection(): DyNTS_GlobalService_Settings;
1678
+
1679
+ /**
1680
+ * MISSING Description (TODO)
1681
+ */
1682
+ abstract getPortSettings(): DyNTS_Http_Settings;
1683
+
1684
+ /**
1685
+ * MISSING Description (TODO)
1686
+ */
1687
+ overrideDynamoNTSGlobalSettings?(): void;
1688
+
1689
+ /**
1690
+ * Ha megadva, a visszaadott értéket használjuk a route prefix-ként
1691
+ * (DyNTS_global_settings.baseUrl felülírása erre az app-ra).
1692
+ */
1693
+ getApiBasePath?(): string;
1694
+
1695
+ /**
1696
+ * MISSING Description (TODO)
1697
+ */
1698
+ getRoutingModules?(): DyNTS_RoutingModule[];
1699
+
1700
+ /**
1701
+ * MISSING Description (TODO)
1702
+ */
1703
+ getRootServices?(): Promise<any[]>;
1704
+
1705
+ /**
1706
+ * MISSING Description (TODO)
1707
+ */
1708
+ getCertificationSettings?(): DyNTS_Certification_Settings;
1709
+
1710
+ /**
1711
+ * Ha megadva, a client static fájlok a '/' alatt lesznek kiszolgálva (API route-ok után).
1712
+ * Opcionális fallbackPath pl. SPA index.html-hez.
1713
+ */
1714
+ getStaticClientSettings?(): DyNTS_StaticClient_Settings | undefined;
1715
+
1716
+ /**
1717
+ * FR-041 — Ha megadva, CORS middleware mount-olódik mindkét Express instance-ra
1718
+ * (open + secure). Az `allowedOrigins` listán szereplő Origin-eket echo-zza vissza,
1719
+ * `Access-Control-Allow-Credentials: true`-val (default) együtt a Bearer JWT
1720
+ * cross-domain auth flow miatt. OPTIONS preflight 204-gyel rövidre záródik.
1721
+ * Ha undefined → no CORS headers, no preflight handling — back-compat.
1722
+ */
1723
+ getCorsSettings?(): DyNTS_Cors_Settings | undefined;
1724
+
1725
+ /**
1726
+ * Opcionális generikus hook: custom Express middleware regisztrálása az API route-ok
1727
+ * UTÁN és a SPA static catch-all ELŐTT. Auth-AGNOSZTIKUS framework extension-point —
1728
+ * a subclass (pl. FDP base App) ezen keresztül mount-olhat reverse-proxyt egy sub-path-re
1729
+ * (pl. `/auth-api`), ami a `app.get('*')` catch-all elé kell kerüljön. A hívási időzítést
1730
+ * lásd: `mountCustomMiddleware`. Undefined → no-op (back-compat).
1731
+ */
1732
+ registerCustomMiddleware?(
1733
+ express: Express.Application,
1734
+ security: DyNTS_RouteSecurity,
1735
+ ): void | Promise<void>;
1736
+
1737
+ /**
1738
+ * MISSING Description (TODO)
1739
+ */
1740
+ createEntries?(): Promise<void>;
1741
+
1742
+ /**
1743
+ * MISSING Description (TODO)
1744
+ */
1745
+ postProcess?(): Promise<void>;
1746
+
1747
+ }