@frontmcp/sdk 0.4.0 → 0.5.0
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/README.md +30 -18
- package/package.json +20 -5
- package/src/app/app.registry.d.ts +3 -2
- package/src/app/app.registry.js +3 -1
- package/src/app/app.registry.js.map +1 -1
- package/src/app/instances/app.local.instance.js +2 -2
- package/src/app/instances/app.local.instance.js.map +1 -1
- package/src/auth/auth.registry.d.ts +34 -2
- package/src/auth/auth.registry.js +162 -24
- package/src/auth/auth.registry.js.map +1 -1
- package/src/auth/auth.utils.js +8 -9
- package/src/auth/auth.utils.js.map +1 -1
- package/src/auth/authorization/authorization.class.d.ts +125 -0
- package/src/auth/authorization/authorization.class.js +224 -0
- package/src/auth/authorization/authorization.class.js.map +1 -0
- package/src/auth/authorization/authorization.types.d.ts +300 -0
- package/src/auth/authorization/authorization.types.js +79 -0
- package/src/auth/authorization/authorization.types.js.map +1 -0
- package/src/auth/authorization/index.d.ts +5 -0
- package/src/auth/authorization/index.js +19 -0
- package/src/auth/authorization/index.js.map +1 -0
- package/src/auth/authorization/orchestrated.authorization.d.ts +242 -0
- package/src/auth/authorization/orchestrated.authorization.js +306 -0
- package/src/auth/authorization/orchestrated.authorization.js.map +1 -0
- package/src/auth/authorization/public.authorization.d.ts +91 -0
- package/src/auth/authorization/public.authorization.js +132 -0
- package/src/auth/authorization/public.authorization.js.map +1 -0
- package/src/auth/authorization/transparent.authorization.d.ts +130 -0
- package/src/auth/authorization/transparent.authorization.js +147 -0
- package/src/auth/authorization/transparent.authorization.js.map +1 -0
- package/src/auth/consent/consent.types.d.ts +111 -0
- package/src/auth/consent/consent.types.js +119 -0
- package/src/auth/consent/consent.types.js.map +1 -0
- package/src/auth/consent/index.d.ts +1 -0
- package/src/auth/consent/index.js +13 -0
- package/src/auth/consent/index.js.map +1 -0
- package/src/auth/detection/auth-provider-detection.d.ts +84 -0
- package/src/auth/detection/auth-provider-detection.js +230 -0
- package/src/auth/detection/auth-provider-detection.js.map +1 -0
- package/src/auth/detection/index.d.ts +1 -0
- package/src/auth/detection/index.js +15 -0
- package/src/auth/detection/index.js.map +1 -0
- package/src/auth/flows/auth.verify.flow.d.ts +110 -0
- package/src/auth/flows/auth.verify.flow.js +379 -0
- package/src/auth/flows/auth.verify.flow.js.map +1 -0
- package/src/auth/flows/oauth.authorize.flow.d.ts +118 -164
- package/src/auth/flows/oauth.authorize.flow.js +701 -33
- package/src/auth/flows/oauth.authorize.flow.js.map +1 -1
- package/src/auth/flows/oauth.callback.flow.d.ts +117 -0
- package/src/auth/flows/oauth.callback.flow.js +357 -0
- package/src/auth/flows/oauth.callback.flow.js.map +1 -0
- package/src/auth/flows/oauth.register.flow.d.ts +32 -125
- package/src/auth/flows/oauth.token.flow.d.ts +52 -154
- package/src/auth/flows/oauth.token.flow.js +193 -55
- package/src/auth/flows/oauth.token.flow.js.map +1 -1
- package/src/auth/flows/session.verify.flow.d.ts +66 -321
- package/src/auth/flows/session.verify.flow.js +107 -18
- package/src/auth/flows/session.verify.flow.js.map +1 -1
- package/src/auth/flows/well-known.jwks.flow.d.ts +34 -205
- package/src/auth/flows/well-known.jwks.flow.js +15 -8
- package/src/auth/flows/well-known.jwks.flow.js.map +1 -1
- package/src/auth/flows/well-known.oauth-authorization-server.flow.d.ts +48 -223
- package/src/auth/flows/well-known.oauth-authorization-server.flow.js +2 -3
- package/src/auth/flows/well-known.oauth-authorization-server.flow.js.map +1 -1
- package/src/auth/flows/well-known.prm.flow.d.ts +19 -120
- package/src/auth/flows/well-known.prm.flow.js +3 -4
- package/src/auth/flows/well-known.prm.flow.js.map +1 -1
- package/src/auth/instances/instance.local-primary-auth.d.ts +91 -4
- package/src/auth/instances/instance.local-primary-auth.js +236 -6
- package/src/auth/instances/instance.local-primary-auth.js.map +1 -1
- package/src/auth/instances/instance.remote-primary-auth.d.ts +4 -3
- package/src/auth/instances/instance.remote-primary-auth.js +2 -2
- package/src/auth/instances/instance.remote-primary-auth.js.map +1 -1
- package/src/auth/session/authorization-vault.d.ts +611 -0
- package/src/auth/session/authorization-vault.js +817 -0
- package/src/auth/session/authorization-vault.js.map +1 -0
- package/src/auth/session/authorization.store.d.ts +301 -0
- package/src/auth/session/authorization.store.js +323 -0
- package/src/auth/session/authorization.store.js.map +1 -0
- package/src/auth/session/encrypted-authorization-vault.d.ts +181 -0
- package/src/auth/session/encrypted-authorization-vault.js +493 -0
- package/src/auth/session/encrypted-authorization-vault.js.map +1 -0
- package/src/auth/session/index.d.ts +4 -4
- package/src/auth/session/index.js +11 -7
- package/src/auth/session/index.js.map +1 -1
- package/src/auth/session/session.schema.d.ts +1 -1
- package/src/auth/session/session.service.d.ts +1 -1
- package/src/auth/session/transport-session.manager.d.ts +101 -0
- package/src/auth/session/transport-session.manager.js +300 -0
- package/src/auth/session/transport-session.manager.js.map +1 -0
- package/src/auth/session/transport-session.types.d.ts +457 -0
- package/src/auth/session/transport-session.types.js +110 -0
- package/src/auth/session/transport-session.types.js.map +1 -0
- package/src/auth/session/utils/session-id.utils.d.ts +14 -2
- package/src/auth/session/utils/session-id.utils.js +68 -19
- package/src/auth/session/utils/session-id.utils.js.map +1 -1
- package/src/auth/session/vault-encryption.d.ts +189 -0
- package/src/auth/session/vault-encryption.js +263 -0
- package/src/auth/session/vault-encryption.js.map +1 -0
- package/src/auth/ui/base-layout.d.ts +188 -0
- package/src/auth/ui/base-layout.js +292 -0
- package/src/auth/ui/base-layout.js.map +1 -0
- package/src/auth/ui/htmx-templates.d.ts +135 -0
- package/src/auth/ui/htmx-templates.js +433 -0
- package/src/auth/ui/htmx-templates.js.map +1 -0
- package/src/auth/ui/index.d.ts +11 -0
- package/src/auth/ui/index.js +35 -0
- package/src/auth/ui/index.js.map +1 -0
- package/src/auth/utils/audience.validator.d.ts +129 -0
- package/src/auth/utils/audience.validator.js +196 -0
- package/src/auth/utils/audience.validator.js.map +1 -0
- package/src/auth/utils/index.d.ts +2 -0
- package/src/auth/utils/index.js +7 -0
- package/src/auth/utils/index.js.map +1 -0
- package/src/auth/utils/www-authenticate.utils.d.ts +97 -0
- package/src/auth/utils/www-authenticate.utils.js +183 -0
- package/src/auth/utils/www-authenticate.utils.js.map +1 -0
- package/src/common/common.schema.d.ts +2 -16
- package/src/common/constants.d.ts +3 -0
- package/src/common/constants.js +6 -1
- package/src/common/constants.js.map +1 -1
- package/src/common/decorators/decorator-utils.d.ts +131 -0
- package/src/common/decorators/decorator-utils.js +195 -0
- package/src/common/decorators/decorator-utils.js.map +1 -0
- package/src/common/decorators/front-mcp.decorator.js +3 -2
- package/src/common/decorators/front-mcp.decorator.js.map +1 -1
- package/src/common/decorators/hook.decorator.d.ts +58 -2
- package/src/common/decorators/hook.decorator.js +127 -17
- package/src/common/decorators/hook.decorator.js.map +1 -1
- package/src/common/decorators/plugin.decorator.d.ts +1 -1
- package/src/common/decorators/plugin.decorator.js +11 -10
- package/src/common/decorators/plugin.decorator.js.map +1 -1
- package/src/common/decorators/resource.decorator.d.ts +32 -3
- package/src/common/decorators/resource.decorator.js +46 -4
- package/src/common/decorators/resource.decorator.js.map +1 -1
- package/src/common/decorators/tool.decorator.d.ts +54 -5
- package/src/common/decorators/tool.decorator.js.map +1 -1
- package/src/common/dynamic/dynamic.plugin.d.ts +22 -11
- package/src/common/dynamic/dynamic.plugin.js +7 -1
- package/src/common/dynamic/dynamic.plugin.js.map +1 -1
- package/src/common/entries/prompt.entry.d.ts +46 -2
- package/src/common/entries/prompt.entry.js +10 -0
- package/src/common/entries/prompt.entry.js.map +1 -1
- package/src/common/entries/resource.entry.d.ts +69 -6
- package/src/common/entries/resource.entry.js +27 -3
- package/src/common/entries/resource.entry.js.map +1 -1
- package/src/common/entries/scope.entry.d.ts +5 -1
- package/src/common/entries/scope.entry.js +3 -3
- package/src/common/entries/scope.entry.js.map +1 -1
- package/src/common/flow/flow.utils.d.ts +56 -0
- package/src/common/flow/flow.utils.js +96 -0
- package/src/common/flow/flow.utils.js.map +1 -0
- package/src/common/index.d.ts +2 -2
- package/src/common/index.js +2 -2
- package/src/common/index.js.map +1 -1
- package/src/common/interfaces/execution-context.interface.d.ts +59 -0
- package/src/common/interfaces/execution-context.interface.js +81 -0
- package/src/common/interfaces/execution-context.interface.js.map +1 -0
- package/src/common/interfaces/flow.interface.d.ts +1 -1
- package/src/common/interfaces/flow.interface.js.map +1 -1
- package/src/common/interfaces/index.d.ts +1 -0
- package/src/common/interfaces/index.js +1 -0
- package/src/common/interfaces/index.js.map +1 -1
- package/src/common/interfaces/internal/primary-auth-provider.interface.d.ts +17 -2
- package/src/common/interfaces/internal/primary-auth-provider.interface.js +52 -4
- package/src/common/interfaces/internal/primary-auth-provider.interface.js.map +1 -1
- package/src/common/interfaces/internal/registry.interface.d.ts +16 -2
- package/src/common/interfaces/internal/registry.interface.js.map +1 -1
- package/src/common/interfaces/plugin.interface.js.map +1 -1
- package/src/common/interfaces/prompt.interface.d.ts +53 -4
- package/src/common/interfaces/prompt.interface.js +78 -0
- package/src/common/interfaces/prompt.interface.js.map +1 -1
- package/src/common/interfaces/resource.interface.d.ts +47 -17
- package/src/common/interfaces/resource.interface.js +53 -0
- package/src/common/interfaces/resource.interface.js.map +1 -1
- package/src/common/interfaces/tool.interface.d.ts +39 -22
- package/src/common/interfaces/tool.interface.js +61 -34
- package/src/common/interfaces/tool.interface.js.map +1 -1
- package/src/common/metadata/adapter.metadata.d.ts +1 -9
- package/src/common/metadata/app.metadata.d.ts +425 -730
- package/src/common/metadata/auth-provider.metadata.d.ts +2 -12
- package/src/common/metadata/flow.metadata.d.ts +10 -25
- package/src/common/metadata/front-mcp.metadata.d.ts +602 -1023
- package/src/common/metadata/front-mcp.metadata.js +6 -4
- package/src/common/metadata/front-mcp.metadata.js.map +1 -1
- package/src/common/metadata/hook.metadata.d.ts +1 -1
- package/src/common/metadata/hook.metadata.js.map +1 -1
- package/src/common/metadata/index.d.ts +1 -0
- package/src/common/metadata/index.js +1 -0
- package/src/common/metadata/index.js.map +1 -1
- package/src/common/metadata/logger.metadata.d.ts +1 -9
- package/src/common/metadata/plugin.metadata.d.ts +8 -30
- package/src/common/metadata/prompt.metadata.d.ts +4 -161
- package/src/common/metadata/provider.metadata.d.ts +2 -12
- package/src/common/metadata/resource.metadata.d.ts +6 -98
- package/src/common/metadata/resource.metadata.js +15 -6
- package/src/common/metadata/resource.metadata.js.map +1 -1
- package/src/common/metadata/tool-ui.metadata.d.ts +10 -0
- package/src/common/metadata/tool-ui.metadata.js +12 -0
- package/src/common/metadata/tool-ui.metadata.js.map +1 -0
- package/src/common/metadata/tool.metadata.d.ts +78 -199
- package/src/common/metadata/tool.metadata.js +11 -14
- package/src/common/metadata/tool.metadata.js.map +1 -1
- package/src/common/providers/base-config.provider.d.ts +84 -0
- package/src/common/providers/base-config.provider.js +128 -0
- package/src/common/providers/base-config.provider.js.map +1 -0
- package/src/common/records/plugin.record.d.ts +5 -6
- package/src/common/records/plugin.record.js.map +1 -1
- package/src/common/records/prompt.record.js.map +1 -1
- package/src/common/records/resource.record.d.ts +17 -1
- package/src/common/records/resource.record.js +12 -6
- package/src/common/records/resource.record.js.map +1 -1
- package/src/common/records/tool.record.js.map +1 -1
- package/src/common/schemas/annotated-class.schema.d.ts +9 -9
- package/src/common/schemas/annotated-class.schema.js +92 -27
- package/src/common/schemas/annotated-class.schema.js.map +1 -1
- package/src/common/schemas/http-input.schema.d.ts +6 -30
- package/src/common/schemas/http-output.schema.d.ts +326 -1630
- package/src/common/schemas/http-output.schema.js +39 -1
- package/src/common/schemas/http-output.schema.js.map +1 -1
- package/src/common/tokens/front-mcp.tokens.js +4 -1
- package/src/common/tokens/front-mcp.tokens.js.map +1 -1
- package/src/common/tokens/resource.tokens.d.ts +2 -0
- package/src/common/tokens/resource.tokens.js +4 -1
- package/src/common/tokens/resource.tokens.js.map +1 -1
- package/src/common/tokens/tool.tokens.d.ts +2 -0
- package/src/common/tokens/tool.tokens.js +2 -0
- package/src/common/tokens/tool.tokens.js.map +1 -1
- package/src/common/types/auth/jwt.types.d.ts +5 -31
- package/src/common/types/auth/session.types.d.ts +97 -192
- package/src/common/types/auth/session.types.js +24 -11
- package/src/common/types/auth/session.types.js.map +1 -1
- package/src/common/types/options/auth.options.d.ts +1013 -490
- package/src/common/types/options/auth.options.js +554 -36
- package/src/common/types/options/auth.options.js.map +1 -1
- package/src/common/types/options/http.options.d.ts +1 -9
- package/src/common/types/options/logging.options.d.ts +7 -13
- package/src/common/types/options/logging.options.js +4 -0
- package/src/common/types/options/logging.options.js.map +1 -1
- package/src/common/types/options/server-info.options.d.ts +3 -31
- package/src/common/types/options/session.options.d.ts +90 -10
- package/src/common/types/options/session.options.js +26 -3
- package/src/common/types/options/session.options.js.map +1 -1
- package/src/common/utils/decide-request-intent.utils.d.ts +8 -46
- package/src/common/utils/decide-request-intent.utils.js +88 -23
- package/src/common/utils/decide-request-intent.utils.js.map +1 -1
- package/src/completion/flows/complete.flow.d.ts +74 -0
- package/src/completion/flows/complete.flow.js +199 -0
- package/src/completion/flows/complete.flow.js.map +1 -0
- package/src/errors/authorization-required.error.d.ts +189 -0
- package/src/errors/authorization-required.error.js +274 -0
- package/src/errors/authorization-required.error.js.map +1 -0
- package/src/errors/index.d.ts +2 -1
- package/src/errors/index.js +17 -1
- package/src/errors/index.js.map +1 -1
- package/src/errors/mcp.error.d.ts +101 -1
- package/src/errors/mcp.error.js +147 -2
- package/src/errors/mcp.error.js.map +1 -1
- package/src/flows/flow.instance.js +4 -3
- package/src/flows/flow.instance.js.map +1 -1
- package/src/flows/flow.registry.js.map +1 -1
- package/src/flows/flow.stages.js +14 -11
- package/src/flows/flow.stages.js.map +1 -1
- package/src/front-mcp/front-mcp.providers.d.ts +464 -102
- package/src/front-mcp/front-mcp.providers.js +3 -5
- package/src/front-mcp/front-mcp.providers.js.map +1 -1
- package/src/hooks/hook.instance.d.ts +1 -1
- package/src/hooks/hook.instance.js +5 -2
- package/src/hooks/hook.instance.js.map +1 -1
- package/src/hooks/hook.registry.js +7 -5
- package/src/hooks/hook.registry.js.map +1 -1
- package/src/index.d.ts +28 -9
- package/src/index.js +5 -1
- package/src/index.js.map +1 -1
- package/src/logger/instances/instance.logger.js +3 -2
- package/src/logger/instances/instance.logger.js.map +1 -1
- package/src/logger/logger.registry.js +7 -2
- package/src/logger/logger.registry.js.map +1 -1
- package/src/logging/flows/set-level.flow.d.ts +62 -0
- package/src/logging/flows/set-level.flow.js +108 -0
- package/src/logging/flows/set-level.flow.js.map +1 -0
- package/src/mcp-apps/csp.d.ts +111 -0
- package/src/mcp-apps/csp.js +267 -0
- package/src/mcp-apps/csp.js.map +1 -0
- package/src/mcp-apps/index.d.ts +23 -0
- package/src/mcp-apps/index.js +91 -0
- package/src/mcp-apps/index.js.map +1 -0
- package/src/mcp-apps/schemas.d.ts +403 -0
- package/src/mcp-apps/schemas.js +345 -0
- package/src/mcp-apps/schemas.js.map +1 -0
- package/src/mcp-apps/template.d.ts +94 -0
- package/src/mcp-apps/template.js +419 -0
- package/src/mcp-apps/template.js.map +1 -0
- package/src/mcp-apps/types.d.ts +323 -0
- package/src/mcp-apps/types.js +59 -0
- package/src/mcp-apps/types.js.map +1 -0
- package/src/notification/index.d.ts +1 -0
- package/src/notification/index.js +13 -0
- package/src/notification/index.js.map +1 -0
- package/src/notification/notification.service.d.ts +378 -0
- package/src/notification/notification.service.js +727 -0
- package/src/notification/notification.service.js.map +1 -0
- package/src/plugin/plugin.registry.js +12 -9
- package/src/plugin/plugin.registry.js.map +1 -1
- package/src/prompt/flows/get-prompt.flow.d.ts +153 -0
- package/src/prompt/flows/get-prompt.flow.js +214 -0
- package/src/prompt/flows/get-prompt.flow.js.map +1 -0
- package/src/prompt/flows/prompts-list.flow.d.ts +67 -0
- package/src/prompt/flows/prompts-list.flow.js +176 -0
- package/src/prompt/flows/prompts-list.flow.js.map +1 -0
- package/src/prompt/index.d.ts +7 -0
- package/src/prompt/index.js +17 -0
- package/src/prompt/index.js.map +1 -0
- package/src/prompt/prompt.events.d.ts +17 -0
- package/src/prompt/prompt.events.js +25 -0
- package/src/prompt/prompt.events.js.map +1 -0
- package/src/prompt/prompt.instance.d.ts +30 -0
- package/src/prompt/prompt.instance.js +120 -0
- package/src/prompt/prompt.instance.js.map +1 -0
- package/src/prompt/prompt.registry.d.ts +79 -12
- package/src/prompt/prompt.registry.js +360 -15
- package/src/prompt/prompt.registry.js.map +1 -1
- package/src/prompt/prompt.types.d.ts +26 -0
- package/src/prompt/prompt.types.js +11 -0
- package/src/prompt/prompt.types.js.map +1 -0
- package/src/prompt/prompt.utils.d.ts +26 -0
- package/src/prompt/prompt.utils.js +136 -0
- package/src/prompt/prompt.utils.js.map +1 -0
- package/src/provider/provider.registry.d.ts +12 -5
- package/src/provider/provider.registry.js +30 -138
- package/src/provider/provider.registry.js.map +1 -1
- package/src/regsitry/registry.base.d.ts +1 -1
- package/src/regsitry/registry.base.js.map +1 -1
- package/src/resource/flows/read-resource.flow.d.ts +91 -0
- package/src/resource/flows/read-resource.flow.js +270 -0
- package/src/resource/flows/read-resource.flow.js.map +1 -0
- package/src/resource/flows/resource-templates-list.flow.d.ts +64 -0
- package/src/resource/flows/resource-templates-list.flow.js +191 -0
- package/src/resource/flows/resource-templates-list.flow.js.map +1 -0
- package/src/resource/flows/resources-list.flow.d.ts +64 -0
- package/src/resource/flows/resources-list.flow.js +196 -0
- package/src/resource/flows/resources-list.flow.js.map +1 -0
- package/src/resource/flows/subscribe-resource.flow.d.ts +45 -0
- package/src/resource/flows/subscribe-resource.flow.js +123 -0
- package/src/resource/flows/subscribe-resource.flow.js.map +1 -0
- package/src/resource/flows/unsubscribe-resource.flow.d.ts +44 -0
- package/src/resource/flows/unsubscribe-resource.flow.js +107 -0
- package/src/resource/flows/unsubscribe-resource.flow.js.map +1 -0
- package/src/resource/index.d.ts +8 -0
- package/src/resource/index.js +20 -0
- package/src/resource/index.js.map +1 -0
- package/src/resource/resource.events.d.ts +24 -0
- package/src/resource/resource.events.js +17 -0
- package/src/resource/resource.events.js.map +1 -0
- package/src/resource/resource.instance.d.ts +35 -0
- package/src/resource/resource.instance.js +163 -0
- package/src/resource/resource.instance.js.map +1 -0
- package/src/resource/resource.registry.d.ts +106 -12
- package/src/resource/resource.registry.js +449 -13
- package/src/resource/resource.registry.js.map +1 -1
- package/src/resource/resource.types.d.ts +35 -0
- package/src/resource/resource.types.js +11 -0
- package/src/resource/resource.types.js.map +1 -0
- package/src/resource/resource.utils.d.ts +30 -0
- package/src/resource/resource.utils.js +151 -0
- package/src/resource/resource.utils.js.map +1 -0
- package/src/scope/flows/http.request.flow.d.ts +48 -330
- package/src/scope/flows/http.request.flow.js +306 -78
- package/src/scope/flows/http.request.flow.js.map +1 -1
- package/src/scope/scope.instance.d.ts +12 -0
- package/src/scope/scope.instance.js +145 -15
- package/src/scope/scope.instance.js.map +1 -1
- package/src/tool/flows/call-tool.flow.d.ts +64 -1110
- package/src/tool/flows/call-tool.flow.js +303 -15
- package/src/tool/flows/call-tool.flow.js.map +1 -1
- package/src/tool/flows/tools-list.flow.d.ts +32 -473
- package/src/tool/flows/tools-list.flow.js +111 -10
- package/src/tool/flows/tools-list.flow.js.map +1 -1
- package/src/tool/tool.events.d.ts +8 -1
- package/src/tool/tool.events.js.map +1 -1
- package/src/tool/tool.instance.d.ts +3 -1
- package/src/tool/tool.instance.js +17 -3
- package/src/tool/tool.instance.js.map +1 -1
- package/src/tool/tool.registry.d.ts +7 -1
- package/src/tool/tool.registry.js +26 -10
- package/src/tool/tool.registry.js.map +1 -1
- package/src/tool/tool.types.d.ts +4 -4
- package/src/tool/tool.types.js.map +1 -1
- package/src/tool/tool.utils.d.ts +3 -12
- package/src/tool/tool.utils.js +39 -193
- package/src/tool/tool.utils.js.map +1 -1
- package/src/tool/ui/index.d.ts +22 -0
- package/src/tool/ui/index.js +63 -0
- package/src/tool/ui/index.js.map +1 -0
- package/src/tool/ui/platform-adapters.d.ts +10 -0
- package/src/tool/ui/platform-adapters.js +18 -0
- package/src/tool/ui/platform-adapters.js.map +1 -0
- package/src/tool/ui/template-helpers.d.ts +46 -0
- package/src/tool/ui/template-helpers.js +112 -0
- package/src/tool/ui/template-helpers.js.map +1 -0
- package/src/tool/ui/ui-resource-template.d.ts +34 -0
- package/src/tool/ui/ui-resource-template.js +64 -0
- package/src/tool/ui/ui-resource-template.js.map +1 -0
- package/src/tool/ui/ui-resource.handler.d.ts +74 -0
- package/src/tool/ui/ui-resource.handler.js +129 -0
- package/src/tool/ui/ui-resource.handler.js.map +1 -0
- package/src/transport/adapters/transport.local.adapter.d.ts +2 -2
- package/src/transport/adapters/transport.local.adapter.js +28 -7
- package/src/transport/adapters/transport.local.adapter.js.map +1 -1
- package/src/transport/adapters/transport.sse.adapter.d.ts +2 -2
- package/src/transport/adapters/transport.sse.adapter.js +4 -3
- package/src/transport/adapters/transport.sse.adapter.js.map +1 -1
- package/src/transport/adapters/transport.streamable-http.adapter.d.ts +10 -3
- package/src/transport/adapters/transport.streamable-http.adapter.js +54 -8
- package/src/transport/adapters/transport.streamable-http.adapter.js.map +1 -1
- package/src/transport/flows/handle.sse.flow.d.ts +29 -63
- package/src/transport/flows/handle.sse.flow.js +78 -10
- package/src/transport/flows/handle.sse.flow.js.map +1 -1
- package/src/transport/flows/handle.stateless-http.flow.d.ts +29 -0
- package/src/transport/flows/handle.stateless-http.flow.js +102 -0
- package/src/transport/flows/handle.stateless-http.flow.js.map +1 -0
- package/src/transport/flows/handle.streamable-http.flow.d.ts +32 -64
- package/src/transport/flows/handle.streamable-http.flow.js +158 -26
- package/src/transport/flows/handle.streamable-http.flow.js.map +1 -1
- package/src/transport/legacy/legacy.sse.tranporter.d.ts +9 -0
- package/src/transport/legacy/legacy.sse.tranporter.js +17 -2
- package/src/transport/legacy/legacy.sse.tranporter.js.map +1 -1
- package/src/transport/mcp-handlers/call-tool-request.handler.js +27 -1
- package/src/transport/mcp-handlers/call-tool-request.handler.js.map +1 -1
- package/src/transport/mcp-handlers/complete-request.handler.d.ts +69 -0
- package/src/transport/mcp-handlers/complete-request.handler.js +11 -0
- package/src/transport/mcp-handlers/complete-request.handler.js.map +1 -0
- package/src/transport/mcp-handlers/get-prompt-request.handler.d.ts +87 -0
- package/src/transport/mcp-handlers/get-prompt-request.handler.js +11 -0
- package/src/transport/mcp-handlers/get-prompt-request.handler.js.map +1 -0
- package/src/transport/mcp-handlers/index.d.ts +517 -208
- package/src/transport/mcp-handlers/index.js +39 -2
- package/src/transport/mcp-handlers/index.js.map +1 -1
- package/src/transport/mcp-handlers/initialize-request.handler.d.ts +1 -1
- package/src/transport/mcp-handlers/initialize-request.handler.js +73 -7
- package/src/transport/mcp-handlers/initialize-request.handler.js.map +1 -1
- package/src/transport/mcp-handlers/list-prompts-request.handler.d.ts +54 -0
- package/src/transport/mcp-handlers/list-prompts-request.handler.js +11 -0
- package/src/transport/mcp-handlers/list-prompts-request.handler.js.map +1 -0
- package/src/transport/mcp-handlers/list-resource-templates-request.handler.d.ts +51 -0
- package/src/transport/mcp-handlers/list-resource-templates-request.handler.js +12 -0
- package/src/transport/mcp-handlers/list-resource-templates-request.handler.js.map +1 -0
- package/src/transport/mcp-handlers/list-resources-request.handler.d.ts +51 -0
- package/src/transport/mcp-handlers/list-resources-request.handler.js +12 -0
- package/src/transport/mcp-handlers/list-resources-request.handler.js.map +1 -0
- package/src/transport/mcp-handlers/list-tools-request.handler.d.ts +19 -146
- package/src/transport/mcp-handlers/logging-set-level-request.handler.d.ts +46 -0
- package/src/transport/mcp-handlers/logging-set-level-request.handler.js +34 -0
- package/src/transport/mcp-handlers/logging-set-level-request.handler.js.map +1 -0
- package/src/transport/mcp-handlers/mcp-handlers.types.d.ts +3 -7
- package/src/transport/mcp-handlers/mcp-handlers.types.js.map +1 -1
- package/src/transport/mcp-handlers/read-resource-request.handler.d.ts +46 -0
- package/src/transport/mcp-handlers/read-resource-request.handler.js +12 -0
- package/src/transport/mcp-handlers/read-resource-request.handler.js.map +1 -0
- package/src/transport/mcp-handlers/roots-list-changed-notification.handler.d.ts +11 -0
- package/src/transport/mcp-handlers/roots-list-changed-notification.handler.js +26 -0
- package/src/transport/mcp-handlers/roots-list-changed-notification.handler.js.map +1 -0
- package/src/transport/mcp-handlers/subscribe-request.handler.d.ts +37 -0
- package/src/transport/mcp-handlers/subscribe-request.handler.js +34 -0
- package/src/transport/mcp-handlers/subscribe-request.handler.js.map +1 -0
- package/src/transport/mcp-handlers/unsubscribe-request.handler.d.ts +37 -0
- package/src/transport/mcp-handlers/unsubscribe-request.handler.js +34 -0
- package/src/transport/mcp-handlers/unsubscribe-request.handler.js.map +1 -0
- package/src/transport/transport.local.js +7 -2
- package/src/transport/transport.local.js.map +1 -1
- package/src/transport/transport.registry.d.ts +30 -0
- package/src/transport/transport.registry.js +84 -1
- package/src/transport/transport.registry.js.map +1 -1
- package/src/transport/transport.types.d.ts +3 -3
- package/src/transport/transport.types.js.map +1 -1
- package/src/utils/content.utils.d.ts +48 -0
- package/src/utils/content.utils.js +194 -0
- package/src/utils/content.utils.js.map +1 -0
- package/src/utils/index.d.ts +8 -0
- package/src/utils/index.js +55 -0
- package/src/utils/index.js.map +1 -0
- package/src/utils/lineage.utils.d.ts +40 -0
- package/src/utils/lineage.utils.js +82 -0
- package/src/utils/lineage.utils.js.map +1 -0
- package/src/utils/naming.utils.d.ts +46 -0
- package/src/utils/naming.utils.js +136 -0
- package/src/utils/naming.utils.js.map +1 -0
- package/src/utils/types.utils.d.ts +2 -2
- package/src/utils/types.utils.js.map +1 -1
- package/src/utils/uri-template.utils.d.ts +57 -0
- package/src/utils/uri-template.utils.js +113 -0
- package/src/utils/uri-template.utils.js.map +1 -0
- package/src/utils/uri-validation.utils.d.ts +40 -0
- package/src/utils/uri-validation.utils.js +76 -0
- package/src/utils/uri-validation.utils.js.map +1 -0
- package/src/__test-utils__/fixtures/hook.fixtures.d.ts +0 -46
- package/src/__test-utils__/fixtures/hook.fixtures.js +0 -114
- package/src/__test-utils__/fixtures/hook.fixtures.js.map +0 -1
- package/src/__test-utils__/fixtures/index.d.ts +0 -7
- package/src/__test-utils__/fixtures/index.js +0 -11
- package/src/__test-utils__/fixtures/index.js.map +0 -1
- package/src/__test-utils__/fixtures/plugin.fixtures.d.ts +0 -46
- package/src/__test-utils__/fixtures/plugin.fixtures.js +0 -127
- package/src/__test-utils__/fixtures/plugin.fixtures.js.map +0 -1
- package/src/__test-utils__/fixtures/provider.fixtures.d.ts +0 -69
- package/src/__test-utils__/fixtures/provider.fixtures.js +0 -131
- package/src/__test-utils__/fixtures/provider.fixtures.js.map +0 -1
- package/src/__test-utils__/fixtures/scope.fixtures.d.ts +0 -14
- package/src/__test-utils__/fixtures/scope.fixtures.js +0 -59
- package/src/__test-utils__/fixtures/scope.fixtures.js.map +0 -1
- package/src/__test-utils__/fixtures/tool.fixtures.d.ts +0 -36
- package/src/__test-utils__/fixtures/tool.fixtures.js +0 -91
- package/src/__test-utils__/fixtures/tool.fixtures.js.map +0 -1
- package/src/__test-utils__/helpers/assertion.helpers.d.ts +0 -45
- package/src/__test-utils__/helpers/assertion.helpers.js +0 -153
- package/src/__test-utils__/helpers/assertion.helpers.js.map +0 -1
- package/src/__test-utils__/helpers/async.helpers.d.ts +0 -48
- package/src/__test-utils__/helpers/async.helpers.js +0 -112
- package/src/__test-utils__/helpers/async.helpers.js.map +0 -1
- package/src/__test-utils__/helpers/index.d.ts +0 -6
- package/src/__test-utils__/helpers/index.js +0 -10
- package/src/__test-utils__/helpers/index.js.map +0 -1
- package/src/__test-utils__/helpers/setup.helpers.d.ts +0 -54
- package/src/__test-utils__/helpers/setup.helpers.js +0 -106
- package/src/__test-utils__/helpers/setup.helpers.js.map +0 -1
- package/src/__test-utils__/index.d.ts +0 -9
- package/src/__test-utils__/index.js +0 -14
- package/src/__test-utils__/index.js.map +0 -1
- package/src/__test-utils__/mocks/flow-instance.mock.d.ts +0 -50
- package/src/__test-utils__/mocks/flow-instance.mock.js +0 -72
- package/src/__test-utils__/mocks/flow-instance.mock.js.map +0 -1
- package/src/__test-utils__/mocks/hook-registry.mock.d.ts +0 -25
- package/src/__test-utils__/mocks/hook-registry.mock.js +0 -65
- package/src/__test-utils__/mocks/hook-registry.mock.js.map +0 -1
- package/src/__test-utils__/mocks/index.d.ts +0 -8
- package/src/__test-utils__/mocks/index.js +0 -12
- package/src/__test-utils__/mocks/index.js.map +0 -1
- package/src/__test-utils__/mocks/plugin-registry.mock.d.ts +0 -43
- package/src/__test-utils__/mocks/plugin-registry.mock.js +0 -70
- package/src/__test-utils__/mocks/plugin-registry.mock.js.map +0 -1
- package/src/__test-utils__/mocks/provider-registry.mock.d.ts +0 -39
- package/src/__test-utils__/mocks/provider-registry.mock.js +0 -72
- package/src/__test-utils__/mocks/provider-registry.mock.js.map +0 -1
- package/src/__test-utils__/mocks/tool-registry.mock.d.ts +0 -43
- package/src/__test-utils__/mocks/tool-registry.mock.js +0 -79
- package/src/__test-utils__/mocks/tool-registry.mock.js.map +0 -1
- package/src/auth/path.utils.d.ts +0 -20
- package/src/auth/path.utils.js +0 -71
- package/src/auth/path.utils.js.map +0 -1
- package/src/common/decorators-old/async-with.decorator.d.ts +0 -10
- package/src/common/decorators-old/async-with.decorator.js +0 -24
- package/src/common/decorators-old/async-with.decorator.js.map +0 -1
- package/src/common/decorators-old/auth-hook.decorator.d.ts +0 -14
- package/src/common/decorators-old/auth-hook.decorator.js +0 -27
- package/src/common/decorators-old/auth-hook.decorator.js.map +0 -1
- package/src/common/decorators-old/session-hook.decorator.d.ts +0 -14
- package/src/common/decorators-old/session-hook.decorator.js +0 -27
- package/src/common/decorators-old/session-hook.decorator.js.map +0 -1
|
@@ -1,72 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/// <reference types="jest" />
|
|
3
|
-
/**
|
|
4
|
-
* Mock factory for FlowInstance
|
|
5
|
-
*/
|
|
6
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
-
exports.createMockFlowInstance = createMockFlowInstance;
|
|
8
|
-
exports.createMockFlowContext = createMockFlowContext;
|
|
9
|
-
exports.createMockStageHandler = createMockStageHandler;
|
|
10
|
-
/**
|
|
11
|
-
* Creates a mock FlowInstance for testing
|
|
12
|
-
*/
|
|
13
|
-
function createMockFlowInstance(overrides = {}) {
|
|
14
|
-
const stages = new Map();
|
|
15
|
-
return {
|
|
16
|
-
stages,
|
|
17
|
-
name: 'TestFlow',
|
|
18
|
-
metadata: {
|
|
19
|
-
name: 'TestFlow',
|
|
20
|
-
stages: ['pre', 'execute', 'post', 'finalize'],
|
|
21
|
-
},
|
|
22
|
-
execute: jest.fn(async (context) => {
|
|
23
|
-
return { success: true, result: 'mock result' };
|
|
24
|
-
}),
|
|
25
|
-
addStage: jest.fn((stageName, handler) => {
|
|
26
|
-
stages.set(stageName, handler);
|
|
27
|
-
}),
|
|
28
|
-
getStage: jest.fn((stageName) => {
|
|
29
|
-
return stages.get(stageName);
|
|
30
|
-
}),
|
|
31
|
-
hasStage: jest.fn((stageName) => {
|
|
32
|
-
return stages.has(stageName);
|
|
33
|
-
}),
|
|
34
|
-
run: jest.fn(async (context) => {
|
|
35
|
-
// Mock run implementation
|
|
36
|
-
return context;
|
|
37
|
-
}),
|
|
38
|
-
...overrides,
|
|
39
|
-
};
|
|
40
|
-
}
|
|
41
|
-
/**
|
|
42
|
-
* Creates a mock flow context
|
|
43
|
-
*/
|
|
44
|
-
function createMockFlowContext(overrides = {}) {
|
|
45
|
-
return {
|
|
46
|
-
flowName: 'TestFlow',
|
|
47
|
-
stage: 'execute',
|
|
48
|
-
data: {},
|
|
49
|
-
result: undefined,
|
|
50
|
-
error: undefined,
|
|
51
|
-
respond: jest.fn((result) => {
|
|
52
|
-
return { responded: true, result };
|
|
53
|
-
}),
|
|
54
|
-
fail: jest.fn((error) => {
|
|
55
|
-
return { failed: true, error };
|
|
56
|
-
}),
|
|
57
|
-
abort: jest.fn(() => {
|
|
58
|
-
return { aborted: true };
|
|
59
|
-
}),
|
|
60
|
-
next: jest.fn(async () => {
|
|
61
|
-
return { continued: true };
|
|
62
|
-
}),
|
|
63
|
-
...overrides,
|
|
64
|
-
};
|
|
65
|
-
}
|
|
66
|
-
/**
|
|
67
|
-
* Creates a mock stage handler
|
|
68
|
-
*/
|
|
69
|
-
function createMockStageHandler(implementation) {
|
|
70
|
-
return jest.fn(implementation || (async (ctx) => ctx));
|
|
71
|
-
}
|
|
72
|
-
//# sourceMappingURL=flow-instance.mock.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"flow-instance.mock.js","sourceRoot":"","sources":["../../../../src/__test-utils__/mocks/flow-instance.mock.ts"],"names":[],"mappings":";AAAA,8BAA8B;AAC9B;;GAEG;;AAKH,wDAkCC;AAKD,sDA0BC;AAKD,wDAEC;AA3ED;;GAEG;AACH,SAAgB,sBAAsB,CAAC,YAA0B,EAAE;IACjE,MAAM,MAAM,GAAG,IAAI,GAAG,EAAe,CAAC;IAEtC,OAAO;QACL,MAAM;QACN,IAAI,EAAE,UAAU;QAChB,QAAQ,EAAE;YACR,IAAI,EAAE,UAAU;YAChB,MAAM,EAAE,CAAC,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,UAAU,CAAC;SAC/C;QAED,OAAO,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,OAAY,EAAE,EAAE;YACtC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,aAAa,EAAE,CAAC;QAClD,CAAC,CAAC;QAEF,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,SAAiB,EAAE,OAAY,EAAE,EAAE;YACpD,MAAM,CAAC,GAAG,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;QACjC,CAAC,CAAC;QAEF,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,SAAiB,EAAE,EAAE;YACtC,OAAO,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAC/B,CAAC,CAAC;QAEF,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,SAAiB,EAAE,EAAE;YACtC,OAAO,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAC/B,CAAC,CAAC;QAEF,GAAG,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,OAAY,EAAE,EAAE;YAClC,0BAA0B;YAC1B,OAAO,OAAO,CAAC;QACjB,CAAC,CAAC;QAEF,GAAG,SAAS;KACb,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,SAAgB,qBAAqB,CAAC,YAA0B,EAAE;IAChE,OAAO;QACL,QAAQ,EAAE,UAAU;QACpB,KAAK,EAAE,SAAS;QAChB,IAAI,EAAE,EAAE;QACR,MAAM,EAAE,SAAS;QACjB,KAAK,EAAE,SAAS;QAEhB,OAAO,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,MAAW,EAAE,EAAE;YAC/B,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;QACrC,CAAC,CAAC;QAEF,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,KAAU,EAAE,EAAE;YAC3B,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;QACjC,CAAC,CAAC;QAEF,KAAK,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE;YAClB,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;QAC3B,CAAC,CAAC;QAEF,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,IAAI,EAAE;YACvB,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;QAC7B,CAAC,CAAC;QAEF,GAAG,SAAS;KACb,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,SAAgB,sBAAsB,CAAC,cAA2C;IAChF,OAAO,IAAI,CAAC,EAAE,CAAC,cAAc,IAAI,CAAC,KAAK,EAAE,GAAQ,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;AAC9D,CAAC","sourcesContent":["/// <reference types=\"jest\" />\n/**\n * Mock factory for FlowInstance\n */\n\n/**\n * Creates a mock FlowInstance for testing\n */\nexport function createMockFlowInstance(overrides: Partial<any> = {}) {\n const stages = new Map<string, any>();\n\n return {\n stages,\n name: 'TestFlow',\n metadata: {\n name: 'TestFlow',\n stages: ['pre', 'execute', 'post', 'finalize'],\n },\n\n execute: jest.fn(async (context: any) => {\n return { success: true, result: 'mock result' };\n }),\n\n addStage: jest.fn((stageName: string, handler: any) => {\n stages.set(stageName, handler);\n }),\n\n getStage: jest.fn((stageName: string) => {\n return stages.get(stageName);\n }),\n\n hasStage: jest.fn((stageName: string) => {\n return stages.has(stageName);\n }),\n\n run: jest.fn(async (context: any) => {\n // Mock run implementation\n return context;\n }),\n\n ...overrides,\n };\n}\n\n/**\n * Creates a mock flow context\n */\nexport function createMockFlowContext(overrides: Partial<any> = {}) {\n return {\n flowName: 'TestFlow',\n stage: 'execute',\n data: {},\n result: undefined,\n error: undefined,\n\n respond: jest.fn((result: any) => {\n return { responded: true, result };\n }),\n\n fail: jest.fn((error: any) => {\n return { failed: true, error };\n }),\n\n abort: jest.fn(() => {\n return { aborted: true };\n }),\n\n next: jest.fn(async () => {\n return { continued: true };\n }),\n\n ...overrides,\n };\n}\n\n/**\n * Creates a mock stage handler\n */\nexport function createMockStageHandler(implementation?: (ctx: any) => Promise<any>) {\n return jest.fn(implementation || (async (ctx: any) => ctx));\n}\n"]}
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Mock factory for HookRegistry
|
|
3
|
-
*/
|
|
4
|
-
import { HookMetadata } from '../../common/metadata';
|
|
5
|
-
/**
|
|
6
|
-
* Creates a mock HookRegistry for testing
|
|
7
|
-
*/
|
|
8
|
-
export declare function createMockHookRegistry(overrides?: Partial<any>): {
|
|
9
|
-
hooks: HookMetadata<keyof ExtendFlows, string, any>[];
|
|
10
|
-
register: jest.Mock<HookMetadata<keyof ExtendFlows, string, any>, [hookMetadata: HookMetadata<keyof ExtendFlows, string, any>], any>;
|
|
11
|
-
getHooks: jest.Mock<HookMetadata<keyof ExtendFlows, string, any>[], [], any>;
|
|
12
|
-
getHooksForFlow: jest.Mock<HookMetadata<keyof ExtendFlows, string, any>[], [flowName: string], any>;
|
|
13
|
-
getHooksForStage: jest.Mock<HookMetadata<keyof ExtendFlows, string, any>[], [flowName: string, stage: string], any>;
|
|
14
|
-
getHooksByPriority: jest.Mock<HookMetadata<keyof ExtendFlows, string, any>[], [flowName: string, stage: string], any>;
|
|
15
|
-
clear: jest.Mock<void, [], any>;
|
|
16
|
-
executeHooks: jest.Mock<Promise<any>, [flowName: string, stage: string, context: any], any>;
|
|
17
|
-
};
|
|
18
|
-
/**
|
|
19
|
-
* Creates a mock hook entry
|
|
20
|
-
*/
|
|
21
|
-
export declare function createMockHookEntry(flowName: string, stage: string, priority?: number): HookMetadata;
|
|
22
|
-
/**
|
|
23
|
-
* Adds a hook to a mock registry
|
|
24
|
-
*/
|
|
25
|
-
export declare function addHookToMock(registry: ReturnType<typeof createMockHookRegistry>, hookMetadata: HookMetadata): void;
|
|
@@ -1,65 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/// <reference types="jest" />
|
|
3
|
-
/**
|
|
4
|
-
* Mock factory for HookRegistry
|
|
5
|
-
*/
|
|
6
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
-
exports.createMockHookRegistry = createMockHookRegistry;
|
|
8
|
-
exports.createMockHookEntry = createMockHookEntry;
|
|
9
|
-
exports.addHookToMock = addHookToMock;
|
|
10
|
-
/**
|
|
11
|
-
* Creates a mock HookRegistry for testing
|
|
12
|
-
*/
|
|
13
|
-
function createMockHookRegistry(overrides = {}) {
|
|
14
|
-
const hooks = [];
|
|
15
|
-
return {
|
|
16
|
-
hooks,
|
|
17
|
-
register: jest.fn((hookMetadata) => {
|
|
18
|
-
hooks.push(hookMetadata);
|
|
19
|
-
return hookMetadata;
|
|
20
|
-
}),
|
|
21
|
-
getHooks: jest.fn(() => hooks),
|
|
22
|
-
getHooksForFlow: jest.fn((flowName) => {
|
|
23
|
-
return hooks.filter((h) => h.flow === flowName);
|
|
24
|
-
}),
|
|
25
|
-
getHooksForStage: jest.fn((flowName, stage) => {
|
|
26
|
-
return hooks.filter((h) => h.flow === flowName && h.stage === stage);
|
|
27
|
-
}),
|
|
28
|
-
getHooksByPriority: jest.fn((flowName, stage) => {
|
|
29
|
-
return hooks
|
|
30
|
-
.filter((h) => h.flow === flowName && h.stage === stage)
|
|
31
|
-
.sort((a, b) => (a.priority || 0) - (b.priority || 0));
|
|
32
|
-
}),
|
|
33
|
-
clear: jest.fn(() => {
|
|
34
|
-
hooks.length = 0;
|
|
35
|
-
}),
|
|
36
|
-
executeHooks: jest.fn(async (flowName, stage, context) => {
|
|
37
|
-
const stageHooks = hooks.filter((h) => h.flow === flowName && h.stage === stage);
|
|
38
|
-
for (const hook of stageHooks) {
|
|
39
|
-
// Mock hook execution
|
|
40
|
-
}
|
|
41
|
-
return context;
|
|
42
|
-
}),
|
|
43
|
-
...overrides,
|
|
44
|
-
};
|
|
45
|
-
}
|
|
46
|
-
/**
|
|
47
|
-
* Creates a mock hook entry
|
|
48
|
-
*/
|
|
49
|
-
function createMockHookEntry(flowName, stage, priority = 0) {
|
|
50
|
-
return {
|
|
51
|
-
type: 'stage',
|
|
52
|
-
flow: flowName,
|
|
53
|
-
stage,
|
|
54
|
-
target: Symbol('MOCK_HOOK'),
|
|
55
|
-
method: 'onStage',
|
|
56
|
-
priority,
|
|
57
|
-
};
|
|
58
|
-
}
|
|
59
|
-
/**
|
|
60
|
-
* Adds a hook to a mock registry
|
|
61
|
-
*/
|
|
62
|
-
function addHookToMock(registry, hookMetadata) {
|
|
63
|
-
registry.hooks.push(hookMetadata);
|
|
64
|
-
}
|
|
65
|
-
//# sourceMappingURL=hook-registry.mock.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"hook-registry.mock.js","sourceRoot":"","sources":["../../../../src/__test-utils__/mocks/hook-registry.mock.ts"],"names":[],"mappings":";AAAA,8BAA8B;AAC9B;;GAEG;;AAOH,wDAyCC;AAKD,kDAaC;AAKD,sCAKC;AAxED;;GAEG;AACH,SAAgB,sBAAsB,CAAC,YAA0B,EAAE;IACjE,MAAM,KAAK,GAAmB,EAAE,CAAC;IAEjC,OAAO;QACL,KAAK;QAEL,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,YAA0B,EAAE,EAAE;YAC/C,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACzB,OAAO,YAAY,CAAC;QACtB,CAAC,CAAC;QAEF,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC;QAE9B,eAAe,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,QAAgB,EAAE,EAAE;YAC5C,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC;QAClD,CAAC,CAAC;QAEF,gBAAgB,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,QAAgB,EAAE,KAAa,EAAE,EAAE;YAC5D,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,IAAI,CAAC,CAAC,KAAK,KAAK,KAAK,CAAC,CAAC;QACvE,CAAC,CAAC;QAEF,kBAAkB,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,QAAgB,EAAE,KAAa,EAAE,EAAE;YAC9D,OAAO,KAAK;iBACT,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,IAAI,CAAC,CAAC,KAAK,KAAK,KAAK,CAAC;iBACvD,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,CAAC,CAAC;QAC3D,CAAC,CAAC;QAEF,KAAK,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE;YAClB,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;QACnB,CAAC,CAAC;QAEF,YAAY,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,QAAgB,EAAE,KAAa,EAAE,OAAY,EAAE,EAAE;YAC5E,MAAM,UAAU,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,IAAI,CAAC,CAAC,KAAK,KAAK,KAAK,CAAC,CAAC;YACjF,KAAK,MAAM,IAAI,IAAI,UAAU,EAAE,CAAC;gBAC9B,sBAAsB;YACxB,CAAC;YACD,OAAO,OAAO,CAAC;QACjB,CAAC,CAAC;QAEF,GAAG,SAAS;KACb,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,SAAgB,mBAAmB,CACjC,QAAgB,EAChB,KAAa,EACb,WAAmB,CAAC;IAEpB,OAAO;QACL,IAAI,EAAE,OAAO;QACb,IAAI,EAAE,QAAe;QACrB,KAAK;QACL,MAAM,EAAE,MAAM,CAAC,WAAW,CAAC;QAC3B,MAAM,EAAE,SAAS;QACjB,QAAQ;KACT,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,SAAgB,aAAa,CAC3B,QAAmD,EACnD,YAA0B;IAE1B,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;AACpC,CAAC","sourcesContent":["/// <reference types=\"jest\" />\n/**\n * Mock factory for HookRegistry\n */\n\nimport { HookMetadata } from '../../common/metadata';\n\n/**\n * Creates a mock HookRegistry for testing\n */\nexport function createMockHookRegistry(overrides: Partial<any> = {}) {\n const hooks: HookMetadata[] = [];\n\n return {\n hooks,\n\n register: jest.fn((hookMetadata: HookMetadata) => {\n hooks.push(hookMetadata);\n return hookMetadata;\n }),\n\n getHooks: jest.fn(() => hooks),\n\n getHooksForFlow: jest.fn((flowName: string) => {\n return hooks.filter((h) => h.flow === flowName);\n }),\n\n getHooksForStage: jest.fn((flowName: string, stage: string) => {\n return hooks.filter((h) => h.flow === flowName && h.stage === stage);\n }),\n\n getHooksByPriority: jest.fn((flowName: string, stage: string) => {\n return hooks\n .filter((h) => h.flow === flowName && h.stage === stage)\n .sort((a, b) => (a.priority || 0) - (b.priority || 0));\n }),\n\n clear: jest.fn(() => {\n hooks.length = 0;\n }),\n\n executeHooks: jest.fn(async (flowName: string, stage: string, context: any) => {\n const stageHooks = hooks.filter((h) => h.flow === flowName && h.stage === stage);\n for (const hook of stageHooks) {\n // Mock hook execution\n }\n return context;\n }),\n\n ...overrides,\n };\n}\n\n/**\n * Creates a mock hook entry\n */\nexport function createMockHookEntry(\n flowName: string,\n stage: string,\n priority: number = 0\n): HookMetadata {\n return {\n type: 'stage',\n flow: flowName as any,\n stage,\n target: Symbol('MOCK_HOOK'),\n method: 'onStage',\n priority,\n };\n}\n\n/**\n * Adds a hook to a mock registry\n */\nexport function addHookToMock(\n registry: ReturnType<typeof createMockHookRegistry>,\n hookMetadata: HookMetadata\n) {\n registry.hooks.push(hookMetadata);\n}\n"]}
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Mock factories for SDK registries and components
|
|
3
|
-
*/
|
|
4
|
-
export * from './provider-registry.mock';
|
|
5
|
-
export * from './flow-instance.mock';
|
|
6
|
-
export * from './hook-registry.mock';
|
|
7
|
-
export * from './tool-registry.mock';
|
|
8
|
-
export * from './plugin-registry.mock';
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/**
|
|
3
|
-
* Mock factories for SDK registries and components
|
|
4
|
-
*/
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
const tslib_1 = require("tslib");
|
|
7
|
-
tslib_1.__exportStar(require("./provider-registry.mock"), exports);
|
|
8
|
-
tslib_1.__exportStar(require("./flow-instance.mock"), exports);
|
|
9
|
-
tslib_1.__exportStar(require("./hook-registry.mock"), exports);
|
|
10
|
-
tslib_1.__exportStar(require("./tool-registry.mock"), exports);
|
|
11
|
-
tslib_1.__exportStar(require("./plugin-registry.mock"), exports);
|
|
12
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/__test-utils__/mocks/index.ts"],"names":[],"mappings":";AAAA;;GAEG;;;AAEH,mEAAyC;AACzC,+DAAqC;AACrC,+DAAqC;AACrC,+DAAqC;AACrC,iEAAuC","sourcesContent":["/**\n * Mock factories for SDK registries and components\n */\n\nexport * from './provider-registry.mock';\nexport * from './flow-instance.mock';\nexport * from './hook-registry.mock';\nexport * from './tool-registry.mock';\nexport * from './plugin-registry.mock';\n"]}
|
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Mock factory for PluginRegistry
|
|
3
|
-
*/
|
|
4
|
-
import { PluginMetadata } from '../../common/metadata';
|
|
5
|
-
/**
|
|
6
|
-
* Creates a mock PluginRegistry for testing
|
|
7
|
-
*/
|
|
8
|
-
export declare function createMockPluginRegistry(overrides?: Partial<any>): {
|
|
9
|
-
plugins: Map<string, any>;
|
|
10
|
-
register: jest.Mock<any, [pluginName: string, plugin: any], any>;
|
|
11
|
-
get: jest.Mock<any, [pluginName: string], any>;
|
|
12
|
-
has: jest.Mock<boolean, [pluginName: string], any>;
|
|
13
|
-
getAll: jest.Mock<any[], [], any>;
|
|
14
|
-
getNames: jest.Mock<string[], [], any>;
|
|
15
|
-
clear: jest.Mock<void, [], any>;
|
|
16
|
-
getProviderRegistry: jest.Mock<null, [], any>;
|
|
17
|
-
getToolRegistry: jest.Mock<null, [], any>;
|
|
18
|
-
getHookRegistry: jest.Mock<null, [], any>;
|
|
19
|
-
};
|
|
20
|
-
/**
|
|
21
|
-
* Creates a mock plugin entry
|
|
22
|
-
*/
|
|
23
|
-
export declare function createMockPluginEntry(name: string, metadata?: Partial<PluginMetadata>): {
|
|
24
|
-
name: string;
|
|
25
|
-
metadata: {
|
|
26
|
-
id?: string;
|
|
27
|
-
name: string;
|
|
28
|
-
description: string;
|
|
29
|
-
providers?: import("@frontmcp/sdk").ProviderType[];
|
|
30
|
-
exports?: import("@frontmcp/sdk").ProviderType[];
|
|
31
|
-
plugins?: import("@frontmcp/sdk").PluginType[];
|
|
32
|
-
adapters?: import("@frontmcp/sdk").AdapterType[];
|
|
33
|
-
tools?: import("@frontmcp/sdk").ToolType[];
|
|
34
|
-
resources?: import("@frontmcp/sdk").ResourceType[];
|
|
35
|
-
prompts?: import("@frontmcp/sdk").PromptType[];
|
|
36
|
-
};
|
|
37
|
-
onInit: jest.Mock<Promise<void>, [], any>;
|
|
38
|
-
onDestroy: jest.Mock<Promise<void>, [], any>;
|
|
39
|
-
};
|
|
40
|
-
/**
|
|
41
|
-
* Adds a plugin to a mock registry
|
|
42
|
-
*/
|
|
43
|
-
export declare function addPluginToMock(registry: ReturnType<typeof createMockPluginRegistry>, name: string, pluginEntry: any): void;
|
|
@@ -1,70 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/// <reference types="jest" />
|
|
3
|
-
/**
|
|
4
|
-
* Mock factory for PluginRegistry
|
|
5
|
-
*/
|
|
6
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
-
exports.createMockPluginRegistry = createMockPluginRegistry;
|
|
8
|
-
exports.createMockPluginEntry = createMockPluginEntry;
|
|
9
|
-
exports.addPluginToMock = addPluginToMock;
|
|
10
|
-
/**
|
|
11
|
-
* Creates a mock PluginRegistry for testing
|
|
12
|
-
*/
|
|
13
|
-
function createMockPluginRegistry(overrides = {}) {
|
|
14
|
-
const plugins = new Map();
|
|
15
|
-
return {
|
|
16
|
-
plugins,
|
|
17
|
-
register: jest.fn((pluginName, plugin) => {
|
|
18
|
-
plugins.set(pluginName, plugin);
|
|
19
|
-
return plugin;
|
|
20
|
-
}),
|
|
21
|
-
get: jest.fn((pluginName) => {
|
|
22
|
-
return plugins.get(pluginName);
|
|
23
|
-
}),
|
|
24
|
-
has: jest.fn((pluginName) => {
|
|
25
|
-
return plugins.has(pluginName);
|
|
26
|
-
}),
|
|
27
|
-
getAll: jest.fn(() => {
|
|
28
|
-
return Array.from(plugins.values());
|
|
29
|
-
}),
|
|
30
|
-
getNames: jest.fn(() => {
|
|
31
|
-
return Array.from(plugins.keys());
|
|
32
|
-
}),
|
|
33
|
-
clear: jest.fn(() => {
|
|
34
|
-
plugins.clear();
|
|
35
|
-
}),
|
|
36
|
-
// Nested registries access
|
|
37
|
-
getProviderRegistry: jest.fn(() => null),
|
|
38
|
-
getToolRegistry: jest.fn(() => null),
|
|
39
|
-
getHookRegistry: jest.fn(() => null),
|
|
40
|
-
...overrides,
|
|
41
|
-
};
|
|
42
|
-
}
|
|
43
|
-
/**
|
|
44
|
-
* Creates a mock plugin entry
|
|
45
|
-
*/
|
|
46
|
-
function createMockPluginEntry(name, metadata) {
|
|
47
|
-
return {
|
|
48
|
-
name,
|
|
49
|
-
metadata: {
|
|
50
|
-
name,
|
|
51
|
-
description: `Mock plugin: ${name}`,
|
|
52
|
-
...metadata,
|
|
53
|
-
},
|
|
54
|
-
onInit: jest.fn(async () => { }),
|
|
55
|
-
onDestroy: jest.fn(async () => { }),
|
|
56
|
-
};
|
|
57
|
-
}
|
|
58
|
-
/**
|
|
59
|
-
* Adds a plugin to a mock registry
|
|
60
|
-
*/
|
|
61
|
-
function addPluginToMock(registry, name, pluginEntry) {
|
|
62
|
-
registry.plugins.set(name, pluginEntry);
|
|
63
|
-
registry.has.mockImplementation((n) => n === name || registry.plugins.has(n));
|
|
64
|
-
registry.get.mockImplementation((n) => {
|
|
65
|
-
if (n === name)
|
|
66
|
-
return pluginEntry;
|
|
67
|
-
return registry.plugins.get(n);
|
|
68
|
-
});
|
|
69
|
-
}
|
|
70
|
-
//# sourceMappingURL=plugin-registry.mock.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"plugin-registry.mock.js","sourceRoot":"","sources":["../../../../src/__test-utils__/mocks/plugin-registry.mock.ts"],"names":[],"mappings":";AAAA,8BAA8B;AAC9B;;GAEG;;AAOH,4DAsCC;AAKD,sDAWC;AAKD,0CAOC;AArED;;GAEG;AACH,SAAgB,wBAAwB,CAAC,YAA0B,EAAE;IACnE,MAAM,OAAO,GAAG,IAAI,GAAG,EAAe,CAAC;IAEvC,OAAO;QACL,OAAO;QAEP,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,UAAkB,EAAE,MAAW,EAAE,EAAE;YACpD,OAAO,CAAC,GAAG,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;YAChC,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC;QAEF,GAAG,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,UAAkB,EAAE,EAAE;YAClC,OAAO,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QACjC,CAAC,CAAC;QAEF,GAAG,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,UAAkB,EAAE,EAAE;YAClC,OAAO,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QACjC,CAAC,CAAC;QAEF,MAAM,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE;YACnB,OAAO,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC;QACtC,CAAC,CAAC;QAEF,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE;YACrB,OAAO,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC;QACpC,CAAC,CAAC;QAEF,KAAK,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE;YAClB,OAAO,CAAC,KAAK,EAAE,CAAC;QAClB,CAAC,CAAC;QAEF,2BAA2B;QAC3B,mBAAmB,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC;QACxC,eAAe,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC;QACpC,eAAe,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC;QAEpC,GAAG,SAAS;KACb,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,SAAgB,qBAAqB,CAAC,IAAY,EAAE,QAAkC;IACpF,OAAO;QACL,IAAI;QACJ,QAAQ,EAAE;YACR,IAAI;YACJ,WAAW,EAAE,gBAAgB,IAAI,EAAE;YACnC,GAAG,QAAQ;SACZ;QACD,MAAM,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,IAAI,EAAE,GAAE,CAAC,CAAC;QAC/B,SAAS,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,IAAI,EAAE,GAAE,CAAC,CAAC;KACnC,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,SAAgB,eAAe,CAAC,QAAqD,EAAE,IAAY,EAAE,WAAgB;IACnH,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC;IACxC,QAAQ,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC,CAAS,EAAE,EAAE,CAAC,CAAC,KAAK,IAAI,IAAI,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IACtF,QAAQ,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC,CAAS,EAAE,EAAE;QAC5C,IAAI,CAAC,KAAK,IAAI;YAAE,OAAO,WAAW,CAAC;QACnC,OAAO,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;AACL,CAAC","sourcesContent":["/// <reference types=\"jest\" />\n/**\n * Mock factory for PluginRegistry\n */\n\nimport { PluginMetadata } from '../../common/metadata';\n\n/**\n * Creates a mock PluginRegistry for testing\n */\nexport function createMockPluginRegistry(overrides: Partial<any> = {}) {\n const plugins = new Map<string, any>();\n\n return {\n plugins,\n\n register: jest.fn((pluginName: string, plugin: any) => {\n plugins.set(pluginName, plugin);\n return plugin;\n }),\n\n get: jest.fn((pluginName: string) => {\n return plugins.get(pluginName);\n }),\n\n has: jest.fn((pluginName: string) => {\n return plugins.has(pluginName);\n }),\n\n getAll: jest.fn(() => {\n return Array.from(plugins.values());\n }),\n\n getNames: jest.fn(() => {\n return Array.from(plugins.keys());\n }),\n\n clear: jest.fn(() => {\n plugins.clear();\n }),\n\n // Nested registries access\n getProviderRegistry: jest.fn(() => null),\n getToolRegistry: jest.fn(() => null),\n getHookRegistry: jest.fn(() => null),\n\n ...overrides,\n };\n}\n\n/**\n * Creates a mock plugin entry\n */\nexport function createMockPluginEntry(name: string, metadata?: Partial<PluginMetadata>) {\n return {\n name,\n metadata: {\n name,\n description: `Mock plugin: ${name}`,\n ...metadata,\n },\n onInit: jest.fn(async () => {}),\n onDestroy: jest.fn(async () => {}),\n };\n}\n\n/**\n * Adds a plugin to a mock registry\n */\nexport function addPluginToMock(registry: ReturnType<typeof createMockPluginRegistry>, name: string, pluginEntry: any) {\n registry.plugins.set(name, pluginEntry);\n registry.has.mockImplementation((n: string) => n === name || registry.plugins.has(n));\n registry.get.mockImplementation((n: string) => {\n if (n === name) return pluginEntry;\n return registry.plugins.get(n);\n });\n}\n"]}
|
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Mock factory for ProviderRegistry
|
|
3
|
-
*/
|
|
4
|
-
import { Token } from '../../common/interfaces';
|
|
5
|
-
import { ProviderScope } from '../../common/metadata';
|
|
6
|
-
/**
|
|
7
|
-
* Creates a mock ProviderRegistry for testing
|
|
8
|
-
*/
|
|
9
|
-
export declare function createMockProviderRegistry(overrides?: Partial<any>): {
|
|
10
|
-
instances: Map<import("../../common/interfaces").Reference<any>, any>;
|
|
11
|
-
defs: Map<import("../../common/interfaces").Reference<any>, any>;
|
|
12
|
-
ready: Promise<void>;
|
|
13
|
-
getProviders: jest.Mock<never[], [], any>;
|
|
14
|
-
get: jest.Mock<any, [token: import("../../common/interfaces").Reference<any>], any>;
|
|
15
|
-
has: jest.Mock<boolean, [token: import("../../common/interfaces").Reference<any>], any>;
|
|
16
|
-
set: jest.Mock<void, [token: import("../../common/interfaces").Reference<any>, value: any], any>;
|
|
17
|
-
resolve: jest.Mock<Promise<any>, [token: import("../../common/interfaces").Reference<any>], any>;
|
|
18
|
-
createViews: jest.Mock<{
|
|
19
|
-
global: Map<import("../../common/interfaces").Reference<any>, any>;
|
|
20
|
-
session: Map<any, any>;
|
|
21
|
-
request: Map<any, any>;
|
|
22
|
-
}, [sessionId?: string | undefined], any>;
|
|
23
|
-
};
|
|
24
|
-
/**
|
|
25
|
-
* Creates a mock provider entry
|
|
26
|
-
*/
|
|
27
|
-
export declare function createMockProviderEntry(token: Token, value: any, scope?: ProviderScope): {
|
|
28
|
-
token: import("../../common/interfaces").Reference<any>;
|
|
29
|
-
value: any;
|
|
30
|
-
scope: ProviderScope;
|
|
31
|
-
metadata: {
|
|
32
|
-
name: string;
|
|
33
|
-
scope: ProviderScope;
|
|
34
|
-
};
|
|
35
|
-
};
|
|
36
|
-
/**
|
|
37
|
-
* Adds a provider to a mock registry
|
|
38
|
-
*/
|
|
39
|
-
export declare function addProviderToMock(registry: ReturnType<typeof createMockProviderRegistry>, token: Token, value: any): void;
|
|
@@ -1,72 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/// <reference types="jest" />
|
|
3
|
-
/**
|
|
4
|
-
* Mock factory for ProviderRegistry
|
|
5
|
-
*/
|
|
6
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
-
exports.createMockProviderRegistry = createMockProviderRegistry;
|
|
8
|
-
exports.createMockProviderEntry = createMockProviderEntry;
|
|
9
|
-
exports.addProviderToMock = addProviderToMock;
|
|
10
|
-
const metadata_1 = require("../../common/metadata");
|
|
11
|
-
/**
|
|
12
|
-
* Creates a mock ProviderRegistry for testing
|
|
13
|
-
*/
|
|
14
|
-
function createMockProviderRegistry(overrides = {}) {
|
|
15
|
-
const instances = new Map();
|
|
16
|
-
const defs = new Map();
|
|
17
|
-
return {
|
|
18
|
-
instances,
|
|
19
|
-
defs,
|
|
20
|
-
ready: Promise.resolve(),
|
|
21
|
-
getProviders: jest.fn(() => []),
|
|
22
|
-
get: jest.fn((token) => {
|
|
23
|
-
if (instances.has(token)) {
|
|
24
|
-
return instances.get(token);
|
|
25
|
-
}
|
|
26
|
-
throw new Error(`Token not found: ${String(token)}`);
|
|
27
|
-
}),
|
|
28
|
-
has: jest.fn((token) => instances.has(token)),
|
|
29
|
-
set: jest.fn((token, value) => {
|
|
30
|
-
instances.set(token, value);
|
|
31
|
-
}),
|
|
32
|
-
resolve: jest.fn(async (token) => {
|
|
33
|
-
if (instances.has(token)) {
|
|
34
|
-
return instances.get(token);
|
|
35
|
-
}
|
|
36
|
-
throw new Error(`Cannot resolve token: ${String(token)}`);
|
|
37
|
-
}),
|
|
38
|
-
createViews: jest.fn((sessionId) => ({
|
|
39
|
-
global: new Map(instances),
|
|
40
|
-
session: new Map(),
|
|
41
|
-
request: new Map(),
|
|
42
|
-
})),
|
|
43
|
-
...overrides,
|
|
44
|
-
};
|
|
45
|
-
}
|
|
46
|
-
/**
|
|
47
|
-
* Creates a mock provider entry
|
|
48
|
-
*/
|
|
49
|
-
function createMockProviderEntry(token, value, scope = metadata_1.ProviderScope.GLOBAL) {
|
|
50
|
-
return {
|
|
51
|
-
token,
|
|
52
|
-
value,
|
|
53
|
-
scope,
|
|
54
|
-
metadata: {
|
|
55
|
-
name: String(token),
|
|
56
|
-
scope,
|
|
57
|
-
},
|
|
58
|
-
};
|
|
59
|
-
}
|
|
60
|
-
/**
|
|
61
|
-
* Adds a provider to a mock registry
|
|
62
|
-
*/
|
|
63
|
-
function addProviderToMock(registry, token, value) {
|
|
64
|
-
registry.instances.set(token, value);
|
|
65
|
-
registry.has.mockImplementation((t) => t === token || registry.instances.has(t));
|
|
66
|
-
registry.get.mockImplementation((t) => {
|
|
67
|
-
if (t === token)
|
|
68
|
-
return value;
|
|
69
|
-
return registry.instances.get(t);
|
|
70
|
-
});
|
|
71
|
-
}
|
|
72
|
-
//# sourceMappingURL=provider-registry.mock.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"provider-registry.mock.js","sourceRoot":"","sources":["../../../../src/__test-utils__/mocks/provider-registry.mock.ts"],"names":[],"mappings":";AAAA,8BAA8B;AAC9B;;GAEG;;AAQH,gEAuCC;AAKD,0DAUC;AAKD,8CAOC;AAvED,oDAAsD;AAEtD;;GAEG;AACH,SAAgB,0BAA0B,CAAC,YAA0B,EAAE;IACrE,MAAM,SAAS,GAAG,IAAI,GAAG,EAAc,CAAC;IACxC,MAAM,IAAI,GAAG,IAAI,GAAG,EAAc,CAAC;IAEnC,OAAO;QACL,SAAS;QACT,IAAI;QACJ,KAAK,EAAE,OAAO,CAAC,OAAO,EAAE;QAExB,YAAY,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC;QAE/B,GAAG,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,KAAY,EAAE,EAAE;YAC5B,IAAI,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC;gBACzB,OAAO,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YAC9B,CAAC;YACD,MAAM,IAAI,KAAK,CAAC,oBAAoB,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QACvD,CAAC,CAAC;QAEF,GAAG,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,KAAY,EAAE,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAEpD,GAAG,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,KAAY,EAAE,KAAU,EAAE,EAAE;YACxC,SAAS,CAAC,GAAG,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAC9B,CAAC,CAAC;QAEF,OAAO,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,KAAY,EAAE,EAAE;YACtC,IAAI,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC;gBACzB,OAAO,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YAC9B,CAAC;YACD,MAAM,IAAI,KAAK,CAAC,yBAAyB,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QAC5D,CAAC,CAAC;QAEF,WAAW,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,SAAkB,EAAE,EAAE,CAAC,CAAC;YAC5C,MAAM,EAAE,IAAI,GAAG,CAAC,SAAS,CAAC;YAC1B,OAAO,EAAE,IAAI,GAAG,EAAE;YAClB,OAAO,EAAE,IAAI,GAAG,EAAE;SACnB,CAAC,CAAC;QAEH,GAAG,SAAS;KACb,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,SAAgB,uBAAuB,CAAC,KAAY,EAAE,KAAU,EAAE,QAAuB,wBAAa,CAAC,MAAM;IAC3G,OAAO;QACL,KAAK;QACL,KAAK;QACL,KAAK;QACL,QAAQ,EAAE;YACR,IAAI,EAAE,MAAM,CAAC,KAAK,CAAC;YACnB,KAAK;SACN;KACF,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,SAAgB,iBAAiB,CAAC,QAAuD,EAAE,KAAY,EAAE,KAAU;IACjH,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IACrC,QAAQ,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC,CAAQ,EAAE,EAAE,CAAC,CAAC,KAAK,KAAK,IAAI,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IACxF,QAAQ,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC,CAAQ,EAAE,EAAE;QAC3C,IAAI,CAAC,KAAK,KAAK;YAAE,OAAO,KAAK,CAAC;QAC9B,OAAO,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IACnC,CAAC,CAAC,CAAC;AACL,CAAC","sourcesContent":["/// <reference types=\"jest\" />\n/**\n * Mock factory for ProviderRegistry\n */\n\nimport { Token } from '../../common/interfaces';\nimport { ProviderScope } from '../../common/metadata';\n\n/**\n * Creates a mock ProviderRegistry for testing\n */\nexport function createMockProviderRegistry(overrides: Partial<any> = {}) {\n const instances = new Map<Token, any>();\n const defs = new Map<Token, any>();\n\n return {\n instances,\n defs,\n ready: Promise.resolve(),\n\n getProviders: jest.fn(() => []),\n\n get: jest.fn((token: Token) => {\n if (instances.has(token)) {\n return instances.get(token);\n }\n throw new Error(`Token not found: ${String(token)}`);\n }),\n\n has: jest.fn((token: Token) => instances.has(token)),\n\n set: jest.fn((token: Token, value: any) => {\n instances.set(token, value);\n }),\n\n resolve: jest.fn(async (token: Token) => {\n if (instances.has(token)) {\n return instances.get(token);\n }\n throw new Error(`Cannot resolve token: ${String(token)}`);\n }),\n\n createViews: jest.fn((sessionId?: string) => ({\n global: new Map(instances),\n session: new Map(),\n request: new Map(),\n })),\n\n ...overrides,\n };\n}\n\n/**\n * Creates a mock provider entry\n */\nexport function createMockProviderEntry(token: Token, value: any, scope: ProviderScope = ProviderScope.GLOBAL) {\n return {\n token,\n value,\n scope,\n metadata: {\n name: String(token),\n scope,\n },\n };\n}\n\n/**\n * Adds a provider to a mock registry\n */\nexport function addProviderToMock(registry: ReturnType<typeof createMockProviderRegistry>, token: Token, value: any) {\n registry.instances.set(token, value);\n registry.has.mockImplementation((t: Token) => t === token || registry.instances.has(t));\n registry.get.mockImplementation((t: Token) => {\n if (t === token) return value;\n return registry.instances.get(t);\n });\n}\n"]}
|
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Mock factory for ToolRegistry
|
|
3
|
-
*/
|
|
4
|
-
import { ToolMetadata } from '../../common/metadata';
|
|
5
|
-
/**
|
|
6
|
-
* Creates a mock ToolRegistry for testing
|
|
7
|
-
*/
|
|
8
|
-
export declare function createMockToolRegistry(overrides?: Partial<any>): {
|
|
9
|
-
tools: Map<string, any>;
|
|
10
|
-
register: jest.Mock<any, [name: string, toolInstance: any], any>;
|
|
11
|
-
get: jest.Mock<any, [name: string], any>;
|
|
12
|
-
has: jest.Mock<boolean, [name: string], any>;
|
|
13
|
-
getAll: jest.Mock<any[], [], any>;
|
|
14
|
-
getNames: jest.Mock<string[], [], any>;
|
|
15
|
-
list: jest.Mock<{
|
|
16
|
-
name: string;
|
|
17
|
-
metadata: any;
|
|
18
|
-
}[], [], any>;
|
|
19
|
-
clear: jest.Mock<void, [], any>;
|
|
20
|
-
call: jest.Mock<Promise<any>, [name: string, input: any], any>;
|
|
21
|
-
};
|
|
22
|
-
/**
|
|
23
|
-
* Creates a mock tool entry
|
|
24
|
-
*/
|
|
25
|
-
export declare function createMockToolEntry(name: string, metadata?: Partial<ToolMetadata>, execute?: (input: any) => Promise<any>): {
|
|
26
|
-
name: string;
|
|
27
|
-
metadata: {
|
|
28
|
-
id?: string;
|
|
29
|
-
name: string;
|
|
30
|
-
description: string;
|
|
31
|
-
inputSchema: import("zod").ZodRawShape;
|
|
32
|
-
rawInputSchema?: import("json-schema").JSONSchema7;
|
|
33
|
-
outputSchema?: import("../../common/metadata").ToolOutputType;
|
|
34
|
-
tags?: string[];
|
|
35
|
-
annotations?: import("../../common/metadata").ToolAnnotations;
|
|
36
|
-
hideFromDiscovery?: boolean;
|
|
37
|
-
};
|
|
38
|
-
execute: jest.Mock<Promise<any>, [input: any], any>;
|
|
39
|
-
};
|
|
40
|
-
/**
|
|
41
|
-
* Adds a tool to a mock registry
|
|
42
|
-
*/
|
|
43
|
-
export declare function addToolToMock(registry: ReturnType<typeof createMockToolRegistry>, name: string, toolEntry: any): void;
|
|
@@ -1,79 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/// <reference types="jest" />
|
|
3
|
-
/**
|
|
4
|
-
* Mock factory for ToolRegistry
|
|
5
|
-
*/
|
|
6
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
-
exports.createMockToolRegistry = createMockToolRegistry;
|
|
8
|
-
exports.createMockToolEntry = createMockToolEntry;
|
|
9
|
-
exports.addToolToMock = addToolToMock;
|
|
10
|
-
/**
|
|
11
|
-
* Creates a mock ToolRegistry for testing
|
|
12
|
-
*/
|
|
13
|
-
function createMockToolRegistry(overrides = {}) {
|
|
14
|
-
const tools = new Map();
|
|
15
|
-
return {
|
|
16
|
-
tools,
|
|
17
|
-
register: jest.fn((name, toolInstance) => {
|
|
18
|
-
tools.set(name, toolInstance);
|
|
19
|
-
return toolInstance;
|
|
20
|
-
}),
|
|
21
|
-
get: jest.fn((name) => {
|
|
22
|
-
return tools.get(name);
|
|
23
|
-
}),
|
|
24
|
-
has: jest.fn((name) => {
|
|
25
|
-
return tools.has(name);
|
|
26
|
-
}),
|
|
27
|
-
getAll: jest.fn(() => {
|
|
28
|
-
return Array.from(tools.values());
|
|
29
|
-
}),
|
|
30
|
-
getNames: jest.fn(() => {
|
|
31
|
-
return Array.from(tools.keys());
|
|
32
|
-
}),
|
|
33
|
-
list: jest.fn(() => {
|
|
34
|
-
return Array.from(tools.entries()).map(([name, tool]) => ({
|
|
35
|
-
name,
|
|
36
|
-
metadata: tool.metadata,
|
|
37
|
-
}));
|
|
38
|
-
}),
|
|
39
|
-
clear: jest.fn(() => {
|
|
40
|
-
tools.clear();
|
|
41
|
-
}),
|
|
42
|
-
call: jest.fn(async (name, input) => {
|
|
43
|
-
const tool = tools.get(name);
|
|
44
|
-
if (!tool) {
|
|
45
|
-
throw new Error(`Tool not found: ${name}`);
|
|
46
|
-
}
|
|
47
|
-
return tool.execute ? await tool.execute(input) : 'mock result';
|
|
48
|
-
}),
|
|
49
|
-
...overrides,
|
|
50
|
-
};
|
|
51
|
-
}
|
|
52
|
-
/**
|
|
53
|
-
* Creates a mock tool entry
|
|
54
|
-
*/
|
|
55
|
-
function createMockToolEntry(name, metadata, execute) {
|
|
56
|
-
return {
|
|
57
|
-
name,
|
|
58
|
-
metadata: {
|
|
59
|
-
name,
|
|
60
|
-
description: `Mock tool: ${name}`,
|
|
61
|
-
inputSchema: {},
|
|
62
|
-
...metadata,
|
|
63
|
-
},
|
|
64
|
-
execute: jest.fn(execute || (async (input) => `Result from ${name}`)),
|
|
65
|
-
};
|
|
66
|
-
}
|
|
67
|
-
/**
|
|
68
|
-
* Adds a tool to a mock registry
|
|
69
|
-
*/
|
|
70
|
-
function addToolToMock(registry, name, toolEntry) {
|
|
71
|
-
registry.tools.set(name, toolEntry);
|
|
72
|
-
registry.has.mockImplementation((n) => n === name || registry.tools.has(n));
|
|
73
|
-
registry.get.mockImplementation((n) => {
|
|
74
|
-
if (n === name)
|
|
75
|
-
return toolEntry;
|
|
76
|
-
return registry.tools.get(n);
|
|
77
|
-
});
|
|
78
|
-
}
|
|
79
|
-
//# sourceMappingURL=tool-registry.mock.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"tool-registry.mock.js","sourceRoot":"","sources":["../../../../src/__test-utils__/mocks/tool-registry.mock.ts"],"names":[],"mappings":";AAAA,8BAA8B;AAC9B;;GAEG;;AAOH,wDAgDC;AAKD,kDAeC;AAKD,sCAOC;AAnFD;;GAEG;AACH,SAAgB,sBAAsB,CAAC,YAA0B,EAAE;IACjE,MAAM,KAAK,GAAG,IAAI,GAAG,EAAe,CAAC;IAErC,OAAO;QACL,KAAK;QAEL,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,IAAY,EAAE,YAAiB,EAAE,EAAE;YACpD,KAAK,CAAC,GAAG,CAAC,IAAI,EAAE,YAAY,CAAC,CAAC;YAC9B,OAAO,YAAY,CAAC;QACtB,CAAC,CAAC;QAEF,GAAG,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,IAAY,EAAE,EAAE;YAC5B,OAAO,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACzB,CAAC,CAAC;QAEF,GAAG,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,IAAY,EAAE,EAAE;YAC5B,OAAO,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACzB,CAAC,CAAC;QAEF,MAAM,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE;YACnB,OAAO,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC;QACpC,CAAC,CAAC;QAEF,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE;YACrB,OAAO,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC;QAClC,CAAC,CAAC;QAEF,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE;YACjB,OAAO,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC;gBACxD,IAAI;gBACJ,QAAQ,EAAE,IAAI,CAAC,QAAQ;aACxB,CAAC,CAAC,CAAC;QACN,CAAC,CAAC;QAEF,KAAK,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE;YAClB,KAAK,CAAC,KAAK,EAAE,CAAC;QAChB,CAAC,CAAC;QAEF,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,IAAY,EAAE,KAAU,EAAE,EAAE;YAC/C,MAAM,IAAI,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAC7B,IAAI,CAAC,IAAI,EAAE,CAAC;gBACV,MAAM,IAAI,KAAK,CAAC,mBAAmB,IAAI,EAAE,CAAC,CAAC;YAC7C,CAAC;YACD,OAAO,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC;QAClE,CAAC,CAAC;QAEF,GAAG,SAAS;KACb,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,SAAgB,mBAAmB,CACjC,IAAY,EACZ,QAAgC,EAChC,OAAsC;IAEtC,OAAO;QACL,IAAI;QACJ,QAAQ,EAAE;YACR,IAAI;YACJ,WAAW,EAAE,cAAc,IAAI,EAAE;YACjC,WAAW,EAAE,EAAE;YACf,GAAG,QAAQ;SACZ;QACD,OAAO,EAAE,IAAI,CAAC,EAAE,CAAC,OAAO,IAAI,CAAC,KAAK,EAAE,KAAU,EAAE,EAAE,CAAC,eAAe,IAAI,EAAE,CAAC,CAAC;KAC3E,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,SAAgB,aAAa,CAAC,QAAmD,EAAE,IAAY,EAAE,SAAc;IAC7G,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;IACpC,QAAQ,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC,CAAS,EAAE,EAAE,CAAC,CAAC,KAAK,IAAI,IAAI,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IACpF,QAAQ,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC,CAAS,EAAE,EAAE;QAC5C,IAAI,CAAC,KAAK,IAAI;YAAE,OAAO,SAAS,CAAC;QACjC,OAAO,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAC/B,CAAC,CAAC,CAAC;AACL,CAAC","sourcesContent":["/// <reference types=\"jest\" />\n/**\n * Mock factory for ToolRegistry\n */\n\nimport { ToolMetadata } from '../../common/metadata';\n\n/**\n * Creates a mock ToolRegistry for testing\n */\nexport function createMockToolRegistry(overrides: Partial<any> = {}) {\n const tools = new Map<string, any>();\n\n return {\n tools,\n\n register: jest.fn((name: string, toolInstance: any) => {\n tools.set(name, toolInstance);\n return toolInstance;\n }),\n\n get: jest.fn((name: string) => {\n return tools.get(name);\n }),\n\n has: jest.fn((name: string) => {\n return tools.has(name);\n }),\n\n getAll: jest.fn(() => {\n return Array.from(tools.values());\n }),\n\n getNames: jest.fn(() => {\n return Array.from(tools.keys());\n }),\n\n list: jest.fn(() => {\n return Array.from(tools.entries()).map(([name, tool]) => ({\n name,\n metadata: tool.metadata,\n }));\n }),\n\n clear: jest.fn(() => {\n tools.clear();\n }),\n\n call: jest.fn(async (name: string, input: any) => {\n const tool = tools.get(name);\n if (!tool) {\n throw new Error(`Tool not found: ${name}`);\n }\n return tool.execute ? await tool.execute(input) : 'mock result';\n }),\n\n ...overrides,\n };\n}\n\n/**\n * Creates a mock tool entry\n */\nexport function createMockToolEntry(\n name: string,\n metadata?: Partial<ToolMetadata>,\n execute?: (input: any) => Promise<any>,\n) {\n return {\n name,\n metadata: {\n name,\n description: `Mock tool: ${name}`,\n inputSchema: {},\n ...metadata,\n },\n execute: jest.fn(execute || (async (input: any) => `Result from ${name}`)),\n };\n}\n\n/**\n * Adds a tool to a mock registry\n */\nexport function addToolToMock(registry: ReturnType<typeof createMockToolRegistry>, name: string, toolEntry: any) {\n registry.tools.set(name, toolEntry);\n registry.has.mockImplementation((n: string) => n === name || registry.tools.has(n));\n registry.get.mockImplementation((n: string) => {\n if (n === name) return toolEntry;\n return registry.tools.get(n);\n });\n}\n"]}
|
package/src/auth/path.utils.d.ts
DELETED
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
import { ServerRequest } from '../common';
|
|
2
|
-
export declare function trimSlashes(s: string): string;
|
|
3
|
-
/** Normalize entryPath (gateway prefix) to "" or "/mcp" */
|
|
4
|
-
export declare function normalizeEntryPrefix(entryPath?: string): string;
|
|
5
|
-
/** Normalize a scope base (per-app or per-auth) to "" or "/app1" */
|
|
6
|
-
export declare function normalizeScopeBase(scopeBase?: string): string;
|
|
7
|
-
/** Join URL path segments with a single slash and no trailing slash */
|
|
8
|
-
export declare function joinPath(...parts: string[]): string;
|
|
9
|
-
export declare function getRequestBaseUrl(req: ServerRequest, entryPath?: string): string;
|
|
10
|
-
export declare function computeIssuer(req: ServerRequest, entryPath: string, scopeBase: string): string;
|
|
11
|
-
export declare function computeResource(req: ServerRequest, entryPath: string, scopeBase: string): string;
|
|
12
|
-
/** Derive a safe provider id from a URL when no id is provided. */
|
|
13
|
-
export declare function urlToSafeId(url: string): string | undefined;
|
|
14
|
-
/**
|
|
15
|
-
* Build all path variants for a given well-known name:
|
|
16
|
-
* - reversed under root: /.well-known/<name><entryPrefix><scopeBase>
|
|
17
|
-
* - in prefix root: <entryPrefix>/.well-known/<name><scopeBase>
|
|
18
|
-
* - in prefix + scope: <entryPrefix><scopeBase>/.well-known/<name>
|
|
19
|
-
*/
|
|
20
|
-
export declare function makeWellKnownPaths(name: string, entryPrefix: string, scopeBase?: string): Set<string>;
|