@futdevpro/nts-dynamo 1.15.83 → 1.15.84

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 (360) hide show
  1. package/.c8rc.json +26 -26
  2. package/.copilot/patterns.json +7 -7
  3. package/.cursor/rules/__assistant_guide.mdc +30 -30
  4. package/.cursor/rules/_ag_backend-structure.mdc +85 -85
  5. package/.cursor/rules/_ag_backend.mdc +16 -16
  6. package/.cursor/rules/_ag_frontend-structure.mdc +86 -86
  7. package/.cursor/rules/_ag_frontend.mdc +39 -39
  8. package/.cursor/rules/_ag_import-rules.mdc +44 -44
  9. package/.cursor/rules/_ag_naming.mdc +115 -115
  10. package/.cursor/rules/_ag_should-be.mdc +6 -6
  11. package/.cursor/rules/ai_development_guide.md +60 -60
  12. package/.cursor/rules/cursor-rules.md +160 -160
  13. package/.cursor/rules/default-command.mdc +464 -464
  14. package/.cursor/rules/error_code_pattern.md +39 -39
  15. package/.cursor/rules/saved rule mcp server use.md +15 -15
  16. package/.vscode/settings.json +10 -10
  17. package/HOWTO.md +15 -15
  18. package/LICENSE +21 -21
  19. package/__documentations/nts-integration-tests-2026-03-17.md +26 -26
  20. package/__documentations/plans/BEDROCK-HYPERPLAN.md +95 -95
  21. package/_specifications/BACKLOG.md +92 -92
  22. package/_specifications/TODO.md +15 -15
  23. package/_specifications/agent.md +138 -138
  24. package/build/_modules/server/errors/errors.controller.d.ts.map +1 -1
  25. package/build/_modules/server/errors/errors.controller.js +12 -1
  26. package/build/_modules/server/errors/errors.controller.js.map +1 -1
  27. package/eslint.config.js +3 -3
  28. package/nodemon.json +24 -24
  29. package/package.json +3 -3
  30. package/pnpm-workspace.yaml +5 -5
  31. package/scripts/run-coverage-tests.js +28 -28
  32. package/spec/support/helpers/spec-reporter-loader.js +359 -359
  33. package/spec/support/helpers/ts-node-helper.js +93 -93
  34. package/spec/support/jasmine.coverage.json +24 -24
  35. package/spec/support/jasmine.json +24 -24
  36. package/src/_collections/archive.util.spec.ts +57 -57
  37. package/src/_collections/archive.util.ts +18 -18
  38. package/src/_collections/atlas-default-db-options.const.ts +9 -9
  39. package/src/_collections/default-fallback-cache-max-age.const.spec.ts +11 -11
  40. package/src/_collections/default-fallback-cache-max-age.const.ts +2 -2
  41. package/src/_collections/default-not-found-page.const.spec.ts +19 -19
  42. package/src/_collections/default-not-found-page.const.ts +22 -22
  43. package/src/_collections/default-socket-path.const.spec.ts +12 -12
  44. package/src/_collections/default-socket-path.const.ts +2 -2
  45. package/src/_collections/get-environment-settings.util.spec.ts +210 -210
  46. package/src/_collections/get-environment-settings.util.ts +48 -48
  47. package/src/_collections/global-settings.const.ts +109 -109
  48. package/src/_collections/sample.env +21 -21
  49. package/src/_collections/star.controller.spec.ts +224 -224
  50. package/src/_collections/star.controller.ts +129 -129
  51. package/src/_enums/data-model-type.enum.ts +14 -14
  52. package/src/_enums/data-service-function.enum.ts +24 -24
  53. package/src/_enums/predefined-data-types.enum.ts +16 -16
  54. package/src/_enums/route-security.enum.ts +12 -12
  55. package/src/_models/control-models/api-call-params.control-model.spec.ts +152 -152
  56. package/src/_models/control-models/api-call-params.control-model.ts +142 -142
  57. package/src/_models/control-models/app-ext-system-controls.control-model.spec.ts +52 -52
  58. package/src/_models/control-models/app-ext-system-controls.control-model.ts +9 -9
  59. package/src/_models/control-models/app-params.control-model.spec.ts +225 -225
  60. package/src/_models/control-models/app-params.control-model.ts +136 -136
  61. package/src/_models/control-models/app-system-controls.control-model.spec.ts +31 -31
  62. package/src/_models/control-models/app-system-controls.control-model.ts +9 -9
  63. package/src/_models/control-models/endpoint-params.control-model.spec.ts +627 -627
  64. package/src/_models/control-models/endpoint-params.control-model.ts +627 -627
  65. package/src/_models/control-models/http-settings.control-model.spec.ts +77 -77
  66. package/src/_models/control-models/http-settings.control-model.ts +37 -37
  67. package/src/_models/control-models/system-control.control-model.spec.ts +27 -27
  68. package/src/_models/control-models/system-control.control-model.ts +12 -12
  69. package/src/_models/interfaces/certification-settings.interface.ts +7 -7
  70. package/src/_models/interfaces/environment-settings.interface.ts +59 -59
  71. package/src/_models/interfaces/global-log-settings.interface.ts +171 -171
  72. package/src/_models/interfaces/global-service-settings.interface.ts +47 -47
  73. package/src/_models/interfaces/global-settings.interface.ts +235 -235
  74. package/src/_models/interfaces/routing-module-settings.interface.ts +21 -21
  75. package/src/_models/interfaces/static-client-settings.interface.spec.ts +29 -29
  76. package/src/_models/interfaces/static-client-settings.interface.ts +28 -28
  77. package/src/_models/types/db-update.type.ts +100 -100
  78. package/src/_modules/ai/_models/ai-input-interfaces.ts +117 -117
  79. package/src/_modules/ai/_models/ai-test-generation-result.interface.ts +16 -16
  80. package/src/_modules/ai/_modules/anthropic/_services/aai-user-key.control-service.ts +138 -138
  81. package/src/_modules/ai/_modules/anthropic/index.ts +5 -5
  82. package/src/_modules/ai/_modules/document-ai/_collections/dai-chunking.util.spec.ts +242 -242
  83. package/src/_modules/ai/_modules/document-ai/_collections/dai-chunking.util.ts +639 -639
  84. package/src/_modules/ai/_modules/document-ai/_collections/dai-code-chunking.util.spec.ts +295 -295
  85. package/src/_modules/ai/_modules/document-ai/_collections/dai-code-chunking.util.ts +518 -518
  86. package/src/_modules/ai/_modules/document-ai/_collections/dai-document.util.spec.ts +209 -209
  87. package/src/_modules/ai/_modules/document-ai/_collections/dai-document.util.ts +85 -85
  88. package/src/_modules/ai/_modules/document-ai/_enums/dai-compare-result-type.enum.ts +7 -7
  89. package/src/_modules/ai/_modules/document-ai/_models/data-models/dai-doc-chunk.data-model.ts +146 -146
  90. package/src/_modules/ai/_modules/document-ai/_models/data-models/dai-doc-page.data-model.ts +162 -162
  91. package/src/_modules/ai/_modules/document-ai/_models/data-models/dai-document.data-model.ts +99 -99
  92. package/src/_modules/ai/_modules/document-ai/_models/interfaces/dai-code-chunk.interface.ts +68 -68
  93. package/src/_modules/ai/_modules/document-ai/_models/interfaces/dai-doc-chunk-compare-result.interface.ts +18 -18
  94. package/src/_modules/ai/_modules/document-ai/_models/interfaces/dai-doc-page-compare-result.interface.ts +19 -19
  95. package/src/_modules/ai/_modules/document-ai/_models/interfaces/dai-document-compare-result.interface.ts +25 -25
  96. package/src/_modules/ai/_modules/document-ai/index.ts +30 -30
  97. package/src/_modules/ai/_modules/fdp-ai/_services/fdpai-user-key.control-service.ts +189 -189
  98. package/src/_modules/ai/_modules/fdp-ai/index.ts +5 -5
  99. package/src/_modules/ai/_modules/open-ai/_collections/oai-global-settings.const.ts +9 -9
  100. package/src/_modules/ai/_modules/open-ai/_collections/oai-llm-predefined-requests-hu.conts.ts +82 -82
  101. package/src/_modules/ai/_modules/open-ai/_collections/oai-llm-predefined-requests.conts.ts +75 -75
  102. package/src/_modules/ai/_modules/open-ai/_enums/oai-gpt-message-role.enum.ts +45 -45
  103. package/src/_modules/ai/_modules/open-ai/_models/interfaces/oai-global-settings.interface.ts +7 -7
  104. package/src/_modules/ai/_modules/open-ai/_models/interfaces/oai-gpt-message.interface.ts +7 -7
  105. package/src/_modules/ai/_modules/open-ai/_models/interfaces/oai-llm-predefined-requests.interface.ts +57 -57
  106. package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-doc-chunk-data.service.ts +292 -292
  107. package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-document.data-service.spec.ts +342 -342
  108. package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-vector-data.service.spec.ts +550 -550
  109. package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-vector-data.service.ts +630 -630
  110. package/src/_modules/ai/_modules/open-ai/_services/oai-embedding.control-service.spec.ts +332 -332
  111. package/src/_modules/ai/_modules/open-ai/_services/oai-llm-chat.service-base.spec.ts +462 -462
  112. package/src/_modules/ai/_modules/open-ai/_services/oai-llm-chat.service-base.ts +634 -634
  113. package/src/_modules/ai/_modules/open-ai/_services/oai-llm.service-base.spec.ts +489 -489
  114. package/src/_modules/ai/_modules/open-ai/_services/oai-llm.service-base.tools.spec.ts +173 -173
  115. package/src/_modules/ai/_modules/open-ai/_services/oai-llm.service-base.ts +1033 -1033
  116. package/src/_modules/ai/_modules/open-ai/_services/oai-user-key.control-service.ts +157 -157
  117. package/src/_modules/ai/_services/ai-embedding-mock.service.spec.ts +115 -115
  118. package/src/_modules/ai/_services/ai-embedding-mock.service.ts +212 -212
  119. package/src/_modules/ai/_services/ai-embedding-provider.registry.spec.ts +110 -110
  120. package/src/_modules/ai/_services/ai-embedding-provider.registry.ts +110 -110
  121. package/src/_modules/ai/_services/ai-embedding.service-base.spec.ts +98 -98
  122. package/src/_modules/ai/_services/ai-embedding.service-base.ts +48 -48
  123. package/src/_modules/ai/_services/ai-llm-chat.service-base.spec.ts +229 -229
  124. package/src/_modules/ai/_services/ai-llm-chat.service-base.ts +68 -68
  125. package/src/_modules/ai/_services/ai-llm.service-base.spec.ts +250 -250
  126. package/src/_modules/ai/_services/ai-llm.service-base.ts +519 -519
  127. package/src/_modules/ai/_services/ai-provider.service-base.spec.ts +158 -158
  128. package/src/_modules/ai/_services/ai-user-key.service-base.ts +59 -59
  129. package/src/_modules/ai/_services/lmstudio-embedding.control-service.spec.ts +197 -197
  130. package/src/_modules/ai/_services/lmstudio-embedding.control-service.ts +371 -371
  131. package/src/_modules/ai/index.ts +23 -23
  132. package/src/_modules/assistant/_collections/ass-global-settings.const.ts +13 -13
  133. package/src/_modules/assistant/_collections/ass.util.spec.ts +176 -176
  134. package/src/_modules/assistant/_collections/ass.util.ts +50 -50
  135. package/src/_modules/assistant/_models/ass-global-settings.interface.ts +15 -15
  136. package/src/_modules/assistant/_services/ass-io.control-service.spec.ts +140 -140
  137. package/src/_modules/assistant/_services/ass-main.control-service.spec.ts +192 -192
  138. package/src/_modules/assistant/_services/ass-main.control-service.ts +107 -107
  139. package/src/_modules/bot/_collections/bot-default-commands.const.ts +12 -12
  140. package/src/_modules/bot/_collections/bot-global-settings.const.ts +39 -39
  141. package/src/_modules/bot/_models/bot-channel-wrapper.interface.ts +62 -62
  142. package/src/_modules/bot/_models/bot-command.interface.ts +8 -8
  143. package/src/_modules/bot/_models/bot-global-settings.interface.ts +96 -96
  144. package/src/_modules/bot/_models/bot-last-mention-date.interface.ts +6 -6
  145. package/src/_modules/bot/_models/bot-last-message-date.interface.ts +5 -5
  146. package/src/_modules/bot/_models/bot-user-wrapper.interface.ts +41 -41
  147. package/src/_modules/bot/_modules/discord-bot/_models/dib-platform.types.ts +9 -9
  148. package/src/_modules/bot/_modules/discord-bot/_services/dib-messaging-provider.control-service.spec.ts +431 -431
  149. package/src/_modules/bot/_modules/dynamo-bot/_collections/dyb-operations.util.spec.ts +160 -160
  150. package/src/_modules/bot/_modules/dynamo-bot/_collections/dyb-operations.util.ts +55 -55
  151. package/src/_modules/bot/_modules/dynamo-bot/_models/dyb-platform.types.ts +15 -15
  152. package/src/_modules/bot/_modules/dynamo-bot/_services/dyb-messaging-provider.control-service.spec.ts +374 -374
  153. package/src/_modules/bot/_modules/dynamo-bot/_services/dyb-messaging-provider.control-service.ts +447 -447
  154. package/src/_modules/bot/_modules/dynamo-bot/index.ts +15 -15
  155. package/src/_modules/bot/_modules/slack-bot/_models/slb-platform.types.ts +9 -9
  156. package/src/_modules/bot/_modules/slack-bot/_services/slb-messaging-provider.control-service.spec.ts +344 -344
  157. package/src/_modules/bot/_modules/slack-bot/_services/slb-messaging-provider.control-service.ts +197 -197
  158. package/src/_modules/bot/_modules/teams-bot/_models/teb-platform.types.ts +9 -9
  159. package/src/_modules/bot/_modules/teams-bot/_services/teb-messaging-provider.control-service.spec.ts +345 -345
  160. package/src/_modules/bot/_modules/teams-bot/_services/teb-messaging-provider.control-service.ts +197 -197
  161. package/src/_modules/bot/_services/bot-commands.control-service.spec.ts +116 -116
  162. package/src/_modules/bot/_services/bot-io.control-service.spec.ts +285 -285
  163. package/src/_modules/bot/_services/bot-main.control-service.spec.ts +208 -208
  164. package/src/_modules/bot/_services/bot-messaging-provider.service-base.spec.ts +349 -349
  165. package/src/_modules/bot/_services/bot-routines.control-service.spec.ts +111 -111
  166. package/src/_modules/custom-data/custom-data.controller.spec.ts +49 -49
  167. package/src/_modules/custom-data/custom-data.controller.ts +67 -67
  168. package/src/_modules/custom-data/custom-data.data-service.spec.ts +54 -54
  169. package/src/_modules/custom-data/custom-data.data-service.ts +21 -21
  170. package/src/_modules/custom-data/get-custom-data-routing-module.util.spec.ts +28 -28
  171. package/src/_modules/custom-data/get-custom-data-routing-module.util.ts +24 -24
  172. package/src/_modules/custom-data/index.ts +9 -9
  173. package/src/_modules/data-readers/_collections/dynts-sqlite-reader.util.spec.ts +161 -161
  174. package/src/_modules/data-readers/_collections/dynts-sqlite-reader.util.ts +203 -203
  175. package/src/_modules/data-readers/_models/interfaces/dynts-sqlite-reader.interface.ts +33 -33
  176. package/src/_modules/data-readers/index.ts +11 -11
  177. package/src/_modules/defaults/_collections/default-endpoints.util.ts +487 -487
  178. package/src/_modules/defaults/_models/default-user.data-model.ts +72 -72
  179. package/src/_modules/defaults/_services/default-auth.service.spec.ts +269 -269
  180. package/src/_modules/defaults/_services/default-auth.service.ts +177 -177
  181. package/src/_modules/defaults/_services/default-socket-events.service.spec.ts +42 -42
  182. package/src/_modules/defaults/_services/default-socket-events.service.ts +61 -61
  183. package/src/_modules/defaults/_services/default-user.data-service.spec.ts +187 -187
  184. package/src/_modules/defaults/_services/default-user.data-service.ts +98 -98
  185. package/src/_modules/defaults/index.ts +17 -17
  186. package/src/_modules/discord-assistant/_collections/dias-global-settings.const.ts +19 -19
  187. package/src/_modules/discord-assistant/_collections/dias.util.spec.ts +366 -366
  188. package/src/_modules/discord-assistant/_collections/dias.util.ts +132 -132
  189. package/src/_modules/discord-assistant/_models/dias-global-settings.interface.ts +19 -19
  190. package/src/_modules/discord-assistant/_models/dias-knowledge.data-model.ts +52 -52
  191. package/src/_modules/discord-assistant/_services/dias-chunk.data-service.ts +177 -177
  192. package/src/_modules/discord-assistant/_services/dias-io.control-service.spec.ts +108 -108
  193. package/src/_modules/discord-assistant/_services/dias-io.control-service.ts +69 -69
  194. package/src/_modules/discord-assistant/_services/dias-main.control-service.spec.ts +22 -22
  195. package/src/_modules/discord-assistant/_services/dias-main.control-service.ts +27 -27
  196. package/src/_modules/discord-assistant/_services/dias.service-base.spec.ts +195 -195
  197. package/src/_modules/discord-assistant/_services/dias.service-base.ts +76 -76
  198. package/src/_modules/discord-assistant/index.ts +38 -38
  199. package/src/_modules/discord-assistant-voiced/_services/dias-discord-bot.control-service.spec.ts +34 -34
  200. package/src/_modules/discord-assistant-voiced/_services/dias-discord-bot.control-service.ts +11 -11
  201. package/src/_modules/discord-assistant-voiced/index.ts +36 -36
  202. package/src/_modules/discord-bot/_collections/dibo-default-commands.const.ts +16 -16
  203. package/src/_modules/discord-bot/_collections/dibo-global-settings.conts.ts +55 -55
  204. package/src/_modules/discord-bot/_collections/dibo-operations.util.spec.ts +214 -214
  205. package/src/_modules/discord-bot/_collections/dibo-operations.util.ts +387 -387
  206. package/src/_modules/discord-bot/_models/dibo-command.interface.ts +12 -12
  207. package/src/_modules/discord-bot/_models/dibo-global-settings.interface.ts +98 -98
  208. package/src/_modules/discord-bot/_models/dibo-last-mention-date.inteface.ts +7 -7
  209. package/src/_modules/discord-bot/_models/dibo-last-message-date.interface.ts +6 -6
  210. package/src/_modules/discord-bot/_services/dibo-commands.control-service.spec.ts +154 -154
  211. package/src/_modules/discord-bot/_services/dibo-commands.control-service.ts +153 -153
  212. package/src/_modules/discord-bot/_services/dibo-io.control-service.spec.ts +264 -264
  213. package/src/_modules/discord-bot/_services/dibo-io.control-service.ts +306 -306
  214. package/src/_modules/discord-bot/_services/dibo-main.control-service.spec.ts +408 -408
  215. package/src/_modules/discord-bot/_services/dibo-main.control-service.ts +487 -487
  216. package/src/_modules/discord-bot/_services/dibo-routines.control-service.spec.ts +105 -105
  217. package/src/_modules/discord-bot/index.ts +36 -36
  218. package/src/_modules/local-vector-search/_enums/lvs-search-mode.enum.ts +35 -35
  219. package/src/_modules/local-vector-search/_models/data-models/lvs-vector-persist.data-model.ts +59 -59
  220. package/src/_modules/local-vector-search/_models/lvs-search-result.interface.ts +17 -17
  221. package/src/_modules/local-vector-search/_services/lvs-doc-chunk-data.service.spec.ts +418 -418
  222. package/src/_modules/local-vector-search/_services/lvs-doc-chunk-data.service.ts +276 -276
  223. package/src/_modules/local-vector-search/_services/lvs-local-vector-search.data-service.spec.ts +480 -480
  224. package/src/_modules/local-vector-search/_services/lvs-local-vector-search.data-service.ts +416 -416
  225. package/src/_modules/local-vector-search/_services/lvs-persistent-vector-pool.control-service.spec.ts +198 -198
  226. package/src/_modules/local-vector-search/_services/lvs-persistent-vector-pool.control-service.ts +146 -146
  227. package/src/_modules/local-vector-search/_services/lvs-vector-persist.data-service.spec.ts +167 -167
  228. package/src/_modules/local-vector-search/_services/lvs-vector-persist.data-service.ts +106 -106
  229. package/src/_modules/local-vector-search/_services/lvs-vector-pool.control-service.spec.ts +507 -507
  230. package/src/_modules/local-vector-search/_services/lvs-vector-pool.control-service.ts +272 -272
  231. package/src/_modules/local-vector-search/index.ts +16 -16
  232. package/src/_modules/logs/index.ts +11 -11
  233. package/src/_modules/mcp/_models/interfaces/dynts-mcp.interface.ts +111 -111
  234. package/src/_modules/mcp/_services/dynts-mcp-server.service-base.spec.ts +142 -142
  235. package/src/_modules/mcp/_services/dynts-mcp-server.service-base.ts +120 -120
  236. package/src/_modules/mcp/_services/dynts-mcp.adapter.ts +168 -168
  237. package/src/_modules/mcp/index.ts +13 -13
  238. package/src/_modules/messaging/README.md +354 -354
  239. package/src/_modules/messaging/_collections/get-messaging-routing-module.util.ts +26 -26
  240. package/src/_modules/messaging/_collections/msg-global-settings.const.ts +22 -22
  241. package/src/_modules/messaging/_collections/msg.util.spec.ts +226 -226
  242. package/src/_modules/messaging/_models/msg-global-settings.interface.ts +37 -37
  243. package/src/_modules/messaging/_services/msg-conversation.data-service.ts +146 -146
  244. package/src/_modules/messaging/_services/msg-events.service.spec.ts +219 -219
  245. package/src/_modules/messaging/_services/msg-events.service.ts +267 -267
  246. package/src/_modules/messaging/_services/msg-integration.control-service.ts +179 -179
  247. package/src/_modules/messaging/_services/msg-main.control-service.spec.ts +147 -147
  248. package/src/_modules/messaging/_services/msg-main.control-service.ts +571 -571
  249. package/src/_modules/messaging/_services/msg-message.data-service.ts +129 -129
  250. package/src/_modules/messaging/_services/msg.controller.spec.ts +201 -201
  251. package/src/_modules/messaging/index.ts +30 -30
  252. package/src/_modules/mock/app-extended-server.mock.ts +201 -201
  253. package/src/_modules/mock/app-integration-test.mock.ts +51 -51
  254. package/src/_modules/mock/app-params.mock.spec.ts +21 -21
  255. package/src/_modules/mock/app-params.mock.ts +9 -9
  256. package/src/_modules/mock/app-server.mock.ts +188 -188
  257. package/src/_modules/mock/auth-service.mock.spec.ts +47 -47
  258. package/src/_modules/mock/auth-service.mock.ts +28 -28
  259. package/src/_modules/mock/controller.mock.spec.ts +26 -26
  260. package/src/_modules/mock/controller.mock.ts +16 -16
  261. package/src/_modules/mock/data-model.mock.spec.ts +111 -111
  262. package/src/_modules/mock/data-model.mock.ts +82 -82
  263. package/src/_modules/mock/email-service-collection.mock.spec.ts +24 -24
  264. package/src/_modules/mock/email-service-collection.mock.ts +15 -15
  265. package/src/_modules/mock/email-service.mock.spec.ts +17 -17
  266. package/src/_modules/mock/email-service.mock.ts +20 -20
  267. package/src/_modules/mock/email-template.mock.html +14 -14
  268. package/src/_modules/mock/endpoint.mock.ts +91 -91
  269. package/src/_modules/mock/socket-client.mock.spec.ts +40 -40
  270. package/src/_modules/mock/socket-client.mock.ts +45 -45
  271. package/src/_modules/mock/socket-server.mock.spec.ts +44 -44
  272. package/src/_modules/mock/socket-server.mock.ts +46 -46
  273. package/src/_modules/oauth2/_routes/oauth2.controller.spec.ts +107 -107
  274. package/src/_modules/oauth2/_routes/oauth2.controller.ts +98 -98
  275. package/src/_modules/oauth2/_services/oauth2.auth-service.spec.ts +254 -254
  276. package/src/_modules/oauth2/_services/oauth2.auth-service.ts +232 -232
  277. package/src/_modules/oauth2/_services/oauth2.control-service.spec.ts +585 -585
  278. package/src/_modules/oauth2/_services/oauth2.control-service.ts +653 -653
  279. package/src/_modules/oauth2/index.ts +17 -17
  280. package/src/_modules/scoped-config/_enums/dynts-scoped-config-level.enum.ts +22 -22
  281. package/src/_modules/scoped-config/_models/data-models/dynts-scoped-config.data-model.ts +81 -81
  282. package/src/_modules/scoped-config/_models/interfaces/dynts-scoped-config.interface.ts +107 -107
  283. package/src/_modules/scoped-config/_services/dynts-scoped-config.control-service.spec.ts +306 -306
  284. package/src/_modules/scoped-config/_services/dynts-scoped-config.control-service.ts +295 -295
  285. package/src/_modules/scoped-config/_services/dynts-scoped-config.data-service.spec.ts +118 -118
  286. package/src/_modules/scoped-config/_services/dynts-scoped-config.data-service.ts +105 -105
  287. package/src/_modules/scoped-config/index.ts +17 -17
  288. package/src/_modules/server/errors/errors.control-service.spec.ts +238 -238
  289. package/src/_modules/server/errors/errors.control-service.ts +100 -100
  290. package/src/_modules/server/errors/errors.controller.spec.ts +268 -268
  291. package/src/_modules/server/errors/errors.controller.ts +527 -515
  292. package/src/_modules/server/errors/errors.data-service.spec.ts +480 -480
  293. package/src/_modules/server/index.ts +30 -30
  294. package/src/_modules/server/server-status/server-status-snapshot.control-service.spec.ts +70 -70
  295. package/src/_modules/server/server-status/server-status-snapshot.control-service.ts +17 -17
  296. package/src/_modules/server/server-status/server-status-snapshot.data-service.spec.ts +77 -77
  297. package/src/_modules/server/server-status/server-status-snapshot.data-service.ts +37 -37
  298. package/src/_modules/server/server-status/server-status.control-service.spec.ts +576 -576
  299. package/src/_modules/server/server-status/server-status.control-service.ts +396 -396
  300. package/src/_modules/server/server-status/server-status.controller.spec.ts +255 -255
  301. package/src/_modules/server/server-status/server-status.controller.ts +272 -272
  302. package/src/_modules/socket/_enums/socket-security.enum.ts +11 -11
  303. package/src/_modules/socket/_models/socket-client-service-params.control-model.spec.ts +32 -32
  304. package/src/_modules/socket/_models/socket-client-service-params.control-model.ts +22 -22
  305. package/src/_modules/socket/_models/socket-presence.control-model.spec.ts +164 -164
  306. package/src/_modules/socket/_models/socket-presence.control-model.ts +210 -210
  307. package/src/_modules/socket/_models/socket-server-service-params.control-model.spec.ts +46 -46
  308. package/src/_modules/socket/_models/socket-server-service-params.control-model.ts +22 -22
  309. package/src/_modules/socket/_services/socket-client.service.spec.ts +15 -15
  310. package/src/_modules/socket/_services/socket-client.service.ts +260 -260
  311. package/src/_modules/socket/_services/socket-server.service.spec.ts +11 -11
  312. package/src/_modules/socket/app-extended.integration.spec.ts +85 -85
  313. package/src/_modules/socket/app-extended.server.ts +630 -630
  314. package/src/_modules/socket/index.ts +42 -42
  315. package/src/_modules/test/get-test-routing-module.util.spec.ts +28 -28
  316. package/src/_modules/test/get-test-routing-module.util.ts +23 -23
  317. package/src/_modules/test/index.ts +11 -11
  318. package/src/_modules/test/test.controller.spec.ts +72 -72
  319. package/src/_modules/test/test.controller.ts +115 -115
  320. package/src/_modules/usage/get-usage-routing-module.util.ts +22 -22
  321. package/src/_modules/usage/index.ts +15 -15
  322. package/src/_modules/usage/usage.controller.spec.ts +81 -81
  323. package/src/_modules/usage/usage.controller.ts +126 -126
  324. package/src/_modules/usage/usage.data-service.spec.ts +332 -332
  325. package/src/_modules/usage/usage.data-service.ts +185 -185
  326. package/src/_services/base/api.service-base.spec.ts +125 -125
  327. package/src/_services/base/api.service-base.ts +74 -74
  328. package/src/_services/base/archive-data.service.spec.ts +209 -209
  329. package/src/_services/base/archive-data.service.ts +224 -224
  330. package/src/_services/base/data.service.spec.ts +729 -729
  331. package/src/_services/base/data.service.ts +2740 -2740
  332. package/src/_services/base/db.service.spec.ts +73 -73
  333. package/src/_services/base/db.service.ts +1575 -1575
  334. package/src/_services/base/singleton.service-base.spec.ts +28 -28
  335. package/src/_services/base/singleton.service-base.ts +24 -24
  336. package/src/_services/base/singleton.service.spec.ts +114 -114
  337. package/src/_services/base/singleton.service.ts +38 -38
  338. package/src/_services/core/api.service.spec.ts +140 -140
  339. package/src/_services/core/auth.service.spec.ts +159 -159
  340. package/src/_services/core/auth.service.ts +174 -174
  341. package/src/_services/core/email.service.spec.ts +85 -85
  342. package/src/_services/core/email.service.ts +742 -742
  343. package/src/_services/core/global.service.spec.ts +292 -292
  344. package/src/_services/core/global.service.ts +487 -487
  345. package/src/_services/core/memory-guard.service.spec.ts +245 -245
  346. package/src/_services/core/memory-guard.service.ts +481 -481
  347. package/src/_services/core/service-collection.service.spec.ts +46 -46
  348. package/src/_services/core/service-collection.service.ts +6 -6
  349. package/src/_services/route/controller.service.spec.ts +53 -53
  350. package/src/_services/route/controller.service.ts +148 -148
  351. package/src/_services/route/routing-module.service.spec.ts +98 -98
  352. package/src/_services/route/routing-module.service.ts +330 -330
  353. package/src/_services/server/app.server.ts +1905 -1905
  354. package/src/_services/shared.static-service.spec.ts +99 -99
  355. package/src/_services/shared.static-service.ts +78 -78
  356. package/src/index.ts +97 -97
  357. package/tsconfig.app.json +12 -12
  358. package/tsconfig.json +42 -42
  359. package/.dynamo/logs/cicd-pipeline/output.log +0 -2791
  360. package/.dynamo/logs/cicd-pipeline/status.json +0 -94
