@futdevpro/nts-dynamo 1.15.74 → 1.15.78
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/.dynamo/logs/cicd-pipeline/output.log +2783 -0
- package/.dynamo/logs/cicd-pipeline/status.json +94 -0
- 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/_services/core/global.service.d.ts +7 -0
- package/build/_services/core/global.service.d.ts.map +1 -1
- package/build/_services/core/global.service.js +10 -0
- package/build/_services/core/global.service.js.map +1 -1
- package/build/_services/server/app.server.d.ts +45 -0
- package/build/_services/server/app.server.d.ts.map +1 -1
- package/build/_services/server/app.server.js +85 -173
- package/build/_services/server/app.server.js.map +1 -1
- package/eslint.config.js +3 -3
- package/nodemon.json +24 -24
- package/package.json +2 -2
- 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 +97 -97
- 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 +216 -216
- 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 +241 -241
- package/src/_modules/server/errors/errors.controller.ts +489 -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 +240 -240
- package/src/_modules/server/server-status/server-status.controller.ts +253 -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 +196 -196
- package/src/_services/base/archive-data.service.ts +216 -216
- package/src/_services/base/data.service.spec.ts +674 -674
- package/src/_services/base/data.service.ts +2719 -2719
- 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 -475
- 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-retention.spec.ts +106 -0
- package/src/_services/server/app.server.ts +1869 -1747
- package/src/_services/shared.static-service.spec.ts +99 -99
- package/src/_services/shared.static-service.ts +78 -78
- package/src/index.ts +96 -96
- package/tsconfig.app.json +12 -12
- package/tsconfig.json +42 -42
|
@@ -1,36 +1,36 @@
|
|
|
1
|
-
|
|
2
|
-
import { DyNTS_ServerStatus_Controller } from './server-status.controller';
|
|
3
|
-
import { DyFM_ServerStatus, DyFM_Error, DyFM_Errors, DyFM_HttpCallType, DyFM_RelativeDate } from '@futdevpro/fsm-dynamo';
|
|
4
|
-
import { DyNTS_Errors_ControlService } from '../errors/errors.control-service';
|
|
5
|
-
import { DyNTS_ServerStatus_ControlService } from './server-status.control-service';
|
|
6
|
-
import { DyNTS_ServerStatusSnapshot_ControlService } from './server-status-snapshot.control-service';
|
|
7
|
-
import { DyNTS_Endpoint_Params } from '../../../_models/control-models/endpoint-params.control-model';
|
|
8
|
-
|
|
9
|
-
class TestServerStatus extends DyFM_ServerStatus {
|
|
10
|
-
testProperty?: string;
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
class TestError extends DyFM_Error {
|
|
14
|
-
testProperty?: string;
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
class TestErrors extends DyFM_Errors<TestError> {
|
|
18
|
-
testProperty?: string;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
class TestErrorsControlService extends DyNTS_Errors_ControlService<TestError, TestErrors> {
|
|
22
|
-
async recordError(data: TestErrors, issuer: string, alwaysRecord?: boolean): Promise<void> {}
|
|
23
|
-
async handleInternalError(error: any, issuer: string, alwaysRecord?: boolean): Promise<void> {}
|
|
24
|
-
checkErrorIsStringifyableOrResolvable(error: TestError, issuer: string): TestError | 'UNRESOLVABLE' { return error; }
|
|
25
|
-
getPriorityMultiplierByLevel(level: any, issuer: string): number { return 0; }
|
|
26
|
-
async getErrorsFromDate(date: Date, issuer: string): Promise<any> { return { results: [] }; }
|
|
27
|
-
async deleteError(errorId: string, issuer: string, alwaysDelete?: boolean): Promise<void> {}
|
|
28
|
-
async deleteAllErrors(issuer: string, alwaysDelete?: boolean): Promise<void> {}
|
|
29
|
-
async recordFixAttempt(errorId: string, version: string, hypothesis: string, issuer: string): Promise<any> {
|
|
30
|
-
return { at: new Date(), by: issuer, version, hypothesis };
|
|
31
|
-
}
|
|
32
|
-
async getErrorsByCategoryPaged(category: string, range: any, pageSize: number, pageIndex: number, issuer: string): Promise<any> {
|
|
33
|
-
return { items: [], total: 0, pageIndex, pageSize };
|
|
1
|
+
|
|
2
|
+
import { DyNTS_ServerStatus_Controller } from './server-status.controller';
|
|
3
|
+
import { DyFM_ServerStatus, DyFM_Error, DyFM_Errors, DyFM_HttpCallType, DyFM_RelativeDate } from '@futdevpro/fsm-dynamo';
|
|
4
|
+
import { DyNTS_Errors_ControlService } from '../errors/errors.control-service';
|
|
5
|
+
import { DyNTS_ServerStatus_ControlService } from './server-status.control-service';
|
|
6
|
+
import { DyNTS_ServerStatusSnapshot_ControlService } from './server-status-snapshot.control-service';
|
|
7
|
+
import { DyNTS_Endpoint_Params } from '../../../_models/control-models/endpoint-params.control-model';
|
|
8
|
+
|
|
9
|
+
class TestServerStatus extends DyFM_ServerStatus {
|
|
10
|
+
testProperty?: string;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
class TestError extends DyFM_Error {
|
|
14
|
+
testProperty?: string;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
class TestErrors extends DyFM_Errors<TestError> {
|
|
18
|
+
testProperty?: string;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
class TestErrorsControlService extends DyNTS_Errors_ControlService<TestError, TestErrors> {
|
|
22
|
+
async recordError(data: TestErrors, issuer: string, alwaysRecord?: boolean): Promise<void> {}
|
|
23
|
+
async handleInternalError(error: any, issuer: string, alwaysRecord?: boolean): Promise<void> {}
|
|
24
|
+
checkErrorIsStringifyableOrResolvable(error: TestError, issuer: string): TestError | 'UNRESOLVABLE' { return error; }
|
|
25
|
+
getPriorityMultiplierByLevel(level: any, issuer: string): number { return 0; }
|
|
26
|
+
async getErrorsFromDate(date: Date, issuer: string): Promise<any> { return { results: [] }; }
|
|
27
|
+
async deleteError(errorId: string, issuer: string, alwaysDelete?: boolean): Promise<void> {}
|
|
28
|
+
async deleteAllErrors(issuer: string, alwaysDelete?: boolean): Promise<void> {}
|
|
29
|
+
async recordFixAttempt(errorId: string, version: string, hypothesis: string, issuer: string): Promise<any> {
|
|
30
|
+
return { at: new Date(), by: issuer, version, hypothesis };
|
|
31
|
+
}
|
|
32
|
+
async getErrorsByCategoryPaged(category: string, range: any, pageSize: number, pageIndex: number, issuer: string): Promise<any> {
|
|
33
|
+
return { items: [], total: 0, pageIndex, pageSize };
|
|
34
34
|
}
|
|
35
35
|
|
|
36
36
|
async resolveError(errorId: string, issuer: string, notes?: string): Promise<void> {
|
|
@@ -39,210 +39,210 @@ class TestErrorsControlService extends DyNTS_Errors_ControlService<TestError, Te
|
|
|
39
39
|
|
|
40
40
|
async getErrorsByStatusPaged(status: string, range: any, pageSize: number, pageIndex: number, issuer: string): Promise<any> {
|
|
41
41
|
return { items: [], total: 0, pageIndex, pageSize };
|
|
42
|
-
}
|
|
43
|
-
async getErrorsInRange(range: DyFM_RelativeDate, issuer: string): Promise<any> { return { results: [] }; }
|
|
44
|
-
async getErrorsPaged(range: DyFM_RelativeDate, pageSize: number, pageIndex: number, issuer: string): Promise<any> { return { results: [] }; }
|
|
45
|
-
async getLastErrors(range: DyFM_RelativeDate, pageSize: number, pageIndex: number, issuer: string): Promise<any> { return { results: [] }; }
|
|
46
|
-
async searchErrors(searchQuery: any, issuer: string): Promise<any> { return { results: [] }; }
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
class TestServerStatusSnapshotControlService extends DyNTS_ServerStatusSnapshot_ControlService<TestServerStatus> {
|
|
50
|
-
async saveSnapshot(snapshot: TestServerStatus, issuer: string): Promise<TestServerStatus> {
|
|
51
|
-
return snapshot;
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
class TestServerStatusControlService extends DyNTS_ServerStatus_ControlService<
|
|
56
|
-
TestServerStatus,
|
|
57
|
-
TestError,
|
|
58
|
-
TestErrors,
|
|
59
|
-
TestErrorsControlService,
|
|
60
|
-
TestServerStatus,
|
|
61
|
-
TestServerStatusSnapshotControlService
|
|
62
|
-
> {
|
|
63
|
-
protected getErrorControlService?(set?: { data?: TestErrors, issuer?: string }): TestErrorsControlService {
|
|
64
|
-
return new TestErrorsControlService();
|
|
65
|
-
}
|
|
66
|
-
protected getServerStatusSnapshotControlService?(set?: { data?: TestServerStatus, issuer?: string }): TestServerStatusSnapshotControlService {
|
|
67
|
-
return new TestServerStatusSnapshotControlService();
|
|
68
|
-
}
|
|
69
|
-
protected requiredServerConnections: any[] = [];
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
class TestServerStatusController extends DyNTS_ServerStatus_Controller<
|
|
73
|
-
TestServerStatus,
|
|
74
|
-
TestError,
|
|
75
|
-
TestErrors,
|
|
76
|
-
TestErrorsControlService,
|
|
77
|
-
TestServerStatus,
|
|
78
|
-
TestServerStatusSnapshotControlService,
|
|
79
|
-
TestServerStatusControlService
|
|
80
|
-
> {
|
|
81
|
-
protected readonly server_CS: TestServerStatusControlService = (TestServerStatusControlService as any).getInstance ? (TestServerStatusControlService as any).getInstance() : new (TestServerStatusControlService as any)();
|
|
82
|
-
protected override readonly additionalEndpoints: DyNTS_Endpoint_Params[] = [];
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
describe('| DyNTS_ServerStatus_Controller', () => {
|
|
86
|
-
let controller: TestServerStatusController;
|
|
87
|
-
|
|
88
|
-
beforeEach(() => {
|
|
89
|
-
controller = new (TestServerStatusController as any)();
|
|
90
|
-
});
|
|
91
|
-
|
|
92
|
-
describe('| setupEndpoints', () => {
|
|
93
|
-
it('| should setup all server status endpoints', () => {
|
|
94
|
-
controller.setupEndpoints();
|
|
95
|
-
|
|
96
|
-
expect(controller.endpoints).toBeDefined();
|
|
97
|
-
expect(controller.endpoints.length).toBeGreaterThanOrEqual(4);
|
|
98
|
-
});
|
|
99
|
-
|
|
100
|
-
it('| should setup getServerStatus endpoint', () => {
|
|
101
|
-
controller.setupEndpoints();
|
|
102
|
-
|
|
103
|
-
const getServerStatusEndpoint = controller.endpoints.find(ep => ep.name === 'getServerStatus');
|
|
104
|
-
expect(getServerStatusEndpoint).toBeDefined();
|
|
105
|
-
expect(getServerStatusEndpoint?.type).toBe(DyFM_HttpCallType.get);
|
|
106
|
-
expect(getServerStatusEndpoint?.endpoint).toBe('/status');
|
|
107
|
-
expect((getServerStatusEndpoint as any)?.tasks).toBeDefined();
|
|
108
|
-
expect((getServerStatusEndpoint as any)?.tasks?.length).toBe(1);
|
|
109
|
-
});
|
|
110
|
-
|
|
111
|
-
it('| should setup getServerHealth endpoint', () => {
|
|
112
|
-
controller.setupEndpoints();
|
|
113
|
-
|
|
114
|
-
const getServerHealthEndpoint = controller.endpoints.find(ep => ep.name === 'getServerHealth');
|
|
115
|
-
expect(getServerHealthEndpoint).toBeDefined();
|
|
116
|
-
expect(getServerHealthEndpoint?.type).toBe(DyFM_HttpCallType.get);
|
|
117
|
-
expect(getServerHealthEndpoint?.endpoint).toBe('/health');
|
|
118
|
-
expect((getServerHealthEndpoint as any)?.tasks).toBeDefined();
|
|
119
|
-
expect((getServerHealthEndpoint as any)?.tasks?.length).toBe(1);
|
|
120
|
-
});
|
|
121
|
-
|
|
122
|
-
it('| should setup getServerStatusForClient endpoint', () => {
|
|
123
|
-
controller.setupEndpoints();
|
|
124
|
-
|
|
125
|
-
const getServerStatusForClientEndpoint = controller.endpoints.find(ep => ep.name === 'getServerStatusForClient');
|
|
126
|
-
expect(getServerStatusForClientEndpoint).toBeDefined();
|
|
127
|
-
expect(getServerStatusForClientEndpoint?.type).toBe(DyFM_HttpCallType.get);
|
|
128
|
-
expect(getServerStatusForClientEndpoint?.endpoint).toBe('/status/:version');
|
|
129
|
-
expect((getServerStatusForClientEndpoint as any)?.tasks).toBeDefined();
|
|
130
|
-
expect((getServerStatusForClientEndpoint as any)?.tasks?.length).toBe(1);
|
|
131
|
-
});
|
|
132
|
-
|
|
133
|
-
it('| should setup getErrorStatistics endpoint', () => {
|
|
134
|
-
controller.setupEndpoints();
|
|
135
|
-
|
|
136
|
-
const getErrorStatisticsEndpoint = controller.endpoints.find(ep => ep.name === 'getErrorStatistics');
|
|
137
|
-
expect(getErrorStatisticsEndpoint).toBeDefined();
|
|
138
|
-
expect(getErrorStatisticsEndpoint?.type).toBe(DyFM_HttpCallType.get);
|
|
139
|
-
expect(getErrorStatisticsEndpoint?.endpoint).toBe('/statistics/error/:range');
|
|
140
|
-
expect((getErrorStatisticsEndpoint as any)?.tasks).toBeDefined();
|
|
141
|
-
expect((getErrorStatisticsEndpoint as any)?.tasks?.length).toBe(1);
|
|
142
|
-
});
|
|
143
|
-
|
|
144
|
-
it('| should include additionalEndpoints', () => {
|
|
145
|
-
const additionalEndpoint = new DyNTS_Endpoint_Params({
|
|
146
|
-
name: 'customEndpoint',
|
|
147
|
-
type: DyFM_HttpCallType.get,
|
|
148
|
-
endpoint: '/status/custom',
|
|
149
|
-
tasks: [],
|
|
150
|
-
});
|
|
151
|
-
(controller as any).additionalEndpoints.push(additionalEndpoint);
|
|
152
|
-
|
|
153
|
-
controller.setupEndpoints();
|
|
154
|
-
|
|
155
|
-
const customEndpoint = controller.endpoints.find(ep => ep.name === 'customEndpoint');
|
|
156
|
-
expect(customEndpoint).toBeDefined();
|
|
157
|
-
});
|
|
158
|
-
|
|
159
|
-
it('| should throw error when additionalEndpoints is not defined', () => {
|
|
160
|
-
const controllerWithoutEndpoints = new (class extends TestServerStatusController {
|
|
161
|
-
protected override readonly additionalEndpoints: DyNTS_Endpoint_Params[] = undefined as any;
|
|
162
|
-
} as any)();
|
|
163
|
-
|
|
164
|
-
expect(() => {
|
|
165
|
-
controllerWithoutEndpoints.setupEndpoints();
|
|
166
|
-
}).toThrow();
|
|
167
|
-
});
|
|
168
|
-
});
|
|
169
|
-
|
|
170
|
-
describe('| opt-in admin auth retrofit', (): void => {
|
|
171
|
-
afterEach((): void => {
|
|
172
|
-
DyNTS_ServerStatus_Controller._resetAuthConfigForTesting();
|
|
173
|
-
});
|
|
174
|
-
|
|
175
|
-
const preCount = (controller: any, name: string): number => {
|
|
176
|
-
const ep: any = controller.endpoints.find((e: any) => e.name === name);
|
|
177
|
-
return (ep?.preProcesses ?? []).length;
|
|
178
|
-
};
|
|
179
|
-
|
|
180
|
-
it('| default: NO preProcesses on any endpoint (backwards compatible)', (): void => {
|
|
181
|
-
controller.setupEndpoints();
|
|
182
|
-
for (const ep of controller.endpoints) {
|
|
183
|
-
const pre: any = (ep as any).preProcesses;
|
|
184
|
-
expect(pre === undefined || pre.length === 0).toBe(true);
|
|
185
|
-
}
|
|
186
|
-
});
|
|
187
|
-
|
|
188
|
-
it('| configure({ authPreProcess }) → csak getErrorStatistics gated, a status-vegpontok NEM', (): void => {
|
|
189
|
-
const fakeAuth = async (): Promise<void> => { /* noop */ };
|
|
190
|
-
DyNTS_ServerStatus_Controller.configure({ authPreProcess: fakeAuth });
|
|
191
|
-
const c: any = new (TestServerStatusController as any)();
|
|
192
|
-
c.setupEndpoints();
|
|
193
|
-
|
|
194
|
-
// admin-adat → gated
|
|
195
|
-
expect(preCount(c, 'getErrorStatistics')).toBe(1);
|
|
196
|
-
// status-vegpontok (a kliens-indikator hivja, /health-tel adat-ekvivalens) → SOHA nem gated
|
|
197
|
-
expect(preCount(c, 'getServerStatus')).toBe(0);
|
|
198
|
-
expect(preCount(c, 'getServerHealth')).toBe(0);
|
|
199
|
-
expect(preCount(c, 'getServerReadiness')).toBe(0);
|
|
200
|
-
expect(preCount(c, 'getServerStatusForClient')).toBe(0);
|
|
201
|
-
});
|
|
202
|
-
|
|
203
|
-
it('| a status-vegpontokat (getServerStatus is) explicit protectedEndpoints-lista SEM gate-eli', (): void => {
|
|
204
|
-
const fakeAuth = async (): Promise<void> => { /* noop */ };
|
|
205
|
-
DyNTS_ServerStatus_Controller.configure({
|
|
206
|
-
authPreProcess: fakeAuth,
|
|
207
|
-
protectedEndpoints: [ 'getServerHealth', 'getServerReadiness', 'getServerStatusForClient', 'getServerStatus', 'getErrorStatistics' ],
|
|
208
|
-
});
|
|
209
|
-
const c: any = new (TestServerStatusController as any)();
|
|
210
|
-
c.setupEndpoints();
|
|
211
|
-
|
|
212
|
-
expect(preCount(c, 'getServerStatus')).toBe(0);
|
|
213
|
-
expect(preCount(c, 'getServerHealth')).toBe(0);
|
|
214
|
-
expect(preCount(c, 'getServerReadiness')).toBe(0);
|
|
215
|
-
expect(preCount(c, 'getServerStatusForClient')).toBe(0);
|
|
216
|
-
// a valodi admin-adat viszont gated
|
|
217
|
-
expect(preCount(c, 'getErrorStatistics')).toBe(1);
|
|
218
|
-
});
|
|
219
|
-
|
|
220
|
-
it('| protectedEndpoints subset → csak a megadott (nem-proba) neveken aktiv', (): void => {
|
|
221
|
-
const fakeAuth = async (): Promise<void> => { /* noop */ };
|
|
222
|
-
DyNTS_ServerStatus_Controller.configure({
|
|
223
|
-
authPreProcess: fakeAuth,
|
|
224
|
-
protectedEndpoints: [ 'getErrorStatistics' ],
|
|
225
|
-
});
|
|
226
|
-
const c: any = new (TestServerStatusController as any)();
|
|
227
|
-
c.setupEndpoints();
|
|
228
|
-
|
|
229
|
-
expect(preCount(c, 'getErrorStatistics')).toBe(1);
|
|
230
|
-
expect(preCount(c, 'getServerStatus')).toBe(0);
|
|
231
|
-
});
|
|
232
|
-
|
|
233
|
-
it('| getAuthConfig() returns the active config', (): void => {
|
|
234
|
-
const fakeAuth = async (): Promise<void> => { /* noop */ };
|
|
235
|
-
DyNTS_ServerStatus_Controller.configure({ authPreProcess: fakeAuth, protectedEndpoints: [ 'getErrorStatistics' ] });
|
|
236
|
-
const cfg = DyNTS_ServerStatus_Controller.getAuthConfig();
|
|
237
|
-
expect(cfg.authPreProcess).toBe(fakeAuth);
|
|
238
|
-
expect(cfg.protectedEndpoints).toEqual([ 'getErrorStatistics' ]);
|
|
239
|
-
});
|
|
240
|
-
|
|
241
|
-
it('| _resetAuthConfigForTesting() clears the config', (): void => {
|
|
242
|
-
DyNTS_ServerStatus_Controller.configure({ authPreProcess: async (): Promise<void> => { /* noop */ } });
|
|
243
|
-
DyNTS_ServerStatus_Controller._resetAuthConfigForTesting();
|
|
244
|
-
expect(DyNTS_ServerStatus_Controller.getAuthConfig().authPreProcess).toBeUndefined();
|
|
245
|
-
});
|
|
246
|
-
});
|
|
247
|
-
});
|
|
248
|
-
|
|
42
|
+
}
|
|
43
|
+
async getErrorsInRange(range: DyFM_RelativeDate, issuer: string): Promise<any> { return { results: [] }; }
|
|
44
|
+
async getErrorsPaged(range: DyFM_RelativeDate, pageSize: number, pageIndex: number, issuer: string): Promise<any> { return { results: [] }; }
|
|
45
|
+
async getLastErrors(range: DyFM_RelativeDate, pageSize: number, pageIndex: number, issuer: string): Promise<any> { return { results: [] }; }
|
|
46
|
+
async searchErrors(searchQuery: any, issuer: string): Promise<any> { return { results: [] }; }
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
class TestServerStatusSnapshotControlService extends DyNTS_ServerStatusSnapshot_ControlService<TestServerStatus> {
|
|
50
|
+
async saveSnapshot(snapshot: TestServerStatus, issuer: string): Promise<TestServerStatus> {
|
|
51
|
+
return snapshot;
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
class TestServerStatusControlService extends DyNTS_ServerStatus_ControlService<
|
|
56
|
+
TestServerStatus,
|
|
57
|
+
TestError,
|
|
58
|
+
TestErrors,
|
|
59
|
+
TestErrorsControlService,
|
|
60
|
+
TestServerStatus,
|
|
61
|
+
TestServerStatusSnapshotControlService
|
|
62
|
+
> {
|
|
63
|
+
protected getErrorControlService?(set?: { data?: TestErrors, issuer?: string }): TestErrorsControlService {
|
|
64
|
+
return new TestErrorsControlService();
|
|
65
|
+
}
|
|
66
|
+
protected getServerStatusSnapshotControlService?(set?: { data?: TestServerStatus, issuer?: string }): TestServerStatusSnapshotControlService {
|
|
67
|
+
return new TestServerStatusSnapshotControlService();
|
|
68
|
+
}
|
|
69
|
+
protected requiredServerConnections: any[] = [];
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
class TestServerStatusController extends DyNTS_ServerStatus_Controller<
|
|
73
|
+
TestServerStatus,
|
|
74
|
+
TestError,
|
|
75
|
+
TestErrors,
|
|
76
|
+
TestErrorsControlService,
|
|
77
|
+
TestServerStatus,
|
|
78
|
+
TestServerStatusSnapshotControlService,
|
|
79
|
+
TestServerStatusControlService
|
|
80
|
+
> {
|
|
81
|
+
protected readonly server_CS: TestServerStatusControlService = (TestServerStatusControlService as any).getInstance ? (TestServerStatusControlService as any).getInstance() : new (TestServerStatusControlService as any)();
|
|
82
|
+
protected override readonly additionalEndpoints: DyNTS_Endpoint_Params[] = [];
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
describe('| DyNTS_ServerStatus_Controller', () => {
|
|
86
|
+
let controller: TestServerStatusController;
|
|
87
|
+
|
|
88
|
+
beforeEach(() => {
|
|
89
|
+
controller = new (TestServerStatusController as any)();
|
|
90
|
+
});
|
|
91
|
+
|
|
92
|
+
describe('| setupEndpoints', () => {
|
|
93
|
+
it('| should setup all server status endpoints', () => {
|
|
94
|
+
controller.setupEndpoints();
|
|
95
|
+
|
|
96
|
+
expect(controller.endpoints).toBeDefined();
|
|
97
|
+
expect(controller.endpoints.length).toBeGreaterThanOrEqual(4);
|
|
98
|
+
});
|
|
99
|
+
|
|
100
|
+
it('| should setup getServerStatus endpoint', () => {
|
|
101
|
+
controller.setupEndpoints();
|
|
102
|
+
|
|
103
|
+
const getServerStatusEndpoint = controller.endpoints.find(ep => ep.name === 'getServerStatus');
|
|
104
|
+
expect(getServerStatusEndpoint).toBeDefined();
|
|
105
|
+
expect(getServerStatusEndpoint?.type).toBe(DyFM_HttpCallType.get);
|
|
106
|
+
expect(getServerStatusEndpoint?.endpoint).toBe('/status');
|
|
107
|
+
expect((getServerStatusEndpoint as any)?.tasks).toBeDefined();
|
|
108
|
+
expect((getServerStatusEndpoint as any)?.tasks?.length).toBe(1);
|
|
109
|
+
});
|
|
110
|
+
|
|
111
|
+
it('| should setup getServerHealth endpoint', () => {
|
|
112
|
+
controller.setupEndpoints();
|
|
113
|
+
|
|
114
|
+
const getServerHealthEndpoint = controller.endpoints.find(ep => ep.name === 'getServerHealth');
|
|
115
|
+
expect(getServerHealthEndpoint).toBeDefined();
|
|
116
|
+
expect(getServerHealthEndpoint?.type).toBe(DyFM_HttpCallType.get);
|
|
117
|
+
expect(getServerHealthEndpoint?.endpoint).toBe('/health');
|
|
118
|
+
expect((getServerHealthEndpoint as any)?.tasks).toBeDefined();
|
|
119
|
+
expect((getServerHealthEndpoint as any)?.tasks?.length).toBe(1);
|
|
120
|
+
});
|
|
121
|
+
|
|
122
|
+
it('| should setup getServerStatusForClient endpoint', () => {
|
|
123
|
+
controller.setupEndpoints();
|
|
124
|
+
|
|
125
|
+
const getServerStatusForClientEndpoint = controller.endpoints.find(ep => ep.name === 'getServerStatusForClient');
|
|
126
|
+
expect(getServerStatusForClientEndpoint).toBeDefined();
|
|
127
|
+
expect(getServerStatusForClientEndpoint?.type).toBe(DyFM_HttpCallType.get);
|
|
128
|
+
expect(getServerStatusForClientEndpoint?.endpoint).toBe('/status/:version');
|
|
129
|
+
expect((getServerStatusForClientEndpoint as any)?.tasks).toBeDefined();
|
|
130
|
+
expect((getServerStatusForClientEndpoint as any)?.tasks?.length).toBe(1);
|
|
131
|
+
});
|
|
132
|
+
|
|
133
|
+
it('| should setup getErrorStatistics endpoint', () => {
|
|
134
|
+
controller.setupEndpoints();
|
|
135
|
+
|
|
136
|
+
const getErrorStatisticsEndpoint = controller.endpoints.find(ep => ep.name === 'getErrorStatistics');
|
|
137
|
+
expect(getErrorStatisticsEndpoint).toBeDefined();
|
|
138
|
+
expect(getErrorStatisticsEndpoint?.type).toBe(DyFM_HttpCallType.get);
|
|
139
|
+
expect(getErrorStatisticsEndpoint?.endpoint).toBe('/statistics/error/:range');
|
|
140
|
+
expect((getErrorStatisticsEndpoint as any)?.tasks).toBeDefined();
|
|
141
|
+
expect((getErrorStatisticsEndpoint as any)?.tasks?.length).toBe(1);
|
|
142
|
+
});
|
|
143
|
+
|
|
144
|
+
it('| should include additionalEndpoints', () => {
|
|
145
|
+
const additionalEndpoint = new DyNTS_Endpoint_Params({
|
|
146
|
+
name: 'customEndpoint',
|
|
147
|
+
type: DyFM_HttpCallType.get,
|
|
148
|
+
endpoint: '/status/custom',
|
|
149
|
+
tasks: [],
|
|
150
|
+
});
|
|
151
|
+
(controller as any).additionalEndpoints.push(additionalEndpoint);
|
|
152
|
+
|
|
153
|
+
controller.setupEndpoints();
|
|
154
|
+
|
|
155
|
+
const customEndpoint = controller.endpoints.find(ep => ep.name === 'customEndpoint');
|
|
156
|
+
expect(customEndpoint).toBeDefined();
|
|
157
|
+
});
|
|
158
|
+
|
|
159
|
+
it('| should throw error when additionalEndpoints is not defined', () => {
|
|
160
|
+
const controllerWithoutEndpoints = new (class extends TestServerStatusController {
|
|
161
|
+
protected override readonly additionalEndpoints: DyNTS_Endpoint_Params[] = undefined as any;
|
|
162
|
+
} as any)();
|
|
163
|
+
|
|
164
|
+
expect(() => {
|
|
165
|
+
controllerWithoutEndpoints.setupEndpoints();
|
|
166
|
+
}).toThrow();
|
|
167
|
+
});
|
|
168
|
+
});
|
|
169
|
+
|
|
170
|
+
describe('| opt-in admin auth retrofit', (): void => {
|
|
171
|
+
afterEach((): void => {
|
|
172
|
+
DyNTS_ServerStatus_Controller._resetAuthConfigForTesting();
|
|
173
|
+
});
|
|
174
|
+
|
|
175
|
+
const preCount = (controller: any, name: string): number => {
|
|
176
|
+
const ep: any = controller.endpoints.find((e: any) => e.name === name);
|
|
177
|
+
return (ep?.preProcesses ?? []).length;
|
|
178
|
+
};
|
|
179
|
+
|
|
180
|
+
it('| default: NO preProcesses on any endpoint (backwards compatible)', (): void => {
|
|
181
|
+
controller.setupEndpoints();
|
|
182
|
+
for (const ep of controller.endpoints) {
|
|
183
|
+
const pre: any = (ep as any).preProcesses;
|
|
184
|
+
expect(pre === undefined || pre.length === 0).toBe(true);
|
|
185
|
+
}
|
|
186
|
+
});
|
|
187
|
+
|
|
188
|
+
it('| configure({ authPreProcess }) → csak getErrorStatistics gated, a status-vegpontok NEM', (): void => {
|
|
189
|
+
const fakeAuth = async (): Promise<void> => { /* noop */ };
|
|
190
|
+
DyNTS_ServerStatus_Controller.configure({ authPreProcess: fakeAuth });
|
|
191
|
+
const c: any = new (TestServerStatusController as any)();
|
|
192
|
+
c.setupEndpoints();
|
|
193
|
+
|
|
194
|
+
// admin-adat → gated
|
|
195
|
+
expect(preCount(c, 'getErrorStatistics')).toBe(1);
|
|
196
|
+
// status-vegpontok (a kliens-indikator hivja, /health-tel adat-ekvivalens) → SOHA nem gated
|
|
197
|
+
expect(preCount(c, 'getServerStatus')).toBe(0);
|
|
198
|
+
expect(preCount(c, 'getServerHealth')).toBe(0);
|
|
199
|
+
expect(preCount(c, 'getServerReadiness')).toBe(0);
|
|
200
|
+
expect(preCount(c, 'getServerStatusForClient')).toBe(0);
|
|
201
|
+
});
|
|
202
|
+
|
|
203
|
+
it('| a status-vegpontokat (getServerStatus is) explicit protectedEndpoints-lista SEM gate-eli', (): void => {
|
|
204
|
+
const fakeAuth = async (): Promise<void> => { /* noop */ };
|
|
205
|
+
DyNTS_ServerStatus_Controller.configure({
|
|
206
|
+
authPreProcess: fakeAuth,
|
|
207
|
+
protectedEndpoints: [ 'getServerHealth', 'getServerReadiness', 'getServerStatusForClient', 'getServerStatus', 'getErrorStatistics' ],
|
|
208
|
+
});
|
|
209
|
+
const c: any = new (TestServerStatusController as any)();
|
|
210
|
+
c.setupEndpoints();
|
|
211
|
+
|
|
212
|
+
expect(preCount(c, 'getServerStatus')).toBe(0);
|
|
213
|
+
expect(preCount(c, 'getServerHealth')).toBe(0);
|
|
214
|
+
expect(preCount(c, 'getServerReadiness')).toBe(0);
|
|
215
|
+
expect(preCount(c, 'getServerStatusForClient')).toBe(0);
|
|
216
|
+
// a valodi admin-adat viszont gated
|
|
217
|
+
expect(preCount(c, 'getErrorStatistics')).toBe(1);
|
|
218
|
+
});
|
|
219
|
+
|
|
220
|
+
it('| protectedEndpoints subset → csak a megadott (nem-proba) neveken aktiv', (): void => {
|
|
221
|
+
const fakeAuth = async (): Promise<void> => { /* noop */ };
|
|
222
|
+
DyNTS_ServerStatus_Controller.configure({
|
|
223
|
+
authPreProcess: fakeAuth,
|
|
224
|
+
protectedEndpoints: [ 'getErrorStatistics' ],
|
|
225
|
+
});
|
|
226
|
+
const c: any = new (TestServerStatusController as any)();
|
|
227
|
+
c.setupEndpoints();
|
|
228
|
+
|
|
229
|
+
expect(preCount(c, 'getErrorStatistics')).toBe(1);
|
|
230
|
+
expect(preCount(c, 'getServerStatus')).toBe(0);
|
|
231
|
+
});
|
|
232
|
+
|
|
233
|
+
it('| getAuthConfig() returns the active config', (): void => {
|
|
234
|
+
const fakeAuth = async (): Promise<void> => { /* noop */ };
|
|
235
|
+
DyNTS_ServerStatus_Controller.configure({ authPreProcess: fakeAuth, protectedEndpoints: [ 'getErrorStatistics' ] });
|
|
236
|
+
const cfg = DyNTS_ServerStatus_Controller.getAuthConfig();
|
|
237
|
+
expect(cfg.authPreProcess).toBe(fakeAuth);
|
|
238
|
+
expect(cfg.protectedEndpoints).toEqual([ 'getErrorStatistics' ]);
|
|
239
|
+
});
|
|
240
|
+
|
|
241
|
+
it('| _resetAuthConfigForTesting() clears the config', (): void => {
|
|
242
|
+
DyNTS_ServerStatus_Controller.configure({ authPreProcess: async (): Promise<void> => { /* noop */ } });
|
|
243
|
+
DyNTS_ServerStatus_Controller._resetAuthConfigForTesting();
|
|
244
|
+
expect(DyNTS_ServerStatus_Controller.getAuthConfig().authPreProcess).toBeUndefined();
|
|
245
|
+
});
|
|
246
|
+
});
|
|
247
|
+
});
|
|
248
|
+
|