@futdevpro/nts-dynamo 1.15.72 → 1.15.73

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 (366) 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 -0
  21. package/_specifications/BACKLOG.md +92 -92
  22. package/_specifications/TODO.md +15 -15
  23. package/_specifications/agent.md +138 -138
  24. package/build/_collections/global-settings.const.d.ts.map +1 -1
  25. package/build/_collections/global-settings.const.js +7 -0
  26. package/build/_collections/global-settings.const.js.map +1 -1
  27. package/build/_models/interfaces/global-settings.interface.d.ts +24 -0
  28. package/build/_models/interfaces/global-settings.interface.d.ts.map +1 -1
  29. package/build/_services/core/memory-guard.service.d.ts +51 -0
  30. package/build/_services/core/memory-guard.service.d.ts.map +1 -1
  31. package/build/_services/core/memory-guard.service.js +169 -6
  32. package/build/_services/core/memory-guard.service.js.map +1 -1
  33. package/eslint.config.js +3 -3
  34. package/nodemon.json +24 -24
  35. package/package.json +1 -1
  36. package/pnpm-workspace.yaml +5 -5
  37. package/scripts/run-coverage-tests.js +28 -28
  38. package/spec/support/helpers/spec-reporter-loader.js +359 -359
  39. package/spec/support/helpers/ts-node-helper.js +93 -93
  40. package/spec/support/jasmine.coverage.json +24 -24
  41. package/spec/support/jasmine.json +24 -24
  42. package/src/_collections/archive.util.spec.ts +57 -57
  43. package/src/_collections/archive.util.ts +18 -18
  44. package/src/_collections/atlas-default-db-options.const.ts +9 -9
  45. package/src/_collections/default-fallback-cache-max-age.const.spec.ts +11 -11
  46. package/src/_collections/default-fallback-cache-max-age.const.ts +2 -2
  47. package/src/_collections/default-not-found-page.const.spec.ts +19 -19
  48. package/src/_collections/default-not-found-page.const.ts +22 -22
  49. package/src/_collections/default-socket-path.const.spec.ts +12 -12
  50. package/src/_collections/default-socket-path.const.ts +2 -2
  51. package/src/_collections/get-environment-settings.util.spec.ts +210 -210
  52. package/src/_collections/get-environment-settings.util.ts +48 -48
  53. package/src/_collections/global-settings.const.ts +96 -89
  54. package/src/_collections/sample.env +21 -21
  55. package/src/_collections/star.controller.spec.ts +224 -224
  56. package/src/_collections/star.controller.ts +129 -129
  57. package/src/_enums/data-model-type.enum.ts +14 -14
  58. package/src/_enums/data-service-function.enum.ts +24 -24
  59. package/src/_enums/predefined-data-types.enum.ts +16 -16
  60. package/src/_enums/route-security.enum.ts +12 -12
  61. package/src/_models/control-models/api-call-params.control-model.spec.ts +152 -152
  62. package/src/_models/control-models/api-call-params.control-model.ts +142 -142
  63. package/src/_models/control-models/app-ext-system-controls.control-model.spec.ts +52 -52
  64. package/src/_models/control-models/app-ext-system-controls.control-model.ts +9 -9
  65. package/src/_models/control-models/app-params.control-model.spec.ts +225 -225
  66. package/src/_models/control-models/app-params.control-model.ts +136 -136
  67. package/src/_models/control-models/app-system-controls.control-model.spec.ts +31 -31
  68. package/src/_models/control-models/app-system-controls.control-model.ts +9 -9
  69. package/src/_models/control-models/endpoint-params.control-model.spec.ts +627 -627
  70. package/src/_models/control-models/endpoint-params.control-model.ts +627 -627
  71. package/src/_models/control-models/http-settings.control-model.spec.ts +77 -77
  72. package/src/_models/control-models/http-settings.control-model.ts +37 -37
  73. package/src/_models/control-models/system-control.control-model.spec.ts +27 -27
  74. package/src/_models/control-models/system-control.control-model.ts +12 -12
  75. package/src/_models/interfaces/certification-settings.interface.ts +7 -7
  76. package/src/_models/interfaces/environment-settings.interface.ts +59 -59
  77. package/src/_models/interfaces/global-log-settings.interface.ts +171 -171
  78. package/src/_models/interfaces/global-service-settings.interface.ts +47 -47
  79. package/src/_models/interfaces/global-settings.interface.ts +24 -0
  80. package/src/_models/interfaces/routing-module-settings.interface.ts +21 -21
  81. package/src/_models/interfaces/static-client-settings.interface.spec.ts +29 -29
  82. package/src/_models/interfaces/static-client-settings.interface.ts +28 -28
  83. package/src/_models/types/db-update.type.ts +100 -100
  84. package/src/_modules/ai/_models/ai-input-interfaces.ts +117 -117
  85. package/src/_modules/ai/_models/ai-test-generation-result.interface.ts +16 -16
  86. package/src/_modules/ai/_modules/anthropic/_services/aai-user-key.control-service.ts +138 -138
  87. package/src/_modules/ai/_modules/anthropic/index.ts +5 -5
  88. package/src/_modules/ai/_modules/document-ai/_collections/dai-chunking.util.spec.ts +242 -242
  89. package/src/_modules/ai/_modules/document-ai/_collections/dai-chunking.util.ts +639 -639
  90. package/src/_modules/ai/_modules/document-ai/_collections/dai-code-chunking.util.spec.ts +295 -295
  91. package/src/_modules/ai/_modules/document-ai/_collections/dai-code-chunking.util.ts +518 -518
  92. package/src/_modules/ai/_modules/document-ai/_collections/dai-document.util.spec.ts +209 -209
  93. package/src/_modules/ai/_modules/document-ai/_collections/dai-document.util.ts +85 -85
  94. package/src/_modules/ai/_modules/document-ai/_enums/dai-compare-result-type.enum.ts +7 -7
  95. package/src/_modules/ai/_modules/document-ai/_models/data-models/dai-doc-chunk.data-model.ts +146 -146
  96. package/src/_modules/ai/_modules/document-ai/_models/data-models/dai-doc-page.data-model.ts +162 -162
  97. package/src/_modules/ai/_modules/document-ai/_models/data-models/dai-document.data-model.ts +99 -99
  98. package/src/_modules/ai/_modules/document-ai/_models/interfaces/dai-code-chunk.interface.ts +68 -68
  99. package/src/_modules/ai/_modules/document-ai/_models/interfaces/dai-doc-chunk-compare-result.interface.ts +18 -18
  100. package/src/_modules/ai/_modules/document-ai/_models/interfaces/dai-doc-page-compare-result.interface.ts +19 -19
  101. package/src/_modules/ai/_modules/document-ai/_models/interfaces/dai-document-compare-result.interface.ts +25 -25
  102. package/src/_modules/ai/_modules/document-ai/index.ts +30 -30
  103. package/src/_modules/ai/_modules/fdp-ai/_services/fdpai-user-key.control-service.ts +189 -189
  104. package/src/_modules/ai/_modules/fdp-ai/index.ts +5 -5
  105. package/src/_modules/ai/_modules/open-ai/_collections/oai-global-settings.const.ts +9 -9
  106. package/src/_modules/ai/_modules/open-ai/_collections/oai-llm-predefined-requests-hu.conts.ts +82 -82
  107. package/src/_modules/ai/_modules/open-ai/_collections/oai-llm-predefined-requests.conts.ts +75 -75
  108. package/src/_modules/ai/_modules/open-ai/_enums/oai-gpt-message-role.enum.ts +45 -45
  109. package/src/_modules/ai/_modules/open-ai/_models/interfaces/oai-global-settings.interface.ts +7 -7
  110. package/src/_modules/ai/_modules/open-ai/_models/interfaces/oai-gpt-message.interface.ts +7 -7
  111. package/src/_modules/ai/_modules/open-ai/_models/interfaces/oai-llm-predefined-requests.interface.ts +57 -57
  112. package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-doc-chunk-data.service.ts +292 -292
  113. package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-document.data-service.spec.ts +342 -342
  114. package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-vector-data.service.spec.ts +550 -550
  115. package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-vector-data.service.ts +630 -630
  116. package/src/_modules/ai/_modules/open-ai/_services/oai-embedding.control-service.spec.ts +332 -332
  117. package/src/_modules/ai/_modules/open-ai/_services/oai-llm-chat.service-base.spec.ts +462 -462
  118. package/src/_modules/ai/_modules/open-ai/_services/oai-llm-chat.service-base.ts +634 -634
  119. package/src/_modules/ai/_modules/open-ai/_services/oai-llm.service-base.spec.ts +489 -489
  120. package/src/_modules/ai/_modules/open-ai/_services/oai-llm.service-base.tools.spec.ts +173 -173
  121. package/src/_modules/ai/_modules/open-ai/_services/oai-llm.service-base.ts +1033 -1033
  122. package/src/_modules/ai/_modules/open-ai/_services/oai-user-key.control-service.ts +157 -157
  123. package/src/_modules/ai/_services/ai-embedding-mock.service.spec.ts +115 -115
  124. package/src/_modules/ai/_services/ai-embedding-mock.service.ts +212 -212
  125. package/src/_modules/ai/_services/ai-embedding-provider.registry.spec.ts +110 -110
  126. package/src/_modules/ai/_services/ai-embedding-provider.registry.ts +110 -110
  127. package/src/_modules/ai/_services/ai-embedding.service-base.spec.ts +98 -98
  128. package/src/_modules/ai/_services/ai-embedding.service-base.ts +48 -48
  129. package/src/_modules/ai/_services/ai-llm-chat.service-base.spec.ts +229 -229
  130. package/src/_modules/ai/_services/ai-llm-chat.service-base.ts +68 -68
  131. package/src/_modules/ai/_services/ai-llm.service-base.spec.ts +250 -250
  132. package/src/_modules/ai/_services/ai-llm.service-base.ts +519 -519
  133. package/src/_modules/ai/_services/ai-provider.service-base.spec.ts +158 -158
  134. package/src/_modules/ai/_services/ai-user-key.service-base.ts +59 -59
  135. package/src/_modules/ai/_services/lmstudio-embedding.control-service.spec.ts +197 -197
  136. package/src/_modules/ai/_services/lmstudio-embedding.control-service.ts +371 -371
  137. package/src/_modules/ai/index.ts +23 -23
  138. package/src/_modules/assistant/_collections/ass-global-settings.const.ts +13 -13
  139. package/src/_modules/assistant/_collections/ass.util.spec.ts +176 -176
  140. package/src/_modules/assistant/_collections/ass.util.ts +50 -50
  141. package/src/_modules/assistant/_models/ass-global-settings.interface.ts +15 -15
  142. package/src/_modules/assistant/_services/ass-io.control-service.spec.ts +140 -140
  143. package/src/_modules/assistant/_services/ass-main.control-service.spec.ts +192 -192
  144. package/src/_modules/assistant/_services/ass-main.control-service.ts +107 -107
  145. package/src/_modules/bot/_collections/bot-default-commands.const.ts +12 -12
  146. package/src/_modules/bot/_collections/bot-global-settings.const.ts +39 -39
  147. package/src/_modules/bot/_models/bot-channel-wrapper.interface.ts +62 -62
  148. package/src/_modules/bot/_models/bot-command.interface.ts +8 -8
  149. package/src/_modules/bot/_models/bot-global-settings.interface.ts +96 -96
  150. package/src/_modules/bot/_models/bot-last-mention-date.interface.ts +6 -6
  151. package/src/_modules/bot/_models/bot-last-message-date.interface.ts +5 -5
  152. package/src/_modules/bot/_models/bot-user-wrapper.interface.ts +41 -41
  153. package/src/_modules/bot/_modules/discord-bot/_models/dib-platform.types.ts +9 -9
  154. package/src/_modules/bot/_modules/discord-bot/_services/dib-messaging-provider.control-service.spec.ts +431 -431
  155. package/src/_modules/bot/_modules/dynamo-bot/_collections/dyb-operations.util.spec.ts +160 -160
  156. package/src/_modules/bot/_modules/dynamo-bot/_collections/dyb-operations.util.ts +55 -55
  157. package/src/_modules/bot/_modules/dynamo-bot/_models/dyb-platform.types.ts +15 -15
  158. package/src/_modules/bot/_modules/dynamo-bot/_services/dyb-messaging-provider.control-service.spec.ts +374 -374
  159. package/src/_modules/bot/_modules/dynamo-bot/_services/dyb-messaging-provider.control-service.ts +447 -447
  160. package/src/_modules/bot/_modules/dynamo-bot/index.ts +15 -15
  161. package/src/_modules/bot/_modules/slack-bot/_models/slb-platform.types.ts +9 -9
  162. package/src/_modules/bot/_modules/slack-bot/_services/slb-messaging-provider.control-service.spec.ts +344 -344
  163. package/src/_modules/bot/_modules/slack-bot/_services/slb-messaging-provider.control-service.ts +197 -197
  164. package/src/_modules/bot/_modules/teams-bot/_models/teb-platform.types.ts +9 -9
  165. package/src/_modules/bot/_modules/teams-bot/_services/teb-messaging-provider.control-service.spec.ts +345 -345
  166. package/src/_modules/bot/_modules/teams-bot/_services/teb-messaging-provider.control-service.ts +197 -197
  167. package/src/_modules/bot/_services/bot-commands.control-service.spec.ts +116 -116
  168. package/src/_modules/bot/_services/bot-io.control-service.spec.ts +285 -285
  169. package/src/_modules/bot/_services/bot-main.control-service.spec.ts +208 -208
  170. package/src/_modules/bot/_services/bot-messaging-provider.service-base.spec.ts +349 -349
  171. package/src/_modules/bot/_services/bot-routines.control-service.spec.ts +111 -111
  172. package/src/_modules/custom-data/custom-data.controller.spec.ts +49 -49
  173. package/src/_modules/custom-data/custom-data.controller.ts +67 -67
  174. package/src/_modules/custom-data/custom-data.data-service.spec.ts +54 -54
  175. package/src/_modules/custom-data/custom-data.data-service.ts +21 -21
  176. package/src/_modules/custom-data/get-custom-data-routing-module.util.spec.ts +28 -28
  177. package/src/_modules/custom-data/get-custom-data-routing-module.util.ts +24 -24
  178. package/src/_modules/custom-data/index.ts +9 -9
  179. package/src/_modules/data-readers/_collections/dynts-sqlite-reader.util.spec.ts +161 -161
  180. package/src/_modules/data-readers/_collections/dynts-sqlite-reader.util.ts +203 -203
  181. package/src/_modules/data-readers/_models/interfaces/dynts-sqlite-reader.interface.ts +33 -33
  182. package/src/_modules/data-readers/index.ts +11 -11
  183. package/src/_modules/defaults/_collections/default-endpoints.util.ts +487 -487
  184. package/src/_modules/defaults/_models/default-user.data-model.ts +72 -72
  185. package/src/_modules/defaults/_services/default-auth.service.spec.ts +269 -269
  186. package/src/_modules/defaults/_services/default-auth.service.ts +177 -177
  187. package/src/_modules/defaults/_services/default-socket-events.service.spec.ts +42 -42
  188. package/src/_modules/defaults/_services/default-socket-events.service.ts +61 -61
  189. package/src/_modules/defaults/_services/default-user.data-service.spec.ts +187 -187
  190. package/src/_modules/defaults/_services/default-user.data-service.ts +98 -98
  191. package/src/_modules/defaults/index.ts +17 -17
  192. package/src/_modules/discord-assistant/_collections/dias-global-settings.const.ts +19 -19
  193. package/src/_modules/discord-assistant/_collections/dias.util.spec.ts +366 -366
  194. package/src/_modules/discord-assistant/_collections/dias.util.ts +132 -132
  195. package/src/_modules/discord-assistant/_models/dias-global-settings.interface.ts +19 -19
  196. package/src/_modules/discord-assistant/_models/dias-knowledge.data-model.ts +52 -52
  197. package/src/_modules/discord-assistant/_services/dias-chunk.data-service.ts +177 -177
  198. package/src/_modules/discord-assistant/_services/dias-io.control-service.spec.ts +108 -108
  199. package/src/_modules/discord-assistant/_services/dias-io.control-service.ts +69 -69
  200. package/src/_modules/discord-assistant/_services/dias-main.control-service.spec.ts +22 -22
  201. package/src/_modules/discord-assistant/_services/dias-main.control-service.ts +27 -27
  202. package/src/_modules/discord-assistant/_services/dias.service-base.spec.ts +195 -195
  203. package/src/_modules/discord-assistant/_services/dias.service-base.ts +76 -76
  204. package/src/_modules/discord-assistant/index.ts +38 -38
  205. package/src/_modules/discord-assistant-voiced/_services/dias-discord-bot.control-service.spec.ts +34 -34
  206. package/src/_modules/discord-assistant-voiced/_services/dias-discord-bot.control-service.ts +11 -11
  207. package/src/_modules/discord-assistant-voiced/index.ts +36 -36
  208. package/src/_modules/discord-bot/_collections/dibo-default-commands.const.ts +16 -16
  209. package/src/_modules/discord-bot/_collections/dibo-global-settings.conts.ts +55 -55
  210. package/src/_modules/discord-bot/_collections/dibo-operations.util.spec.ts +214 -214
  211. package/src/_modules/discord-bot/_collections/dibo-operations.util.ts +387 -387
  212. package/src/_modules/discord-bot/_models/dibo-command.interface.ts +12 -12
  213. package/src/_modules/discord-bot/_models/dibo-global-settings.interface.ts +98 -98
  214. package/src/_modules/discord-bot/_models/dibo-last-mention-date.inteface.ts +7 -7
  215. package/src/_modules/discord-bot/_models/dibo-last-message-date.interface.ts +6 -6
  216. package/src/_modules/discord-bot/_services/dibo-commands.control-service.spec.ts +154 -154
  217. package/src/_modules/discord-bot/_services/dibo-commands.control-service.ts +153 -153
  218. package/src/_modules/discord-bot/_services/dibo-io.control-service.spec.ts +264 -264
  219. package/src/_modules/discord-bot/_services/dibo-io.control-service.ts +306 -306
  220. package/src/_modules/discord-bot/_services/dibo-main.control-service.spec.ts +408 -408
  221. package/src/_modules/discord-bot/_services/dibo-main.control-service.ts +487 -487
  222. package/src/_modules/discord-bot/_services/dibo-routines.control-service.spec.ts +105 -105
  223. package/src/_modules/discord-bot/index.ts +36 -36
  224. package/src/_modules/local-vector-search/_enums/lvs-search-mode.enum.ts +35 -35
  225. package/src/_modules/local-vector-search/_models/data-models/lvs-vector-persist.data-model.ts +59 -59
  226. package/src/_modules/local-vector-search/_models/lvs-search-result.interface.ts +17 -17
  227. package/src/_modules/local-vector-search/_services/lvs-doc-chunk-data.service.spec.ts +418 -418
  228. package/src/_modules/local-vector-search/_services/lvs-doc-chunk-data.service.ts +276 -276
  229. package/src/_modules/local-vector-search/_services/lvs-local-vector-search.data-service.spec.ts +480 -480
  230. package/src/_modules/local-vector-search/_services/lvs-local-vector-search.data-service.ts +416 -416
  231. package/src/_modules/local-vector-search/_services/lvs-persistent-vector-pool.control-service.spec.ts +198 -198
  232. package/src/_modules/local-vector-search/_services/lvs-persistent-vector-pool.control-service.ts +146 -146
  233. package/src/_modules/local-vector-search/_services/lvs-vector-persist.data-service.spec.ts +167 -167
  234. package/src/_modules/local-vector-search/_services/lvs-vector-persist.data-service.ts +106 -106
  235. package/src/_modules/local-vector-search/_services/lvs-vector-pool.control-service.spec.ts +507 -507
  236. package/src/_modules/local-vector-search/_services/lvs-vector-pool.control-service.ts +272 -272
  237. package/src/_modules/local-vector-search/index.ts +16 -16
  238. package/src/_modules/logs/index.ts +11 -11
  239. package/src/_modules/mcp/_models/interfaces/dynts-mcp.interface.ts +111 -111
  240. package/src/_modules/mcp/_services/dynts-mcp-server.service-base.spec.ts +142 -142
  241. package/src/_modules/mcp/_services/dynts-mcp-server.service-base.ts +120 -120
  242. package/src/_modules/mcp/_services/dynts-mcp.adapter.ts +168 -168
  243. package/src/_modules/mcp/index.ts +13 -13
  244. package/src/_modules/messaging/README.md +354 -354
  245. package/src/_modules/messaging/_collections/get-messaging-routing-module.util.ts +26 -26
  246. package/src/_modules/messaging/_collections/msg-global-settings.const.ts +22 -22
  247. package/src/_modules/messaging/_collections/msg.util.spec.ts +226 -226
  248. package/src/_modules/messaging/_models/msg-global-settings.interface.ts +37 -37
  249. package/src/_modules/messaging/_services/msg-conversation.data-service.ts +146 -146
  250. package/src/_modules/messaging/_services/msg-events.service.spec.ts +219 -219
  251. package/src/_modules/messaging/_services/msg-events.service.ts +267 -267
  252. package/src/_modules/messaging/_services/msg-integration.control-service.ts +179 -179
  253. package/src/_modules/messaging/_services/msg-main.control-service.spec.ts +147 -147
  254. package/src/_modules/messaging/_services/msg-main.control-service.ts +571 -571
  255. package/src/_modules/messaging/_services/msg-message.data-service.ts +129 -129
  256. package/src/_modules/messaging/_services/msg.controller.spec.ts +201 -201
  257. package/src/_modules/messaging/index.ts +30 -30
  258. package/src/_modules/mock/app-extended-server.mock.ts +201 -201
  259. package/src/_modules/mock/app-integration-test.mock.ts +51 -51
  260. package/src/_modules/mock/app-params.mock.spec.ts +21 -21
  261. package/src/_modules/mock/app-params.mock.ts +9 -9
  262. package/src/_modules/mock/app-server.mock.ts +188 -188
  263. package/src/_modules/mock/auth-service.mock.spec.ts +47 -47
  264. package/src/_modules/mock/auth-service.mock.ts +28 -28
  265. package/src/_modules/mock/controller.mock.spec.ts +26 -26
  266. package/src/_modules/mock/controller.mock.ts +16 -16
  267. package/src/_modules/mock/data-model.mock.spec.ts +111 -111
  268. package/src/_modules/mock/data-model.mock.ts +82 -82
  269. package/src/_modules/mock/email-service-collection.mock.spec.ts +24 -24
  270. package/src/_modules/mock/email-service-collection.mock.ts +15 -15
  271. package/src/_modules/mock/email-service.mock.spec.ts +17 -17
  272. package/src/_modules/mock/email-service.mock.ts +20 -20
  273. package/src/_modules/mock/email-template.mock.html +14 -14
  274. package/src/_modules/mock/endpoint.mock.ts +91 -91
  275. package/src/_modules/mock/socket-client.mock.spec.ts +40 -40
  276. package/src/_modules/mock/socket-client.mock.ts +45 -45
  277. package/src/_modules/mock/socket-server.mock.spec.ts +44 -44
  278. package/src/_modules/mock/socket-server.mock.ts +46 -46
  279. package/src/_modules/oauth2/_routes/oauth2.controller.spec.ts +107 -107
  280. package/src/_modules/oauth2/_routes/oauth2.controller.ts +98 -98
  281. package/src/_modules/oauth2/_services/oauth2.auth-service.spec.ts +254 -254
  282. package/src/_modules/oauth2/_services/oauth2.auth-service.ts +232 -232
  283. package/src/_modules/oauth2/_services/oauth2.control-service.spec.ts +585 -585
  284. package/src/_modules/oauth2/_services/oauth2.control-service.ts +653 -653
  285. package/src/_modules/oauth2/index.ts +17 -17
  286. package/src/_modules/scoped-config/_enums/dynts-scoped-config-level.enum.ts +22 -22
  287. package/src/_modules/scoped-config/_models/data-models/dynts-scoped-config.data-model.ts +81 -81
  288. package/src/_modules/scoped-config/_models/interfaces/dynts-scoped-config.interface.ts +107 -107
  289. package/src/_modules/scoped-config/_services/dynts-scoped-config.control-service.spec.ts +306 -306
  290. package/src/_modules/scoped-config/_services/dynts-scoped-config.control-service.ts +295 -295
  291. package/src/_modules/scoped-config/_services/dynts-scoped-config.data-service.spec.ts +118 -118
  292. package/src/_modules/scoped-config/_services/dynts-scoped-config.data-service.ts +105 -105
  293. package/src/_modules/scoped-config/index.ts +17 -17
  294. package/src/_modules/server/errors/errors.control-service.spec.ts +238 -238
  295. package/src/_modules/server/errors/errors.control-service.ts +100 -100
  296. package/src/_modules/server/errors/errors.controller.spec.ts +241 -241
  297. package/src/_modules/server/errors/errors.controller.ts +489 -489
  298. package/src/_modules/server/errors/errors.data-service.spec.ts +480 -480
  299. package/src/_modules/server/index.ts +30 -30
  300. package/src/_modules/server/server-status/server-status-snapshot.control-service.spec.ts +70 -70
  301. package/src/_modules/server/server-status/server-status-snapshot.control-service.ts +17 -17
  302. package/src/_modules/server/server-status/server-status-snapshot.data-service.spec.ts +77 -77
  303. package/src/_modules/server/server-status/server-status-snapshot.data-service.ts +37 -37
  304. package/src/_modules/server/server-status/server-status.control-service.spec.ts +576 -576
  305. package/src/_modules/server/server-status/server-status.control-service.ts +396 -396
  306. package/src/_modules/server/server-status/server-status.controller.spec.ts +240 -240
  307. package/src/_modules/server/server-status/server-status.controller.ts +253 -253
  308. package/src/_modules/socket/_enums/socket-security.enum.ts +11 -11
  309. package/src/_modules/socket/_models/socket-client-service-params.control-model.spec.ts +32 -32
  310. package/src/_modules/socket/_models/socket-client-service-params.control-model.ts +22 -22
  311. package/src/_modules/socket/_models/socket-presence.control-model.spec.ts +164 -164
  312. package/src/_modules/socket/_models/socket-presence.control-model.ts +210 -210
  313. package/src/_modules/socket/_models/socket-server-service-params.control-model.spec.ts +46 -46
  314. package/src/_modules/socket/_models/socket-server-service-params.control-model.ts +22 -22
  315. package/src/_modules/socket/_services/socket-client.service.spec.ts +15 -15
  316. package/src/_modules/socket/_services/socket-client.service.ts +260 -260
  317. package/src/_modules/socket/_services/socket-server.service.spec.ts +11 -11
  318. package/src/_modules/socket/app-extended.integration.spec.ts +85 -85
  319. package/src/_modules/socket/app-extended.server.ts +630 -630
  320. package/src/_modules/socket/index.ts +42 -42
  321. package/src/_modules/test/get-test-routing-module.util.spec.ts +28 -28
  322. package/src/_modules/test/get-test-routing-module.util.ts +23 -23
  323. package/src/_modules/test/index.ts +11 -11
  324. package/src/_modules/test/test.controller.spec.ts +72 -72
  325. package/src/_modules/test/test.controller.ts +115 -115
  326. package/src/_modules/usage/get-usage-routing-module.util.ts +22 -22
  327. package/src/_modules/usage/index.ts +15 -15
  328. package/src/_modules/usage/usage.controller.spec.ts +81 -81
  329. package/src/_modules/usage/usage.controller.ts +126 -126
  330. package/src/_modules/usage/usage.data-service.spec.ts +332 -332
  331. package/src/_modules/usage/usage.data-service.ts +185 -185
  332. package/src/_services/base/api.service-base.spec.ts +125 -125
  333. package/src/_services/base/api.service-base.ts +74 -74
  334. package/src/_services/base/archive-data.service.spec.ts +196 -196
  335. package/src/_services/base/archive-data.service.ts +216 -216
  336. package/src/_services/base/data.service.spec.ts +674 -674
  337. package/src/_services/base/data.service.ts +2719 -2719
  338. package/src/_services/base/db.service.spec.ts +73 -73
  339. package/src/_services/base/db.service.ts +1575 -1575
  340. package/src/_services/base/singleton.service-base.spec.ts +28 -28
  341. package/src/_services/base/singleton.service-base.ts +24 -24
  342. package/src/_services/base/singleton.service.spec.ts +114 -114
  343. package/src/_services/base/singleton.service.ts +38 -38
  344. package/src/_services/core/api.service.spec.ts +140 -140
  345. package/src/_services/core/auth.service.spec.ts +159 -159
  346. package/src/_services/core/auth.service.ts +174 -174
  347. package/src/_services/core/email.service.spec.ts +85 -85
  348. package/src/_services/core/email.service.ts +742 -742
  349. package/src/_services/core/global.service.spec.ts +292 -292
  350. package/src/_services/core/global.service.ts +475 -475
  351. package/src/_services/core/memory-guard.service.spec.ts +62 -0
  352. package/src/_services/core/memory-guard.service.ts +195 -6
  353. package/src/_services/core/service-collection.service.spec.ts +46 -46
  354. package/src/_services/core/service-collection.service.ts +6 -6
  355. package/src/_services/route/controller.service.spec.ts +53 -53
  356. package/src/_services/route/controller.service.ts +148 -148
  357. package/src/_services/route/routing-module.service.spec.ts +98 -98
  358. package/src/_services/route/routing-module.service.ts +330 -330
  359. package/src/_services/server/app.server.ts +1747 -1747
  360. package/src/_services/shared.static-service.spec.ts +99 -99
  361. package/src/_services/shared.static-service.ts +78 -78
  362. package/src/index.ts +96 -96
  363. package/tsconfig.app.json +12 -12
  364. package/tsconfig.json +42 -42
  365. package/.dynamo/logs/cicd-pipeline/output.log +0 -2875
  366. package/.dynamo/logs/cicd-pipeline/status.json +0 -94
