@futdevpro/nts-dynamo 1.15.15 → 1.15.17
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/version-bump.config.json +5 -0
- package/.github/workflows/main.yml +426 -393
- package/.husky/pre-commit +1 -0
- package/.vscode/settings.json +10 -10
- package/HOWTO.md +15 -15
- package/LICENSE +21 -21
- package/__documentations/2026-04-28-logs-module.md +49 -0
- package/__documentations/nts-integration-tests-2026-03-17.md +26 -26
- package/_specifications/BACKLOG.md +50 -50
- package/_specifications/TODO.md +15 -15
- package/_specifications/agent.md +138 -138
- package/eslint.config.js +3 -3
- package/nodemon.json +24 -24
- package/package.json +343 -362
- package/pipeline.cicd.config.json +152 -0
- package/pnpm-workspace.yaml +2 -0
- 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 +108 -108
- 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 +240 -240
- package/src/_modules/ai/_modules/open-ai/_services/oai-embedding.control-service.ts +98 -98
- 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 +615 -615
- package/src/_modules/ai/_modules/open-ai/_services/oai-llm.service-base.spec.ts +437 -437
- package/src/_modules/ai/_modules/open-ai/_services/oai-llm.service-base.ts +833 -833
- 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 +332 -332
- package/src/_modules/ai/_services/ai-provider.service-base.spec.ts +79 -79
- package/src/_modules/ai/_services/ai-provider.service-base.ts +29 -29
- 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 +19 -19
- 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 +345 -345
- package/src/_modules/local-vector-search/_services/lvs-local-vector-search.data-service.ts +330 -330
- 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 +230 -230
- package/src/_modules/server/errors/errors.control-service.ts +69 -69
- package/src/_modules/server/errors/errors.controller.spec.ts +165 -165
- package/src/_modules/server/errors/errors.controller.ts +270 -270
- package/src/_modules/server/errors/errors.data-service.spec.ts +355 -355
- 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 +516 -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 +156 -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 +493 -493
- package/src/_services/base/data.service.ts +2525 -2525
- 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 +94 -94
- package/tsconfig.app.json +12 -12
- package/tsconfig.json +42 -42
- package/build/_modules/logs/get-logs-routing-module.util.d.ts +0 -19
- package/build/_modules/logs/get-logs-routing-module.util.d.ts.map +0 -1
- package/build/_modules/logs/get-logs-routing-module.util.js +0 -32
- package/build/_modules/logs/get-logs-routing-module.util.js.map +0 -1
- package/build/_modules/logs/index.d.ts +0 -4
- package/build/_modules/logs/index.d.ts.map +0 -1
- package/build/_modules/logs/index.js +0 -10
- package/build/_modules/logs/index.js.map +0 -1
- package/build/_modules/logs/log-buffer.service.d.ts +0 -38
- package/build/_modules/logs/log-buffer.service.d.ts.map +0 -1
- package/build/_modules/logs/log-buffer.service.js +0 -97
- package/build/_modules/logs/log-buffer.service.js.map +0 -1
- package/build/_modules/logs/logs.controller.d.ts +0 -27
- package/build/_modules/logs/logs.controller.d.ts.map +0 -1
- package/build/_modules/logs/logs.controller.js +0 -90
- package/build/_modules/logs/logs.controller.js.map +0 -1
- package/build/_modules/logs/logs.service.d.ts +0 -40
- package/build/_modules/logs/logs.service.d.ts.map +0 -1
- package/build/_modules/logs/logs.service.js +0 -97
- package/build/_modules/logs/logs.service.js.map +0 -1
- package/src/_modules/logs/get-logs-routing-module.util.ts +0 -36
- package/src/_modules/logs/index.ts +0 -3
- package/src/_modules/logs/log-buffer.service.ts +0 -101
- package/src/_modules/logs/logs.controller.ts +0 -109
- package/src/_modules/logs/logs.service.ts +0 -100
package/src/_modules/bot/_modules/teams-bot/_services/teb-messaging-provider.control-service.ts
CHANGED
|
@@ -1,197 +1,197 @@
|
|
|
1
|
-
import { DyFM_AnyError, DyFM_Error } from '@futdevpro/fsm-dynamo';
|
|
2
|
-
import { DyFM_Msg_Provider_Type } from '@futdevpro/fsm-dynamo/messaging';
|
|
3
|
-
|
|
4
|
-
import {
|
|
5
|
-
DyNTS_Bot_MessagingProvider_ServiceBase, DyNTS_Bot_MessagingProvider_Config, Teams_MessagingProviderConfig
|
|
6
|
-
} from '../../../_services/bot-messaging-provider.service-base';
|
|
7
|
-
import { DyNTS_Bot_ChannelWrapper } from '../../../_models/bot-channel-wrapper.interface';
|
|
8
|
-
import { DyNTS_Bot_LastMessageDate } from '../../../_models/bot-last-message-date.interface';
|
|
9
|
-
import { DyNTS_Bot_LastMentionDate } from '../../../_models/bot-last-mention-date.interface';
|
|
10
|
-
import { DyNTS_Bot_MessageWrapper } from '../../../_models/bot-message-wrapper.interface';
|
|
11
|
-
import { DyNTS_Bot_UserWrapper } from '../../../_models/bot-user-wrapper.interface';
|
|
12
|
-
|
|
13
|
-
// Stub types for Teams - will be replaced with actual Teams SDK types when implemented
|
|
14
|
-
type TeamsChannel = any;
|
|
15
|
-
type TeamsMessage = any;
|
|
16
|
-
type TeamsUser = any;
|
|
17
|
-
|
|
18
|
-
export class DyNTS_TeB_MessagingProvider_ControlService extends DyNTS_Bot_MessagingProvider_ServiceBase<
|
|
19
|
-
TeamsChannel,
|
|
20
|
-
TeamsMessage,
|
|
21
|
-
TeamsUser,
|
|
22
|
-
Teams_MessagingProviderConfig,
|
|
23
|
-
any
|
|
24
|
-
> {
|
|
25
|
-
readonly name = 'teams';
|
|
26
|
-
readonly type = DyFM_Msg_Provider_Type.teams;
|
|
27
|
-
|
|
28
|
-
get botId(): string {
|
|
29
|
-
return 'teams-bot-stub';
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
get botDisplayName(): string {
|
|
33
|
-
return 'Teams Bot (Stub)';
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
override readonly config: Teams_MessagingProviderConfig;
|
|
37
|
-
|
|
38
|
-
/* override protected readonly channelCache: Map<string, TeamsChannel> = new Map();
|
|
39
|
-
override protected readonly roleCache: Map<string, any> = new Map(); */
|
|
40
|
-
|
|
41
|
-
constructor(setConfig: Teams_MessagingProviderConfig) {
|
|
42
|
-
super();
|
|
43
|
-
this.config = setConfig;
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
async setup(issuer: string): Promise<void> {
|
|
47
|
-
throw new Error('Teams provider not yet implemented');
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
async start(issuer: string): Promise<void> {
|
|
51
|
-
throw new Error('Teams provider not yet implemented');
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
// Channel operations
|
|
55
|
-
async getChannelByName(name: string): Promise<DyNTS_Bot_ChannelWrapper<TeamsChannel>> {
|
|
56
|
-
throw new Error('Teams provider not yet implemented');
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
async getChannelById(id: string): Promise<DyNTS_Bot_ChannelWrapper<TeamsChannel>> {
|
|
60
|
-
throw new Error('Teams provider not yet implemented');
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
async sendMessageToChannelByName(channelName: string, message: string, issuer: string): Promise<DyNTS_Bot_MessageWrapper<TeamsMessage>> {
|
|
64
|
-
throw new Error('Teams provider not yet implemented');
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
async getMessagesFromChannelByChannelName(channelName: string, limit?: number): Promise<DyNTS_Bot_MessageWrapper<TeamsMessage>[]> {
|
|
68
|
-
throw new Error('Teams provider not yet implemented');
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
async getLastMessageInChannel(channelName: string): Promise<DyNTS_Bot_MessageWrapper<TeamsMessage>> {
|
|
72
|
-
throw new Error('Teams provider not yet implemented');
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
async clearChannel(channelWrapper: DyNTS_Bot_ChannelWrapper<TeamsChannel>): Promise<void> {
|
|
76
|
-
throw new Error('Teams provider not yet implemented');
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
// Message operations
|
|
80
|
-
async sendMessageToChannel(channelWrapper: DyNTS_Bot_ChannelWrapper<TeamsChannel>, content: string): Promise<DyNTS_Bot_MessageWrapper<TeamsMessage>> {
|
|
81
|
-
throw new Error('Teams provider not yet implemented');
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
async replyToMessage(messageWrapper: DyNTS_Bot_MessageWrapper<TeamsMessage>, content: string): Promise<DyNTS_Bot_MessageWrapper<TeamsMessage>> {
|
|
85
|
-
throw new Error('Teams provider not yet implemented');
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
async sendTyping(channelWrapper: DyNTS_Bot_ChannelWrapper<TeamsChannel>): Promise<void> {
|
|
89
|
-
throw new Error('Teams provider not yet implemented');
|
|
90
|
-
}
|
|
91
|
-
|
|
92
|
-
async sendTypingForMessage(messageWrapper: DyNTS_Bot_MessageWrapper<TeamsMessage>): Promise<void> {
|
|
93
|
-
throw new Error('Teams provider not yet implemented');
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
async fetchMessagesById(id: string, limit: number): Promise<DyNTS_Bot_MessageWrapper<TeamsMessage>[]> {
|
|
97
|
-
throw new Error('Teams provider not yet implemented');
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
async fetchMessages(channelWrapper: DyNTS_Bot_ChannelWrapper<TeamsChannel>, limit: number): Promise<DyNTS_Bot_MessageWrapper<TeamsMessage>[]> {
|
|
101
|
-
throw new Error('Teams provider not yet implemented');
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
async fetchMessagesForMessage(messageWrapper: DyNTS_Bot_MessageWrapper<TeamsMessage>, limit: number): Promise<DyNTS_Bot_MessageWrapper<TeamsMessage>[]> {
|
|
105
|
-
throw new Error('Teams provider not yet implemented');
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
async fetchAllMessagesWithPaging(channelWrapper: DyNTS_Bot_ChannelWrapper<TeamsChannel>, maxFetch?: number): Promise<DyNTS_Bot_MessageWrapper<TeamsMessage>[]> {
|
|
109
|
-
throw new Error('Teams provider not yet implemented');
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
async deleteMessage(messageWrapper: DyNTS_Bot_MessageWrapper<TeamsMessage>): Promise<void> {
|
|
113
|
-
throw new Error('Teams provider not yet implemented');
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
async updateMessage(message: TeamsMessage, issuer: string): Promise<void> {
|
|
117
|
-
throw new Error('Teams provider not yet implemented');
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
// User operations
|
|
121
|
-
async getUserByName(username: string): Promise<DyNTS_Bot_UserWrapper<TeamsUser>> {
|
|
122
|
-
throw new Error('Teams provider not yet implemented');
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
getUserMention(userId: string): string {
|
|
126
|
-
return `<@${userId}>`;
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
async readMembersInChannel(channelName: string): Promise<DyNTS_Bot_UserWrapper<TeamsUser>[]> {
|
|
130
|
-
throw new Error('Teams provider not yet implemented');
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
async readMemberNamesInChannel(channelName: string): Promise<string[]> {
|
|
134
|
-
throw new Error('Teams provider not yet implemented');
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
// Advanced message queries
|
|
138
|
-
async getLastMessageSentBy(channelName: string, username: string): Promise<DyNTS_Bot_MessageWrapper<TeamsMessage>> {
|
|
139
|
-
throw new Error('Teams provider not yet implemented');
|
|
140
|
-
}
|
|
141
|
-
|
|
142
|
-
async getLastMentionOf(channelName: string, username: string): Promise<DyNTS_Bot_MessageWrapper<TeamsMessage>> {
|
|
143
|
-
throw new Error('Teams provider not yet implemented');
|
|
144
|
-
}
|
|
145
|
-
|
|
146
|
-
async readLastMessageDatesByMembers(channelName: string, memberNames: string[]): Promise<DyNTS_Bot_LastMessageDate[]> {
|
|
147
|
-
throw new Error('Teams provider not yet implemented');
|
|
148
|
-
}
|
|
149
|
-
|
|
150
|
-
async readLastMessageWithMemberNamePingInIt(channelName: string, users: DyNTS_Bot_UserWrapper<TeamsUser>[]): Promise<DyNTS_Bot_LastMentionDate[]> {
|
|
151
|
-
throw new Error('Teams provider not yet implemented');
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
// Platform-specific features
|
|
155
|
-
getRoleByName?(roleName: string): any {
|
|
156
|
-
throw new Error('Teams provider not yet implemented');
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
getRolePingByName?(roleName: string): Promise<string> {
|
|
160
|
-
throw new Error('Teams provider not yet implemented');
|
|
161
|
-
}
|
|
162
|
-
|
|
163
|
-
getRolePingsByName?(roleNames: string[]): Promise<string> {
|
|
164
|
-
throw new Error('Teams provider not yet implemented');
|
|
165
|
-
}
|
|
166
|
-
|
|
167
|
-
// Event binding
|
|
168
|
-
async create_onMessageEventListener(
|
|
169
|
-
handler: (message: DyNTS_Bot_MessageWrapper<TeamsMessage>, issuer: string) => Promise<void>
|
|
170
|
-
): Promise<void> {
|
|
171
|
-
throw new Error('Teams provider not yet implemented');
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
create_onErrorEventListener(handler: (error: DyFM_AnyError) => void): void {
|
|
175
|
-
throw new Error('Teams provider not yet implemented');
|
|
176
|
-
}
|
|
177
|
-
|
|
178
|
-
async sendReport(message: string): Promise<DyNTS_Bot_MessageWrapper<TeamsMessage>> {
|
|
179
|
-
throw new Error('Teams provider not yet implemented');
|
|
180
|
-
}
|
|
181
|
-
|
|
182
|
-
async sendReportIn(message: string): Promise<DyNTS_Bot_MessageWrapper<TeamsMessage>> {
|
|
183
|
-
throw new Error('Teams provider not yet implemented');
|
|
184
|
-
}
|
|
185
|
-
|
|
186
|
-
wrapMessage(message: TeamsMessage): Promise<DyNTS_Bot_MessageWrapper<TeamsMessage>> {
|
|
187
|
-
throw new Error('Teams provider not yet implemented');
|
|
188
|
-
}
|
|
189
|
-
|
|
190
|
-
wrapChannel(channel: TeamsChannel): Promise<DyNTS_Bot_ChannelWrapper<TeamsChannel>> {
|
|
191
|
-
throw new Error('Teams provider not yet implemented');
|
|
192
|
-
}
|
|
193
|
-
|
|
194
|
-
wrapUser(user: TeamsUser): Promise<DyNTS_Bot_UserWrapper<TeamsUser>> {
|
|
195
|
-
throw new Error('Teams provider not yet implemented');
|
|
196
|
-
}
|
|
197
|
-
}
|
|
1
|
+
import { DyFM_AnyError, DyFM_Error } from '@futdevpro/fsm-dynamo';
|
|
2
|
+
import { DyFM_Msg_Provider_Type } from '@futdevpro/fsm-dynamo/messaging';
|
|
3
|
+
|
|
4
|
+
import {
|
|
5
|
+
DyNTS_Bot_MessagingProvider_ServiceBase, DyNTS_Bot_MessagingProvider_Config, Teams_MessagingProviderConfig
|
|
6
|
+
} from '../../../_services/bot-messaging-provider.service-base';
|
|
7
|
+
import { DyNTS_Bot_ChannelWrapper } from '../../../_models/bot-channel-wrapper.interface';
|
|
8
|
+
import { DyNTS_Bot_LastMessageDate } from '../../../_models/bot-last-message-date.interface';
|
|
9
|
+
import { DyNTS_Bot_LastMentionDate } from '../../../_models/bot-last-mention-date.interface';
|
|
10
|
+
import { DyNTS_Bot_MessageWrapper } from '../../../_models/bot-message-wrapper.interface';
|
|
11
|
+
import { DyNTS_Bot_UserWrapper } from '../../../_models/bot-user-wrapper.interface';
|
|
12
|
+
|
|
13
|
+
// Stub types for Teams - will be replaced with actual Teams SDK types when implemented
|
|
14
|
+
type TeamsChannel = any;
|
|
15
|
+
type TeamsMessage = any;
|
|
16
|
+
type TeamsUser = any;
|
|
17
|
+
|
|
18
|
+
export class DyNTS_TeB_MessagingProvider_ControlService extends DyNTS_Bot_MessagingProvider_ServiceBase<
|
|
19
|
+
TeamsChannel,
|
|
20
|
+
TeamsMessage,
|
|
21
|
+
TeamsUser,
|
|
22
|
+
Teams_MessagingProviderConfig,
|
|
23
|
+
any
|
|
24
|
+
> {
|
|
25
|
+
readonly name = 'teams';
|
|
26
|
+
readonly type = DyFM_Msg_Provider_Type.teams;
|
|
27
|
+
|
|
28
|
+
get botId(): string {
|
|
29
|
+
return 'teams-bot-stub';
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
get botDisplayName(): string {
|
|
33
|
+
return 'Teams Bot (Stub)';
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
override readonly config: Teams_MessagingProviderConfig;
|
|
37
|
+
|
|
38
|
+
/* override protected readonly channelCache: Map<string, TeamsChannel> = new Map();
|
|
39
|
+
override protected readonly roleCache: Map<string, any> = new Map(); */
|
|
40
|
+
|
|
41
|
+
constructor(setConfig: Teams_MessagingProviderConfig) {
|
|
42
|
+
super();
|
|
43
|
+
this.config = setConfig;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
async setup(issuer: string): Promise<void> {
|
|
47
|
+
throw new Error('Teams provider not yet implemented');
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
async start(issuer: string): Promise<void> {
|
|
51
|
+
throw new Error('Teams provider not yet implemented');
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
// Channel operations
|
|
55
|
+
async getChannelByName(name: string): Promise<DyNTS_Bot_ChannelWrapper<TeamsChannel>> {
|
|
56
|
+
throw new Error('Teams provider not yet implemented');
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
async getChannelById(id: string): Promise<DyNTS_Bot_ChannelWrapper<TeamsChannel>> {
|
|
60
|
+
throw new Error('Teams provider not yet implemented');
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
async sendMessageToChannelByName(channelName: string, message: string, issuer: string): Promise<DyNTS_Bot_MessageWrapper<TeamsMessage>> {
|
|
64
|
+
throw new Error('Teams provider not yet implemented');
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
async getMessagesFromChannelByChannelName(channelName: string, limit?: number): Promise<DyNTS_Bot_MessageWrapper<TeamsMessage>[]> {
|
|
68
|
+
throw new Error('Teams provider not yet implemented');
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
async getLastMessageInChannel(channelName: string): Promise<DyNTS_Bot_MessageWrapper<TeamsMessage>> {
|
|
72
|
+
throw new Error('Teams provider not yet implemented');
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
async clearChannel(channelWrapper: DyNTS_Bot_ChannelWrapper<TeamsChannel>): Promise<void> {
|
|
76
|
+
throw new Error('Teams provider not yet implemented');
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
// Message operations
|
|
80
|
+
async sendMessageToChannel(channelWrapper: DyNTS_Bot_ChannelWrapper<TeamsChannel>, content: string): Promise<DyNTS_Bot_MessageWrapper<TeamsMessage>> {
|
|
81
|
+
throw new Error('Teams provider not yet implemented');
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
async replyToMessage(messageWrapper: DyNTS_Bot_MessageWrapper<TeamsMessage>, content: string): Promise<DyNTS_Bot_MessageWrapper<TeamsMessage>> {
|
|
85
|
+
throw new Error('Teams provider not yet implemented');
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
async sendTyping(channelWrapper: DyNTS_Bot_ChannelWrapper<TeamsChannel>): Promise<void> {
|
|
89
|
+
throw new Error('Teams provider not yet implemented');
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
async sendTypingForMessage(messageWrapper: DyNTS_Bot_MessageWrapper<TeamsMessage>): Promise<void> {
|
|
93
|
+
throw new Error('Teams provider not yet implemented');
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
async fetchMessagesById(id: string, limit: number): Promise<DyNTS_Bot_MessageWrapper<TeamsMessage>[]> {
|
|
97
|
+
throw new Error('Teams provider not yet implemented');
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
async fetchMessages(channelWrapper: DyNTS_Bot_ChannelWrapper<TeamsChannel>, limit: number): Promise<DyNTS_Bot_MessageWrapper<TeamsMessage>[]> {
|
|
101
|
+
throw new Error('Teams provider not yet implemented');
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
async fetchMessagesForMessage(messageWrapper: DyNTS_Bot_MessageWrapper<TeamsMessage>, limit: number): Promise<DyNTS_Bot_MessageWrapper<TeamsMessage>[]> {
|
|
105
|
+
throw new Error('Teams provider not yet implemented');
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
async fetchAllMessagesWithPaging(channelWrapper: DyNTS_Bot_ChannelWrapper<TeamsChannel>, maxFetch?: number): Promise<DyNTS_Bot_MessageWrapper<TeamsMessage>[]> {
|
|
109
|
+
throw new Error('Teams provider not yet implemented');
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
async deleteMessage(messageWrapper: DyNTS_Bot_MessageWrapper<TeamsMessage>): Promise<void> {
|
|
113
|
+
throw new Error('Teams provider not yet implemented');
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
async updateMessage(message: TeamsMessage, issuer: string): Promise<void> {
|
|
117
|
+
throw new Error('Teams provider not yet implemented');
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
// User operations
|
|
121
|
+
async getUserByName(username: string): Promise<DyNTS_Bot_UserWrapper<TeamsUser>> {
|
|
122
|
+
throw new Error('Teams provider not yet implemented');
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
getUserMention(userId: string): string {
|
|
126
|
+
return `<@${userId}>`;
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
async readMembersInChannel(channelName: string): Promise<DyNTS_Bot_UserWrapper<TeamsUser>[]> {
|
|
130
|
+
throw new Error('Teams provider not yet implemented');
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
async readMemberNamesInChannel(channelName: string): Promise<string[]> {
|
|
134
|
+
throw new Error('Teams provider not yet implemented');
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
// Advanced message queries
|
|
138
|
+
async getLastMessageSentBy(channelName: string, username: string): Promise<DyNTS_Bot_MessageWrapper<TeamsMessage>> {
|
|
139
|
+
throw new Error('Teams provider not yet implemented');
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
async getLastMentionOf(channelName: string, username: string): Promise<DyNTS_Bot_MessageWrapper<TeamsMessage>> {
|
|
143
|
+
throw new Error('Teams provider not yet implemented');
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
async readLastMessageDatesByMembers(channelName: string, memberNames: string[]): Promise<DyNTS_Bot_LastMessageDate[]> {
|
|
147
|
+
throw new Error('Teams provider not yet implemented');
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
async readLastMessageWithMemberNamePingInIt(channelName: string, users: DyNTS_Bot_UserWrapper<TeamsUser>[]): Promise<DyNTS_Bot_LastMentionDate[]> {
|
|
151
|
+
throw new Error('Teams provider not yet implemented');
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
// Platform-specific features
|
|
155
|
+
getRoleByName?(roleName: string): any {
|
|
156
|
+
throw new Error('Teams provider not yet implemented');
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
getRolePingByName?(roleName: string): Promise<string> {
|
|
160
|
+
throw new Error('Teams provider not yet implemented');
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
getRolePingsByName?(roleNames: string[]): Promise<string> {
|
|
164
|
+
throw new Error('Teams provider not yet implemented');
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
// Event binding
|
|
168
|
+
async create_onMessageEventListener(
|
|
169
|
+
handler: (message: DyNTS_Bot_MessageWrapper<TeamsMessage>, issuer: string) => Promise<void>
|
|
170
|
+
): Promise<void> {
|
|
171
|
+
throw new Error('Teams provider not yet implemented');
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
create_onErrorEventListener(handler: (error: DyFM_AnyError) => void): void {
|
|
175
|
+
throw new Error('Teams provider not yet implemented');
|
|
176
|
+
}
|
|
177
|
+
|
|
178
|
+
async sendReport(message: string): Promise<DyNTS_Bot_MessageWrapper<TeamsMessage>> {
|
|
179
|
+
throw new Error('Teams provider not yet implemented');
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
async sendReportIn(message: string): Promise<DyNTS_Bot_MessageWrapper<TeamsMessage>> {
|
|
183
|
+
throw new Error('Teams provider not yet implemented');
|
|
184
|
+
}
|
|
185
|
+
|
|
186
|
+
wrapMessage(message: TeamsMessage): Promise<DyNTS_Bot_MessageWrapper<TeamsMessage>> {
|
|
187
|
+
throw new Error('Teams provider not yet implemented');
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
wrapChannel(channel: TeamsChannel): Promise<DyNTS_Bot_ChannelWrapper<TeamsChannel>> {
|
|
191
|
+
throw new Error('Teams provider not yet implemented');
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
wrapUser(user: TeamsUser): Promise<DyNTS_Bot_UserWrapper<TeamsUser>> {
|
|
195
|
+
throw new Error('Teams provider not yet implemented');
|
|
196
|
+
}
|
|
197
|
+
}
|
|
@@ -1,116 +1,116 @@
|
|
|
1
|
-
|
|
2
|
-
import { DyNTS_Bot_Commands_ControlService } from './bot-commands.control-service';
|
|
3
|
-
import { DyNTS_Bot_Main_ControlService } from './bot-main.control-service';
|
|
4
|
-
import { DyNTS_Bot_MessageWrapper } from '../_models/bot-message-wrapper.interface';
|
|
5
|
-
import { DyNTS_Bot_MessagingProvider_ServiceBase } from './bot-messaging-provider.service-base';
|
|
6
|
-
import { DyFM_Error, DyFM_EnvironmentFlag } from '@futdevpro/fsm-dynamo';
|
|
7
|
-
import { DyNTS_global_settings } from '../../../_collections/global-settings.const';
|
|
8
|
-
import { DyNTS_GlobalService } from '../../../_services/core/global.service';
|
|
9
|
-
|
|
10
|
-
class TestBotCommandsService extends DyNTS_Bot_Commands_ControlService {
|
|
11
|
-
protected declare mainBot_CS: any;
|
|
12
|
-
protected getMainBotControlService(): DyNTS_Bot_Main_ControlService {
|
|
13
|
-
return {
|
|
14
|
-
defaultProvider: {
|
|
15
|
-
botId: 'bot-123',
|
|
16
|
-
},
|
|
17
|
-
} as any;
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
static getInstance(): TestBotCommandsService {
|
|
21
|
-
return TestBotCommandsService.getSingletonInstance();
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
xdescribe('| DyNTS_Bot_Commands_ControlService', () => {
|
|
26
|
-
let service: TestBotCommandsService;
|
|
27
|
-
let mockDBService: jasmine.SpyObj<{
|
|
28
|
-
find: (f: unknown) => Promise<unknown[]>;
|
|
29
|
-
getAll: () => Promise<unknown[]>;
|
|
30
|
-
getDataById: (id: string) => Promise<unknown>;
|
|
31
|
-
}>;
|
|
32
|
-
|
|
33
|
-
beforeAll(() => {
|
|
34
|
-
if (!DyNTS_global_settings.systemShortCodeName) {
|
|
35
|
-
(DyNTS_global_settings as { systemShortCodeName?: string }).systemShortCodeName = 'TEST';
|
|
36
|
-
}
|
|
37
|
-
});
|
|
38
|
-
|
|
39
|
-
beforeEach(() => {
|
|
40
|
-
DyNTS_global_settings.env_settings = {
|
|
41
|
-
environment: DyFM_EnvironmentFlag.local,
|
|
42
|
-
mongoUri: 'mongodb://localhost:27017/test',
|
|
43
|
-
} as typeof DyNTS_global_settings.env_settings;
|
|
44
|
-
|
|
45
|
-
mockDBService = jasmine.createSpyObj('DyNTS_DBService', [
|
|
46
|
-
'find', 'findOne', 'getDataById', 'getAll', 'getDataListByIds', 'getDataByDependencyId',
|
|
47
|
-
'getDataListByDependencyId', 'getDataListByDependencyIds', 'createData', 'modifyData',
|
|
48
|
-
'markDeletedById', 'trueDeleteDataById', 'trueDeleteAllData', 'restoreDeletedById',
|
|
49
|
-
]);
|
|
50
|
-
spyOn(DyNTS_GlobalService, 'getDBService').and.returnValue(mockDBService as never);
|
|
51
|
-
spyOn(DyNTS_GlobalService, 'getDBServiceByKey').and.returnValue(mockDBService as never);
|
|
52
|
-
|
|
53
|
-
service = TestBotCommandsService.getInstance();
|
|
54
|
-
});
|
|
55
|
-
|
|
56
|
-
it('| should be a singleton instance', () => {
|
|
57
|
-
const instance1 = TestBotCommandsService.getInstance();
|
|
58
|
-
const instance2 = TestBotCommandsService.getInstance();
|
|
59
|
-
|
|
60
|
-
expect(instance1).toBe(instance2);
|
|
61
|
-
expect(instance1).toBeInstanceOf(TestBotCommandsService);
|
|
62
|
-
});
|
|
63
|
-
|
|
64
|
-
describe('| defaultProvider', () => {
|
|
65
|
-
it('| should return default provider from main bot service', () => {
|
|
66
|
-
(service as any).mainBot_CS = (service as any).getMainBotControlService();
|
|
67
|
-
|
|
68
|
-
expect(service.defaultProvider).toBeDefined();
|
|
69
|
-
});
|
|
70
|
-
});
|
|
71
|
-
|
|
72
|
-
describe('| setup', () => {
|
|
73
|
-
it('| should setup main bot service', async () => {
|
|
74
|
-
await service.setup('issuer-123');
|
|
75
|
-
|
|
76
|
-
expect((service as any).mainBot_CS).toBeDefined();
|
|
77
|
-
});
|
|
78
|
-
|
|
79
|
-
it('| should throw error when main bot service not found', async () => {
|
|
80
|
-
const serviceWithoutMainBot = new (class extends TestBotCommandsService {
|
|
81
|
-
protected override getMainBotControlService(): any {
|
|
82
|
-
return null;
|
|
83
|
-
}
|
|
84
|
-
} as any)();
|
|
85
|
-
|
|
86
|
-
await expectAsync(
|
|
87
|
-
serviceWithoutMainBot.setup('issuer-123')
|
|
88
|
-
).toBeRejected();
|
|
89
|
-
});
|
|
90
|
-
});
|
|
91
|
-
|
|
92
|
-
describe('| start', () => {
|
|
93
|
-
it('| should throw error when default provider not started', async () => {
|
|
94
|
-
const serviceWithoutProvider = new (class extends TestBotCommandsService {
|
|
95
|
-
protected override getMainBotControlService(): any {
|
|
96
|
-
return {
|
|
97
|
-
defaultProvider: null,
|
|
98
|
-
};
|
|
99
|
-
}
|
|
100
|
-
} as any)();
|
|
101
|
-
|
|
102
|
-
await expectAsync(
|
|
103
|
-
serviceWithoutProvider.start('issuer-123')
|
|
104
|
-
).toBeRejected();
|
|
105
|
-
});
|
|
106
|
-
|
|
107
|
-
it('| should succeed when default provider is started', async () => {
|
|
108
|
-
(service as any).mainBot_CS = (service as any).getMainBotControlService();
|
|
109
|
-
|
|
110
|
-
await expectAsync(
|
|
111
|
-
service.start('issuer-123')
|
|
112
|
-
).toBeResolved();
|
|
113
|
-
});
|
|
114
|
-
});
|
|
115
|
-
});
|
|
116
|
-
|
|
1
|
+
|
|
2
|
+
import { DyNTS_Bot_Commands_ControlService } from './bot-commands.control-service';
|
|
3
|
+
import { DyNTS_Bot_Main_ControlService } from './bot-main.control-service';
|
|
4
|
+
import { DyNTS_Bot_MessageWrapper } from '../_models/bot-message-wrapper.interface';
|
|
5
|
+
import { DyNTS_Bot_MessagingProvider_ServiceBase } from './bot-messaging-provider.service-base';
|
|
6
|
+
import { DyFM_Error, DyFM_EnvironmentFlag } from '@futdevpro/fsm-dynamo';
|
|
7
|
+
import { DyNTS_global_settings } from '../../../_collections/global-settings.const';
|
|
8
|
+
import { DyNTS_GlobalService } from '../../../_services/core/global.service';
|
|
9
|
+
|
|
10
|
+
class TestBotCommandsService extends DyNTS_Bot_Commands_ControlService {
|
|
11
|
+
protected declare mainBot_CS: any;
|
|
12
|
+
protected getMainBotControlService(): DyNTS_Bot_Main_ControlService {
|
|
13
|
+
return {
|
|
14
|
+
defaultProvider: {
|
|
15
|
+
botId: 'bot-123',
|
|
16
|
+
},
|
|
17
|
+
} as any;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
static getInstance(): TestBotCommandsService {
|
|
21
|
+
return TestBotCommandsService.getSingletonInstance();
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
xdescribe('| DyNTS_Bot_Commands_ControlService', () => {
|
|
26
|
+
let service: TestBotCommandsService;
|
|
27
|
+
let mockDBService: jasmine.SpyObj<{
|
|
28
|
+
find: (f: unknown) => Promise<unknown[]>;
|
|
29
|
+
getAll: () => Promise<unknown[]>;
|
|
30
|
+
getDataById: (id: string) => Promise<unknown>;
|
|
31
|
+
}>;
|
|
32
|
+
|
|
33
|
+
beforeAll(() => {
|
|
34
|
+
if (!DyNTS_global_settings.systemShortCodeName) {
|
|
35
|
+
(DyNTS_global_settings as { systemShortCodeName?: string }).systemShortCodeName = 'TEST';
|
|
36
|
+
}
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
beforeEach(() => {
|
|
40
|
+
DyNTS_global_settings.env_settings = {
|
|
41
|
+
environment: DyFM_EnvironmentFlag.local,
|
|
42
|
+
mongoUri: 'mongodb://localhost:27017/test',
|
|
43
|
+
} as typeof DyNTS_global_settings.env_settings;
|
|
44
|
+
|
|
45
|
+
mockDBService = jasmine.createSpyObj('DyNTS_DBService', [
|
|
46
|
+
'find', 'findOne', 'getDataById', 'getAll', 'getDataListByIds', 'getDataByDependencyId',
|
|
47
|
+
'getDataListByDependencyId', 'getDataListByDependencyIds', 'createData', 'modifyData',
|
|
48
|
+
'markDeletedById', 'trueDeleteDataById', 'trueDeleteAllData', 'restoreDeletedById',
|
|
49
|
+
]);
|
|
50
|
+
spyOn(DyNTS_GlobalService, 'getDBService').and.returnValue(mockDBService as never);
|
|
51
|
+
spyOn(DyNTS_GlobalService, 'getDBServiceByKey').and.returnValue(mockDBService as never);
|
|
52
|
+
|
|
53
|
+
service = TestBotCommandsService.getInstance();
|
|
54
|
+
});
|
|
55
|
+
|
|
56
|
+
it('| should be a singleton instance', () => {
|
|
57
|
+
const instance1 = TestBotCommandsService.getInstance();
|
|
58
|
+
const instance2 = TestBotCommandsService.getInstance();
|
|
59
|
+
|
|
60
|
+
expect(instance1).toBe(instance2);
|
|
61
|
+
expect(instance1).toBeInstanceOf(TestBotCommandsService);
|
|
62
|
+
});
|
|
63
|
+
|
|
64
|
+
describe('| defaultProvider', () => {
|
|
65
|
+
it('| should return default provider from main bot service', () => {
|
|
66
|
+
(service as any).mainBot_CS = (service as any).getMainBotControlService();
|
|
67
|
+
|
|
68
|
+
expect(service.defaultProvider).toBeDefined();
|
|
69
|
+
});
|
|
70
|
+
});
|
|
71
|
+
|
|
72
|
+
describe('| setup', () => {
|
|
73
|
+
it('| should setup main bot service', async () => {
|
|
74
|
+
await service.setup('issuer-123');
|
|
75
|
+
|
|
76
|
+
expect((service as any).mainBot_CS).toBeDefined();
|
|
77
|
+
});
|
|
78
|
+
|
|
79
|
+
it('| should throw error when main bot service not found', async () => {
|
|
80
|
+
const serviceWithoutMainBot = new (class extends TestBotCommandsService {
|
|
81
|
+
protected override getMainBotControlService(): any {
|
|
82
|
+
return null;
|
|
83
|
+
}
|
|
84
|
+
} as any)();
|
|
85
|
+
|
|
86
|
+
await expectAsync(
|
|
87
|
+
serviceWithoutMainBot.setup('issuer-123')
|
|
88
|
+
).toBeRejected();
|
|
89
|
+
});
|
|
90
|
+
});
|
|
91
|
+
|
|
92
|
+
describe('| start', () => {
|
|
93
|
+
it('| should throw error when default provider not started', async () => {
|
|
94
|
+
const serviceWithoutProvider = new (class extends TestBotCommandsService {
|
|
95
|
+
protected override getMainBotControlService(): any {
|
|
96
|
+
return {
|
|
97
|
+
defaultProvider: null,
|
|
98
|
+
};
|
|
99
|
+
}
|
|
100
|
+
} as any)();
|
|
101
|
+
|
|
102
|
+
await expectAsync(
|
|
103
|
+
serviceWithoutProvider.start('issuer-123')
|
|
104
|
+
).toBeRejected();
|
|
105
|
+
});
|
|
106
|
+
|
|
107
|
+
it('| should succeed when default provider is started', async () => {
|
|
108
|
+
(service as any).mainBot_CS = (service as any).getMainBotControlService();
|
|
109
|
+
|
|
110
|
+
await expectAsync(
|
|
111
|
+
service.start('issuer-123')
|
|
112
|
+
).toBeResolved();
|
|
113
|
+
});
|
|
114
|
+
});
|
|
115
|
+
});
|
|
116
|
+
|