@futdevpro/nts-dynamo 1.15.82 → 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.
- package/.c8rc.json +26 -26
- package/.copilot/patterns.json +7 -7
- package/.cursor/rules/__assistant_guide.mdc +30 -30
- package/.cursor/rules/_ag_backend-structure.mdc +85 -85
- package/.cursor/rules/_ag_backend.mdc +16 -16
- package/.cursor/rules/_ag_frontend-structure.mdc +86 -86
- package/.cursor/rules/_ag_frontend.mdc +39 -39
- package/.cursor/rules/_ag_import-rules.mdc +44 -44
- package/.cursor/rules/_ag_naming.mdc +115 -115
- package/.cursor/rules/_ag_should-be.mdc +6 -6
- package/.cursor/rules/ai_development_guide.md +60 -60
- package/.cursor/rules/cursor-rules.md +160 -160
- package/.cursor/rules/default-command.mdc +464 -464
- package/.cursor/rules/error_code_pattern.md +39 -39
- package/.cursor/rules/saved rule mcp server use.md +15 -15
- package/.vscode/settings.json +10 -10
- package/HOWTO.md +15 -15
- package/LICENSE +21 -21
- package/__documentations/nts-integration-tests-2026-03-17.md +26 -26
- package/__documentations/plans/BEDROCK-HYPERPLAN.md +95 -95
- package/_specifications/BACKLOG.md +92 -92
- package/_specifications/TODO.md +15 -15
- package/_specifications/agent.md +138 -138
- package/build/_modules/server/errors/errors.controller.d.ts +15 -0
- package/build/_modules/server/errors/errors.controller.d.ts.map +1 -1
- package/build/_modules/server/errors/errors.controller.js +51 -13
- package/build/_modules/server/errors/errors.controller.js.map +1 -1
- package/build/_modules/server/server-status/server-status.controller.d.ts +8 -0
- package/build/_modules/server/server-status/server-status.controller.d.ts.map +1 -1
- package/build/_modules/server/server-status/server-status.controller.js +25 -5
- package/build/_modules/server/server-status/server-status.controller.js.map +1 -1
- package/eslint.config.js +3 -3
- package/nodemon.json +24 -24
- package/package.json +3 -3
- package/pnpm-workspace.yaml +5 -5
- package/scripts/run-coverage-tests.js +28 -28
- package/spec/support/helpers/spec-reporter-loader.js +359 -359
- package/spec/support/helpers/ts-node-helper.js +93 -93
- package/spec/support/jasmine.coverage.json +24 -24
- package/spec/support/jasmine.json +24 -24
- package/src/_collections/archive.util.spec.ts +57 -57
- package/src/_collections/archive.util.ts +18 -18
- package/src/_collections/atlas-default-db-options.const.ts +9 -9
- package/src/_collections/default-fallback-cache-max-age.const.spec.ts +11 -11
- package/src/_collections/default-fallback-cache-max-age.const.ts +2 -2
- package/src/_collections/default-not-found-page.const.spec.ts +19 -19
- package/src/_collections/default-not-found-page.const.ts +22 -22
- package/src/_collections/default-socket-path.const.spec.ts +12 -12
- package/src/_collections/default-socket-path.const.ts +2 -2
- package/src/_collections/get-environment-settings.util.spec.ts +210 -210
- package/src/_collections/get-environment-settings.util.ts +48 -48
- package/src/_collections/global-settings.const.ts +109 -109
- package/src/_collections/sample.env +21 -21
- package/src/_collections/star.controller.spec.ts +224 -224
- package/src/_collections/star.controller.ts +129 -129
- package/src/_enums/data-model-type.enum.ts +14 -14
- package/src/_enums/data-service-function.enum.ts +24 -24
- package/src/_enums/predefined-data-types.enum.ts +16 -16
- package/src/_enums/route-security.enum.ts +12 -12
- package/src/_models/control-models/api-call-params.control-model.spec.ts +152 -152
- package/src/_models/control-models/api-call-params.control-model.ts +142 -142
- package/src/_models/control-models/app-ext-system-controls.control-model.spec.ts +52 -52
- package/src/_models/control-models/app-ext-system-controls.control-model.ts +9 -9
- package/src/_models/control-models/app-params.control-model.spec.ts +225 -225
- package/src/_models/control-models/app-params.control-model.ts +136 -136
- package/src/_models/control-models/app-system-controls.control-model.spec.ts +31 -31
- package/src/_models/control-models/app-system-controls.control-model.ts +9 -9
- package/src/_models/control-models/endpoint-params.control-model.spec.ts +627 -627
- package/src/_models/control-models/endpoint-params.control-model.ts +627 -627
- package/src/_models/control-models/http-settings.control-model.spec.ts +77 -77
- package/src/_models/control-models/http-settings.control-model.ts +37 -37
- package/src/_models/control-models/system-control.control-model.spec.ts +27 -27
- package/src/_models/control-models/system-control.control-model.ts +12 -12
- package/src/_models/interfaces/certification-settings.interface.ts +7 -7
- package/src/_models/interfaces/environment-settings.interface.ts +59 -59
- package/src/_models/interfaces/global-log-settings.interface.ts +171 -171
- package/src/_models/interfaces/global-service-settings.interface.ts +47 -47
- package/src/_models/interfaces/global-settings.interface.ts +235 -235
- package/src/_models/interfaces/routing-module-settings.interface.ts +21 -21
- package/src/_models/interfaces/static-client-settings.interface.spec.ts +29 -29
- package/src/_models/interfaces/static-client-settings.interface.ts +28 -28
- package/src/_models/types/db-update.type.ts +100 -100
- package/src/_modules/ai/_models/ai-input-interfaces.ts +117 -117
- package/src/_modules/ai/_models/ai-test-generation-result.interface.ts +16 -16
- package/src/_modules/ai/_modules/anthropic/_services/aai-user-key.control-service.ts +138 -138
- package/src/_modules/ai/_modules/anthropic/index.ts +5 -5
- package/src/_modules/ai/_modules/document-ai/_collections/dai-chunking.util.spec.ts +242 -242
- package/src/_modules/ai/_modules/document-ai/_collections/dai-chunking.util.ts +639 -639
- package/src/_modules/ai/_modules/document-ai/_collections/dai-code-chunking.util.spec.ts +295 -295
- package/src/_modules/ai/_modules/document-ai/_collections/dai-code-chunking.util.ts +518 -518
- package/src/_modules/ai/_modules/document-ai/_collections/dai-document.util.spec.ts +209 -209
- package/src/_modules/ai/_modules/document-ai/_collections/dai-document.util.ts +85 -85
- package/src/_modules/ai/_modules/document-ai/_enums/dai-compare-result-type.enum.ts +7 -7
- package/src/_modules/ai/_modules/document-ai/_models/data-models/dai-doc-chunk.data-model.ts +146 -146
- package/src/_modules/ai/_modules/document-ai/_models/data-models/dai-doc-page.data-model.ts +162 -162
- package/src/_modules/ai/_modules/document-ai/_models/data-models/dai-document.data-model.ts +99 -99
- package/src/_modules/ai/_modules/document-ai/_models/interfaces/dai-code-chunk.interface.ts +68 -68
- package/src/_modules/ai/_modules/document-ai/_models/interfaces/dai-doc-chunk-compare-result.interface.ts +18 -18
- package/src/_modules/ai/_modules/document-ai/_models/interfaces/dai-doc-page-compare-result.interface.ts +19 -19
- package/src/_modules/ai/_modules/document-ai/_models/interfaces/dai-document-compare-result.interface.ts +25 -25
- package/src/_modules/ai/_modules/document-ai/index.ts +30 -30
- package/src/_modules/ai/_modules/fdp-ai/_services/fdpai-user-key.control-service.ts +189 -189
- package/src/_modules/ai/_modules/fdp-ai/index.ts +5 -5
- package/src/_modules/ai/_modules/open-ai/_collections/oai-global-settings.const.ts +9 -9
- package/src/_modules/ai/_modules/open-ai/_collections/oai-llm-predefined-requests-hu.conts.ts +82 -82
- package/src/_modules/ai/_modules/open-ai/_collections/oai-llm-predefined-requests.conts.ts +75 -75
- package/src/_modules/ai/_modules/open-ai/_enums/oai-gpt-message-role.enum.ts +45 -45
- package/src/_modules/ai/_modules/open-ai/_models/interfaces/oai-global-settings.interface.ts +7 -7
- package/src/_modules/ai/_modules/open-ai/_models/interfaces/oai-gpt-message.interface.ts +7 -7
- package/src/_modules/ai/_modules/open-ai/_models/interfaces/oai-llm-predefined-requests.interface.ts +57 -57
- package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-doc-chunk-data.service.ts +292 -292
- package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-document.data-service.spec.ts +342 -342
- package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-vector-data.service.spec.ts +550 -550
- package/src/_modules/ai/_modules/open-ai/_services/data-services/oai-vector-data.service.ts +630 -630
- package/src/_modules/ai/_modules/open-ai/_services/oai-embedding.control-service.spec.ts +332 -332
- package/src/_modules/ai/_modules/open-ai/_services/oai-llm-chat.service-base.spec.ts +462 -462
- package/src/_modules/ai/_modules/open-ai/_services/oai-llm-chat.service-base.ts +634 -634
- package/src/_modules/ai/_modules/open-ai/_services/oai-llm.service-base.spec.ts +489 -489
- package/src/_modules/ai/_modules/open-ai/_services/oai-llm.service-base.tools.spec.ts +173 -173
- package/src/_modules/ai/_modules/open-ai/_services/oai-llm.service-base.ts +1033 -1033
- package/src/_modules/ai/_modules/open-ai/_services/oai-user-key.control-service.ts +157 -157
- package/src/_modules/ai/_services/ai-embedding-mock.service.spec.ts +115 -115
- package/src/_modules/ai/_services/ai-embedding-mock.service.ts +212 -212
- package/src/_modules/ai/_services/ai-embedding-provider.registry.spec.ts +110 -110
- package/src/_modules/ai/_services/ai-embedding-provider.registry.ts +110 -110
- package/src/_modules/ai/_services/ai-embedding.service-base.spec.ts +98 -98
- package/src/_modules/ai/_services/ai-embedding.service-base.ts +48 -48
- package/src/_modules/ai/_services/ai-llm-chat.service-base.spec.ts +229 -229
- package/src/_modules/ai/_services/ai-llm-chat.service-base.ts +68 -68
- package/src/_modules/ai/_services/ai-llm.service-base.spec.ts +250 -250
- package/src/_modules/ai/_services/ai-llm.service-base.ts +519 -519
- package/src/_modules/ai/_services/ai-provider.service-base.spec.ts +158 -158
- package/src/_modules/ai/_services/ai-user-key.service-base.ts +59 -59
- package/src/_modules/ai/_services/lmstudio-embedding.control-service.spec.ts +197 -197
- package/src/_modules/ai/_services/lmstudio-embedding.control-service.ts +371 -371
- package/src/_modules/ai/index.ts +23 -23
- package/src/_modules/assistant/_collections/ass-global-settings.const.ts +13 -13
- package/src/_modules/assistant/_collections/ass.util.spec.ts +176 -176
- package/src/_modules/assistant/_collections/ass.util.ts +50 -50
- package/src/_modules/assistant/_models/ass-global-settings.interface.ts +15 -15
- package/src/_modules/assistant/_services/ass-io.control-service.spec.ts +140 -140
- package/src/_modules/assistant/_services/ass-main.control-service.spec.ts +192 -192
- package/src/_modules/assistant/_services/ass-main.control-service.ts +107 -107
- package/src/_modules/bot/_collections/bot-default-commands.const.ts +12 -12
- package/src/_modules/bot/_collections/bot-global-settings.const.ts +39 -39
- package/src/_modules/bot/_models/bot-channel-wrapper.interface.ts +62 -62
- package/src/_modules/bot/_models/bot-command.interface.ts +8 -8
- package/src/_modules/bot/_models/bot-global-settings.interface.ts +96 -96
- package/src/_modules/bot/_models/bot-last-mention-date.interface.ts +6 -6
- package/src/_modules/bot/_models/bot-last-message-date.interface.ts +5 -5
- package/src/_modules/bot/_models/bot-user-wrapper.interface.ts +41 -41
- package/src/_modules/bot/_modules/discord-bot/_models/dib-platform.types.ts +9 -9
- package/src/_modules/bot/_modules/discord-bot/_services/dib-messaging-provider.control-service.spec.ts +431 -431
- package/src/_modules/bot/_modules/dynamo-bot/_collections/dyb-operations.util.spec.ts +160 -160
- package/src/_modules/bot/_modules/dynamo-bot/_collections/dyb-operations.util.ts +55 -55
- package/src/_modules/bot/_modules/dynamo-bot/_models/dyb-platform.types.ts +15 -15
- package/src/_modules/bot/_modules/dynamo-bot/_services/dyb-messaging-provider.control-service.spec.ts +374 -374
- package/src/_modules/bot/_modules/dynamo-bot/_services/dyb-messaging-provider.control-service.ts +447 -447
- package/src/_modules/bot/_modules/dynamo-bot/index.ts +15 -15
- package/src/_modules/bot/_modules/slack-bot/_models/slb-platform.types.ts +9 -9
- package/src/_modules/bot/_modules/slack-bot/_services/slb-messaging-provider.control-service.spec.ts +344 -344
- package/src/_modules/bot/_modules/slack-bot/_services/slb-messaging-provider.control-service.ts +197 -197
- package/src/_modules/bot/_modules/teams-bot/_models/teb-platform.types.ts +9 -9
- package/src/_modules/bot/_modules/teams-bot/_services/teb-messaging-provider.control-service.spec.ts +345 -345
- package/src/_modules/bot/_modules/teams-bot/_services/teb-messaging-provider.control-service.ts +197 -197
- package/src/_modules/bot/_services/bot-commands.control-service.spec.ts +116 -116
- package/src/_modules/bot/_services/bot-io.control-service.spec.ts +285 -285
- package/src/_modules/bot/_services/bot-main.control-service.spec.ts +208 -208
- package/src/_modules/bot/_services/bot-messaging-provider.service-base.spec.ts +349 -349
- package/src/_modules/bot/_services/bot-routines.control-service.spec.ts +111 -111
- package/src/_modules/custom-data/custom-data.controller.spec.ts +49 -49
- package/src/_modules/custom-data/custom-data.controller.ts +67 -67
- package/src/_modules/custom-data/custom-data.data-service.spec.ts +54 -54
- package/src/_modules/custom-data/custom-data.data-service.ts +21 -21
- package/src/_modules/custom-data/get-custom-data-routing-module.util.spec.ts +28 -28
- package/src/_modules/custom-data/get-custom-data-routing-module.util.ts +24 -24
- package/src/_modules/custom-data/index.ts +9 -9
- package/src/_modules/data-readers/_collections/dynts-sqlite-reader.util.spec.ts +161 -161
- package/src/_modules/data-readers/_collections/dynts-sqlite-reader.util.ts +203 -203
- package/src/_modules/data-readers/_models/interfaces/dynts-sqlite-reader.interface.ts +33 -33
- package/src/_modules/data-readers/index.ts +11 -11
- package/src/_modules/defaults/_collections/default-endpoints.util.ts +487 -487
- package/src/_modules/defaults/_models/default-user.data-model.ts +72 -72
- package/src/_modules/defaults/_services/default-auth.service.spec.ts +269 -269
- package/src/_modules/defaults/_services/default-auth.service.ts +177 -177
- package/src/_modules/defaults/_services/default-socket-events.service.spec.ts +42 -42
- package/src/_modules/defaults/_services/default-socket-events.service.ts +61 -61
- package/src/_modules/defaults/_services/default-user.data-service.spec.ts +187 -187
- package/src/_modules/defaults/_services/default-user.data-service.ts +98 -98
- package/src/_modules/defaults/index.ts +17 -17
- package/src/_modules/discord-assistant/_collections/dias-global-settings.const.ts +19 -19
- package/src/_modules/discord-assistant/_collections/dias.util.spec.ts +366 -366
- package/src/_modules/discord-assistant/_collections/dias.util.ts +132 -132
- package/src/_modules/discord-assistant/_models/dias-global-settings.interface.ts +19 -19
- package/src/_modules/discord-assistant/_models/dias-knowledge.data-model.ts +52 -52
- package/src/_modules/discord-assistant/_services/dias-chunk.data-service.ts +177 -177
- package/src/_modules/discord-assistant/_services/dias-io.control-service.spec.ts +108 -108
- package/src/_modules/discord-assistant/_services/dias-io.control-service.ts +69 -69
- package/src/_modules/discord-assistant/_services/dias-main.control-service.spec.ts +22 -22
- package/src/_modules/discord-assistant/_services/dias-main.control-service.ts +27 -27
- package/src/_modules/discord-assistant/_services/dias.service-base.spec.ts +195 -195
- package/src/_modules/discord-assistant/_services/dias.service-base.ts +76 -76
- package/src/_modules/discord-assistant/index.ts +38 -38
- package/src/_modules/discord-assistant-voiced/_services/dias-discord-bot.control-service.spec.ts +34 -34
- package/src/_modules/discord-assistant-voiced/_services/dias-discord-bot.control-service.ts +11 -11
- package/src/_modules/discord-assistant-voiced/index.ts +36 -36
- package/src/_modules/discord-bot/_collections/dibo-default-commands.const.ts +16 -16
- package/src/_modules/discord-bot/_collections/dibo-global-settings.conts.ts +55 -55
- package/src/_modules/discord-bot/_collections/dibo-operations.util.spec.ts +214 -214
- package/src/_modules/discord-bot/_collections/dibo-operations.util.ts +387 -387
- package/src/_modules/discord-bot/_models/dibo-command.interface.ts +12 -12
- package/src/_modules/discord-bot/_models/dibo-global-settings.interface.ts +98 -98
- package/src/_modules/discord-bot/_models/dibo-last-mention-date.inteface.ts +7 -7
- package/src/_modules/discord-bot/_models/dibo-last-message-date.interface.ts +6 -6
- package/src/_modules/discord-bot/_services/dibo-commands.control-service.spec.ts +154 -154
- package/src/_modules/discord-bot/_services/dibo-commands.control-service.ts +153 -153
- package/src/_modules/discord-bot/_services/dibo-io.control-service.spec.ts +264 -264
- package/src/_modules/discord-bot/_services/dibo-io.control-service.ts +306 -306
- package/src/_modules/discord-bot/_services/dibo-main.control-service.spec.ts +408 -408
- package/src/_modules/discord-bot/_services/dibo-main.control-service.ts +487 -487
- package/src/_modules/discord-bot/_services/dibo-routines.control-service.spec.ts +105 -105
- package/src/_modules/discord-bot/index.ts +36 -36
- package/src/_modules/local-vector-search/_enums/lvs-search-mode.enum.ts +35 -35
- package/src/_modules/local-vector-search/_models/data-models/lvs-vector-persist.data-model.ts +59 -59
- package/src/_modules/local-vector-search/_models/lvs-search-result.interface.ts +17 -17
- package/src/_modules/local-vector-search/_services/lvs-doc-chunk-data.service.spec.ts +418 -418
- package/src/_modules/local-vector-search/_services/lvs-doc-chunk-data.service.ts +276 -276
- package/src/_modules/local-vector-search/_services/lvs-local-vector-search.data-service.spec.ts +480 -480
- package/src/_modules/local-vector-search/_services/lvs-local-vector-search.data-service.ts +416 -416
- package/src/_modules/local-vector-search/_services/lvs-persistent-vector-pool.control-service.spec.ts +198 -198
- package/src/_modules/local-vector-search/_services/lvs-persistent-vector-pool.control-service.ts +146 -146
- package/src/_modules/local-vector-search/_services/lvs-vector-persist.data-service.spec.ts +167 -167
- package/src/_modules/local-vector-search/_services/lvs-vector-persist.data-service.ts +106 -106
- package/src/_modules/local-vector-search/_services/lvs-vector-pool.control-service.spec.ts +507 -507
- package/src/_modules/local-vector-search/_services/lvs-vector-pool.control-service.ts +272 -272
- package/src/_modules/local-vector-search/index.ts +16 -16
- package/src/_modules/logs/index.ts +11 -11
- package/src/_modules/mcp/_models/interfaces/dynts-mcp.interface.ts +111 -111
- package/src/_modules/mcp/_services/dynts-mcp-server.service-base.spec.ts +142 -142
- package/src/_modules/mcp/_services/dynts-mcp-server.service-base.ts +120 -120
- package/src/_modules/mcp/_services/dynts-mcp.adapter.ts +168 -168
- package/src/_modules/mcp/index.ts +13 -13
- package/src/_modules/messaging/README.md +354 -354
- package/src/_modules/messaging/_collections/get-messaging-routing-module.util.ts +26 -26
- package/src/_modules/messaging/_collections/msg-global-settings.const.ts +22 -22
- package/src/_modules/messaging/_collections/msg.util.spec.ts +226 -226
- package/src/_modules/messaging/_models/msg-global-settings.interface.ts +37 -37
- package/src/_modules/messaging/_services/msg-conversation.data-service.ts +146 -146
- package/src/_modules/messaging/_services/msg-events.service.spec.ts +219 -219
- package/src/_modules/messaging/_services/msg-events.service.ts +267 -267
- package/src/_modules/messaging/_services/msg-integration.control-service.ts +179 -179
- package/src/_modules/messaging/_services/msg-main.control-service.spec.ts +147 -147
- package/src/_modules/messaging/_services/msg-main.control-service.ts +571 -571
- package/src/_modules/messaging/_services/msg-message.data-service.ts +129 -129
- package/src/_modules/messaging/_services/msg.controller.spec.ts +201 -201
- package/src/_modules/messaging/index.ts +30 -30
- package/src/_modules/mock/app-extended-server.mock.ts +201 -201
- package/src/_modules/mock/app-integration-test.mock.ts +51 -51
- package/src/_modules/mock/app-params.mock.spec.ts +21 -21
- package/src/_modules/mock/app-params.mock.ts +9 -9
- package/src/_modules/mock/app-server.mock.ts +188 -188
- package/src/_modules/mock/auth-service.mock.spec.ts +47 -47
- package/src/_modules/mock/auth-service.mock.ts +28 -28
- package/src/_modules/mock/controller.mock.spec.ts +26 -26
- package/src/_modules/mock/controller.mock.ts +16 -16
- package/src/_modules/mock/data-model.mock.spec.ts +111 -111
- package/src/_modules/mock/data-model.mock.ts +82 -82
- package/src/_modules/mock/email-service-collection.mock.spec.ts +24 -24
- package/src/_modules/mock/email-service-collection.mock.ts +15 -15
- package/src/_modules/mock/email-service.mock.spec.ts +17 -17
- package/src/_modules/mock/email-service.mock.ts +20 -20
- package/src/_modules/mock/email-template.mock.html +14 -14
- package/src/_modules/mock/endpoint.mock.ts +91 -91
- package/src/_modules/mock/socket-client.mock.spec.ts +40 -40
- package/src/_modules/mock/socket-client.mock.ts +45 -45
- package/src/_modules/mock/socket-server.mock.spec.ts +44 -44
- package/src/_modules/mock/socket-server.mock.ts +46 -46
- package/src/_modules/oauth2/_routes/oauth2.controller.spec.ts +107 -107
- package/src/_modules/oauth2/_routes/oauth2.controller.ts +98 -98
- package/src/_modules/oauth2/_services/oauth2.auth-service.spec.ts +254 -254
- package/src/_modules/oauth2/_services/oauth2.auth-service.ts +232 -232
- package/src/_modules/oauth2/_services/oauth2.control-service.spec.ts +585 -585
- package/src/_modules/oauth2/_services/oauth2.control-service.ts +653 -653
- package/src/_modules/oauth2/index.ts +17 -17
- package/src/_modules/scoped-config/_enums/dynts-scoped-config-level.enum.ts +22 -22
- package/src/_modules/scoped-config/_models/data-models/dynts-scoped-config.data-model.ts +81 -81
- package/src/_modules/scoped-config/_models/interfaces/dynts-scoped-config.interface.ts +107 -107
- package/src/_modules/scoped-config/_services/dynts-scoped-config.control-service.spec.ts +306 -306
- package/src/_modules/scoped-config/_services/dynts-scoped-config.control-service.ts +295 -295
- package/src/_modules/scoped-config/_services/dynts-scoped-config.data-service.spec.ts +118 -118
- package/src/_modules/scoped-config/_services/dynts-scoped-config.data-service.ts +105 -105
- package/src/_modules/scoped-config/index.ts +17 -17
- package/src/_modules/server/errors/errors.control-service.spec.ts +238 -238
- package/src/_modules/server/errors/errors.control-service.ts +100 -100
- package/src/_modules/server/errors/errors.controller.spec.ts +268 -249
- package/src/_modules/server/errors/errors.controller.ts +527 -489
- package/src/_modules/server/errors/errors.data-service.spec.ts +480 -480
- package/src/_modules/server/index.ts +30 -30
- package/src/_modules/server/server-status/server-status-snapshot.control-service.spec.ts +70 -70
- package/src/_modules/server/server-status/server-status-snapshot.control-service.ts +17 -17
- package/src/_modules/server/server-status/server-status-snapshot.data-service.spec.ts +77 -77
- package/src/_modules/server/server-status/server-status-snapshot.data-service.ts +37 -37
- package/src/_modules/server/server-status/server-status.control-service.spec.ts +576 -576
- package/src/_modules/server/server-status/server-status.control-service.ts +396 -396
- package/src/_modules/server/server-status/server-status.controller.spec.ts +255 -248
- package/src/_modules/server/server-status/server-status.controller.ts +272 -253
- package/src/_modules/socket/_enums/socket-security.enum.ts +11 -11
- package/src/_modules/socket/_models/socket-client-service-params.control-model.spec.ts +32 -32
- package/src/_modules/socket/_models/socket-client-service-params.control-model.ts +22 -22
- package/src/_modules/socket/_models/socket-presence.control-model.spec.ts +164 -164
- package/src/_modules/socket/_models/socket-presence.control-model.ts +210 -210
- package/src/_modules/socket/_models/socket-server-service-params.control-model.spec.ts +46 -46
- package/src/_modules/socket/_models/socket-server-service-params.control-model.ts +22 -22
- package/src/_modules/socket/_services/socket-client.service.spec.ts +15 -15
- package/src/_modules/socket/_services/socket-client.service.ts +260 -260
- package/src/_modules/socket/_services/socket-server.service.spec.ts +11 -11
- package/src/_modules/socket/app-extended.integration.spec.ts +85 -85
- package/src/_modules/socket/app-extended.server.ts +630 -630
- package/src/_modules/socket/index.ts +42 -42
- package/src/_modules/test/get-test-routing-module.util.spec.ts +28 -28
- package/src/_modules/test/get-test-routing-module.util.ts +23 -23
- package/src/_modules/test/index.ts +11 -11
- package/src/_modules/test/test.controller.spec.ts +72 -72
- package/src/_modules/test/test.controller.ts +115 -115
- package/src/_modules/usage/get-usage-routing-module.util.ts +22 -22
- package/src/_modules/usage/index.ts +15 -15
- package/src/_modules/usage/usage.controller.spec.ts +81 -81
- package/src/_modules/usage/usage.controller.ts +126 -126
- package/src/_modules/usage/usage.data-service.spec.ts +332 -332
- package/src/_modules/usage/usage.data-service.ts +185 -185
- package/src/_services/base/api.service-base.spec.ts +125 -125
- package/src/_services/base/api.service-base.ts +74 -74
- package/src/_services/base/archive-data.service.spec.ts +209 -209
- package/src/_services/base/archive-data.service.ts +224 -224
- package/src/_services/base/data.service.spec.ts +729 -729
- package/src/_services/base/data.service.ts +2740 -2740
- package/src/_services/base/db.service.spec.ts +73 -73
- package/src/_services/base/db.service.ts +1575 -1575
- package/src/_services/base/singleton.service-base.spec.ts +28 -28
- package/src/_services/base/singleton.service-base.ts +24 -24
- package/src/_services/base/singleton.service.spec.ts +114 -114
- package/src/_services/base/singleton.service.ts +38 -38
- package/src/_services/core/api.service.spec.ts +140 -140
- package/src/_services/core/auth.service.spec.ts +159 -159
- package/src/_services/core/auth.service.ts +174 -174
- package/src/_services/core/email.service.spec.ts +85 -85
- package/src/_services/core/email.service.ts +742 -742
- package/src/_services/core/global.service.spec.ts +292 -292
- package/src/_services/core/global.service.ts +487 -487
- package/src/_services/core/memory-guard.service.spec.ts +245 -245
- package/src/_services/core/memory-guard.service.ts +481 -481
- package/src/_services/core/service-collection.service.spec.ts +46 -46
- package/src/_services/core/service-collection.service.ts +6 -6
- package/src/_services/route/controller.service.spec.ts +53 -53
- package/src/_services/route/controller.service.ts +148 -148
- package/src/_services/route/routing-module.service.spec.ts +98 -98
- package/src/_services/route/routing-module.service.ts +330 -330
- package/src/_services/server/app.server.ts +1905 -1905
- package/src/_services/shared.static-service.spec.ts +99 -99
- package/src/_services/shared.static-service.ts +78 -78
- package/src/index.ts +97 -97
- package/tsconfig.app.json +12 -12
- package/tsconfig.json +42 -42
- package/.dynamo/logs/cicd-pipeline/output.log +0 -2867
- package/.dynamo/logs/cicd-pipeline/status.json +0 -94
package/src/_modules/local-vector-search/_services/lvs-persistent-vector-pool.control-service.ts
CHANGED
|
@@ -1,150 +1,150 @@
|
|
|
1
|
-
|
|
2
|
-
import { DyFM_Log } from '@futdevpro/fsm-dynamo';
|
|
3
|
-
|
|
4
|
-
import { LVS_Search_Mode } from '../_enums/lvs-search-mode.enum';
|
|
5
|
-
import { LVS_SearchResult } from '../_models/lvs-search-result.interface';
|
|
6
|
-
import { DyNTS_LVS_VectorPersist } from '../_models/data-models/lvs-vector-persist.data-model';
|
|
7
|
-
import { DyNTS_LVS_VectorPersist_DataService } from './lvs-vector-persist.data-service';
|
|
8
|
-
import { LVS_VectorPool_ControlService } from './lvs-vector-pool.control-service';
|
|
9
|
-
|
|
10
|
-
/**
|
|
11
|
-
* `DyNTS_LVS_PersistentVectorPool_ControlService` (BFR-AM-001) — egy `LVS_VectorPool_ControlService` in-memory pool +
|
|
12
|
-
* MongoDB-perzisztencia **kompozíciója**. A FAM (fdp-agent-memory) `FAM_VectorSearch_ControlService`
|
|
13
|
-
* persist+hydrate workaround-ját generalizálja bedrock-szintre: a vektorok a SAJÁT Mongo-ban
|
|
14
|
-
* (`dynts_lvs_vector`) élnek, boot-kor a memória-pool-ba hidratálódnak — **NEM** MongoDB Atlas
|
|
15
|
-
* Vector Search.
|
|
16
|
-
*
|
|
17
|
-
* **Miért KOMPOZÍCIÓ (NEM a pool-class módosítása):** a `LVS_VectorPool_ControlService`-t egy másik,
|
|
18
|
-
* párhuzamos WIP (hybrid cosine+BM25) is érinti; a pool-class változtatása merge-konfliktust okozna.
|
|
19
|
-
* Ez a wrapper a pool-t VÁLTOZATLANUL hagyja (delegál: `addVector`/`removeVector`/`updateVector`/
|
|
20
|
-
* `search`), és a perzisztencia-mellékhatást a wrapper-metódusokban végzi. Egy wrapper-instance egy
|
|
21
|
-
* `collectionKey` (logikai pool); több pool = több wrapper.
|
|
22
|
-
*
|
|
23
|
-
* **FIGYELEM (memory: dynts_dataservice_eager_resolve):** a `DyNTS_DataService` base-ctor EAGER
|
|
24
|
-
* `getDBService`-t hív, ezért a wrapper NEM tart élő data-service-mezőt — minden DB-művelet előtt lazy
|
|
25
|
-
* `new DyNTS_LVS_VectorPersist_DataService(...)` (a `getPersistService` ezt adja).
|
|
26
|
-
*/
|
|
27
|
-
export class DyNTS_LVS_PersistentVectorPool_ControlService {
|
|
28
|
-
|
|
29
|
-
/** A wrapped in-memory pool (a Dynamo LVS engine; VÁLTOZATLAN — kompozíció, nem módosítás). */
|
|
30
|
-
private readonly pool: LVS_VectorPool_ControlService;
|
|
31
|
-
|
|
32
|
-
/** A pool-particionálás kulcsa (a Mongo-rekordok `collectionKey`-e + a hidratálás-szűrő). */
|
|
33
|
-
private readonly collectionKey: string;
|
|
34
|
-
|
|
35
|
-
/** A perzisztencia-műveletek issuer-e (audit). */
|
|
36
|
-
private readonly issuer: string;
|
|
37
|
-
|
|
38
|
-
constructor(set: {
|
|
39
|
-
collectionKey: string,
|
|
40
|
-
issuer: string,
|
|
41
|
-
pool?: LVS_VectorPool_ControlService,
|
|
42
|
-
}) {
|
|
43
|
-
this.collectionKey = set.collectionKey;
|
|
44
|
-
this.issuer = set.issuer;
|
|
45
|
-
// Saját pool, ha a hívó nem ad be egyet (a wrapper nem módosítja a pool-osztályt — kompozíció).
|
|
46
|
-
this.pool = set.pool ?? new LVS_VectorPool_ControlService();
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
/** A wrapped in-memory pool (közvetlen olvasáshoz — pl. más search-mód, getAll). */
|
|
50
|
-
getPool(): LVS_VectorPool_ControlService {
|
|
51
|
-
return this.pool;
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
/**
|
|
55
|
-
* Egy vektor felvétele a memória-pool-ba ÉS tartós upsert-je Mongo-ba (persist-on-write, FAM-minta).
|
|
56
|
-
* A pool `addVector`-ja upsert-szemantikájú (azonos kulcson felülír), a Mongo-oldal is `(collectionKey,
|
|
57
|
-
* vectorId)`-upsert. A Mongo-írás MELLÉKHATÁS a memória-művelet után (a memória a forrás, a Mongo a tár).
|
|
58
|
-
*/
|
|
59
|
-
async addVector(vectorId: string, vector: number[], metadata?: unknown): Promise<void> {
|
|
60
|
-
this.pool.addVector(vectorId, vector);
|
|
61
|
-
await this.getPersistService().upsertVector({
|
|
62
|
-
collectionKey: this.collectionKey,
|
|
63
|
-
vectorId: vectorId,
|
|
64
|
-
embedding: vector,
|
|
65
|
-
metadata: metadata,
|
|
66
|
-
});
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
/**
|
|
70
|
-
* Egy MEGLÉVŐ vektor frissítése a memória-pool-ban + tartós upsert Mongo-ba. A pool `updateVector`-ja
|
|
71
|
-
* dob, ha a kulcs nem létezik (a pool-szerződés változatlan) — a Mongo-írás csak siker után fut.
|
|
72
|
-
*/
|
|
73
|
-
async updateVector(vectorId: string, vector: number[], metadata?: unknown): Promise<void> {
|
|
74
|
-
this.pool.updateVector(vectorId, vector);
|
|
75
|
-
await this.getPersistService().upsertVector({
|
|
76
|
-
collectionKey: this.collectionKey,
|
|
77
|
-
vectorId: vectorId,
|
|
78
|
-
embedding: vector,
|
|
79
|
-
metadata: metadata,
|
|
80
|
-
});
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
/** Egy vektor eltávolítása a memória-pool-ból ÉS a tartós tárból (`(collectionKey, vectorId)`). */
|
|
84
|
-
async removeVector(vectorId: string): Promise<void> {
|
|
85
|
-
this.pool.removeVector(vectorId);
|
|
86
|
-
await this.getPersistService().removeVector(this.collectionKey, vectorId);
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
/** Keresés a memória-pool-on (a wrapped pool `search`-jét delegálja — VÁLTOZATLAN engine). */
|
|
90
|
-
search(query: number[], k: number, mode: LVS_Search_Mode): LVS_SearchResult[] {
|
|
91
|
-
return this.pool.search(query, k, mode);
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
/**
|
|
95
|
-
* BOOT-HIDRATÁLÁS (FAM-minta, BFR-AM-001): a `collectionKey` ÖSSZES perzistált vektorát betölti a
|
|
96
|
-
* MEMÓRIA-pool-ba (`pool.addVector`), így a szerver-restart utáni in-memory index újraépül. A pool-t
|
|
97
|
-
* előbb üríti (idempotens hidratálás). A hiányos (üres `vectorId`/`embedding`) rekordokat átugorja.
|
|
98
|
-
* Visszaadja a betöltött vektorok számát. **NEM** Atlas — saját Mongo + in-memory pool.
|
|
99
|
-
*/
|
|
100
|
-
async hydrateFromMongo(): Promise<number> {
|
|
101
|
-
const records: DyNTS_LVS_VectorPersist[] =
|
|
102
|
-
await this.getPersistService().findByCollectionKey(this.collectionKey);
|
|
103
|
-
|
|
104
|
-
this.pool.clearPool();
|
|
105
|
-
|
|
1
|
+
|
|
2
|
+
import { DyFM_Log } from '@futdevpro/fsm-dynamo';
|
|
3
|
+
|
|
4
|
+
import { LVS_Search_Mode } from '../_enums/lvs-search-mode.enum';
|
|
5
|
+
import { LVS_SearchResult } from '../_models/lvs-search-result.interface';
|
|
6
|
+
import { DyNTS_LVS_VectorPersist } from '../_models/data-models/lvs-vector-persist.data-model';
|
|
7
|
+
import { DyNTS_LVS_VectorPersist_DataService } from './lvs-vector-persist.data-service';
|
|
8
|
+
import { LVS_VectorPool_ControlService } from './lvs-vector-pool.control-service';
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* `DyNTS_LVS_PersistentVectorPool_ControlService` (BFR-AM-001) — egy `LVS_VectorPool_ControlService` in-memory pool +
|
|
12
|
+
* MongoDB-perzisztencia **kompozíciója**. A FAM (fdp-agent-memory) `FAM_VectorSearch_ControlService`
|
|
13
|
+
* persist+hydrate workaround-ját generalizálja bedrock-szintre: a vektorok a SAJÁT Mongo-ban
|
|
14
|
+
* (`dynts_lvs_vector`) élnek, boot-kor a memória-pool-ba hidratálódnak — **NEM** MongoDB Atlas
|
|
15
|
+
* Vector Search.
|
|
16
|
+
*
|
|
17
|
+
* **Miért KOMPOZÍCIÓ (NEM a pool-class módosítása):** a `LVS_VectorPool_ControlService`-t egy másik,
|
|
18
|
+
* párhuzamos WIP (hybrid cosine+BM25) is érinti; a pool-class változtatása merge-konfliktust okozna.
|
|
19
|
+
* Ez a wrapper a pool-t VÁLTOZATLANUL hagyja (delegál: `addVector`/`removeVector`/`updateVector`/
|
|
20
|
+
* `search`), és a perzisztencia-mellékhatást a wrapper-metódusokban végzi. Egy wrapper-instance egy
|
|
21
|
+
* `collectionKey` (logikai pool); több pool = több wrapper.
|
|
22
|
+
*
|
|
23
|
+
* **FIGYELEM (memory: dynts_dataservice_eager_resolve):** a `DyNTS_DataService` base-ctor EAGER
|
|
24
|
+
* `getDBService`-t hív, ezért a wrapper NEM tart élő data-service-mezőt — minden DB-művelet előtt lazy
|
|
25
|
+
* `new DyNTS_LVS_VectorPersist_DataService(...)` (a `getPersistService` ezt adja).
|
|
26
|
+
*/
|
|
27
|
+
export class DyNTS_LVS_PersistentVectorPool_ControlService {
|
|
28
|
+
|
|
29
|
+
/** A wrapped in-memory pool (a Dynamo LVS engine; VÁLTOZATLAN — kompozíció, nem módosítás). */
|
|
30
|
+
private readonly pool: LVS_VectorPool_ControlService;
|
|
31
|
+
|
|
32
|
+
/** A pool-particionálás kulcsa (a Mongo-rekordok `collectionKey`-e + a hidratálás-szűrő). */
|
|
33
|
+
private readonly collectionKey: string;
|
|
34
|
+
|
|
35
|
+
/** A perzisztencia-műveletek issuer-e (audit). */
|
|
36
|
+
private readonly issuer: string;
|
|
37
|
+
|
|
38
|
+
constructor(set: {
|
|
39
|
+
collectionKey: string,
|
|
40
|
+
issuer: string,
|
|
41
|
+
pool?: LVS_VectorPool_ControlService,
|
|
42
|
+
}) {
|
|
43
|
+
this.collectionKey = set.collectionKey;
|
|
44
|
+
this.issuer = set.issuer;
|
|
45
|
+
// Saját pool, ha a hívó nem ad be egyet (a wrapper nem módosítja a pool-osztályt — kompozíció).
|
|
46
|
+
this.pool = set.pool ?? new LVS_VectorPool_ControlService();
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
/** A wrapped in-memory pool (közvetlen olvasáshoz — pl. más search-mód, getAll). */
|
|
50
|
+
getPool(): LVS_VectorPool_ControlService {
|
|
51
|
+
return this.pool;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
/**
|
|
55
|
+
* Egy vektor felvétele a memória-pool-ba ÉS tartós upsert-je Mongo-ba (persist-on-write, FAM-minta).
|
|
56
|
+
* A pool `addVector`-ja upsert-szemantikájú (azonos kulcson felülír), a Mongo-oldal is `(collectionKey,
|
|
57
|
+
* vectorId)`-upsert. A Mongo-írás MELLÉKHATÁS a memória-művelet után (a memória a forrás, a Mongo a tár).
|
|
58
|
+
*/
|
|
59
|
+
async addVector(vectorId: string, vector: number[], metadata?: unknown): Promise<void> {
|
|
60
|
+
this.pool.addVector(vectorId, vector);
|
|
61
|
+
await this.getPersistService().upsertVector({
|
|
62
|
+
collectionKey: this.collectionKey,
|
|
63
|
+
vectorId: vectorId,
|
|
64
|
+
embedding: vector,
|
|
65
|
+
metadata: metadata,
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
/**
|
|
70
|
+
* Egy MEGLÉVŐ vektor frissítése a memória-pool-ban + tartós upsert Mongo-ba. A pool `updateVector`-ja
|
|
71
|
+
* dob, ha a kulcs nem létezik (a pool-szerződés változatlan) — a Mongo-írás csak siker után fut.
|
|
72
|
+
*/
|
|
73
|
+
async updateVector(vectorId: string, vector: number[], metadata?: unknown): Promise<void> {
|
|
74
|
+
this.pool.updateVector(vectorId, vector);
|
|
75
|
+
await this.getPersistService().upsertVector({
|
|
76
|
+
collectionKey: this.collectionKey,
|
|
77
|
+
vectorId: vectorId,
|
|
78
|
+
embedding: vector,
|
|
79
|
+
metadata: metadata,
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
/** Egy vektor eltávolítása a memória-pool-ból ÉS a tartós tárból (`(collectionKey, vectorId)`). */
|
|
84
|
+
async removeVector(vectorId: string): Promise<void> {
|
|
85
|
+
this.pool.removeVector(vectorId);
|
|
86
|
+
await this.getPersistService().removeVector(this.collectionKey, vectorId);
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
/** Keresés a memória-pool-on (a wrapped pool `search`-jét delegálja — VÁLTOZATLAN engine). */
|
|
90
|
+
search(query: number[], k: number, mode: LVS_Search_Mode): LVS_SearchResult[] {
|
|
91
|
+
return this.pool.search(query, k, mode);
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
/**
|
|
95
|
+
* BOOT-HIDRATÁLÁS (FAM-minta, BFR-AM-001): a `collectionKey` ÖSSZES perzistált vektorát betölti a
|
|
96
|
+
* MEMÓRIA-pool-ba (`pool.addVector`), így a szerver-restart utáni in-memory index újraépül. A pool-t
|
|
97
|
+
* előbb üríti (idempotens hidratálás). A hiányos (üres `vectorId`/`embedding`) rekordokat átugorja.
|
|
98
|
+
* Visszaadja a betöltött vektorok számát. **NEM** Atlas — saját Mongo + in-memory pool.
|
|
99
|
+
*/
|
|
100
|
+
async hydrateFromMongo(): Promise<number> {
|
|
101
|
+
const records: DyNTS_LVS_VectorPersist[] =
|
|
102
|
+
await this.getPersistService().findByCollectionKey(this.collectionKey);
|
|
103
|
+
|
|
104
|
+
this.pool.clearPool();
|
|
105
|
+
|
|
106
106
|
let loaded: number = 0;
|
|
107
|
-
|
|
108
|
-
for (const record of records) {
|
|
109
|
-
if (!record.vectorId || !record.embedding?.length) {
|
|
110
|
-
continue;
|
|
111
|
-
}
|
|
112
|
-
this.pool.addVector(record.vectorId, record.embedding);
|
|
113
|
-
loaded++;
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
DyFM_Log.log(
|
|
117
|
-
`[DyNTS LVS hydrate] '${this.collectionKey}' pool: ${loaded} vektor betöltve az in-memory pool-ba.`,
|
|
107
|
+
|
|
108
|
+
for (const record of records) {
|
|
109
|
+
if (!record.vectorId || !record.embedding?.length) {
|
|
110
|
+
continue;
|
|
111
|
+
}
|
|
112
|
+
this.pool.addVector(record.vectorId, record.embedding);
|
|
113
|
+
loaded++;
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
DyFM_Log.log(
|
|
117
|
+
`[DyNTS LVS hydrate] '${this.collectionKey}' pool: ${loaded} vektor betöltve az in-memory pool-ba.`,
|
|
118
118
|
);
|
|
119
|
-
|
|
120
|
-
return loaded;
|
|
121
|
-
}
|
|
122
|
-
|
|
123
|
-
/**
|
|
124
|
-
* Perzistált rekordok közvetlen hidratálása a memória-pool-ba (Mongo-olvasás NÉLKÜL) — ha a hívó már
|
|
125
|
-
* kezében van a rekord-halmaz (pl. batch-boot). A pool-t előbb üríti (idempotens). Visszaadja a
|
|
126
|
-
* betöltött vektorok számát.
|
|
127
|
-
*/
|
|
128
|
-
hydrate(records: DyNTS_LVS_VectorPersist[]): number {
|
|
129
|
-
this.pool.clearPool();
|
|
119
|
+
|
|
120
|
+
return loaded;
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
/**
|
|
124
|
+
* Perzistált rekordok közvetlen hidratálása a memória-pool-ba (Mongo-olvasás NÉLKÜL) — ha a hívó már
|
|
125
|
+
* kezében van a rekord-halmaz (pl. batch-boot). A pool-t előbb üríti (idempotens). Visszaadja a
|
|
126
|
+
* betöltött vektorok számát.
|
|
127
|
+
*/
|
|
128
|
+
hydrate(records: DyNTS_LVS_VectorPersist[]): number {
|
|
129
|
+
this.pool.clearPool();
|
|
130
130
|
let loaded: number = 0;
|
|
131
|
-
|
|
132
|
-
for (const record of records) {
|
|
133
|
-
if (!record.vectorId || !record.embedding?.length) {
|
|
134
|
-
continue;
|
|
135
|
-
}
|
|
136
|
-
this.pool.addVector(record.vectorId, record.embedding);
|
|
137
|
-
loaded++;
|
|
131
|
+
|
|
132
|
+
for (const record of records) {
|
|
133
|
+
if (!record.vectorId || !record.embedding?.length) {
|
|
134
|
+
continue;
|
|
135
|
+
}
|
|
136
|
+
this.pool.addVector(record.vectorId, record.embedding);
|
|
137
|
+
loaded++;
|
|
138
138
|
}
|
|
139
|
-
|
|
140
|
-
return loaded;
|
|
141
|
-
}
|
|
142
|
-
|
|
143
|
-
/**
|
|
144
|
-
* Lazy persist-data-service (memory: dynts_dataservice_eager_resolve — a base-ctor eager
|
|
145
|
-
* `getDBService`-e miatt NEM tartható élő mezőként).
|
|
146
|
-
*/
|
|
147
|
-
private getPersistService(): DyNTS_LVS_VectorPersist_DataService {
|
|
148
|
-
return new DyNTS_LVS_VectorPersist_DataService({ issuer: this.issuer });
|
|
149
|
-
}
|
|
150
|
-
}
|
|
139
|
+
|
|
140
|
+
return loaded;
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
/**
|
|
144
|
+
* Lazy persist-data-service (memory: dynts_dataservice_eager_resolve — a base-ctor eager
|
|
145
|
+
* `getDBService`-e miatt NEM tartható élő mezőként).
|
|
146
|
+
*/
|
|
147
|
+
private getPersistService(): DyNTS_LVS_VectorPersist_DataService {
|
|
148
|
+
return new DyNTS_LVS_VectorPersist_DataService({ issuer: this.issuer });
|
|
149
|
+
}
|
|
150
|
+
}
|
|
@@ -1,167 +1,167 @@
|
|
|
1
|
-
|
|
2
|
-
import { DyFM_EnvironmentFlag } from '@futdevpro/fsm-dynamo';
|
|
3
|
-
|
|
4
|
-
import { DyNTS_global_settings } from '../../../_collections/global-settings.const';
|
|
5
|
-
import { DyNTS_GlobalService } from '../../../_services/core/global.service';
|
|
6
|
-
import { DyNTS_LVS_VectorPersist } from '../_models/data-models/lvs-vector-persist.data-model';
|
|
7
|
-
import { DyNTS_LVS_VectorPersist_DataService } from './lvs-vector-persist.data-service';
|
|
8
|
-
|
|
9
|
-
/**
|
|
10
|
-
* BFR-AM-001 — a `DyNTS_LVS_VectorPersist_DataService` spec-jei. A base-ctor eager `getDBService`-jét
|
|
11
|
-
* stub-oljuk (memory: dynts_dataservice_eager_resolve), így NEM kell élő Mongo. Az upsert atomikus
|
|
12
|
-
* `$set`-jét (Mixed `metadata` — memory: mongoose_mixed_atomic_write) + a dimenzió-tárolást bizonyítja.
|
|
13
|
-
*/
|
|
14
|
-
describe('| DyNTS_LVS_VectorPersist_DataService', () => {
|
|
15
|
-
|
|
16
|
-
let mockDBService: jasmine.SpyObj<{ find: () => Promise<unknown[]>; findOne: () => Promise<unknown> }>;
|
|
17
|
-
|
|
18
|
-
beforeAll(() => {
|
|
19
|
-
if (!DyNTS_global_settings.systemShortCodeName) {
|
|
20
|
-
(DyNTS_global_settings as { systemShortCodeName?: string }).systemShortCodeName = 'TEST';
|
|
21
|
-
}
|
|
22
|
-
if (!DyNTS_global_settings.env_settings) {
|
|
23
|
-
(DyNTS_global_settings as { env_settings?: unknown }).env_settings = {
|
|
24
|
-
environment: DyFM_EnvironmentFlag.local,
|
|
25
|
-
};
|
|
26
|
-
}
|
|
27
|
-
});
|
|
28
|
-
|
|
29
|
-
beforeEach(() => {
|
|
30
|
-
mockDBService = jasmine.createSpyObj('DyNTS_DBService', ['find', 'findOne']);
|
|
31
|
-
mockDBService.find.and.returnValue(Promise.resolve([]));
|
|
32
|
-
mockDBService.findOne.and.returnValue(Promise.resolve(null));
|
|
33
|
-
spyOn(DyNTS_GlobalService, 'getDBService').and.returnValue(mockDBService as never);
|
|
34
|
-
});
|
|
35
|
-
|
|
36
|
-
describe('| constructor', () => {
|
|
37
|
-
|
|
38
|
-
it('| should create the service with a data model', () => {
|
|
39
|
-
const data: DyNTS_LVS_VectorPersist = new DyNTS_LVS_VectorPersist({
|
|
40
|
-
collectionKey: 'pool-a',
|
|
41
|
-
vectorId: 'v1',
|
|
42
|
-
embedding: [1, 2, 3],
|
|
43
|
-
});
|
|
44
|
-
|
|
45
|
-
const service: DyNTS_LVS_VectorPersist_DataService =
|
|
46
|
-
new DyNTS_LVS_VectorPersist_DataService({ data: data, issuer: 'issuer-123' });
|
|
47
|
-
|
|
48
|
-
expect(service).toBeInstanceOf(DyNTS_LVS_VectorPersist_DataService);
|
|
49
|
-
expect(service.data).toBeDefined();
|
|
50
|
-
expect(service.data.vectorId).toBe('v1');
|
|
51
|
-
expect(service.data.collectionKey).toBe('pool-a');
|
|
52
|
-
});
|
|
53
|
-
|
|
54
|
-
it('| should create the service without data', () => {
|
|
55
|
-
const service: DyNTS_LVS_VectorPersist_DataService =
|
|
56
|
-
new DyNTS_LVS_VectorPersist_DataService({ issuer: 'issuer-123' });
|
|
57
|
-
|
|
58
|
-
expect(service).toBeInstanceOf(DyNTS_LVS_VectorPersist_DataService);
|
|
59
|
-
expect(service.data).toBeInstanceOf(DyNTS_LVS_VectorPersist);
|
|
60
|
-
});
|
|
61
|
-
});
|
|
62
|
-
|
|
63
|
-
describe('| findByCollectionKey', () => {
|
|
64
|
-
|
|
65
|
-
it('| should query the persisted vectors for a collectionKey', async () => {
|
|
66
|
-
const service: DyNTS_LVS_VectorPersist_DataService =
|
|
67
|
-
new DyNTS_LVS_VectorPersist_DataService({ issuer: 'issuer-123' });
|
|
68
|
-
|
|
69
|
-
const records: DyNTS_LVS_VectorPersist[] = [
|
|
70
|
-
new DyNTS_LVS_VectorPersist({ collectionKey: 'pool-a', vectorId: 'v1', embedding: [1, 0] }),
|
|
71
|
-
];
|
|
72
|
-
const findSpy = spyOn(service, 'findDataList').and.returnValue(Promise.resolve(records));
|
|
73
|
-
|
|
74
|
-
const result: DyNTS_LVS_VectorPersist[] = await service.findByCollectionKey('pool-a');
|
|
75
|
-
|
|
76
|
-
expect(findSpy).toHaveBeenCalledTimes(1);
|
|
77
|
-
const filterArg = findSpy.calls.mostRecent().args[0] as { collectionKey: string };
|
|
78
|
-
expect(filterArg.collectionKey).toBe('pool-a');
|
|
79
|
-
expect(result).toBe(records);
|
|
80
|
-
});
|
|
81
|
-
});
|
|
82
|
-
|
|
83
|
-
describe('| upsertVector — atomic $set + dimension store', () => {
|
|
84
|
-
|
|
85
|
-
it('| should issue an updateOne $set (with dimensions) for an EXISTING record', async () => {
|
|
86
|
-
const service: DyNTS_LVS_VectorPersist_DataService =
|
|
87
|
-
new DyNTS_LVS_VectorPersist_DataService({ issuer: 'issuer-123' });
|
|
88
|
-
|
|
89
|
-
const existing: DyNTS_LVS_VectorPersist = new DyNTS_LVS_VectorPersist({
|
|
90
|
-
collectionKey: 'pool-a', vectorId: 'v1', embedding: [1, 2, 3],
|
|
91
|
-
});
|
|
92
|
-
existing._id = 'rec-1';
|
|
93
|
-
|
|
94
|
-
spyOn(service, 'findData').and.returnValue(Promise.resolve(existing));
|
|
95
|
-
const updateSpy = spyOn(service, 'updateData').and.returnValue(Promise.resolve());
|
|
96
|
-
const saveSpy = spyOn(service, 'saveData').and.returnValue(Promise.resolve(existing));
|
|
97
|
-
|
|
98
|
-
await service.upsertVector({
|
|
99
|
-
collectionKey: 'pool-a', vectorId: 'v1', embedding: [4, 5, 6, 7], metadata: { tag: 'x' },
|
|
100
|
-
});
|
|
101
|
-
|
|
102
|
-
expect(saveSpy).not.toHaveBeenCalled();
|
|
103
|
-
expect(updateSpy).toHaveBeenCalledTimes(1);
|
|
104
|
-
const arg = updateSpy.calls.mostRecent().args[0] as {
|
|
105
|
-
filterBy: { _id: string };
|
|
106
|
-
update: { $set: { embedding: number[]; dimensions: number; metadata: unknown } };
|
|
107
|
-
};
|
|
108
|
-
expect(arg.filterBy._id).toBe('rec-1');
|
|
109
|
-
expect(arg.update.$set.embedding).toEqual([4, 5, 6, 7]);
|
|
110
|
-
expect(arg.update.$set.dimensions).toBe(4);
|
|
111
|
-
expect(arg.update.$set.metadata).toEqual({ tag: 'x' });
|
|
112
|
-
});
|
|
113
|
-
|
|
114
|
-
it('| should saveData a NEW record (with stored dimensions) when none exists', async () => {
|
|
115
|
-
const service: DyNTS_LVS_VectorPersist_DataService =
|
|
116
|
-
new DyNTS_LVS_VectorPersist_DataService({ issuer: 'issuer-123' });
|
|
117
|
-
|
|
118
|
-
spyOn(service, 'findData').and.returnValue(Promise.resolve(null));
|
|
119
|
-
const updateSpy = spyOn(service, 'updateData').and.returnValue(Promise.resolve());
|
|
120
|
-
const saveSpy = spyOn(service, 'saveData')
|
|
121
|
-
.and.callFake((data?: DyNTS_LVS_VectorPersist) =>
|
|
122
|
-
Promise.resolve(data as DyNTS_LVS_VectorPersist));
|
|
123
|
-
|
|
124
|
-
await service.upsertVector({ collectionKey: 'pool-a', vectorId: 'v2', embedding: [0.1, 0.2] });
|
|
125
|
-
|
|
126
|
-
expect(updateSpy).not.toHaveBeenCalled();
|
|
127
|
-
expect(saveSpy).toHaveBeenCalledTimes(1);
|
|
128
|
-
const written = saveSpy.calls.mostRecent().args[0] as DyNTS_LVS_VectorPersist;
|
|
129
|
-
expect(written.vectorId).toBe('v2');
|
|
130
|
-
expect(written.collectionKey).toBe('pool-a');
|
|
131
|
-
expect(written.embedding).toEqual([0.1, 0.2]);
|
|
132
|
-
expect(written.dimensions).toBe(2);
|
|
133
|
-
});
|
|
134
|
-
});
|
|
135
|
-
|
|
136
|
-
describe('| removeVector', () => {
|
|
137
|
-
|
|
138
|
-
it('| should absolute-delete the matching record', async () => {
|
|
139
|
-
const service: DyNTS_LVS_VectorPersist_DataService =
|
|
140
|
-
new DyNTS_LVS_VectorPersist_DataService({ issuer: 'issuer-123' });
|
|
141
|
-
|
|
142
|
-
const existing: DyNTS_LVS_VectorPersist = new DyNTS_LVS_VectorPersist({
|
|
143
|
-
collectionKey: 'pool-a', vectorId: 'v1', embedding: [1, 0],
|
|
144
|
-
});
|
|
145
|
-
existing._id = 'rec-1';
|
|
146
|
-
|
|
147
|
-
spyOn(service, 'findData').and.returnValue(Promise.resolve(existing));
|
|
148
|
-
const deleteSpy = spyOn(service, 'deleteData').and.returnValue(Promise.resolve());
|
|
149
|
-
|
|
150
|
-
await service.removeVector('pool-a', 'v1');
|
|
151
|
-
|
|
152
|
-
expect(deleteSpy).toHaveBeenCalledWith('rec-1', true);
|
|
153
|
-
});
|
|
154
|
-
|
|
155
|
-
it('| should be a no-op when no matching record exists', async () => {
|
|
156
|
-
const service: DyNTS_LVS_VectorPersist_DataService =
|
|
157
|
-
new DyNTS_LVS_VectorPersist_DataService({ issuer: 'issuer-123' });
|
|
158
|
-
|
|
159
|
-
spyOn(service, 'findData').and.returnValue(Promise.resolve(null));
|
|
160
|
-
const deleteSpy = spyOn(service, 'deleteData').and.returnValue(Promise.resolve());
|
|
161
|
-
|
|
162
|
-
await service.removeVector('pool-a', 'missing');
|
|
163
|
-
|
|
164
|
-
expect(deleteSpy).not.toHaveBeenCalled();
|
|
165
|
-
});
|
|
166
|
-
});
|
|
167
|
-
});
|
|
1
|
+
|
|
2
|
+
import { DyFM_EnvironmentFlag } from '@futdevpro/fsm-dynamo';
|
|
3
|
+
|
|
4
|
+
import { DyNTS_global_settings } from '../../../_collections/global-settings.const';
|
|
5
|
+
import { DyNTS_GlobalService } from '../../../_services/core/global.service';
|
|
6
|
+
import { DyNTS_LVS_VectorPersist } from '../_models/data-models/lvs-vector-persist.data-model';
|
|
7
|
+
import { DyNTS_LVS_VectorPersist_DataService } from './lvs-vector-persist.data-service';
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* BFR-AM-001 — a `DyNTS_LVS_VectorPersist_DataService` spec-jei. A base-ctor eager `getDBService`-jét
|
|
11
|
+
* stub-oljuk (memory: dynts_dataservice_eager_resolve), így NEM kell élő Mongo. Az upsert atomikus
|
|
12
|
+
* `$set`-jét (Mixed `metadata` — memory: mongoose_mixed_atomic_write) + a dimenzió-tárolást bizonyítja.
|
|
13
|
+
*/
|
|
14
|
+
describe('| DyNTS_LVS_VectorPersist_DataService', () => {
|
|
15
|
+
|
|
16
|
+
let mockDBService: jasmine.SpyObj<{ find: () => Promise<unknown[]>; findOne: () => Promise<unknown> }>;
|
|
17
|
+
|
|
18
|
+
beforeAll(() => {
|
|
19
|
+
if (!DyNTS_global_settings.systemShortCodeName) {
|
|
20
|
+
(DyNTS_global_settings as { systemShortCodeName?: string }).systemShortCodeName = 'TEST';
|
|
21
|
+
}
|
|
22
|
+
if (!DyNTS_global_settings.env_settings) {
|
|
23
|
+
(DyNTS_global_settings as { env_settings?: unknown }).env_settings = {
|
|
24
|
+
environment: DyFM_EnvironmentFlag.local,
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
beforeEach(() => {
|
|
30
|
+
mockDBService = jasmine.createSpyObj('DyNTS_DBService', ['find', 'findOne']);
|
|
31
|
+
mockDBService.find.and.returnValue(Promise.resolve([]));
|
|
32
|
+
mockDBService.findOne.and.returnValue(Promise.resolve(null));
|
|
33
|
+
spyOn(DyNTS_GlobalService, 'getDBService').and.returnValue(mockDBService as never);
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
describe('| constructor', () => {
|
|
37
|
+
|
|
38
|
+
it('| should create the service with a data model', () => {
|
|
39
|
+
const data: DyNTS_LVS_VectorPersist = new DyNTS_LVS_VectorPersist({
|
|
40
|
+
collectionKey: 'pool-a',
|
|
41
|
+
vectorId: 'v1',
|
|
42
|
+
embedding: [1, 2, 3],
|
|
43
|
+
});
|
|
44
|
+
|
|
45
|
+
const service: DyNTS_LVS_VectorPersist_DataService =
|
|
46
|
+
new DyNTS_LVS_VectorPersist_DataService({ data: data, issuer: 'issuer-123' });
|
|
47
|
+
|
|
48
|
+
expect(service).toBeInstanceOf(DyNTS_LVS_VectorPersist_DataService);
|
|
49
|
+
expect(service.data).toBeDefined();
|
|
50
|
+
expect(service.data.vectorId).toBe('v1');
|
|
51
|
+
expect(service.data.collectionKey).toBe('pool-a');
|
|
52
|
+
});
|
|
53
|
+
|
|
54
|
+
it('| should create the service without data', () => {
|
|
55
|
+
const service: DyNTS_LVS_VectorPersist_DataService =
|
|
56
|
+
new DyNTS_LVS_VectorPersist_DataService({ issuer: 'issuer-123' });
|
|
57
|
+
|
|
58
|
+
expect(service).toBeInstanceOf(DyNTS_LVS_VectorPersist_DataService);
|
|
59
|
+
expect(service.data).toBeInstanceOf(DyNTS_LVS_VectorPersist);
|
|
60
|
+
});
|
|
61
|
+
});
|
|
62
|
+
|
|
63
|
+
describe('| findByCollectionKey', () => {
|
|
64
|
+
|
|
65
|
+
it('| should query the persisted vectors for a collectionKey', async () => {
|
|
66
|
+
const service: DyNTS_LVS_VectorPersist_DataService =
|
|
67
|
+
new DyNTS_LVS_VectorPersist_DataService({ issuer: 'issuer-123' });
|
|
68
|
+
|
|
69
|
+
const records: DyNTS_LVS_VectorPersist[] = [
|
|
70
|
+
new DyNTS_LVS_VectorPersist({ collectionKey: 'pool-a', vectorId: 'v1', embedding: [1, 0] }),
|
|
71
|
+
];
|
|
72
|
+
const findSpy = spyOn(service, 'findDataList').and.returnValue(Promise.resolve(records));
|
|
73
|
+
|
|
74
|
+
const result: DyNTS_LVS_VectorPersist[] = await service.findByCollectionKey('pool-a');
|
|
75
|
+
|
|
76
|
+
expect(findSpy).toHaveBeenCalledTimes(1);
|
|
77
|
+
const filterArg = findSpy.calls.mostRecent().args[0] as { collectionKey: string };
|
|
78
|
+
expect(filterArg.collectionKey).toBe('pool-a');
|
|
79
|
+
expect(result).toBe(records);
|
|
80
|
+
});
|
|
81
|
+
});
|
|
82
|
+
|
|
83
|
+
describe('| upsertVector — atomic $set + dimension store', () => {
|
|
84
|
+
|
|
85
|
+
it('| should issue an updateOne $set (with dimensions) for an EXISTING record', async () => {
|
|
86
|
+
const service: DyNTS_LVS_VectorPersist_DataService =
|
|
87
|
+
new DyNTS_LVS_VectorPersist_DataService({ issuer: 'issuer-123' });
|
|
88
|
+
|
|
89
|
+
const existing: DyNTS_LVS_VectorPersist = new DyNTS_LVS_VectorPersist({
|
|
90
|
+
collectionKey: 'pool-a', vectorId: 'v1', embedding: [1, 2, 3],
|
|
91
|
+
});
|
|
92
|
+
existing._id = 'rec-1';
|
|
93
|
+
|
|
94
|
+
spyOn(service, 'findData').and.returnValue(Promise.resolve(existing));
|
|
95
|
+
const updateSpy = spyOn(service, 'updateData').and.returnValue(Promise.resolve());
|
|
96
|
+
const saveSpy = spyOn(service, 'saveData').and.returnValue(Promise.resolve(existing));
|
|
97
|
+
|
|
98
|
+
await service.upsertVector({
|
|
99
|
+
collectionKey: 'pool-a', vectorId: 'v1', embedding: [4, 5, 6, 7], metadata: { tag: 'x' },
|
|
100
|
+
});
|
|
101
|
+
|
|
102
|
+
expect(saveSpy).not.toHaveBeenCalled();
|
|
103
|
+
expect(updateSpy).toHaveBeenCalledTimes(1);
|
|
104
|
+
const arg = updateSpy.calls.mostRecent().args[0] as {
|
|
105
|
+
filterBy: { _id: string };
|
|
106
|
+
update: { $set: { embedding: number[]; dimensions: number; metadata: unknown } };
|
|
107
|
+
};
|
|
108
|
+
expect(arg.filterBy._id).toBe('rec-1');
|
|
109
|
+
expect(arg.update.$set.embedding).toEqual([4, 5, 6, 7]);
|
|
110
|
+
expect(arg.update.$set.dimensions).toBe(4);
|
|
111
|
+
expect(arg.update.$set.metadata).toEqual({ tag: 'x' });
|
|
112
|
+
});
|
|
113
|
+
|
|
114
|
+
it('| should saveData a NEW record (with stored dimensions) when none exists', async () => {
|
|
115
|
+
const service: DyNTS_LVS_VectorPersist_DataService =
|
|
116
|
+
new DyNTS_LVS_VectorPersist_DataService({ issuer: 'issuer-123' });
|
|
117
|
+
|
|
118
|
+
spyOn(service, 'findData').and.returnValue(Promise.resolve(null));
|
|
119
|
+
const updateSpy = spyOn(service, 'updateData').and.returnValue(Promise.resolve());
|
|
120
|
+
const saveSpy = spyOn(service, 'saveData')
|
|
121
|
+
.and.callFake((data?: DyNTS_LVS_VectorPersist) =>
|
|
122
|
+
Promise.resolve(data as DyNTS_LVS_VectorPersist));
|
|
123
|
+
|
|
124
|
+
await service.upsertVector({ collectionKey: 'pool-a', vectorId: 'v2', embedding: [0.1, 0.2] });
|
|
125
|
+
|
|
126
|
+
expect(updateSpy).not.toHaveBeenCalled();
|
|
127
|
+
expect(saveSpy).toHaveBeenCalledTimes(1);
|
|
128
|
+
const written = saveSpy.calls.mostRecent().args[0] as DyNTS_LVS_VectorPersist;
|
|
129
|
+
expect(written.vectorId).toBe('v2');
|
|
130
|
+
expect(written.collectionKey).toBe('pool-a');
|
|
131
|
+
expect(written.embedding).toEqual([0.1, 0.2]);
|
|
132
|
+
expect(written.dimensions).toBe(2);
|
|
133
|
+
});
|
|
134
|
+
});
|
|
135
|
+
|
|
136
|
+
describe('| removeVector', () => {
|
|
137
|
+
|
|
138
|
+
it('| should absolute-delete the matching record', async () => {
|
|
139
|
+
const service: DyNTS_LVS_VectorPersist_DataService =
|
|
140
|
+
new DyNTS_LVS_VectorPersist_DataService({ issuer: 'issuer-123' });
|
|
141
|
+
|
|
142
|
+
const existing: DyNTS_LVS_VectorPersist = new DyNTS_LVS_VectorPersist({
|
|
143
|
+
collectionKey: 'pool-a', vectorId: 'v1', embedding: [1, 0],
|
|
144
|
+
});
|
|
145
|
+
existing._id = 'rec-1';
|
|
146
|
+
|
|
147
|
+
spyOn(service, 'findData').and.returnValue(Promise.resolve(existing));
|
|
148
|
+
const deleteSpy = spyOn(service, 'deleteData').and.returnValue(Promise.resolve());
|
|
149
|
+
|
|
150
|
+
await service.removeVector('pool-a', 'v1');
|
|
151
|
+
|
|
152
|
+
expect(deleteSpy).toHaveBeenCalledWith('rec-1', true);
|
|
153
|
+
});
|
|
154
|
+
|
|
155
|
+
it('| should be a no-op when no matching record exists', async () => {
|
|
156
|
+
const service: DyNTS_LVS_VectorPersist_DataService =
|
|
157
|
+
new DyNTS_LVS_VectorPersist_DataService({ issuer: 'issuer-123' });
|
|
158
|
+
|
|
159
|
+
spyOn(service, 'findData').and.returnValue(Promise.resolve(null));
|
|
160
|
+
const deleteSpy = spyOn(service, 'deleteData').and.returnValue(Promise.resolve());
|
|
161
|
+
|
|
162
|
+
await service.removeVector('pool-a', 'missing');
|
|
163
|
+
|
|
164
|
+
expect(deleteSpy).not.toHaveBeenCalled();
|
|
165
|
+
});
|
|
166
|
+
});
|
|
167
|
+
});
|