@@ -1,125 +1,125 @@
1
- import { DyFM_Log } from '@futdevpro/fsm-dynamo';
2
-
3
- import {
4
- DyNTS_Mcp_CallResult,
5
- DyNTS_Mcp_ServerInfo,
6
- DyNTS_Mcp_StartOptions,
7
- DyNTS_Mcp_ToolDefinition
8
- } from '../_models/interfaces/dynts-mcp.interface';
9
- import { DyNTS_Mcp_Adapter } from './dynts-mcp.adapter';
10
-
11
- /**
12
- * `DyNTS_Mcp_Server_ServiceBase` (BFR-AM-003) — a **domain-agnosztikus** MCP-szerver-base. Egy bedrock-réteg
13
- * a hivatalos `@modelcontextprotocol/sdk` fölött: a server-base felel a tool-registry-ért, a
14
- * `tools/list`/`tools/call` dispatch-ért (az adaptoron át) + a transport-indításért — a SDK KIZÁRÓLAG
15
- * a `DyNTS_Mcp_Adapter` mögött él (egy jövőbeli transport-/SDK-csere NON-breaking).
16
- *
17
- * **Használat (consumer):** a consumer leszármazik (`extends DyNTS_Mcp_Server_ServiceBase`) + implementálja a
18
- * `getServerInfo()` (név/verzió) és `getTools()` (a SAJÁT tool-jai) abstract metódusokat. A bedrock
19
- * SEMMILYEN domain-tool-t NEM definiál — csak a server-base + a transport + a registry. (Pl. a FAM a
20
- * `read`/`write`/`capabilities` tool-jait itt regisztrálja, a bedrock-on kívül.)
21
- *
22
- * ```ts
23
- * class My_McpServer extends DyNTS_Mcp_Server_ServiceBase {
24
- * protected getServerInfo() { return { name: 'my-app', version: '1.0.0' }; }
25
- * protected getTools() { return [readTool, writeTool]; }
26
- * }
27
- * await new My_McpServer().start({ transport: 'stdio' });
28
- * ```
29
- *
30
- * **stdio-konvenció:** a stdout a JSON-RPC csatorna — a boot-üzenet + minden log a stderr-re megy (a
31
- * hívó App a `DyFM_Log`-ot stdio-módban stderr-re konfigurálja).
32
- */
33
- export abstract class DyNTS_Mcp_Server_ServiceBase {
34
-
35
- /** Az MCP-adaptor (a regisztrált tool-ok + a transport mögötti SDK-réteg). Lazy a `build()`-ben. */
36
- private adapter: DyNTS_Mcp_Adapter | null = null;
37
-
38
- /**
39
- * A szerver identitása (név/verzió) — a consumer adja. A SDK `serverInfo`-jaként hirdetődik.
40
- */
41
- protected abstract getServerInfo(): DyNTS_Mcp_ServerInfo;
42
-
43
- /**
44
- * A consumer SAJÁT tool-definíciói (az advertised halmaz). A `build()` ezeket regisztrálja az
45
- * adaptoron át — a `tools/list` PONTOSAN ezeket hirdeti, a `tools/call` ezekre dispatch-el.
46
- */
47
- protected abstract getTools(): DyNTS_Mcp_ToolDefinition[];
48
-
49
- /**
50
- * A szerver felépítése (a consumer-tool-ok regisztrálása az adaptoron). NEM indítja a transportot
51
- * — a `start()` teszi. Külön lépés a contract-teszt kedvéért (a szerver felépül + a tool-okat
52
- * hirdeti, transport nélkül). Idempotens: ismételt hívás ugyanazt az adaptort adja vissza.
53
- */
54
- public build(): DyNTS_Mcp_Adapter {
55
- if (this.adapter) {
56
- return this.adapter;
57
- }
1
+ import { DyFM_Log } from '@futdevpro/fsm-dynamo';
2
+
3
+ import {
4
+ DyNTS_Mcp_CallResult,
5
+ DyNTS_Mcp_ServerInfo,
6
+ DyNTS_Mcp_StartOptions,
7
+ DyNTS_Mcp_ToolDefinition
8
+ } from '../_models/interfaces/dynts-mcp.interface';
9
+ import { DyNTS_Mcp_Adapter } from './dynts-mcp.adapter';
10
+
11
+ /**
12
+ * `DyNTS_Mcp_Server_ServiceBase` (BFR-AM-003) — a **domain-agnosztikus** MCP-szerver-base. Egy bedrock-réteg
13
+ * a hivatalos `@modelcontextprotocol/sdk` fölött: a server-base felel a tool-registry-ért, a
14
+ * `tools/list`/`tools/call` dispatch-ért (az adaptoron át) + a transport-indításért — a SDK KIZÁRÓLAG
15
+ * a `DyNTS_Mcp_Adapter` mögött él (egy jövőbeli transport-/SDK-csere NON-breaking).
16
+ *
17
+ * **Használat (consumer):** a consumer leszármazik (`extends DyNTS_Mcp_Server_ServiceBase`) + implementálja a
18
+ * `getServerInfo()` (név/verzió) és `getTools()` (a SAJÁT tool-jai) abstract metódusokat. A bedrock
19
+ * SEMMILYEN domain-tool-t NEM definiál — csak a server-base + a transport + a registry. (Pl. a FAM a
20
+ * `read`/`write`/`capabilities` tool-jait itt regisztrálja, a bedrock-on kívül.)
21
+ *
22
+ * ```ts
23
+ * class My_McpServer extends DyNTS_Mcp_Server_ServiceBase {
24
+ * protected getServerInfo() { return { name: 'my-app', version: '1.0.0' }; }
25
+ * protected getTools() { return [readTool, writeTool]; }
26
+ * }
27
+ * await new My_McpServer().start({ transport: 'stdio' });
28
+ * ```
29
+ *
30
+ * **stdio-konvenció:** a stdout a JSON-RPC csatorna — a boot-üzenet + minden log a stderr-re megy (a
31
+ * hívó App a `DyFM_Log`-ot stdio-módban stderr-re konfigurálja).
32
+ */
33
+ export abstract class DyNTS_Mcp_Server_ServiceBase {
34
+
35
+ /** Az MCP-adaptor (a regisztrált tool-ok + a transport mögötti SDK-réteg). Lazy a `build()`-ben. */
36
+ private adapter: DyNTS_Mcp_Adapter | null = null;
37
+
38
+ /**
39
+ * A szerver identitása (név/verzió) — a consumer adja. A SDK `serverInfo`-jaként hirdetődik.
40
+ */
41
+ protected abstract getServerInfo(): DyNTS_Mcp_ServerInfo;
42
+
43
+ /**
44
+ * A consumer SAJÁT tool-definíciói (az advertised halmaz). A `build()` ezeket regisztrálja az
45
+ * adaptoron át — a `tools/list` PONTOSAN ezeket hirdeti, a `tools/call` ezekre dispatch-el.
46
+ */
47
+ protected abstract getTools(): DyNTS_Mcp_ToolDefinition[];
48
+
49
+ /**
50
+ * A szerver felépítése (a consumer-tool-ok regisztrálása az adaptoron). NEM indítja a transportot
51
+ * — a `start()` teszi. Külön lépés a contract-teszt kedvéért (a szerver felépül + a tool-okat
52
+ * hirdeti, transport nélkül). Idempotens: ismételt hívás ugyanazt az adaptort adja vissza.
53
+ */
54
+ public build(): DyNTS_Mcp_Adapter {
55
+ if (this.adapter) {
56
+ return this.adapter;
57
+ }
58
58
  const adapter: DyNTS_Mcp_Adapter = new DyNTS_Mcp_Adapter(this.getServerInfo());
59
-
60
- for (const tool of this.getTools()) {
61
- adapter.registerTool(tool);
62
- }
59
+
60
+ for (const tool of this.getTools()) {
61
+ adapter.registerTool(tool);
62
+ }
63
63
  this.adapter = adapter;
64
-
65
- return adapter;
66
- }
67
-
68
- /**
69
- * Az MCP-szerver indítása a választott transporton (default `stdio`). Felépíti a szervert (ha még
70
- * nem), majd a transportot csatlakoztatja — innentől a `tools/list` a consumer-tool-okat hirdeti,
71
- * a `tools/call` route-ol. A boot-üzenet a stderr-en.
72
- */
73
- public async start(options?: DyNTS_Mcp_StartOptions): Promise<void> {
74
- const transport: 'stdio' = options?.transport ?? 'stdio';
75
- const adapter: DyNTS_Mcp_Adapter = this.build();
64
+
65
+ return adapter;
66
+ }
67
+
68
+ /**
69
+ * Az MCP-szerver indítása a választott transporton (default `stdio`). Felépíti a szervert (ha még
70
+ * nem), majd a transportot csatlakoztatja — innentől a `tools/list` a consumer-tool-okat hirdeti,
71
+ * a `tools/call` route-ol. A boot-üzenet a stderr-en.
72
+ */
73
+ public async start(options?: DyNTS_Mcp_StartOptions): Promise<void> {
74
+ const transport: 'stdio' = options?.transport ?? 'stdio';
75
+ const adapter: DyNTS_Mcp_Adapter = this.build();
76
76
  const info: DyNTS_Mcp_ServerInfo = this.getServerInfo();
77
-
78
- DyFM_Log.testInfo(`[DyNTS MCP] ${transport} server starting (${info.name} v${info.version}); `
79
- + `advertised tools: ${adapter.getAdvertisedToolNames().join(', ')}`);
80
- await this.startTransport(adapter, transport);
81
- }
82
-
83
- /**
84
- * A felépített tool-nevek (a contract/diszjunkció-teszthez). Build előtt a deklarált `getTools()`
85
- * neveit adja (transport nélkül is determinisztikus).
86
- */
87
- public getAdvertisedToolNames(): string[] {
88
- return this.adapter
89
- ? this.adapter.getAdvertisedToolNames()
90
- : this.getTools().map((tool) => tool.name);
91
- }
92
-
93
- /**
94
- * Egy tool KÖZVETLEN hívása (a transport megkerülésével) — a contract-teszthez / REST-paritáshoz.
95
- * Felépíti a szervert (ha még nem), majd az adaptor egységes dispatch-ét futtatja (ismeretlen
96
- * tool → strukturált hiba; handler-hiba → `isError:true`).
97
- */
98
- public async callTool(set: { name: string; arguments?: unknown }): Promise<DyNTS_Mcp_CallResult> {
99
- return this.build().dispatchToolCall(set);
100
- }
101
-
102
- /** A szerver leállítása (graceful close — teszt-/shutdown-úthoz). */
103
- public async close(): Promise<void> {
104
- if (this.adapter) {
105
- await this.adapter.close();
106
- }
107
- }
108
-
109
- /**
110
- * A transport-indítás dispatch-e. Külön metódus, hogy egy jövőbeli transport (http/sse) NON-breaking
111
- * módon bővíthető legyen (a `start()` + a registry változatlan). MVP: csak `stdio`.
112
- */
113
- private async startTransport(adapter: DyNTS_Mcp_Adapter, transport: 'stdio'): Promise<void> {
114
- switch (transport) {
115
- case 'stdio':
77
+
78
+ DyFM_Log.testInfo(`[DyNTS MCP] ${transport} server starting (${info.name} v${info.version}); `
79
+ + `advertised tools: ${adapter.getAdvertisedToolNames().join(', ')}`);
80
+ await this.startTransport(adapter, transport);
81
+ }
82
+
83
+ /**
84
+ * A felépített tool-nevek (a contract/diszjunkció-teszthez). Build előtt a deklarált `getTools()`
85
+ * neveit adja (transport nélkül is determinisztikus).
86
+ */
87
+ public getAdvertisedToolNames(): string[] {
88
+ return this.adapter
89
+ ? this.adapter.getAdvertisedToolNames()
90
+ : this.getTools().map((tool) => tool.name);
91
+ }
92
+
93
+ /**
94
+ * Egy tool KÖZVETLEN hívása (a transport megkerülésével) — a contract-teszthez / REST-paritáshoz.
95
+ * Felépíti a szervert (ha még nem), majd az adaptor egységes dispatch-ét futtatja (ismeretlen
96
+ * tool → strukturált hiba; handler-hiba → `isError:true`).
97
+ */
98
+ public async callTool(set: { name: string; arguments?: unknown }): Promise<DyNTS_Mcp_CallResult> {
99
+ return this.build().dispatchToolCall(set);
100
+ }
101
+
102
+ /** A szerver leállítása (graceful close — teszt-/shutdown-úthoz). */
103
+ public async close(): Promise<void> {
104
+ if (this.adapter) {
105
+ await this.adapter.close();
106
+ }
107
+ }
108
+
109
+ /**
110
+ * A transport-indítás dispatch-e. Külön metódus, hogy egy jövőbeli transport (http/sse) NON-breaking
111
+ * módon bővíthető legyen (a `start()` + a registry változatlan). MVP: csak `stdio`.
112
+ */
113
+ private async startTransport(adapter: DyNTS_Mcp_Adapter, transport: 'stdio'): Promise<void> {
114
+ switch (transport) {
115
+ case 'stdio':
116
116
  await adapter.startStdio();
117
-
117
+
118
118
  return;
119
-
120
- default:
121
- // Exhaustiveness-guard: a `DyNTS_Mcp_TransportKind` bővülésekor itt fordítási hibát kapunk.
122
- throw new Error(`Unsupported MCP transport: '${transport as string}'.`);
123
- }
124
- }
125
- }
119
+
120
+ default:
121
+ // Exhaustiveness-guard: a `DyNTS_Mcp_TransportKind` bővülésekor itt fordítási hibát kapunk.
122
+ throw new Error(`Unsupported MCP transport: '${transport as string}'.`);
123
+ }
124
+ }
125
+ }
@@ -1,168 +1,168 @@
1
- // A `@modelcontextprotocol/sdk` ESM-only csomag; a deep subpath-importjai (server/index, server/stdio,
2
- // types) KÖTELEZŐEN `.js`-suffixet igényelnek (az SDK `exports`-map így oldja fel) — ezért a `no-js-import`
3
- // szabály ITT indokoltan kikapcsolva (C2, FAM-REV bedrock-fix). Suffix-strip → resolve-hiba.
4
- /* eslint-disable @futdevpro/dynamo/no-js-import */
5
- import { Server } from '@modelcontextprotocol/sdk/server/index.js';
6
- import { StdioServerTransport } from '@modelcontextprotocol/sdk/server/stdio.js';
7
- import { CallToolRequestSchema, CallToolResult, ListToolsRequestSchema } from '@modelcontextprotocol/sdk/types.js';
8
- /* eslint-enable @futdevpro/dynamo/no-js-import */
9
-
10
- import { DyFM_Error } from '@futdevpro/fsm-dynamo';
11
-
12
- import {
13
- DyNTS_Mcp_CallResult,
14
- DyNTS_Mcp_ServerInfo,
15
- DyNTS_Mcp_ToolDefinition,
16
- DyNTS_Mcp_ToolOutcome
17
- } from '../_models/interfaces/dynts-mcp.interface';
18
-
19
- /**
20
- * `DyNTS_Mcp_Adapter` (BFR-AM-003) — a hivatalos `@modelcontextprotocol/sdk` köré épített **vékony
21
- * adaptor-réteg**. EZ az EGYETLEN hely a `/mcp` submodule-ban, ahol a SDK-típusok megjelennek — a
22
- * `DyNTS_Mcp_Server_ServiceBase` + a consumer tool-jai SDK-mentesek, így egy jövőbeli transport-/SDK-csere
23
- * NON-breaking (csak ez az osztály cserélődik).
24
- *
25
- * Felelősség (3 dolog, semmi domain-logika):
26
- * 1. EGY `registerTool` choke-pont (a tool-name → def map),
27
- * 2. a `tools/list` + `tools/call` JSON-RPC handler bekötése a SDK-szerverre,
28
- * 3. egységes hiba-fordítás: a tool-handler dobott hibája (vagy `isError:true` outcome-ja)
29
- * strukturált `CallToolResult { isError:true }`-tá fordul — SOHA nem néma, SOHA nem crash.
30
- *
31
- * **stdio-konvenció:** a stdout a JSON-RPC csatorna — az adaptor maga SEMMIT nem ír a stdout-ra a
32
- * transport-payload-on kívül (minden log/diag a hívó App felelőssége, stderr-re).
33
- */
34
- export class DyNTS_Mcp_Adapter {
35
-
36
- /** A SDK MCP-szerver (a transport-agnosztikus protocol-réteg). */
37
- private readonly server: Server;
38
-
39
- /** A regisztrált tool-definíciók `name` → def map-je (a `tools/call` dispatch-hez). */
40
- private readonly tools: Map<string, DyNTS_Mcp_ToolDefinition> =
41
- new Map<string, DyNTS_Mcp_ToolDefinition>();
42
-
43
- constructor(set: DyNTS_Mcp_ServerInfo) {
44
- this.server = new Server(
45
- { name: set.name, version: set.version },
46
- { capabilities: { tools: {} } },
47
- );
48
- this.installHandlers();
49
- }
50
-
51
- /**
52
- * Az EGYETLEN tool-regisztrációs choke-pont. A regisztrált tool-ok hirdetődnek a `tools/list`-ben
53
- * és dispatch-elhetők a `tools/call`-on. Az azonos nevű ismételt regisztráció felülír (last-wins).
54
- */
55
- public registerTool(definition: DyNTS_Mcp_ToolDefinition): void {
56
- this.tools.set(definition.name, definition);
57
- }
58
-
59
- /** A hirdetett (regisztrált) tool-nevek (a contract/diszjunkció-teszthez). */
60
- public getAdvertisedToolNames(): string[] {
61
- return Array.from(this.tools.keys());
62
- }
63
-
64
- /**
65
- * A stdio transport csatlakoztatása + a szerver indítása. A `connect` után a `tools/list` a
66
- * regisztrált tool-okat hirdeti. A boot-üzenetek a stderr-en (a hívó App felel).
67
- */
68
- public async startStdio(): Promise<void> {
69
- const transport: StdioServerTransport = new StdioServerTransport();
70
-
71
- await this.server.connect(transport);
72
- }
73
-
74
- /** A szerver leállítása (graceful close — teszt-/shutdown-úthoz). */
75
- public async close(): Promise<void> {
76
- await this.server.close();
77
- }
78
-
79
- /**
80
- * Egy tool-hívás KÖZVETLEN dispatch-elése (a transport-megkerülésével) — a contract/registry-teszt
81
- * ezt hívja a stdio-szerver indítása nélkül. Ugyanaz a logika fut, mint a SDK `tools/call`-on:
82
- * ismeretlen tool → strukturált hiba; handler-hiba → `isError:true` fordítás.
83
- */
84
- public async dispatchToolCall(set: { name: string; arguments?: unknown }): Promise<DyNTS_Mcp_CallResult> {
85
- const definition: DyNTS_Mcp_ToolDefinition | undefined = this.tools.get(set.name);
86
-
87
- if (!definition) {
88
- return this.errorResult(`Unknown tool: '${set.name}'. Advertised tools: `
89
- + `${this.getAdvertisedToolNames().join(', ')}.`);
90
- }
91
- try {
92
- const outcome: DyNTS_Mcp_ToolOutcome = await definition.handler(set.arguments);
93
-
94
- return this.toCallResult(outcome);
95
- } catch (error) {
96
- return this.errorResult(this.describeError(error), error);
97
- }
98
- }
99
-
100
- // =========================================================================
101
- // SDK request-handler bekötés (tools/list + tools/call)
102
- // =========================================================================
103
-
104
- /** A `tools/list` és a `tools/call` JSON-RPC handler bekötése a SDK-szerverre. */
105
- private installHandlers(): void {
106
- // tools/list — PONTOSAN a regisztrált (advertised) tool-okat hirdeti.
107
- this.server.setRequestHandler(ListToolsRequestSchema, async () => ({
108
- tools: Array.from(this.tools.values()).map((definition) => ({
109
- name: definition.name,
110
- description: definition.description,
111
- inputSchema: definition.inputSchema,
112
- })),
113
- }));
114
-
115
- // tools/call — a megfelelő handler futtatása + egységes hiba-fordítás (a közös dispatch-en át).
116
- // A `DyNTS_Mcp_CallResult` a SDK `CallToolResult` egy al-shape-je (text-content + isError) — a
117
- // SDK-cast KIZÁRÓLAG itt, az adaptor-boundary-n él (a SDK izolálva marad).
118
- this.server.setRequestHandler(CallToolRequestSchema, async (request): Promise<CallToolResult> =>
119
- (await this.dispatchToolCall({
120
- name: request.params.name,
121
- arguments: request.params.arguments,
122
- })) as CallToolResult);
123
- }
124
-
125
- // =========================================================================
126
- // CallToolResult fordítás (a transport-payload — text-JSON; egységes hiba-fordítás)
127
- // =========================================================================
128
-
129
- /** Egy sikeres (vagy strukturált-hiba) handler-outcome → `CallToolResult` (text-JSON content). */
130
- private toCallResult(outcome: DyNTS_Mcp_ToolOutcome): DyNTS_Mcp_CallResult {
131
- return {
132
- content: [{ type: 'text', text: this.stringify(outcome.data) }],
133
- isError: outcome.isError === true,
134
- };
135
- }
136
-
137
- /** Egy hiba → `CallToolResult { isError:true }` strukturált hiba-payload-dal (soha nem néma). */
138
- private errorResult(message: string, error?: unknown): DyNTS_Mcp_CallResult {
139
- const errorCode: string | undefined = error instanceof DyFM_Error
140
- ? DyFM_Error.getErrorCode(error)
141
- : undefined;
142
- const payload: object = { ok: false, error: { errorCode: errorCode, message: message } };
143
-
144
- return { content: [{ type: 'text', text: this.stringify(payload) }], isError: true };
145
- }
146
-
147
- /** Egy hiba ember-olvasható üzenete (DyFM_Error → message; Error → message; egyéb → fallback). */
148
- private describeError(error: unknown): string {
149
- if (error instanceof DyFM_Error) {
150
- return DyFM_Error.getErrorMessage(error) || 'Unknown DyFM error.';
151
- }
152
-
153
- if (error instanceof Error) {
154
- return error.message;
155
- }
156
-
157
- return 'Unknown error during tool execution.';
158
- }
159
-
160
- /** JSON-stringify (a transport text-content payload-ja); szerializálás-hiba → strukturált hiba. */
161
- private stringify(data: unknown): string {
162
- try {
163
- return JSON.stringify(data);
164
- } catch {
165
- return JSON.stringify({ ok: false, error: { message: 'The response is not JSON-serializable.' } });
166
- }
167
- }
168
- }
1
+ // A `@modelcontextprotocol/sdk` ESM-only csomag; a deep subpath-importjai (server/index, server/stdio,
2
+ // types) KÖTELEZŐEN `.js`-suffixet igényelnek (az SDK `exports`-map így oldja fel) — ezért a `no-js-import`
3
+ // szabály ITT indokoltan kikapcsolva (C2, FAM-REV bedrock-fix). Suffix-strip → resolve-hiba.
4
+ /* eslint-disable @futdevpro/dynamo/no-js-import */
5
+ import { Server } from '@modelcontextprotocol/sdk/server/index.js';
6
+ import { StdioServerTransport } from '@modelcontextprotocol/sdk/server/stdio.js';
7
+ import { CallToolRequestSchema, CallToolResult, ListToolsRequestSchema } from '@modelcontextprotocol/sdk/types.js';
8
+ /* eslint-enable @futdevpro/dynamo/no-js-import */
9
+
10
+ import { DyFM_Error } from '@futdevpro/fsm-dynamo';
11
+
12
+ import {
13
+ DyNTS_Mcp_CallResult,
14
+ DyNTS_Mcp_ServerInfo,
15
+ DyNTS_Mcp_ToolDefinition,
16
+ DyNTS_Mcp_ToolOutcome
17
+ } from '../_models/interfaces/dynts-mcp.interface';
18
+
19
+ /**
20
+ * `DyNTS_Mcp_Adapter` (BFR-AM-003) — a hivatalos `@modelcontextprotocol/sdk` köré épített **vékony
21
+ * adaptor-réteg**. EZ az EGYETLEN hely a `/mcp` submodule-ban, ahol a SDK-típusok megjelennek — a
22
+ * `DyNTS_Mcp_Server_ServiceBase` + a consumer tool-jai SDK-mentesek, így egy jövőbeli transport-/SDK-csere
23
+ * NON-breaking (csak ez az osztály cserélődik).
24
+ *
25
+ * Felelősség (3 dolog, semmi domain-logika):
26
+ * 1. EGY `registerTool` choke-pont (a tool-name → def map),
27
+ * 2. a `tools/list` + `tools/call` JSON-RPC handler bekötése a SDK-szerverre,
28
+ * 3. egységes hiba-fordítás: a tool-handler dobott hibája (vagy `isError:true` outcome-ja)
29
+ * strukturált `CallToolResult { isError:true }`-tá fordul — SOHA nem néma, SOHA nem crash.
30
+ *
31
+ * **stdio-konvenció:** a stdout a JSON-RPC csatorna — az adaptor maga SEMMIT nem ír a stdout-ra a
32
+ * transport-payload-on kívül (minden log/diag a hívó App felelőssége, stderr-re).
33
+ */
34
+ export class DyNTS_Mcp_Adapter {
35
+
36
+ /** A SDK MCP-szerver (a transport-agnosztikus protocol-réteg). */
37
+ private readonly server: Server;
38
+
39
+ /** A regisztrált tool-definíciók `name` → def map-je (a `tools/call` dispatch-hez). */
40
+ private readonly tools: Map<string, DyNTS_Mcp_ToolDefinition> =
41
+ new Map<string, DyNTS_Mcp_ToolDefinition>();
42
+
43
+ constructor(set: DyNTS_Mcp_ServerInfo) {
44
+ this.server = new Server(
45
+ { name: set.name, version: set.version },
46
+ { capabilities: { tools: {} } },
47
+ );
48
+ this.installHandlers();
49
+ }
50
+
51
+ /**
52
+ * Az EGYETLEN tool-regisztrációs choke-pont. A regisztrált tool-ok hirdetődnek a `tools/list`-ben
53
+ * és dispatch-elhetők a `tools/call`-on. Az azonos nevű ismételt regisztráció felülír (last-wins).
54
+ */
55
+ public registerTool(definition: DyNTS_Mcp_ToolDefinition): void {
56
+ this.tools.set(definition.name, definition);
57
+ }
58
+
59
+ /** A hirdetett (regisztrált) tool-nevek (a contract/diszjunkció-teszthez). */
60
+ public getAdvertisedToolNames(): string[] {
61
+ return Array.from(this.tools.keys());
62
+ }
63
+
64
+ /**
65
+ * A stdio transport csatlakoztatása + a szerver indítása. A `connect` után a `tools/list` a
66
+ * regisztrált tool-okat hirdeti. A boot-üzenetek a stderr-en (a hívó App felel).
67
+ */
68
+ public async startStdio(): Promise<void> {
69
+ const transport: StdioServerTransport = new StdioServerTransport();
70
+
71
+ await this.server.connect(transport);
72
+ }
73
+
74
+ /** A szerver leállítása (graceful close — teszt-/shutdown-úthoz). */
75
+ public async close(): Promise<void> {
76
+ await this.server.close();
77
+ }
78
+
79
+ /**
80
+ * Egy tool-hívás KÖZVETLEN dispatch-elése (a transport-megkerülésével) — a contract/registry-teszt
81
+ * ezt hívja a stdio-szerver indítása nélkül. Ugyanaz a logika fut, mint a SDK `tools/call`-on:
82
+ * ismeretlen tool → strukturált hiba; handler-hiba → `isError:true` fordítás.
83
+ */
84
+ public async dispatchToolCall(set: { name: string; arguments?: unknown }): Promise<DyNTS_Mcp_CallResult> {
85
+ const definition: DyNTS_Mcp_ToolDefinition | undefined = this.tools.get(set.name);
86
+
87
+ if (!definition) {
88
+ return this.errorResult(`Unknown tool: '${set.name}'. Advertised tools: `
89
+ + `${this.getAdvertisedToolNames().join(', ')}.`);
90
+ }
91
+ try {
92
+ const outcome: DyNTS_Mcp_ToolOutcome = await definition.handler(set.arguments);
93
+
94
+ return this.toCallResult(outcome);
95
+ } catch (error) {
96
+ return this.errorResult(this.describeError(error), error);
97
+ }
98
+ }
99
+
100
+ // =========================================================================
101
+ // SDK request-handler bekötés (tools/list + tools/call)
102
+ // =========================================================================
103
+
104
+ /** A `tools/list` és a `tools/call` JSON-RPC handler bekötése a SDK-szerverre. */
105
+ private installHandlers(): void {
106
+ // tools/list — PONTOSAN a regisztrált (advertised) tool-okat hirdeti.
107
+ this.server.setRequestHandler(ListToolsRequestSchema, async () => ({
108
+ tools: Array.from(this.tools.values()).map((definition) => ({
109
+ name: definition.name,
110
+ description: definition.description,
111
+ inputSchema: definition.inputSchema,
112
+ })),
113
+ }));
114
+
115
+ // tools/call — a megfelelő handler futtatása + egységes hiba-fordítás (a közös dispatch-en át).
116
+ // A `DyNTS_Mcp_CallResult` a SDK `CallToolResult` egy al-shape-je (text-content + isError) — a
117
+ // SDK-cast KIZÁRÓLAG itt, az adaptor-boundary-n él (a SDK izolálva marad).
118
+ this.server.setRequestHandler(CallToolRequestSchema, async (request): Promise<CallToolResult> =>
119
+ (await this.dispatchToolCall({
120
+ name: request.params.name,
121
+ arguments: request.params.arguments,
122
+ })) as CallToolResult);
123
+ }
124
+
125
+ // =========================================================================
126
+ // CallToolResult fordítás (a transport-payload — text-JSON; egységes hiba-fordítás)
127
+ // =========================================================================
128
+
129
+ /** Egy sikeres (vagy strukturált-hiba) handler-outcome → `CallToolResult` (text-JSON content). */
130
+ private toCallResult(outcome: DyNTS_Mcp_ToolOutcome): DyNTS_Mcp_CallResult {
131
+ return {
132
+ content: [{ type: 'text', text: this.stringify(outcome.data) }],
133
+ isError: outcome.isError === true,
134
+ };
135
+ }
136
+
137
+ /** Egy hiba → `CallToolResult { isError:true }` strukturált hiba-payload-dal (soha nem néma). */
138
+ private errorResult(message: string, error?: unknown): DyNTS_Mcp_CallResult {
139
+ const errorCode: string | undefined = error instanceof DyFM_Error
140
+ ? DyFM_Error.getErrorCode(error)
141
+ : undefined;
142
+ const payload: object = { ok: false, error: { errorCode: errorCode, message: message } };
143
+
144
+ return { content: [{ type: 'text', text: this.stringify(payload) }], isError: true };
145
+ }
146
+
147
+ /** Egy hiba ember-olvasható üzenete (DyFM_Error → message; Error → message; egyéb → fallback). */
148
+ private describeError(error: unknown): string {
149
+ if (error instanceof DyFM_Error) {
150
+ return DyFM_Error.getErrorMessage(error) || 'Unknown DyFM error.';
151
+ }
152
+
153
+ if (error instanceof Error) {
154
+ return error.message;
155
+ }
156
+
157
+ return 'Unknown error during tool execution.';
158
+ }
159
+
160
+ /** JSON-stringify (a transport text-content payload-ja); szerializálás-hiba → strukturált hiba. */
161
+ private stringify(data: unknown): string {
162
+ try {
163
+ return JSON.stringify(data);
164
+ } catch {
165
+ return JSON.stringify({ ok: false, error: { message: 'The response is not JSON-serializable.' } });
166
+ }
167
+ }
168
+ }
@@ -1,13 +1,13 @@
1
-
2
-
3
- // MCP MODULE (BFR-AM-003) — domain-agnosztikus Model Context Protocol szerver-base + transport +
4
- // tool-registry, a hivatalos `@modelcontextprotocol/sdk` köré izolált adaptorral. A consumer
5
- // leszármazik a `DyNTS_Mcp_Server_ServiceBase`-ből + a SAJÁT tool-jait regisztrálja (a bedrock NEM definiál
6
- // domain-tool-t). A SDK KIZÁRÓLAG a `DyNTS_Mcp_Adapter` mögött él (transport-csere NON-breaking).
7
-
8
- // INTERFACES
9
- export * from './_models/interfaces/dynts-mcp.interface';
10
-
11
- // SERVICES
12
- export * from './_services/dynts-mcp.adapter';
13
- export * from './_services/dynts-mcp-server.service-base';
1
+
2
+
3
+ // MCP MODULE (BFR-AM-003) — domain-agnosztikus Model Context Protocol szerver-base + transport +
4
+ // tool-registry, a hivatalos `@modelcontextprotocol/sdk` köré izolált adaptorral. A consumer
5
+ // leszármazik a `DyNTS_Mcp_Server_ServiceBase`-ből + a SAJÁT tool-jait regisztrálja (a bedrock NEM definiál
6
+ // domain-tool-t). A SDK KIZÁRÓLAG a `DyNTS_Mcp_Adapter` mögött él (transport-csere NON-breaking).
7
+
8
+ // INTERFACES
9
+ export * from './_models/interfaces/dynts-mcp.interface';
10
+
11
+ // SERVICES
12
+ export * from './_services/dynts-mcp.adapter';
13
+ export * from './_services/dynts-mcp-server.service-base';