@futdevpro/nts-dynamo 1.15.89 → 1.15.90
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 +2816 -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/_modules/scheduler/_models/scheduler-job.interface.d.ts +34 -0
- package/build/_modules/scheduler/_models/scheduler-job.interface.d.ts.map +1 -0
- package/build/_modules/scheduler/_models/scheduler-job.interface.js +3 -0
- package/build/_modules/scheduler/_models/scheduler-job.interface.js.map +1 -0
- package/build/_modules/scheduler/get-scheduler-routing-module.util.d.ts +18 -0
- package/build/_modules/scheduler/get-scheduler-routing-module.util.d.ts.map +1 -0
- package/build/_modules/scheduler/get-scheduler-routing-module.util.js +31 -0
- package/build/_modules/scheduler/get-scheduler-routing-module.util.js.map +1 -0
- package/build/_modules/scheduler/index.d.ts +5 -0
- package/build/_modules/scheduler/index.d.ts.map +1 -0
- package/build/_modules/scheduler/index.js +10 -0
- package/build/_modules/scheduler/index.js.map +1 -0
- package/build/_modules/scheduler/scheduler.controller.d.ts +25 -0
- package/build/_modules/scheduler/scheduler.controller.d.ts.map +1 -0
- package/build/_modules/scheduler/scheduler.controller.js +54 -0
- package/build/_modules/scheduler/scheduler.controller.js.map +1 -0
- package/build/_modules/scheduler/scheduler.service.d.ts +54 -0
- package/build/_modules/scheduler/scheduler.service.d.ts.map +1 -0
- package/build/_modules/scheduler/scheduler.service.js +164 -0
- package/build/_modules/scheduler/scheduler.service.js.map +1 -0
- package/eslint.config.js +3 -3
- package/nodemon.json +24 -24
- package/package.json +10 -1
- 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 +244 -244
- 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/scheduler/_models/scheduler-job.interface.ts +35 -0
- package/src/_modules/scheduler/get-scheduler-routing-module.util.ts +33 -0
- package/src/_modules/scheduler/index.ts +8 -0
- package/src/_modules/scheduler/scheduler.controller.spec.ts +42 -0
- package/src/_modules/scheduler/scheduler.controller.ts +69 -0
- package/src/_modules/scheduler/scheduler.service.spec.ts +141 -0
- package/src/_modules/scheduler/scheduler.service.ts +176 -0
- 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 -268
- package/src/_modules/server/errors/errors.controller.ts +515 -515
- 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 -255
- package/src/_modules/server/server-status/server-status.controller.ts +272 -272
- 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 +1941 -1941
- 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
|
@@ -1,255 +1,255 @@
|
|
|
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
|
-
}
|
|
35
|
-
|
|
36
|
-
async resolveError(errorId: string, issuer: string, notes?: string): Promise<void> {
|
|
37
|
-
return;
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
async getErrorsByStatusPaged(status: string, range: any, pageSize: number, pageIndex: number, issuer: string): Promise<any> {
|
|
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
|
-
// FR-263 — a guard request-idoben fut (lazy wrapper). "Gated-e egy endpoint" = a wrapper
|
|
176
|
-
// meghivasa lefuttatja-e a configured authPreProcess-t. A counter-t a teszt-spy lepteti.
|
|
177
|
-
let guardCalls: number = 0;
|
|
178
|
-
const spyAuth = async (): Promise<void> => { guardCalls++; };
|
|
179
|
-
const runGuard = async (c: any, name: string): Promise<void> => {
|
|
180
|
-
const ep: any = c.endpoints.find((e: any) => e.name === name);
|
|
181
|
-
await ep?.preProcesses?.[0]?.({} as any, { headersSent: false } as any);
|
|
182
|
-
};
|
|
183
|
-
beforeEach((): void => { guardCalls = 0; });
|
|
184
|
-
|
|
185
|
-
it('| default (no config): a wrapper jelen van, de egy keres NEM hiv guardot (nyitva marad)', async (): Promise<void> => {
|
|
186
|
-
controller.setupEndpoints();
|
|
187
|
-
for (const ep of controller.endpoints) {
|
|
188
|
-
await (ep as any).preProcesses?.[0]?.({} as any, { headersSent: false } as any); // no-op, nem dob
|
|
189
|
-
}
|
|
190
|
-
expect(guardCalls).toBe(0);
|
|
191
|
-
});
|
|
192
|
-
|
|
193
|
-
it('| configure({ authPreProcess }) → CSAK getErrorStatistics-en fut a guard, a status-vegpontokon NEM', async (): Promise<void> => {
|
|
194
|
-
DyNTS_ServerStatus_Controller.configure({ authPreProcess: spyAuth });
|
|
195
|
-
const c: any = new (TestServerStatusController as any)();
|
|
196
|
-
c.setupEndpoints();
|
|
197
|
-
await runGuard(c, 'getErrorStatistics');
|
|
198
|
-
expect(guardCalls).withContext('admin-adat → gated').toBe(1);
|
|
199
|
-
guardCalls = 0;
|
|
200
|
-
for (const name of ['getServerStatus', 'getServerHealth', 'getServerReadiness', 'getServerStatusForClient']) {
|
|
201
|
-
await runGuard(c, name);
|
|
202
|
-
}
|
|
203
|
-
expect(guardCalls).withContext('status-probak SOHA nem gated').toBe(0);
|
|
204
|
-
});
|
|
205
|
-
|
|
206
|
-
it('| a status-vegpontokat explicit protectedEndpoints-lista SEM gate-eli (PUBLIC_PROBE kizart)', async (): Promise<void> => {
|
|
207
|
-
DyNTS_ServerStatus_Controller.configure({
|
|
208
|
-
authPreProcess: spyAuth,
|
|
209
|
-
protectedEndpoints: [ 'getServerHealth', 'getServerReadiness', 'getServerStatusForClient', 'getServerStatus', 'getErrorStatistics' ],
|
|
210
|
-
});
|
|
211
|
-
const c: any = new (TestServerStatusController as any)();
|
|
212
|
-
c.setupEndpoints();
|
|
213
|
-
for (const name of ['getServerStatus', 'getServerHealth', 'getServerReadiness', 'getServerStatusForClient']) {
|
|
214
|
-
await runGuard(c, name);
|
|
215
|
-
}
|
|
216
|
-
expect(guardCalls).withContext('status-probak kizartak meg explicit listan is').toBe(0);
|
|
217
|
-
await runGuard(c, 'getErrorStatistics');
|
|
218
|
-
expect(guardCalls).withContext('getErrorStatistics gated').toBe(1);
|
|
219
|
-
});
|
|
220
|
-
|
|
221
|
-
it('| protectedEndpoints subset → getErrorStatistics gated, getServerStatus NEM', async (): Promise<void> => {
|
|
222
|
-
DyNTS_ServerStatus_Controller.configure({ authPreProcess: spyAuth, protectedEndpoints: [ 'getErrorStatistics' ] });
|
|
223
|
-
const c: any = new (TestServerStatusController as any)();
|
|
224
|
-
c.setupEndpoints();
|
|
225
|
-
await runGuard(c, 'getErrorStatistics');
|
|
226
|
-
expect(guardCalls).toBe(1);
|
|
227
|
-
guardCalls = 0;
|
|
228
|
-
await runGuard(c, 'getServerStatus');
|
|
229
|
-
expect(guardCalls).toBe(0);
|
|
230
|
-
});
|
|
231
|
-
|
|
232
|
-
it('| FR-263 ORDER-INDEPENDENCE: setupEndpoints() ELOTT epitett endpoint is enforce-olja a guardot', async (): Promise<void> => {
|
|
233
|
-
const c: any = new (TestServerStatusController as any)();
|
|
234
|
-
c.setupEndpoints(); // config NELKUL (korai framework-konstrukcio szimulacioja)
|
|
235
|
-
DyNTS_ServerStatus_Controller.configure({ authPreProcess: spyAuth }); // configure UTANA
|
|
236
|
-
await runGuard(c, 'getErrorStatistics');
|
|
237
|
-
expect(guardCalls).withContext('guard runs despite configure() AFTER setupEndpoints').toBe(1);
|
|
238
|
-
});
|
|
239
|
-
|
|
240
|
-
it('| getAuthConfig() returns the active config', (): void => {
|
|
241
|
-
const fakeAuth = async (): Promise<void> => { /* noop */ };
|
|
242
|
-
DyNTS_ServerStatus_Controller.configure({ authPreProcess: fakeAuth, protectedEndpoints: [ 'getErrorStatistics' ] });
|
|
243
|
-
const cfg = DyNTS_ServerStatus_Controller.getAuthConfig();
|
|
244
|
-
expect(cfg.authPreProcess).toBe(fakeAuth);
|
|
245
|
-
expect(cfg.protectedEndpoints).toEqual([ 'getErrorStatistics' ]);
|
|
246
|
-
});
|
|
247
|
-
|
|
248
|
-
it('| _resetAuthConfigForTesting() clears the config', (): void => {
|
|
249
|
-
DyNTS_ServerStatus_Controller.configure({ authPreProcess: async (): Promise<void> => { /* noop */ } });
|
|
250
|
-
DyNTS_ServerStatus_Controller._resetAuthConfigForTesting();
|
|
251
|
-
expect(DyNTS_ServerStatus_Controller.getAuthConfig().authPreProcess).toBeUndefined();
|
|
252
|
-
});
|
|
253
|
-
});
|
|
254
|
-
});
|
|
255
|
-
|
|
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
|
+
}
|
|
35
|
+
|
|
36
|
+
async resolveError(errorId: string, issuer: string, notes?: string): Promise<void> {
|
|
37
|
+
return;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
async getErrorsByStatusPaged(status: string, range: any, pageSize: number, pageIndex: number, issuer: string): Promise<any> {
|
|
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
|
+
// FR-263 — a guard request-idoben fut (lazy wrapper). "Gated-e egy endpoint" = a wrapper
|
|
176
|
+
// meghivasa lefuttatja-e a configured authPreProcess-t. A counter-t a teszt-spy lepteti.
|
|
177
|
+
let guardCalls: number = 0;
|
|
178
|
+
const spyAuth = async (): Promise<void> => { guardCalls++; };
|
|
179
|
+
const runGuard = async (c: any, name: string): Promise<void> => {
|
|
180
|
+
const ep: any = c.endpoints.find((e: any) => e.name === name);
|
|
181
|
+
await ep?.preProcesses?.[0]?.({} as any, { headersSent: false } as any);
|
|
182
|
+
};
|
|
183
|
+
beforeEach((): void => { guardCalls = 0; });
|
|
184
|
+
|
|
185
|
+
it('| default (no config): a wrapper jelen van, de egy keres NEM hiv guardot (nyitva marad)', async (): Promise<void> => {
|
|
186
|
+
controller.setupEndpoints();
|
|
187
|
+
for (const ep of controller.endpoints) {
|
|
188
|
+
await (ep as any).preProcesses?.[0]?.({} as any, { headersSent: false } as any); // no-op, nem dob
|
|
189
|
+
}
|
|
190
|
+
expect(guardCalls).toBe(0);
|
|
191
|
+
});
|
|
192
|
+
|
|
193
|
+
it('| configure({ authPreProcess }) → CSAK getErrorStatistics-en fut a guard, a status-vegpontokon NEM', async (): Promise<void> => {
|
|
194
|
+
DyNTS_ServerStatus_Controller.configure({ authPreProcess: spyAuth });
|
|
195
|
+
const c: any = new (TestServerStatusController as any)();
|
|
196
|
+
c.setupEndpoints();
|
|
197
|
+
await runGuard(c, 'getErrorStatistics');
|
|
198
|
+
expect(guardCalls).withContext('admin-adat → gated').toBe(1);
|
|
199
|
+
guardCalls = 0;
|
|
200
|
+
for (const name of ['getServerStatus', 'getServerHealth', 'getServerReadiness', 'getServerStatusForClient']) {
|
|
201
|
+
await runGuard(c, name);
|
|
202
|
+
}
|
|
203
|
+
expect(guardCalls).withContext('status-probak SOHA nem gated').toBe(0);
|
|
204
|
+
});
|
|
205
|
+
|
|
206
|
+
it('| a status-vegpontokat explicit protectedEndpoints-lista SEM gate-eli (PUBLIC_PROBE kizart)', async (): Promise<void> => {
|
|
207
|
+
DyNTS_ServerStatus_Controller.configure({
|
|
208
|
+
authPreProcess: spyAuth,
|
|
209
|
+
protectedEndpoints: [ 'getServerHealth', 'getServerReadiness', 'getServerStatusForClient', 'getServerStatus', 'getErrorStatistics' ],
|
|
210
|
+
});
|
|
211
|
+
const c: any = new (TestServerStatusController as any)();
|
|
212
|
+
c.setupEndpoints();
|
|
213
|
+
for (const name of ['getServerStatus', 'getServerHealth', 'getServerReadiness', 'getServerStatusForClient']) {
|
|
214
|
+
await runGuard(c, name);
|
|
215
|
+
}
|
|
216
|
+
expect(guardCalls).withContext('status-probak kizartak meg explicit listan is').toBe(0);
|
|
217
|
+
await runGuard(c, 'getErrorStatistics');
|
|
218
|
+
expect(guardCalls).withContext('getErrorStatistics gated').toBe(1);
|
|
219
|
+
});
|
|
220
|
+
|
|
221
|
+
it('| protectedEndpoints subset → getErrorStatistics gated, getServerStatus NEM', async (): Promise<void> => {
|
|
222
|
+
DyNTS_ServerStatus_Controller.configure({ authPreProcess: spyAuth, protectedEndpoints: [ 'getErrorStatistics' ] });
|
|
223
|
+
const c: any = new (TestServerStatusController as any)();
|
|
224
|
+
c.setupEndpoints();
|
|
225
|
+
await runGuard(c, 'getErrorStatistics');
|
|
226
|
+
expect(guardCalls).toBe(1);
|
|
227
|
+
guardCalls = 0;
|
|
228
|
+
await runGuard(c, 'getServerStatus');
|
|
229
|
+
expect(guardCalls).toBe(0);
|
|
230
|
+
});
|
|
231
|
+
|
|
232
|
+
it('| FR-263 ORDER-INDEPENDENCE: setupEndpoints() ELOTT epitett endpoint is enforce-olja a guardot', async (): Promise<void> => {
|
|
233
|
+
const c: any = new (TestServerStatusController as any)();
|
|
234
|
+
c.setupEndpoints(); // config NELKUL (korai framework-konstrukcio szimulacioja)
|
|
235
|
+
DyNTS_ServerStatus_Controller.configure({ authPreProcess: spyAuth }); // configure UTANA
|
|
236
|
+
await runGuard(c, 'getErrorStatistics');
|
|
237
|
+
expect(guardCalls).withContext('guard runs despite configure() AFTER setupEndpoints').toBe(1);
|
|
238
|
+
});
|
|
239
|
+
|
|
240
|
+
it('| getAuthConfig() returns the active config', (): void => {
|
|
241
|
+
const fakeAuth = async (): Promise<void> => { /* noop */ };
|
|
242
|
+
DyNTS_ServerStatus_Controller.configure({ authPreProcess: fakeAuth, protectedEndpoints: [ 'getErrorStatistics' ] });
|
|
243
|
+
const cfg = DyNTS_ServerStatus_Controller.getAuthConfig();
|
|
244
|
+
expect(cfg.authPreProcess).toBe(fakeAuth);
|
|
245
|
+
expect(cfg.protectedEndpoints).toEqual([ 'getErrorStatistics' ]);
|
|
246
|
+
});
|
|
247
|
+
|
|
248
|
+
it('| _resetAuthConfigForTesting() clears the config', (): void => {
|
|
249
|
+
DyNTS_ServerStatus_Controller.configure({ authPreProcess: async (): Promise<void> => { /* noop */ } });
|
|
250
|
+
DyNTS_ServerStatus_Controller._resetAuthConfigForTesting();
|
|
251
|
+
expect(DyNTS_ServerStatus_Controller.getAuthConfig().authPreProcess).toBeUndefined();
|
|
252
|
+
});
|
|
253
|
+
});
|
|
254
|
+
});
|
|
255
|
+
|