@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 +1 @@
|
|
|
1
|
-
{"version":3,"file":"front-mcp.providers.js","sourceRoot":"","sources":["../../../src/front-mcp/front-mcp.providers.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"front-mcp.providers.js","sourceRoot":"","sources":["../../../src/front-mcp/front-mcp.providers.ts"],"names":[],"mappings":";;AAyBA,4DAEC;AA3BD,sCAAgH;AAChH,+DAAmE;AACnE,yDAAoD;AAEpD,MAAM,cAAc,GAAG;IACrB,IAAI,EAAE,CAAC,QAA4B,EAAyC,EAAE,CAAC,CAAC;QAC9E,IAAI,EAAE,iBAAiB;QACvB,OAAO,EAAE,iCAAc;QACvB,KAAK,EAAE,sBAAa,CAAC,MAAM;QAC3B,QAAQ,EAAE,QAAQ;KACnB,CAAC;CACH,CAAC;AAEF,MAAM,oBAAoB,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,CAAC;AAE/D,MAAM,cAAc,GAAG,IAAA,sBAAa,EAAC;IACnC,IAAI,EAAE,iBAAiB;IACvB,KAAK,EAAE,sBAAa,CAAC,MAAM;IAC3B,OAAO,EAAE,uBAAc;IACvB,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC,iCAAc,CAAC;IAC9B,UAAU,EAAE,CAAC,MAAM,EAAE,EAAE;QACrB,OAAO,IAAI,wCAAsB,CAAC,MAAM,CAAC,IAAI,IAAI,oBAAoB,CAAC,CAAC;IACzE,CAAC;CACF,CAAC,CAAC;AAEH,SAAgB,wBAAwB,CAAC,QAA4B;IACnE,OAAO,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,cAAc,CAAC,CAAC;AACzD,CAAC","sourcesContent":["import { FrontMcpConfigType, ProviderScope, FrontMcpServer, ProviderValueType, AsyncProvider } from '../common';\nimport { FrontMcpServerInstance } from '../server/server.instance';\nimport { FrontMcpConfig } from './front-mcp.tokens';\n\nconst frontMcpConfig = {\n with: (metadata: FrontMcpConfigType): ProviderValueType<FrontMcpConfigType> => ({\n name: 'frontmcp:config',\n provide: FrontMcpConfig,\n scope: ProviderScope.GLOBAL,\n useValue: metadata,\n }),\n};\n\nconst DEFAULT_HTTP_OPTIONS = { port: 3000, entryPath: '/mcp' };\n\nconst frontMcpServer = AsyncProvider({\n name: 'frontmcp:server',\n scope: ProviderScope.GLOBAL,\n provide: FrontMcpServer,\n inject: () => [FrontMcpConfig],\n useFactory: (config) => {\n return new FrontMcpServerInstance(config.http ?? DEFAULT_HTTP_OPTIONS);\n },\n});\n\nexport function createMcpGlobalProviders(metadata: FrontMcpConfigType) {\n return [frontMcpConfig.with(metadata), frontMcpServer];\n}\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { FlowCtxOf, FlowInputOf, FlowName, FlowStagesOf, FrontMcpLogger, HookEntry, HookRecord, ProviderRegistryInterface, ScopeEntry, Token } from
|
|
1
|
+
import { FlowCtxOf, FlowInputOf, FlowName, FlowStagesOf, FrontMcpLogger, HookEntry, HookRecord, ProviderRegistryInterface, ScopeEntry, Token } from '../common';
|
|
2
2
|
export declare class HookInstance<Name extends FlowName, In = FlowInputOf<Name>, Stage = FlowStagesOf<Name>, Ctx = FlowCtxOf<Name>> extends HookEntry<In, Name, Stage, Ctx> {
|
|
3
3
|
logger: FrontMcpLogger;
|
|
4
4
|
constructor(scope: ScopeEntry, providers: ProviderRegistryInterface, record: HookRecord, token: Token);
|
|
@@ -14,9 +14,12 @@ class HookInstance extends common_1.HookEntry {
|
|
|
14
14
|
}
|
|
15
15
|
async run(input, ctx) {
|
|
16
16
|
const { target, method } = this.metadata;
|
|
17
|
-
|
|
17
|
+
if (!target) {
|
|
18
|
+
throw new Error(`Hook target is not defined for method "${method}". This is a bug in hook configuration.`);
|
|
19
|
+
}
|
|
20
|
+
this.logger.verbose('start');
|
|
18
21
|
await target[method](input, ctx);
|
|
19
|
-
this.logger.verbose(
|
|
22
|
+
this.logger.verbose('done');
|
|
20
23
|
}
|
|
21
24
|
}
|
|
22
25
|
exports.HookInstance = HookInstance;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"hook.instance.js","sourceRoot":"","sources":["../../../src/hooks/hook.instance.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"hook.instance.js","sourceRoot":"","sources":["../../../src/hooks/hook.instance.ts"],"names":[],"mappings":";;;AAAA,sCAYmB;AAEnB,MAAa,YAKX,SAAQ,kBAA+B;IACvC,MAAM,CAAiB;IAEvB,YAAY,KAAiB,EAAE,SAAoC,EAAE,MAAkB,EAAE,KAAY;QACnG,KAAK,CAAC,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC,QAA0C,CAAC,CAAC;QAE1F,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC9C,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,IAAI,SAAS,KAAK,IAAI,MAAM,GAAG,CAAC,CAAC;IACvE,CAAC;IAES,UAAU;QAClB,OAAO,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IACpC,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,KAAS,EAAE,GAAQ;QAC3B,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,QAAQ,CAAC;QACzC,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,MAAM,IAAI,KAAK,CAAC,0CAA0C,MAAM,yCAAyC,CAAC,CAAC;QAC7G,CAAC;QACD,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QAC7B,MAAM,MAAM,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;QACjC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IAC9B,CAAC;CACF;AA5BD,oCA4BC","sourcesContent":["import {\n FlowCtxOf,\n FlowInputOf,\n FlowName,\n FlowStagesOf,\n FrontMcpLogger,\n HookEntry,\n HookMetadata,\n HookRecord,\n ProviderRegistryInterface,\n ScopeEntry,\n Token,\n} from '../common';\n\nexport class HookInstance<\n Name extends FlowName,\n In = FlowInputOf<Name>,\n Stage = FlowStagesOf<Name>,\n Ctx = FlowCtxOf<Name>,\n> extends HookEntry<In, Name, Stage, Ctx> {\n logger: FrontMcpLogger;\n\n constructor(scope: ScopeEntry, providers: ProviderRegistryInterface, record: HookRecord, token: Token) {\n super(scope, providers, record, token, record.metadata as HookMetadata<Name, Stage, Ctx>);\n\n const { flow, method, stage } = this.metadata;\n this.logger = scope.logger.child(`${flow}:hook:${stage}(${method})`);\n }\n\n protected initialize(): Promise<void> {\n return Promise.resolve(undefined);\n }\n\n async run(input: In, ctx: Ctx): Promise<void> {\n const { target, method } = this.metadata;\n if (!target) {\n throw new Error(`Hook target is not defined for method \"${method}\". This is a bug in hook configuration.`);\n }\n this.logger.verbose('start');\n await target[method](input, ctx);\n this.logger.verbose('done');\n }\n}\n"]}
|
|
@@ -89,16 +89,18 @@ class HookRegistry extends regsitry_1.RegistryAbstract {
|
|
|
89
89
|
this.instances.set(token, instance);
|
|
90
90
|
// Keep raw records grouped by class (if needed elsewhere)
|
|
91
91
|
const cls = rec.metadata.target;
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
92
|
+
if (cls) {
|
|
93
|
+
const recs = this.recordsByCls.get(cls) ?? [];
|
|
94
|
+
recs.push(rec);
|
|
95
|
+
this.recordsByCls.set(cls, recs);
|
|
96
|
+
}
|
|
95
97
|
// Build fast indexes of *instances*, sorted by priority
|
|
96
98
|
const entry = this.instances.get(token);
|
|
97
99
|
const { flow, stage, target } = rec.metadata;
|
|
98
|
-
if (embedded) {
|
|
100
|
+
if (embedded && target) {
|
|
99
101
|
this.indexByClass(target.constructor ?? target, entry);
|
|
100
102
|
}
|
|
101
|
-
else {
|
|
103
|
+
else if (!embedded) {
|
|
102
104
|
this.indexByFlowStage(flow, String(stage), entry);
|
|
103
105
|
this.indexByFlow(flow, entry);
|
|
104
106
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"hook.registry.js","sourceRoot":"","sources":["../../../src/hooks/hook.registry.ts"],"names":[],"mappings":"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","sourcesContent":["// src/hooks/hook.registry.ts\n\nimport {\n FlowCtxOf,\n FlowInputOf,\n FlowName,\n FlowStagesOf,\n HookEntry,\n HookRecord,\n HookRegistryInterface,\n HookType,\n ScopeEntry,\n Token,\n} from '../common';\nimport { RegistryAbstract, RegistryBuildMapResult } from '../regsitry';\nimport ProviderRegistry from '../provider/provider.registry';\nimport { HookInstance } from './hook.instance';\n\nexport default class HookRegistry\n extends RegistryAbstract<HookEntry, HookRecord, HookType[]>\n implements HookRegistryInterface\n{\n scope: ScopeEntry;\n\n /** Historical records by class (kept if you still want access to raw records) */\n recordsByCls: Map<Token, HookRecord[]> = new Map();\n\n /** Fast O(1) indexes of *instances*, sorted by priority (desc) */\n private entriesByCls: Map<Token, HookEntry[]> = new Map();\n private hooksByFlow: Map<FlowName, HookEntry[]> = new Map();\n private hooksByFlowStage: Map<FlowName, Map<string, HookEntry[]>> = new Map();\n\n constructor(providers: ProviderRegistry, list: HookType[]) {\n super('HookRegistry', providers, list);\n this.scope = this.providers.getActiveScope();\n }\n\n protected override buildMap(): RegistryBuildMapResult<HookRecord> {\n const tokens = new Set<Token>();\n const defs = new Map<Token, HookRecord>();\n const graph = new Map<Token, Set<Token>>();\n /**\n * No need to build graph for hooks,\n * hooks are injected by other tokens\n */\n return { tokens, defs, graph };\n }\n\n protected buildGraph() {\n /**\n * Currently, hooks cannot be depended on other tokens,\n * in the future we can add this feature, so hooks can depends on:\n * - other hooks completions\n * - specific injected providers\n */\n }\n\n async initialize() {\n /**\n * No need to initialize hooks,\n * hooks are injected by other tokens\n */\n }\n\n /** Priority helper (default 0) */\n private getPriority(entry: Pick<HookEntry, 'metadata'> | Pick<HookRecord, 'metadata'>): number {\n return entry.metadata?.priority ?? 0;\n }\n\n /** Binary insert by priority (desc). Stable for equal priorities. */\n private insertSorted(arr: HookEntry[], item: HookEntry) {\n const p = this.getPriority(item);\n let lo = 0;\n let hi = arr.length;\n // Insert AFTER existing equal-priority items to keep stable order.\n while (lo < hi) {\n const mid = (lo + hi) >>> 1;\n const mp = this.getPriority(arr[mid]);\n if (mp < p) {\n hi = mid;\n } else {\n lo = mid + 1;\n }\n }\n arr.splice(lo, 0, item);\n }\n\n private upsert<K, V>(map: Map<K, V>, key: K, init: () => V): V {\n let v = map.get(key);\n if (!v) {\n v = init();\n map.set(key, v);\n }\n return v;\n }\n\n private indexByClass(cls: Token, entry: HookEntry) {\n const list = this.upsert(this.entriesByCls, cls, () => []);\n this.insertSorted(list, entry);\n }\n\n private indexByFlow(flow: FlowName, entry: HookEntry) {\n const list = this.upsert(this.hooksByFlow, flow, () => []);\n this.insertSorted(list, entry);\n }\n\n private indexByFlowStage(flow: FlowName, stage: string, entry: HookEntry) {\n const stages = this.upsert(this.hooksByFlowStage, flow, () => new Map<string, HookEntry[]>());\n const list = this.upsert(stages, String(stage), () => []);\n this.insertSorted(list, entry);\n }\n\n private initializeOne(embedded: boolean, token: Token) {\n const rec = this.defs.get(token)!;\n const providers = this.providers; // nearest token provider registry\n const instance = new HookInstance(this.scope, providers, rec, token);\n this.instances.set(token, instance);\n\n // Keep raw records grouped by class (if needed elsewhere)\n const cls = rec.metadata.target;\n const recs = this.recordsByCls.get(cls) ?? [];\n recs.push(rec);\n this.recordsByCls.set(cls, recs);\n\n // Build fast indexes of *instances*, sorted by priority\n const entry = this.instances.get(token)!;\n const { flow, stage, target } = rec.metadata;\n\n if (embedded) {\n this.indexByClass(target.constructor ?? target, entry);\n } else {\n this.indexByFlowStage(flow, String(stage), entry);\n this.indexByFlow(flow, entry);\n }\n\n return instance.ready;\n }\n\n registerHooks(embedded: boolean, ...records: HookRecord[]) {\n const readyArr: Promise<void>[] = [];\n for (const record of records) {\n this.defs.set(record.provide, record);\n this.tokens.add(record.provide);\n this.graph.set(record.provide, new Set());\n readyArr.push(this.initializeOne(embedded, record.provide));\n }\n return Promise.all(readyArr);\n }\n\n /** Hooks for a given *flow*, filtered by owner if provided, sorted by priority (desc). */\n getFlowHooksForOwner<Name extends FlowName>(\n flow: Name,\n ownerId?: string,\n ): HookEntry<FlowInputOf<Name>, Name, FlowStagesOf<Name>, FlowCtxOf<Name>>[] {\n const allHooks = this.getFlowHooks(flow);\n if (!ownerId) {\n return allHooks;\n }\n // Filter hooks to only include those that belong to the same owner or have no owner (global hooks)\n return allHooks.filter((hook) => {\n const hookOwner = hook.metadata.owner;\n return !hookOwner || hookOwner.id === ownerId;\n });\n }\n\n /** Hooks defined on a given *class* (metadata.target), sorted by priority (desc). */\n getClsHooks(token: Token): HookEntry[] {\n return this.entriesByCls.get(token) ?? [];\n }\n\n /** All hooks (instances, unordered) */\n getHooks(): HookEntry[] {\n return [...this.instances.values()];\n }\n\n /** Hooks for a given *flow*, sorted by priority (desc). */\n getFlowHooks<Name extends FlowName>(\n flow: Name,\n ): HookEntry<FlowInputOf<Name>, Name, FlowStagesOf<Name>, FlowCtxOf<Name>>[] {\n const list = this.hooksByFlow.get(flow) ?? [];\n return list as HookEntry<FlowInputOf<Name>, Name, FlowStagesOf<Name>, FlowCtxOf<Name>>[];\n }\n\n /** Hooks for a specific *flow + stage*, sorted by priority (desc). */\n getFlowStageHooks<Name extends FlowName>(\n flow: Name,\n stage: FlowStagesOf<Name> | string,\n ): HookEntry<FlowInputOf<Name>, Name, FlowStagesOf<Name>, FlowCtxOf<Name>>[] {\n const byStage = this.hooksByFlowStage.get(flow);\n const list = byStage?.get(String(stage)) ?? [];\n return list as HookEntry<FlowInputOf<Name>, Name, FlowStagesOf<Name>, FlowCtxOf<Name>>[];\n }\n}\n"]}
|
|
1
|
+
{"version":3,"file":"hook.registry.js","sourceRoot":"","sources":["../../../src/hooks/hook.registry.ts"],"names":[],"mappings":"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","sourcesContent":["// src/hooks/hook.registry.ts\n\nimport {\n FlowCtxOf,\n FlowInputOf,\n FlowName,\n FlowStagesOf,\n HookEntry,\n HookRecord,\n HookRegistryInterface,\n HookType,\n ScopeEntry,\n Token,\n} from '../common';\nimport { RegistryAbstract, RegistryBuildMapResult } from '../regsitry';\nimport ProviderRegistry from '../provider/provider.registry';\nimport { HookInstance } from './hook.instance';\n\nexport default class HookRegistry\n extends RegistryAbstract<HookEntry, HookRecord, HookType[]>\n implements HookRegistryInterface\n{\n scope: ScopeEntry;\n\n /** Historical records by class (kept if you still want access to raw records) */\n recordsByCls: Map<Token, HookRecord[]> = new Map();\n\n /** Fast O(1) indexes of *instances*, sorted by priority (desc) */\n private entriesByCls: Map<Token, HookEntry[]> = new Map();\n private hooksByFlow: Map<FlowName, HookEntry[]> = new Map();\n private hooksByFlowStage: Map<FlowName, Map<string, HookEntry[]>> = new Map();\n\n constructor(providers: ProviderRegistry, list: HookType[]) {\n super('HookRegistry', providers, list);\n this.scope = this.providers.getActiveScope();\n }\n\n protected override buildMap(): RegistryBuildMapResult<HookRecord> {\n const tokens = new Set<Token>();\n const defs = new Map<Token, HookRecord>();\n const graph = new Map<Token, Set<Token>>();\n /**\n * No need to build graph for hooks,\n * hooks are injected by other tokens\n */\n return { tokens, defs, graph };\n }\n\n protected buildGraph() {\n /**\n * Currently, hooks cannot be depended on other tokens,\n * in the future we can add this feature, so hooks can depends on:\n * - other hooks completions\n * - specific injected providers\n */\n }\n\n async initialize() {\n /**\n * No need to initialize hooks,\n * hooks are injected by other tokens\n */\n }\n\n /** Priority helper (default 0) */\n private getPriority(entry: Pick<HookEntry, 'metadata'> | Pick<HookRecord, 'metadata'>): number {\n return entry.metadata?.priority ?? 0;\n }\n\n /** Binary insert by priority (desc). Stable for equal priorities. */\n private insertSorted(arr: HookEntry[], item: HookEntry) {\n const p = this.getPriority(item);\n let lo = 0;\n let hi = arr.length;\n // Insert AFTER existing equal-priority items to keep stable order.\n while (lo < hi) {\n const mid = (lo + hi) >>> 1;\n const mp = this.getPriority(arr[mid]);\n if (mp < p) {\n hi = mid;\n } else {\n lo = mid + 1;\n }\n }\n arr.splice(lo, 0, item);\n }\n\n private upsert<K, V>(map: Map<K, V>, key: K, init: () => V): V {\n let v = map.get(key);\n if (!v) {\n v = init();\n map.set(key, v);\n }\n return v;\n }\n\n private indexByClass(cls: Token, entry: HookEntry) {\n const list = this.upsert(this.entriesByCls, cls, () => []);\n this.insertSorted(list, entry);\n }\n\n private indexByFlow(flow: FlowName, entry: HookEntry) {\n const list = this.upsert(this.hooksByFlow, flow, () => []);\n this.insertSorted(list, entry);\n }\n\n private indexByFlowStage(flow: FlowName, stage: string, entry: HookEntry) {\n const stages = this.upsert(this.hooksByFlowStage, flow, () => new Map<string, HookEntry[]>());\n const list = this.upsert(stages, String(stage), () => []);\n this.insertSorted(list, entry);\n }\n\n private initializeOne(embedded: boolean, token: Token) {\n const rec = this.defs.get(token)!;\n const providers = this.providers; // nearest token provider registry\n const instance = new HookInstance(this.scope, providers, rec, token);\n this.instances.set(token, instance);\n\n // Keep raw records grouped by class (if needed elsewhere)\n const cls = rec.metadata.target;\n if (cls) {\n const recs = this.recordsByCls.get(cls) ?? [];\n recs.push(rec);\n this.recordsByCls.set(cls, recs);\n }\n\n // Build fast indexes of *instances*, sorted by priority\n const entry = this.instances.get(token)!;\n const { flow, stage, target } = rec.metadata;\n\n if (embedded && target) {\n this.indexByClass(target.constructor ?? target, entry);\n } else if (!embedded) {\n this.indexByFlowStage(flow, String(stage), entry);\n this.indexByFlow(flow, entry);\n }\n\n return instance.ready;\n }\n\n registerHooks(embedded: boolean, ...records: HookRecord[]) {\n const readyArr: Promise<void>[] = [];\n for (const record of records) {\n this.defs.set(record.provide, record);\n this.tokens.add(record.provide);\n this.graph.set(record.provide, new Set());\n readyArr.push(this.initializeOne(embedded, record.provide));\n }\n return Promise.all(readyArr);\n }\n\n /** Hooks for a given *flow*, filtered by owner if provided, sorted by priority (desc). */\n getFlowHooksForOwner<Name extends FlowName>(\n flow: Name,\n ownerId?: string,\n ): HookEntry<FlowInputOf<Name>, Name, FlowStagesOf<Name>, FlowCtxOf<Name>>[] {\n const allHooks = this.getFlowHooks(flow);\n if (!ownerId) {\n return allHooks;\n }\n // Filter hooks to only include those that belong to the same owner or have no owner (global hooks)\n return allHooks.filter((hook) => {\n const hookOwner = hook.metadata.owner;\n return !hookOwner || hookOwner.id === ownerId;\n });\n }\n\n /** Hooks defined on a given *class* (metadata.target), sorted by priority (desc). */\n getClsHooks(token: Token): HookEntry[] {\n return this.entriesByCls.get(token) ?? [];\n }\n\n /** All hooks (instances, unordered) */\n getHooks(): HookEntry[] {\n return [...this.instances.values()];\n }\n\n /** Hooks for a given *flow*, sorted by priority (desc). */\n getFlowHooks<Name extends FlowName>(\n flow: Name,\n ): HookEntry<FlowInputOf<Name>, Name, FlowStagesOf<Name>, FlowCtxOf<Name>>[] {\n const list = this.hooksByFlow.get(flow) ?? [];\n return list as HookEntry<FlowInputOf<Name>, Name, FlowStagesOf<Name>, FlowCtxOf<Name>>[];\n }\n\n /** Hooks for a specific *flow + stage*, sorted by priority (desc). */\n getFlowStageHooks<Name extends FlowName>(\n flow: Name,\n stage: FlowStagesOf<Name> | string,\n ): HookEntry<FlowInputOf<Name>, Name, FlowStagesOf<Name>, FlowCtxOf<Name>>[] {\n const byStage = this.hooksByFlowStage.get(flow);\n const list = byStage?.get(String(stage)) ?? [];\n return list as HookEntry<FlowInputOf<Name>, Name, FlowStagesOf<Name>, FlowCtxOf<Name>>[];\n }\n}\n"]}
|
package/src/index.d.ts
CHANGED
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
import 'reflect-metadata';
|
|
2
2
|
export { FrontMcpInstance } from './front-mcp';
|
|
3
|
-
export * from
|
|
3
|
+
export * from './common';
|
|
4
|
+
export { ToolChangeEvent, ToolChangeKind, ToolChangeScope } from './tool/tool.events';
|
|
4
5
|
export declare const ToolHook: {
|
|
5
|
-
Stage: (stage: "execute" | "finalize" | "parseInput" | "findTool" | "createToolCallContext" | "acquireQuota" | "acquireSemaphore" | "validateInput" | "validateOutput" | "releaseSemaphore" | "releaseQuota", opts?: import("./common").HookOptions<import("./tool/flows/call-tool.flow").default>) => MethodDecorator;
|
|
6
|
-
Will: (stage: "execute" | "finalize" | "parseInput" | "findTool" | "createToolCallContext" | "acquireQuota" | "acquireSemaphore" | "validateInput" | "validateOutput" | "releaseSemaphore" | "releaseQuota", opts?: import("./common").HookOptions<import("./tool/flows/call-tool.flow").default>) => MethodDecorator;
|
|
7
|
-
Did: (stage: "execute" | "finalize" | "parseInput" | "findTool" | "createToolCallContext" | "acquireQuota" | "acquireSemaphore" | "validateInput" | "validateOutput" | "releaseSemaphore" | "releaseQuota", opts?: import("./common").HookOptions<import("./tool/flows/call-tool.flow").default>) => MethodDecorator;
|
|
8
|
-
Around: (stage: "execute" | "finalize" | "parseInput" | "findTool" | "createToolCallContext" | "acquireQuota" | "acquireSemaphore" | "validateInput" | "validateOutput" | "releaseSemaphore" | "releaseQuota", opts?: import("./common").HookOptions<import("./tool/flows/call-tool.flow").default>) => MethodDecorator;
|
|
6
|
+
Stage: (stage: "execute" | "finalize" | "parseInput" | "findTool" | "checkToolAuthorization" | "createToolCallContext" | "acquireQuota" | "acquireSemaphore" | "validateInput" | "validateOutput" | "releaseSemaphore" | "releaseQuota", opts?: import("./common").HookOptions<import("./tool/flows/call-tool.flow").default>) => MethodDecorator;
|
|
7
|
+
Will: (stage: "execute" | "finalize" | "parseInput" | "findTool" | "checkToolAuthorization" | "createToolCallContext" | "acquireQuota" | "acquireSemaphore" | "validateInput" | "validateOutput" | "releaseSemaphore" | "releaseQuota", opts?: import("./common").HookOptions<import("./tool/flows/call-tool.flow").default>) => MethodDecorator;
|
|
8
|
+
Did: (stage: "execute" | "finalize" | "parseInput" | "findTool" | "checkToolAuthorization" | "createToolCallContext" | "acquireQuota" | "acquireSemaphore" | "validateInput" | "validateOutput" | "releaseSemaphore" | "releaseQuota", opts?: import("./common").HookOptions<import("./tool/flows/call-tool.flow").default>) => MethodDecorator;
|
|
9
|
+
Around: (stage: "execute" | "finalize" | "parseInput" | "findTool" | "checkToolAuthorization" | "createToolCallContext" | "acquireQuota" | "acquireSemaphore" | "validateInput" | "validateOutput" | "releaseSemaphore" | "releaseQuota", opts?: import("./common").HookOptions<import("./tool/flows/call-tool.flow").default>) => MethodDecorator;
|
|
9
10
|
};
|
|
10
11
|
export declare const ListToolsHook: {
|
|
11
12
|
Stage: (stage: "parseInput" | "findTools" | "resolveConflicts" | "parseTools", opts?: import("./common").HookOptions<import("./tool/flows/tools-list.flow").default>) => MethodDecorator;
|
|
@@ -14,8 +15,26 @@ export declare const ListToolsHook: {
|
|
|
14
15
|
Around: (stage: "parseInput" | "findTools" | "resolveConflicts" | "parseTools", opts?: import("./common").HookOptions<import("./tool/flows/tools-list.flow").default>) => MethodDecorator;
|
|
15
16
|
};
|
|
16
17
|
export declare const HttpHook: {
|
|
17
|
-
Stage: (stage: "
|
|
18
|
-
Will: (stage: "
|
|
19
|
-
Did: (stage: "
|
|
20
|
-
Around: (stage: "
|
|
18
|
+
Stage: (stage: "finalize" | "acquireQuota" | "acquireSemaphore" | "releaseSemaphore" | "releaseQuota" | "traceRequest" | "checkAuthorization" | "router" | "handleLegacySse" | "handleSse" | "handleStreamableHttp" | "handleStatefulHttp" | "handleStatelessHttp" | "handleDeleteSession" | "audit" | "metrics", opts?: import("./common").HookOptions<import("./scope/flows/http.request.flow").default>) => MethodDecorator;
|
|
19
|
+
Will: (stage: "finalize" | "acquireQuota" | "acquireSemaphore" | "releaseSemaphore" | "releaseQuota" | "traceRequest" | "checkAuthorization" | "router" | "handleLegacySse" | "handleSse" | "handleStreamableHttp" | "handleStatefulHttp" | "handleStatelessHttp" | "handleDeleteSession" | "audit" | "metrics", opts?: import("./common").HookOptions<import("./scope/flows/http.request.flow").default>) => MethodDecorator;
|
|
20
|
+
Did: (stage: "finalize" | "acquireQuota" | "acquireSemaphore" | "releaseSemaphore" | "releaseQuota" | "traceRequest" | "checkAuthorization" | "router" | "handleLegacySse" | "handleSse" | "handleStreamableHttp" | "handleStatefulHttp" | "handleStatelessHttp" | "handleDeleteSession" | "audit" | "metrics", opts?: import("./common").HookOptions<import("./scope/flows/http.request.flow").default>) => MethodDecorator;
|
|
21
|
+
Around: (stage: "finalize" | "acquireQuota" | "acquireSemaphore" | "releaseSemaphore" | "releaseQuota" | "traceRequest" | "checkAuthorization" | "router" | "handleLegacySse" | "handleSse" | "handleStreamableHttp" | "handleStatefulHttp" | "handleStatelessHttp" | "handleDeleteSession" | "audit" | "metrics", opts?: import("./common").HookOptions<import("./scope/flows/http.request.flow").default>) => MethodDecorator;
|
|
22
|
+
};
|
|
23
|
+
export declare const ResourceHook: {
|
|
24
|
+
Stage: (stage: "execute" | "finalize" | "parseInput" | "validateOutput" | "findResource" | "createResourceContext", opts?: import("./common").HookOptions<import("./resource").ReadResourceFlow>) => MethodDecorator;
|
|
25
|
+
Will: (stage: "execute" | "finalize" | "parseInput" | "validateOutput" | "findResource" | "createResourceContext", opts?: import("./common").HookOptions<import("./resource").ReadResourceFlow>) => MethodDecorator;
|
|
26
|
+
Did: (stage: "execute" | "finalize" | "parseInput" | "validateOutput" | "findResource" | "createResourceContext", opts?: import("./common").HookOptions<import("./resource").ReadResourceFlow>) => MethodDecorator;
|
|
27
|
+
Around: (stage: "execute" | "finalize" | "parseInput" | "validateOutput" | "findResource" | "createResourceContext", opts?: import("./common").HookOptions<import("./resource").ReadResourceFlow>) => MethodDecorator;
|
|
28
|
+
};
|
|
29
|
+
export declare const ListResourcesHook: {
|
|
30
|
+
Stage: (stage: "parseInput" | "resolveConflicts" | "findResources" | "parseResources", opts?: import("./common").HookOptions<import("./resource").ResourcesListFlow>) => MethodDecorator;
|
|
31
|
+
Will: (stage: "parseInput" | "resolveConflicts" | "findResources" | "parseResources", opts?: import("./common").HookOptions<import("./resource").ResourcesListFlow>) => MethodDecorator;
|
|
32
|
+
Did: (stage: "parseInput" | "resolveConflicts" | "findResources" | "parseResources", opts?: import("./common").HookOptions<import("./resource").ResourcesListFlow>) => MethodDecorator;
|
|
33
|
+
Around: (stage: "parseInput" | "resolveConflicts" | "findResources" | "parseResources", opts?: import("./common").HookOptions<import("./resource").ResourcesListFlow>) => MethodDecorator;
|
|
34
|
+
};
|
|
35
|
+
export declare const ListResourceTemplatesHook: {
|
|
36
|
+
Stage: (stage: "parseInput" | "resolveConflicts" | "findTemplates" | "parseTemplates", opts?: import("./common").HookOptions<import("./resource").ResourceTemplatesListFlow>) => MethodDecorator;
|
|
37
|
+
Will: (stage: "parseInput" | "resolveConflicts" | "findTemplates" | "parseTemplates", opts?: import("./common").HookOptions<import("./resource").ResourceTemplatesListFlow>) => MethodDecorator;
|
|
38
|
+
Did: (stage: "parseInput" | "resolveConflicts" | "findTemplates" | "parseTemplates", opts?: import("./common").HookOptions<import("./resource").ResourceTemplatesListFlow>) => MethodDecorator;
|
|
39
|
+
Around: (stage: "parseInput" | "resolveConflicts" | "findTemplates" | "parseTemplates", opts?: import("./common").HookOptions<import("./resource").ResourceTemplatesListFlow>) => MethodDecorator;
|
|
21
40
|
};
|
package/src/index.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.HttpHook = exports.ListToolsHook = exports.ToolHook = exports.FrontMcpInstance = void 0;
|
|
3
|
+
exports.ListResourceTemplatesHook = exports.ListResourcesHook = exports.ResourceHook = exports.HttpHook = exports.ListToolsHook = exports.ToolHook = exports.FrontMcpInstance = void 0;
|
|
4
4
|
const tslib_1 = require("tslib");
|
|
5
5
|
require("reflect-metadata");
|
|
6
6
|
const common_1 = require("./common");
|
|
@@ -10,4 +10,8 @@ tslib_1.__exportStar(require("./common"), exports);
|
|
|
10
10
|
exports.ToolHook = (0, common_1.FlowHooksOf)('tools:call-tool');
|
|
11
11
|
exports.ListToolsHook = (0, common_1.FlowHooksOf)('tools:list-tools');
|
|
12
12
|
exports.HttpHook = (0, common_1.FlowHooksOf)('http:request');
|
|
13
|
+
// Resource hooks
|
|
14
|
+
exports.ResourceHook = (0, common_1.FlowHooksOf)('resources:read-resource');
|
|
15
|
+
exports.ListResourcesHook = (0, common_1.FlowHooksOf)('resources:list-resources');
|
|
16
|
+
exports.ListResourceTemplatesHook = (0, common_1.FlowHooksOf)('resources:list-resource-templates');
|
|
13
17
|
//# sourceMappingURL=index.js.map
|
package/src/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";;;;AAAA,4BAA0B;AAC1B,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";;;;AAAA,4BAA0B;AAC1B,qCAAuC;AAEvC,yCAA+C;AAAtC,6GAAA,gBAAgB,OAAA;AACzB,mDAAyB;AAKZ,QAAA,QAAQ,GAAG,IAAA,oBAAW,EAAC,iBAAiB,CAAC,CAAC;AAC1C,QAAA,aAAa,GAAG,IAAA,oBAAW,EAAC,kBAAkB,CAAC,CAAC;AAChD,QAAA,QAAQ,GAAG,IAAA,oBAAW,EAAC,cAAc,CAAC,CAAC;AAEpD,iBAAiB;AACJ,QAAA,YAAY,GAAG,IAAA,oBAAW,EAAC,yBAAyB,CAAC,CAAC;AACtD,QAAA,iBAAiB,GAAG,IAAA,oBAAW,EAAC,0BAA0B,CAAC,CAAC;AAC5D,QAAA,yBAAyB,GAAG,IAAA,oBAAW,EAAC,mCAAmC,CAAC,CAAC","sourcesContent":["import 'reflect-metadata';\nimport { FlowHooksOf } from './common';\n\nexport { FrontMcpInstance } from './front-mcp';\nexport * from './common';\n\n// Tool change events for subscription\nexport { ToolChangeEvent, ToolChangeKind, ToolChangeScope } from './tool/tool.events';\n\nexport const ToolHook = FlowHooksOf('tools:call-tool');\nexport const ListToolsHook = FlowHooksOf('tools:list-tools');\nexport const HttpHook = FlowHooksOf('http:request');\n\n// Resource hooks\nexport const ResourceHook = FlowHooksOf('resources:read-resource');\nexport const ListResourcesHook = FlowHooksOf('resources:list-resources');\nexport const ListResourceTemplatesHook = FlowHooksOf('resources:list-resource-templates');\n"]}
|
|
@@ -41,8 +41,9 @@ class LoggerInstance extends common_1.FrontMcpLogger {
|
|
|
41
41
|
}
|
|
42
42
|
catch (err) {
|
|
43
43
|
// Never throw from logging
|
|
44
|
+
// Use safe logging to avoid Node.js 24 util.inspect bug with Zod errors
|
|
44
45
|
// eslint-disable-next-line no-console
|
|
45
|
-
console.error('[Logger] Transport error:', err);
|
|
46
|
+
console.error('[Logger] Transport error:', err instanceof Error ? err.message : 'Unknown error');
|
|
46
47
|
}
|
|
47
48
|
}
|
|
48
49
|
}
|
|
@@ -63,7 +64,7 @@ class LoggerInstance extends common_1.FrontMcpLogger {
|
|
|
63
64
|
}
|
|
64
65
|
_getter(level) {
|
|
65
66
|
if (level < this.level || this.level === common_1.LogLevel.Off)
|
|
66
|
-
return (
|
|
67
|
+
return () => void 0;
|
|
67
68
|
if (process.env['NODE_ENV'] === 'development' && this.config.enableConsole && this.consoleTransport) {
|
|
68
69
|
return this.consoleTransport.bind(level, this.prefix);
|
|
69
70
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"instance.logger.js","sourceRoot":"","sources":["../../../../src/logger/instances/instance.logger.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"instance.logger.js","sourceRoot":"","sources":["../../../../src/logger/instances/instance.logger.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n FrontMcpLogger,\n LogTransportInterface,\n LogFn,\n LoggingConfigType,\n LogLevel,\n LogLevelName,\n LogRecord,\n} from '../../common';\nimport { ConsoleLogTransportInstance } from './instance.console-logger';\n\nexport type GetTransports = () => {\n consoleTransport?: ConsoleLogTransportInstance;\n transports: LogTransportInterface[];\n};\n\nexport class LoggerInstance extends FrontMcpLogger {\n private readonly level: LogLevel;\n private readonly prefix: string;\n private readonly transports: LogTransportInterface[];\n private readonly consoleTransport?: ConsoleLogTransportInstance;\n\n constructor(private readonly config: LoggingConfigType, private getTransports: GetTransports) {\n super();\n this.level = config.level;\n this.prefix = config.prefix ?? '';\n\n const { transports, consoleTransport } = getTransports();\n this.transports = transports;\n this.consoleTransport = consoleTransport;\n }\n\n child(prefix: string): FrontMcpLogger {\n return new LoggerInstance({ ...this.config, prefix }, this.getTransports);\n }\n\n /** Internal: fan out to transports if level passes a threshold. */\n private emit(level: LogLevel, message: string, args: unknown[]) {\n if (level < this.level || this.level === LogLevel.Off) return;\n const rec: LogRecord = {\n level,\n levelName: LogLevelName[level],\n message,\n args,\n timestamp: new Date(),\n prefix: this.prefix,\n };\n for (const t of this.transports) {\n try {\n // Fire-and-forget; transports may be async\n void t.log(rec);\n } catch (err) {\n // Never throw from logging\n // Use safe logging to avoid Node.js 24 util.inspect bug with Zod errors\n // eslint-disable-next-line no-console\n console.error('[Logger] Transport error:', err instanceof Error ? err.message : 'Unknown error');\n }\n }\n }\n\n get verbose(): LogFn {\n return this._getter(LogLevel.VERBOSE);\n }\n\n get debug(): LogFn {\n return this._getter(LogLevel.Debug);\n }\n\n get info(): LogFn {\n return this._getter(LogLevel.Info);\n }\n\n get warn(): LogFn {\n return this._getter(LogLevel.Warn);\n }\n\n get error(): LogFn {\n return this._getter(LogLevel.Error);\n }\n\n private _getter(level: LogLevel): LogFn {\n if (level < this.level || this.level === LogLevel.Off) return () => void 0;\n if (process.env['NODE_ENV'] === 'development' && this.config.enableConsole && this.consoleTransport) {\n return this.consoleTransport.bind(level, this.prefix);\n }\n const emit = this.emit.bind(this);\n return function (...args: unknown[]) {\n emit(level, String(args[0]), Array.prototype.slice.call(args, 1));\n };\n }\n}\n"]}
|
|
@@ -13,8 +13,13 @@ class LoggerRegistry extends regsitry_1.RegistryAbstract {
|
|
|
13
13
|
config;
|
|
14
14
|
constructor(globalProviders) {
|
|
15
15
|
const { logging } = globalProviders.get(front_mcp_tokens_1.FrontMcpConfig);
|
|
16
|
-
const
|
|
17
|
-
|
|
16
|
+
const loggingConfig = logging ?? {
|
|
17
|
+
level: common_1.LogLevel.Info,
|
|
18
|
+
enableConsole: true,
|
|
19
|
+
transports: [],
|
|
20
|
+
};
|
|
21
|
+
const { transports, ...config } = loggingConfig;
|
|
22
|
+
const list = [...(transports ?? [])];
|
|
18
23
|
if (config.enableConsole) {
|
|
19
24
|
list.push(instance_console_logger_1.ConsoleLogTransportInstance);
|
|
20
25
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"logger.registry.js","sourceRoot":"","sources":["../../../src/logger/logger.registry.ts"],"names":[],"mappings":";;AAAA,4BAA0B;AAC1B,
|
|
1
|
+
{"version":3,"file":"logger.registry.js","sourceRoot":"","sources":["../../../src/logger/logger.registry.ts"],"names":[],"mappings":"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","sourcesContent":["import 'reflect-metadata';\nimport {\n FrontMcpLogger,\n LogLevel,\n LogTransportType,\n LogTransportInterface,\n LoggingConfigType,\n ProviderScope,\n Token,\n} from '../common';\nimport { RegistryAbstract, RegistryBuildMapResult } from '../regsitry';\nimport ProviderRegistry from '../provider/provider.registry';\nimport { LoggerKind, LoggerRecord } from './logger.types';\nimport { loggerDiscoveryDeps, normalizeLogger } from './logger.utils';\nimport { FrontMcpConfig } from '../front-mcp/front-mcp.tokens';\nimport { ConsoleLogTransportInstance } from './instances/instance.console-logger';\nimport { tokenName } from '../utils/token.utils';\nimport { GetTransports, LoggerInstance } from './instances/instance.logger';\n\nexport default class LoggerRegistry extends RegistryAbstract<LogTransportInterface, LoggerRecord, LogTransportType[]> {\n config: LoggingConfigType;\n\n constructor(globalProviders: ProviderRegistry) {\n const { logging } = globalProviders.get(FrontMcpConfig);\n const loggingConfig = logging ?? {\n level: LogLevel.Info,\n enableConsole: true,\n transports: [] as LogTransportType[],\n };\n const { transports, ...config } = loggingConfig;\n const list: LogTransportType[] = [...(transports ?? [])];\n if (config.enableConsole) {\n list.push(ConsoleLogTransportInstance);\n }\n\n super('LoggerRegistry', globalProviders, list);\n\n this.config = config;\n }\n\n protected buildGraph() {\n for (const token of this.tokens) {\n const rec = this.defs.get(token)!;\n const deps = loggerDiscoveryDeps(rec).slice(1);\n for (const d of deps) {\n if (!this.providers.get(d)) {\n throw new Error(`Logger ${tokenName(token)} depends on ${tokenName(d)}, which is not registered.`);\n }\n this.graph.get(token)!.add(d);\n }\n }\n }\n\n protected override buildMap(list: LogTransportType[]): RegistryBuildMapResult<LoggerRecord> {\n const tokens = new Set<Token>();\n const defs = new Map<Token, LoggerRecord>();\n const graph = new Map<Token, Set<Token>>();\n\n for (const raw of list) {\n const rec = normalizeLogger(raw);\n const provide = rec.provide;\n tokens.add(provide);\n defs.set(provide, rec);\n graph.set(provide, new Set());\n }\n\n return {\n tokens,\n defs,\n graph,\n };\n }\n\n protected async initialize(): Promise<void> {\n for (const token of this.tokens) {\n const rec = this.defs.get(token)!;\n const deps = this.graph.get(token)!;\n\n const depsTokens = [...deps];\n const depsInstances = await Promise.all(depsTokens.map((t) => this.providers.resolveBootstrapDep(t)));\n\n let app: LogTransportInterface;\n if (rec.kind === LoggerKind.CLASS_TOKEN) {\n const LocalAppClass = rec.provide;\n app = new LocalAppClass(this.config, ...depsInstances);\n } else {\n throw Error('Invalid logger kind');\n }\n\n this.instances.set(token, app);\n }\n this.bindLogger();\n }\n\n protected bindLogger() {\n const consoleTransport = this.instances.get(ConsoleLogTransportInstance) as ConsoleLogTransportInstance;\n const transports = [...this.instances.values()];\n const getTransports: GetTransports = () => {\n return { consoleTransport, transports };\n };\n const logger = new LoggerInstance(this.config, getTransports);\n\n this.providers.injectProvider({\n provide: FrontMcpLogger,\n value: logger,\n metadata: {\n id: 'frontmcp-logger',\n name: 'FrontMcpLogger',\n scope: ProviderScope.GLOBAL,\n description: 'Logger instance that transport logs to all registered transporters.',\n },\n });\n }\n}\n"]}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { FlowBase, FlowRunOptions } from '../../common';
|
|
2
|
+
import { z } from 'zod';
|
|
3
|
+
declare const inputSchema: z.ZodObject<{
|
|
4
|
+
request: z.ZodObject<{
|
|
5
|
+
method: z.ZodLiteral<"logging/setLevel">;
|
|
6
|
+
params: z.ZodObject<{
|
|
7
|
+
_meta: z.ZodOptional<z.ZodObject<{
|
|
8
|
+
progressToken: z.ZodOptional<z.ZodUnion<readonly [z.ZodString, z.ZodNumber]>>;
|
|
9
|
+
}, z.core.$loose>>;
|
|
10
|
+
level: z.ZodEnum<{
|
|
11
|
+
error: "error";
|
|
12
|
+
debug: "debug";
|
|
13
|
+
info: "info";
|
|
14
|
+
notice: "notice";
|
|
15
|
+
warning: "warning";
|
|
16
|
+
critical: "critical";
|
|
17
|
+
alert: "alert";
|
|
18
|
+
emergency: "emergency";
|
|
19
|
+
}>;
|
|
20
|
+
}, z.core.$loose>;
|
|
21
|
+
}, z.core.$strip>;
|
|
22
|
+
ctx: z.ZodUnknown;
|
|
23
|
+
}, z.core.$strip>;
|
|
24
|
+
declare const outputSchema: z.ZodObject<{
|
|
25
|
+
_meta: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodUnknown>>;
|
|
26
|
+
}, z.core.$strict>;
|
|
27
|
+
declare const stateSchema: z.ZodObject<{
|
|
28
|
+
input: z.ZodObject<{
|
|
29
|
+
level: z.ZodEnum<{
|
|
30
|
+
error: "error";
|
|
31
|
+
debug: "debug";
|
|
32
|
+
info: "info";
|
|
33
|
+
notice: "notice";
|
|
34
|
+
warning: "warning";
|
|
35
|
+
critical: "critical";
|
|
36
|
+
alert: "alert";
|
|
37
|
+
emergency: "emergency";
|
|
38
|
+
}>;
|
|
39
|
+
}, z.core.$strip>;
|
|
40
|
+
sessionId: z.ZodString;
|
|
41
|
+
output: z.ZodObject<{
|
|
42
|
+
_meta: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodUnknown>>;
|
|
43
|
+
}, z.core.$strict>;
|
|
44
|
+
}, z.core.$strip>;
|
|
45
|
+
declare const plan: {
|
|
46
|
+
readonly pre: ["parseInput"];
|
|
47
|
+
readonly execute: ["setLevel"];
|
|
48
|
+
readonly finalize: ["finalize"];
|
|
49
|
+
};
|
|
50
|
+
declare global {
|
|
51
|
+
interface ExtendFlows {
|
|
52
|
+
'logging:set-level': FlowRunOptions<SetLevelFlow, typeof plan, typeof inputSchema, typeof outputSchema, typeof stateSchema>;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
declare const name: "logging:set-level";
|
|
56
|
+
export default class SetLevelFlow extends FlowBase<typeof name> {
|
|
57
|
+
logger: import("../../common").FrontMcpLogger;
|
|
58
|
+
parseInput(): Promise<void>;
|
|
59
|
+
setLevel(): Promise<void>;
|
|
60
|
+
finalize(): Promise<void>;
|
|
61
|
+
}
|
|
62
|
+
export {};
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// file: libs/sdk/src/logging/flows/set-level.flow.ts
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const common_1 = require("../../common");
|
|
6
|
+
const zod_1 = require("zod");
|
|
7
|
+
const types_js_1 = require("@modelcontextprotocol/sdk/types.js");
|
|
8
|
+
const errors_1 = require("../../errors");
|
|
9
|
+
const inputSchema = zod_1.z.object({
|
|
10
|
+
request: types_js_1.SetLevelRequestSchema,
|
|
11
|
+
ctx: zod_1.z.unknown(),
|
|
12
|
+
});
|
|
13
|
+
const outputSchema = types_js_1.EmptyResultSchema;
|
|
14
|
+
const stateSchema = zod_1.z.object({
|
|
15
|
+
input: zod_1.z.object({
|
|
16
|
+
level: types_js_1.LoggingLevelSchema,
|
|
17
|
+
}),
|
|
18
|
+
sessionId: zod_1.z.string(),
|
|
19
|
+
output: outputSchema,
|
|
20
|
+
});
|
|
21
|
+
const plan = {
|
|
22
|
+
pre: ['parseInput'],
|
|
23
|
+
execute: ['setLevel'],
|
|
24
|
+
finalize: ['finalize'],
|
|
25
|
+
};
|
|
26
|
+
const name = 'logging:set-level';
|
|
27
|
+
const { Stage } = (0, common_1.FlowHooksOf)(name);
|
|
28
|
+
let SetLevelFlow = class SetLevelFlow extends common_1.FlowBase {
|
|
29
|
+
logger = this.scopeLogger.child('SetLevelFlow');
|
|
30
|
+
async parseInput() {
|
|
31
|
+
this.logger.verbose('parseInput:start');
|
|
32
|
+
let method;
|
|
33
|
+
let params;
|
|
34
|
+
let ctx;
|
|
35
|
+
try {
|
|
36
|
+
const inputData = inputSchema.parse(this.rawInput);
|
|
37
|
+
method = inputData.request.method;
|
|
38
|
+
params = inputData.request.params;
|
|
39
|
+
ctx = inputData.ctx;
|
|
40
|
+
}
|
|
41
|
+
catch (e) {
|
|
42
|
+
throw new errors_1.InvalidInputError('Invalid Input', e instanceof zod_1.z.ZodError ? e.issues : undefined);
|
|
43
|
+
}
|
|
44
|
+
if (method !== 'logging/setLevel') {
|
|
45
|
+
this.logger.warn(`parseInput: invalid method "${method}"`);
|
|
46
|
+
throw new errors_1.InvalidMethodError(method, 'logging/setLevel');
|
|
47
|
+
}
|
|
48
|
+
// Get session ID from context - required for logging level tracking
|
|
49
|
+
const sessionId = ctx?.['sessionId'];
|
|
50
|
+
if (!sessionId || typeof sessionId !== 'string') {
|
|
51
|
+
this.logger.warn('parseInput: sessionId not found in context');
|
|
52
|
+
throw new errors_1.InvalidInputError('Session ID is required for setting log level');
|
|
53
|
+
}
|
|
54
|
+
this.state.set({ input: params, sessionId });
|
|
55
|
+
this.logger.verbose('parseInput:done');
|
|
56
|
+
}
|
|
57
|
+
async setLevel() {
|
|
58
|
+
this.logger.verbose('setLevel:start');
|
|
59
|
+
const { level } = this.state.required.input;
|
|
60
|
+
const { sessionId } = this.state.required;
|
|
61
|
+
// Set the log level for this session via NotificationService
|
|
62
|
+
const success = this.scope.notifications.setLogLevel(sessionId, level);
|
|
63
|
+
if (success) {
|
|
64
|
+
this.logger.info(`setLevel: session log level set to "${level}"`);
|
|
65
|
+
}
|
|
66
|
+
else {
|
|
67
|
+
// Per MCP spec, return Internal error (-32603) when operation fails
|
|
68
|
+
this.logger.warn(`setLevel: failed to set log level for session (session not registered?)`);
|
|
69
|
+
throw new errors_1.GenericServerError('Failed to set log level: session not registered');
|
|
70
|
+
}
|
|
71
|
+
this.logger.verbose('setLevel:done');
|
|
72
|
+
}
|
|
73
|
+
async finalize() {
|
|
74
|
+
this.logger.verbose('finalize:start');
|
|
75
|
+
// Per MCP spec, logging/setLevel returns an empty result on success
|
|
76
|
+
this.respond({});
|
|
77
|
+
this.logger.verbose('finalize:done');
|
|
78
|
+
}
|
|
79
|
+
};
|
|
80
|
+
tslib_1.__decorate([
|
|
81
|
+
Stage('parseInput'),
|
|
82
|
+
tslib_1.__metadata("design:type", Function),
|
|
83
|
+
tslib_1.__metadata("design:paramtypes", []),
|
|
84
|
+
tslib_1.__metadata("design:returntype", Promise)
|
|
85
|
+
], SetLevelFlow.prototype, "parseInput", null);
|
|
86
|
+
tslib_1.__decorate([
|
|
87
|
+
Stage('setLevel'),
|
|
88
|
+
tslib_1.__metadata("design:type", Function),
|
|
89
|
+
tslib_1.__metadata("design:paramtypes", []),
|
|
90
|
+
tslib_1.__metadata("design:returntype", Promise)
|
|
91
|
+
], SetLevelFlow.prototype, "setLevel", null);
|
|
92
|
+
tslib_1.__decorate([
|
|
93
|
+
Stage('finalize'),
|
|
94
|
+
tslib_1.__metadata("design:type", Function),
|
|
95
|
+
tslib_1.__metadata("design:paramtypes", []),
|
|
96
|
+
tslib_1.__metadata("design:returntype", Promise)
|
|
97
|
+
], SetLevelFlow.prototype, "finalize", null);
|
|
98
|
+
SetLevelFlow = tslib_1.__decorate([
|
|
99
|
+
(0, common_1.Flow)({
|
|
100
|
+
name,
|
|
101
|
+
plan,
|
|
102
|
+
inputSchema,
|
|
103
|
+
outputSchema,
|
|
104
|
+
access: 'authorized',
|
|
105
|
+
})
|
|
106
|
+
], SetLevelFlow);
|
|
107
|
+
exports.default = SetLevelFlow;
|
|
108
|
+
//# sourceMappingURL=set-level.flow.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"set-level.flow.js","sourceRoot":"","sources":["../../../../src/logging/flows/set-level.flow.ts"],"names":[],"mappings":"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","sourcesContent":["// file: libs/sdk/src/logging/flows/set-level.flow.ts\n\nimport { Flow, FlowBase, FlowHooksOf, FlowPlan, FlowRunOptions } from '../../common';\nimport { z } from 'zod';\nimport { SetLevelRequestSchema, EmptyResultSchema, LoggingLevelSchema } from '@modelcontextprotocol/sdk/types.js';\nimport { InvalidMethodError, InvalidInputError, GenericServerError } from '../../errors';\n\nconst inputSchema = z.object({\n request: SetLevelRequestSchema,\n ctx: z.unknown(),\n});\n\nconst outputSchema = EmptyResultSchema;\n\nconst stateSchema = z.object({\n input: z.object({\n level: LoggingLevelSchema,\n }),\n sessionId: z.string(),\n output: outputSchema,\n});\n\nconst plan = {\n pre: ['parseInput'],\n execute: ['setLevel'],\n finalize: ['finalize'],\n} as const satisfies FlowPlan<string>;\n\ndeclare global {\n interface ExtendFlows {\n 'logging:set-level': FlowRunOptions<\n SetLevelFlow,\n typeof plan,\n typeof inputSchema,\n typeof outputSchema,\n typeof stateSchema\n >;\n }\n}\n\nconst name = 'logging:set-level' as const;\nconst { Stage } = FlowHooksOf<'logging:set-level'>(name);\n\n@Flow({\n name,\n plan,\n inputSchema,\n outputSchema,\n access: 'authorized',\n})\nexport default class SetLevelFlow extends FlowBase<typeof name> {\n logger = this.scopeLogger.child('SetLevelFlow');\n\n @Stage('parseInput')\n async parseInput() {\n this.logger.verbose('parseInput:start');\n\n let method!: string;\n let params: z.infer<typeof SetLevelRequestSchema>['params'];\n let ctx: unknown;\n try {\n const inputData = inputSchema.parse(this.rawInput);\n method = inputData.request.method;\n params = inputData.request.params;\n ctx = inputData.ctx;\n } catch (e) {\n throw new InvalidInputError('Invalid Input', e instanceof z.ZodError ? e.issues : undefined);\n }\n\n if (method !== 'logging/setLevel') {\n this.logger.warn(`parseInput: invalid method \"${method}\"`);\n throw new InvalidMethodError(method, 'logging/setLevel');\n }\n\n // Get session ID from context - required for logging level tracking\n const sessionId = (ctx as Record<string, unknown> | undefined)?.['sessionId'];\n if (!sessionId || typeof sessionId !== 'string') {\n this.logger.warn('parseInput: sessionId not found in context');\n throw new InvalidInputError('Session ID is required for setting log level');\n }\n\n this.state.set({ input: params, sessionId });\n this.logger.verbose('parseInput:done');\n }\n\n @Stage('setLevel')\n async setLevel() {\n this.logger.verbose('setLevel:start');\n const { level } = this.state.required.input;\n const { sessionId } = this.state.required;\n\n // Set the log level for this session via NotificationService\n const success = this.scope.notifications.setLogLevel(sessionId, level);\n\n if (success) {\n this.logger.info(`setLevel: session log level set to \"${level}\"`);\n } else {\n // Per MCP spec, return Internal error (-32603) when operation fails\n this.logger.warn(`setLevel: failed to set log level for session (session not registered?)`);\n throw new GenericServerError('Failed to set log level: session not registered');\n }\n\n this.logger.verbose('setLevel:done');\n }\n\n @Stage('finalize')\n async finalize() {\n this.logger.verbose('finalize:start');\n // Per MCP spec, logging/setLevel returns an empty result on success\n this.respond({});\n this.logger.verbose('finalize:done');\n }\n}\n"]}
|