x-m32-mcp-server 2.1.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/LICENSE +21 -0
- package/README.md +281 -0
- package/dist/cjs/client/auth.d.ts +270 -0
- package/dist/cjs/client/auth.d.ts.map +1 -0
- package/dist/cjs/client/auth.js +747 -0
- package/dist/cjs/client/auth.js.map +1 -0
- package/dist/cjs/client/index.d.ts +913 -0
- package/dist/cjs/client/index.d.ts.map +1 -0
- package/dist/cjs/client/index.js +367 -0
- package/dist/cjs/client/index.js.map +1 -0
- package/dist/cjs/client/middleware.d.ts +169 -0
- package/dist/cjs/client/middleware.d.ts.map +1 -0
- package/dist/cjs/client/middleware.js +252 -0
- package/dist/cjs/client/middleware.js.map +1 -0
- package/dist/cjs/client/sse.d.ts +80 -0
- package/dist/cjs/client/sse.d.ts.map +1 -0
- package/dist/cjs/client/sse.js +211 -0
- package/dist/cjs/client/sse.js.map +1 -0
- package/dist/cjs/client/stdio.d.ts +78 -0
- package/dist/cjs/client/stdio.d.ts.map +1 -0
- package/dist/cjs/client/stdio.js +184 -0
- package/dist/cjs/client/stdio.js.map +1 -0
- package/dist/cjs/client/streamableHttp.d.ts +158 -0
- package/dist/cjs/client/streamableHttp.d.ts.map +1 -0
- package/dist/cjs/client/streamableHttp.js +406 -0
- package/dist/cjs/client/streamableHttp.js.map +1 -0
- package/dist/cjs/client/websocket.d.ts +17 -0
- package/dist/cjs/client/websocket.d.ts.map +1 -0
- package/dist/cjs/client/websocket.js +63 -0
- package/dist/cjs/client/websocket.js.map +1 -0
- package/dist/cjs/examples/client/multipleClientsParallel.d.ts +2 -0
- package/dist/cjs/examples/client/multipleClientsParallel.d.ts.map +1 -0
- package/dist/cjs/examples/client/multipleClientsParallel.js +134 -0
- package/dist/cjs/examples/client/multipleClientsParallel.js.map +1 -0
- package/dist/cjs/examples/client/parallelToolCallsClient.d.ts +2 -0
- package/dist/cjs/examples/client/parallelToolCallsClient.d.ts.map +1 -0
- package/dist/cjs/examples/client/parallelToolCallsClient.js +176 -0
- package/dist/cjs/examples/client/parallelToolCallsClient.js.map +1 -0
- package/dist/cjs/examples/client/simpleOAuthClient.d.ts +3 -0
- package/dist/cjs/examples/client/simpleOAuthClient.d.ts.map +1 -0
- package/dist/cjs/examples/client/simpleOAuthClient.js +376 -0
- package/dist/cjs/examples/client/simpleOAuthClient.js.map +1 -0
- package/dist/cjs/examples/client/simpleStreamableHttp.d.ts +2 -0
- package/dist/cjs/examples/client/simpleStreamableHttp.d.ts.map +1 -0
- package/dist/cjs/examples/client/simpleStreamableHttp.js +744 -0
- package/dist/cjs/examples/client/simpleStreamableHttp.js.map +1 -0
- package/dist/cjs/examples/client/streamableHttpWithSseFallbackClient.d.ts +2 -0
- package/dist/cjs/examples/client/streamableHttpWithSseFallbackClient.d.ts.map +1 -0
- package/dist/cjs/examples/client/streamableHttpWithSseFallbackClient.js +168 -0
- package/dist/cjs/examples/client/streamableHttpWithSseFallbackClient.js.map +1 -0
- package/dist/cjs/examples/server/demoInMemoryOAuthProvider.d.ts +78 -0
- package/dist/cjs/examples/server/demoInMemoryOAuthProvider.d.ts.map +1 -0
- package/dist/cjs/examples/server/demoInMemoryOAuthProvider.js +189 -0
- package/dist/cjs/examples/server/demoInMemoryOAuthProvider.js.map +1 -0
- package/dist/cjs/examples/server/elicitationExample.d.ts +2 -0
- package/dist/cjs/examples/server/elicitationExample.d.ts.map +1 -0
- package/dist/cjs/examples/server/elicitationExample.js +435 -0
- package/dist/cjs/examples/server/elicitationExample.js.map +1 -0
- package/dist/cjs/examples/server/jsonResponseStreamableHttp.d.ts +2 -0
- package/dist/cjs/examples/server/jsonResponseStreamableHttp.d.ts.map +1 -0
- package/dist/cjs/examples/server/jsonResponseStreamableHttp.js +152 -0
- package/dist/cjs/examples/server/jsonResponseStreamableHttp.js.map +1 -0
- package/dist/cjs/examples/server/mcpServerOutputSchema.d.ts +7 -0
- package/dist/cjs/examples/server/mcpServerOutputSchema.d.ts.map +1 -0
- package/dist/cjs/examples/server/mcpServerOutputSchema.js +72 -0
- package/dist/cjs/examples/server/mcpServerOutputSchema.js.map +1 -0
- package/dist/cjs/examples/server/simpleSseServer.d.ts +2 -0
- package/dist/cjs/examples/server/simpleSseServer.d.ts.map +1 -0
- package/dist/cjs/examples/server/simpleSseServer.js +146 -0
- package/dist/cjs/examples/server/simpleSseServer.js.map +1 -0
- package/dist/cjs/examples/server/simpleStatelessStreamableHttp.d.ts +2 -0
- package/dist/cjs/examples/server/simpleStatelessStreamableHttp.d.ts.map +1 -0
- package/dist/cjs/examples/server/simpleStatelessStreamableHttp.js +147 -0
- package/dist/cjs/examples/server/simpleStatelessStreamableHttp.js.map +1 -0
- package/dist/cjs/examples/server/simpleStreamableHttp.d.ts +2 -0
- package/dist/cjs/examples/server/simpleStreamableHttp.d.ts.map +1 -0
- package/dist/cjs/examples/server/simpleStreamableHttp.js +587 -0
- package/dist/cjs/examples/server/simpleStreamableHttp.js.map +1 -0
- package/dist/cjs/examples/server/sseAndStreamableHttpCompatibleServer.d.ts +2 -0
- package/dist/cjs/examples/server/sseAndStreamableHttpCompatibleServer.d.ts.map +1 -0
- package/dist/cjs/examples/server/sseAndStreamableHttpCompatibleServer.js +240 -0
- package/dist/cjs/examples/server/sseAndStreamableHttpCompatibleServer.js.map +1 -0
- package/dist/cjs/examples/server/standaloneSseWithGetStreamableHttp.d.ts +2 -0
- package/dist/cjs/examples/server/standaloneSseWithGetStreamableHttp.d.ts.map +1 -0
- package/dist/cjs/examples/server/standaloneSseWithGetStreamableHttp.js +116 -0
- package/dist/cjs/examples/server/standaloneSseWithGetStreamableHttp.js.map +1 -0
- package/dist/cjs/examples/server/toolWithSampleServer.d.ts +2 -0
- package/dist/cjs/examples/server/toolWithSampleServer.d.ts.map +1 -0
- package/dist/cjs/examples/server/toolWithSampleServer.js +49 -0
- package/dist/cjs/examples/server/toolWithSampleServer.js.map +1 -0
- package/dist/cjs/examples/shared/inMemoryEventStore.d.ts +31 -0
- package/dist/cjs/examples/shared/inMemoryEventStore.d.ts.map +1 -0
- package/dist/cjs/examples/shared/inMemoryEventStore.js +69 -0
- package/dist/cjs/examples/shared/inMemoryEventStore.js.map +1 -0
- package/dist/cjs/inMemory.d.ts +31 -0
- package/dist/cjs/inMemory.d.ts.map +1 -0
- package/dist/cjs/inMemory.js +53 -0
- package/dist/cjs/inMemory.js.map +1 -0
- package/dist/cjs/index.d.ts +3 -0
- package/dist/cjs/index.d.ts.map +1 -0
- package/dist/cjs/index.js +85 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/package.json +1 -0
- package/dist/cjs/server/auth/clients.d.ts +19 -0
- package/dist/cjs/server/auth/clients.d.ts.map +1 -0
- package/dist/cjs/server/auth/clients.js +3 -0
- package/dist/cjs/server/auth/clients.js.map +1 -0
- package/dist/cjs/server/auth/errors.d.ts +141 -0
- package/dist/cjs/server/auth/errors.d.ts.map +1 -0
- package/dist/cjs/server/auth/errors.js +193 -0
- package/dist/cjs/server/auth/errors.js.map +1 -0
- package/dist/cjs/server/auth/handlers/authorize.d.ts +13 -0
- package/dist/cjs/server/auth/handlers/authorize.d.ts.map +1 -0
- package/dist/cjs/server/auth/handlers/authorize.js +144 -0
- package/dist/cjs/server/auth/handlers/authorize.js.map +1 -0
- package/dist/cjs/server/auth/handlers/metadata.d.ts +4 -0
- package/dist/cjs/server/auth/handlers/metadata.d.ts.map +1 -0
- package/dist/cjs/server/auth/handlers/metadata.js +21 -0
- package/dist/cjs/server/auth/handlers/metadata.js.map +1 -0
- package/dist/cjs/server/auth/handlers/register.d.ts +29 -0
- package/dist/cjs/server/auth/handlers/register.d.ts.map +1 -0
- package/dist/cjs/server/auth/handlers/register.js +77 -0
- package/dist/cjs/server/auth/handlers/register.js.map +1 -0
- package/dist/cjs/server/auth/handlers/revoke.d.ts +13 -0
- package/dist/cjs/server/auth/handlers/revoke.d.ts.map +1 -0
- package/dist/cjs/server/auth/handlers/revoke.js +65 -0
- package/dist/cjs/server/auth/handlers/revoke.js.map +1 -0
- package/dist/cjs/server/auth/handlers/token.d.ts +13 -0
- package/dist/cjs/server/auth/handlers/token.d.ts.map +1 -0
- package/dist/cjs/server/auth/handlers/token.js +113 -0
- package/dist/cjs/server/auth/handlers/token.js.map +1 -0
- package/dist/cjs/server/auth/middleware/allowedMethods.d.ts +9 -0
- package/dist/cjs/server/auth/middleware/allowedMethods.d.ts.map +1 -0
- package/dist/cjs/server/auth/middleware/allowedMethods.js +21 -0
- package/dist/cjs/server/auth/middleware/allowedMethods.js.map +1 -0
- package/dist/cjs/server/auth/middleware/bearerAuth.d.ts +35 -0
- package/dist/cjs/server/auth/middleware/bearerAuth.d.ts.map +1 -0
- package/dist/cjs/server/auth/middleware/bearerAuth.js +70 -0
- package/dist/cjs/server/auth/middleware/bearerAuth.js.map +1 -0
- package/dist/cjs/server/auth/middleware/clientAuth.d.ts +19 -0
- package/dist/cjs/server/auth/middleware/clientAuth.d.ts.map +1 -0
- package/dist/cjs/server/auth/middleware/clientAuth.js +52 -0
- package/dist/cjs/server/auth/middleware/clientAuth.js.map +1 -0
- package/dist/cjs/server/auth/provider.d.ts +68 -0
- package/dist/cjs/server/auth/provider.d.ts.map +1 -0
- package/dist/cjs/server/auth/provider.js +3 -0
- package/dist/cjs/server/auth/provider.js.map +1 -0
- package/dist/cjs/server/auth/providers/proxyProvider.d.ts +49 -0
- package/dist/cjs/server/auth/providers/proxyProvider.d.ts.map +1 -0
- package/dist/cjs/server/auth/providers/proxyProvider.js +161 -0
- package/dist/cjs/server/auth/providers/proxyProvider.js.map +1 -0
- package/dist/cjs/server/auth/router.d.ts +101 -0
- package/dist/cjs/server/auth/router.d.ts.map +1 -0
- package/dist/cjs/server/auth/router.js +125 -0
- package/dist/cjs/server/auth/router.js.map +1 -0
- package/dist/cjs/server/auth/types.d.ts +32 -0
- package/dist/cjs/server/auth/types.d.ts.map +1 -0
- package/dist/cjs/server/auth/types.js +3 -0
- package/dist/cjs/server/auth/types.js.map +1 -0
- package/dist/cjs/server/completable.d.ts +24 -0
- package/dist/cjs/server/completable.d.ts.map +1 -0
- package/dist/cjs/server/completable.js +65 -0
- package/dist/cjs/server/completable.js.map +1 -0
- package/dist/cjs/server/index.d.ts +191 -0
- package/dist/cjs/server/index.d.ts.map +1 -0
- package/dist/cjs/server/index.js +259 -0
- package/dist/cjs/server/index.js.map +1 -0
- package/dist/cjs/server/mcp.d.ts +331 -0
- package/dist/cjs/server/mcp.d.ts.map +1 -0
- package/dist/cjs/server/mcp.js +706 -0
- package/dist/cjs/server/mcp.js.map +1 -0
- package/dist/cjs/server/sse.d.ts +76 -0
- package/dist/cjs/server/sse.d.ts.map +1 -0
- package/dist/cjs/server/sse.js +168 -0
- package/dist/cjs/server/sse.js.map +1 -0
- package/dist/cjs/server/stdio.d.ts +28 -0
- package/dist/cjs/server/stdio.d.ts.map +1 -0
- package/dist/cjs/server/stdio.js +85 -0
- package/dist/cjs/server/stdio.js.map +1 -0
- package/dist/cjs/server/streamableHttp.d.ts +185 -0
- package/dist/cjs/server/streamableHttp.d.ts.map +1 -0
- package/dist/cjs/server/streamableHttp.js +631 -0
- package/dist/cjs/server/streamableHttp.js.map +1 -0
- package/dist/cjs/server.d.ts +3 -0
- package/dist/cjs/server.d.ts.map +1 -0
- package/dist/cjs/server.js +9 -0
- package/dist/cjs/server.js.map +1 -0
- package/dist/cjs/services/x32-connection.d.ts +87 -0
- package/dist/cjs/services/x32-connection.d.ts.map +1 -0
- package/dist/cjs/services/x32-connection.js +287 -0
- package/dist/cjs/services/x32-connection.js.map +1 -0
- package/dist/cjs/shared/auth-utils.d.ts +23 -0
- package/dist/cjs/shared/auth-utils.d.ts.map +1 -0
- package/dist/cjs/shared/auth-utils.js +48 -0
- package/dist/cjs/shared/auth-utils.js.map +1 -0
- package/dist/cjs/shared/auth.d.ts +626 -0
- package/dist/cjs/shared/auth.d.ts.map +1 -0
- package/dist/cjs/shared/auth.js +203 -0
- package/dist/cjs/shared/auth.js.map +1 -0
- package/dist/cjs/shared/metadataUtils.d.ts +16 -0
- package/dist/cjs/shared/metadataUtils.d.ts.map +1 -0
- package/dist/cjs/shared/metadataUtils.js +26 -0
- package/dist/cjs/shared/metadataUtils.js.map +1 -0
- package/dist/cjs/shared/protocol.d.ts +230 -0
- package/dist/cjs/shared/protocol.d.ts.map +1 -0
- package/dist/cjs/shared/protocol.js +428 -0
- package/dist/cjs/shared/protocol.js.map +1 -0
- package/dist/cjs/shared/stdio.d.ts +13 -0
- package/dist/cjs/shared/stdio.d.ts.map +1 -0
- package/dist/cjs/shared/stdio.js +37 -0
- package/dist/cjs/shared/stdio.js.map +1 -0
- package/dist/cjs/shared/toolNameValidation.d.ts +31 -0
- package/dist/cjs/shared/toolNameValidation.d.ts.map +1 -0
- package/dist/cjs/shared/toolNameValidation.js +97 -0
- package/dist/cjs/shared/toolNameValidation.js.map +1 -0
- package/dist/cjs/shared/transport.d.ts +75 -0
- package/dist/cjs/shared/transport.d.ts.map +1 -0
- package/dist/cjs/shared/transport.js +3 -0
- package/dist/cjs/shared/transport.js.map +1 -0
- package/dist/cjs/shared/uriTemplate.d.ts +25 -0
- package/dist/cjs/shared/uriTemplate.d.ts.map +1 -0
- package/dist/cjs/shared/uriTemplate.js +243 -0
- package/dist/cjs/shared/uriTemplate.js.map +1 -0
- package/dist/cjs/spec.types.d.ts +1687 -0
- package/dist/cjs/spec.types.d.ts.map +1 -0
- package/dist/cjs/spec.types.js +29 -0
- package/dist/cjs/spec.types.js.map +1 -0
- package/dist/cjs/tools/channel.d.ts +7 -0
- package/dist/cjs/tools/channel.d.ts.map +1 -0
- package/dist/cjs/tools/channel.js +536 -0
- package/dist/cjs/tools/channel.js.map +1 -0
- package/dist/cjs/tools/connection.d.ts +7 -0
- package/dist/cjs/tools/connection.d.ts.map +1 -0
- package/dist/cjs/tools/connection.js +230 -0
- package/dist/cjs/tools/connection.js.map +1 -0
- package/dist/cjs/tools/index.d.ts +8 -0
- package/dist/cjs/tools/index.d.ts.map +1 -0
- package/dist/cjs/tools/index.js +14 -0
- package/dist/cjs/tools/index.js.map +1 -0
- package/dist/cjs/tools/parameter.d.ts +7 -0
- package/dist/cjs/tools/parameter.d.ts.map +1 -0
- package/dist/cjs/tools/parameter.js +129 -0
- package/dist/cjs/tools/parameter.js.map +1 -0
- package/dist/cjs/types/index.d.ts +4 -0
- package/dist/cjs/types/index.d.ts.map +1 -0
- package/dist/cjs/types/index.js +20 -0
- package/dist/cjs/types/index.js.map +1 -0
- package/dist/cjs/types/osc.d.ts +36 -0
- package/dist/cjs/types/osc.d.ts.map +1 -0
- package/dist/cjs/types/osc.js +7 -0
- package/dist/cjs/types/osc.js.map +1 -0
- package/dist/cjs/types/x32.d.ts +94 -0
- package/dist/cjs/types/x32.d.ts.map +1 -0
- package/dist/cjs/types/x32.js +3 -0
- package/dist/cjs/types/x32.js.map +1 -0
- package/dist/cjs/types.d.ts +24615 -0
- package/dist/cjs/types.d.ts.map +1 -0
- package/dist/cjs/types.js +1434 -0
- package/dist/cjs/types.js.map +1 -0
- package/dist/cjs/utils/color-converter.d.ts +54 -0
- package/dist/cjs/utils/color-converter.d.ts.map +1 -0
- package/dist/cjs/utils/color-converter.js +86 -0
- package/dist/cjs/utils/color-converter.js.map +1 -0
- package/dist/cjs/utils/db-converter.d.ts +58 -0
- package/dist/cjs/utils/db-converter.d.ts.map +1 -0
- package/dist/cjs/utils/db-converter.js +150 -0
- package/dist/cjs/utils/db-converter.js.map +1 -0
- package/dist/cjs/utils/pan-converter.d.ts +56 -0
- package/dist/cjs/utils/pan-converter.d.ts.map +1 -0
- package/dist/cjs/utils/pan-converter.js +135 -0
- package/dist/cjs/utils/pan-converter.js.map +1 -0
- package/dist/cjs/validation/ajv-provider.d.ts +53 -0
- package/dist/cjs/validation/ajv-provider.d.ts.map +1 -0
- package/dist/cjs/validation/ajv-provider.js +95 -0
- package/dist/cjs/validation/ajv-provider.js.map +1 -0
- package/dist/cjs/validation/cfworker-provider.d.ts +52 -0
- package/dist/cjs/validation/cfworker-provider.d.ts.map +1 -0
- package/dist/cjs/validation/cfworker-provider.js +71 -0
- package/dist/cjs/validation/cfworker-provider.js.map +1 -0
- package/dist/cjs/validation/index.d.ts +29 -0
- package/dist/cjs/validation/index.d.ts.map +1 -0
- package/dist/cjs/validation/index.js +30 -0
- package/dist/cjs/validation/index.js.map +1 -0
- package/dist/cjs/validation/types.d.ts +55 -0
- package/dist/cjs/validation/types.d.ts.map +1 -0
- package/dist/cjs/validation/types.js +3 -0
- package/dist/cjs/validation/types.js.map +1 -0
- package/dist/cjs/x32-server/index.d.ts +3 -0
- package/dist/cjs/x32-server/index.d.ts.map +1 -0
- package/dist/cjs/x32-server/index.js +73 -0
- package/dist/cjs/x32-server/index.js.map +1 -0
- package/dist/cjs/x32-server/tools/channel.tool.d.ts +8 -0
- package/dist/cjs/x32-server/tools/channel.tool.d.ts.map +1 -0
- package/dist/cjs/x32-server/tools/channel.tool.js +82 -0
- package/dist/cjs/x32-server/tools/channel.tool.js.map +1 -0
- package/dist/cjs/x32-server/tools/connect.tool.d.ts +8 -0
- package/dist/cjs/x32-server/tools/connect.tool.d.ts.map +1 -0
- package/dist/cjs/x32-server/tools/connect.tool.js +54 -0
- package/dist/cjs/x32-server/tools/connect.tool.js.map +1 -0
- package/dist/cjs/x32-server/tools/get-parameter.tool.d.ts +8 -0
- package/dist/cjs/x32-server/tools/get-parameter.tool.d.ts.map +1 -0
- package/dist/cjs/x32-server/tools/get-parameter.tool.js +54 -0
- package/dist/cjs/x32-server/tools/get-parameter.tool.js.map +1 -0
- package/dist/cjs/x32-server/tools/index.d.ts +11 -0
- package/dist/cjs/x32-server/tools/index.d.ts.map +1 -0
- package/dist/cjs/x32-server/tools/index.js +20 -0
- package/dist/cjs/x32-server/tools/index.js.map +1 -0
- package/dist/cjs/x32-server/tools/info.tool.d.ts +8 -0
- package/dist/cjs/x32-server/tools/info.tool.d.ts.map +1 -0
- package/dist/cjs/x32-server/tools/info.tool.js +57 -0
- package/dist/cjs/x32-server/tools/info.tool.js.map +1 -0
- package/dist/cjs/x32-server/tools/set-parameter.tool.d.ts +8 -0
- package/dist/cjs/x32-server/tools/set-parameter.tool.d.ts.map +1 -0
- package/dist/cjs/x32-server/tools/set-parameter.tool.js +55 -0
- package/dist/cjs/x32-server/tools/set-parameter.tool.js.map +1 -0
- package/dist/cjs/x32-server/tools/status.tool.d.ts +8 -0
- package/dist/cjs/x32-server/tools/status.tool.d.ts.map +1 -0
- package/dist/cjs/x32-server/tools/status.tool.js +52 -0
- package/dist/cjs/x32-server/tools/status.tool.js.map +1 -0
- package/dist/cjs/x32-server/types.d.ts +94 -0
- package/dist/cjs/x32-server/types.d.ts.map +1 -0
- package/dist/cjs/x32-server/types.js +3 -0
- package/dist/cjs/x32-server/types.js.map +1 -0
- package/dist/cjs/x32-server/x32-connection.d.ts +87 -0
- package/dist/cjs/x32-server/x32-connection.d.ts.map +1 -0
- package/dist/cjs/x32-server/x32-connection.js +277 -0
- package/dist/cjs/x32-server/x32-connection.js.map +1 -0
- package/dist/esm/client/auth.d.ts +270 -0
- package/dist/esm/client/auth.d.ts.map +1 -0
- package/dist/esm/client/auth.js +726 -0
- package/dist/esm/client/auth.js.map +1 -0
- package/dist/esm/client/index.d.ts +913 -0
- package/dist/esm/client/index.d.ts.map +1 -0
- package/dist/esm/client/index.js +363 -0
- package/dist/esm/client/index.js.map +1 -0
- package/dist/esm/client/middleware.d.ts +169 -0
- package/dist/esm/client/middleware.d.ts.map +1 -0
- package/dist/esm/client/middleware.js +245 -0
- package/dist/esm/client/middleware.js.map +1 -0
- package/dist/esm/client/sse.d.ts +80 -0
- package/dist/esm/client/sse.d.ts.map +1 -0
- package/dist/esm/client/sse.js +206 -0
- package/dist/esm/client/sse.js.map +1 -0
- package/dist/esm/client/stdio.d.ts +78 -0
- package/dist/esm/client/stdio.d.ts.map +1 -0
- package/dist/esm/client/stdio.js +176 -0
- package/dist/esm/client/stdio.js.map +1 -0
- package/dist/esm/client/streamableHttp.d.ts +158 -0
- package/dist/esm/client/streamableHttp.d.ts.map +1 -0
- package/dist/esm/client/streamableHttp.js +401 -0
- package/dist/esm/client/streamableHttp.js.map +1 -0
- package/dist/esm/client/websocket.d.ts +17 -0
- package/dist/esm/client/websocket.d.ts.map +1 -0
- package/dist/esm/client/websocket.js +59 -0
- package/dist/esm/client/websocket.js.map +1 -0
- package/dist/esm/examples/client/multipleClientsParallel.d.ts +2 -0
- package/dist/esm/examples/client/multipleClientsParallel.d.ts.map +1 -0
- package/dist/esm/examples/client/multipleClientsParallel.js +132 -0
- package/dist/esm/examples/client/multipleClientsParallel.js.map +1 -0
- package/dist/esm/examples/client/parallelToolCallsClient.d.ts +2 -0
- package/dist/esm/examples/client/parallelToolCallsClient.d.ts.map +1 -0
- package/dist/esm/examples/client/parallelToolCallsClient.js +174 -0
- package/dist/esm/examples/client/parallelToolCallsClient.js.map +1 -0
- package/dist/esm/examples/client/simpleOAuthClient.d.ts +3 -0
- package/dist/esm/examples/client/simpleOAuthClient.d.ts.map +1 -0
- package/dist/esm/examples/client/simpleOAuthClient.js +374 -0
- package/dist/esm/examples/client/simpleOAuthClient.js.map +1 -0
- package/dist/esm/examples/client/simpleStreamableHttp.d.ts +2 -0
- package/dist/esm/examples/client/simpleStreamableHttp.d.ts.map +1 -0
- package/dist/esm/examples/client/simpleStreamableHttp.js +742 -0
- package/dist/esm/examples/client/simpleStreamableHttp.js.map +1 -0
- package/dist/esm/examples/client/streamableHttpWithSseFallbackClient.d.ts +2 -0
- package/dist/esm/examples/client/streamableHttpWithSseFallbackClient.d.ts.map +1 -0
- package/dist/esm/examples/client/streamableHttpWithSseFallbackClient.js +166 -0
- package/dist/esm/examples/client/streamableHttpWithSseFallbackClient.js.map +1 -0
- package/dist/esm/examples/server/demoInMemoryOAuthProvider.d.ts +78 -0
- package/dist/esm/examples/server/demoInMemoryOAuthProvider.d.ts.map +1 -0
- package/dist/esm/examples/server/demoInMemoryOAuthProvider.js +180 -0
- package/dist/esm/examples/server/demoInMemoryOAuthProvider.js.map +1 -0
- package/dist/esm/examples/server/elicitationExample.d.ts +2 -0
- package/dist/esm/examples/server/elicitationExample.d.ts.map +1 -0
- package/dist/esm/examples/server/elicitationExample.js +430 -0
- package/dist/esm/examples/server/elicitationExample.js.map +1 -0
- package/dist/esm/examples/server/jsonResponseStreamableHttp.d.ts +2 -0
- package/dist/esm/examples/server/jsonResponseStreamableHttp.d.ts.map +1 -0
- package/dist/esm/examples/server/jsonResponseStreamableHttp.js +147 -0
- package/dist/esm/examples/server/jsonResponseStreamableHttp.js.map +1 -0
- package/dist/esm/examples/server/mcpServerOutputSchema.d.ts +7 -0
- package/dist/esm/examples/server/mcpServerOutputSchema.d.ts.map +1 -0
- package/dist/esm/examples/server/mcpServerOutputSchema.js +70 -0
- package/dist/esm/examples/server/mcpServerOutputSchema.js.map +1 -0
- package/dist/esm/examples/server/simpleSseServer.d.ts +2 -0
- package/dist/esm/examples/server/simpleSseServer.d.ts.map +1 -0
- package/dist/esm/examples/server/simpleSseServer.js +141 -0
- package/dist/esm/examples/server/simpleSseServer.js.map +1 -0
- package/dist/esm/examples/server/simpleStatelessStreamableHttp.d.ts +2 -0
- package/dist/esm/examples/server/simpleStatelessStreamableHttp.d.ts.map +1 -0
- package/dist/esm/examples/server/simpleStatelessStreamableHttp.js +142 -0
- package/dist/esm/examples/server/simpleStatelessStreamableHttp.js.map +1 -0
- package/dist/esm/examples/server/simpleStreamableHttp.d.ts +2 -0
- package/dist/esm/examples/server/simpleStreamableHttp.d.ts.map +1 -0
- package/dist/esm/examples/server/simpleStreamableHttp.js +582 -0
- package/dist/esm/examples/server/simpleStreamableHttp.js.map +1 -0
- package/dist/esm/examples/server/sseAndStreamableHttpCompatibleServer.d.ts +2 -0
- package/dist/esm/examples/server/sseAndStreamableHttpCompatibleServer.d.ts.map +1 -0
- package/dist/esm/examples/server/sseAndStreamableHttpCompatibleServer.js +235 -0
- package/dist/esm/examples/server/sseAndStreamableHttpCompatibleServer.js.map +1 -0
- package/dist/esm/examples/server/standaloneSseWithGetStreamableHttp.d.ts +2 -0
- package/dist/esm/examples/server/standaloneSseWithGetStreamableHttp.d.ts.map +1 -0
- package/dist/esm/examples/server/standaloneSseWithGetStreamableHttp.js +111 -0
- package/dist/esm/examples/server/standaloneSseWithGetStreamableHttp.js.map +1 -0
- package/dist/esm/examples/server/toolWithSampleServer.d.ts +2 -0
- package/dist/esm/examples/server/toolWithSampleServer.d.ts.map +1 -0
- package/dist/esm/examples/server/toolWithSampleServer.js +47 -0
- package/dist/esm/examples/server/toolWithSampleServer.js.map +1 -0
- package/dist/esm/examples/shared/inMemoryEventStore.d.ts +31 -0
- package/dist/esm/examples/shared/inMemoryEventStore.d.ts.map +1 -0
- package/dist/esm/examples/shared/inMemoryEventStore.js +65 -0
- package/dist/esm/examples/shared/inMemoryEventStore.js.map +1 -0
- package/dist/esm/inMemory.d.ts +31 -0
- package/dist/esm/inMemory.d.ts.map +1 -0
- package/dist/esm/inMemory.js +49 -0
- package/dist/esm/inMemory.js.map +1 -0
- package/dist/esm/index.d.ts +3 -0
- package/dist/esm/index.d.ts.map +1 -0
- package/dist/esm/index.js +83 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/mcp/completable.d.ts +24 -0
- package/dist/esm/mcp/completable.d.ts.map +1 -0
- package/dist/esm/mcp/completable.js +60 -0
- package/dist/esm/mcp/completable.js.map +1 -0
- package/dist/esm/mcp/index.d.ts +124 -0
- package/dist/esm/mcp/index.d.ts.map +1 -0
- package/dist/esm/mcp/index.js +255 -0
- package/dist/esm/mcp/index.js.map +1 -0
- package/dist/esm/mcp/mcp.d.ts +331 -0
- package/dist/esm/mcp/mcp.d.ts.map +1 -0
- package/dist/esm/mcp/mcp.js +701 -0
- package/dist/esm/mcp/mcp.js.map +1 -0
- package/dist/esm/mcp/shared/metadataUtils.d.ts +16 -0
- package/dist/esm/mcp/shared/metadataUtils.d.ts.map +1 -0
- package/dist/esm/mcp/shared/metadataUtils.js +23 -0
- package/dist/esm/mcp/shared/metadataUtils.js.map +1 -0
- package/dist/esm/mcp/shared/protocol.d.ts +231 -0
- package/dist/esm/mcp/shared/protocol.d.ts.map +1 -0
- package/dist/esm/mcp/shared/protocol.js +423 -0
- package/dist/esm/mcp/shared/protocol.js.map +1 -0
- package/dist/esm/mcp/shared/stdio.d.ts +13 -0
- package/dist/esm/mcp/shared/stdio.d.ts.map +1 -0
- package/dist/esm/mcp/shared/stdio.js +31 -0
- package/dist/esm/mcp/shared/stdio.js.map +1 -0
- package/dist/esm/mcp/shared/toolNameValidation.d.ts +31 -0
- package/dist/esm/mcp/shared/toolNameValidation.d.ts.map +1 -0
- package/dist/esm/mcp/shared/toolNameValidation.js +92 -0
- package/dist/esm/mcp/shared/toolNameValidation.js.map +1 -0
- package/dist/esm/mcp/shared/transport.d.ts +75 -0
- package/dist/esm/mcp/shared/transport.d.ts.map +1 -0
- package/dist/esm/mcp/shared/transport.js +2 -0
- package/dist/esm/mcp/shared/transport.js.map +1 -0
- package/dist/esm/mcp/shared/uriTemplate.d.ts +25 -0
- package/dist/esm/mcp/shared/uriTemplate.d.ts.map +1 -0
- package/dist/esm/mcp/shared/uriTemplate.js +239 -0
- package/dist/esm/mcp/shared/uriTemplate.js.map +1 -0
- package/dist/esm/mcp/stdio.d.ts +28 -0
- package/dist/esm/mcp/stdio.d.ts.map +1 -0
- package/dist/esm/mcp/stdio.js +78 -0
- package/dist/esm/mcp/stdio.js.map +1 -0
- package/dist/esm/mcp/validation/ajv-provider.d.ts +53 -0
- package/dist/esm/mcp/validation/ajv-provider.d.ts.map +1 -0
- package/dist/esm/mcp/validation/ajv-provider.js +88 -0
- package/dist/esm/mcp/validation/ajv-provider.js.map +1 -0
- package/dist/esm/mcp/validation/index.d.ts +29 -0
- package/dist/esm/mcp/validation/index.d.ts.map +1 -0
- package/dist/esm/mcp/validation/index.js +29 -0
- package/dist/esm/mcp/validation/index.js.map +1 -0
- package/dist/esm/mcp/validation/types.d.ts +55 -0
- package/dist/esm/mcp/validation/types.d.ts.map +1 -0
- package/dist/esm/mcp/validation/types.js +2 -0
- package/dist/esm/mcp/validation/types.js.map +1 -0
- package/dist/esm/package.json +1 -0
- package/dist/esm/server/auth/clients.d.ts +19 -0
- package/dist/esm/server/auth/clients.d.ts.map +1 -0
- package/dist/esm/server/auth/clients.js +2 -0
- package/dist/esm/server/auth/clients.js.map +1 -0
- package/dist/esm/server/auth/errors.d.ts +141 -0
- package/dist/esm/server/auth/errors.d.ts.map +1 -0
- package/dist/esm/server/auth/errors.js +172 -0
- package/dist/esm/server/auth/errors.js.map +1 -0
- package/dist/esm/server/auth/handlers/authorize.d.ts +13 -0
- package/dist/esm/server/auth/handlers/authorize.d.ts.map +1 -0
- package/dist/esm/server/auth/handlers/authorize.js +138 -0
- package/dist/esm/server/auth/handlers/authorize.js.map +1 -0
- package/dist/esm/server/auth/handlers/metadata.d.ts +4 -0
- package/dist/esm/server/auth/handlers/metadata.d.ts.map +1 -0
- package/dist/esm/server/auth/handlers/metadata.js +15 -0
- package/dist/esm/server/auth/handlers/metadata.js.map +1 -0
- package/dist/esm/server/auth/handlers/register.d.ts +29 -0
- package/dist/esm/server/auth/handlers/register.d.ts.map +1 -0
- package/dist/esm/server/auth/handlers/register.js +71 -0
- package/dist/esm/server/auth/handlers/register.js.map +1 -0
- package/dist/esm/server/auth/handlers/revoke.d.ts +13 -0
- package/dist/esm/server/auth/handlers/revoke.d.ts.map +1 -0
- package/dist/esm/server/auth/handlers/revoke.js +59 -0
- package/dist/esm/server/auth/handlers/revoke.js.map +1 -0
- package/dist/esm/server/auth/handlers/token.d.ts +13 -0
- package/dist/esm/server/auth/handlers/token.d.ts.map +1 -0
- package/dist/esm/server/auth/handlers/token.js +107 -0
- package/dist/esm/server/auth/handlers/token.js.map +1 -0
- package/dist/esm/server/auth/middleware/allowedMethods.d.ts +9 -0
- package/dist/esm/server/auth/middleware/allowedMethods.d.ts.map +1 -0
- package/dist/esm/server/auth/middleware/allowedMethods.js +18 -0
- package/dist/esm/server/auth/middleware/allowedMethods.js.map +1 -0
- package/dist/esm/server/auth/middleware/bearerAuth.d.ts +35 -0
- package/dist/esm/server/auth/middleware/bearerAuth.d.ts.map +1 -0
- package/dist/esm/server/auth/middleware/bearerAuth.js +67 -0
- package/dist/esm/server/auth/middleware/bearerAuth.js.map +1 -0
- package/dist/esm/server/auth/middleware/clientAuth.d.ts +19 -0
- package/dist/esm/server/auth/middleware/clientAuth.d.ts.map +1 -0
- package/dist/esm/server/auth/middleware/clientAuth.js +49 -0
- package/dist/esm/server/auth/middleware/clientAuth.js.map +1 -0
- package/dist/esm/server/auth/provider.d.ts +68 -0
- package/dist/esm/server/auth/provider.d.ts.map +1 -0
- package/dist/esm/server/auth/provider.js +2 -0
- package/dist/esm/server/auth/provider.js.map +1 -0
- package/dist/esm/server/auth/providers/proxyProvider.d.ts +49 -0
- package/dist/esm/server/auth/providers/proxyProvider.d.ts.map +1 -0
- package/dist/esm/server/auth/providers/proxyProvider.js +157 -0
- package/dist/esm/server/auth/providers/proxyProvider.js.map +1 -0
- package/dist/esm/server/auth/router.d.ts +101 -0
- package/dist/esm/server/auth/router.d.ts.map +1 -0
- package/dist/esm/server/auth/router.js +115 -0
- package/dist/esm/server/auth/router.js.map +1 -0
- package/dist/esm/server/auth/types.d.ts +32 -0
- package/dist/esm/server/auth/types.d.ts.map +1 -0
- package/dist/esm/server/auth/types.js +2 -0
- package/dist/esm/server/auth/types.js.map +1 -0
- package/dist/esm/server/completable.d.ts +24 -0
- package/dist/esm/server/completable.d.ts.map +1 -0
- package/dist/esm/server/completable.js +60 -0
- package/dist/esm/server/completable.js.map +1 -0
- package/dist/esm/server/index.d.ts +191 -0
- package/dist/esm/server/index.d.ts.map +1 -0
- package/dist/esm/server/index.js +255 -0
- package/dist/esm/server/index.js.map +1 -0
- package/dist/esm/server/mcp.d.ts +331 -0
- package/dist/esm/server/mcp.d.ts.map +1 -0
- package/dist/esm/server/mcp.js +701 -0
- package/dist/esm/server/mcp.js.map +1 -0
- package/dist/esm/server/sse.d.ts +76 -0
- package/dist/esm/server/sse.d.ts.map +1 -0
- package/dist/esm/server/sse.js +161 -0
- package/dist/esm/server/sse.js.map +1 -0
- package/dist/esm/server/stdio.d.ts +28 -0
- package/dist/esm/server/stdio.d.ts.map +1 -0
- package/dist/esm/server/stdio.js +78 -0
- package/dist/esm/server/stdio.js.map +1 -0
- package/dist/esm/server/streamableHttp.d.ts +185 -0
- package/dist/esm/server/streamableHttp.d.ts.map +1 -0
- package/dist/esm/server/streamableHttp.js +624 -0
- package/dist/esm/server/streamableHttp.js.map +1 -0
- package/dist/esm/server.d.ts +3 -0
- package/dist/esm/server.d.ts.map +1 -0
- package/dist/esm/server.js +4 -0
- package/dist/esm/server.js.map +1 -0
- package/dist/esm/services/x32-connection.d.ts +87 -0
- package/dist/esm/services/x32-connection.d.ts.map +1 -0
- package/dist/esm/services/x32-connection.js +280 -0
- package/dist/esm/services/x32-connection.js.map +1 -0
- package/dist/esm/shared/auth-utils.d.ts +23 -0
- package/dist/esm/shared/auth-utils.d.ts.map +1 -0
- package/dist/esm/shared/auth-utils.js +44 -0
- package/dist/esm/shared/auth-utils.js.map +1 -0
- package/dist/esm/shared/auth.d.ts +626 -0
- package/dist/esm/shared/auth.d.ts.map +1 -0
- package/dist/esm/shared/auth.js +200 -0
- package/dist/esm/shared/auth.js.map +1 -0
- package/dist/esm/shared/metadataUtils.d.ts +16 -0
- package/dist/esm/shared/metadataUtils.d.ts.map +1 -0
- package/dist/esm/shared/metadataUtils.js +23 -0
- package/dist/esm/shared/metadataUtils.js.map +1 -0
- package/dist/esm/shared/protocol.d.ts +230 -0
- package/dist/esm/shared/protocol.d.ts.map +1 -0
- package/dist/esm/shared/protocol.js +423 -0
- package/dist/esm/shared/protocol.js.map +1 -0
- package/dist/esm/shared/stdio.d.ts +13 -0
- package/dist/esm/shared/stdio.d.ts.map +1 -0
- package/dist/esm/shared/stdio.js +31 -0
- package/dist/esm/shared/stdio.js.map +1 -0
- package/dist/esm/shared/toolNameValidation.d.ts +31 -0
- package/dist/esm/shared/toolNameValidation.d.ts.map +1 -0
- package/dist/esm/shared/toolNameValidation.js +92 -0
- package/dist/esm/shared/toolNameValidation.js.map +1 -0
- package/dist/esm/shared/transport.d.ts +75 -0
- package/dist/esm/shared/transport.d.ts.map +1 -0
- package/dist/esm/shared/transport.js +2 -0
- package/dist/esm/shared/transport.js.map +1 -0
- package/dist/esm/shared/uriTemplate.d.ts +25 -0
- package/dist/esm/shared/uriTemplate.d.ts.map +1 -0
- package/dist/esm/shared/uriTemplate.js +239 -0
- package/dist/esm/shared/uriTemplate.js.map +1 -0
- package/dist/esm/spec.types.d.ts +1429 -0
- package/dist/esm/spec.types.d.ts.map +1 -0
- package/dist/esm/spec.types.js +17 -0
- package/dist/esm/spec.types.js.map +1 -0
- package/dist/esm/src/index.d.ts +3 -0
- package/dist/esm/src/index.d.ts.map +1 -0
- package/dist/esm/src/index.js +68 -0
- package/dist/esm/src/index.js.map +1 -0
- package/dist/esm/src/mcp/completable.d.ts +24 -0
- package/dist/esm/src/mcp/completable.d.ts.map +1 -0
- package/dist/esm/src/mcp/completable.js +60 -0
- package/dist/esm/src/mcp/completable.js.map +1 -0
- package/dist/esm/src/mcp/index.d.ts +124 -0
- package/dist/esm/src/mcp/index.d.ts.map +1 -0
- package/dist/esm/src/mcp/index.js +255 -0
- package/dist/esm/src/mcp/index.js.map +1 -0
- package/dist/esm/src/mcp/mcp.d.ts +331 -0
- package/dist/esm/src/mcp/mcp.d.ts.map +1 -0
- package/dist/esm/src/mcp/mcp.js +701 -0
- package/dist/esm/src/mcp/mcp.js.map +1 -0
- package/dist/esm/src/mcp/shared/metadataUtils.d.ts +16 -0
- package/dist/esm/src/mcp/shared/metadataUtils.d.ts.map +1 -0
- package/dist/esm/src/mcp/shared/metadataUtils.js +23 -0
- package/dist/esm/src/mcp/shared/metadataUtils.js.map +1 -0
- package/dist/esm/src/mcp/shared/protocol.d.ts +231 -0
- package/dist/esm/src/mcp/shared/protocol.d.ts.map +1 -0
- package/dist/esm/src/mcp/shared/protocol.js +423 -0
- package/dist/esm/src/mcp/shared/protocol.js.map +1 -0
- package/dist/esm/src/mcp/shared/stdio.d.ts +13 -0
- package/dist/esm/src/mcp/shared/stdio.d.ts.map +1 -0
- package/dist/esm/src/mcp/shared/stdio.js +31 -0
- package/dist/esm/src/mcp/shared/stdio.js.map +1 -0
- package/dist/esm/src/mcp/shared/toolNameValidation.d.ts +31 -0
- package/dist/esm/src/mcp/shared/toolNameValidation.d.ts.map +1 -0
- package/dist/esm/src/mcp/shared/toolNameValidation.js +92 -0
- package/dist/esm/src/mcp/shared/toolNameValidation.js.map +1 -0
- package/dist/esm/src/mcp/shared/transport.d.ts +75 -0
- package/dist/esm/src/mcp/shared/transport.d.ts.map +1 -0
- package/dist/esm/src/mcp/shared/transport.js +2 -0
- package/dist/esm/src/mcp/shared/transport.js.map +1 -0
- package/dist/esm/src/mcp/shared/uriTemplate.d.ts +25 -0
- package/dist/esm/src/mcp/shared/uriTemplate.d.ts.map +1 -0
- package/dist/esm/src/mcp/shared/uriTemplate.js +239 -0
- package/dist/esm/src/mcp/shared/uriTemplate.js.map +1 -0
- package/dist/esm/src/mcp/stdio.d.ts +28 -0
- package/dist/esm/src/mcp/stdio.d.ts.map +1 -0
- package/dist/esm/src/mcp/stdio.js +78 -0
- package/dist/esm/src/mcp/stdio.js.map +1 -0
- package/dist/esm/src/mcp/validation/ajv-provider.d.ts +53 -0
- package/dist/esm/src/mcp/validation/ajv-provider.d.ts.map +1 -0
- package/dist/esm/src/mcp/validation/ajv-provider.js +88 -0
- package/dist/esm/src/mcp/validation/ajv-provider.js.map +1 -0
- package/dist/esm/src/mcp/validation/index.d.ts +29 -0
- package/dist/esm/src/mcp/validation/index.d.ts.map +1 -0
- package/dist/esm/src/mcp/validation/index.js +29 -0
- package/dist/esm/src/mcp/validation/index.js.map +1 -0
- package/dist/esm/src/mcp/validation/types.d.ts +55 -0
- package/dist/esm/src/mcp/validation/types.d.ts.map +1 -0
- package/dist/esm/src/mcp/validation/types.js +2 -0
- package/dist/esm/src/mcp/validation/types.js.map +1 -0
- package/dist/esm/src/server.d.ts +3 -0
- package/dist/esm/src/server.d.ts.map +1 -0
- package/dist/esm/src/server.js +4 -0
- package/dist/esm/src/server.js.map +1 -0
- package/dist/esm/src/services/x32-connection.d.ts +87 -0
- package/dist/esm/src/services/x32-connection.d.ts.map +1 -0
- package/dist/esm/src/services/x32-connection.js +279 -0
- package/dist/esm/src/services/x32-connection.js.map +1 -0
- package/dist/esm/src/tools/channel.d.ts +7 -0
- package/dist/esm/src/tools/channel.d.ts.map +1 -0
- package/dist/esm/src/tools/channel.js +441 -0
- package/dist/esm/src/tools/channel.js.map +1 -0
- package/dist/esm/src/tools/connection.d.ts +7 -0
- package/dist/esm/src/tools/connection.d.ts.map +1 -0
- package/dist/esm/src/tools/connection.js +227 -0
- package/dist/esm/src/tools/connection.js.map +1 -0
- package/dist/esm/src/tools/index.d.ts +8 -0
- package/dist/esm/src/tools/index.d.ts.map +1 -0
- package/dist/esm/src/tools/index.js +8 -0
- package/dist/esm/src/tools/index.js.map +1 -0
- package/dist/esm/src/tools/parameter.d.ts +7 -0
- package/dist/esm/src/tools/parameter.d.ts.map +1 -0
- package/dist/esm/src/tools/parameter.js +120 -0
- package/dist/esm/src/tools/parameter.js.map +1 -0
- package/dist/esm/src/types/index.d.ts +4 -0
- package/dist/esm/src/types/index.d.ts.map +1 -0
- package/dist/esm/src/types/index.js +4 -0
- package/dist/esm/src/types/index.js.map +1 -0
- package/dist/esm/src/types/osc.d.ts +35 -0
- package/dist/esm/src/types/osc.d.ts.map +1 -0
- package/dist/esm/src/types/osc.js +6 -0
- package/dist/esm/src/types/osc.js.map +1 -0
- package/dist/esm/src/types/x32.d.ts +94 -0
- package/dist/esm/src/types/x32.d.ts.map +1 -0
- package/dist/esm/src/types/x32.js +2 -0
- package/dist/esm/src/types/x32.js.map +1 -0
- package/dist/esm/tools/channel.d.ts +7 -0
- package/dist/esm/tools/channel.d.ts.map +1 -0
- package/dist/esm/tools/channel.js +533 -0
- package/dist/esm/tools/channel.js.map +1 -0
- package/dist/esm/tools/channel.tool.d.ts +8 -0
- package/dist/esm/tools/channel.tool.d.ts.map +1 -0
- package/dist/esm/tools/channel.tool.js +79 -0
- package/dist/esm/tools/channel.tool.js.map +1 -0
- package/dist/esm/tools/connect.tool.d.ts +8 -0
- package/dist/esm/tools/connect.tool.d.ts.map +1 -0
- package/dist/esm/tools/connect.tool.js +51 -0
- package/dist/esm/tools/connect.tool.js.map +1 -0
- package/dist/esm/tools/connection.d.ts +7 -0
- package/dist/esm/tools/connection.d.ts.map +1 -0
- package/dist/esm/tools/connection.js +227 -0
- package/dist/esm/tools/connection.js.map +1 -0
- package/dist/esm/tools/get-parameter.tool.d.ts +8 -0
- package/dist/esm/tools/get-parameter.tool.d.ts.map +1 -0
- package/dist/esm/tools/get-parameter.tool.js +51 -0
- package/dist/esm/tools/get-parameter.tool.js.map +1 -0
- package/dist/esm/tools/index.d.ts +8 -0
- package/dist/esm/tools/index.d.ts.map +1 -0
- package/dist/esm/tools/index.js +8 -0
- package/dist/esm/tools/index.js.map +1 -0
- package/dist/esm/tools/info.tool.d.ts +8 -0
- package/dist/esm/tools/info.tool.d.ts.map +1 -0
- package/dist/esm/tools/info.tool.js +54 -0
- package/dist/esm/tools/info.tool.js.map +1 -0
- package/dist/esm/tools/parameter.d.ts +7 -0
- package/dist/esm/tools/parameter.d.ts.map +1 -0
- package/dist/esm/tools/parameter.js +126 -0
- package/dist/esm/tools/parameter.js.map +1 -0
- package/dist/esm/tools/set-parameter.tool.d.ts +8 -0
- package/dist/esm/tools/set-parameter.tool.d.ts.map +1 -0
- package/dist/esm/tools/set-parameter.tool.js +52 -0
- package/dist/esm/tools/set-parameter.tool.js.map +1 -0
- package/dist/esm/tools/status.tool.d.ts +8 -0
- package/dist/esm/tools/status.tool.d.ts.map +1 -0
- package/dist/esm/tools/status.tool.js +49 -0
- package/dist/esm/tools/status.tool.js.map +1 -0
- package/dist/esm/types/index.d.ts +4 -0
- package/dist/esm/types/index.d.ts.map +1 -0
- package/dist/esm/types/index.js +4 -0
- package/dist/esm/types/index.js.map +1 -0
- package/dist/esm/types/osc.d.ts +36 -0
- package/dist/esm/types/osc.d.ts.map +1 -0
- package/dist/esm/types/osc.js +6 -0
- package/dist/esm/types/osc.js.map +1 -0
- package/dist/esm/types/x32.d.ts +94 -0
- package/dist/esm/types/x32.d.ts.map +1 -0
- package/dist/esm/types/x32.js +2 -0
- package/dist/esm/types/x32.js.map +1 -0
- package/dist/esm/types.d.ts +24615 -0
- package/dist/esm/types.d.ts.map +1 -0
- package/dist/esm/types.js +1420 -0
- package/dist/esm/types.js.map +1 -0
- package/dist/esm/utils/color-converter.d.ts +54 -0
- package/dist/esm/utils/color-converter.d.ts.map +1 -0
- package/dist/esm/utils/color-converter.js +79 -0
- package/dist/esm/utils/color-converter.js.map +1 -0
- package/dist/esm/utils/db-converter.d.ts +58 -0
- package/dist/esm/utils/db-converter.d.ts.map +1 -0
- package/dist/esm/utils/db-converter.js +143 -0
- package/dist/esm/utils/db-converter.js.map +1 -0
- package/dist/esm/utils/pan-converter.d.ts +56 -0
- package/dist/esm/utils/pan-converter.d.ts.map +1 -0
- package/dist/esm/utils/pan-converter.js +127 -0
- package/dist/esm/utils/pan-converter.js.map +1 -0
- package/dist/esm/validation/ajv-provider.d.ts +53 -0
- package/dist/esm/validation/ajv-provider.d.ts.map +1 -0
- package/dist/esm/validation/ajv-provider.js +88 -0
- package/dist/esm/validation/ajv-provider.js.map +1 -0
- package/dist/esm/validation/cfworker-provider.d.ts +52 -0
- package/dist/esm/validation/cfworker-provider.d.ts.map +1 -0
- package/dist/esm/validation/cfworker-provider.js +67 -0
- package/dist/esm/validation/cfworker-provider.js.map +1 -0
- package/dist/esm/validation/index.d.ts +29 -0
- package/dist/esm/validation/index.d.ts.map +1 -0
- package/dist/esm/validation/index.js +29 -0
- package/dist/esm/validation/index.js.map +1 -0
- package/dist/esm/validation/types.d.ts +55 -0
- package/dist/esm/validation/types.d.ts.map +1 -0
- package/dist/esm/validation/types.js +2 -0
- package/dist/esm/validation/types.js.map +1 -0
- package/dist/esm/x32-server/index.d.ts +3 -0
- package/dist/esm/x32-server/index.d.ts.map +1 -0
- package/dist/esm/x32-server/index.js +71 -0
- package/dist/esm/x32-server/index.js.map +1 -0
- package/dist/esm/x32-server/tools/channel.tool.d.ts +8 -0
- package/dist/esm/x32-server/tools/channel.tool.d.ts.map +1 -0
- package/dist/esm/x32-server/tools/channel.tool.js +79 -0
- package/dist/esm/x32-server/tools/channel.tool.js.map +1 -0
- package/dist/esm/x32-server/tools/connect.tool.d.ts +8 -0
- package/dist/esm/x32-server/tools/connect.tool.d.ts.map +1 -0
- package/dist/esm/x32-server/tools/connect.tool.js +51 -0
- package/dist/esm/x32-server/tools/connect.tool.js.map +1 -0
- package/dist/esm/x32-server/tools/get-parameter.tool.d.ts +8 -0
- package/dist/esm/x32-server/tools/get-parameter.tool.d.ts.map +1 -0
- package/dist/esm/x32-server/tools/get-parameter.tool.js +51 -0
- package/dist/esm/x32-server/tools/get-parameter.tool.js.map +1 -0
- package/dist/esm/x32-server/tools/index.d.ts +11 -0
- package/dist/esm/x32-server/tools/index.d.ts.map +1 -0
- package/dist/esm/x32-server/tools/index.js +11 -0
- package/dist/esm/x32-server/tools/index.js.map +1 -0
- package/dist/esm/x32-server/tools/info.tool.d.ts +8 -0
- package/dist/esm/x32-server/tools/info.tool.d.ts.map +1 -0
- package/dist/esm/x32-server/tools/info.tool.js +54 -0
- package/dist/esm/x32-server/tools/info.tool.js.map +1 -0
- package/dist/esm/x32-server/tools/set-parameter.tool.d.ts +8 -0
- package/dist/esm/x32-server/tools/set-parameter.tool.d.ts.map +1 -0
- package/dist/esm/x32-server/tools/set-parameter.tool.js +52 -0
- package/dist/esm/x32-server/tools/set-parameter.tool.js.map +1 -0
- package/dist/esm/x32-server/tools/status.tool.d.ts +8 -0
- package/dist/esm/x32-server/tools/status.tool.d.ts.map +1 -0
- package/dist/esm/x32-server/tools/status.tool.js +49 -0
- package/dist/esm/x32-server/tools/status.tool.js.map +1 -0
- package/dist/esm/x32-server/types.d.ts +94 -0
- package/dist/esm/x32-server/types.d.ts.map +1 -0
- package/dist/esm/x32-server/types.js +2 -0
- package/dist/esm/x32-server/types.js.map +1 -0
- package/dist/esm/x32-server/x32-connection.d.ts +87 -0
- package/dist/esm/x32-server/x32-connection.d.ts.map +1 -0
- package/dist/esm/x32-server/x32-connection.js +270 -0
- package/dist/esm/x32-server/x32-connection.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +81 -0
- package/dist/index.js.map +1 -0
- package/dist/mcp/completable.d.ts +24 -0
- package/dist/mcp/completable.d.ts.map +1 -0
- package/dist/mcp/completable.js +59 -0
- package/dist/mcp/completable.js.map +1 -0
- package/dist/mcp/index.d.ts +124 -0
- package/dist/mcp/index.d.ts.map +1 -0
- package/dist/mcp/index.js +262 -0
- package/dist/mcp/index.js.map +1 -0
- package/dist/mcp/mcp.d.ts +331 -0
- package/dist/mcp/mcp.d.ts.map +1 -0
- package/dist/mcp/mcp.js +706 -0
- package/dist/mcp/mcp.js.map +1 -0
- package/dist/mcp/shared/metadataUtils.d.ts +16 -0
- package/dist/mcp/shared/metadataUtils.d.ts.map +1 -0
- package/dist/mcp/shared/metadataUtils.js +22 -0
- package/dist/mcp/shared/metadataUtils.js.map +1 -0
- package/dist/mcp/shared/protocol.d.ts +231 -0
- package/dist/mcp/shared/protocol.d.ts.map +1 -0
- package/dist/mcp/shared/protocol.js +436 -0
- package/dist/mcp/shared/protocol.js.map +1 -0
- package/dist/mcp/shared/stdio.d.ts +13 -0
- package/dist/mcp/shared/stdio.d.ts.map +1 -0
- package/dist/mcp/shared/stdio.js +32 -0
- package/dist/mcp/shared/stdio.js.map +1 -0
- package/dist/mcp/shared/toolNameValidation.d.ts +31 -0
- package/dist/mcp/shared/toolNameValidation.d.ts.map +1 -0
- package/dist/mcp/shared/toolNameValidation.js +92 -0
- package/dist/mcp/shared/toolNameValidation.js.map +1 -0
- package/dist/mcp/shared/transport.d.ts +75 -0
- package/dist/mcp/shared/transport.d.ts.map +1 -0
- package/dist/mcp/shared/transport.js +2 -0
- package/dist/mcp/shared/transport.js.map +1 -0
- package/dist/mcp/shared/uriTemplate.d.ts +25 -0
- package/dist/mcp/shared/uriTemplate.d.ts.map +1 -0
- package/dist/mcp/shared/uriTemplate.js +241 -0
- package/dist/mcp/shared/uriTemplate.js.map +1 -0
- package/dist/mcp/stdio.d.ts +28 -0
- package/dist/mcp/stdio.d.ts.map +1 -0
- package/dist/mcp/stdio.js +80 -0
- package/dist/mcp/stdio.js.map +1 -0
- package/dist/mcp/validation/ajv-provider.d.ts +53 -0
- package/dist/mcp/validation/ajv-provider.d.ts.map +1 -0
- package/dist/mcp/validation/ajv-provider.js +88 -0
- package/dist/mcp/validation/ajv-provider.js.map +1 -0
- package/dist/mcp/validation/index.d.ts +29 -0
- package/dist/mcp/validation/index.d.ts.map +1 -0
- package/dist/mcp/validation/index.js +29 -0
- package/dist/mcp/validation/index.js.map +1 -0
- package/dist/mcp/validation/types.d.ts +55 -0
- package/dist/mcp/validation/types.d.ts.map +1 -0
- package/dist/mcp/validation/types.js +2 -0
- package/dist/mcp/validation/types.js.map +1 -0
- package/dist/server.d.ts +3 -0
- package/dist/server.d.ts.map +1 -0
- package/dist/server.js +4 -0
- package/dist/server.js.map +1 -0
- package/dist/services/x32-connection.d.ts +87 -0
- package/dist/services/x32-connection.d.ts.map +1 -0
- package/dist/services/x32-connection.js +279 -0
- package/dist/services/x32-connection.js.map +1 -0
- package/dist/simple-server.d.ts +3 -0
- package/dist/simple-server.d.ts.map +1 -0
- package/dist/simple-server.js +243 -0
- package/dist/simple-server.js.map +1 -0
- package/dist/tools/channel.d.ts +7 -0
- package/dist/tools/channel.d.ts.map +1 -0
- package/dist/tools/channel.js +534 -0
- package/dist/tools/channel.js.map +1 -0
- package/dist/tools/connection.d.ts +7 -0
- package/dist/tools/connection.d.ts.map +1 -0
- package/dist/tools/connection.js +227 -0
- package/dist/tools/connection.js.map +1 -0
- package/dist/tools/index.d.ts +8 -0
- package/dist/tools/index.d.ts.map +1 -0
- package/dist/tools/index.js +8 -0
- package/dist/tools/index.js.map +1 -0
- package/dist/tools/parameter.d.ts +7 -0
- package/dist/tools/parameter.d.ts.map +1 -0
- package/dist/tools/parameter.js +120 -0
- package/dist/tools/parameter.js.map +1 -0
- package/dist/types/index.d.ts +4 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +4 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/osc.d.ts +35 -0
- package/dist/types/osc.d.ts.map +1 -0
- package/dist/types/osc.js +6 -0
- package/dist/types/osc.js.map +1 -0
- package/dist/types/x32.d.ts +94 -0
- package/dist/types/x32.d.ts.map +1 -0
- package/dist/types/x32.js +2 -0
- package/dist/types/x32.js.map +1 -0
- package/dist/utils/color-converter.d.ts +54 -0
- package/dist/utils/color-converter.d.ts.map +1 -0
- package/dist/utils/color-converter.js +79 -0
- package/dist/utils/color-converter.js.map +1 -0
- package/dist/utils/db-converter.d.ts +58 -0
- package/dist/utils/db-converter.d.ts.map +1 -0
- package/dist/utils/db-converter.js +143 -0
- package/dist/utils/db-converter.js.map +1 -0
- package/dist/utils/pan-converter.d.ts +56 -0
- package/dist/utils/pan-converter.d.ts.map +1 -0
- package/dist/utils/pan-converter.js +127 -0
- package/dist/utils/pan-converter.js.map +1 -0
- package/package.json +145 -0
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { RequestHandler } from 'express';
|
|
2
|
+
import { OAuthMetadata, OAuthProtectedResourceMetadata } from '../../../shared/auth.js';
|
|
3
|
+
export declare function metadataHandler(metadata: OAuthMetadata | OAuthProtectedResourceMetadata): RequestHandler;
|
|
4
|
+
//# sourceMappingURL=metadata.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"metadata.d.ts","sourceRoot":"","sources":["../../../../../src/server/auth/handlers/metadata.ts"],"names":[],"mappings":"AAAA,OAAgB,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAClD,OAAO,EAAE,aAAa,EAAE,8BAA8B,EAAE,MAAM,yBAAyB,CAAC;AAIxF,wBAAgB,eAAe,CAAC,QAAQ,EAAE,aAAa,GAAG,8BAA8B,GAAG,cAAc,CAaxG"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.metadataHandler = metadataHandler;
|
|
7
|
+
const express_1 = __importDefault(require("express"));
|
|
8
|
+
const cors_1 = __importDefault(require("cors"));
|
|
9
|
+
const allowedMethods_js_1 = require("../middleware/allowedMethods.js");
|
|
10
|
+
function metadataHandler(metadata) {
|
|
11
|
+
// Nested router so we can configure middleware and restrict HTTP method
|
|
12
|
+
const router = express_1.default.Router();
|
|
13
|
+
// Configure CORS to allow any origin, to make accessible to web-based MCP clients
|
|
14
|
+
router.use((0, cors_1.default)());
|
|
15
|
+
router.use((0, allowedMethods_js_1.allowedMethods)(['GET', 'OPTIONS']));
|
|
16
|
+
router.get('/', (req, res) => {
|
|
17
|
+
res.status(200).json(metadata);
|
|
18
|
+
});
|
|
19
|
+
return router;
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=metadata.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"metadata.js","sourceRoot":"","sources":["../../../../../src/server/auth/handlers/metadata.ts"],"names":[],"mappings":";;;;;AAKA,0CAaC;AAlBD,sDAAkD;AAElD,gDAAwB;AACxB,uEAAiE;AAEjE,SAAgB,eAAe,CAAC,QAAwD;IACpF,wEAAwE;IACxE,MAAM,MAAM,GAAG,iBAAO,CAAC,MAAM,EAAE,CAAC;IAEhC,kFAAkF;IAClF,MAAM,CAAC,GAAG,CAAC,IAAA,cAAI,GAAE,CAAC,CAAC;IAEnB,MAAM,CAAC,GAAG,CAAC,IAAA,kCAAc,EAAC,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC;IAC/C,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;QACzB,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACnC,CAAC,CAAC,CAAC;IAEH,OAAO,MAAM,CAAC;AAClB,CAAC"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { RequestHandler } from 'express';
|
|
2
|
+
import { OAuthRegisteredClientsStore } from '../clients.js';
|
|
3
|
+
import { Options as RateLimitOptions } from 'express-rate-limit';
|
|
4
|
+
export type ClientRegistrationHandlerOptions = {
|
|
5
|
+
/**
|
|
6
|
+
* A store used to save information about dynamically registered OAuth clients.
|
|
7
|
+
*/
|
|
8
|
+
clientsStore: OAuthRegisteredClientsStore;
|
|
9
|
+
/**
|
|
10
|
+
* The number of seconds after which to expire issued client secrets, or 0 to prevent expiration of client secrets (not recommended).
|
|
11
|
+
*
|
|
12
|
+
* If not set, defaults to 30 days.
|
|
13
|
+
*/
|
|
14
|
+
clientSecretExpirySeconds?: number;
|
|
15
|
+
/**
|
|
16
|
+
* Rate limiting configuration for the client registration endpoint.
|
|
17
|
+
* Set to false to disable rate limiting for this endpoint.
|
|
18
|
+
* Registration endpoints are particularly sensitive to abuse and should be rate limited.
|
|
19
|
+
*/
|
|
20
|
+
rateLimit?: Partial<RateLimitOptions> | false;
|
|
21
|
+
/**
|
|
22
|
+
* Whether to generate a client ID before calling the client registration endpoint.
|
|
23
|
+
*
|
|
24
|
+
* If not set, defaults to true.
|
|
25
|
+
*/
|
|
26
|
+
clientIdGeneration?: boolean;
|
|
27
|
+
};
|
|
28
|
+
export declare function clientRegistrationHandler({ clientsStore, clientSecretExpirySeconds, rateLimit: rateLimitConfig, clientIdGeneration }: ClientRegistrationHandlerOptions): RequestHandler;
|
|
29
|
+
//# sourceMappingURL=register.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"register.d.ts","sourceRoot":"","sources":["../../../../../src/server/auth/handlers/register.ts"],"names":[],"mappings":"AAAA,OAAgB,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAIlD,OAAO,EAAE,2BAA2B,EAAE,MAAM,eAAe,CAAC;AAC5D,OAAO,EAAa,OAAO,IAAI,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAI5E,MAAM,MAAM,gCAAgC,GAAG;IAC3C;;OAEG;IACH,YAAY,EAAE,2BAA2B,CAAC;IAE1C;;;;OAIG;IACH,yBAAyB,CAAC,EAAE,MAAM,CAAC;IAEnC;;;;OAIG;IACH,SAAS,CAAC,EAAE,OAAO,CAAC,gBAAgB,CAAC,GAAG,KAAK,CAAC;IAE9C;;;;OAIG;IACH,kBAAkB,CAAC,EAAE,OAAO,CAAC;CAChC,CAAC;AAIF,wBAAgB,yBAAyB,CAAC,EACtC,YAAY,EACZ,yBAAgE,EAChE,SAAS,EAAE,eAAe,EAC1B,kBAAyB,EAC5B,EAAE,gCAAgC,GAAG,cAAc,CA0EnD"}
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.clientRegistrationHandler = clientRegistrationHandler;
|
|
7
|
+
const express_1 = __importDefault(require("express"));
|
|
8
|
+
const auth_js_1 = require("../../../shared/auth.js");
|
|
9
|
+
const node_crypto_1 = __importDefault(require("node:crypto"));
|
|
10
|
+
const cors_1 = __importDefault(require("cors"));
|
|
11
|
+
const express_rate_limit_1 = require("express-rate-limit");
|
|
12
|
+
const allowedMethods_js_1 = require("../middleware/allowedMethods.js");
|
|
13
|
+
const errors_js_1 = require("../errors.js");
|
|
14
|
+
const DEFAULT_CLIENT_SECRET_EXPIRY_SECONDS = 30 * 24 * 60 * 60; // 30 days
|
|
15
|
+
function clientRegistrationHandler({ clientsStore, clientSecretExpirySeconds = DEFAULT_CLIENT_SECRET_EXPIRY_SECONDS, rateLimit: rateLimitConfig, clientIdGeneration = true }) {
|
|
16
|
+
if (!clientsStore.registerClient) {
|
|
17
|
+
throw new Error('Client registration store does not support registering clients');
|
|
18
|
+
}
|
|
19
|
+
// Nested router so we can configure middleware and restrict HTTP method
|
|
20
|
+
const router = express_1.default.Router();
|
|
21
|
+
// Configure CORS to allow any origin, to make accessible to web-based MCP clients
|
|
22
|
+
router.use((0, cors_1.default)());
|
|
23
|
+
router.use((0, allowedMethods_js_1.allowedMethods)(['POST']));
|
|
24
|
+
router.use(express_1.default.json());
|
|
25
|
+
// Apply rate limiting unless explicitly disabled - stricter limits for registration
|
|
26
|
+
if (rateLimitConfig !== false) {
|
|
27
|
+
router.use((0, express_rate_limit_1.rateLimit)({
|
|
28
|
+
windowMs: 60 * 60 * 1000, // 1 hour
|
|
29
|
+
max: 20, // 20 requests per hour - stricter as registration is sensitive
|
|
30
|
+
standardHeaders: true,
|
|
31
|
+
legacyHeaders: false,
|
|
32
|
+
message: new errors_js_1.TooManyRequestsError('You have exceeded the rate limit for client registration requests').toResponseObject(),
|
|
33
|
+
...rateLimitConfig
|
|
34
|
+
}));
|
|
35
|
+
}
|
|
36
|
+
router.post('/', async (req, res) => {
|
|
37
|
+
res.setHeader('Cache-Control', 'no-store');
|
|
38
|
+
try {
|
|
39
|
+
const parseResult = auth_js_1.OAuthClientMetadataSchema.safeParse(req.body);
|
|
40
|
+
if (!parseResult.success) {
|
|
41
|
+
throw new errors_js_1.InvalidClientMetadataError(parseResult.error.message);
|
|
42
|
+
}
|
|
43
|
+
const clientMetadata = parseResult.data;
|
|
44
|
+
const isPublicClient = clientMetadata.token_endpoint_auth_method === 'none';
|
|
45
|
+
// Generate client credentials
|
|
46
|
+
const clientSecret = isPublicClient ? undefined : node_crypto_1.default.randomBytes(32).toString('hex');
|
|
47
|
+
const clientIdIssuedAt = Math.floor(Date.now() / 1000);
|
|
48
|
+
// Calculate client secret expiry time
|
|
49
|
+
const clientsDoExpire = clientSecretExpirySeconds > 0;
|
|
50
|
+
const secretExpiryTime = clientsDoExpire ? clientIdIssuedAt + clientSecretExpirySeconds : 0;
|
|
51
|
+
const clientSecretExpiresAt = isPublicClient ? undefined : secretExpiryTime;
|
|
52
|
+
let clientInfo = {
|
|
53
|
+
...clientMetadata,
|
|
54
|
+
client_secret: clientSecret,
|
|
55
|
+
client_secret_expires_at: clientSecretExpiresAt
|
|
56
|
+
};
|
|
57
|
+
if (clientIdGeneration) {
|
|
58
|
+
clientInfo.client_id = node_crypto_1.default.randomUUID();
|
|
59
|
+
clientInfo.client_id_issued_at = clientIdIssuedAt;
|
|
60
|
+
}
|
|
61
|
+
clientInfo = await clientsStore.registerClient(clientInfo);
|
|
62
|
+
res.status(201).json(clientInfo);
|
|
63
|
+
}
|
|
64
|
+
catch (error) {
|
|
65
|
+
if (error instanceof errors_js_1.OAuthError) {
|
|
66
|
+
const status = error instanceof errors_js_1.ServerError ? 500 : 400;
|
|
67
|
+
res.status(status).json(error.toResponseObject());
|
|
68
|
+
}
|
|
69
|
+
else {
|
|
70
|
+
const serverError = new errors_js_1.ServerError('Internal Server Error');
|
|
71
|
+
res.status(500).json(serverError.toResponseObject());
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
});
|
|
75
|
+
return router;
|
|
76
|
+
}
|
|
77
|
+
//# sourceMappingURL=register.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"register.js","sourceRoot":"","sources":["../../../../../src/server/auth/handlers/register.ts"],"names":[],"mappings":";;;;;AAuCA,8DA+EC;AAtHD,sDAAkD;AAClD,qDAAgG;AAChG,8DAAiC;AACjC,gDAAwB;AAExB,2DAA4E;AAC5E,uEAAiE;AACjE,4CAAyG;AA8BzG,MAAM,oCAAoC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC,UAAU;AAE1E,SAAgB,yBAAyB,CAAC,EACtC,YAAY,EACZ,yBAAyB,GAAG,oCAAoC,EAChE,SAAS,EAAE,eAAe,EAC1B,kBAAkB,GAAG,IAAI,EACM;IAC/B,IAAI,CAAC,YAAY,CAAC,cAAc,EAAE,CAAC;QAC/B,MAAM,IAAI,KAAK,CAAC,gEAAgE,CAAC,CAAC;IACtF,CAAC;IAED,wEAAwE;IACxE,MAAM,MAAM,GAAG,iBAAO,CAAC,MAAM,EAAE,CAAC;IAEhC,kFAAkF;IAClF,MAAM,CAAC,GAAG,CAAC,IAAA,cAAI,GAAE,CAAC,CAAC;IAEnB,MAAM,CAAC,GAAG,CAAC,IAAA,kCAAc,EAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;IACrC,MAAM,CAAC,GAAG,CAAC,iBAAO,CAAC,IAAI,EAAE,CAAC,CAAC;IAE3B,oFAAoF;IACpF,IAAI,eAAe,KAAK,KAAK,EAAE,CAAC;QAC5B,MAAM,CAAC,GAAG,CACN,IAAA,8BAAS,EAAC;YACN,QAAQ,EAAE,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,SAAS;YACnC,GAAG,EAAE,EAAE,EAAE,+DAA+D;YACxE,eAAe,EAAE,IAAI;YACrB,aAAa,EAAE,KAAK;YACpB,OAAO,EAAE,IAAI,gCAAoB,CAAC,mEAAmE,CAAC,CAAC,gBAAgB,EAAE;YACzH,GAAG,eAAe;SACrB,CAAC,CACL,CAAC;IACN,CAAC;IAED,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE;QAChC,GAAG,CAAC,SAAS,CAAC,eAAe,EAAE,UAAU,CAAC,CAAC;QAE3C,IAAI,CAAC;YACD,MAAM,WAAW,GAAG,mCAAyB,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAClE,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;gBACvB,MAAM,IAAI,sCAA0B,CAAC,WAAW,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YACpE,CAAC;YAED,MAAM,cAAc,GAAG,WAAW,CAAC,IAAI,CAAC;YACxC,MAAM,cAAc,GAAG,cAAc,CAAC,0BAA0B,KAAK,MAAM,CAAC;YAE5E,8BAA8B;YAC9B,MAAM,YAAY,GAAG,cAAc,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,qBAAM,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YACzF,MAAM,gBAAgB,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC;YAEvD,sCAAsC;YACtC,MAAM,eAAe,GAAG,yBAAyB,GAAG,CAAC,CAAC;YACtD,MAAM,gBAAgB,GAAG,eAAe,CAAC,CAAC,CAAC,gBAAgB,GAAG,yBAAyB,CAAC,CAAC,CAAC,CAAC,CAAC;YAC5F,MAAM,qBAAqB,GAAG,cAAc,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,gBAAgB,CAAC;YAE5E,IAAI,UAAU,GAA2E;gBACrF,GAAG,cAAc;gBACjB,aAAa,EAAE,YAAY;gBAC3B,wBAAwB,EAAE,qBAAqB;aAClD,CAAC;YAEF,IAAI,kBAAkB,EAAE,CAAC;gBACrB,UAAU,CAAC,SAAS,GAAG,qBAAM,CAAC,UAAU,EAAE,CAAC;gBAC3C,UAAU,CAAC,mBAAmB,GAAG,gBAAgB,CAAC;YACtD,CAAC;YAED,UAAU,GAAG,MAAM,YAAY,CAAC,cAAe,CAAC,UAAU,CAAC,CAAC;YAC5D,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACrC,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACb,IAAI,KAAK,YAAY,sBAAU,EAAE,CAAC;gBAC9B,MAAM,MAAM,GAAG,KAAK,YAAY,uBAAW,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;gBACxD,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,gBAAgB,EAAE,CAAC,CAAC;YACtD,CAAC;iBAAM,CAAC;gBACJ,MAAM,WAAW,GAAG,IAAI,uBAAW,CAAC,uBAAuB,CAAC,CAAC;gBAC7D,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,gBAAgB,EAAE,CAAC,CAAC;YACzD,CAAC;QACL,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,OAAO,MAAM,CAAC;AAClB,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { OAuthServerProvider } from '../provider.js';
|
|
2
|
+
import { RequestHandler } from 'express';
|
|
3
|
+
import { Options as RateLimitOptions } from 'express-rate-limit';
|
|
4
|
+
export type RevocationHandlerOptions = {
|
|
5
|
+
provider: OAuthServerProvider;
|
|
6
|
+
/**
|
|
7
|
+
* Rate limiting configuration for the token revocation endpoint.
|
|
8
|
+
* Set to false to disable rate limiting for this endpoint.
|
|
9
|
+
*/
|
|
10
|
+
rateLimit?: Partial<RateLimitOptions> | false;
|
|
11
|
+
};
|
|
12
|
+
export declare function revocationHandler({ provider, rateLimit: rateLimitConfig }: RevocationHandlerOptions): RequestHandler;
|
|
13
|
+
//# sourceMappingURL=revoke.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"revoke.d.ts","sourceRoot":"","sources":["../../../../../src/server/auth/handlers/revoke.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AACrD,OAAgB,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAIlD,OAAO,EAAa,OAAO,IAAI,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAI5E,MAAM,MAAM,wBAAwB,GAAG;IACnC,QAAQ,EAAE,mBAAmB,CAAC;IAC9B;;;OAGG;IACH,SAAS,CAAC,EAAE,OAAO,CAAC,gBAAgB,CAAC,GAAG,KAAK,CAAC;CACjD,CAAC;AAEF,wBAAgB,iBAAiB,CAAC,EAAE,QAAQ,EAAE,SAAS,EAAE,eAAe,EAAE,EAAE,wBAAwB,GAAG,cAAc,CA4DpH"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.revocationHandler = revocationHandler;
|
|
7
|
+
const express_1 = __importDefault(require("express"));
|
|
8
|
+
const cors_1 = __importDefault(require("cors"));
|
|
9
|
+
const clientAuth_js_1 = require("../middleware/clientAuth.js");
|
|
10
|
+
const auth_js_1 = require("../../../shared/auth.js");
|
|
11
|
+
const express_rate_limit_1 = require("express-rate-limit");
|
|
12
|
+
const allowedMethods_js_1 = require("../middleware/allowedMethods.js");
|
|
13
|
+
const errors_js_1 = require("../errors.js");
|
|
14
|
+
function revocationHandler({ provider, rateLimit: rateLimitConfig }) {
|
|
15
|
+
if (!provider.revokeToken) {
|
|
16
|
+
throw new Error('Auth provider does not support revoking tokens');
|
|
17
|
+
}
|
|
18
|
+
// Nested router so we can configure middleware and restrict HTTP method
|
|
19
|
+
const router = express_1.default.Router();
|
|
20
|
+
// Configure CORS to allow any origin, to make accessible to web-based MCP clients
|
|
21
|
+
router.use((0, cors_1.default)());
|
|
22
|
+
router.use((0, allowedMethods_js_1.allowedMethods)(['POST']));
|
|
23
|
+
router.use(express_1.default.urlencoded({ extended: false }));
|
|
24
|
+
// Apply rate limiting unless explicitly disabled
|
|
25
|
+
if (rateLimitConfig !== false) {
|
|
26
|
+
router.use((0, express_rate_limit_1.rateLimit)({
|
|
27
|
+
windowMs: 15 * 60 * 1000, // 15 minutes
|
|
28
|
+
max: 50, // 50 requests per windowMs
|
|
29
|
+
standardHeaders: true,
|
|
30
|
+
legacyHeaders: false,
|
|
31
|
+
message: new errors_js_1.TooManyRequestsError('You have exceeded the rate limit for token revocation requests').toResponseObject(),
|
|
32
|
+
...rateLimitConfig
|
|
33
|
+
}));
|
|
34
|
+
}
|
|
35
|
+
// Authenticate and extract client details
|
|
36
|
+
router.use((0, clientAuth_js_1.authenticateClient)({ clientsStore: provider.clientsStore }));
|
|
37
|
+
router.post('/', async (req, res) => {
|
|
38
|
+
res.setHeader('Cache-Control', 'no-store');
|
|
39
|
+
try {
|
|
40
|
+
const parseResult = auth_js_1.OAuthTokenRevocationRequestSchema.safeParse(req.body);
|
|
41
|
+
if (!parseResult.success) {
|
|
42
|
+
throw new errors_js_1.InvalidRequestError(parseResult.error.message);
|
|
43
|
+
}
|
|
44
|
+
const client = req.client;
|
|
45
|
+
if (!client) {
|
|
46
|
+
// This should never happen
|
|
47
|
+
throw new errors_js_1.ServerError('Internal Server Error');
|
|
48
|
+
}
|
|
49
|
+
await provider.revokeToken(client, parseResult.data);
|
|
50
|
+
res.status(200).json({});
|
|
51
|
+
}
|
|
52
|
+
catch (error) {
|
|
53
|
+
if (error instanceof errors_js_1.OAuthError) {
|
|
54
|
+
const status = error instanceof errors_js_1.ServerError ? 500 : 400;
|
|
55
|
+
res.status(status).json(error.toResponseObject());
|
|
56
|
+
}
|
|
57
|
+
else {
|
|
58
|
+
const serverError = new errors_js_1.ServerError('Internal Server Error');
|
|
59
|
+
res.status(500).json(serverError.toResponseObject());
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
});
|
|
63
|
+
return router;
|
|
64
|
+
}
|
|
65
|
+
//# sourceMappingURL=revoke.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"revoke.js","sourceRoot":"","sources":["../../../../../src/server/auth/handlers/revoke.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { RequestHandler } from 'express';
|
|
2
|
+
import { OAuthServerProvider } from '../provider.js';
|
|
3
|
+
import { Options as RateLimitOptions } from 'express-rate-limit';
|
|
4
|
+
export type TokenHandlerOptions = {
|
|
5
|
+
provider: OAuthServerProvider;
|
|
6
|
+
/**
|
|
7
|
+
* Rate limiting configuration for the token endpoint.
|
|
8
|
+
* Set to false to disable rate limiting for this endpoint.
|
|
9
|
+
*/
|
|
10
|
+
rateLimit?: Partial<RateLimitOptions> | false;
|
|
11
|
+
};
|
|
12
|
+
export declare function tokenHandler({ provider, rateLimit: rateLimitConfig }: TokenHandlerOptions): RequestHandler;
|
|
13
|
+
//# sourceMappingURL=token.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"token.d.ts","sourceRoot":"","sources":["../../../../../src/server/auth/handlers/token.ts"],"names":[],"mappings":"AACA,OAAgB,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAClD,OAAO,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAIrD,OAAO,EAAa,OAAO,IAAI,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAW5E,MAAM,MAAM,mBAAmB,GAAG;IAC9B,QAAQ,EAAE,mBAAmB,CAAC;IAC9B;;;OAGG;IACH,SAAS,CAAC,EAAE,OAAO,CAAC,gBAAgB,CAAC,GAAG,KAAK,CAAC;CACjD,CAAC;AAmBF,wBAAgB,YAAY,CAAC,EAAE,QAAQ,EAAE,SAAS,EAAE,eAAe,EAAE,EAAE,mBAAmB,GAAG,cAAc,CAiH1G"}
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.tokenHandler = tokenHandler;
|
|
7
|
+
const zod_1 = require("zod");
|
|
8
|
+
const express_1 = __importDefault(require("express"));
|
|
9
|
+
const cors_1 = __importDefault(require("cors"));
|
|
10
|
+
const pkce_challenge_1 = require("pkce-challenge");
|
|
11
|
+
const clientAuth_js_1 = require("../middleware/clientAuth.js");
|
|
12
|
+
const express_rate_limit_1 = require("express-rate-limit");
|
|
13
|
+
const allowedMethods_js_1 = require("../middleware/allowedMethods.js");
|
|
14
|
+
const errors_js_1 = require("../errors.js");
|
|
15
|
+
const TokenRequestSchema = zod_1.z.object({
|
|
16
|
+
grant_type: zod_1.z.string()
|
|
17
|
+
});
|
|
18
|
+
const AuthorizationCodeGrantSchema = zod_1.z.object({
|
|
19
|
+
code: zod_1.z.string(),
|
|
20
|
+
code_verifier: zod_1.z.string(),
|
|
21
|
+
redirect_uri: zod_1.z.string().optional(),
|
|
22
|
+
resource: zod_1.z.string().url().optional()
|
|
23
|
+
});
|
|
24
|
+
const RefreshTokenGrantSchema = zod_1.z.object({
|
|
25
|
+
refresh_token: zod_1.z.string(),
|
|
26
|
+
scope: zod_1.z.string().optional(),
|
|
27
|
+
resource: zod_1.z.string().url().optional()
|
|
28
|
+
});
|
|
29
|
+
function tokenHandler({ provider, rateLimit: rateLimitConfig }) {
|
|
30
|
+
// Nested router so we can configure middleware and restrict HTTP method
|
|
31
|
+
const router = express_1.default.Router();
|
|
32
|
+
// Configure CORS to allow any origin, to make accessible to web-based MCP clients
|
|
33
|
+
router.use((0, cors_1.default)());
|
|
34
|
+
router.use((0, allowedMethods_js_1.allowedMethods)(['POST']));
|
|
35
|
+
router.use(express_1.default.urlencoded({ extended: false }));
|
|
36
|
+
// Apply rate limiting unless explicitly disabled
|
|
37
|
+
if (rateLimitConfig !== false) {
|
|
38
|
+
router.use((0, express_rate_limit_1.rateLimit)({
|
|
39
|
+
windowMs: 15 * 60 * 1000, // 15 minutes
|
|
40
|
+
max: 50, // 50 requests per windowMs
|
|
41
|
+
standardHeaders: true,
|
|
42
|
+
legacyHeaders: false,
|
|
43
|
+
message: new errors_js_1.TooManyRequestsError('You have exceeded the rate limit for token requests').toResponseObject(),
|
|
44
|
+
...rateLimitConfig
|
|
45
|
+
}));
|
|
46
|
+
}
|
|
47
|
+
// Authenticate and extract client details
|
|
48
|
+
router.use((0, clientAuth_js_1.authenticateClient)({ clientsStore: provider.clientsStore }));
|
|
49
|
+
router.post('/', async (req, res) => {
|
|
50
|
+
res.setHeader('Cache-Control', 'no-store');
|
|
51
|
+
try {
|
|
52
|
+
const parseResult = TokenRequestSchema.safeParse(req.body);
|
|
53
|
+
if (!parseResult.success) {
|
|
54
|
+
throw new errors_js_1.InvalidRequestError(parseResult.error.message);
|
|
55
|
+
}
|
|
56
|
+
const { grant_type } = parseResult.data;
|
|
57
|
+
const client = req.client;
|
|
58
|
+
if (!client) {
|
|
59
|
+
// This should never happen
|
|
60
|
+
throw new errors_js_1.ServerError('Internal Server Error');
|
|
61
|
+
}
|
|
62
|
+
switch (grant_type) {
|
|
63
|
+
case 'authorization_code': {
|
|
64
|
+
const parseResult = AuthorizationCodeGrantSchema.safeParse(req.body);
|
|
65
|
+
if (!parseResult.success) {
|
|
66
|
+
throw new errors_js_1.InvalidRequestError(parseResult.error.message);
|
|
67
|
+
}
|
|
68
|
+
const { code, code_verifier, redirect_uri, resource } = parseResult.data;
|
|
69
|
+
const skipLocalPkceValidation = provider.skipLocalPkceValidation;
|
|
70
|
+
// Perform local PKCE validation unless explicitly skipped
|
|
71
|
+
// (e.g. to validate code_verifier in upstream server)
|
|
72
|
+
if (!skipLocalPkceValidation) {
|
|
73
|
+
const codeChallenge = await provider.challengeForAuthorizationCode(client, code);
|
|
74
|
+
if (!(await (0, pkce_challenge_1.verifyChallenge)(code_verifier, codeChallenge))) {
|
|
75
|
+
throw new errors_js_1.InvalidGrantError('code_verifier does not match the challenge');
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
// Passes the code_verifier to the provider if PKCE validation didn't occur locally
|
|
79
|
+
const tokens = await provider.exchangeAuthorizationCode(client, code, skipLocalPkceValidation ? code_verifier : undefined, redirect_uri, resource ? new URL(resource) : undefined);
|
|
80
|
+
res.status(200).json(tokens);
|
|
81
|
+
break;
|
|
82
|
+
}
|
|
83
|
+
case 'refresh_token': {
|
|
84
|
+
const parseResult = RefreshTokenGrantSchema.safeParse(req.body);
|
|
85
|
+
if (!parseResult.success) {
|
|
86
|
+
throw new errors_js_1.InvalidRequestError(parseResult.error.message);
|
|
87
|
+
}
|
|
88
|
+
const { refresh_token, scope, resource } = parseResult.data;
|
|
89
|
+
const scopes = scope === null || scope === void 0 ? void 0 : scope.split(' ');
|
|
90
|
+
const tokens = await provider.exchangeRefreshToken(client, refresh_token, scopes, resource ? new URL(resource) : undefined);
|
|
91
|
+
res.status(200).json(tokens);
|
|
92
|
+
break;
|
|
93
|
+
}
|
|
94
|
+
// Not supported right now
|
|
95
|
+
//case "client_credentials":
|
|
96
|
+
default:
|
|
97
|
+
throw new errors_js_1.UnsupportedGrantTypeError('The grant type is not supported by this authorization server.');
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
catch (error) {
|
|
101
|
+
if (error instanceof errors_js_1.OAuthError) {
|
|
102
|
+
const status = error instanceof errors_js_1.ServerError ? 500 : 400;
|
|
103
|
+
res.status(status).json(error.toResponseObject());
|
|
104
|
+
}
|
|
105
|
+
else {
|
|
106
|
+
const serverError = new errors_js_1.ServerError('Internal Server Error');
|
|
107
|
+
res.status(500).json(serverError.toResponseObject());
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
});
|
|
111
|
+
return router;
|
|
112
|
+
}
|
|
113
|
+
//# sourceMappingURL=token.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"token.js","sourceRoot":"","sources":["../../../../../src/server/auth/handlers/token.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { RequestHandler } from 'express';
|
|
2
|
+
/**
|
|
3
|
+
* Middleware to handle unsupported HTTP methods with a 405 Method Not Allowed response.
|
|
4
|
+
*
|
|
5
|
+
* @param allowedMethods Array of allowed HTTP methods for this endpoint (e.g., ['GET', 'POST'])
|
|
6
|
+
* @returns Express middleware that returns a 405 error if method not in allowed list
|
|
7
|
+
*/
|
|
8
|
+
export declare function allowedMethods(allowedMethods: string[]): RequestHandler;
|
|
9
|
+
//# sourceMappingURL=allowedMethods.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"allowedMethods.d.ts","sourceRoot":"","sources":["../../../../../src/server/auth/middleware/allowedMethods.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAGzC;;;;;GAKG;AACH,wBAAgB,cAAc,CAAC,cAAc,EAAE,MAAM,EAAE,GAAG,cAAc,CAUvE"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.allowedMethods = allowedMethods;
|
|
4
|
+
const errors_js_1 = require("../errors.js");
|
|
5
|
+
/**
|
|
6
|
+
* Middleware to handle unsupported HTTP methods with a 405 Method Not Allowed response.
|
|
7
|
+
*
|
|
8
|
+
* @param allowedMethods Array of allowed HTTP methods for this endpoint (e.g., ['GET', 'POST'])
|
|
9
|
+
* @returns Express middleware that returns a 405 error if method not in allowed list
|
|
10
|
+
*/
|
|
11
|
+
function allowedMethods(allowedMethods) {
|
|
12
|
+
return (req, res, next) => {
|
|
13
|
+
if (allowedMethods.includes(req.method)) {
|
|
14
|
+
next();
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
const error = new errors_js_1.MethodNotAllowedError(`The method ${req.method} is not allowed for this endpoint`);
|
|
18
|
+
res.status(405).set('Allow', allowedMethods.join(', ')).json(error.toResponseObject());
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=allowedMethods.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"allowedMethods.js","sourceRoot":"","sources":["../../../../../src/server/auth/middleware/allowedMethods.ts"],"names":[],"mappings":";;AASA,wCAUC;AAlBD,4CAAqD;AAErD;;;;;GAKG;AACH,SAAgB,cAAc,CAAC,cAAwB;IACnD,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;QACtB,IAAI,cAAc,CAAC,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC;YACtC,IAAI,EAAE,CAAC;YACP,OAAO;QACX,CAAC;QAED,MAAM,KAAK,GAAG,IAAI,iCAAqB,CAAC,cAAc,GAAG,CAAC,MAAM,mCAAmC,CAAC,CAAC;QACrG,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,gBAAgB,EAAE,CAAC,CAAC;IAC3F,CAAC,CAAC;AACN,CAAC"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { RequestHandler } from 'express';
|
|
2
|
+
import { OAuthTokenVerifier } from '../provider.js';
|
|
3
|
+
import { AuthInfo } from '../types.js';
|
|
4
|
+
export type BearerAuthMiddlewareOptions = {
|
|
5
|
+
/**
|
|
6
|
+
* A provider used to verify tokens.
|
|
7
|
+
*/
|
|
8
|
+
verifier: OAuthTokenVerifier;
|
|
9
|
+
/**
|
|
10
|
+
* Optional scopes that the token must have.
|
|
11
|
+
*/
|
|
12
|
+
requiredScopes?: string[];
|
|
13
|
+
/**
|
|
14
|
+
* Optional resource metadata URL to include in WWW-Authenticate header.
|
|
15
|
+
*/
|
|
16
|
+
resourceMetadataUrl?: string;
|
|
17
|
+
};
|
|
18
|
+
declare module 'express-serve-static-core' {
|
|
19
|
+
interface Request {
|
|
20
|
+
/**
|
|
21
|
+
* Information about the validated access token, if the `requireBearerAuth` middleware was used.
|
|
22
|
+
*/
|
|
23
|
+
auth?: AuthInfo;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Middleware that requires a valid Bearer token in the Authorization header.
|
|
28
|
+
*
|
|
29
|
+
* This will validate the token with the auth provider and add the resulting auth info to the request object.
|
|
30
|
+
*
|
|
31
|
+
* If resourceMetadataUrl is provided, it will be included in the WWW-Authenticate header
|
|
32
|
+
* for 401 responses as per the OAuth 2.0 Protected Resource Metadata spec.
|
|
33
|
+
*/
|
|
34
|
+
export declare function requireBearerAuth({ verifier, requiredScopes, resourceMetadataUrl }: BearerAuthMiddlewareOptions): RequestHandler;
|
|
35
|
+
//# sourceMappingURL=bearerAuth.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bearerAuth.d.ts","sourceRoot":"","sources":["../../../../../src/server/auth/middleware/bearerAuth.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAEzC,OAAO,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AACpD,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAEvC,MAAM,MAAM,2BAA2B,GAAG;IACtC;;OAEG;IACH,QAAQ,EAAE,kBAAkB,CAAC;IAE7B;;OAEG;IACH,cAAc,CAAC,EAAE,MAAM,EAAE,CAAC;IAE1B;;OAEG;IACH,mBAAmB,CAAC,EAAE,MAAM,CAAC;CAChC,CAAC;AAEF,OAAO,QAAQ,2BAA2B,CAAC;IACvC,UAAU,OAAO;QACb;;WAEG;QACH,IAAI,CAAC,EAAE,QAAQ,CAAC;KACnB;CACJ;AAED;;;;;;;GAOG;AACH,wBAAgB,iBAAiB,CAAC,EAAE,QAAQ,EAAE,cAAmB,EAAE,mBAAmB,EAAE,EAAE,2BAA2B,GAAG,cAAc,CAwDrI"}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.requireBearerAuth = requireBearerAuth;
|
|
4
|
+
const errors_js_1 = require("../errors.js");
|
|
5
|
+
/**
|
|
6
|
+
* Middleware that requires a valid Bearer token in the Authorization header.
|
|
7
|
+
*
|
|
8
|
+
* This will validate the token with the auth provider and add the resulting auth info to the request object.
|
|
9
|
+
*
|
|
10
|
+
* If resourceMetadataUrl is provided, it will be included in the WWW-Authenticate header
|
|
11
|
+
* for 401 responses as per the OAuth 2.0 Protected Resource Metadata spec.
|
|
12
|
+
*/
|
|
13
|
+
function requireBearerAuth({ verifier, requiredScopes = [], resourceMetadataUrl }) {
|
|
14
|
+
return async (req, res, next) => {
|
|
15
|
+
try {
|
|
16
|
+
const authHeader = req.headers.authorization;
|
|
17
|
+
if (!authHeader) {
|
|
18
|
+
throw new errors_js_1.InvalidTokenError('Missing Authorization header');
|
|
19
|
+
}
|
|
20
|
+
const [type, token] = authHeader.split(' ');
|
|
21
|
+
if (type.toLowerCase() !== 'bearer' || !token) {
|
|
22
|
+
throw new errors_js_1.InvalidTokenError("Invalid Authorization header format, expected 'Bearer TOKEN'");
|
|
23
|
+
}
|
|
24
|
+
const authInfo = await verifier.verifyAccessToken(token);
|
|
25
|
+
// Check if token has the required scopes (if any)
|
|
26
|
+
if (requiredScopes.length > 0) {
|
|
27
|
+
const hasAllScopes = requiredScopes.every(scope => authInfo.scopes.includes(scope));
|
|
28
|
+
if (!hasAllScopes) {
|
|
29
|
+
throw new errors_js_1.InsufficientScopeError('Insufficient scope');
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
// Check if the token is set to expire or if it is expired
|
|
33
|
+
if (typeof authInfo.expiresAt !== 'number' || isNaN(authInfo.expiresAt)) {
|
|
34
|
+
throw new errors_js_1.InvalidTokenError('Token has no expiration time');
|
|
35
|
+
}
|
|
36
|
+
else if (authInfo.expiresAt < Date.now() / 1000) {
|
|
37
|
+
throw new errors_js_1.InvalidTokenError('Token has expired');
|
|
38
|
+
}
|
|
39
|
+
req.auth = authInfo;
|
|
40
|
+
next();
|
|
41
|
+
}
|
|
42
|
+
catch (error) {
|
|
43
|
+
if (error instanceof errors_js_1.InvalidTokenError) {
|
|
44
|
+
const wwwAuthValue = resourceMetadataUrl
|
|
45
|
+
? `Bearer error="${error.errorCode}", error_description="${error.message}", resource_metadata="${resourceMetadataUrl}"`
|
|
46
|
+
: `Bearer error="${error.errorCode}", error_description="${error.message}"`;
|
|
47
|
+
res.set('WWW-Authenticate', wwwAuthValue);
|
|
48
|
+
res.status(401).json(error.toResponseObject());
|
|
49
|
+
}
|
|
50
|
+
else if (error instanceof errors_js_1.InsufficientScopeError) {
|
|
51
|
+
const wwwAuthValue = resourceMetadataUrl
|
|
52
|
+
? `Bearer error="${error.errorCode}", error_description="${error.message}", resource_metadata="${resourceMetadataUrl}"`
|
|
53
|
+
: `Bearer error="${error.errorCode}", error_description="${error.message}"`;
|
|
54
|
+
res.set('WWW-Authenticate', wwwAuthValue);
|
|
55
|
+
res.status(403).json(error.toResponseObject());
|
|
56
|
+
}
|
|
57
|
+
else if (error instanceof errors_js_1.ServerError) {
|
|
58
|
+
res.status(500).json(error.toResponseObject());
|
|
59
|
+
}
|
|
60
|
+
else if (error instanceof errors_js_1.OAuthError) {
|
|
61
|
+
res.status(400).json(error.toResponseObject());
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
const serverError = new errors_js_1.ServerError('Internal Server Error');
|
|
65
|
+
res.status(500).json(serverError.toResponseObject());
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
//# sourceMappingURL=bearerAuth.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bearerAuth.js","sourceRoot":"","sources":["../../../../../src/server/auth/middleware/bearerAuth.ts"],"names":[],"mappings":";;AAuCA,8CAwDC;AA9FD,4CAAkG;AA8BlG;;;;;;;GAOG;AACH,SAAgB,iBAAiB,CAAC,EAAE,QAAQ,EAAE,cAAc,GAAG,EAAE,EAAE,mBAAmB,EAA+B;IACjH,OAAO,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;QAC5B,IAAI,CAAC;YACD,MAAM,UAAU,GAAG,GAAG,CAAC,OAAO,CAAC,aAAa,CAAC;YAC7C,IAAI,CAAC,UAAU,EAAE,CAAC;gBACd,MAAM,IAAI,6BAAiB,CAAC,8BAA8B,CAAC,CAAC;YAChE,CAAC;YAED,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,GAAG,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YAC5C,IAAI,IAAI,CAAC,WAAW,EAAE,KAAK,QAAQ,IAAI,CAAC,KAAK,EAAE,CAAC;gBAC5C,MAAM,IAAI,6BAAiB,CAAC,8DAA8D,CAAC,CAAC;YAChG,CAAC;YAED,MAAM,QAAQ,GAAG,MAAM,QAAQ,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;YAEzD,kDAAkD;YAClD,IAAI,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC5B,MAAM,YAAY,GAAG,cAAc,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;gBAEpF,IAAI,CAAC,YAAY,EAAE,CAAC;oBAChB,MAAM,IAAI,kCAAsB,CAAC,oBAAoB,CAAC,CAAC;gBAC3D,CAAC;YACL,CAAC;YAED,0DAA0D;YAC1D,IAAI,OAAO,QAAQ,CAAC,SAAS,KAAK,QAAQ,IAAI,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE,CAAC;gBACtE,MAAM,IAAI,6BAAiB,CAAC,8BAA8B,CAAC,CAAC;YAChE,CAAC;iBAAM,IAAI,QAAQ,CAAC,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,EAAE,CAAC;gBAChD,MAAM,IAAI,6BAAiB,CAAC,mBAAmB,CAAC,CAAC;YACrD,CAAC;YAED,GAAG,CAAC,IAAI,GAAG,QAAQ,CAAC;YACpB,IAAI,EAAE,CAAC;QACX,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACb,IAAI,KAAK,YAAY,6BAAiB,EAAE,CAAC;gBACrC,MAAM,YAAY,GAAG,mBAAmB;oBACpC,CAAC,CAAC,iBAAiB,KAAK,CAAC,SAAS,yBAAyB,KAAK,CAAC,OAAO,yBAAyB,mBAAmB,GAAG;oBACvH,CAAC,CAAC,iBAAiB,KAAK,CAAC,SAAS,yBAAyB,KAAK,CAAC,OAAO,GAAG,CAAC;gBAChF,GAAG,CAAC,GAAG,CAAC,kBAAkB,EAAE,YAAY,CAAC,CAAC;gBAC1C,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,gBAAgB,EAAE,CAAC,CAAC;YACnD,CAAC;iBAAM,IAAI,KAAK,YAAY,kCAAsB,EAAE,CAAC;gBACjD,MAAM,YAAY,GAAG,mBAAmB;oBACpC,CAAC,CAAC,iBAAiB,KAAK,CAAC,SAAS,yBAAyB,KAAK,CAAC,OAAO,yBAAyB,mBAAmB,GAAG;oBACvH,CAAC,CAAC,iBAAiB,KAAK,CAAC,SAAS,yBAAyB,KAAK,CAAC,OAAO,GAAG,CAAC;gBAChF,GAAG,CAAC,GAAG,CAAC,kBAAkB,EAAE,YAAY,CAAC,CAAC;gBAC1C,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,gBAAgB,EAAE,CAAC,CAAC;YACnD,CAAC;iBAAM,IAAI,KAAK,YAAY,uBAAW,EAAE,CAAC;gBACtC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,gBAAgB,EAAE,CAAC,CAAC;YACnD,CAAC;iBAAM,IAAI,KAAK,YAAY,sBAAU,EAAE,CAAC;gBACrC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,gBAAgB,EAAE,CAAC,CAAC;YACnD,CAAC;iBAAM,CAAC;gBACJ,MAAM,WAAW,GAAG,IAAI,uBAAW,CAAC,uBAAuB,CAAC,CAAC;gBAC7D,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,gBAAgB,EAAE,CAAC,CAAC;YACzD,CAAC;QACL,CAAC;IACL,CAAC,CAAC;AACN,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { RequestHandler } from 'express';
|
|
2
|
+
import { OAuthRegisteredClientsStore } from '../clients.js';
|
|
3
|
+
import { OAuthClientInformationFull } from '../../../shared/auth.js';
|
|
4
|
+
export type ClientAuthenticationMiddlewareOptions = {
|
|
5
|
+
/**
|
|
6
|
+
* A store used to read information about registered OAuth clients.
|
|
7
|
+
*/
|
|
8
|
+
clientsStore: OAuthRegisteredClientsStore;
|
|
9
|
+
};
|
|
10
|
+
declare module 'express-serve-static-core' {
|
|
11
|
+
interface Request {
|
|
12
|
+
/**
|
|
13
|
+
* The authenticated client for this request, if the `authenticateClient` middleware was used.
|
|
14
|
+
*/
|
|
15
|
+
client?: OAuthClientInformationFull;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
export declare function authenticateClient({ clientsStore }: ClientAuthenticationMiddlewareOptions): RequestHandler;
|
|
19
|
+
//# sourceMappingURL=clientAuth.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"clientAuth.d.ts","sourceRoot":"","sources":["../../../../../src/server/auth/middleware/clientAuth.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AACzC,OAAO,EAAE,2BAA2B,EAAE,MAAM,eAAe,CAAC;AAC5D,OAAO,EAAE,0BAA0B,EAAE,MAAM,yBAAyB,CAAC;AAGrE,MAAM,MAAM,qCAAqC,GAAG;IAChD;;OAEG;IACH,YAAY,EAAE,2BAA2B,CAAC;CAC7C,CAAC;AAOF,OAAO,QAAQ,2BAA2B,CAAC;IACvC,UAAU,OAAO;QACb;;WAEG;QACH,MAAM,CAAC,EAAE,0BAA0B,CAAC;KACvC;CACJ;AAED,wBAAgB,kBAAkB,CAAC,EAAE,YAAY,EAAE,EAAE,qCAAqC,GAAG,cAAc,CA4C1G"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.authenticateClient = authenticateClient;
|
|
4
|
+
const zod_1 = require("zod");
|
|
5
|
+
const errors_js_1 = require("../errors.js");
|
|
6
|
+
const ClientAuthenticatedRequestSchema = zod_1.z.object({
|
|
7
|
+
client_id: zod_1.z.string(),
|
|
8
|
+
client_secret: zod_1.z.string().optional()
|
|
9
|
+
});
|
|
10
|
+
function authenticateClient({ clientsStore }) {
|
|
11
|
+
return async (req, res, next) => {
|
|
12
|
+
try {
|
|
13
|
+
const result = ClientAuthenticatedRequestSchema.safeParse(req.body);
|
|
14
|
+
if (!result.success) {
|
|
15
|
+
throw new errors_js_1.InvalidRequestError(String(result.error));
|
|
16
|
+
}
|
|
17
|
+
const { client_id, client_secret } = result.data;
|
|
18
|
+
const client = await clientsStore.getClient(client_id);
|
|
19
|
+
if (!client) {
|
|
20
|
+
throw new errors_js_1.InvalidClientError('Invalid client_id');
|
|
21
|
+
}
|
|
22
|
+
// If client has a secret, validate it
|
|
23
|
+
if (client.client_secret) {
|
|
24
|
+
// Check if client_secret is required but not provided
|
|
25
|
+
if (!client_secret) {
|
|
26
|
+
throw new errors_js_1.InvalidClientError('Client secret is required');
|
|
27
|
+
}
|
|
28
|
+
// Check if client_secret matches
|
|
29
|
+
if (client.client_secret !== client_secret) {
|
|
30
|
+
throw new errors_js_1.InvalidClientError('Invalid client_secret');
|
|
31
|
+
}
|
|
32
|
+
// Check if client_secret has expired
|
|
33
|
+
if (client.client_secret_expires_at && client.client_secret_expires_at < Math.floor(Date.now() / 1000)) {
|
|
34
|
+
throw new errors_js_1.InvalidClientError('Client secret has expired');
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
req.client = client;
|
|
38
|
+
next();
|
|
39
|
+
}
|
|
40
|
+
catch (error) {
|
|
41
|
+
if (error instanceof errors_js_1.OAuthError) {
|
|
42
|
+
const status = error instanceof errors_js_1.ServerError ? 500 : 400;
|
|
43
|
+
res.status(status).json(error.toResponseObject());
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
46
|
+
const serverError = new errors_js_1.ServerError('Internal Server Error');
|
|
47
|
+
res.status(500).json(serverError.toResponseObject());
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
//# sourceMappingURL=clientAuth.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"clientAuth.js","sourceRoot":"","sources":["../../../../../src/server/auth/middleware/clientAuth.ts"],"names":[],"mappings":";;AA2BA,gDA4CC;AAvED,6BAAwB;AAIxB,4CAAgG;AAShG,MAAM,gCAAgC,GAAG,OAAC,CAAC,MAAM,CAAC;IAC9C,SAAS,EAAE,OAAC,CAAC,MAAM,EAAE;IACrB,aAAa,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;CACvC,CAAC,CAAC;AAWH,SAAgB,kBAAkB,CAAC,EAAE,YAAY,EAAyC;IACtF,OAAO,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;QAC5B,IAAI,CAAC;YACD,MAAM,MAAM,GAAG,gCAAgC,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YACpE,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;gBAClB,MAAM,IAAI,+BAAmB,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;YACxD,CAAC;YAED,MAAM,EAAE,SAAS,EAAE,aAAa,EAAE,GAAG,MAAM,CAAC,IAAI,CAAC;YACjD,MAAM,MAAM,GAAG,MAAM,YAAY,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;YACvD,IAAI,CAAC,MAAM,EAAE,CAAC;gBACV,MAAM,IAAI,8BAAkB,CAAC,mBAAmB,CAAC,CAAC;YACtD,CAAC;YAED,sCAAsC;YACtC,IAAI,MAAM,CAAC,aAAa,EAAE,CAAC;gBACvB,sDAAsD;gBACtD,IAAI,CAAC,aAAa,EAAE,CAAC;oBACjB,MAAM,IAAI,8BAAkB,CAAC,2BAA2B,CAAC,CAAC;gBAC9D,CAAC;gBAED,iCAAiC;gBACjC,IAAI,MAAM,CAAC,aAAa,KAAK,aAAa,EAAE,CAAC;oBACzC,MAAM,IAAI,8BAAkB,CAAC,uBAAuB,CAAC,CAAC;gBAC1D,CAAC;gBAED,qCAAqC;gBACrC,IAAI,MAAM,CAAC,wBAAwB,IAAI,MAAM,CAAC,wBAAwB,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,CAAC;oBACrG,MAAM,IAAI,8BAAkB,CAAC,2BAA2B,CAAC,CAAC;gBAC9D,CAAC;YACL,CAAC;YAED,GAAG,CAAC,MAAM,GAAG,MAAM,CAAC;YACpB,IAAI,EAAE,CAAC;QACX,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACb,IAAI,KAAK,YAAY,sBAAU,EAAE,CAAC;gBAC9B,MAAM,MAAM,GAAG,KAAK,YAAY,uBAAW,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;gBACxD,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,gBAAgB,EAAE,CAAC,CAAC;YACtD,CAAC;iBAAM,CAAC;gBACJ,MAAM,WAAW,GAAG,IAAI,uBAAW,CAAC,uBAAuB,CAAC,CAAC;gBAC7D,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,gBAAgB,EAAE,CAAC,CAAC;YACzD,CAAC;QACL,CAAC;IACL,CAAC,CAAC;AACN,CAAC"}
|