@frontmcp/sdk 0.4.1 → 0.5.1
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 +110 -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 +336 -1632
- 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 +89 -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 +77 -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 +248 -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 +78 -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 +110 -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 +83 -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 +83 -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 +60 -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 +59 -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 +161 -1112
- 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 +51 -474
- package/src/tool/flows/tools-list.flow.js +121 -40
- 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 +95 -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 +138 -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 +922 -207
- 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 +80 -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 +82 -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 +82 -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 +47 -145
- package/src/transport/mcp-handlers/logging-set-level-request.handler.d.ts +66 -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 +72 -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 +57 -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 +57 -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
|
@@ -0,0 +1,194 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// file: libs/sdk/src/utils/content.utils.ts
|
|
3
|
+
// Content building and sanitization utilities for MCP responses
|
|
4
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
5
|
+
exports.sanitizeToJson = sanitizeToJson;
|
|
6
|
+
exports.toStructuredContent = toStructuredContent;
|
|
7
|
+
exports.buildResourceContent = buildResourceContent;
|
|
8
|
+
exports.inferMimeType = inferMimeType;
|
|
9
|
+
/**
|
|
10
|
+
* Sanitize arbitrary JS values into JSON-safe objects suitable for:
|
|
11
|
+
* - MCP `structuredContent`
|
|
12
|
+
* - JSON.stringify without circular reference errors
|
|
13
|
+
*
|
|
14
|
+
* Rules:
|
|
15
|
+
* - Drop functions and symbols.
|
|
16
|
+
* - BigInt → string.
|
|
17
|
+
* - Date → ISO string.
|
|
18
|
+
* - Error → { name, message, stack }.
|
|
19
|
+
* - Map → plain object.
|
|
20
|
+
* - Set → array.
|
|
21
|
+
* - Protect against circular references via WeakSet.
|
|
22
|
+
*/
|
|
23
|
+
function sanitizeToJson(value) {
|
|
24
|
+
const seen = new WeakSet();
|
|
25
|
+
function sanitize(val) {
|
|
26
|
+
if (typeof val === 'function' || typeof val === 'symbol') {
|
|
27
|
+
return undefined;
|
|
28
|
+
}
|
|
29
|
+
if (typeof val === 'bigint') {
|
|
30
|
+
return val.toString();
|
|
31
|
+
}
|
|
32
|
+
if (val instanceof Date) {
|
|
33
|
+
return val.toISOString();
|
|
34
|
+
}
|
|
35
|
+
if (val instanceof Error) {
|
|
36
|
+
return {
|
|
37
|
+
name: val.name,
|
|
38
|
+
message: val.message,
|
|
39
|
+
stack: val.stack,
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
if (val instanceof Map) {
|
|
43
|
+
const obj = {};
|
|
44
|
+
for (const [k, v] of val.entries()) {
|
|
45
|
+
obj[String(k)] = sanitize(v);
|
|
46
|
+
}
|
|
47
|
+
return obj;
|
|
48
|
+
}
|
|
49
|
+
if (val instanceof Set) {
|
|
50
|
+
return Array.from(val).map(sanitize);
|
|
51
|
+
}
|
|
52
|
+
if (Array.isArray(val)) {
|
|
53
|
+
if (seen.has(val)) {
|
|
54
|
+
return undefined;
|
|
55
|
+
}
|
|
56
|
+
seen.add(val);
|
|
57
|
+
return val.map(sanitize);
|
|
58
|
+
}
|
|
59
|
+
if (val && typeof val === 'object') {
|
|
60
|
+
if (seen.has(val)) {
|
|
61
|
+
// Drop circular references
|
|
62
|
+
return undefined;
|
|
63
|
+
}
|
|
64
|
+
seen.add(val);
|
|
65
|
+
const sanitized = {};
|
|
66
|
+
for (const [key, value] of Object.entries(val)) {
|
|
67
|
+
const clean = sanitize(value);
|
|
68
|
+
if (clean !== undefined) {
|
|
69
|
+
sanitized[key] = clean;
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
return sanitized;
|
|
73
|
+
}
|
|
74
|
+
// Primitives pass through
|
|
75
|
+
return val;
|
|
76
|
+
}
|
|
77
|
+
return sanitize(value);
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* Convert a value to MCP structuredContent format.
|
|
81
|
+
* Returns Record<string, unknown> or undefined (matching MCP's structuredContent type).
|
|
82
|
+
* Primitives and arrays are wrapped in { value: ... }.
|
|
83
|
+
*/
|
|
84
|
+
function toStructuredContent(value) {
|
|
85
|
+
const result = sanitizeToJson(value);
|
|
86
|
+
if (result === undefined || result === null)
|
|
87
|
+
return undefined;
|
|
88
|
+
if (typeof result === 'object' && !Array.isArray(result)) {
|
|
89
|
+
return result;
|
|
90
|
+
}
|
|
91
|
+
// Wrap primitives and arrays in an object
|
|
92
|
+
return { value: result };
|
|
93
|
+
}
|
|
94
|
+
/**
|
|
95
|
+
* Build a resource content item for MCP ReadResourceResult format.
|
|
96
|
+
* Handles both text and binary (blob) content.
|
|
97
|
+
*
|
|
98
|
+
* @param uri - The resource URI
|
|
99
|
+
* @param content - The content to serialize (string, Buffer, object, etc.)
|
|
100
|
+
* @param mimeType - Optional MIME type override
|
|
101
|
+
*/
|
|
102
|
+
function buildResourceContent(uri, content, mimeType) {
|
|
103
|
+
// If content is already in the expected format
|
|
104
|
+
if (content && typeof content === 'object') {
|
|
105
|
+
const obj = content;
|
|
106
|
+
if ('blob' in obj && typeof obj['blob'] === 'string') {
|
|
107
|
+
return {
|
|
108
|
+
uri,
|
|
109
|
+
mimeType: obj['mimeType'] || mimeType,
|
|
110
|
+
blob: obj['blob'],
|
|
111
|
+
};
|
|
112
|
+
}
|
|
113
|
+
if ('text' in obj && typeof obj['text'] === 'string') {
|
|
114
|
+
return {
|
|
115
|
+
uri,
|
|
116
|
+
mimeType: obj['mimeType'] || mimeType,
|
|
117
|
+
text: obj['text'],
|
|
118
|
+
};
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
// Binary content (Buffer, Uint8Array)
|
|
122
|
+
if (Buffer.isBuffer(content) || content instanceof Uint8Array) {
|
|
123
|
+
const buffer = Buffer.isBuffer(content) ? content : Buffer.from(content);
|
|
124
|
+
return {
|
|
125
|
+
uri,
|
|
126
|
+
mimeType: mimeType || 'application/octet-stream',
|
|
127
|
+
blob: buffer.toString('base64'),
|
|
128
|
+
};
|
|
129
|
+
}
|
|
130
|
+
// String content
|
|
131
|
+
if (typeof content === 'string') {
|
|
132
|
+
return {
|
|
133
|
+
uri,
|
|
134
|
+
mimeType: mimeType || 'text/plain',
|
|
135
|
+
text: content,
|
|
136
|
+
};
|
|
137
|
+
}
|
|
138
|
+
// JSON-serializable content
|
|
139
|
+
try {
|
|
140
|
+
return {
|
|
141
|
+
uri,
|
|
142
|
+
mimeType: mimeType || 'application/json',
|
|
143
|
+
text: JSON.stringify(content),
|
|
144
|
+
};
|
|
145
|
+
}
|
|
146
|
+
catch {
|
|
147
|
+
return {
|
|
148
|
+
uri,
|
|
149
|
+
mimeType: mimeType || 'text/plain',
|
|
150
|
+
text: String(content),
|
|
151
|
+
};
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
/**
|
|
155
|
+
* Infer MIME type from file extension or content.
|
|
156
|
+
*/
|
|
157
|
+
function inferMimeType(uri, content) {
|
|
158
|
+
// Try to infer from URI extension
|
|
159
|
+
const ext = uri.split('.').pop()?.toLowerCase();
|
|
160
|
+
const mimeTypes = {
|
|
161
|
+
json: 'application/json',
|
|
162
|
+
xml: 'application/xml',
|
|
163
|
+
html: 'text/html',
|
|
164
|
+
htm: 'text/html',
|
|
165
|
+
css: 'text/css',
|
|
166
|
+
js: 'application/javascript',
|
|
167
|
+
ts: 'application/typescript',
|
|
168
|
+
txt: 'text/plain',
|
|
169
|
+
md: 'text/markdown',
|
|
170
|
+
yaml: 'application/yaml',
|
|
171
|
+
yml: 'application/yaml',
|
|
172
|
+
csv: 'text/csv',
|
|
173
|
+
png: 'image/png',
|
|
174
|
+
jpg: 'image/jpeg',
|
|
175
|
+
jpeg: 'image/jpeg',
|
|
176
|
+
gif: 'image/gif',
|
|
177
|
+
svg: 'image/svg+xml',
|
|
178
|
+
pdf: 'application/pdf',
|
|
179
|
+
};
|
|
180
|
+
if (ext && mimeTypes[ext]) {
|
|
181
|
+
return mimeTypes[ext];
|
|
182
|
+
}
|
|
183
|
+
// Try to infer from content
|
|
184
|
+
if (typeof content === 'string') {
|
|
185
|
+
if (content.trim().startsWith('{') || content.trim().startsWith('[')) {
|
|
186
|
+
return 'application/json';
|
|
187
|
+
}
|
|
188
|
+
if (content.trim().startsWith('<')) {
|
|
189
|
+
return content.includes('<!DOCTYPE html') || content.includes('<html') ? 'text/html' : 'application/xml';
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
return 'text/plain';
|
|
193
|
+
}
|
|
194
|
+
//# sourceMappingURL=content.utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"content.utils.js","sourceRoot":"","sources":["../../../src/utils/content.utils.ts"],"names":[],"mappings":"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","sourcesContent":["// file: libs/sdk/src/utils/content.utils.ts\n// Content building and sanitization utilities for MCP responses\n\n/**\n * Sanitize arbitrary JS values into JSON-safe objects suitable for:\n * - MCP `structuredContent`\n * - JSON.stringify without circular reference errors\n *\n * Rules:\n * - Drop functions and symbols.\n * - BigInt → string.\n * - Date → ISO string.\n * - Error → { name, message, stack }.\n * - Map → plain object.\n * - Set → array.\n * - Protect against circular references via WeakSet.\n */\nexport function sanitizeToJson(value: unknown): unknown {\n const seen = new WeakSet<object>();\n\n function sanitize(val: unknown): unknown {\n if (typeof val === 'function' || typeof val === 'symbol') {\n return undefined;\n }\n\n if (typeof val === 'bigint') {\n return val.toString();\n }\n\n if (val instanceof Date) {\n return val.toISOString();\n }\n\n if (val instanceof Error) {\n return {\n name: val.name,\n message: val.message,\n stack: val.stack,\n };\n }\n\n if (val instanceof Map) {\n const obj: Record<string, unknown> = {};\n for (const [k, v] of val.entries()) {\n obj[String(k)] = sanitize(v);\n }\n return obj;\n }\n\n if (val instanceof Set) {\n return Array.from(val).map(sanitize);\n }\n\n if (Array.isArray(val)) {\n if (seen.has(val)) {\n return undefined;\n }\n seen.add(val);\n return val.map(sanitize);\n }\n\n if (val && typeof val === 'object') {\n if (seen.has(val)) {\n // Drop circular references\n return undefined;\n }\n seen.add(val);\n\n const sanitized: Record<string, unknown> = {};\n for (const [key, value] of Object.entries(val)) {\n const clean = sanitize(value);\n if (clean !== undefined) {\n sanitized[key] = clean;\n }\n }\n return sanitized;\n }\n\n // Primitives pass through\n return val;\n }\n\n return sanitize(value);\n}\n\n/**\n * Convert a value to MCP structuredContent format.\n * Returns Record<string, unknown> or undefined (matching MCP's structuredContent type).\n * Primitives and arrays are wrapped in { value: ... }.\n */\nexport function toStructuredContent(value: unknown): Record<string, unknown> | undefined {\n const result = sanitizeToJson(value);\n if (result === undefined || result === null) return undefined;\n if (typeof result === 'object' && !Array.isArray(result)) {\n return result as Record<string, unknown>;\n }\n // Wrap primitives and arrays in an object\n return { value: result };\n}\n\n/** MCP-compatible text resource content */\nexport type TextContent = {\n uri: string;\n mimeType?: string;\n text: string;\n};\n\n/** MCP-compatible blob resource content */\nexport type BlobContent = {\n uri: string;\n mimeType?: string;\n blob: string;\n};\n\n/** MCP-compatible resource content (text or blob) */\nexport type ResourceContent = TextContent | BlobContent;\n\n/**\n * Build a resource content item for MCP ReadResourceResult format.\n * Handles both text and binary (blob) content.\n *\n * @param uri - The resource URI\n * @param content - The content to serialize (string, Buffer, object, etc.)\n * @param mimeType - Optional MIME type override\n */\nexport function buildResourceContent(uri: string, content: unknown, mimeType?: string): ResourceContent {\n // If content is already in the expected format\n if (content && typeof content === 'object') {\n const obj = content as Record<string, unknown>;\n if ('blob' in obj && typeof obj['blob'] === 'string') {\n return {\n uri,\n mimeType: (obj['mimeType'] as string) || mimeType,\n blob: obj['blob'],\n };\n }\n if ('text' in obj && typeof obj['text'] === 'string') {\n return {\n uri,\n mimeType: (obj['mimeType'] as string) || mimeType,\n text: obj['text'],\n };\n }\n }\n\n // Binary content (Buffer, Uint8Array)\n if (Buffer.isBuffer(content) || content instanceof Uint8Array) {\n const buffer = Buffer.isBuffer(content) ? content : Buffer.from(content);\n return {\n uri,\n mimeType: mimeType || 'application/octet-stream',\n blob: buffer.toString('base64'),\n };\n }\n\n // String content\n if (typeof content === 'string') {\n return {\n uri,\n mimeType: mimeType || 'text/plain',\n text: content,\n };\n }\n\n // JSON-serializable content\n try {\n return {\n uri,\n mimeType: mimeType || 'application/json',\n text: JSON.stringify(content),\n };\n } catch {\n return {\n uri,\n mimeType: mimeType || 'text/plain',\n text: String(content),\n };\n }\n}\n\n/**\n * Infer MIME type from file extension or content.\n */\nexport function inferMimeType(uri: string, content?: unknown): string {\n // Try to infer from URI extension\n const ext = uri.split('.').pop()?.toLowerCase();\n const mimeTypes: Record<string, string> = {\n json: 'application/json',\n xml: 'application/xml',\n html: 'text/html',\n htm: 'text/html',\n css: 'text/css',\n js: 'application/javascript',\n ts: 'application/typescript',\n txt: 'text/plain',\n md: 'text/markdown',\n yaml: 'application/yaml',\n yml: 'application/yaml',\n csv: 'text/csv',\n png: 'image/png',\n jpg: 'image/jpeg',\n jpeg: 'image/jpeg',\n gif: 'image/gif',\n svg: 'image/svg+xml',\n pdf: 'application/pdf',\n };\n\n if (ext && mimeTypes[ext]) {\n return mimeTypes[ext];\n }\n\n // Try to infer from content\n if (typeof content === 'string') {\n if (content.trim().startsWith('{') || content.trim().startsWith('[')) {\n return 'application/json';\n }\n if (content.trim().startsWith('<')) {\n return content.includes('<!DOCTYPE html') || content.includes('<html') ? 'text/html' : 'application/xml';\n }\n }\n\n return 'text/plain';\n}\n"]}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export { NameCase, splitWords, toCase, sepFor, normalizeSegment, normalizeProviderId, normalizeOwnerPath, shortHash, ensureMaxLen, } from './naming.utils';
|
|
2
|
+
export { ownerKeyOf, qualifiedNameOf, parseQualifiedName, lineageDepth, lineagesEqual, isAncestorLineage, } from './lineage.utils';
|
|
3
|
+
export { isValidMcpUri, extractUriScheme, isValidMcpUriTemplate } from './uri-validation.utils';
|
|
4
|
+
export { parseUriTemplate, matchUriTemplate, expandUriTemplate } from './uri-template.utils';
|
|
5
|
+
export { tokenName, isClass, isPromise, depsOfClass, depsOfFunc } from './token.utils';
|
|
6
|
+
export { sanitizeToJson, toStructuredContent, TextContent, BlobContent, ResourceContent, buildResourceContent, inferMimeType, } from './content.utils';
|
|
7
|
+
export { idFromString } from './string.utils';
|
|
8
|
+
export { getMetadata, setMetadata, hasAsyncWith } from './metadata.utils';
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// file: libs/sdk/src/utils/index.ts
|
|
3
|
+
// Centralized exports for SDK utilities
|
|
4
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
5
|
+
exports.hasAsyncWith = exports.setMetadata = exports.getMetadata = exports.idFromString = exports.inferMimeType = exports.buildResourceContent = exports.toStructuredContent = exports.sanitizeToJson = exports.depsOfFunc = exports.depsOfClass = exports.isPromise = exports.isClass = exports.tokenName = exports.expandUriTemplate = exports.matchUriTemplate = exports.parseUriTemplate = exports.isValidMcpUriTemplate = exports.extractUriScheme = exports.isValidMcpUri = exports.isAncestorLineage = exports.lineagesEqual = exports.lineageDepth = exports.parseQualifiedName = exports.qualifiedNameOf = exports.ownerKeyOf = exports.ensureMaxLen = exports.shortHash = exports.normalizeOwnerPath = exports.normalizeProviderId = exports.normalizeSegment = exports.sepFor = exports.toCase = exports.splitWords = void 0;
|
|
6
|
+
// Naming and case conversion utilities
|
|
7
|
+
var naming_utils_1 = require("./naming.utils");
|
|
8
|
+
Object.defineProperty(exports, "splitWords", { enumerable: true, get: function () { return naming_utils_1.splitWords; } });
|
|
9
|
+
Object.defineProperty(exports, "toCase", { enumerable: true, get: function () { return naming_utils_1.toCase; } });
|
|
10
|
+
Object.defineProperty(exports, "sepFor", { enumerable: true, get: function () { return naming_utils_1.sepFor; } });
|
|
11
|
+
Object.defineProperty(exports, "normalizeSegment", { enumerable: true, get: function () { return naming_utils_1.normalizeSegment; } });
|
|
12
|
+
Object.defineProperty(exports, "normalizeProviderId", { enumerable: true, get: function () { return naming_utils_1.normalizeProviderId; } });
|
|
13
|
+
Object.defineProperty(exports, "normalizeOwnerPath", { enumerable: true, get: function () { return naming_utils_1.normalizeOwnerPath; } });
|
|
14
|
+
Object.defineProperty(exports, "shortHash", { enumerable: true, get: function () { return naming_utils_1.shortHash; } });
|
|
15
|
+
Object.defineProperty(exports, "ensureMaxLen", { enumerable: true, get: function () { return naming_utils_1.ensureMaxLen; } });
|
|
16
|
+
// Owner lineage and qualified name utilities
|
|
17
|
+
var lineage_utils_1 = require("./lineage.utils");
|
|
18
|
+
Object.defineProperty(exports, "ownerKeyOf", { enumerable: true, get: function () { return lineage_utils_1.ownerKeyOf; } });
|
|
19
|
+
Object.defineProperty(exports, "qualifiedNameOf", { enumerable: true, get: function () { return lineage_utils_1.qualifiedNameOf; } });
|
|
20
|
+
Object.defineProperty(exports, "parseQualifiedName", { enumerable: true, get: function () { return lineage_utils_1.parseQualifiedName; } });
|
|
21
|
+
Object.defineProperty(exports, "lineageDepth", { enumerable: true, get: function () { return lineage_utils_1.lineageDepth; } });
|
|
22
|
+
Object.defineProperty(exports, "lineagesEqual", { enumerable: true, get: function () { return lineage_utils_1.lineagesEqual; } });
|
|
23
|
+
Object.defineProperty(exports, "isAncestorLineage", { enumerable: true, get: function () { return lineage_utils_1.isAncestorLineage; } });
|
|
24
|
+
// URI validation utilities (RFC 3986)
|
|
25
|
+
var uri_validation_utils_1 = require("./uri-validation.utils");
|
|
26
|
+
Object.defineProperty(exports, "isValidMcpUri", { enumerable: true, get: function () { return uri_validation_utils_1.isValidMcpUri; } });
|
|
27
|
+
Object.defineProperty(exports, "extractUriScheme", { enumerable: true, get: function () { return uri_validation_utils_1.extractUriScheme; } });
|
|
28
|
+
Object.defineProperty(exports, "isValidMcpUriTemplate", { enumerable: true, get: function () { return uri_validation_utils_1.isValidMcpUriTemplate; } });
|
|
29
|
+
// URI template parsing and matching utilities
|
|
30
|
+
var uri_template_utils_1 = require("./uri-template.utils");
|
|
31
|
+
Object.defineProperty(exports, "parseUriTemplate", { enumerable: true, get: function () { return uri_template_utils_1.parseUriTemplate; } });
|
|
32
|
+
Object.defineProperty(exports, "matchUriTemplate", { enumerable: true, get: function () { return uri_template_utils_1.matchUriTemplate; } });
|
|
33
|
+
Object.defineProperty(exports, "expandUriTemplate", { enumerable: true, get: function () { return uri_template_utils_1.expandUriTemplate; } });
|
|
34
|
+
// Token utilities
|
|
35
|
+
var token_utils_1 = require("./token.utils");
|
|
36
|
+
Object.defineProperty(exports, "tokenName", { enumerable: true, get: function () { return token_utils_1.tokenName; } });
|
|
37
|
+
Object.defineProperty(exports, "isClass", { enumerable: true, get: function () { return token_utils_1.isClass; } });
|
|
38
|
+
Object.defineProperty(exports, "isPromise", { enumerable: true, get: function () { return token_utils_1.isPromise; } });
|
|
39
|
+
Object.defineProperty(exports, "depsOfClass", { enumerable: true, get: function () { return token_utils_1.depsOfClass; } });
|
|
40
|
+
Object.defineProperty(exports, "depsOfFunc", { enumerable: true, get: function () { return token_utils_1.depsOfFunc; } });
|
|
41
|
+
// Content utilities
|
|
42
|
+
var content_utils_1 = require("./content.utils");
|
|
43
|
+
Object.defineProperty(exports, "sanitizeToJson", { enumerable: true, get: function () { return content_utils_1.sanitizeToJson; } });
|
|
44
|
+
Object.defineProperty(exports, "toStructuredContent", { enumerable: true, get: function () { return content_utils_1.toStructuredContent; } });
|
|
45
|
+
Object.defineProperty(exports, "buildResourceContent", { enumerable: true, get: function () { return content_utils_1.buildResourceContent; } });
|
|
46
|
+
Object.defineProperty(exports, "inferMimeType", { enumerable: true, get: function () { return content_utils_1.inferMimeType; } });
|
|
47
|
+
// String utilities
|
|
48
|
+
var string_utils_1 = require("./string.utils");
|
|
49
|
+
Object.defineProperty(exports, "idFromString", { enumerable: true, get: function () { return string_utils_1.idFromString; } });
|
|
50
|
+
// Metadata utilities
|
|
51
|
+
var metadata_utils_1 = require("./metadata.utils");
|
|
52
|
+
Object.defineProperty(exports, "getMetadata", { enumerable: true, get: function () { return metadata_utils_1.getMetadata; } });
|
|
53
|
+
Object.defineProperty(exports, "setMetadata", { enumerable: true, get: function () { return metadata_utils_1.setMetadata; } });
|
|
54
|
+
Object.defineProperty(exports, "hasAsyncWith", { enumerable: true, get: function () { return metadata_utils_1.hasAsyncWith; } });
|
|
55
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/utils/index.ts"],"names":[],"mappings":";AAAA,oCAAoC;AACpC,wCAAwC;;;AAExC,uCAAuC;AACvC,+CAUwB;AARtB,0GAAA,UAAU,OAAA;AACV,sGAAA,MAAM,OAAA;AACN,sGAAA,MAAM,OAAA;AACN,gHAAA,gBAAgB,OAAA;AAChB,mHAAA,mBAAmB,OAAA;AACnB,kHAAA,kBAAkB,OAAA;AAClB,yGAAA,SAAS,OAAA;AACT,4GAAA,YAAY,OAAA;AAGd,6CAA6C;AAC7C,iDAOyB;AANvB,2GAAA,UAAU,OAAA;AACV,gHAAA,eAAe,OAAA;AACf,mHAAA,kBAAkB,OAAA;AAClB,6GAAA,YAAY,OAAA;AACZ,8GAAA,aAAa,OAAA;AACb,kHAAA,iBAAiB,OAAA;AAGnB,sCAAsC;AACtC,+DAAgG;AAAvF,qHAAA,aAAa,OAAA;AAAE,wHAAA,gBAAgB,OAAA;AAAE,6HAAA,qBAAqB,OAAA;AAE/D,8CAA8C;AAC9C,2DAA6F;AAApF,sHAAA,gBAAgB,OAAA;AAAE,sHAAA,gBAAgB,OAAA;AAAE,uHAAA,iBAAiB,OAAA;AAE9D,kBAAkB;AAClB,6CAAuF;AAA9E,wGAAA,SAAS,OAAA;AAAE,sGAAA,OAAO,OAAA;AAAE,wGAAA,SAAS,OAAA;AAAE,0GAAA,WAAW,OAAA;AAAE,yGAAA,UAAU,OAAA;AAE/D,oBAAoB;AACpB,iDAQyB;AAPvB,+GAAA,cAAc,OAAA;AACd,oHAAA,mBAAmB,OAAA;AAInB,qHAAA,oBAAoB,OAAA;AACpB,8GAAA,aAAa,OAAA;AAGf,mBAAmB;AACnB,+CAA8C;AAArC,4GAAA,YAAY,OAAA;AAErB,qBAAqB;AACrB,mDAA0E;AAAjE,6GAAA,WAAW,OAAA;AAAE,6GAAA,WAAW,OAAA;AAAE,8GAAA,YAAY,OAAA","sourcesContent":["// file: libs/sdk/src/utils/index.ts\n// Centralized exports for SDK utilities\n\n// Naming and case conversion utilities\nexport {\n NameCase,\n splitWords,\n toCase,\n sepFor,\n normalizeSegment,\n normalizeProviderId,\n normalizeOwnerPath,\n shortHash,\n ensureMaxLen,\n} from './naming.utils';\n\n// Owner lineage and qualified name utilities\nexport {\n ownerKeyOf,\n qualifiedNameOf,\n parseQualifiedName,\n lineageDepth,\n lineagesEqual,\n isAncestorLineage,\n} from './lineage.utils';\n\n// URI validation utilities (RFC 3986)\nexport { isValidMcpUri, extractUriScheme, isValidMcpUriTemplate } from './uri-validation.utils';\n\n// URI template parsing and matching utilities\nexport { parseUriTemplate, matchUriTemplate, expandUriTemplate } from './uri-template.utils';\n\n// Token utilities\nexport { tokenName, isClass, isPromise, depsOfClass, depsOfFunc } from './token.utils';\n\n// Content utilities\nexport {\n sanitizeToJson,\n toStructuredContent,\n TextContent,\n BlobContent,\n ResourceContent,\n buildResourceContent,\n inferMimeType,\n} from './content.utils';\n\n// String utilities\nexport { idFromString } from './string.utils';\n\n// Metadata utilities\nexport { getMetadata, setMetadata, hasAsyncWith } from './metadata.utils';\n"]}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { EntryLineage } from '../common';
|
|
2
|
+
/**
|
|
3
|
+
* Convert an entry lineage to a string key.
|
|
4
|
+
*
|
|
5
|
+
* @example
|
|
6
|
+
* ownerKeyOf([{ kind: 'app', id: 'Portal' }, { kind: 'plugin', id: 'Auth' }])
|
|
7
|
+
* => "app:Portal/plugin:Auth"
|
|
8
|
+
*/
|
|
9
|
+
export declare function ownerKeyOf(lineage: EntryLineage): string;
|
|
10
|
+
/**
|
|
11
|
+
* Create a fully qualified name from lineage and name.
|
|
12
|
+
*
|
|
13
|
+
* @example
|
|
14
|
+
* qualifiedNameOf([{ kind: 'app', id: 'Portal' }], 'myTool')
|
|
15
|
+
* => "app:Portal:myTool"
|
|
16
|
+
*/
|
|
17
|
+
export declare function qualifiedNameOf(lineage: EntryLineage, name: string): string;
|
|
18
|
+
/**
|
|
19
|
+
* Parse a qualified name back into lineage and name.
|
|
20
|
+
*
|
|
21
|
+
* @example
|
|
22
|
+
* parseQualifiedName("app:Portal/plugin:Auth:myTool")
|
|
23
|
+
* => { lineage: [{ kind: 'app', id: 'Portal' }, { kind: 'plugin', id: 'Auth' }], name: 'myTool' }
|
|
24
|
+
*/
|
|
25
|
+
export declare function parseQualifiedName(qualifiedName: string): {
|
|
26
|
+
lineage: EntryLineage;
|
|
27
|
+
name: string;
|
|
28
|
+
} | null;
|
|
29
|
+
/**
|
|
30
|
+
* Get the depth of a lineage (number of owners).
|
|
31
|
+
*/
|
|
32
|
+
export declare function lineageDepth(lineage: EntryLineage): number;
|
|
33
|
+
/**
|
|
34
|
+
* Check if two lineages are equal.
|
|
35
|
+
*/
|
|
36
|
+
export declare function lineagesEqual(a: EntryLineage, b: EntryLineage): boolean;
|
|
37
|
+
/**
|
|
38
|
+
* Check if lineage `a` is an ancestor of lineage `b`.
|
|
39
|
+
*/
|
|
40
|
+
export declare function isAncestorLineage(ancestor: EntryLineage, descendant: EntryLineage): boolean;
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// file: libs/sdk/src/utils/lineage.utils.ts
|
|
3
|
+
// Owner lineage and qualified name utilities
|
|
4
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
5
|
+
exports.ownerKeyOf = ownerKeyOf;
|
|
6
|
+
exports.qualifiedNameOf = qualifiedNameOf;
|
|
7
|
+
exports.parseQualifiedName = parseQualifiedName;
|
|
8
|
+
exports.lineageDepth = lineageDepth;
|
|
9
|
+
exports.lineagesEqual = lineagesEqual;
|
|
10
|
+
exports.isAncestorLineage = isAncestorLineage;
|
|
11
|
+
/**
|
|
12
|
+
* Convert an entry lineage to a string key.
|
|
13
|
+
*
|
|
14
|
+
* @example
|
|
15
|
+
* ownerKeyOf([{ kind: 'app', id: 'Portal' }, { kind: 'plugin', id: 'Auth' }])
|
|
16
|
+
* => "app:Portal/plugin:Auth"
|
|
17
|
+
*/
|
|
18
|
+
function ownerKeyOf(lineage) {
|
|
19
|
+
return lineage.map((o) => `${o.kind}:${o.id}`).join('/');
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Create a fully qualified name from lineage and name.
|
|
23
|
+
*
|
|
24
|
+
* @example
|
|
25
|
+
* qualifiedNameOf([{ kind: 'app', id: 'Portal' }], 'myTool')
|
|
26
|
+
* => "app:Portal:myTool"
|
|
27
|
+
*/
|
|
28
|
+
function qualifiedNameOf(lineage, name) {
|
|
29
|
+
return `${ownerKeyOf(lineage)}:${name}`;
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Parse a qualified name back into lineage and name.
|
|
33
|
+
*
|
|
34
|
+
* @example
|
|
35
|
+
* parseQualifiedName("app:Portal/plugin:Auth:myTool")
|
|
36
|
+
* => { lineage: [{ kind: 'app', id: 'Portal' }, { kind: 'plugin', id: 'Auth' }], name: 'myTool' }
|
|
37
|
+
*/
|
|
38
|
+
function parseQualifiedName(qualifiedName) {
|
|
39
|
+
const lastColon = qualifiedName.lastIndexOf(':');
|
|
40
|
+
if (lastColon === -1)
|
|
41
|
+
return null;
|
|
42
|
+
const ownerKey = qualifiedName.slice(0, lastColon);
|
|
43
|
+
const name = qualifiedName.slice(lastColon + 1);
|
|
44
|
+
const lineage = [];
|
|
45
|
+
const parts = ownerKey.split('/');
|
|
46
|
+
for (const part of parts) {
|
|
47
|
+
const colonIdx = part.indexOf(':');
|
|
48
|
+
if (colonIdx === -1)
|
|
49
|
+
continue;
|
|
50
|
+
const kind = part.slice(0, colonIdx);
|
|
51
|
+
if (kind !== 'scope' && kind !== 'app' && kind !== 'plugin')
|
|
52
|
+
continue;
|
|
53
|
+
const id = part.slice(colonIdx + 1);
|
|
54
|
+
// `ref` is required by EntryOwnerRef but cannot be resolved from string parsing.
|
|
55
|
+
// Callers must resolve the ref from context if needed.
|
|
56
|
+
lineage.push({ kind, id, ref: undefined });
|
|
57
|
+
}
|
|
58
|
+
return { lineage, name };
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* Get the depth of a lineage (number of owners).
|
|
62
|
+
*/
|
|
63
|
+
function lineageDepth(lineage) {
|
|
64
|
+
return lineage.length;
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Check if two lineages are equal.
|
|
68
|
+
*/
|
|
69
|
+
function lineagesEqual(a, b) {
|
|
70
|
+
if (a.length !== b.length)
|
|
71
|
+
return false;
|
|
72
|
+
return a.every((owner, i) => owner.kind === b[i].kind && owner.id === b[i].id);
|
|
73
|
+
}
|
|
74
|
+
/**
|
|
75
|
+
* Check if lineage `a` is an ancestor of lineage `b`.
|
|
76
|
+
*/
|
|
77
|
+
function isAncestorLineage(ancestor, descendant) {
|
|
78
|
+
if (ancestor.length >= descendant.length)
|
|
79
|
+
return false;
|
|
80
|
+
return ancestor.every((owner, i) => owner.kind === descendant[i].kind && owner.id === descendant[i].id);
|
|
81
|
+
}
|
|
82
|
+
//# sourceMappingURL=lineage.utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lineage.utils.js","sourceRoot":"","sources":["../../../src/utils/lineage.utils.ts"],"names":[],"mappings":";AAAA,4CAA4C;AAC5C,6CAA6C;;AAW7C,gCAEC;AASD,0CAEC;AASD,gDAsBC;AAKD,oCAEC;AAKD,sCAGC;AAKD,8CAGC;AA1ED;;;;;;GAMG;AACH,SAAgB,UAAU,CAAC,OAAqB;IAC9C,OAAO,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AAC3D,CAAC;AAED;;;;;;GAMG;AACH,SAAgB,eAAe,CAAC,OAAqB,EAAE,IAAY;IACjE,OAAO,GAAG,UAAU,CAAC,OAAO,CAAC,IAAI,IAAI,EAAE,CAAC;AAC1C,CAAC;AAED;;;;;;GAMG;AACH,SAAgB,kBAAkB,CAAC,aAAqB;IACtD,MAAM,SAAS,GAAG,aAAa,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;IACjD,IAAI,SAAS,KAAK,CAAC,CAAC;QAAE,OAAO,IAAI,CAAC;IAElC,MAAM,QAAQ,GAAG,aAAa,CAAC,KAAK,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;IACnD,MAAM,IAAI,GAAG,aAAa,CAAC,KAAK,CAAC,SAAS,GAAG,CAAC,CAAC,CAAC;IAEhD,MAAM,OAAO,GAAiB,EAAE,CAAC;IACjC,MAAM,KAAK,GAAG,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAElC,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QACzB,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QACnC,IAAI,QAAQ,KAAK,CAAC,CAAC;YAAE,SAAS;QAC9B,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC;QACrC,IAAI,IAAI,KAAK,OAAO,IAAI,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,QAAQ;YAAE,SAAS;QACtE,MAAM,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC;QACpC,iFAAiF;QACjF,uDAAuD;QACvD,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,GAAG,EAAE,SAAgB,EAAE,CAAC,CAAC;IACpD,CAAC;IAED,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;AAC3B,CAAC;AAED;;GAEG;AACH,SAAgB,YAAY,CAAC,OAAqB;IAChD,OAAO,OAAO,CAAC,MAAM,CAAC;AACxB,CAAC;AAED;;GAEG;AACH,SAAgB,aAAa,CAAC,CAAe,EAAE,CAAe;IAC5D,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC,MAAM;QAAE,OAAO,KAAK,CAAC;IACxC,OAAO,CAAC,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,KAAK,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;AACjF,CAAC;AAED;;GAEG;AACH,SAAgB,iBAAiB,CAAC,QAAsB,EAAE,UAAwB;IAChF,IAAI,QAAQ,CAAC,MAAM,IAAI,UAAU,CAAC,MAAM;QAAE,OAAO,KAAK,CAAC;IACvD,OAAO,QAAQ,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,KAAK,UAAU,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,KAAK,CAAC,EAAE,KAAK,UAAU,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;AAC1G,CAAC","sourcesContent":["// file: libs/sdk/src/utils/lineage.utils.ts\n// Owner lineage and qualified name utilities\n\nimport { EntryLineage } from '../common';\n\n/**\n * Convert an entry lineage to a string key.\n *\n * @example\n * ownerKeyOf([{ kind: 'app', id: 'Portal' }, { kind: 'plugin', id: 'Auth' }])\n * => \"app:Portal/plugin:Auth\"\n */\nexport function ownerKeyOf(lineage: EntryLineage): string {\n return lineage.map((o) => `${o.kind}:${o.id}`).join('/');\n}\n\n/**\n * Create a fully qualified name from lineage and name.\n *\n * @example\n * qualifiedNameOf([{ kind: 'app', id: 'Portal' }], 'myTool')\n * => \"app:Portal:myTool\"\n */\nexport function qualifiedNameOf(lineage: EntryLineage, name: string): string {\n return `${ownerKeyOf(lineage)}:${name}`;\n}\n\n/**\n * Parse a qualified name back into lineage and name.\n *\n * @example\n * parseQualifiedName(\"app:Portal/plugin:Auth:myTool\")\n * => { lineage: [{ kind: 'app', id: 'Portal' }, { kind: 'plugin', id: 'Auth' }], name: 'myTool' }\n */\nexport function parseQualifiedName(qualifiedName: string): { lineage: EntryLineage; name: string } | null {\n const lastColon = qualifiedName.lastIndexOf(':');\n if (lastColon === -1) return null;\n\n const ownerKey = qualifiedName.slice(0, lastColon);\n const name = qualifiedName.slice(lastColon + 1);\n\n const lineage: EntryLineage = [];\n const parts = ownerKey.split('/');\n\n for (const part of parts) {\n const colonIdx = part.indexOf(':');\n if (colonIdx === -1) continue;\n const kind = part.slice(0, colonIdx);\n if (kind !== 'scope' && kind !== 'app' && kind !== 'plugin') continue;\n const id = part.slice(colonIdx + 1);\n // `ref` is required by EntryOwnerRef but cannot be resolved from string parsing.\n // Callers must resolve the ref from context if needed.\n lineage.push({ kind, id, ref: undefined as any });\n }\n\n return { lineage, name };\n}\n\n/**\n * Get the depth of a lineage (number of owners).\n */\nexport function lineageDepth(lineage: EntryLineage): number {\n return lineage.length;\n}\n\n/**\n * Check if two lineages are equal.\n */\nexport function lineagesEqual(a: EntryLineage, b: EntryLineage): boolean {\n if (a.length !== b.length) return false;\n return a.every((owner, i) => owner.kind === b[i].kind && owner.id === b[i].id);\n}\n\n/**\n * Check if lineage `a` is an ancestor of lineage `b`.\n */\nexport function isAncestorLineage(ancestor: EntryLineage, descendant: EntryLineage): boolean {\n if (ancestor.length >= descendant.length) return false;\n return ancestor.every((owner, i) => owner.kind === descendant[i].kind && owner.id === descendant[i].id);\n}\n"]}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Supported naming conventions for MCP identifiers
|
|
3
|
+
*/
|
|
4
|
+
export type NameCase = 'snake' | 'kebab' | 'dot' | 'camel';
|
|
5
|
+
/**
|
|
6
|
+
* Split a string into words, handling camelCase, PascalCase, and delimiters.
|
|
7
|
+
*
|
|
8
|
+
* @example
|
|
9
|
+
* splitWords("myFunctionName") => ["my", "Function", "Name"]
|
|
10
|
+
* splitWords("my_function_name") => ["my", "function", "name"]
|
|
11
|
+
*/
|
|
12
|
+
export declare function splitWords(input: string): string[];
|
|
13
|
+
/**
|
|
14
|
+
* Convert words to a specific naming case.
|
|
15
|
+
*
|
|
16
|
+
* @example
|
|
17
|
+
* toCase(["my", "function"], "snake") => "my_function"
|
|
18
|
+
* toCase(["my", "function"], "camel") => "myFunction"
|
|
19
|
+
*/
|
|
20
|
+
export declare function toCase(words: string[], kind: NameCase): string;
|
|
21
|
+
/**
|
|
22
|
+
* Get the separator character for a naming case.
|
|
23
|
+
*/
|
|
24
|
+
export declare function sepFor(kind: NameCase): string;
|
|
25
|
+
/**
|
|
26
|
+
* Normalize a single segment (name part) to MCP-safe characters.
|
|
27
|
+
*/
|
|
28
|
+
export declare function normalizeSegment(raw: string, kind: NameCase): string;
|
|
29
|
+
/**
|
|
30
|
+
* Normalize a provider ID to MCP-safe characters.
|
|
31
|
+
*/
|
|
32
|
+
export declare function normalizeProviderId(raw: string | undefined, kind: NameCase): string | undefined;
|
|
33
|
+
/**
|
|
34
|
+
* Normalize an owner path (app:id/plugin:id) to the specified naming case.
|
|
35
|
+
*/
|
|
36
|
+
export declare function normalizeOwnerPath(ownerKey: string, kind: NameCase): string;
|
|
37
|
+
/**
|
|
38
|
+
* Generate a short hash (6 hex chars) from a string.
|
|
39
|
+
* Uses djb2 algorithm for fast, reasonable distribution.
|
|
40
|
+
*/
|
|
41
|
+
export declare function shortHash(s: string): string;
|
|
42
|
+
/**
|
|
43
|
+
* Ensure a name fits within a maximum length, using hash truncation if needed.
|
|
44
|
+
* Preserves meaningful suffix while adding a hash for uniqueness.
|
|
45
|
+
*/
|
|
46
|
+
export declare function ensureMaxLen(name: string, max: number): string;
|
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// file: libs/sdk/src/utils/naming.utils.ts
|
|
3
|
+
// Shared naming and case conversion utilities for MCP-compliant identifiers
|
|
4
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
5
|
+
exports.splitWords = splitWords;
|
|
6
|
+
exports.toCase = toCase;
|
|
7
|
+
exports.sepFor = sepFor;
|
|
8
|
+
exports.normalizeSegment = normalizeSegment;
|
|
9
|
+
exports.normalizeProviderId = normalizeProviderId;
|
|
10
|
+
exports.normalizeOwnerPath = normalizeOwnerPath;
|
|
11
|
+
exports.shortHash = shortHash;
|
|
12
|
+
exports.ensureMaxLen = ensureMaxLen;
|
|
13
|
+
// Allowed chars per MCP spec: a-zA-Z0-9 _ - . /
|
|
14
|
+
const MCP_ALLOWED = /[A-Za-z0-9_\-./]/;
|
|
15
|
+
/**
|
|
16
|
+
* Split a string into words, handling camelCase, PascalCase, and delimiters.
|
|
17
|
+
*
|
|
18
|
+
* @example
|
|
19
|
+
* splitWords("myFunctionName") => ["my", "Function", "Name"]
|
|
20
|
+
* splitWords("my_function_name") => ["my", "function", "name"]
|
|
21
|
+
*/
|
|
22
|
+
function splitWords(input) {
|
|
23
|
+
const parts = [];
|
|
24
|
+
let buff = '';
|
|
25
|
+
for (let i = 0; i < input.length; i++) {
|
|
26
|
+
const ch = input[i];
|
|
27
|
+
const isAlphaNum = /[A-Za-z0-9]/.test(ch);
|
|
28
|
+
if (!isAlphaNum) {
|
|
29
|
+
if (buff) {
|
|
30
|
+
parts.push(buff);
|
|
31
|
+
buff = '';
|
|
32
|
+
}
|
|
33
|
+
continue;
|
|
34
|
+
}
|
|
35
|
+
if (buff && /[a-z]/.test(buff[buff.length - 1]) && /[A-Z]/.test(ch)) {
|
|
36
|
+
parts.push(buff);
|
|
37
|
+
buff = ch;
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
buff += ch;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
if (buff)
|
|
44
|
+
parts.push(buff);
|
|
45
|
+
return parts;
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Convert words to a specific naming case.
|
|
49
|
+
*
|
|
50
|
+
* @example
|
|
51
|
+
* toCase(["my", "function"], "snake") => "my_function"
|
|
52
|
+
* toCase(["my", "function"], "camel") => "myFunction"
|
|
53
|
+
*/
|
|
54
|
+
function toCase(words, kind) {
|
|
55
|
+
const safe = words.filter(Boolean);
|
|
56
|
+
switch (kind) {
|
|
57
|
+
case 'snake':
|
|
58
|
+
return safe.map((w) => w.toLowerCase()).join('_');
|
|
59
|
+
case 'kebab':
|
|
60
|
+
return safe.map((w) => w.toLowerCase()).join('-');
|
|
61
|
+
case 'dot':
|
|
62
|
+
return safe.map((w) => w.toLowerCase()).join('.');
|
|
63
|
+
case 'camel':
|
|
64
|
+
if (safe.length === 0)
|
|
65
|
+
return '';
|
|
66
|
+
return (safe[0].toLowerCase() +
|
|
67
|
+
safe
|
|
68
|
+
.slice(1)
|
|
69
|
+
.map((w) => w.charAt(0).toUpperCase() + w.slice(1).toLowerCase())
|
|
70
|
+
.join(''));
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* Get the separator character for a naming case.
|
|
75
|
+
*/
|
|
76
|
+
function sepFor(kind) {
|
|
77
|
+
return kind === 'snake' ? '_' : kind === 'kebab' ? '-' : kind === 'dot' ? '.' : '';
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* Normalize a single segment (name part) to MCP-safe characters.
|
|
81
|
+
*/
|
|
82
|
+
function normalizeSegment(raw, kind) {
|
|
83
|
+
const words = splitWords(raw);
|
|
84
|
+
let cased = toCase(words, kind);
|
|
85
|
+
cased = [...cased].filter((ch) => MCP_ALLOWED.test(ch)).join('');
|
|
86
|
+
return cased || 'x';
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* Normalize a provider ID to MCP-safe characters.
|
|
90
|
+
*/
|
|
91
|
+
function normalizeProviderId(raw, kind) {
|
|
92
|
+
if (!raw)
|
|
93
|
+
return undefined;
|
|
94
|
+
const tokens = raw.split(/\W+/);
|
|
95
|
+
const cased = toCase(tokens, kind);
|
|
96
|
+
const safe = [...cased].filter((ch) => MCP_ALLOWED.test(ch)).join('');
|
|
97
|
+
return safe || undefined;
|
|
98
|
+
}
|
|
99
|
+
/**
|
|
100
|
+
* Normalize an owner path (app:id/plugin:id) to the specified naming case.
|
|
101
|
+
*/
|
|
102
|
+
function normalizeOwnerPath(ownerKey, kind) {
|
|
103
|
+
const levels = ownerKey.split('/');
|
|
104
|
+
const normLevels = levels.map((level) => {
|
|
105
|
+
const parts = level.split(':'); // ["app","Portal"]
|
|
106
|
+
return parts.map((p) => normalizeSegment(p, kind)).join(sepFor(kind));
|
|
107
|
+
});
|
|
108
|
+
if (kind === 'camel')
|
|
109
|
+
return normLevels.map((seg) => seg.charAt(0).toLowerCase() + seg.slice(1)).join('');
|
|
110
|
+
return normLevels.join(sepFor(kind));
|
|
111
|
+
}
|
|
112
|
+
/**
|
|
113
|
+
* Generate a short hash (6 hex chars) from a string.
|
|
114
|
+
* Uses djb2 algorithm for fast, reasonable distribution.
|
|
115
|
+
*/
|
|
116
|
+
function shortHash(s) {
|
|
117
|
+
let h = 5381;
|
|
118
|
+
for (let i = 0; i < s.length; i++)
|
|
119
|
+
h = (h << 5) + h + s.charCodeAt(i);
|
|
120
|
+
return (h >>> 0).toString(16).slice(-6).padStart(6, '0');
|
|
121
|
+
}
|
|
122
|
+
/**
|
|
123
|
+
* Ensure a name fits within a maximum length, using hash truncation if needed.
|
|
124
|
+
* Preserves meaningful suffix while adding a hash for uniqueness.
|
|
125
|
+
*/
|
|
126
|
+
function ensureMaxLen(name, max) {
|
|
127
|
+
if (name.length <= max)
|
|
128
|
+
return name;
|
|
129
|
+
const hash = shortHash(name);
|
|
130
|
+
const lastSep = Math.max(name.lastIndexOf('_'), name.lastIndexOf('-'), name.lastIndexOf('.'), name.lastIndexOf('/'));
|
|
131
|
+
const tail = lastSep > 0 ? name.slice(lastSep + 1) : name.slice(-Math.max(3, Math.min(16, Math.floor(max / 4))));
|
|
132
|
+
const budget = Math.max(1, max - (1 + hash.length + 1 + tail.length));
|
|
133
|
+
const prefix = name.slice(0, budget);
|
|
134
|
+
return `${prefix}-${hash}-${tail}`.slice(0, max);
|
|
135
|
+
}
|
|
136
|
+
//# sourceMappingURL=naming.utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"naming.utils.js","sourceRoot":"","sources":["../../../src/utils/naming.utils.ts"],"names":[],"mappings":"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","sourcesContent":["// file: libs/sdk/src/utils/naming.utils.ts\n// Shared naming and case conversion utilities for MCP-compliant identifiers\n\n/**\n * Supported naming conventions for MCP identifiers\n */\nexport type NameCase = 'snake' | 'kebab' | 'dot' | 'camel';\n\n// Allowed chars per MCP spec: a-zA-Z0-9 _ - . /\nconst MCP_ALLOWED = /[A-Za-z0-9_\\-./]/;\n\n/**\n * Split a string into words, handling camelCase, PascalCase, and delimiters.\n *\n * @example\n * splitWords(\"myFunctionName\") => [\"my\", \"Function\", \"Name\"]\n * splitWords(\"my_function_name\") => [\"my\", \"function\", \"name\"]\n */\nexport function splitWords(input: string): string[] {\n const parts: string[] = [];\n let buff = '';\n for (let i = 0; i < input.length; i++) {\n const ch = input[i];\n const isAlphaNum = /[A-Za-z0-9]/.test(ch);\n if (!isAlphaNum) {\n if (buff) {\n parts.push(buff);\n buff = '';\n }\n continue;\n }\n if (buff && /[a-z]/.test(buff[buff.length - 1]) && /[A-Z]/.test(ch)) {\n parts.push(buff);\n buff = ch;\n } else {\n buff += ch;\n }\n }\n if (buff) parts.push(buff);\n return parts;\n}\n\n/**\n * Convert words to a specific naming case.\n *\n * @example\n * toCase([\"my\", \"function\"], \"snake\") => \"my_function\"\n * toCase([\"my\", \"function\"], \"camel\") => \"myFunction\"\n */\nexport function toCase(words: string[], kind: NameCase): string {\n const safe = words.filter(Boolean);\n switch (kind) {\n case 'snake':\n return safe.map((w) => w.toLowerCase()).join('_');\n case 'kebab':\n return safe.map((w) => w.toLowerCase()).join('-');\n case 'dot':\n return safe.map((w) => w.toLowerCase()).join('.');\n case 'camel':\n if (safe.length === 0) return '';\n return (\n safe[0].toLowerCase() +\n safe\n .slice(1)\n .map((w) => w.charAt(0).toUpperCase() + w.slice(1).toLowerCase())\n .join('')\n );\n }\n}\n\n/**\n * Get the separator character for a naming case.\n */\nexport function sepFor(kind: NameCase): string {\n return kind === 'snake' ? '_' : kind === 'kebab' ? '-' : kind === 'dot' ? '.' : '';\n}\n\n/**\n * Normalize a single segment (name part) to MCP-safe characters.\n */\nexport function normalizeSegment(raw: string, kind: NameCase): string {\n const words = splitWords(raw);\n let cased = toCase(words, kind);\n cased = [...cased].filter((ch) => MCP_ALLOWED.test(ch)).join('');\n return cased || 'x';\n}\n\n/**\n * Normalize a provider ID to MCP-safe characters.\n */\nexport function normalizeProviderId(raw: string | undefined, kind: NameCase): string | undefined {\n if (!raw) return undefined;\n const tokens = raw.split(/\\W+/);\n const cased = toCase(tokens, kind);\n const safe = [...cased].filter((ch) => MCP_ALLOWED.test(ch)).join('');\n return safe || undefined;\n}\n\n/**\n * Normalize an owner path (app:id/plugin:id) to the specified naming case.\n */\nexport function normalizeOwnerPath(ownerKey: string, kind: NameCase): string {\n const levels = ownerKey.split('/');\n const normLevels = levels.map((level) => {\n const parts = level.split(':'); // [\"app\",\"Portal\"]\n return parts.map((p) => normalizeSegment(p, kind)).join(sepFor(kind));\n });\n if (kind === 'camel') return normLevels.map((seg) => seg.charAt(0).toLowerCase() + seg.slice(1)).join('');\n return normLevels.join(sepFor(kind));\n}\n\n/**\n * Generate a short hash (6 hex chars) from a string.\n * Uses djb2 algorithm for fast, reasonable distribution.\n */\nexport function shortHash(s: string): string {\n let h = 5381;\n for (let i = 0; i < s.length; i++) h = (h << 5) + h + s.charCodeAt(i);\n return (h >>> 0).toString(16).slice(-6).padStart(6, '0');\n}\n\n/**\n * Ensure a name fits within a maximum length, using hash truncation if needed.\n * Preserves meaningful suffix while adding a hash for uniqueness.\n */\nexport function ensureMaxLen(name: string, max: number): string {\n if (name.length <= max) return name;\n const hash = shortHash(name);\n const lastSep = Math.max(name.lastIndexOf('_'), name.lastIndexOf('-'), name.lastIndexOf('.'), name.lastIndexOf('/'));\n const tail = lastSep > 0 ? name.slice(lastSep + 1) : name.slice(-Math.max(3, Math.min(16, Math.floor(max / 4))));\n const budget = Math.max(1, max - (1 + hash.length + 1 + tail.length));\n const prefix = name.slice(0, budget);\n return `${prefix}-${hash}-${tail}`.slice(0, max);\n}\n"]}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { z,
|
|
1
|
+
import { z, ZodType } from 'zod';
|
|
2
2
|
type Primitive = string | number | boolean | bigint | null | undefined;
|
|
3
3
|
type Flatten<T> = T extends Primitive ? T : T extends Array<infer U> ? Array<Flatten<U>> : T extends Set<infer U> ? Set<Flatten<U>> : T extends Map<infer K, infer V> ? Map<Flatten<K>, Flatten<V>> : T extends object ? {
|
|
4
4
|
[K in keyof T]: Flatten<T[K]>;
|
|
5
5
|
} : T;
|
|
6
|
-
export type Infer<Schema extends
|
|
6
|
+
export type Infer<Schema extends ZodType> = Flatten<z.infer<Schema>>;
|
|
7
7
|
export {};
|