@@ -2,551 +2,551 @@ import * as ts from 'typescript';
2
2
 
3
3
  import { DyFM_Log } from '@futdevpro/fsm-dynamo';
4
4
 
5
- import { DyNTS_DAI_CodeChunk, DyNTS_DAI_CodeChunkType } from '../_models/interfaces/dai-code-chunk.interface';
6
-
7
- /** A kód-chunker méret-paraméterei (a FAM/CCAP konstansokkal egyező default-ok). */
8
- export interface DyNTS_DAI_CodeChunking_Options {
9
- /** Max chunk-méret karakterben (e fölött sliding-window sub-split). Default: 1500. */
10
- maxChunkSize?: number;
11
- /** Overlap karakterben a nagy-node sliding-window-ban. Default: 100. */
12
- overlap?: number;
13
- /** Minimum chunk-méret (ennél kisebb chunk-ot eldobunk a zaj ellen). Default: 50. */
14
- minChunkSize?: number;
15
- }
16
-
17
- /** Belső, normalizált méret-konfiguráció (a default-ok feloldása után). */
18
- interface DyNTS_DAI_CodeChunking_Sizing {
19
- maxChunkSize: number;
20
- overlap: number;
21
- minChunkSize: number;
22
- }
23
-
24
- /**
25
- * Belső, AST-ből kinyert szemantikus blokk (a chunkká alakítás előtti közbenső reprezentáció).
26
- */
27
- interface DyNTS_DAI_CodeBlock {
28
- /** A node forrás-szövege (JSDoc + dekorátorok kezdetétől a node végéig). */
29
- text: string;
30
- /** A chunk szemantikus típusa. */
31
- chunkType: DyNTS_DAI_CodeChunkType;
32
- /** A symbol-lánc szegmensei (pl. `['class:Foo', 'method:bar']`). */
33
- symbolSegments: string[];
34
- /** A legbelső symbol neve, ha van. */
35
- symbolName?: string;
36
- /** Karakter-kezdőpozíció a forrásban (0-alapú, inkluzív; JSDoc-ot is tartalmazza). */
37
- charStart: number;
38
- /** Karakter-végpozíció a forrásban (0-alapú, exkluzív). */
39
- charEnd: number;
40
- }
41
-
42
- /**
43
- * `DyNTS_DAI_CodeChunking_Util` (BFR-AM-005) — **AST-pontos** TypeScript/JavaScript kód-chunker
44
- * a TypeScript Compiler API-val (`ts.createSourceFile`). A FAM `FAM_TsChunker_Util` regex/brace-depth
45
- * workaround-jának **bedrock-szintű, durable** változata: a `{`/`}` számolás helyett a valódi
46
- * szintaxisfát járja be, így string-literálban / template-literálban / comment-ben lévő zárójelek
47
- * NEM tévesztik meg.
48
- *
49
- * **Chunkolási stratégia (top-level node-onként, egy chunk per szemantikus egység):**
50
- * - **import-group** — az összes egymást követő top-level `import` / `export ... from` egy chunkba
51
- * (a köztük lévő üres sorokkal együtt).
52
- * - **class** — ha belefér a `maxChunkSize`-ba, az egész osztály egy chunk (dekorátorok + JSDoc-cal);
53
- * ha NEM fér bele, **metódusonként** bomlik (osztály-fej + minden metódus külön chunk, a
54
- * `class:Foo > method:bar` symbol-lánccal).
55
- * - **interface / enum / type-alias / standalone function / top-level const(=>fn/value)** — egy chunk
56
- * per deklaráció.
57
- * - **nagy node** (a fentiek közül bármelyik, ami a metódus-bontás UTÁN is `maxChunkSize` fölötti) →
58
- * karakter-alapú **sliding-window** sub-split (örökölt `chunkType` + symbol-lánc, `subChunkIndex`-szel).
59
- * - **tiny / parse-degenerált tartalom** → egyetlen `fallback` chunk (a teljes forrás), hogy soha
60
- * ne vesszen el tartalom.
61
- *
62
- * A JSDoc + `@Decorator` MINDIG a következő node-dal együtt marad (a `node.getStart(sf, true)` a
63
- * leading-JSDoc elejétől indul, a `ts.getDecorators` a node része).
64
- *
65
- * **headingPath = kód-symbol-lánc** (a markdown-chunker heading-láncának kód-megfelelője):
66
- * `symbolPath` = a szegmensek ` > `-rel összefűzve.
67
- */
68
- export class DyNTS_DAI_CodeChunking_Util {
69
-
70
- /** A FAM/CCAP-egyeztetett default méret-konstansok. */
71
- private static readonly DEFAULT_MAX_CHUNK_SIZE: number = 1500;
72
- private static readonly DEFAULT_OVERLAP: number = 100;
73
- private static readonly DEFAULT_MIN_CHUNK_SIZE: number = 50;
74
-
75
- /**
76
- * Egy TS/JS forrás chunkolása szemantikus blokkok mentén a TS Compiler API AST-jával.
77
- * Üres / whitespace-only tartalom → üres lista. A `maxChunkSize` fölötti node-ok sliding-window-ra
78
- * bomlanak; a degenerált (parse-hiba / 0 blokk) esetet egyetlen `fallback` chunk fedi.
79
- *
80
- * @param code - A forráskód.
81
- * @param opts - Méret-paraméterek (default 1500/100/50).
82
- * @returns A szemantikus kód-chunkok listája (0-alapú `chunkIndex`-szel).
83
- */
84
- static chunkTs(code: string, opts?: DyNTS_DAI_CodeChunking_Options): DyNTS_DAI_CodeChunk[] {
85
- if (!code?.trim()) {
86
- return [];
87
- }
88
-
89
- const sizing: DyNTS_DAI_CodeChunking_Sizing = this.resolveSizing(opts);
90
-
5
+ import { DyNTS_DAI_CodeChunk, DyNTS_DAI_CodeChunkType } from '../_models/interfaces/dai-code-chunk.interface';
6
+
7
+ /** A kód-chunker méret-paraméterei (a FAM/CCAP konstansokkal egyező default-ok). */
8
+ export interface DyNTS_DAI_CodeChunking_Options {
9
+ /** Max chunk-méret karakterben (e fölött sliding-window sub-split). Default: 1500. */
10
+ maxChunkSize?: number;
11
+ /** Overlap karakterben a nagy-node sliding-window-ban. Default: 100. */
12
+ overlap?: number;
13
+ /** Minimum chunk-méret (ennél kisebb chunk-ot eldobunk a zaj ellen). Default: 50. */
14
+ minChunkSize?: number;
15
+ }
16
+
17
+ /** Belső, normalizált méret-konfiguráció (a default-ok feloldása után). */
18
+ interface DyNTS_DAI_CodeChunking_Sizing {
19
+ maxChunkSize: number;
20
+ overlap: number;
21
+ minChunkSize: number;
22
+ }
23
+
24
+ /**
25
+ * Belső, AST-ből kinyert szemantikus blokk (a chunkká alakítás előtti közbenső reprezentáció).
26
+ */
27
+ interface DyNTS_DAI_CodeBlock {
28
+ /** A node forrás-szövege (JSDoc + dekorátorok kezdetétől a node végéig). */
29
+ text: string;
30
+ /** A chunk szemantikus típusa. */
31
+ chunkType: DyNTS_DAI_CodeChunkType;
32
+ /** A symbol-lánc szegmensei (pl. `['class:Foo', 'method:bar']`). */
33
+ symbolSegments: string[];
34
+ /** A legbelső symbol neve, ha van. */
35
+ symbolName?: string;
36
+ /** Karakter-kezdőpozíció a forrásban (0-alapú, inkluzív; JSDoc-ot is tartalmazza). */
37
+ charStart: number;
38
+ /** Karakter-végpozíció a forrásban (0-alapú, exkluzív). */
39
+ charEnd: number;
40
+ }
41
+
42
+ /**
43
+ * `DyNTS_DAI_CodeChunking_Util` (BFR-AM-005) — **AST-pontos** TypeScript/JavaScript kód-chunker
44
+ * a TypeScript Compiler API-val (`ts.createSourceFile`). A FAM `FAM_TsChunker_Util` regex/brace-depth
45
+ * workaround-jának **bedrock-szintű, durable** változata: a `{`/`}` számolás helyett a valódi
46
+ * szintaxisfát járja be, így string-literálban / template-literálban / comment-ben lévő zárójelek
47
+ * NEM tévesztik meg.
48
+ *
49
+ * **Chunkolási stratégia (top-level node-onként, egy chunk per szemantikus egység):**
50
+ * - **import-group** — az összes egymást követő top-level `import` / `export ... from` egy chunkba
51
+ * (a köztük lévő üres sorokkal együtt).
52
+ * - **class** — ha belefér a `maxChunkSize`-ba, az egész osztály egy chunk (dekorátorok + JSDoc-cal);
53
+ * ha NEM fér bele, **metódusonként** bomlik (osztály-fej + minden metódus külön chunk, a
54
+ * `class:Foo > method:bar` symbol-lánccal).
55
+ * - **interface / enum / type-alias / standalone function / top-level const(=>fn/value)** — egy chunk
56
+ * per deklaráció.
57
+ * - **nagy node** (a fentiek közül bármelyik, ami a metódus-bontás UTÁN is `maxChunkSize` fölötti) →
58
+ * karakter-alapú **sliding-window** sub-split (örökölt `chunkType` + symbol-lánc, `subChunkIndex`-szel).
59
+ * - **tiny / parse-degenerált tartalom** → egyetlen `fallback` chunk (a teljes forrás), hogy soha
60
+ * ne vesszen el tartalom.
61
+ *
62
+ * A JSDoc + `@Decorator` MINDIG a következő node-dal együtt marad (a `node.getStart(sf, true)` a
63
+ * leading-JSDoc elejétől indul, a `ts.getDecorators` a node része).
64
+ *
65
+ * **headingPath = kód-symbol-lánc** (a markdown-chunker heading-láncának kód-megfelelője):
66
+ * `symbolPath` = a szegmensek ` > `-rel összefűzve.
67
+ */
68
+ export class DyNTS_DAI_CodeChunking_Util {
69
+
70
+ /** A FAM/CCAP-egyeztetett default méret-konstansok. */
71
+ private static readonly DEFAULT_MAX_CHUNK_SIZE: number = 1500;
72
+ private static readonly DEFAULT_OVERLAP: number = 100;
73
+ private static readonly DEFAULT_MIN_CHUNK_SIZE: number = 50;
74
+
75
+ /**
76
+ * Egy TS/JS forrás chunkolása szemantikus blokkok mentén a TS Compiler API AST-jával.
77
+ * Üres / whitespace-only tartalom → üres lista. A `maxChunkSize` fölötti node-ok sliding-window-ra
78
+ * bomlanak; a degenerált (parse-hiba / 0 blokk) esetet egyetlen `fallback` chunk fedi.
79
+ *
80
+ * @param code - A forráskód.
81
+ * @param opts - Méret-paraméterek (default 1500/100/50).
82
+ * @returns A szemantikus kód-chunkok listája (0-alapú `chunkIndex`-szel).
83
+ */
84
+ static chunkTs(code: string, opts?: DyNTS_DAI_CodeChunking_Options): DyNTS_DAI_CodeChunk[] {
85
+ if (!code?.trim()) {
86
+ return [];
87
+ }
88
+
89
+ const sizing: DyNTS_DAI_CodeChunking_Sizing = this.resolveSizing(opts);
90
+
91
91
  let blocks: DyNTS_DAI_CodeBlock[] = [];
92
-
93
- try {
94
- const sourceFile: ts.SourceFile = ts.createSourceFile(
95
- 'chunk-input.ts',
96
- code,
97
- ts.ScriptTarget.Latest,
98
- /* setParentNodes */ true,
99
- ts.ScriptKind.TSX
92
+
93
+ try {
94
+ const sourceFile: ts.SourceFile = ts.createSourceFile(
95
+ 'chunk-input.ts',
96
+ code,
97
+ ts.ScriptTarget.Latest,
98
+ /* setParentNodes */ true,
99
+ ts.ScriptKind.TSX
100
100
  );
101
-
102
- blocks = this.identifyBlocks(sourceFile, code, sizing);
103
- } catch (error) {
104
- // Parse-hiba (degenerált forrás) → a tiny-fallback veszi át lentebb.
105
- DyFM_Log.warn('DyNTS_DAI_CodeChunking_Util.chunkTs: AST parse failed, using fallback chunk', {
106
- error: (error as Error)?.message,
107
- });
108
- blocks = [];
109
- }
110
-
111
- // Tiny / degenerált esetek: ha nincs azonosított blokk, vagy a teljes forrás kicsi → egyetlen
112
- // fallback chunk (soha ne vesszen el tartalom).
113
- if (!blocks.length) {
114
- return this.buildFallbackChunks(code, sizing);
115
- }
116
-
117
- // A sor-pozíciókhoz a teljes forrás sortörés-offszetjei (egyszer számolva).
118
- const lineStartOffsets: number[] = this.computeLineStartOffsets(code);
119
-
101
+
102
+ blocks = this.identifyBlocks(sourceFile, code, sizing);
103
+ } catch (error) {
104
+ // Parse-hiba (degenerált forrás) → a tiny-fallback veszi át lentebb.
105
+ DyFM_Log.warn('DyNTS_DAI_CodeChunking_Util.chunkTs: AST parse failed, using fallback chunk', {
106
+ error: (error as Error)?.message,
107
+ });
108
+ blocks = [];
109
+ }
110
+
111
+ // Tiny / degenerált esetek: ha nincs azonosított blokk, vagy a teljes forrás kicsi → egyetlen
112
+ // fallback chunk (soha ne vesszen el tartalom).
113
+ if (!blocks.length) {
114
+ return this.buildFallbackChunks(code, sizing);
115
+ }
116
+
117
+ // A sor-pozíciókhoz a teljes forrás sortörés-offszetjei (egyszer számolva).
118
+ const lineStartOffsets: number[] = this.computeLineStartOffsets(code);
119
+
120
120
  const chunks: DyNTS_DAI_CodeChunk[] = [];
121
-
122
- for (const block of blocks) {
123
- // Zaj-szűrés: CSAK a névtelen `generic` blokkokat dobjuk a minChunkSize alatt. A nevesített
124
- // szemantikus deklarációk (type-alias / rövid function / class-fej / metódus / interface /
125
- // enum / variable) MINDIG saját chunkot kapnak, méretüktől függetlenül — egy `type Id = string`
126
- // teljes értékű egység. Az import-csoport sosem esik ki.
127
- if (block.chunkType === 'generic' && block.text.trim().length < sizing.minChunkSize) {
128
- continue;
129
- }
130
-
131
- if (block.text.length <= sizing.maxChunkSize) {
132
- chunks.push(this.blockToChunk(block, chunks.length, lineStartOffsets));
133
- continue;
134
- }
135
-
136
- // Túl nagy node → karakter-alapú sliding-window sub-split (örökölt symbol-lánc + chunkType).
137
- this.splitLargeBlock(block, sizing, chunks, lineStartOffsets);
138
- }
139
-
140
- // Ha minden blokk kiesett a minChunkSize-szűrőn (pl. sok apró egysoros), essünk vissza a
141
- // fallback-re, hogy ne adjunk vissza üres listát nem-üres bemenetre.
142
- if (!chunks.length) {
143
- return this.buildFallbackChunks(code, sizing);
144
- }
145
-
146
- return chunks;
147
- }
148
-
149
- /**
150
- * Dispatcher: a `filename` kiterjesztése alapján a `.ts/.tsx/.js/.jsx/.mts/.cts/.mjs/.cjs`
151
- * forrásokat az AST-chunkerre (`chunkTs`), minden mást (pl. `.md`) az adott formátum nyers
152
- * sliding-fallback-jére irányít. A markdown-specifikus chunkolás a `DyNTS_DAI_DocChunking_Util`
153
- * felelőssége (page-modell + parent-hierarchia kell hozzá), ezért azt itt NEM hívjuk —
154
- * additív marad. Nem-kód input → `fallback` chunk a tartalom megőrzéséhez.
155
- *
156
- * @param content - A fájl tartalma.
157
- * @param filename - A fájlnév (a kiterjesztés-alapú routinghoz).
158
- * @param opts - Méret-paraméterek.
159
- */
160
- static chunk(content: string, filename: string, opts?: DyNTS_DAI_CodeChunking_Options): DyNTS_DAI_CodeChunk[] {
161
- if (this.isTsLike(filename)) {
162
- return this.chunkTs(content, opts);
121
+
122
+ for (const block of blocks) {
123
+ // Zaj-szűrés: CSAK a névtelen `generic` blokkokat dobjuk a minChunkSize alatt. A nevesített
124
+ // szemantikus deklarációk (type-alias / rövid function / class-fej / metódus / interface /
125
+ // enum / variable) MINDIG saját chunkot kapnak, méretüktől függetlenül — egy `type Id = string`
126
+ // teljes értékű egység. Az import-csoport sosem esik ki.
127
+ if (block.chunkType === 'generic' && block.text.trim().length < sizing.minChunkSize) {
128
+ continue;
129
+ }
130
+
131
+ if (block.text.length <= sizing.maxChunkSize) {
132
+ chunks.push(this.blockToChunk(block, chunks.length, lineStartOffsets));
133
+ continue;
134
+ }
135
+
136
+ // Túl nagy node → karakter-alapú sliding-window sub-split (örökölt symbol-lánc + chunkType).
137
+ this.splitLargeBlock(block, sizing, chunks, lineStartOffsets);
138
+ }
139
+
140
+ // Ha minden blokk kiesett a minChunkSize-szűrőn (pl. sok apró egysoros), essünk vissza a
141
+ // fallback-re, hogy ne adjunk vissza üres listát nem-üres bemenetre.
142
+ if (!chunks.length) {
143
+ return this.buildFallbackChunks(code, sizing);
144
+ }
145
+
146
+ return chunks;
147
+ }
148
+
149
+ /**
150
+ * Dispatcher: a `filename` kiterjesztése alapján a `.ts/.tsx/.js/.jsx/.mts/.cts/.mjs/.cjs`
151
+ * forrásokat az AST-chunkerre (`chunkTs`), minden mást (pl. `.md`) az adott formátum nyers
152
+ * sliding-fallback-jére irányít. A markdown-specifikus chunkolás a `DyNTS_DAI_DocChunking_Util`
153
+ * felelőssége (page-modell + parent-hierarchia kell hozzá), ezért azt itt NEM hívjuk —
154
+ * additív marad. Nem-kód input → `fallback` chunk a tartalom megőrzéséhez.
155
+ *
156
+ * @param content - A fájl tartalma.
157
+ * @param filename - A fájlnév (a kiterjesztés-alapú routinghoz).
158
+ * @param opts - Méret-paraméterek.
159
+ */
160
+ static chunk(content: string, filename: string, opts?: DyNTS_DAI_CodeChunking_Options): DyNTS_DAI_CodeChunk[] {
161
+ if (this.isTsLike(filename)) {
162
+ return this.chunkTs(content, opts);
163
163
  }
164
-
165
- // Nem-kód (pl. .md / .txt / ismeretlen): nyers fallback chunkok — a tartalmat megőrizzük,
166
- // de NEM próbáljuk szemantikusan darabolni (a markdown-darabolás külön util-é).
167
- if (!content?.trim()) {
168
- return [];
164
+
165
+ // Nem-kód (pl. .md / .txt / ismeretlen): nyers fallback chunkok — a tartalmat megőrizzük,
166
+ // de NEM próbáljuk szemantikusan darabolni (a markdown-darabolás külön util-é).
167
+ if (!content?.trim()) {
168
+ return [];
169
169
  }
170
-
171
- return this.buildFallbackChunks(content, this.resolveSizing(opts));
172
- }
173
-
174
- /** `true`, ha a fájlnév TS/JS-szerű (a `chunkTs` AST-parsere tudja kezelni). */
175
- private static isTsLike(filename: string): boolean {
176
- return /\.(ts|tsx|mts|cts|js|jsx|mjs|cjs)$/i.test(filename || '');
177
- }
178
-
179
- /** A default-ok feloldása (1500/100/50) + sanity-clamp. */
180
- private static resolveSizing(opts?: DyNTS_DAI_CodeChunking_Options): DyNTS_DAI_CodeChunking_Sizing {
181
- const maxChunkSize: number = Math.max(1, opts?.maxChunkSize ?? this.DEFAULT_MAX_CHUNK_SIZE);
182
- const overlap: number = Math.max(0, Math.min(opts?.overlap ?? this.DEFAULT_OVERLAP, maxChunkSize - 1));
170
+
171
+ return this.buildFallbackChunks(content, this.resolveSizing(opts));
172
+ }
173
+
174
+ /** `true`, ha a fájlnév TS/JS-szerű (a `chunkTs` AST-parsere tudja kezelni). */
175
+ private static isTsLike(filename: string): boolean {
176
+ return /\.(ts|tsx|mts|cts|js|jsx|mjs|cjs)$/i.test(filename || '');
177
+ }
178
+
179
+ /** A default-ok feloldása (1500/100/50) + sanity-clamp. */
180
+ private static resolveSizing(opts?: DyNTS_DAI_CodeChunking_Options): DyNTS_DAI_CodeChunking_Sizing {
181
+ const maxChunkSize: number = Math.max(1, opts?.maxChunkSize ?? this.DEFAULT_MAX_CHUNK_SIZE);
182
+ const overlap: number = Math.max(0, Math.min(opts?.overlap ?? this.DEFAULT_OVERLAP, maxChunkSize - 1));
183
183
  const minChunkSize: number = Math.max(0, opts?.minChunkSize ?? this.DEFAULT_MIN_CHUNK_SIZE);
184
-
185
- return { maxChunkSize: maxChunkSize, overlap: overlap, minChunkSize: minChunkSize };
186
- }
187
-
188
- /**
189
- * AST-bejárás: a `SourceFile` top-level statement-jeit szemantikus blokkokká alakítja. Az
190
- * egymást követő import-okat egy `imports` blokkba vonja össze. A `maxChunkSize` fölötti
191
- * osztályt metódusonként bontja.
192
- */
193
- private static identifyBlocks(
194
- sourceFile: ts.SourceFile,
195
- code: string,
196
- sizing: DyNTS_DAI_CodeChunking_Sizing
197
- ): DyNTS_DAI_CodeBlock[] {
198
- const blocks: DyNTS_DAI_CodeBlock[] = [];
199
-
200
- // -- Import-csoport összevonás --
201
- let importStart: number = -1;
202
- let importEnd: number = -1;
203
-
204
- const flushImports: () => void = () => {
205
- if (importStart < 0) {
206
- return;
207
- }
184
+
185
+ return { maxChunkSize: maxChunkSize, overlap: overlap, minChunkSize: minChunkSize };
186
+ }
187
+
188
+ /**
189
+ * AST-bejárás: a `SourceFile` top-level statement-jeit szemantikus blokkokká alakítja. Az
190
+ * egymást követő import-okat egy `imports` blokkba vonja össze. A `maxChunkSize` fölötti
191
+ * osztályt metódusonként bontja.
192
+ */
193
+ private static identifyBlocks(
194
+ sourceFile: ts.SourceFile,
195
+ code: string,
196
+ sizing: DyNTS_DAI_CodeChunking_Sizing
197
+ ): DyNTS_DAI_CodeBlock[] {
198
+ const blocks: DyNTS_DAI_CodeBlock[] = [];
199
+
200
+ // -- Import-csoport összevonás --
201
+ let importStart: number = -1;
202
+ let importEnd: number = -1;
203
+
204
+ const flushImports: () => void = () => {
205
+ if (importStart < 0) {
206
+ return;
207
+ }
208
208
  const text: string = code.substring(importStart, importEnd);
209
-
210
- if (text.trim().length) {
211
- blocks.push({
212
- text: text,
213
- chunkType: 'imports',
214
- symbolSegments: [],
215
- symbolName: undefined,
216
- charStart: importStart,
217
- charEnd: importEnd,
218
- });
219
- }
220
- importStart = -1;
221
- importEnd = -1;
222
- };
223
-
224
- for (const statement of sourceFile.statements) {
225
- if (this.isImportLike(statement)) {
209
+
210
+ if (text.trim().length) {
211
+ blocks.push({
212
+ text: text,
213
+ chunkType: 'imports',
214
+ symbolSegments: [],
215
+ symbolName: undefined,
216
+ charStart: importStart,
217
+ charEnd: importEnd,
218
+ });
219
+ }
220
+ importStart = -1;
221
+ importEnd = -1;
222
+ };
223
+
224
+ for (const statement of sourceFile.statements) {
225
+ if (this.isImportLike(statement)) {
226
226
  const start: number = statement.getStart(sourceFile, /* includeJsDocComment */ true);
227
-
228
- if (importStart < 0) {
229
- importStart = start;
230
- }
231
- importEnd = statement.getEnd();
232
- continue;
233
- }
234
-
235
- // Más jött → import-csoport lezárása.
236
- flushImports();
237
-
238
- const detected: { chunkType: DyNTS_DAI_CodeChunkType; name?: string } = this.detectDeclaration(statement);
239
- const start: number = statement.getStart(sourceFile, /* includeJsDocComment */ true);
240
- const end: number = statement.getEnd();
241
- const text: string = code.substring(start, end);
242
- const symbolSegments: string[] = detected.name ? [ `${detected.chunkType}:${detected.name}` ] : [];
243
-
244
- // Nagy osztály → metódusonkénti bontás (osztály-fej + metódusok).
245
- if (ts.isClassDeclaration(statement) && text.length > sizing.maxChunkSize) {
246
- this.splitClassByMethods(statement, sourceFile, code, detected.name, blocks);
247
- continue;
248
- }
249
-
250
- blocks.push({
251
- text: text,
252
- chunkType: detected.chunkType,
253
- symbolSegments: symbolSegments,
254
- symbolName: detected.name,
255
- charStart: start,
256
- charEnd: end,
257
- });
227
+
228
+ if (importStart < 0) {
229
+ importStart = start;
230
+ }
231
+ importEnd = statement.getEnd();
232
+ continue;
233
+ }
234
+
235
+ // Más jött → import-csoport lezárása.
236
+ flushImports();
237
+
238
+ const detected: { chunkType: DyNTS_DAI_CodeChunkType; name?: string } = this.detectDeclaration(statement);
239
+ const start: number = statement.getStart(sourceFile, /* includeJsDocComment */ true);
240
+ const end: number = statement.getEnd();
241
+ const text: string = code.substring(start, end);
242
+ const symbolSegments: string[] = detected.name ? [ `${detected.chunkType}:${detected.name}` ] : [];
243
+
244
+ // Nagy osztály → metódusonkénti bontás (osztály-fej + metódusok).
245
+ if (ts.isClassDeclaration(statement) && text.length > sizing.maxChunkSize) {
246
+ this.splitClassByMethods(statement, sourceFile, code, detected.name, blocks);
247
+ continue;
248
+ }
249
+
250
+ blocks.push({
251
+ text: text,
252
+ chunkType: detected.chunkType,
253
+ symbolSegments: symbolSegments,
254
+ symbolName: detected.name,
255
+ charStart: start,
256
+ charEnd: end,
257
+ });
258
+ }
259
+
260
+ // Maradék import-csoport (ha a fájl import-tal végződik).
261
+ flushImports();
262
+
263
+ return blocks;
264
+ }
265
+
266
+ /** `true`, ha a statement import / re-export (`export ... from`) — az import-csoporthoz. */
267
+ private static isImportLike(statement: ts.Statement): boolean {
268
+ if (ts.isImportDeclaration(statement) || ts.isImportEqualsDeclaration(statement)) {
269
+ return true;
258
270
  }
259
-
260
- // Maradék import-csoport (ha a fájl import-tal végződik).
261
- flushImports();
262
-
263
- return blocks;
264
- }
265
-
266
- /** `true`, ha a statement import / re-export (`export ... from`) — az import-csoporthoz. */
267
- private static isImportLike(statement: ts.Statement): boolean {
268
- if (ts.isImportDeclaration(statement) || ts.isImportEqualsDeclaration(statement)) {
269
- return true;
271
+
272
+ // `export { ... } from '...'` / `export * from '...'` — csak ha van moduleSpecifier.
273
+ if (ts.isExportDeclaration(statement) && !!statement.moduleSpecifier) {
274
+ return true;
270
275
  }
271
-
272
- // `export { ... } from '...'` / `export * from '...'` — csak ha van moduleSpecifier.
273
- if (ts.isExportDeclaration(statement) && !!statement.moduleSpecifier) {
274
- return true;
276
+
277
+ return false;
278
+ }
279
+
280
+ /** Egy top-level statement → szemantikus chunk-típus + symbol-név. */
281
+ private static detectDeclaration(statement: ts.Statement): { chunkType: DyNTS_DAI_CodeChunkType; name?: string } {
282
+ if (ts.isClassDeclaration(statement)) {
283
+ return { chunkType: 'class', name: statement.name?.getText() };
275
284
  }
276
-
277
- return false;
278
- }
279
-
280
- /** Egy top-level statement → szemantikus chunk-típus + symbol-név. */
281
- private static detectDeclaration(statement: ts.Statement): { chunkType: DyNTS_DAI_CodeChunkType; name?: string } {
282
- if (ts.isClassDeclaration(statement)) {
283
- return { chunkType: 'class', name: statement.name?.getText() };
285
+
286
+ if (ts.isInterfaceDeclaration(statement)) {
287
+ return { chunkType: 'interface', name: statement.name.getText() };
284
288
  }
285
-
286
- if (ts.isInterfaceDeclaration(statement)) {
287
- return { chunkType: 'interface', name: statement.name.getText() };
289
+
290
+ if (ts.isEnumDeclaration(statement)) {
291
+ return { chunkType: 'enum', name: statement.name.getText() };
288
292
  }
289
-
290
- if (ts.isEnumDeclaration(statement)) {
291
- return { chunkType: 'enum', name: statement.name.getText() };
292
- }
293
-
294
- if (ts.isTypeAliasDeclaration(statement)) {
295
- return { chunkType: 'type', name: statement.name.getText() };
293
+
294
+ if (ts.isTypeAliasDeclaration(statement)) {
295
+ return { chunkType: 'type', name: statement.name.getText() };
296
296
  }
297
-
298
- if (ts.isFunctionDeclaration(statement)) {
299
- return { chunkType: 'function', name: statement.name?.getText() };
297
+
298
+ if (ts.isFunctionDeclaration(statement)) {
299
+ return { chunkType: 'function', name: statement.name?.getText() };
300
300
  }
301
-
302
- if (ts.isVariableStatement(statement)) {
303
- const firstDecl: ts.VariableDeclaration | undefined = statement.declarationList.declarations[0];
304
- const name: string | undefined = firstDecl && ts.isIdentifier(firstDecl.name)
305
- ? firstDecl.name.getText()
306
- : undefined;
307
- // Ha a const egy függvény/arrow → 'function', egyébként 'variable'.
308
- const initializer: ts.Expression | undefined = firstDecl?.initializer;
309
- const isFn: boolean = !!initializer
301
+
302
+ if (ts.isVariableStatement(statement)) {
303
+ const firstDecl: ts.VariableDeclaration | undefined = statement.declarationList.declarations[0];
304
+ const name: string | undefined = firstDecl && ts.isIdentifier(firstDecl.name)
305
+ ? firstDecl.name.getText()
306
+ : undefined;
307
+ // Ha a const egy függvény/arrow → 'function', egyébként 'variable'.
308
+ const initializer: ts.Expression | undefined = firstDecl?.initializer;
309
+ const isFn: boolean = !!initializer
310
310
  && (ts.isArrowFunction(initializer) || ts.isFunctionExpression(initializer));
311
-
312
- return { chunkType: isFn ? 'function' : 'variable', name: name };
311
+
312
+ return { chunkType: isFn ? 'function' : 'variable', name: name };
313
313
  }
314
-
315
- return { chunkType: 'generic', name: undefined };
316
- }
317
-
318
- /**
319
- * Nagy osztály metódusonkénti bontása. Az első chunk az osztály-fej (a class-kulcsszótól az első
320
- * tag előttig, dekorátorok + JSDoc-cal), majd minden metódus / property-deklaráció külön chunk a
321
- * `class:Foo > method:bar` symbol-lánccal.
322
- */
323
- private static splitClassByMethods(
324
- classDecl: ts.ClassDeclaration,
325
- sourceFile: ts.SourceFile,
326
- code: string,
327
- className: string | undefined,
328
- blocks: DyNTS_DAI_CodeBlock[]
329
- ): void {
330
- const classSegment: string = `class:${className ?? 'anonymous'}`;
331
- const classStart: number = classDecl.getStart(sourceFile, /* includeJsDocComment */ true);
332
-
333
- const members: ts.ClassElement[] = [ ...classDecl.members ];
334
-
335
- // Osztály-fej: a class kezdetétől az első tag kezdetéig (dekorátorok/JSDoc + `class X {`-rész).
336
- const headerEnd: number = members.length
337
- ? members[0].getStart(sourceFile, /* includeJsDocComment */ true)
338
- : classDecl.getEnd();
314
+
315
+ return { chunkType: 'generic', name: undefined };
316
+ }
317
+
318
+ /**
319
+ * Nagy osztály metódusonkénti bontása. Az első chunk az osztály-fej (a class-kulcsszótól az első
320
+ * tag előttig, dekorátorok + JSDoc-cal), majd minden metódus / property-deklaráció külön chunk a
321
+ * `class:Foo > method:bar` symbol-lánccal.
322
+ */
323
+ private static splitClassByMethods(
324
+ classDecl: ts.ClassDeclaration,
325
+ sourceFile: ts.SourceFile,
326
+ code: string,
327
+ className: string | undefined,
328
+ blocks: DyNTS_DAI_CodeBlock[]
329
+ ): void {
330
+ const classSegment: string = `class:${className ?? 'anonymous'}`;
331
+ const classStart: number = classDecl.getStart(sourceFile, /* includeJsDocComment */ true);
332
+
333
+ const members: ts.ClassElement[] = [ ...classDecl.members ];
334
+
335
+ // Osztály-fej: a class kezdetétől az első tag kezdetéig (dekorátorok/JSDoc + `class X {`-rész).
336
+ const headerEnd: number = members.length
337
+ ? members[0].getStart(sourceFile, /* includeJsDocComment */ true)
338
+ : classDecl.getEnd();
339
339
  const headerText: string = code.substring(classStart, headerEnd);
340
-
341
- if (headerText.trim().length) {
342
- blocks.push({
343
- text: headerText,
344
- chunkType: 'class',
345
- symbolSegments: [ classSegment ],
346
- symbolName: className,
347
- charStart: classStart,
348
- charEnd: headerEnd,
349
- });
350
- }
351
-
352
- // Tagonkénti chunk (metódus / accessor / property).
353
- for (const member of members) {
354
- const memberStart: number = member.getStart(sourceFile, /* includeJsDocComment */ true);
355
- const memberEnd: number = member.getEnd();
340
+
341
+ if (headerText.trim().length) {
342
+ blocks.push({
343
+ text: headerText,
344
+ chunkType: 'class',
345
+ symbolSegments: [ classSegment ],
346
+ symbolName: className,
347
+ charStart: classStart,
348
+ charEnd: headerEnd,
349
+ });
350
+ }
351
+
352
+ // Tagonkénti chunk (metódus / accessor / property).
353
+ for (const member of members) {
354
+ const memberStart: number = member.getStart(sourceFile, /* includeJsDocComment */ true);
355
+ const memberEnd: number = member.getEnd();
356
356
  const memberText: string = code.substring(memberStart, memberEnd);
357
-
358
- if (!memberText.trim().length) {
359
- continue;
360
- }
361
-
362
- const memberName: string | undefined = member.name && ts.isIdentifier(member.name)
363
- ? member.name.getText()
364
- : (member.name ? member.name.getText() : undefined);
365
- const memberKind: DyNTS_DAI_CodeChunkType = this.classMemberKind(member);
366
- const memberSegment: string = memberName
367
- ? `${memberKind}:${memberName}`
368
- : memberKind;
369
-
370
- blocks.push({
371
- text: memberText,
372
- chunkType: memberKind,
373
- symbolSegments: [ classSegment, memberSegment ],
374
- symbolName: memberName,
375
- charStart: memberStart,
376
- charEnd: memberEnd,
377
- });
378
- }
379
- }
380
-
381
- /** Egy osztály-tag → chunk-típus (metódus/accessor → 'method', mező → 'variable'). */
382
- private static classMemberKind(member: ts.ClassElement): DyNTS_DAI_CodeChunkType {
383
- if (
384
- ts.isMethodDeclaration(member)
385
- || ts.isConstructorDeclaration(member)
386
- || ts.isGetAccessorDeclaration(member)
387
- || ts.isSetAccessorDeclaration(member)
388
- ) {
389
- return 'method';
357
+
358
+ if (!memberText.trim().length) {
359
+ continue;
360
+ }
361
+
362
+ const memberName: string | undefined = member.name && ts.isIdentifier(member.name)
363
+ ? member.name.getText()
364
+ : (member.name ? member.name.getText() : undefined);
365
+ const memberKind: DyNTS_DAI_CodeChunkType = this.classMemberKind(member);
366
+ const memberSegment: string = memberName
367
+ ? `${memberKind}:${memberName}`
368
+ : memberKind;
369
+
370
+ blocks.push({
371
+ text: memberText,
372
+ chunkType: memberKind,
373
+ symbolSegments: [ classSegment, memberSegment ],
374
+ symbolName: memberName,
375
+ charStart: memberStart,
376
+ charEnd: memberEnd,
377
+ });
378
+ }
379
+ }
380
+
381
+ /** Egy osztály-tag → chunk-típus (metódus/accessor → 'method', mező → 'variable'). */
382
+ private static classMemberKind(member: ts.ClassElement): DyNTS_DAI_CodeChunkType {
383
+ if (
384
+ ts.isMethodDeclaration(member)
385
+ || ts.isConstructorDeclaration(member)
386
+ || ts.isGetAccessorDeclaration(member)
387
+ || ts.isSetAccessorDeclaration(member)
388
+ ) {
389
+ return 'method';
390
390
  }
391
-
392
- return 'variable';
393
- }
394
-
395
- /** Egy belső blokk → `DyNTS_DAI_CodeChunk` (pozíció + symbol-lánc kiszámolásával). */
396
- private static blockToChunk(
397
- block: DyNTS_DAI_CodeBlock,
398
- chunkIndex: number,
399
- lineStartOffsets: number[]
400
- ): DyNTS_DAI_CodeChunk {
401
- const lineStart: number = this.lineOfOffset(block.charStart, lineStartOffsets);
391
+
392
+ return 'variable';
393
+ }
394
+
395
+ /** Egy belső blokk → `DyNTS_DAI_CodeChunk` (pozíció + symbol-lánc kiszámolásával). */
396
+ private static blockToChunk(
397
+ block: DyNTS_DAI_CodeBlock,
398
+ chunkIndex: number,
399
+ lineStartOffsets: number[]
400
+ ): DyNTS_DAI_CodeChunk {
401
+ const lineStart: number = this.lineOfOffset(block.charStart, lineStartOffsets);
402
402
  const lineEnd: number = this.lineOfOffset(Math.max(block.charStart, block.charEnd - 1), lineStartOffsets);
403
-
404
- return {
405
- content: block.text,
406
- chunkType: block.chunkType,
407
- symbolPath: block.symbolSegments.join(' > '),
408
- symbolSegments: block.symbolSegments,
409
- symbolName: block.symbolName,
410
- lineStart: lineStart,
411
- lineEnd: lineEnd,
412
- charStart: block.charStart,
413
- charEnd: block.charEnd,
414
- chunkIndex: chunkIndex,
415
- };
416
- }
417
-
418
- /**
419
- * Túl nagy blokk karakter-alapú sliding-window sub-splitje (örökölt chunkType + symbol-lánc).
420
- * Az átfedés (`overlap`) karakter-szinten, a `minChunkSize` alatti farok-chunkokat kihagyja.
421
- */
422
- private static splitLargeBlock(
423
- block: DyNTS_DAI_CodeBlock,
424
- sizing: DyNTS_DAI_CodeChunking_Sizing,
425
- out: DyNTS_DAI_CodeChunk[],
426
- lineStartOffsets: number[]
427
- ): void {
428
- const text: string = block.text;
429
- const step: number = Math.max(1, sizing.maxChunkSize - sizing.overlap);
430
- let subChunkIndex: number = 0;
431
-
432
- for (let start: number = 0; start < text.length; start += step) {
433
- const end: number = Math.min(start + sizing.maxChunkSize, text.length);
434
- const slice: string = text.substring(start, end);
435
-
436
- // A nagyon kicsi farok-chunkot (az utolsó, ami már nem éri el a minChunkSize-t) kihagyjuk,
437
- // de csak ha NEM ez az egyetlen chunk.
438
- if (slice.trim().length < sizing.minChunkSize && subChunkIndex > 0) {
439
- break;
440
- }
441
-
442
- const absoluteCharStart: number = block.charStart + start;
443
- const absoluteCharEnd: number = block.charStart + end;
444
- const lineStart: number = this.lineOfOffset(absoluteCharStart, lineStartOffsets);
445
- const lineEnd: number = this.lineOfOffset(Math.max(absoluteCharStart, absoluteCharEnd - 1), lineStartOffsets);
446
-
447
- out.push({
448
- content: slice,
449
- chunkType: block.chunkType,
450
- symbolPath: block.symbolSegments.join(' > '),
451
- symbolSegments: block.symbolSegments,
452
- symbolName: block.symbolName,
453
- lineStart: lineStart,
454
- lineEnd: lineEnd,
455
- charStart: absoluteCharStart,
456
- charEnd: absoluteCharEnd,
457
- chunkIndex: out.length,
458
- subChunkIndex: subChunkIndex,
459
- });
460
- subChunkIndex++;
461
-
462
- if (end >= text.length) {
463
- break;
464
- }
465
- }
466
- }
467
-
468
- /**
469
- * Tiny / degenerált fallback: a teljes tartalmat egy (vagy nagy bemenetnél sliding) chunkba teszi.
470
- * Soha nem ad vissza üres listát nem-üres bemenetre — a tartalom megőrzése a cél.
471
- */
472
- private static buildFallbackChunks(content: string, sizing: DyNTS_DAI_CodeChunking_Sizing): DyNTS_DAI_CodeChunk[] {
403
+
404
+ return {
405
+ content: block.text,
406
+ chunkType: block.chunkType,
407
+ symbolPath: block.symbolSegments.join(' > '),
408
+ symbolSegments: block.symbolSegments,
409
+ symbolName: block.symbolName,
410
+ lineStart: lineStart,
411
+ lineEnd: lineEnd,
412
+ charStart: block.charStart,
413
+ charEnd: block.charEnd,
414
+ chunkIndex: chunkIndex,
415
+ };
416
+ }
417
+
418
+ /**
419
+ * Túl nagy blokk karakter-alapú sliding-window sub-splitje (örökölt chunkType + symbol-lánc).
420
+ * Az átfedés (`overlap`) karakter-szinten, a `minChunkSize` alatti farok-chunkokat kihagyja.
421
+ */
422
+ private static splitLargeBlock(
423
+ block: DyNTS_DAI_CodeBlock,
424
+ sizing: DyNTS_DAI_CodeChunking_Sizing,
425
+ out: DyNTS_DAI_CodeChunk[],
426
+ lineStartOffsets: number[]
427
+ ): void {
428
+ const text: string = block.text;
429
+ const step: number = Math.max(1, sizing.maxChunkSize - sizing.overlap);
430
+ let subChunkIndex: number = 0;
431
+
432
+ for (let start: number = 0; start < text.length; start += step) {
433
+ const end: number = Math.min(start + sizing.maxChunkSize, text.length);
434
+ const slice: string = text.substring(start, end);
435
+
436
+ // A nagyon kicsi farok-chunkot (az utolsó, ami már nem éri el a minChunkSize-t) kihagyjuk,
437
+ // de csak ha NEM ez az egyetlen chunk.
438
+ if (slice.trim().length < sizing.minChunkSize && subChunkIndex > 0) {
439
+ break;
440
+ }
441
+
442
+ const absoluteCharStart: number = block.charStart + start;
443
+ const absoluteCharEnd: number = block.charStart + end;
444
+ const lineStart: number = this.lineOfOffset(absoluteCharStart, lineStartOffsets);
445
+ const lineEnd: number = this.lineOfOffset(Math.max(absoluteCharStart, absoluteCharEnd - 1), lineStartOffsets);
446
+
447
+ out.push({
448
+ content: slice,
449
+ chunkType: block.chunkType,
450
+ symbolPath: block.symbolSegments.join(' > '),
451
+ symbolSegments: block.symbolSegments,
452
+ symbolName: block.symbolName,
453
+ lineStart: lineStart,
454
+ lineEnd: lineEnd,
455
+ charStart: absoluteCharStart,
456
+ charEnd: absoluteCharEnd,
457
+ chunkIndex: out.length,
458
+ subChunkIndex: subChunkIndex,
459
+ });
460
+ subChunkIndex++;
461
+
462
+ if (end >= text.length) {
463
+ break;
464
+ }
465
+ }
466
+ }
467
+
468
+ /**
469
+ * Tiny / degenerált fallback: a teljes tartalmat egy (vagy nagy bemenetnél sliding) chunkba teszi.
470
+ * Soha nem ad vissza üres listát nem-üres bemenetre — a tartalom megőrzése a cél.
471
+ */
472
+ private static buildFallbackChunks(content: string, sizing: DyNTS_DAI_CodeChunking_Sizing): DyNTS_DAI_CodeChunk[] {
473
473
  const trimmed: string = content.trim();
474
-
475
- if (!trimmed) {
476
- return [];
477
- }
478
-
479
- const lineStartOffsets: number[] = this.computeLineStartOffsets(content);
480
-
481
- // Kis tartalom → egyetlen fallback chunk.
482
- if (content.length <= sizing.maxChunkSize) {
474
+
475
+ if (!trimmed) {
476
+ return [];
477
+ }
478
+
479
+ const lineStartOffsets: number[] = this.computeLineStartOffsets(content);
480
+
481
+ // Kis tartalom → egyetlen fallback chunk.
482
+ if (content.length <= sizing.maxChunkSize) {
483
483
  const lineEnd: number = this.lineOfOffset(Math.max(0, content.length - 1), lineStartOffsets);
484
-
485
- return [{
486
- content: content,
487
- chunkType: 'fallback',
488
- symbolPath: '',
489
- symbolSegments: [],
490
- symbolName: undefined,
491
- lineStart: 1,
492
- lineEnd: lineEnd,
493
- charStart: 0,
494
- charEnd: content.length,
495
- chunkIndex: 0,
496
- }];
497
- }
498
-
499
- // Nagy, de nem-parse-olható tartalom → sliding-window fallback.
500
- const fallbackBlock: DyNTS_DAI_CodeBlock = {
501
- text: content,
502
- chunkType: 'fallback',
503
- symbolSegments: [],
504
- symbolName: undefined,
505
- charStart: 0,
506
- charEnd: content.length,
507
- };
484
+
485
+ return [{
486
+ content: content,
487
+ chunkType: 'fallback',
488
+ symbolPath: '',
489
+ symbolSegments: [],
490
+ symbolName: undefined,
491
+ lineStart: 1,
492
+ lineEnd: lineEnd,
493
+ charStart: 0,
494
+ charEnd: content.length,
495
+ chunkIndex: 0,
496
+ }];
497
+ }
498
+
499
+ // Nagy, de nem-parse-olható tartalom → sliding-window fallback.
500
+ const fallbackBlock: DyNTS_DAI_CodeBlock = {
501
+ text: content,
502
+ chunkType: 'fallback',
503
+ symbolSegments: [],
504
+ symbolName: undefined,
505
+ charStart: 0,
506
+ charEnd: content.length,
507
+ };
508
508
  const out: DyNTS_DAI_CodeChunk[] = [];
509
-
509
+
510
510
  this.splitLargeBlock(fallbackBlock, sizing, out, lineStartOffsets);
511
-
512
- return out;
513
- }
514
-
515
- /**
516
- * A forrás minden sorának kezdő karakter-offszetje (0-alapú). A `lineStartOffsets[i]` az `i`-edik
517
- * (0-alapú) sor első karakterének abszolút pozíciója — bináris kereséssel gyors `offset → sor`
518
- * konverziót ad a chunkokhoz.
519
- */
520
- private static computeLineStartOffsets(source: string): number[] {
511
+
512
+ return out;
513
+ }
514
+
515
+ /**
516
+ * A forrás minden sorának kezdő karakter-offszetje (0-alapú). A `lineStartOffsets[i]` az `i`-edik
517
+ * (0-alapú) sor első karakterének abszolút pozíciója — bináris kereséssel gyors `offset → sor`
518
+ * konverziót ad a chunkokhoz.
519
+ */
520
+ private static computeLineStartOffsets(source: string): number[] {
521
521
  const offsets: number[] = [ 0 ];
522
-
523
- for (let i: number = 0; i < source.length; i++) {
524
- if (source[i] === '\n') {
525
- offsets.push(i + 1);
526
- }
522
+
523
+ for (let i: number = 0; i < source.length; i++) {
524
+ if (source[i] === '\n') {
525
+ offsets.push(i + 1);
526
+ }
527
527
  }
528
-
529
- return offsets;
530
- }
531
-
532
- /**
533
- * Egy abszolút karakter-offszet → 1-alapú sorszám a forrásban (bináris keresés a
534
- * `lineStartOffsets`-ben). A sor-mezők így a forrás VALÓDI soraira mutatnak (nem chunk-relatív).
535
- */
536
- private static lineOfOffset(offset: number, lineStartOffsets: number[]): number {
537
- let lo: number = 0;
528
+
529
+ return offsets;
530
+ }
531
+
532
+ /**
533
+ * Egy abszolút karakter-offszet → 1-alapú sorszám a forrásban (bináris keresés a
534
+ * `lineStartOffsets`-ben). A sor-mezők így a forrás VALÓDI soraira mutatnak (nem chunk-relatív).
535
+ */
536
+ private static lineOfOffset(offset: number, lineStartOffsets: number[]): number {
537
+ let lo: number = 0;
538
538
  let hi: number = lineStartOffsets.length - 1;
539
-
540
- while (lo < hi) {
539
+
540
+ while (lo < hi) {
541
541
  const mid: number = (lo + hi + 1) >> 1;
542
-
543
- if (lineStartOffsets[mid] <= offset) {
544
- lo = mid;
545
- } else {
546
- hi = mid - 1;
547
- }
542
+
543
+ if (lineStartOffsets[mid] <= offset) {
544
+ lo = mid;
545
+ } else {
546
+ hi = mid - 1;
547
+ }
548
548
  }
549
-
550
- return lo + 1;
551
- }
552
- }
549
+
550
+ return lo + 1;
551
+ }
552
+ }