@futdevpro/nts-dynamo 1.15.37 → 1.15.39
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/.github/workflows/main.yml +432 -432
- package/.vscode/settings.json +10 -10
- package/HOWTO.md +15 -15
- package/LICENSE +21 -21
- package/__documentations/2026-06-01-fr041-cors-middleware.md +96 -0
- package/__documentations/nts-integration-tests-2026-03-17.md +26 -26
- package/_specifications/BACKLOG.md +92 -92
- package/_specifications/TODO.md +15 -15
- package/_specifications/agent.md +138 -138
- package/build/_modules/server/errors/errors.control-service.d.ts +3 -1
- package/build/_modules/server/errors/errors.control-service.d.ts.map +1 -1
- package/build/_modules/server/errors/errors.control-service.js.map +1 -1
- package/build/_modules/server/errors/errors.controller.d.ts.map +1 -1
- package/build/_modules/server/errors/errors.controller.js +45 -1
- package/build/_modules/server/errors/errors.controller.js.map +1 -1
- package/build/_modules/server/errors/errors.data-service.d.ts +27 -1
- package/build/_modules/server/errors/errors.data-service.d.ts.map +1 -1
- package/build/_modules/server/errors/errors.data-service.js +124 -0
- package/build/_modules/server/errors/errors.data-service.js.map +1 -1
- package/eslint.config.js +3 -3
- package/nodemon.json +24 -24
- package/package.json +2 -2
- package/pnpm-workspace.yaml +8 -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/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 +578 -578
- package/src/_models/control-models/endpoint-params.control-model.ts +526 -526
- 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 +144 -144
- package/src/_models/interfaces/global-service-settings.interface.ts +47 -47
- 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-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-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 +28 -28
- 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 +106 -106
- package/src/_modules/ai/_modules/open-ai/_services/oai-llm.service-base.ts +1011 -1011
- package/src/_modules/ai/_modules/open-ai/_services/oai-user-key.control-service.ts +157 -157
- 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 +510 -510
- 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/index.ts +13 -13
- 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/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/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-vector-pool.control-service.spec.ts +393 -393
- package/src/_modules/local-vector-search/_services/lvs-vector-pool.control-service.ts +220 -220
- package/src/_modules/local-vector-search/index.ts +11 -11
- 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/server/errors/errors.control-service.spec.ts +238 -230
- package/src/_modules/server/errors/errors.control-service.ts +85 -69
- package/src/_modules/server/errors/errors.controller.spec.ts +241 -235
- package/src/_modules/server/errors/errors.controller.ts +431 -372
- package/src/_modules/server/errors/errors.data-service.spec.ts +355 -355
- package/src/_modules/server/errors/errors.data-service.ts +157 -7
- 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 +524 -516
- package/src/_modules/server/server-status/server-status.control-service.ts +336 -336
- package/src/_modules/server/server-status/server-status.controller.spec.ts +162 -156
- package/src/_modules/server/server-status/server-status.controller.ts +131 -131
- 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 +275 -275
- package/src/_services/core/global.service.ts +461 -461
- 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/shared.static-service.spec.ts +99 -99
- package/src/_services/shared.static-service.ts +78 -78
- package/src/index.ts +95 -95
- package/tsconfig.app.json +12 -12
- package/tsconfig.json +42 -42
- package/.dynamo/logs/cicd-pipeline/output.log +0 -2630
- package/.dynamo/logs/cicd-pipeline/status.json +0 -321
|
@@ -12,7 +12,8 @@ import {
|
|
|
12
12
|
DyFM_Paged,
|
|
13
13
|
DyFM_Time,
|
|
14
14
|
DyFM_SearchQuery,
|
|
15
|
-
DyFM_SearchResult
|
|
15
|
+
DyFM_SearchResult,
|
|
16
|
+
DyFM_Errors_FixAttempt
|
|
16
17
|
} from '@futdevpro/fsm-dynamo';
|
|
17
18
|
|
|
18
19
|
import { DyNTS_Errors_ControlService } from './errors.control-service';
|
|
@@ -142,6 +143,20 @@ export class DyNTS_Errors_DataService<
|
|
|
142
143
|
};
|
|
143
144
|
}
|
|
144
145
|
|
|
146
|
+
// Regression detect — a duplicate-ag-on egy NEW occurrence érkezett.
|
|
147
|
+
// Ha mar volt fix-attempt erre az error-ra, es a jelenlegi version
|
|
148
|
+
// ujabb vagy egyenlo mint a fix-attempt verzioja, akkor a hipotezis
|
|
149
|
+
// nem zarta le a problemat → flag-eljuk a dashboardnak.
|
|
150
|
+
if (
|
|
151
|
+
duplicateError.lastFixedInVersion &&
|
|
152
|
+
DyNTS_Errors_DataService.isVersionAtLeast(errorVersion, duplicateError.lastFixedInVersion)
|
|
153
|
+
) {
|
|
154
|
+
(duplicateRecordUpdate as any).$set = {
|
|
155
|
+
...((duplicateRecordUpdate as any).$set ?? {}),
|
|
156
|
+
regressedAfterFix: true,
|
|
157
|
+
};
|
|
158
|
+
}
|
|
159
|
+
|
|
145
160
|
await this.updateData({
|
|
146
161
|
filterBy: { _id: duplicateError._id } as DyFM_DBFilter<T_ErrorsRecord>,
|
|
147
162
|
update: duplicateRecordUpdate,
|
|
@@ -374,7 +389,7 @@ export class DyNTS_Errors_DataService<
|
|
|
374
389
|
|
|
375
390
|
getPriorityMultiplierByLevel(level: DyFM_ErrorLevel): number {
|
|
376
391
|
switch (level) {
|
|
377
|
-
case DyFM_ErrorLevel.critical:
|
|
392
|
+
case DyFM_ErrorLevel.critical:
|
|
378
393
|
case DyFM_ErrorLevel.fatal:
|
|
379
394
|
return 1000;
|
|
380
395
|
|
|
@@ -382,16 +397,22 @@ export class DyNTS_Errors_DataService<
|
|
|
382
397
|
case DyFM_ErrorLevel.serious:
|
|
383
398
|
return 100;
|
|
384
399
|
|
|
385
|
-
case DyFM_ErrorLevel.
|
|
400
|
+
case DyFM_ErrorLevel.buildFailure:
|
|
401
|
+
return 50;
|
|
402
|
+
|
|
403
|
+
case DyFM_ErrorLevel.systemUnreachable:
|
|
404
|
+
return 20;
|
|
405
|
+
|
|
406
|
+
case DyFM_ErrorLevel.warning:
|
|
386
407
|
return 10;
|
|
387
408
|
|
|
388
|
-
case DyFM_ErrorLevel.info:
|
|
409
|
+
case DyFM_ErrorLevel.info:
|
|
389
410
|
case DyFM_ErrorLevel.debug:
|
|
390
411
|
case DyFM_ErrorLevel.known:
|
|
391
412
|
return 0.01;
|
|
392
413
|
|
|
393
|
-
case DyFM_ErrorLevel.user:
|
|
394
|
-
default:
|
|
414
|
+
case DyFM_ErrorLevel.user:
|
|
415
|
+
default:
|
|
395
416
|
return 0;
|
|
396
417
|
}
|
|
397
418
|
}
|
|
@@ -452,6 +473,99 @@ export class DyNTS_Errors_DataService<
|
|
|
452
473
|
}
|
|
453
474
|
}
|
|
454
475
|
|
|
476
|
+
/**
|
|
477
|
+
* Record a "we think this is fixed" claim on an existing error.
|
|
478
|
+
*
|
|
479
|
+
* Append-only: every call pushes a new `DyFM_Errors_FixAttempt` to
|
|
480
|
+
* `fixAttempts[]` and updates the `last*` aliases for quick reads.
|
|
481
|
+
* Also clears `regressedAfterFix` so the dashboard treats the error as
|
|
482
|
+
* freshly-claimed-fixed; if a new occurrence arrives with a version
|
|
483
|
+
* `>= version`, `recordError` will flip the flag back on.
|
|
484
|
+
*/
|
|
485
|
+
async recordFixAttempt(
|
|
486
|
+
errorId: string,
|
|
487
|
+
version: string,
|
|
488
|
+
hypothesis: string,
|
|
489
|
+
issuer: string
|
|
490
|
+
): Promise<DyFM_Errors_FixAttempt> {
|
|
491
|
+
try {
|
|
492
|
+
if (issuer && !this.issuer) {
|
|
493
|
+
this.issuer = issuer;
|
|
494
|
+
}
|
|
495
|
+
|
|
496
|
+
const existing = await this.findData({ _id: errorId } as DyFM_DBFilter<T_ErrorsRecord>);
|
|
497
|
+
if (!existing) {
|
|
498
|
+
throw new DyFM_Error({
|
|
499
|
+
...this.getDefaultErrorSettings('recordFixAttempt', new Error(`error not found: ${errorId}`)),
|
|
500
|
+
errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-EDS-RFA0`,
|
|
501
|
+
});
|
|
502
|
+
}
|
|
503
|
+
|
|
504
|
+
const attempt: DyFM_Errors_FixAttempt = {
|
|
505
|
+
at: new Date(),
|
|
506
|
+
by: issuer,
|
|
507
|
+
version: version,
|
|
508
|
+
hypothesis: hypothesis,
|
|
509
|
+
};
|
|
510
|
+
|
|
511
|
+
const nextAttempts: DyFM_Errors_FixAttempt[] = [
|
|
512
|
+
...((existing as any).fixAttempts ?? []),
|
|
513
|
+
attempt,
|
|
514
|
+
];
|
|
515
|
+
|
|
516
|
+
await this.updateData({
|
|
517
|
+
filterBy: { _id: errorId } as DyFM_DBFilter<T_ErrorsRecord>,
|
|
518
|
+
update: {
|
|
519
|
+
$set: {
|
|
520
|
+
fixAttempts: nextAttempts,
|
|
521
|
+
lastFixedAt: attempt.at,
|
|
522
|
+
lastFixedBy: attempt.by,
|
|
523
|
+
lastFixedInVersion: attempt.version,
|
|
524
|
+
lastFixHypothesis: attempt.hypothesis,
|
|
525
|
+
regressedAfterFix: false,
|
|
526
|
+
},
|
|
527
|
+
} as DyNTS_DBUpdate<T_ErrorsRecord>,
|
|
528
|
+
});
|
|
529
|
+
|
|
530
|
+
return attempt;
|
|
531
|
+
} catch (error) {
|
|
532
|
+
throw new DyFM_Error({
|
|
533
|
+
...this.getDefaultErrorSettings('recordFixAttempt', error),
|
|
534
|
+
errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-EDS-RFA1`,
|
|
535
|
+
});
|
|
536
|
+
}
|
|
537
|
+
}
|
|
538
|
+
|
|
539
|
+
/**
|
|
540
|
+
* Loose numeric compare of two version strings of shape `MAJOR.MINOR.PATCH`
|
|
541
|
+
* (`01.15.117`). Pads missing segments with 0. Non-numeric segments are
|
|
542
|
+
* treated as 0 — version strings carrying prefixes like `SERVER-` from
|
|
543
|
+
* `recordError` are caller-stripped before this is invoked.
|
|
544
|
+
*
|
|
545
|
+
* Returns true when `a >= b`.
|
|
546
|
+
*/
|
|
547
|
+
static isVersionAtLeast(a: string, b: string): boolean {
|
|
548
|
+
if (!a || !b) {
|
|
549
|
+
return false;
|
|
550
|
+
}
|
|
551
|
+
const strip = (v: string): string => v.replace(/^[^0-9]+/, '');
|
|
552
|
+
const parse = (v: string): number[] => strip(v).split('.').map(s => Number(s) || 0);
|
|
553
|
+
const aParts = parse(a);
|
|
554
|
+
const bParts = parse(b);
|
|
555
|
+
const len = Math.max(aParts.length, bParts.length);
|
|
556
|
+
for (let i = 0; i < len; i++) {
|
|
557
|
+
const av = aParts[i] ?? 0;
|
|
558
|
+
const bv = bParts[i] ?? 0;
|
|
559
|
+
if (av > bv) {
|
|
560
|
+
return true;
|
|
561
|
+
}
|
|
562
|
+
if (av < bv) {
|
|
563
|
+
return false;
|
|
564
|
+
}
|
|
565
|
+
}
|
|
566
|
+
return true;
|
|
567
|
+
}
|
|
568
|
+
|
|
455
569
|
async getErrorsInRange(range: DyFM_RelativeDate, issuer: string): Promise<DyFM_Paged<T_ErrorsRecord>> {
|
|
456
570
|
try {
|
|
457
571
|
if (issuer && !this.issuer) {
|
|
@@ -488,7 +602,7 @@ export class DyNTS_Errors_DataService<
|
|
|
488
602
|
|
|
489
603
|
const fromDate: Date = DyFM_Time.getDateByRelativeDate(range);
|
|
490
604
|
|
|
491
|
-
let errors: T_ErrorsRecord[] = await this.findDataList({ __lastModified: { $gte: fromDate } });
|
|
605
|
+
let errors: T_ErrorsRecord[] = await this.findDataList({ __lastModified: { $gte: fromDate } });
|
|
492
606
|
errors = errors.sort(
|
|
493
607
|
(a, b): number => b.priority - a.priority
|
|
494
608
|
);
|
|
@@ -503,6 +617,42 @@ export class DyNTS_Errors_DataService<
|
|
|
503
617
|
}
|
|
504
618
|
}
|
|
505
619
|
|
|
620
|
+
/**
|
|
621
|
+
* Paged-eredmenyek a `category` mezo szerint. A frontend "Errors" page tab-jai
|
|
622
|
+
* (Application / System Unreachable / Build Failure) ezt hivjak. Egy ures-
|
|
623
|
+
* vagy `'all'` kategoria mindent visszaad (azonos szemantikaval mint a
|
|
624
|
+
* `getErrorsPaged`-tel).
|
|
625
|
+
*/
|
|
626
|
+
async getErrorsByCategoryPaged(
|
|
627
|
+
category: string,
|
|
628
|
+
range: DyFM_RelativeDate,
|
|
629
|
+
pageSize: number,
|
|
630
|
+
pageIndex: number,
|
|
631
|
+
issuer: string,
|
|
632
|
+
): Promise<DyFM_Paged<T_ErrorsRecord>> {
|
|
633
|
+
try {
|
|
634
|
+
if (issuer && !this.issuer) {
|
|
635
|
+
this.issuer = issuer;
|
|
636
|
+
}
|
|
637
|
+
|
|
638
|
+
const fromDate: Date = DyFM_Time.getDateByRelativeDate(range);
|
|
639
|
+
const filter: any = { __lastModified: { $gte: fromDate } };
|
|
640
|
+
if (category && category !== 'all') {
|
|
641
|
+
filter.category = category;
|
|
642
|
+
}
|
|
643
|
+
|
|
644
|
+
let errors: T_ErrorsRecord[] = await this.findDataList(filter);
|
|
645
|
+
errors = errors.sort((a, b): number => b.priority - a.priority);
|
|
646
|
+
|
|
647
|
+
return DyFM_Array.paged(errors, pageIndex, pageSize);
|
|
648
|
+
} catch (error) {
|
|
649
|
+
throw new DyFM_Error({
|
|
650
|
+
...this.getDefaultErrorSettings('getErrorsByCategoryPaged', error),
|
|
651
|
+
errorCode: `${DyNTS_global_settings.systemShortCodeName}|DyNTS-EDS-GBCP0`,
|
|
652
|
+
});
|
|
653
|
+
}
|
|
654
|
+
}
|
|
655
|
+
|
|
506
656
|
async getLastErrors(
|
|
507
657
|
range: DyFM_RelativeDate,
|
|
508
658
|
pageSize: number,
|
|
@@ -1,30 +1,30 @@
|
|
|
1
|
-
|
|
2
|
-
//
|
|
3
|
-
// Server module
|
|
4
|
-
//
|
|
5
|
-
// This module contains solutions for basic server endpoints such as:
|
|
6
|
-
//
|
|
7
|
-
// - Errors;
|
|
8
|
-
// saving and retrieving errors that are occuring on the server
|
|
9
|
-
//
|
|
10
|
-
// - Server Status;
|
|
11
|
-
// retrieving the status of the server
|
|
12
|
-
//
|
|
13
|
-
// - Server Status Snapshot;
|
|
14
|
-
// saving and retrieving the status of the server at a specific time
|
|
15
|
-
//
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
// ERRORS
|
|
19
|
-
export * from './errors/errors.controller';
|
|
20
|
-
export * from './errors/errors.control-service';
|
|
21
|
-
export * from './errors/errors.data-service';
|
|
22
|
-
|
|
23
|
-
// SERVER-STATUS
|
|
24
|
-
export * from './server-status/server-status-snapshot.data-service';
|
|
25
|
-
export * from './server-status/server-status-snapshot.control-service';
|
|
26
|
-
export * from './server-status/server-status.control-service';
|
|
27
|
-
export * from './server-status/server-status.controller';
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
1
|
+
|
|
2
|
+
//
|
|
3
|
+
// Server module
|
|
4
|
+
//
|
|
5
|
+
// This module contains solutions for basic server endpoints such as:
|
|
6
|
+
//
|
|
7
|
+
// - Errors;
|
|
8
|
+
// saving and retrieving errors that are occuring on the server
|
|
9
|
+
//
|
|
10
|
+
// - Server Status;
|
|
11
|
+
// retrieving the status of the server
|
|
12
|
+
//
|
|
13
|
+
// - Server Status Snapshot;
|
|
14
|
+
// saving and retrieving the status of the server at a specific time
|
|
15
|
+
//
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
// ERRORS
|
|
19
|
+
export * from './errors/errors.controller';
|
|
20
|
+
export * from './errors/errors.control-service';
|
|
21
|
+
export * from './errors/errors.data-service';
|
|
22
|
+
|
|
23
|
+
// SERVER-STATUS
|
|
24
|
+
export * from './server-status/server-status-snapshot.data-service';
|
|
25
|
+
export * from './server-status/server-status-snapshot.control-service';
|
|
26
|
+
export * from './server-status/server-status.control-service';
|
|
27
|
+
export * from './server-status/server-status.controller';
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
|
|
@@ -1,70 +1,70 @@
|
|
|
1
|
-
|
|
2
|
-
import { DyNTS_ServerStatusSnapshot_ControlService } from './server-status-snapshot.control-service';
|
|
3
|
-
import { DyFM_ServerStatus } from '@futdevpro/fsm-dynamo';
|
|
4
|
-
|
|
5
|
-
class TestServerStatus extends DyFM_ServerStatus {
|
|
6
|
-
constructor(set?: Partial<TestServerStatus>) {
|
|
7
|
-
super();
|
|
8
|
-
Object.assign(this, set);
|
|
9
|
-
}
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
class TestServerStatusSnapshotControlService extends DyNTS_ServerStatusSnapshot_ControlService<TestServerStatus> {
|
|
13
|
-
async saveSnapshot(snapshot: TestServerStatus, issuer: string): Promise<TestServerStatus> {
|
|
14
|
-
return snapshot;
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
static getInstance(): TestServerStatusSnapshotControlService {
|
|
18
|
-
return (TestServerStatusSnapshotControlService as any).getSingletonInstance();
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
describe('| DyNTS_ServerStatusSnapshot_ControlService', () => {
|
|
23
|
-
let service: TestServerStatusSnapshotControlService;
|
|
24
|
-
|
|
25
|
-
beforeEach(() => {
|
|
26
|
-
service = new TestServerStatusSnapshotControlService();
|
|
27
|
-
});
|
|
28
|
-
|
|
29
|
-
describe('| constructor', () => {
|
|
30
|
-
it('| should create instance', () => {
|
|
31
|
-
expect(service).toBeDefined();
|
|
32
|
-
expect(service).toBeInstanceOf(TestServerStatusSnapshotControlService);
|
|
33
|
-
});
|
|
34
|
-
});
|
|
35
|
-
|
|
36
|
-
describe('| saveSnapshot', () => {
|
|
37
|
-
it('| should save snapshot', async () => {
|
|
38
|
-
const snapshot: TestServerStatus = new TestServerStatus({
|
|
39
|
-
status: 'ready',
|
|
40
|
-
systemName: 'Test System',
|
|
41
|
-
});
|
|
42
|
-
|
|
43
|
-
const result = await service.saveSnapshot(snapshot, 'test-issuer');
|
|
44
|
-
|
|
45
|
-
expect(result).toBeDefined();
|
|
46
|
-
expect(result.status).toBe('ready');
|
|
47
|
-
expect(result.systemName).toBe('Test System');
|
|
48
|
-
});
|
|
49
|
-
|
|
50
|
-
it('| should handle snapshot with all properties', async () => {
|
|
51
|
-
const snapshot: TestServerStatus = new TestServerStatus({
|
|
52
|
-
status: 'ready',
|
|
53
|
-
systemName: 'Test System',
|
|
54
|
-
systemShortCode: 'TEST',
|
|
55
|
-
uptime: 1000,
|
|
56
|
-
memoryUsage: process.memoryUsage(),
|
|
57
|
-
cpuUsage: process.cpuUsage(),
|
|
58
|
-
});
|
|
59
|
-
|
|
60
|
-
const result = await service.saveSnapshot(snapshot, 'test-issuer');
|
|
61
|
-
|
|
62
|
-
expect(result).toBeDefined();
|
|
63
|
-
expect(result.status).toBe('ready');
|
|
64
|
-
expect(result.systemName).toBe('Test System');
|
|
65
|
-
expect(result.systemShortCode).toBe('TEST');
|
|
66
|
-
expect(result.uptime).toBe(1000);
|
|
67
|
-
});
|
|
68
|
-
});
|
|
69
|
-
});
|
|
70
|
-
|
|
1
|
+
|
|
2
|
+
import { DyNTS_ServerStatusSnapshot_ControlService } from './server-status-snapshot.control-service';
|
|
3
|
+
import { DyFM_ServerStatus } from '@futdevpro/fsm-dynamo';
|
|
4
|
+
|
|
5
|
+
class TestServerStatus extends DyFM_ServerStatus {
|
|
6
|
+
constructor(set?: Partial<TestServerStatus>) {
|
|
7
|
+
super();
|
|
8
|
+
Object.assign(this, set);
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
class TestServerStatusSnapshotControlService extends DyNTS_ServerStatusSnapshot_ControlService<TestServerStatus> {
|
|
13
|
+
async saveSnapshot(snapshot: TestServerStatus, issuer: string): Promise<TestServerStatus> {
|
|
14
|
+
return snapshot;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
static getInstance(): TestServerStatusSnapshotControlService {
|
|
18
|
+
return (TestServerStatusSnapshotControlService as any).getSingletonInstance();
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
describe('| DyNTS_ServerStatusSnapshot_ControlService', () => {
|
|
23
|
+
let service: TestServerStatusSnapshotControlService;
|
|
24
|
+
|
|
25
|
+
beforeEach(() => {
|
|
26
|
+
service = new TestServerStatusSnapshotControlService();
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
describe('| constructor', () => {
|
|
30
|
+
it('| should create instance', () => {
|
|
31
|
+
expect(service).toBeDefined();
|
|
32
|
+
expect(service).toBeInstanceOf(TestServerStatusSnapshotControlService);
|
|
33
|
+
});
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
describe('| saveSnapshot', () => {
|
|
37
|
+
it('| should save snapshot', async () => {
|
|
38
|
+
const snapshot: TestServerStatus = new TestServerStatus({
|
|
39
|
+
status: 'ready',
|
|
40
|
+
systemName: 'Test System',
|
|
41
|
+
});
|
|
42
|
+
|
|
43
|
+
const result = await service.saveSnapshot(snapshot, 'test-issuer');
|
|
44
|
+
|
|
45
|
+
expect(result).toBeDefined();
|
|
46
|
+
expect(result.status).toBe('ready');
|
|
47
|
+
expect(result.systemName).toBe('Test System');
|
|
48
|
+
});
|
|
49
|
+
|
|
50
|
+
it('| should handle snapshot with all properties', async () => {
|
|
51
|
+
const snapshot: TestServerStatus = new TestServerStatus({
|
|
52
|
+
status: 'ready',
|
|
53
|
+
systemName: 'Test System',
|
|
54
|
+
systemShortCode: 'TEST',
|
|
55
|
+
uptime: 1000,
|
|
56
|
+
memoryUsage: process.memoryUsage(),
|
|
57
|
+
cpuUsage: process.cpuUsage(),
|
|
58
|
+
});
|
|
59
|
+
|
|
60
|
+
const result = await service.saveSnapshot(snapshot, 'test-issuer');
|
|
61
|
+
|
|
62
|
+
expect(result).toBeDefined();
|
|
63
|
+
expect(result.status).toBe('ready');
|
|
64
|
+
expect(result.systemName).toBe('Test System');
|
|
65
|
+
expect(result.systemShortCode).toBe('TEST');
|
|
66
|
+
expect(result.uptime).toBe(1000);
|
|
67
|
+
});
|
|
68
|
+
});
|
|
69
|
+
});
|
|
70
|
+
|
|
@@ -1,17 +1,17 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
/* import { ServerStatus_ControlService } from './server-status.control-service'; */
|
|
6
|
-
|
|
7
|
-
import { DyFM_Error, DyFM_ServerStatus } from '@futdevpro/fsm-dynamo';
|
|
8
|
-
import { DyNTS_SingletonService } from '../../../_services/base/singleton.service';
|
|
9
|
-
|
|
10
|
-
export abstract class DyNTS_ServerStatusSnapshot_ControlService<
|
|
11
|
-
T_ServerStatusSnapshot extends DyFM_ServerStatus
|
|
12
|
-
> {
|
|
13
|
-
abstract saveSnapshot(
|
|
14
|
-
snapshot: T_ServerStatusSnapshot,
|
|
15
|
-
issuer: string
|
|
16
|
-
): Promise<T_ServerStatusSnapshot>;
|
|
17
|
-
}
|
|
1
|
+
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
|
|
5
|
+
/* import { ServerStatus_ControlService } from './server-status.control-service'; */
|
|
6
|
+
|
|
7
|
+
import { DyFM_Error, DyFM_ServerStatus } from '@futdevpro/fsm-dynamo';
|
|
8
|
+
import { DyNTS_SingletonService } from '../../../_services/base/singleton.service';
|
|
9
|
+
|
|
10
|
+
export abstract class DyNTS_ServerStatusSnapshot_ControlService<
|
|
11
|
+
T_ServerStatusSnapshot extends DyFM_ServerStatus
|
|
12
|
+
> {
|
|
13
|
+
abstract saveSnapshot(
|
|
14
|
+
snapshot: T_ServerStatusSnapshot,
|
|
15
|
+
issuer: string
|
|
16
|
+
): Promise<T_ServerStatusSnapshot>;
|
|
17
|
+
}
|
|
@@ -1,77 +1,77 @@
|
|
|
1
|
-
|
|
2
|
-
import { DyNTS_ServerStatusSnapshot_DataService } from './server-status-snapshot.data-service';
|
|
3
|
-
import { DyFM_ServerStatus, DyFM_DataModel_Params } from '@futdevpro/fsm-dynamo';
|
|
4
|
-
import { DyNTS_GlobalService } from '../../../_services/core/global.service';
|
|
5
|
-
import { DyNTS_DBService } from '../../../_services/base/db.service';
|
|
6
|
-
|
|
7
|
-
class TestServerStatus extends DyFM_ServerStatus {
|
|
8
|
-
testProperty?: string;
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
const testDataParams = new DyFM_DataModel_Params<TestServerStatus>({
|
|
12
|
-
dataName: 'test_server_status',
|
|
13
|
-
properties: {},
|
|
14
|
-
});
|
|
15
|
-
|
|
16
|
-
describe('| DyNTS_ServerStatusSnapshot_DataService', () => {
|
|
17
|
-
let service: DyNTS_ServerStatusSnapshot_DataService<TestServerStatus>;
|
|
18
|
-
let mockDBService: jasmine.SpyObj<DyNTS_DBService<TestServerStatus>>;
|
|
19
|
-
|
|
20
|
-
beforeEach(() => {
|
|
21
|
-
mockDBService = jasmine.createSpyObj('DyNTS_DBService', [
|
|
22
|
-
'getAll',
|
|
23
|
-
'getDataById',
|
|
24
|
-
'createData',
|
|
25
|
-
'modifyData',
|
|
26
|
-
]);
|
|
27
|
-
|
|
28
|
-
spyOn(DyNTS_GlobalService, 'getDBService').and.returnValue(mockDBService);
|
|
29
|
-
|
|
30
|
-
const testData = new TestServerStatus({
|
|
31
|
-
status: 'ready',
|
|
32
|
-
systemName: 'test-system',
|
|
33
|
-
});
|
|
34
|
-
|
|
35
|
-
service = new DyNTS_ServerStatusSnapshot_DataService<TestServerStatus>(
|
|
36
|
-
testData,
|
|
37
|
-
testDataParams,
|
|
38
|
-
'test-issuer'
|
|
39
|
-
);
|
|
40
|
-
});
|
|
41
|
-
|
|
42
|
-
it('| should create service instance', () => {
|
|
43
|
-
expect(service).toBeDefined();
|
|
44
|
-
expect(service.data).toBeDefined();
|
|
45
|
-
});
|
|
46
|
-
|
|
47
|
-
describe('| saveSnapshot', () => {
|
|
48
|
-
it('| should save snapshot', async () => {
|
|
49
|
-
const snapshot = new TestServerStatus({
|
|
50
|
-
status: 'ready',
|
|
51
|
-
systemName: 'test-system',
|
|
52
|
-
uptime: 1000,
|
|
53
|
-
});
|
|
54
|
-
const savedSnapshot = { ...snapshot, _id: 'snapshot-id' };
|
|
55
|
-
spyOn(service, 'saveData').and.returnValue(Promise.resolve(savedSnapshot));
|
|
56
|
-
|
|
57
|
-
const result = await service.saveSnapshot(snapshot, 'test-issuer');
|
|
58
|
-
|
|
59
|
-
expect(result).toBe(savedSnapshot);
|
|
60
|
-
expect(service.issuer).toBe('test-issuer');
|
|
61
|
-
expect(service.saveData).toHaveBeenCalledWith(snapshot);
|
|
62
|
-
});
|
|
63
|
-
|
|
64
|
-
it('| should throw error when save fails', async () => {
|
|
65
|
-
const snapshot = new TestServerStatus({
|
|
66
|
-
status: 'ready',
|
|
67
|
-
systemName: 'test-system',
|
|
68
|
-
});
|
|
69
|
-
spyOn(service, 'saveData').and.returnValue(Promise.reject(new Error('Save failed')));
|
|
70
|
-
|
|
71
|
-
await expectAsync(
|
|
72
|
-
service.saveSnapshot(snapshot, 'test-issuer')
|
|
73
|
-
).toBeRejected();
|
|
74
|
-
});
|
|
75
|
-
});
|
|
76
|
-
});
|
|
77
|
-
|
|
1
|
+
|
|
2
|
+
import { DyNTS_ServerStatusSnapshot_DataService } from './server-status-snapshot.data-service';
|
|
3
|
+
import { DyFM_ServerStatus, DyFM_DataModel_Params } from '@futdevpro/fsm-dynamo';
|
|
4
|
+
import { DyNTS_GlobalService } from '../../../_services/core/global.service';
|
|
5
|
+
import { DyNTS_DBService } from '../../../_services/base/db.service';
|
|
6
|
+
|
|
7
|
+
class TestServerStatus extends DyFM_ServerStatus {
|
|
8
|
+
testProperty?: string;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
const testDataParams = new DyFM_DataModel_Params<TestServerStatus>({
|
|
12
|
+
dataName: 'test_server_status',
|
|
13
|
+
properties: {},
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
describe('| DyNTS_ServerStatusSnapshot_DataService', () => {
|
|
17
|
+
let service: DyNTS_ServerStatusSnapshot_DataService<TestServerStatus>;
|
|
18
|
+
let mockDBService: jasmine.SpyObj<DyNTS_DBService<TestServerStatus>>;
|
|
19
|
+
|
|
20
|
+
beforeEach(() => {
|
|
21
|
+
mockDBService = jasmine.createSpyObj('DyNTS_DBService', [
|
|
22
|
+
'getAll',
|
|
23
|
+
'getDataById',
|
|
24
|
+
'createData',
|
|
25
|
+
'modifyData',
|
|
26
|
+
]);
|
|
27
|
+
|
|
28
|
+
spyOn(DyNTS_GlobalService, 'getDBService').and.returnValue(mockDBService);
|
|
29
|
+
|
|
30
|
+
const testData = new TestServerStatus({
|
|
31
|
+
status: 'ready',
|
|
32
|
+
systemName: 'test-system',
|
|
33
|
+
});
|
|
34
|
+
|
|
35
|
+
service = new DyNTS_ServerStatusSnapshot_DataService<TestServerStatus>(
|
|
36
|
+
testData,
|
|
37
|
+
testDataParams,
|
|
38
|
+
'test-issuer'
|
|
39
|
+
);
|
|
40
|
+
});
|
|
41
|
+
|
|
42
|
+
it('| should create service instance', () => {
|
|
43
|
+
expect(service).toBeDefined();
|
|
44
|
+
expect(service.data).toBeDefined();
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
describe('| saveSnapshot', () => {
|
|
48
|
+
it('| should save snapshot', async () => {
|
|
49
|
+
const snapshot = new TestServerStatus({
|
|
50
|
+
status: 'ready',
|
|
51
|
+
systemName: 'test-system',
|
|
52
|
+
uptime: 1000,
|
|
53
|
+
});
|
|
54
|
+
const savedSnapshot = { ...snapshot, _id: 'snapshot-id' };
|
|
55
|
+
spyOn(service, 'saveData').and.returnValue(Promise.resolve(savedSnapshot));
|
|
56
|
+
|
|
57
|
+
const result = await service.saveSnapshot(snapshot, 'test-issuer');
|
|
58
|
+
|
|
59
|
+
expect(result).toBe(savedSnapshot);
|
|
60
|
+
expect(service.issuer).toBe('test-issuer');
|
|
61
|
+
expect(service.saveData).toHaveBeenCalledWith(snapshot);
|
|
62
|
+
});
|
|
63
|
+
|
|
64
|
+
it('| should throw error when save fails', async () => {
|
|
65
|
+
const snapshot = new TestServerStatus({
|
|
66
|
+
status: 'ready',
|
|
67
|
+
systemName: 'test-system',
|
|
68
|
+
});
|
|
69
|
+
spyOn(service, 'saveData').and.returnValue(Promise.reject(new Error('Save failed')));
|
|
70
|
+
|
|
71
|
+
await expectAsync(
|
|
72
|
+
service.saveSnapshot(snapshot, 'test-issuer')
|
|
73
|
+
).toBeRejected();
|
|
74
|
+
});
|
|
75
|
+
});
|
|
76
|
+
});
|
|
77
|
+
|