@strapi/core 5.46.0 → 5.47.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/dist/core-api/routes/index.js +2 -0
- package/dist/core-api/routes/index.js.map +1 -1
- package/dist/core-api/routes/index.mjs +2 -0
- package/dist/core-api/routes/index.mjs.map +1 -1
- package/dist/core-api/routes/validation/content-type.d.ts +13 -1
- package/dist/core-api/routes/validation/content-type.d.ts.map +1 -1
- package/dist/core-api/routes/validation/content-type.js +15 -2
- package/dist/core-api/routes/validation/content-type.js.map +1 -1
- package/dist/core-api/routes/validation/content-type.mjs +15 -2
- package/dist/core-api/routes/validation/content-type.mjs.map +1 -1
- package/dist/migrations/database/5.0.0-discard-drafts.d.ts +2 -1
- package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -1
- package/dist/migrations/database/5.0.0-discard-drafts.js +64 -30
- package/dist/migrations/database/5.0.0-discard-drafts.js.map +1 -1
- package/dist/migrations/database/5.0.0-discard-drafts.mjs +64 -30
- package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +1 -1
- package/dist/package.json.js +14 -12
- package/dist/package.json.js.map +1 -1
- package/dist/package.json.mjs +14 -12
- package/dist/package.json.mjs.map +1 -1
- package/dist/providers/index.d.ts.map +1 -1
- package/dist/providers/index.js +3 -1
- package/dist/providers/index.js.map +1 -1
- package/dist/providers/index.mjs +3 -1
- package/dist/providers/index.mjs.map +1 -1
- package/dist/providers/mcp.d.ts +3 -0
- package/dist/providers/mcp.d.ts.map +1 -0
- package/dist/providers/mcp.js +39 -0
- package/dist/providers/mcp.js.map +1 -0
- package/dist/providers/mcp.mjs +37 -0
- package/dist/providers/mcp.mjs.map +1 -0
- package/dist/providers/session-manager.d.ts.map +1 -1
- package/dist/providers/session-manager.js +1 -2
- package/dist/providers/session-manager.js.map +1 -1
- package/dist/providers/session-manager.mjs +1 -2
- package/dist/providers/session-manager.mjs.map +1 -1
- package/dist/services/ai.d.ts.map +1 -1
- package/dist/services/ai.js +3 -0
- package/dist/services/ai.js.map +1 -1
- package/dist/services/ai.mjs +3 -0
- package/dist/services/ai.mjs.map +1 -1
- package/dist/services/document-service/draft-and-publish.d.ts +2 -16
- package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
- package/dist/services/document-service/draft-and-publish.js +0 -53
- package/dist/services/document-service/draft-and-publish.js.map +1 -1
- package/dist/services/document-service/draft-and-publish.mjs +2 -53
- package/dist/services/document-service/draft-and-publish.mjs.map +1 -1
- package/dist/services/document-service/params.d.ts +2 -2
- package/dist/services/document-service/params.d.ts.map +1 -1
- package/dist/services/document-service/publication-filter.d.ts +6 -0
- package/dist/services/document-service/publication-filter.d.ts.map +1 -0
- package/dist/services/document-service/publication-filter.js +20 -0
- package/dist/services/document-service/publication-filter.js.map +1 -0
- package/dist/services/document-service/publication-filter.mjs +15 -0
- package/dist/services/document-service/publication-filter.mjs.map +1 -0
- package/dist/services/document-service/transform/query.d.ts +1 -1
- package/dist/services/document-service/transform/query.d.ts.map +1 -1
- package/dist/services/document-service/transform/query.js +32 -19
- package/dist/services/document-service/transform/query.js.map +1 -1
- package/dist/services/document-service/transform/query.mjs +33 -20
- package/dist/services/document-service/transform/query.mjs.map +1 -1
- package/dist/services/entity-validator/blocks-validator.js +1 -1
- package/dist/services/entity-validator/blocks-validator.js.map +1 -1
- package/dist/services/entity-validator/blocks-validator.mjs +1 -1
- package/dist/services/entity-validator/blocks-validator.mjs.map +1 -1
- package/dist/services/mcp/authentication.d.ts +23 -0
- package/dist/services/mcp/authentication.d.ts.map +1 -0
- package/dist/services/mcp/authentication.js +45 -0
- package/dist/services/mcp/authentication.js.map +1 -0
- package/dist/services/mcp/authentication.mjs +43 -0
- package/dist/services/mcp/authentication.mjs.map +1 -0
- package/dist/services/mcp/handlers/handlePost.d.ts +4 -0
- package/dist/services/mcp/handlers/handlePost.d.ts.map +1 -0
- package/dist/services/mcp/handlers/handlePost.js +59 -0
- package/dist/services/mcp/handlers/handlePost.js.map +1 -0
- package/dist/services/mcp/handlers/handlePost.mjs +57 -0
- package/dist/services/mcp/handlers/handlePost.mjs.map +1 -0
- package/dist/services/mcp/handlers/types.d.ts +12 -0
- package/dist/services/mcp/handlers/types.d.ts.map +1 -0
- package/dist/services/mcp/index.d.ts +6 -0
- package/dist/services/mcp/index.d.ts.map +1 -0
- package/dist/services/mcp/index.js +101 -0
- package/dist/services/mcp/index.js.map +1 -0
- package/dist/services/mcp/index.mjs +99 -0
- package/dist/services/mcp/index.mjs.map +1 -0
- package/dist/services/mcp/internal/McpCapabilityDefinitionRegistry.d.ts +13 -0
- package/dist/services/mcp/internal/McpCapabilityDefinitionRegistry.d.ts.map +1 -0
- package/dist/services/mcp/internal/McpCapabilityDefinitionRegistry.js +53 -0
- package/dist/services/mcp/internal/McpCapabilityDefinitionRegistry.js.map +1 -0
- package/dist/services/mcp/internal/McpCapabilityDefinitionRegistry.mjs +51 -0
- package/dist/services/mcp/internal/McpCapabilityDefinitionRegistry.mjs.map +1 -0
- package/dist/services/mcp/internal/McpCapabilityRegistry.d.ts +43 -0
- package/dist/services/mcp/internal/McpCapabilityRegistry.d.ts.map +1 -0
- package/dist/services/mcp/internal/McpCapabilityRegistry.js +108 -0
- package/dist/services/mcp/internal/McpCapabilityRegistry.js.map +1 -0
- package/dist/services/mcp/internal/McpCapabilityRegistry.mjs +106 -0
- package/dist/services/mcp/internal/McpCapabilityRegistry.mjs.map +1 -0
- package/dist/services/mcp/internal/McpConfiguration.d.ts +11 -0
- package/dist/services/mcp/internal/McpConfiguration.d.ts.map +1 -0
- package/dist/services/mcp/internal/McpConfiguration.js +34 -0
- package/dist/services/mcp/internal/McpConfiguration.js.map +1 -0
- package/dist/services/mcp/internal/McpConfiguration.mjs +32 -0
- package/dist/services/mcp/internal/McpConfiguration.mjs.map +1 -0
- package/dist/services/mcp/internal/McpServerFactory.d.ts +37 -0
- package/dist/services/mcp/internal/McpServerFactory.d.ts.map +1 -0
- package/dist/services/mcp/internal/McpServerFactory.js +71 -0
- package/dist/services/mcp/internal/McpServerFactory.js.map +1 -0
- package/dist/services/mcp/internal/McpServerFactory.mjs +69 -0
- package/dist/services/mcp/internal/McpServerFactory.mjs.map +1 -0
- package/dist/services/mcp/internal/syncMcpSessionCapabilities.d.ts +21 -0
- package/dist/services/mcp/internal/syncMcpSessionCapabilities.d.ts.map +1 -0
- package/dist/services/mcp/internal/syncMcpSessionCapabilities.js +76 -0
- package/dist/services/mcp/internal/syncMcpSessionCapabilities.js.map +1 -0
- package/dist/services/mcp/internal/syncMcpSessionCapabilities.mjs +73 -0
- package/dist/services/mcp/internal/syncMcpSessionCapabilities.mjs.map +1 -0
- package/dist/services/mcp/metrics/metrics.d.ts +29 -0
- package/dist/services/mcp/metrics/metrics.d.ts.map +1 -0
- package/dist/services/mcp/metrics/metrics.js +97 -0
- package/dist/services/mcp/metrics/metrics.js.map +1 -0
- package/dist/services/mcp/metrics/metrics.mjs +88 -0
- package/dist/services/mcp/metrics/metrics.mjs.map +1 -0
- package/dist/services/mcp/metrics/normalizeMcpCapability.d.ts +11 -0
- package/dist/services/mcp/metrics/normalizeMcpCapability.d.ts.map +1 -0
- package/dist/services/mcp/metrics/normalizeMcpCapability.js +10 -0
- package/dist/services/mcp/metrics/normalizeMcpCapability.js.map +1 -0
- package/dist/services/mcp/metrics/normalizeMcpCapability.mjs +8 -0
- package/dist/services/mcp/metrics/normalizeMcpCapability.mjs.map +1 -0
- package/dist/services/mcp/metrics/wrapCapabilityHandlerForMetrics.d.ts +4 -0
- package/dist/services/mcp/metrics/wrapCapabilityHandlerForMetrics.d.ts.map +1 -0
- package/dist/services/mcp/metrics/wrapCapabilityHandlerForMetrics.js +27 -0
- package/dist/services/mcp/metrics/wrapCapabilityHandlerForMetrics.js.map +1 -0
- package/dist/services/mcp/metrics/wrapCapabilityHandlerForMetrics.mjs +25 -0
- package/dist/services/mcp/metrics/wrapCapabilityHandlerForMetrics.mjs.map +1 -0
- package/dist/services/mcp/middleware/oauthDiscoveryFallback.d.ts +3 -0
- package/dist/services/mcp/middleware/oauthDiscoveryFallback.d.ts.map +1 -0
- package/dist/services/mcp/middleware/oauthDiscoveryFallback.js +47 -0
- package/dist/services/mcp/middleware/oauthDiscoveryFallback.js.map +1 -0
- package/dist/services/mcp/middleware/oauthDiscoveryFallback.mjs +45 -0
- package/dist/services/mcp/middleware/oauthDiscoveryFallback.mjs.map +1 -0
- package/dist/services/mcp/prompt-registry.d.ts +16 -0
- package/dist/services/mcp/prompt-registry.d.ts.map +1 -0
- package/dist/services/mcp/prompt-registry.js +77 -0
- package/dist/services/mcp/prompt-registry.js.map +1 -0
- package/dist/services/mcp/prompt-registry.mjs +75 -0
- package/dist/services/mcp/prompt-registry.mjs.map +1 -0
- package/dist/services/mcp/resource-registry.d.ts +14 -0
- package/dist/services/mcp/resource-registry.d.ts.map +1 -0
- package/dist/services/mcp/resource-registry.js +67 -0
- package/dist/services/mcp/resource-registry.js.map +1 -0
- package/dist/services/mcp/resource-registry.mjs +65 -0
- package/dist/services/mcp/resource-registry.mjs.map +1 -0
- package/dist/services/mcp/routes.d.ts +11 -0
- package/dist/services/mcp/routes.d.ts.map +1 -0
- package/dist/services/mcp/routes.js +58 -0
- package/dist/services/mcp/routes.js.map +1 -0
- package/dist/services/mcp/routes.mjs +56 -0
- package/dist/services/mcp/routes.mjs.map +1 -0
- package/dist/services/mcp/tool-registry.d.ts +25 -0
- package/dist/services/mcp/tool-registry.d.ts.map +1 -0
- package/dist/services/mcp/tool-registry.js +102 -0
- package/dist/services/mcp/tool-registry.js.map +1 -0
- package/dist/services/mcp/tool-registry.mjs +99 -0
- package/dist/services/mcp/tool-registry.mjs.map +1 -0
- package/dist/services/mcp/tools/log.d.ts +87 -0
- package/dist/services/mcp/tools/log.d.ts.map +1 -0
- package/dist/services/mcp/tools/log.js +88 -0
- package/dist/services/mcp/tools/log.js.map +1 -0
- package/dist/services/mcp/tools/log.mjs +86 -0
- package/dist/services/mcp/tools/log.mjs.map +1 -0
- package/dist/services/mcp/utils/createSafeCapabilityRegistration.d.ts +36 -0
- package/dist/services/mcp/utils/createSafeCapabilityRegistration.d.ts.map +1 -0
- package/dist/services/mcp/utils/createSafeCapabilityRegistration.js +59 -0
- package/dist/services/mcp/utils/createSafeCapabilityRegistration.js.map +1 -0
- package/dist/services/mcp/utils/createSafeCapabilityRegistration.mjs +56 -0
- package/dist/services/mcp/utils/createSafeCapabilityRegistration.mjs.map +1 -0
- package/dist/services/mcp/utils/jsonRpcErrors.d.ts +22 -0
- package/dist/services/mcp/utils/jsonRpcErrors.d.ts.map +1 -0
- package/dist/services/mcp/utils/jsonRpcErrors.js +25 -0
- package/dist/services/mcp/utils/jsonRpcErrors.js.map +1 -0
- package/dist/services/mcp/utils/jsonRpcErrors.mjs +23 -0
- package/dist/services/mcp/utils/jsonRpcErrors.mjs.map +1 -0
- package/dist/services/mcp/utils/safeHandlerWrapper.d.ts +18 -0
- package/dist/services/mcp/utils/safeHandlerWrapper.d.ts.map +1 -0
- package/dist/services/mcp/utils/safeHandlerWrapper.js +29 -0
- package/dist/services/mcp/utils/safeHandlerWrapper.js.map +1 -0
- package/dist/services/mcp/utils/safeHandlerWrapper.mjs +27 -0
- package/dist/services/mcp/utils/safeHandlerWrapper.mjs.map +1 -0
- package/dist/services/mcp/utils/sendJsonRpcError.d.ts +5 -0
- package/dist/services/mcp/utils/sendJsonRpcError.d.ts.map +1 -0
- package/dist/services/mcp/utils/sendJsonRpcError.js +23 -0
- package/dist/services/mcp/utils/sendJsonRpcError.js.map +1 -0
- package/dist/services/mcp/utils/sendJsonRpcError.mjs +21 -0
- package/dist/services/mcp/utils/sendJsonRpcError.mjs.map +1 -0
- package/dist/services/mcp/utils/withTimeout.d.ts +7 -0
- package/dist/services/mcp/utils/withTimeout.d.ts.map +1 -0
- package/dist/services/mcp/utils/withTimeout.js +23 -0
- package/dist/services/mcp/utils/withTimeout.js.map +1 -0
- package/dist/services/mcp/utils/withTimeout.mjs +21 -0
- package/dist/services/mcp/utils/withTimeout.mjs.map +1 -0
- package/dist/services/metrics/index.d.ts.map +1 -1
- package/dist/services/metrics/index.js +3 -1
- package/dist/services/metrics/index.js.map +1 -1
- package/dist/services/metrics/index.mjs +3 -1
- package/dist/services/metrics/index.mjs.map +1 -1
- package/package.json +14 -12
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"authentication.js","sources":["../../../src/services/mcp/authentication.ts"],"sourcesContent":["import type { Core, Data } from '@strapi/types';\nimport type { Ability } from '@casl/ability';\nimport type { Context } from 'koa';\n\nexport type McpAdminTokenAbility = Ability;\n\nexport type McpAuthFailureReason = 'missing_token' | 'invalid_token';\n\nexport type McpAdminTokenAuthResult =\n | { authenticated: false; reason: McpAuthFailureReason; error?: Error }\n | {\n authenticated: true;\n credentials: { id: Data.ID };\n user: { id: Data.ID };\n ability: McpAdminTokenAbility;\n };\n\nconst extractBearerToken = (ctx: Context): string | null => {\n const authorization = ctx.request.header.authorization;\n\n if (authorization === undefined) {\n return null;\n }\n\n const parts = authorization.split(/\\s+/);\n\n if (parts[0].toLowerCase() !== 'bearer' || parts.length !== 2) {\n return null;\n }\n\n return parts[1];\n};\n\nexport const createMcpAdminTokenAuthenticator = (strapi: Core.Strapi) => ({\n async authenticate(ctx: Context): Promise<McpAdminTokenAuthResult> {\n const token = extractBearerToken(ctx);\n\n if (token === null) {\n return { authenticated: false, reason: 'missing_token' };\n }\n\n const authResult = (await strapi.admin.services['api-token-admin'].authenticateAdminToken(\n token\n )) as McpAdminTokenAuthResult;\n\n if (authResult.authenticated === false) {\n return {\n authenticated: false,\n reason: 'invalid_token',\n error: authResult.error,\n };\n }\n\n return {\n authenticated: true,\n credentials: { id: authResult.credentials.id },\n user: { id: authResult.user.id },\n ability: authResult.ability,\n };\n },\n});\n"],"names":["extractBearerToken","ctx","authorization","request","header","undefined","parts","split","toLowerCase","length","createMcpAdminTokenAuthenticator","strapi","authenticate","token","authenticated","reason","authResult","admin","services","authenticateAdminToken","error","credentials","id","user","ability"],"mappings":";;AAiBA,MAAMA,qBAAqB,CAACC,GAAAA,GAAAA;AAC1B,IAAA,MAAMC,gBAAgBD,GAAAA,CAAIE,OAAO,CAACC,MAAM,CAACF,aAAa;AAEtD,IAAA,IAAIA,kBAAkBG,SAAAA,EAAW;QAC/B,OAAO,IAAA;AACT,IAAA;IAEA,MAAMC,KAAAA,GAAQJ,aAAAA,CAAcK,KAAK,CAAC,KAAA,CAAA;IAElC,IAAID,KAAK,CAAC,CAAA,CAAE,CAACE,WAAW,OAAO,QAAA,IAAYF,KAAAA,CAAMG,MAAM,KAAK,CAAA,EAAG;QAC7D,OAAO,IAAA;AACT,IAAA;IAEA,OAAOH,KAAK,CAAC,CAAA,CAAE;AACjB,CAAA;AAEO,MAAMI,gCAAAA,GAAmC,CAACC,MAAAA,IAAyB;AACxE,QAAA,MAAMC,cAAaX,GAAY,EAAA;AAC7B,YAAA,MAAMY,QAAQb,kBAAAA,CAAmBC,GAAAA,CAAAA;AAEjC,YAAA,IAAIY,UAAU,IAAA,EAAM;gBAClB,OAAO;oBAAEC,aAAAA,EAAe,KAAA;oBAAOC,MAAAA,EAAQ;AAAgB,iBAAA;AACzD,YAAA;YAEA,MAAMC,UAAAA,GAAc,MAAML,MAAAA,CAAOM,KAAK,CAACC,QAAQ,CAAC,iBAAA,CAAkB,CAACC,sBAAsB,CACvFN,KAAAA,CAAAA;YAGF,IAAIG,UAAAA,CAAWF,aAAa,KAAK,KAAA,EAAO;gBACtC,OAAO;oBACLA,aAAAA,EAAe,KAAA;oBACfC,MAAAA,EAAQ,eAAA;AACRK,oBAAAA,KAAAA,EAAOJ,WAAWI;AACpB,iBAAA;AACF,YAAA;YAEA,OAAO;gBACLN,aAAAA,EAAe,IAAA;gBACfO,WAAAA,EAAa;oBAAEC,EAAAA,EAAIN,UAAAA,CAAWK,WAAW,CAACC;AAAG,iBAAA;gBAC7CC,IAAAA,EAAM;oBAAED,EAAAA,EAAIN,UAAAA,CAAWO,IAAI,CAACD;AAAG,iBAAA;AAC/BE,gBAAAA,OAAAA,EAASR,WAAWQ;AACtB,aAAA;AACF,QAAA;AACF,KAAA;;;;"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
const extractBearerToken = (ctx)=>{
|
|
2
|
+
const authorization = ctx.request.header.authorization;
|
|
3
|
+
if (authorization === undefined) {
|
|
4
|
+
return null;
|
|
5
|
+
}
|
|
6
|
+
const parts = authorization.split(/\s+/);
|
|
7
|
+
if (parts[0].toLowerCase() !== 'bearer' || parts.length !== 2) {
|
|
8
|
+
return null;
|
|
9
|
+
}
|
|
10
|
+
return parts[1];
|
|
11
|
+
};
|
|
12
|
+
const createMcpAdminTokenAuthenticator = (strapi)=>({
|
|
13
|
+
async authenticate (ctx) {
|
|
14
|
+
const token = extractBearerToken(ctx);
|
|
15
|
+
if (token === null) {
|
|
16
|
+
return {
|
|
17
|
+
authenticated: false,
|
|
18
|
+
reason: 'missing_token'
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
const authResult = await strapi.admin.services['api-token-admin'].authenticateAdminToken(token);
|
|
22
|
+
if (authResult.authenticated === false) {
|
|
23
|
+
return {
|
|
24
|
+
authenticated: false,
|
|
25
|
+
reason: 'invalid_token',
|
|
26
|
+
error: authResult.error
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
return {
|
|
30
|
+
authenticated: true,
|
|
31
|
+
credentials: {
|
|
32
|
+
id: authResult.credentials.id
|
|
33
|
+
},
|
|
34
|
+
user: {
|
|
35
|
+
id: authResult.user.id
|
|
36
|
+
},
|
|
37
|
+
ability: authResult.ability
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
|
|
42
|
+
export { createMcpAdminTokenAuthenticator };
|
|
43
|
+
//# sourceMappingURL=authentication.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"authentication.mjs","sources":["../../../src/services/mcp/authentication.ts"],"sourcesContent":["import type { Core, Data } from '@strapi/types';\nimport type { Ability } from '@casl/ability';\nimport type { Context } from 'koa';\n\nexport type McpAdminTokenAbility = Ability;\n\nexport type McpAuthFailureReason = 'missing_token' | 'invalid_token';\n\nexport type McpAdminTokenAuthResult =\n | { authenticated: false; reason: McpAuthFailureReason; error?: Error }\n | {\n authenticated: true;\n credentials: { id: Data.ID };\n user: { id: Data.ID };\n ability: McpAdminTokenAbility;\n };\n\nconst extractBearerToken = (ctx: Context): string | null => {\n const authorization = ctx.request.header.authorization;\n\n if (authorization === undefined) {\n return null;\n }\n\n const parts = authorization.split(/\\s+/);\n\n if (parts[0].toLowerCase() !== 'bearer' || parts.length !== 2) {\n return null;\n }\n\n return parts[1];\n};\n\nexport const createMcpAdminTokenAuthenticator = (strapi: Core.Strapi) => ({\n async authenticate(ctx: Context): Promise<McpAdminTokenAuthResult> {\n const token = extractBearerToken(ctx);\n\n if (token === null) {\n return { authenticated: false, reason: 'missing_token' };\n }\n\n const authResult = (await strapi.admin.services['api-token-admin'].authenticateAdminToken(\n token\n )) as McpAdminTokenAuthResult;\n\n if (authResult.authenticated === false) {\n return {\n authenticated: false,\n reason: 'invalid_token',\n error: authResult.error,\n };\n }\n\n return {\n authenticated: true,\n credentials: { id: authResult.credentials.id },\n user: { id: authResult.user.id },\n ability: authResult.ability,\n };\n },\n});\n"],"names":["extractBearerToken","ctx","authorization","request","header","undefined","parts","split","toLowerCase","length","createMcpAdminTokenAuthenticator","strapi","authenticate","token","authenticated","reason","authResult","admin","services","authenticateAdminToken","error","credentials","id","user","ability"],"mappings":"AAiBA,MAAMA,qBAAqB,CAACC,GAAAA,GAAAA;AAC1B,IAAA,MAAMC,gBAAgBD,GAAAA,CAAIE,OAAO,CAACC,MAAM,CAACF,aAAa;AAEtD,IAAA,IAAIA,kBAAkBG,SAAAA,EAAW;QAC/B,OAAO,IAAA;AACT,IAAA;IAEA,MAAMC,KAAAA,GAAQJ,aAAAA,CAAcK,KAAK,CAAC,KAAA,CAAA;IAElC,IAAID,KAAK,CAAC,CAAA,CAAE,CAACE,WAAW,OAAO,QAAA,IAAYF,KAAAA,CAAMG,MAAM,KAAK,CAAA,EAAG;QAC7D,OAAO,IAAA;AACT,IAAA;IAEA,OAAOH,KAAK,CAAC,CAAA,CAAE;AACjB,CAAA;AAEO,MAAMI,gCAAAA,GAAmC,CAACC,MAAAA,IAAyB;AACxE,QAAA,MAAMC,cAAaX,GAAY,EAAA;AAC7B,YAAA,MAAMY,QAAQb,kBAAAA,CAAmBC,GAAAA,CAAAA;AAEjC,YAAA,IAAIY,UAAU,IAAA,EAAM;gBAClB,OAAO;oBAAEC,aAAAA,EAAe,KAAA;oBAAOC,MAAAA,EAAQ;AAAgB,iBAAA;AACzD,YAAA;YAEA,MAAMC,UAAAA,GAAc,MAAML,MAAAA,CAAOM,KAAK,CAACC,QAAQ,CAAC,iBAAA,CAAkB,CAACC,sBAAsB,CACvFN,KAAAA,CAAAA;YAGF,IAAIG,UAAAA,CAAWF,aAAa,KAAK,KAAA,EAAO;gBACtC,OAAO;oBACLA,aAAAA,EAAe,KAAA;oBACfC,MAAAA,EAAQ,eAAA;AACRK,oBAAAA,KAAAA,EAAOJ,WAAWI;AACpB,iBAAA;AACF,YAAA;YAEA,OAAO;gBACLN,aAAAA,EAAe,IAAA;gBACfO,WAAAA,EAAa;oBAAEC,EAAAA,EAAIN,UAAAA,CAAWK,WAAW,CAACC;AAAG,iBAAA;gBAC7CC,IAAAA,EAAM;oBAAED,EAAAA,EAAIN,UAAAA,CAAWO,IAAI,CAACD;AAAG,iBAAA;AAC/BE,gBAAAA,OAAAA,EAASR,WAAWQ;AACtB,aAAA;AACF,QAAA;AACF,KAAA;;;;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"handlePost.d.ts","sourceRoot":"","sources":["../../../../src/services/mcp/handlers/handlePost.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAS1C,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,SAAS,CAAC;AAEtD,eAAO,MAAM,iBAAiB,SAAU,sBAAsB,KAAG,KAAK,iBAuErE,CAAC"}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var streamableHttp_js = require('@modelcontextprotocol/sdk/server/streamableHttp.js');
|
|
4
|
+
var metrics = require('../metrics/metrics.js');
|
|
5
|
+
var sendJsonRpcError = require('../utils/sendJsonRpcError.js');
|
|
6
|
+
var withTimeout = require('../utils/withTimeout.js');
|
|
7
|
+
|
|
8
|
+
// eslint-disable-next-line import/extensions
|
|
9
|
+
const createPostHandler = (deps)=>{
|
|
10
|
+
const { strapi, authenticationStrategy, config, createServerWithRegistries, capabilityDefinitions } = deps;
|
|
11
|
+
return async (ctx)=>{
|
|
12
|
+
// Opt out of Koa's response phase — the MCP SDK writes directly to ctx.res
|
|
13
|
+
// (via res.writeHead / res.end / SSE streaming). Without this, Koa's respond()
|
|
14
|
+
// would also try to write ctx.body to the socket after the handler returns.
|
|
15
|
+
ctx.respond = false;
|
|
16
|
+
const req = ctx.req;
|
|
17
|
+
const res = ctx.res;
|
|
18
|
+
let hadAuthenticatedMcpRequest = false;
|
|
19
|
+
try {
|
|
20
|
+
const authResult = await authenticationStrategy.authenticate(ctx);
|
|
21
|
+
if (authResult.authenticated === false) {
|
|
22
|
+
metrics.sendDidNotAuthenticateMcpRequest(strapi, authResult.reason);
|
|
23
|
+
sendJsonRpcError.sendJsonRpcError(res, 'AUTHENTICATION_REQUIRED');
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
hadAuthenticatedMcpRequest = true;
|
|
27
|
+
metrics.sendDidUseMcpServer(strapi);
|
|
28
|
+
const { mcpServer } = createServerWithRegistries({
|
|
29
|
+
strapi,
|
|
30
|
+
definitions: capabilityDefinitions,
|
|
31
|
+
isDevMode: config.isDevMode(),
|
|
32
|
+
ability: authResult.ability,
|
|
33
|
+
user: authResult.user
|
|
34
|
+
});
|
|
35
|
+
const transport = new streamableHttp_js.StreamableHTTPServerTransport({
|
|
36
|
+
sessionIdGenerator: undefined
|
|
37
|
+
});
|
|
38
|
+
try {
|
|
39
|
+
await withTimeout.withTimeout(mcpServer.connect(transport), config.connectTimeoutMs, 'mcpServer.connect');
|
|
40
|
+
const requestBody = ctx.request.body ?? null;
|
|
41
|
+
await withTimeout.withTimeout(transport.handleRequest(req, res, requestBody), config.requestTimeoutMs, 'transport.handleRequest');
|
|
42
|
+
} finally{
|
|
43
|
+
await mcpServer.close();
|
|
44
|
+
}
|
|
45
|
+
} catch (error) {
|
|
46
|
+
strapi.log.error('[MCP] Error handling POST request', {
|
|
47
|
+
error: error instanceof Error ? error.message : 'Unknown error',
|
|
48
|
+
stack: error instanceof Error ? error.stack : undefined
|
|
49
|
+
});
|
|
50
|
+
sendJsonRpcError.sendJsonRpcError(res, 'INTERNAL_ERROR');
|
|
51
|
+
if (hadAuthenticatedMcpRequest) {
|
|
52
|
+
metrics.sendDidNotHandleMcpRequest(strapi, metrics.classifyMcpRequestFailure(error));
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
};
|
|
56
|
+
};
|
|
57
|
+
|
|
58
|
+
exports.createPostHandler = createPostHandler;
|
|
59
|
+
//# sourceMappingURL=handlePost.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"handlePost.js","sources":["../../../../src/services/mcp/handlers/handlePost.ts"],"sourcesContent":["// eslint-disable-next-line import/extensions\nimport { StreamableHTTPServerTransport } from '@modelcontextprotocol/sdk/server/streamableHttp.js';\nimport type { Core } from '@strapi/types';\nimport {\n classifyMcpRequestFailure,\n sendDidNotAuthenticateMcpRequest,\n sendDidNotHandleMcpRequest,\n sendDidUseMcpServer,\n} from '../metrics/metrics';\nimport { sendJsonRpcError } from '../utils/sendJsonRpcError';\nimport { withTimeout } from '../utils/withTimeout';\nimport type { McpHandlerDependencies } from './types';\n\nexport const createPostHandler = (deps: McpHandlerDependencies): Core.MiddlewareHandler => {\n const {\n strapi,\n authenticationStrategy,\n config,\n createServerWithRegistries,\n capabilityDefinitions,\n } = deps;\n\n return async (ctx) => {\n // Opt out of Koa's response phase — the MCP SDK writes directly to ctx.res\n // (via res.writeHead / res.end / SSE streaming). Without this, Koa's respond()\n // would also try to write ctx.body to the socket after the handler returns.\n ctx.respond = false;\n const req = ctx.req;\n const res = ctx.res;\n\n let hadAuthenticatedMcpRequest = false;\n\n try {\n const authResult = await authenticationStrategy.authenticate(ctx);\n if (authResult.authenticated === false) {\n sendDidNotAuthenticateMcpRequest(strapi, authResult.reason);\n sendJsonRpcError(res, 'AUTHENTICATION_REQUIRED');\n return;\n }\n\n hadAuthenticatedMcpRequest = true;\n sendDidUseMcpServer(strapi);\n\n const { mcpServer } = createServerWithRegistries({\n strapi,\n definitions: capabilityDefinitions,\n isDevMode: config.isDevMode(),\n ability: authResult.ability,\n user: authResult.user,\n });\n\n const transport = new StreamableHTTPServerTransport({\n sessionIdGenerator: undefined,\n });\n\n try {\n await withTimeout(\n mcpServer.connect(transport),\n config.connectTimeoutMs,\n 'mcpServer.connect'\n );\n\n const requestBody = ctx.request.body ?? null;\n await withTimeout(\n transport.handleRequest(req, res, requestBody),\n config.requestTimeoutMs,\n 'transport.handleRequest'\n );\n } finally {\n await mcpServer.close();\n }\n } catch (error) {\n strapi.log.error('[MCP] Error handling POST request', {\n error: error instanceof Error ? error.message : 'Unknown error',\n stack: error instanceof Error ? error.stack : undefined,\n });\n\n sendJsonRpcError(res, 'INTERNAL_ERROR');\n\n if (hadAuthenticatedMcpRequest) {\n sendDidNotHandleMcpRequest(strapi, classifyMcpRequestFailure(error));\n }\n }\n };\n};\n"],"names":["createPostHandler","deps","strapi","authenticationStrategy","config","createServerWithRegistries","capabilityDefinitions","ctx","respond","req","res","hadAuthenticatedMcpRequest","authResult","authenticate","authenticated","sendDidNotAuthenticateMcpRequest","reason","sendJsonRpcError","sendDidUseMcpServer","mcpServer","definitions","isDevMode","ability","user","transport","StreamableHTTPServerTransport","sessionIdGenerator","undefined","withTimeout","connect","connectTimeoutMs","requestBody","request","body","handleRequest","requestTimeoutMs","close","error","log","Error","message","stack","sendDidNotHandleMcpRequest","classifyMcpRequestFailure"],"mappings":";;;;;;;AAAA;AAaO,MAAMA,oBAAoB,CAACC,IAAAA,GAAAA;IAChC,MAAM,EACJC,MAAM,EACNC,sBAAsB,EACtBC,MAAM,EACNC,0BAA0B,EAC1BC,qBAAqB,EACtB,GAAGL,IAAAA;AAEJ,IAAA,OAAO,OAAOM,GAAAA,GAAAA;;;;AAIZA,QAAAA,GAAAA,CAAIC,OAAO,GAAG,KAAA;QACd,MAAMC,GAAAA,GAAMF,IAAIE,GAAG;QACnB,MAAMC,GAAAA,GAAMH,IAAIG,GAAG;AAEnB,QAAA,IAAIC,0BAAAA,GAA6B,KAAA;QAEjC,IAAI;AACF,YAAA,MAAMC,UAAAA,GAAa,MAAMT,sBAAAA,CAAuBU,YAAY,CAACN,GAAAA,CAAAA;YAC7D,IAAIK,UAAAA,CAAWE,aAAa,KAAK,KAAA,EAAO;gBACtCC,wCAAAA,CAAiCb,MAAAA,EAAQU,WAAWI,MAAM,CAAA;AAC1DC,gBAAAA,iCAAAA,CAAiBP,GAAAA,EAAK,yBAAA,CAAA;AACtB,gBAAA;AACF,YAAA;YAEAC,0BAAAA,GAA6B,IAAA;YAC7BO,2BAAAA,CAAoBhB,MAAAA,CAAAA;AAEpB,YAAA,MAAM,EAAEiB,SAAS,EAAE,GAAGd,0BAAAA,CAA2B;AAC/CH,gBAAAA,MAAAA;gBACAkB,WAAAA,EAAad,qBAAAA;AACbe,gBAAAA,SAAAA,EAAWjB,OAAOiB,SAAS,EAAA;AAC3BC,gBAAAA,OAAAA,EAASV,WAAWU,OAAO;AAC3BC,gBAAAA,IAAAA,EAAMX,WAAWW;AACnB,aAAA,CAAA;YAEA,MAAMC,SAAAA,GAAY,IAAIC,+CAAAA,CAA8B;gBAClDC,kBAAAA,EAAoBC;AACtB,aAAA,CAAA;YAEA,IAAI;AACF,gBAAA,MAAMC,wBACJT,SAAAA,CAAUU,OAAO,CAACL,SAAAA,CAAAA,EAClBpB,MAAAA,CAAO0B,gBAAgB,EACvB,mBAAA,CAAA;AAGF,gBAAA,MAAMC,WAAAA,GAAcxB,GAAAA,CAAIyB,OAAO,CAACC,IAAI,IAAI,IAAA;gBACxC,MAAML,uBAAAA,CACJJ,UAAUU,aAAa,CAACzB,KAAKC,GAAAA,EAAKqB,WAAAA,CAAAA,EAClC3B,MAAAA,CAAO+B,gBAAgB,EACvB,yBAAA,CAAA;YAEJ,CAAA,QAAU;AACR,gBAAA,MAAMhB,UAAUiB,KAAK,EAAA;AACvB,YAAA;AACF,QAAA,CAAA,CAAE,OAAOC,KAAAA,EAAO;AACdnC,YAAAA,MAAAA,CAAOoC,GAAG,CAACD,KAAK,CAAC,mCAAA,EAAqC;AACpDA,gBAAAA,KAAAA,EAAOA,KAAAA,YAAiBE,KAAAA,GAAQF,KAAAA,CAAMG,OAAO,GAAG,eAAA;AAChDC,gBAAAA,KAAAA,EAAOJ,KAAAA,YAAiBE,KAAAA,GAAQF,KAAAA,CAAMI,KAAK,GAAGd;AAChD,aAAA,CAAA;AAEAV,YAAAA,iCAAAA,CAAiBP,GAAAA,EAAK,gBAAA,CAAA;AAEtB,YAAA,IAAIC,0BAAAA,EAA4B;AAC9B+B,gBAAAA,kCAAAA,CAA2BxC,QAAQyC,iCAAAA,CAA0BN,KAAAA,CAAAA,CAAAA;AAC/D,YAAA;AACF,QAAA;AACF,IAAA,CAAA;AACF;;;;"}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { StreamableHTTPServerTransport } from '@modelcontextprotocol/sdk/server/streamableHttp.js';
|
|
2
|
+
import { sendDidNotAuthenticateMcpRequest, sendDidUseMcpServer, sendDidNotHandleMcpRequest, classifyMcpRequestFailure } from '../metrics/metrics.mjs';
|
|
3
|
+
import { sendJsonRpcError } from '../utils/sendJsonRpcError.mjs';
|
|
4
|
+
import { withTimeout } from '../utils/withTimeout.mjs';
|
|
5
|
+
|
|
6
|
+
// eslint-disable-next-line import/extensions
|
|
7
|
+
const createPostHandler = (deps)=>{
|
|
8
|
+
const { strapi, authenticationStrategy, config, createServerWithRegistries, capabilityDefinitions } = deps;
|
|
9
|
+
return async (ctx)=>{
|
|
10
|
+
// Opt out of Koa's response phase — the MCP SDK writes directly to ctx.res
|
|
11
|
+
// (via res.writeHead / res.end / SSE streaming). Without this, Koa's respond()
|
|
12
|
+
// would also try to write ctx.body to the socket after the handler returns.
|
|
13
|
+
ctx.respond = false;
|
|
14
|
+
const req = ctx.req;
|
|
15
|
+
const res = ctx.res;
|
|
16
|
+
let hadAuthenticatedMcpRequest = false;
|
|
17
|
+
try {
|
|
18
|
+
const authResult = await authenticationStrategy.authenticate(ctx);
|
|
19
|
+
if (authResult.authenticated === false) {
|
|
20
|
+
sendDidNotAuthenticateMcpRequest(strapi, authResult.reason);
|
|
21
|
+
sendJsonRpcError(res, 'AUTHENTICATION_REQUIRED');
|
|
22
|
+
return;
|
|
23
|
+
}
|
|
24
|
+
hadAuthenticatedMcpRequest = true;
|
|
25
|
+
sendDidUseMcpServer(strapi);
|
|
26
|
+
const { mcpServer } = createServerWithRegistries({
|
|
27
|
+
strapi,
|
|
28
|
+
definitions: capabilityDefinitions,
|
|
29
|
+
isDevMode: config.isDevMode(),
|
|
30
|
+
ability: authResult.ability,
|
|
31
|
+
user: authResult.user
|
|
32
|
+
});
|
|
33
|
+
const transport = new StreamableHTTPServerTransport({
|
|
34
|
+
sessionIdGenerator: undefined
|
|
35
|
+
});
|
|
36
|
+
try {
|
|
37
|
+
await withTimeout(mcpServer.connect(transport), config.connectTimeoutMs, 'mcpServer.connect');
|
|
38
|
+
const requestBody = ctx.request.body ?? null;
|
|
39
|
+
await withTimeout(transport.handleRequest(req, res, requestBody), config.requestTimeoutMs, 'transport.handleRequest');
|
|
40
|
+
} finally{
|
|
41
|
+
await mcpServer.close();
|
|
42
|
+
}
|
|
43
|
+
} catch (error) {
|
|
44
|
+
strapi.log.error('[MCP] Error handling POST request', {
|
|
45
|
+
error: error instanceof Error ? error.message : 'Unknown error',
|
|
46
|
+
stack: error instanceof Error ? error.stack : undefined
|
|
47
|
+
});
|
|
48
|
+
sendJsonRpcError(res, 'INTERNAL_ERROR');
|
|
49
|
+
if (hadAuthenticatedMcpRequest) {
|
|
50
|
+
sendDidNotHandleMcpRequest(strapi, classifyMcpRequestFailure(error));
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
};
|
|
54
|
+
};
|
|
55
|
+
|
|
56
|
+
export { createPostHandler };
|
|
57
|
+
//# sourceMappingURL=handlePost.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"handlePost.mjs","sources":["../../../../src/services/mcp/handlers/handlePost.ts"],"sourcesContent":["// eslint-disable-next-line import/extensions\nimport { StreamableHTTPServerTransport } from '@modelcontextprotocol/sdk/server/streamableHttp.js';\nimport type { Core } from '@strapi/types';\nimport {\n classifyMcpRequestFailure,\n sendDidNotAuthenticateMcpRequest,\n sendDidNotHandleMcpRequest,\n sendDidUseMcpServer,\n} from '../metrics/metrics';\nimport { sendJsonRpcError } from '../utils/sendJsonRpcError';\nimport { withTimeout } from '../utils/withTimeout';\nimport type { McpHandlerDependencies } from './types';\n\nexport const createPostHandler = (deps: McpHandlerDependencies): Core.MiddlewareHandler => {\n const {\n strapi,\n authenticationStrategy,\n config,\n createServerWithRegistries,\n capabilityDefinitions,\n } = deps;\n\n return async (ctx) => {\n // Opt out of Koa's response phase — the MCP SDK writes directly to ctx.res\n // (via res.writeHead / res.end / SSE streaming). Without this, Koa's respond()\n // would also try to write ctx.body to the socket after the handler returns.\n ctx.respond = false;\n const req = ctx.req;\n const res = ctx.res;\n\n let hadAuthenticatedMcpRequest = false;\n\n try {\n const authResult = await authenticationStrategy.authenticate(ctx);\n if (authResult.authenticated === false) {\n sendDidNotAuthenticateMcpRequest(strapi, authResult.reason);\n sendJsonRpcError(res, 'AUTHENTICATION_REQUIRED');\n return;\n }\n\n hadAuthenticatedMcpRequest = true;\n sendDidUseMcpServer(strapi);\n\n const { mcpServer } = createServerWithRegistries({\n strapi,\n definitions: capabilityDefinitions,\n isDevMode: config.isDevMode(),\n ability: authResult.ability,\n user: authResult.user,\n });\n\n const transport = new StreamableHTTPServerTransport({\n sessionIdGenerator: undefined,\n });\n\n try {\n await withTimeout(\n mcpServer.connect(transport),\n config.connectTimeoutMs,\n 'mcpServer.connect'\n );\n\n const requestBody = ctx.request.body ?? null;\n await withTimeout(\n transport.handleRequest(req, res, requestBody),\n config.requestTimeoutMs,\n 'transport.handleRequest'\n );\n } finally {\n await mcpServer.close();\n }\n } catch (error) {\n strapi.log.error('[MCP] Error handling POST request', {\n error: error instanceof Error ? error.message : 'Unknown error',\n stack: error instanceof Error ? error.stack : undefined,\n });\n\n sendJsonRpcError(res, 'INTERNAL_ERROR');\n\n if (hadAuthenticatedMcpRequest) {\n sendDidNotHandleMcpRequest(strapi, classifyMcpRequestFailure(error));\n }\n }\n };\n};\n"],"names":["createPostHandler","deps","strapi","authenticationStrategy","config","createServerWithRegistries","capabilityDefinitions","ctx","respond","req","res","hadAuthenticatedMcpRequest","authResult","authenticate","authenticated","sendDidNotAuthenticateMcpRequest","reason","sendJsonRpcError","sendDidUseMcpServer","mcpServer","definitions","isDevMode","ability","user","transport","StreamableHTTPServerTransport","sessionIdGenerator","undefined","withTimeout","connect","connectTimeoutMs","requestBody","request","body","handleRequest","requestTimeoutMs","close","error","log","Error","message","stack","sendDidNotHandleMcpRequest","classifyMcpRequestFailure"],"mappings":";;;;;AAAA;AAaO,MAAMA,oBAAoB,CAACC,IAAAA,GAAAA;IAChC,MAAM,EACJC,MAAM,EACNC,sBAAsB,EACtBC,MAAM,EACNC,0BAA0B,EAC1BC,qBAAqB,EACtB,GAAGL,IAAAA;AAEJ,IAAA,OAAO,OAAOM,GAAAA,GAAAA;;;;AAIZA,QAAAA,GAAAA,CAAIC,OAAO,GAAG,KAAA;QACd,MAAMC,GAAAA,GAAMF,IAAIE,GAAG;QACnB,MAAMC,GAAAA,GAAMH,IAAIG,GAAG;AAEnB,QAAA,IAAIC,0BAAAA,GAA6B,KAAA;QAEjC,IAAI;AACF,YAAA,MAAMC,UAAAA,GAAa,MAAMT,sBAAAA,CAAuBU,YAAY,CAACN,GAAAA,CAAAA;YAC7D,IAAIK,UAAAA,CAAWE,aAAa,KAAK,KAAA,EAAO;gBACtCC,gCAAAA,CAAiCb,MAAAA,EAAQU,WAAWI,MAAM,CAAA;AAC1DC,gBAAAA,gBAAAA,CAAiBP,GAAAA,EAAK,yBAAA,CAAA;AACtB,gBAAA;AACF,YAAA;YAEAC,0BAAAA,GAA6B,IAAA;YAC7BO,mBAAAA,CAAoBhB,MAAAA,CAAAA;AAEpB,YAAA,MAAM,EAAEiB,SAAS,EAAE,GAAGd,0BAAAA,CAA2B;AAC/CH,gBAAAA,MAAAA;gBACAkB,WAAAA,EAAad,qBAAAA;AACbe,gBAAAA,SAAAA,EAAWjB,OAAOiB,SAAS,EAAA;AAC3BC,gBAAAA,OAAAA,EAASV,WAAWU,OAAO;AAC3BC,gBAAAA,IAAAA,EAAMX,WAAWW;AACnB,aAAA,CAAA;YAEA,MAAMC,SAAAA,GAAY,IAAIC,6BAAAA,CAA8B;gBAClDC,kBAAAA,EAAoBC;AACtB,aAAA,CAAA;YAEA,IAAI;AACF,gBAAA,MAAMC,YACJT,SAAAA,CAAUU,OAAO,CAACL,SAAAA,CAAAA,EAClBpB,MAAAA,CAAO0B,gBAAgB,EACvB,mBAAA,CAAA;AAGF,gBAAA,MAAMC,WAAAA,GAAcxB,GAAAA,CAAIyB,OAAO,CAACC,IAAI,IAAI,IAAA;gBACxC,MAAML,WAAAA,CACJJ,UAAUU,aAAa,CAACzB,KAAKC,GAAAA,EAAKqB,WAAAA,CAAAA,EAClC3B,MAAAA,CAAO+B,gBAAgB,EACvB,yBAAA,CAAA;YAEJ,CAAA,QAAU;AACR,gBAAA,MAAMhB,UAAUiB,KAAK,EAAA;AACvB,YAAA;AACF,QAAA,CAAA,CAAE,OAAOC,KAAAA,EAAO;AACdnC,YAAAA,MAAAA,CAAOoC,GAAG,CAACD,KAAK,CAAC,mCAAA,EAAqC;AACpDA,gBAAAA,KAAAA,EAAOA,KAAAA,YAAiBE,KAAAA,GAAQF,KAAAA,CAAMG,OAAO,GAAG,eAAA;AAChDC,gBAAAA,KAAAA,EAAOJ,KAAAA,YAAiBE,KAAAA,GAAQF,KAAAA,CAAMI,KAAK,GAAGd;AAChD,aAAA,CAAA;AAEAV,YAAAA,gBAAAA,CAAiBP,GAAAA,EAAK,gBAAA,CAAA;AAEtB,YAAA,IAAIC,0BAAAA,EAA4B;AAC9B+B,gBAAAA,0BAAAA,CAA2BxC,QAAQyC,yBAAAA,CAA0BN,KAAAA,CAAAA,CAAAA;AAC/D,YAAA;AACF,QAAA;AACF,IAAA,CAAA;AACF;;;;"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { Core } from '@strapi/types';
|
|
2
|
+
import type { McpConfiguration } from '../internal/McpConfiguration';
|
|
3
|
+
import type { McpCapabilityDefinitions, createMcpServerWithRegistries } from '../internal/McpServerFactory';
|
|
4
|
+
import type { createMcpAdminTokenAuthenticator } from '../authentication';
|
|
5
|
+
export type McpHandlerDependencies = {
|
|
6
|
+
strapi: Core.Strapi;
|
|
7
|
+
authenticationStrategy: ReturnType<typeof createMcpAdminTokenAuthenticator>;
|
|
8
|
+
config: McpConfiguration;
|
|
9
|
+
createServerWithRegistries: typeof createMcpServerWithRegistries;
|
|
10
|
+
capabilityDefinitions: McpCapabilityDefinitions;
|
|
11
|
+
};
|
|
12
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/services/mcp/handlers/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAC1C,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AACrE,OAAO,KAAK,EACV,wBAAwB,EACxB,6BAA6B,EAC9B,MAAM,8BAA8B,CAAC;AACtC,OAAO,KAAK,EAAE,gCAAgC,EAAE,MAAM,mBAAmB,CAAC;AAE1E,MAAM,MAAM,sBAAsB,GAAG;IACnC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC;IACpB,sBAAsB,EAAE,UAAU,CAAC,OAAO,gCAAgC,CAAC,CAAC;IAC5E,MAAM,EAAE,gBAAgB,CAAC;IACzB,0BAA0B,EAAE,OAAO,6BAA6B,CAAC;IACjE,qBAAqB,EAAE,wBAAwB,CAAC;CACjD,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/services/mcp/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAYnD;;GAEG;AACH,eAAO,MAAM,gBAAgB,WAAY,KAAK,MAAM,KAAG,QAAQ,GAAG,CAAC,UAsHlE,CAAC"}
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var authentication = require('./authentication.js');
|
|
4
|
+
var handlePost = require('./handlers/handlePost.js');
|
|
5
|
+
var McpCapabilityDefinitionRegistry = require('./internal/McpCapabilityDefinitionRegistry.js');
|
|
6
|
+
var McpConfiguration = require('./internal/McpConfiguration.js');
|
|
7
|
+
var McpServerFactory = require('./internal/McpServerFactory.js');
|
|
8
|
+
var oauthDiscoveryFallback = require('./middleware/oauthDiscoveryFallback.js');
|
|
9
|
+
var routes = require('./routes.js');
|
|
10
|
+
var metrics = require('./metrics/metrics.js');
|
|
11
|
+
var log = require('./tools/log.js');
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* Creates an MCP service instance for Strapi Core
|
|
15
|
+
*/ const createMcpService = (strapi)=>{
|
|
16
|
+
// Initialize configuration
|
|
17
|
+
const config = new McpConfiguration.McpConfiguration(strapi);
|
|
18
|
+
const authenticationStrategy = authentication.createMcpAdminTokenAuthenticator(strapi);
|
|
19
|
+
// Status tracking
|
|
20
|
+
let serverStatus = 'idle';
|
|
21
|
+
// Definition registries
|
|
22
|
+
const toolDefinitions = new McpCapabilityDefinitionRegistry.McpCapabilityDefinitionRegistry('tool');
|
|
23
|
+
const promptDefinitions = new McpCapabilityDefinitionRegistry.McpCapabilityDefinitionRegistry('prompt');
|
|
24
|
+
const resourceDefinitions = new McpCapabilityDefinitionRegistry.McpCapabilityDefinitionRegistry('resource');
|
|
25
|
+
// Prepare handler dependencies
|
|
26
|
+
const handlerDependencies = {
|
|
27
|
+
strapi,
|
|
28
|
+
authenticationStrategy,
|
|
29
|
+
config,
|
|
30
|
+
createServerWithRegistries: McpServerFactory.createMcpServerWithRegistries,
|
|
31
|
+
capabilityDefinitions: {
|
|
32
|
+
tools: toolDefinitions,
|
|
33
|
+
prompts: promptDefinitions,
|
|
34
|
+
resources: resourceDefinitions
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
// Create HTTP handlers
|
|
38
|
+
const handlePost$1 = handlePost.createPostHandler(handlerDependencies);
|
|
39
|
+
const service = {
|
|
40
|
+
isEnabled () {
|
|
41
|
+
return config.isEnabled();
|
|
42
|
+
},
|
|
43
|
+
isRunning () {
|
|
44
|
+
return serverStatus === 'running';
|
|
45
|
+
},
|
|
46
|
+
registerTool (tool) {
|
|
47
|
+
if (serverStatus !== 'idle') {
|
|
48
|
+
throw new Error('[MCP] Tools must be registered before MCP server starts. Register during plugin register().');
|
|
49
|
+
}
|
|
50
|
+
toolDefinitions.define(tool);
|
|
51
|
+
},
|
|
52
|
+
registerPrompt (prompt) {
|
|
53
|
+
if (serverStatus !== 'idle') {
|
|
54
|
+
throw new Error('[MCP] Prompts must be registered before MCP server starts. Register during plugin register().');
|
|
55
|
+
}
|
|
56
|
+
promptDefinitions.define(prompt);
|
|
57
|
+
},
|
|
58
|
+
registerResource (resource) {
|
|
59
|
+
if (serverStatus !== 'idle') {
|
|
60
|
+
throw new Error('[MCP] Resources must be registered before MCP server starts. Register during plugin register().');
|
|
61
|
+
}
|
|
62
|
+
resourceDefinitions.define(resource);
|
|
63
|
+
},
|
|
64
|
+
async start () {
|
|
65
|
+
if (service.isEnabled() === false) {
|
|
66
|
+
strapi.log.debug('[MCP] Server is disabled');
|
|
67
|
+
return;
|
|
68
|
+
}
|
|
69
|
+
if (serverStatus === 'error') {
|
|
70
|
+
throw new Error('[MCP] Cannot start server: previous error state');
|
|
71
|
+
}
|
|
72
|
+
if (serverStatus !== 'idle') {
|
|
73
|
+
throw new Error(`[MCP] Server already started or starting (status: ${serverStatus})`);
|
|
74
|
+
}
|
|
75
|
+
serverStatus = 'starting';
|
|
76
|
+
strapi.server.use(oauthDiscoveryFallback.createOAuthDiscoveryFallbackMiddleware());
|
|
77
|
+
const routes$1 = routes.createMcpRoutes(config, {
|
|
78
|
+
handlePost: handlePost$1
|
|
79
|
+
});
|
|
80
|
+
strapi.server.routes(routes$1);
|
|
81
|
+
serverStatus = 'running';
|
|
82
|
+
metrics.sendDidStartMcpServer(strapi, {
|
|
83
|
+
path: config.path,
|
|
84
|
+
numberOfTools: toolDefinitions.size,
|
|
85
|
+
numberOfPrompts: promptDefinitions.size,
|
|
86
|
+
numberOfResources: resourceDefinitions.size
|
|
87
|
+
});
|
|
88
|
+
const baseUrl = strapi.config.get('server.url', 'http://localhost:1337');
|
|
89
|
+
strapi.log.info(`[MCP] Server available at ${baseUrl}${config.path}`);
|
|
90
|
+
},
|
|
91
|
+
async stop () {
|
|
92
|
+
serverStatus = 'idle';
|
|
93
|
+
strapi.log.info('[MCP] Service stopped');
|
|
94
|
+
}
|
|
95
|
+
};
|
|
96
|
+
service.registerTool(log.logToolDefinition);
|
|
97
|
+
return service;
|
|
98
|
+
};
|
|
99
|
+
|
|
100
|
+
exports.createMcpService = createMcpService;
|
|
101
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../src/services/mcp/index.ts"],"sourcesContent":["import type { Core, Modules } from '@strapi/types';\nimport { createMcpAdminTokenAuthenticator } from './authentication';\nimport { createPostHandler } from './handlers/handlePost';\nimport type { McpHandlerDependencies } from './handlers/types';\nimport { McpCapabilityDefinitionRegistry } from './internal/McpCapabilityDefinitionRegistry';\nimport { McpConfiguration } from './internal/McpConfiguration';\nimport { createMcpServerWithRegistries } from './internal/McpServerFactory';\nimport { createOAuthDiscoveryFallbackMiddleware } from './middleware/oauthDiscoveryFallback';\nimport { createMcpRoutes } from './routes';\nimport { sendDidStartMcpServer } from './metrics/metrics';\nimport { logToolDefinition } from './tools/log';\n\n/**\n * Creates an MCP service instance for Strapi Core\n */\nexport const createMcpService = (strapi: Core.Strapi): Modules.MCP.McpService => {\n // Initialize configuration\n const config = new McpConfiguration(strapi);\n\n const authenticationStrategy = createMcpAdminTokenAuthenticator(strapi);\n\n // Status tracking\n let serverStatus: Modules.MCP.McpServiceStatus = 'idle';\n\n // Definition registries\n const toolDefinitions = new McpCapabilityDefinitionRegistry<\n 'tool',\n Modules.MCP.McpToolDefinition\n >('tool');\n\n const promptDefinitions = new McpCapabilityDefinitionRegistry<\n 'prompt',\n Modules.MCP.McpPromptDefinition\n >('prompt');\n\n const resourceDefinitions = new McpCapabilityDefinitionRegistry<\n 'resource',\n Modules.MCP.McpResourceDefinition\n >('resource');\n\n // Prepare handler dependencies\n const handlerDependencies: McpHandlerDependencies = {\n strapi,\n authenticationStrategy,\n config,\n createServerWithRegistries: createMcpServerWithRegistries,\n capabilityDefinitions: {\n tools: toolDefinitions,\n prompts: promptDefinitions,\n resources: resourceDefinitions,\n },\n };\n\n // Create HTTP handlers\n const handlePost = createPostHandler(handlerDependencies);\n\n const service: Modules.MCP.McpService = {\n isEnabled() {\n return config.isEnabled();\n },\n\n isRunning() {\n return serverStatus === 'running';\n },\n\n registerTool(tool: Modules.MCP.McpToolDefinition) {\n if (serverStatus !== 'idle') {\n throw new Error(\n '[MCP] Tools must be registered before MCP server starts. Register during plugin register().'\n );\n }\n\n toolDefinitions.define(tool);\n },\n\n registerPrompt(prompt) {\n if (serverStatus !== 'idle') {\n throw new Error(\n '[MCP] Prompts must be registered before MCP server starts. Register during plugin register().'\n );\n }\n promptDefinitions.define(prompt);\n },\n\n registerResource(resource) {\n if (serverStatus !== 'idle') {\n throw new Error(\n '[MCP] Resources must be registered before MCP server starts. Register during plugin register().'\n );\n }\n resourceDefinitions.define(resource);\n },\n\n async start() {\n if (service.isEnabled() === false) {\n strapi.log.debug('[MCP] Server is disabled');\n return;\n }\n if (serverStatus === 'error') {\n throw new Error('[MCP] Cannot start server: previous error state');\n }\n if (serverStatus !== 'idle') {\n throw new Error(`[MCP] Server already started or starting (status: ${serverStatus})`);\n }\n serverStatus = 'starting';\n\n strapi.server.use(createOAuthDiscoveryFallbackMiddleware());\n\n const routes = createMcpRoutes(config, { handlePost });\n strapi.server.routes(routes);\n\n serverStatus = 'running';\n\n sendDidStartMcpServer(strapi, {\n path: config.path,\n numberOfTools: toolDefinitions.size,\n numberOfPrompts: promptDefinitions.size,\n numberOfResources: resourceDefinitions.size,\n });\n\n const baseUrl = strapi.config.get('server.url', 'http://localhost:1337');\n strapi.log.info(`[MCP] Server available at ${baseUrl}${config.path}`);\n },\n\n async stop() {\n serverStatus = 'idle';\n strapi.log.info('[MCP] Service stopped');\n },\n };\n\n service.registerTool(logToolDefinition);\n\n return service;\n};\n"],"names":["createMcpService","strapi","config","McpConfiguration","authenticationStrategy","createMcpAdminTokenAuthenticator","serverStatus","toolDefinitions","McpCapabilityDefinitionRegistry","promptDefinitions","resourceDefinitions","handlerDependencies","createServerWithRegistries","createMcpServerWithRegistries","capabilityDefinitions","tools","prompts","resources","handlePost","createPostHandler","service","isEnabled","isRunning","registerTool","tool","Error","define","registerPrompt","prompt","registerResource","resource","start","log","debug","server","use","createOAuthDiscoveryFallbackMiddleware","routes","createMcpRoutes","sendDidStartMcpServer","path","numberOfTools","size","numberOfPrompts","numberOfResources","baseUrl","get","info","stop","logToolDefinition"],"mappings":"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"}
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
import { createMcpAdminTokenAuthenticator } from './authentication.mjs';
|
|
2
|
+
import { createPostHandler } from './handlers/handlePost.mjs';
|
|
3
|
+
import { McpCapabilityDefinitionRegistry } from './internal/McpCapabilityDefinitionRegistry.mjs';
|
|
4
|
+
import { McpConfiguration } from './internal/McpConfiguration.mjs';
|
|
5
|
+
import { createMcpServerWithRegistries } from './internal/McpServerFactory.mjs';
|
|
6
|
+
import { createOAuthDiscoveryFallbackMiddleware } from './middleware/oauthDiscoveryFallback.mjs';
|
|
7
|
+
import { createMcpRoutes } from './routes.mjs';
|
|
8
|
+
import { sendDidStartMcpServer } from './metrics/metrics.mjs';
|
|
9
|
+
import { logToolDefinition } from './tools/log.mjs';
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* Creates an MCP service instance for Strapi Core
|
|
13
|
+
*/ const createMcpService = (strapi)=>{
|
|
14
|
+
// Initialize configuration
|
|
15
|
+
const config = new McpConfiguration(strapi);
|
|
16
|
+
const authenticationStrategy = createMcpAdminTokenAuthenticator(strapi);
|
|
17
|
+
// Status tracking
|
|
18
|
+
let serverStatus = 'idle';
|
|
19
|
+
// Definition registries
|
|
20
|
+
const toolDefinitions = new McpCapabilityDefinitionRegistry('tool');
|
|
21
|
+
const promptDefinitions = new McpCapabilityDefinitionRegistry('prompt');
|
|
22
|
+
const resourceDefinitions = new McpCapabilityDefinitionRegistry('resource');
|
|
23
|
+
// Prepare handler dependencies
|
|
24
|
+
const handlerDependencies = {
|
|
25
|
+
strapi,
|
|
26
|
+
authenticationStrategy,
|
|
27
|
+
config,
|
|
28
|
+
createServerWithRegistries: createMcpServerWithRegistries,
|
|
29
|
+
capabilityDefinitions: {
|
|
30
|
+
tools: toolDefinitions,
|
|
31
|
+
prompts: promptDefinitions,
|
|
32
|
+
resources: resourceDefinitions
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
// Create HTTP handlers
|
|
36
|
+
const handlePost = createPostHandler(handlerDependencies);
|
|
37
|
+
const service = {
|
|
38
|
+
isEnabled () {
|
|
39
|
+
return config.isEnabled();
|
|
40
|
+
},
|
|
41
|
+
isRunning () {
|
|
42
|
+
return serverStatus === 'running';
|
|
43
|
+
},
|
|
44
|
+
registerTool (tool) {
|
|
45
|
+
if (serverStatus !== 'idle') {
|
|
46
|
+
throw new Error('[MCP] Tools must be registered before MCP server starts. Register during plugin register().');
|
|
47
|
+
}
|
|
48
|
+
toolDefinitions.define(tool);
|
|
49
|
+
},
|
|
50
|
+
registerPrompt (prompt) {
|
|
51
|
+
if (serverStatus !== 'idle') {
|
|
52
|
+
throw new Error('[MCP] Prompts must be registered before MCP server starts. Register during plugin register().');
|
|
53
|
+
}
|
|
54
|
+
promptDefinitions.define(prompt);
|
|
55
|
+
},
|
|
56
|
+
registerResource (resource) {
|
|
57
|
+
if (serverStatus !== 'idle') {
|
|
58
|
+
throw new Error('[MCP] Resources must be registered before MCP server starts. Register during plugin register().');
|
|
59
|
+
}
|
|
60
|
+
resourceDefinitions.define(resource);
|
|
61
|
+
},
|
|
62
|
+
async start () {
|
|
63
|
+
if (service.isEnabled() === false) {
|
|
64
|
+
strapi.log.debug('[MCP] Server is disabled');
|
|
65
|
+
return;
|
|
66
|
+
}
|
|
67
|
+
if (serverStatus === 'error') {
|
|
68
|
+
throw new Error('[MCP] Cannot start server: previous error state');
|
|
69
|
+
}
|
|
70
|
+
if (serverStatus !== 'idle') {
|
|
71
|
+
throw new Error(`[MCP] Server already started or starting (status: ${serverStatus})`);
|
|
72
|
+
}
|
|
73
|
+
serverStatus = 'starting';
|
|
74
|
+
strapi.server.use(createOAuthDiscoveryFallbackMiddleware());
|
|
75
|
+
const routes = createMcpRoutes(config, {
|
|
76
|
+
handlePost
|
|
77
|
+
});
|
|
78
|
+
strapi.server.routes(routes);
|
|
79
|
+
serverStatus = 'running';
|
|
80
|
+
sendDidStartMcpServer(strapi, {
|
|
81
|
+
path: config.path,
|
|
82
|
+
numberOfTools: toolDefinitions.size,
|
|
83
|
+
numberOfPrompts: promptDefinitions.size,
|
|
84
|
+
numberOfResources: resourceDefinitions.size
|
|
85
|
+
});
|
|
86
|
+
const baseUrl = strapi.config.get('server.url', 'http://localhost:1337');
|
|
87
|
+
strapi.log.info(`[MCP] Server available at ${baseUrl}${config.path}`);
|
|
88
|
+
},
|
|
89
|
+
async stop () {
|
|
90
|
+
serverStatus = 'idle';
|
|
91
|
+
strapi.log.info('[MCP] Service stopped');
|
|
92
|
+
}
|
|
93
|
+
};
|
|
94
|
+
service.registerTool(logToolDefinition);
|
|
95
|
+
return service;
|
|
96
|
+
};
|
|
97
|
+
|
|
98
|
+
export { createMcpService };
|
|
99
|
+
//# sourceMappingURL=index.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":["../../../src/services/mcp/index.ts"],"sourcesContent":["import type { Core, Modules } from '@strapi/types';\nimport { createMcpAdminTokenAuthenticator } from './authentication';\nimport { createPostHandler } from './handlers/handlePost';\nimport type { McpHandlerDependencies } from './handlers/types';\nimport { McpCapabilityDefinitionRegistry } from './internal/McpCapabilityDefinitionRegistry';\nimport { McpConfiguration } from './internal/McpConfiguration';\nimport { createMcpServerWithRegistries } from './internal/McpServerFactory';\nimport { createOAuthDiscoveryFallbackMiddleware } from './middleware/oauthDiscoveryFallback';\nimport { createMcpRoutes } from './routes';\nimport { sendDidStartMcpServer } from './metrics/metrics';\nimport { logToolDefinition } from './tools/log';\n\n/**\n * Creates an MCP service instance for Strapi Core\n */\nexport const createMcpService = (strapi: Core.Strapi): Modules.MCP.McpService => {\n // Initialize configuration\n const config = new McpConfiguration(strapi);\n\n const authenticationStrategy = createMcpAdminTokenAuthenticator(strapi);\n\n // Status tracking\n let serverStatus: Modules.MCP.McpServiceStatus = 'idle';\n\n // Definition registries\n const toolDefinitions = new McpCapabilityDefinitionRegistry<\n 'tool',\n Modules.MCP.McpToolDefinition\n >('tool');\n\n const promptDefinitions = new McpCapabilityDefinitionRegistry<\n 'prompt',\n Modules.MCP.McpPromptDefinition\n >('prompt');\n\n const resourceDefinitions = new McpCapabilityDefinitionRegistry<\n 'resource',\n Modules.MCP.McpResourceDefinition\n >('resource');\n\n // Prepare handler dependencies\n const handlerDependencies: McpHandlerDependencies = {\n strapi,\n authenticationStrategy,\n config,\n createServerWithRegistries: createMcpServerWithRegistries,\n capabilityDefinitions: {\n tools: toolDefinitions,\n prompts: promptDefinitions,\n resources: resourceDefinitions,\n },\n };\n\n // Create HTTP handlers\n const handlePost = createPostHandler(handlerDependencies);\n\n const service: Modules.MCP.McpService = {\n isEnabled() {\n return config.isEnabled();\n },\n\n isRunning() {\n return serverStatus === 'running';\n },\n\n registerTool(tool: Modules.MCP.McpToolDefinition) {\n if (serverStatus !== 'idle') {\n throw new Error(\n '[MCP] Tools must be registered before MCP server starts. Register during plugin register().'\n );\n }\n\n toolDefinitions.define(tool);\n },\n\n registerPrompt(prompt) {\n if (serverStatus !== 'idle') {\n throw new Error(\n '[MCP] Prompts must be registered before MCP server starts. Register during plugin register().'\n );\n }\n promptDefinitions.define(prompt);\n },\n\n registerResource(resource) {\n if (serverStatus !== 'idle') {\n throw new Error(\n '[MCP] Resources must be registered before MCP server starts. Register during plugin register().'\n );\n }\n resourceDefinitions.define(resource);\n },\n\n async start() {\n if (service.isEnabled() === false) {\n strapi.log.debug('[MCP] Server is disabled');\n return;\n }\n if (serverStatus === 'error') {\n throw new Error('[MCP] Cannot start server: previous error state');\n }\n if (serverStatus !== 'idle') {\n throw new Error(`[MCP] Server already started or starting (status: ${serverStatus})`);\n }\n serverStatus = 'starting';\n\n strapi.server.use(createOAuthDiscoveryFallbackMiddleware());\n\n const routes = createMcpRoutes(config, { handlePost });\n strapi.server.routes(routes);\n\n serverStatus = 'running';\n\n sendDidStartMcpServer(strapi, {\n path: config.path,\n numberOfTools: toolDefinitions.size,\n numberOfPrompts: promptDefinitions.size,\n numberOfResources: resourceDefinitions.size,\n });\n\n const baseUrl = strapi.config.get('server.url', 'http://localhost:1337');\n strapi.log.info(`[MCP] Server available at ${baseUrl}${config.path}`);\n },\n\n async stop() {\n serverStatus = 'idle';\n strapi.log.info('[MCP] Service stopped');\n },\n };\n\n service.registerTool(logToolDefinition);\n\n return service;\n};\n"],"names":["createMcpService","strapi","config","McpConfiguration","authenticationStrategy","createMcpAdminTokenAuthenticator","serverStatus","toolDefinitions","McpCapabilityDefinitionRegistry","promptDefinitions","resourceDefinitions","handlerDependencies","createServerWithRegistries","createMcpServerWithRegistries","capabilityDefinitions","tools","prompts","resources","handlePost","createPostHandler","service","isEnabled","isRunning","registerTool","tool","Error","define","registerPrompt","prompt","registerResource","resource","start","log","debug","server","use","createOAuthDiscoveryFallbackMiddleware","routes","createMcpRoutes","sendDidStartMcpServer","path","numberOfTools","size","numberOfPrompts","numberOfResources","baseUrl","get","info","stop","logToolDefinition"],"mappings":";;;;;;;;;;AAYA;;IAGO,MAAMA,gBAAAA,GAAmB,CAACC,MAAAA,GAAAA;;IAE/B,MAAMC,MAAAA,GAAS,IAAIC,gBAAAA,CAAiBF,MAAAA,CAAAA;AAEpC,IAAA,MAAMG,yBAAyBC,gCAAAA,CAAiCJ,MAAAA,CAAAA;;AAGhE,IAAA,IAAIK,YAAAA,GAA6C,MAAA;;IAGjD,MAAMC,eAAAA,GAAkB,IAAIC,+BAAAA,CAG1B,MAAA,CAAA;IAEF,MAAMC,iBAAAA,GAAoB,IAAID,+BAAAA,CAG5B,QAAA,CAAA;IAEF,MAAME,mBAAAA,GAAsB,IAAIF,+BAAAA,CAG9B,UAAA,CAAA;;AAGF,IAAA,MAAMG,mBAAAA,GAA8C;AAClDV,QAAAA,MAAAA;AACAG,QAAAA,sBAAAA;AACAF,QAAAA,MAAAA;QACAU,0BAAAA,EAA4BC,6BAAAA;QAC5BC,qBAAAA,EAAuB;YACrBC,KAAAA,EAAOR,eAAAA;YACPS,OAAAA,EAASP,iBAAAA;YACTQ,SAAAA,EAAWP;AACb;AACF,KAAA;;AAGA,IAAA,MAAMQ,aAAaC,iBAAAA,CAAkBR,mBAAAA,CAAAA;AAErC,IAAA,MAAMS,OAAAA,GAAkC;AACtCC,QAAAA,SAAAA,CAAAA,GAAAA;AACE,YAAA,OAAOnB,OAAOmB,SAAS,EAAA;AACzB,QAAA,CAAA;AAEAC,QAAAA,SAAAA,CAAAA,GAAAA;AACE,YAAA,OAAOhB,YAAAA,KAAiB,SAAA;AAC1B,QAAA,CAAA;AAEAiB,QAAAA,YAAAA,CAAAA,CAAaC,IAAmC,EAAA;AAC9C,YAAA,IAAIlB,iBAAiB,MAAA,EAAQ;AAC3B,gBAAA,MAAM,IAAImB,KAAAA,CACR,6FAAA,CAAA;AAEJ,YAAA;AAEAlB,YAAAA,eAAAA,CAAgBmB,MAAM,CAACF,IAAAA,CAAAA;AACzB,QAAA,CAAA;AAEAG,QAAAA,cAAAA,CAAAA,CAAeC,MAAM,EAAA;AACnB,YAAA,IAAItB,iBAAiB,MAAA,EAAQ;AAC3B,gBAAA,MAAM,IAAImB,KAAAA,CACR,+FAAA,CAAA;AAEJ,YAAA;AACAhB,YAAAA,iBAAAA,CAAkBiB,MAAM,CAACE,MAAAA,CAAAA;AAC3B,QAAA,CAAA;AAEAC,QAAAA,gBAAAA,CAAAA,CAAiBC,QAAQ,EAAA;AACvB,YAAA,IAAIxB,iBAAiB,MAAA,EAAQ;AAC3B,gBAAA,MAAM,IAAImB,KAAAA,CACR,iGAAA,CAAA;AAEJ,YAAA;AACAf,YAAAA,mBAAAA,CAAoBgB,MAAM,CAACI,QAAAA,CAAAA;AAC7B,QAAA,CAAA;QAEA,MAAMC,KAAAA,CAAAA,GAAAA;YACJ,IAAIX,OAAAA,CAAQC,SAAS,EAAA,KAAO,KAAA,EAAO;gBACjCpB,MAAAA,CAAO+B,GAAG,CAACC,KAAK,CAAC,0BAAA,CAAA;AACjB,gBAAA;AACF,YAAA;AACA,YAAA,IAAI3B,iBAAiB,OAAA,EAAS;AAC5B,gBAAA,MAAM,IAAImB,KAAAA,CAAM,iDAAA,CAAA;AAClB,YAAA;AACA,YAAA,IAAInB,iBAAiB,MAAA,EAAQ;AAC3B,gBAAA,MAAM,IAAImB,KAAAA,CAAM,CAAC,kDAAkD,EAAEnB,YAAAA,CAAa,CAAC,CAAC,CAAA;AACtF,YAAA;YACAA,YAAAA,GAAe,UAAA;YAEfL,MAAAA,CAAOiC,MAAM,CAACC,GAAG,CAACC,sCAAAA,EAAAA,CAAAA;YAElB,MAAMC,MAAAA,GAASC,gBAAgBpC,MAAAA,EAAQ;AAAEgB,gBAAAA;AAAW,aAAA,CAAA;YACpDjB,MAAAA,CAAOiC,MAAM,CAACG,MAAM,CAACA,MAAAA,CAAAA;YAErB/B,YAAAA,GAAe,SAAA;AAEfiC,YAAAA,qBAAAA,CAAsBtC,MAAAA,EAAQ;AAC5BuC,gBAAAA,IAAAA,EAAMtC,OAAOsC,IAAI;AACjBC,gBAAAA,aAAAA,EAAelC,gBAAgBmC,IAAI;AACnCC,gBAAAA,eAAAA,EAAiBlC,kBAAkBiC,IAAI;AACvCE,gBAAAA,iBAAAA,EAAmBlC,oBAAoBgC;AACzC,aAAA,CAAA;AAEA,YAAA,MAAMG,UAAU5C,MAAAA,CAAOC,MAAM,CAAC4C,GAAG,CAAC,YAAA,EAAc,uBAAA,CAAA;YAChD7C,MAAAA,CAAO+B,GAAG,CAACe,IAAI,CAAC,CAAC,0BAA0B,EAAEF,OAAAA,CAAAA,EAAU3C,MAAAA,CAAOsC,IAAI,CAAA,CAAE,CAAA;AACtE,QAAA,CAAA;QAEA,MAAMQ,IAAAA,CAAAA,GAAAA;YACJ1C,YAAAA,GAAe,MAAA;YACfL,MAAAA,CAAO+B,GAAG,CAACe,IAAI,CAAC,uBAAA,CAAA;AAClB,QAAA;AACF,KAAA;AAEA3B,IAAAA,OAAAA,CAAQG,YAAY,CAAC0B,iBAAAA,CAAAA;IAErB,OAAO7B,OAAAA;AACT;;;;"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { Modules } from '@strapi/types';
|
|
2
|
+
export declare class McpCapabilityDefinitionRegistry<CapabilityName extends 'tool' | 'prompt' | 'resource', Definition extends Modules.MCP.McpCapabilityDefinition> {
|
|
3
|
+
#private;
|
|
4
|
+
capability: CapabilityName;
|
|
5
|
+
constructor(capability: CapabilityName);
|
|
6
|
+
get size(): number;
|
|
7
|
+
define(definition: Definition): void;
|
|
8
|
+
get(name: string): Definition | undefined;
|
|
9
|
+
delete(name: string): boolean;
|
|
10
|
+
getAll(): Definition[];
|
|
11
|
+
forEach(callback: (definition: Definition) => void): void;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=McpCapabilityDefinitionRegistry.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"McpCapabilityDefinitionRegistry.d.ts","sourceRoot":"","sources":["../../../../src/services/mcp/internal/McpCapabilityDefinitionRegistry.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAE7C,qBAAa,+BAA+B,CAC1C,cAAc,SAAS,MAAM,GAAG,QAAQ,GAAG,UAAU,EACrD,UAAU,SAAS,OAAO,CAAC,GAAG,CAAC,uBAAuB;;IAEtD,UAAU,EAAE,cAAc,CAAC;gBAIf,UAAU,EAAE,cAAc;IAItC,IAAI,IAAI,IAAI,MAAM,CAEjB;IAED,MAAM,CAAC,UAAU,EAAE,UAAU;IAuB7B,GAAG,CAAC,IAAI,EAAE,MAAM,GAAG,UAAU,GAAG,SAAS;IAIzC,MAAM,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO;IAI7B,MAAM,IAAI,UAAU,EAAE;IAItB,OAAO,CAAC,QAAQ,EAAE,CAAC,UAAU,EAAE,UAAU,KAAK,IAAI;CAGnD"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
function _class_private_field_loose_base(receiver, privateKey) {
|
|
4
|
+
if (!Object.prototype.hasOwnProperty.call(receiver, privateKey)) {
|
|
5
|
+
throw new TypeError("attempted to use private field on non-instance");
|
|
6
|
+
}
|
|
7
|
+
return receiver;
|
|
8
|
+
}
|
|
9
|
+
var id = 0;
|
|
10
|
+
function _class_private_field_loose_key(name) {
|
|
11
|
+
return "__private_" + id++ + "_" + name;
|
|
12
|
+
}
|
|
13
|
+
var _definitions = /*#__PURE__*/ _class_private_field_loose_key("_definitions");
|
|
14
|
+
class McpCapabilityDefinitionRegistry {
|
|
15
|
+
get size() {
|
|
16
|
+
return _class_private_field_loose_base(this, _definitions)[_definitions].size;
|
|
17
|
+
}
|
|
18
|
+
define(definition) {
|
|
19
|
+
const existing = _class_private_field_loose_base(this, _definitions)[_definitions].get(definition.name);
|
|
20
|
+
if (existing !== undefined) {
|
|
21
|
+
throw new Error(`[MCP] ${this.capability} with name "${definition.name}" is already registered. Names must be unique.`);
|
|
22
|
+
}
|
|
23
|
+
if (definition.devModeOnly !== true) {
|
|
24
|
+
if (definition.auth === undefined || definition.auth.policies.length === 0 || definition.auth.policies.some((p)=>p.action === '')) {
|
|
25
|
+
throw new Error(`[MCP] ${this.capability} with name "${definition.name}" must declare auth policies or be devModeOnly.`);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
_class_private_field_loose_base(this, _definitions)[_definitions].set(definition.name, definition);
|
|
29
|
+
}
|
|
30
|
+
get(name) {
|
|
31
|
+
return _class_private_field_loose_base(this, _definitions)[_definitions].get(name);
|
|
32
|
+
}
|
|
33
|
+
delete(name) {
|
|
34
|
+
return _class_private_field_loose_base(this, _definitions)[_definitions].delete(name);
|
|
35
|
+
}
|
|
36
|
+
getAll() {
|
|
37
|
+
return Array.from(_class_private_field_loose_base(this, _definitions)[_definitions].values());
|
|
38
|
+
}
|
|
39
|
+
forEach(callback) {
|
|
40
|
+
_class_private_field_loose_base(this, _definitions)[_definitions].forEach(callback);
|
|
41
|
+
}
|
|
42
|
+
constructor(capability){
|
|
43
|
+
Object.defineProperty(this, _definitions, {
|
|
44
|
+
writable: true,
|
|
45
|
+
value: void 0
|
|
46
|
+
});
|
|
47
|
+
_class_private_field_loose_base(this, _definitions)[_definitions] = new Map();
|
|
48
|
+
this.capability = capability;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
exports.McpCapabilityDefinitionRegistry = McpCapabilityDefinitionRegistry;
|
|
53
|
+
//# sourceMappingURL=McpCapabilityDefinitionRegistry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"McpCapabilityDefinitionRegistry.js","sources":["../../../../src/services/mcp/internal/McpCapabilityDefinitionRegistry.ts"],"sourcesContent":["import type { Modules } from '@strapi/types';\n\nexport class McpCapabilityDefinitionRegistry<\n CapabilityName extends 'tool' | 'prompt' | 'resource',\n Definition extends Modules.MCP.McpCapabilityDefinition,\n> {\n capability: CapabilityName;\n\n #definitions = new Map<string, Definition>();\n\n constructor(capability: CapabilityName) {\n this.capability = capability;\n }\n\n get size(): number {\n return this.#definitions.size;\n }\n\n define(definition: Definition) {\n const existing = this.#definitions.get(definition.name);\n if (existing !== undefined) {\n throw new Error(\n `[MCP] ${this.capability} with name \"${definition.name}\" is already registered. Names must be unique.`\n );\n }\n\n if (definition.devModeOnly !== true) {\n if (\n definition.auth === undefined ||\n definition.auth.policies.length === 0 ||\n definition.auth.policies.some((p) => p.action === '')\n ) {\n throw new Error(\n `[MCP] ${this.capability} with name \"${definition.name}\" must declare auth policies or be devModeOnly.`\n );\n }\n }\n\n this.#definitions.set(definition.name, definition);\n }\n\n get(name: string): Definition | undefined {\n return this.#definitions.get(name);\n }\n\n delete(name: string): boolean {\n return this.#definitions.delete(name);\n }\n\n getAll(): Definition[] {\n return Array.from(this.#definitions.values());\n }\n\n forEach(callback: (definition: Definition) => void) {\n this.#definitions.forEach(callback);\n }\n}\n"],"names":["McpCapabilityDefinitionRegistry","size","define","definition","existing","get","name","undefined","Error","capability","devModeOnly","auth","policies","length","some","p","action","set","delete","getAll","Array","from","values","forEach","callback","Map"],"mappings":";;;;;;;;;;;;AAQE,IAAA,YAAA,iBAAA,8BAAA,CAAA,cAAA,CAAA;AANK,MAAMA,+BAAAA,CAAAA;AAYX,IAAA,IAAIC,IAAAA,GAAe;AACjB,QAAA,OAAO,+BAAA,CAAA,IAAI,EAAC,YAAA,CAAA,CAAA,cAAaA,IAAI;AAC/B,IAAA;AAEAC,IAAAA,MAAAA,CAAOC,UAAsB,EAAE;QAC7B,MAAMC,QAAAA,GAAW,gCAAA,IAAI,EAAC,cAAA,YAAA,CAAA,CAAaC,GAAG,CAACF,UAAAA,CAAWG,IAAI,CAAA;AACtD,QAAA,IAAIF,aAAaG,SAAAA,EAAW;AAC1B,YAAA,MAAM,IAAIC,KAAAA,CACR,CAAC,MAAM,EAAE,IAAI,CAACC,UAAU,CAAC,YAAY,EAAEN,UAAAA,CAAWG,IAAI,CAAC,8CAA8C,CAAC,CAAA;AAE1G,QAAA;QAEA,IAAIH,UAAAA,CAAWO,WAAW,KAAK,IAAA,EAAM;YACnC,IACEP,UAAAA,CAAWQ,IAAI,KAAKJ,SAAAA,IACpBJ,UAAAA,CAAWQ,IAAI,CAACC,QAAQ,CAACC,MAAM,KAAK,CAAA,IACpCV,WAAWQ,IAAI,CAACC,QAAQ,CAACE,IAAI,CAAC,CAACC,CAAAA,GAAMA,CAAAA,CAAEC,MAAM,KAAK,EAAA,CAAA,EAClD;AACA,gBAAA,MAAM,IAAIR,KAAAA,CACR,CAAC,MAAM,EAAE,IAAI,CAACC,UAAU,CAAC,YAAY,EAAEN,UAAAA,CAAWG,IAAI,CAAC,+CAA+C,CAAC,CAAA;AAE3G,YAAA;AACF,QAAA;QAEA,+BAAA,CAAA,IAAI,EAAC,YAAA,CAAA,CAAA,YAAA,CAAA,CAAaW,GAAG,CAACd,UAAAA,CAAWG,IAAI,EAAEH,UAAAA,CAAAA;AACzC,IAAA;AAEAE,IAAAA,GAAAA,CAAIC,IAAY,EAA0B;AACxC,QAAA,OAAO,gCAAA,IAAI,EAAC,YAAA,CAAA,CAAA,YAAA,CAAA,CAAaD,GAAG,CAACC,IAAAA,CAAAA;AAC/B,IAAA;AAEAY,IAAAA,MAAAA,CAAOZ,IAAY,EAAW;AAC5B,QAAA,OAAO,gCAAA,IAAI,EAAC,YAAA,CAAA,CAAA,YAAA,CAAA,CAAaY,MAAM,CAACZ,IAAAA,CAAAA;AAClC,IAAA;IAEAa,MAAAA,GAAuB;QACrB,OAAOC,KAAAA,CAAMC,IAAI,CAAC,+BAAA,CAAA,IAAI,EAAC,YAAA,CAAA,CAAA,cAAaC,MAAM,EAAA,CAAA;AAC5C,IAAA;AAEAC,IAAAA,OAAAA,CAAQC,QAA0C,EAAE;AAClD,QAAA,+BAAA,CAAA,IAAI,EAAC,YAAA,CAAA,CAAA,YAAA,CAAA,CAAaD,OAAO,CAACC,QAAAA,CAAAA;AAC5B,IAAA;AA7CA,IAAA,WAAA,CAAYf,UAA0B,CAAE;QAFxC,MAAA,CAAA,cAAA,CAAA,IAAA,EAAA,YAAA,EAAA;;mBAAA;;AAAA,QAAA,+BAAA,CAAA,IAAA,EAAA,YAAA,CAAA,CAAA,gBAAe,IAAIgB,GAAAA,EAAAA;QAGjB,IAAI,CAAChB,UAAU,GAAGA,UAAAA;AACpB,IAAA;AA4CF;;;;"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
function _class_private_field_loose_base(receiver, privateKey) {
|
|
2
|
+
if (!Object.prototype.hasOwnProperty.call(receiver, privateKey)) {
|
|
3
|
+
throw new TypeError("attempted to use private field on non-instance");
|
|
4
|
+
}
|
|
5
|
+
return receiver;
|
|
6
|
+
}
|
|
7
|
+
var id = 0;
|
|
8
|
+
function _class_private_field_loose_key(name) {
|
|
9
|
+
return "__private_" + id++ + "_" + name;
|
|
10
|
+
}
|
|
11
|
+
var _definitions = /*#__PURE__*/ _class_private_field_loose_key("_definitions");
|
|
12
|
+
class McpCapabilityDefinitionRegistry {
|
|
13
|
+
get size() {
|
|
14
|
+
return _class_private_field_loose_base(this, _definitions)[_definitions].size;
|
|
15
|
+
}
|
|
16
|
+
define(definition) {
|
|
17
|
+
const existing = _class_private_field_loose_base(this, _definitions)[_definitions].get(definition.name);
|
|
18
|
+
if (existing !== undefined) {
|
|
19
|
+
throw new Error(`[MCP] ${this.capability} with name "${definition.name}" is already registered. Names must be unique.`);
|
|
20
|
+
}
|
|
21
|
+
if (definition.devModeOnly !== true) {
|
|
22
|
+
if (definition.auth === undefined || definition.auth.policies.length === 0 || definition.auth.policies.some((p)=>p.action === '')) {
|
|
23
|
+
throw new Error(`[MCP] ${this.capability} with name "${definition.name}" must declare auth policies or be devModeOnly.`);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
_class_private_field_loose_base(this, _definitions)[_definitions].set(definition.name, definition);
|
|
27
|
+
}
|
|
28
|
+
get(name) {
|
|
29
|
+
return _class_private_field_loose_base(this, _definitions)[_definitions].get(name);
|
|
30
|
+
}
|
|
31
|
+
delete(name) {
|
|
32
|
+
return _class_private_field_loose_base(this, _definitions)[_definitions].delete(name);
|
|
33
|
+
}
|
|
34
|
+
getAll() {
|
|
35
|
+
return Array.from(_class_private_field_loose_base(this, _definitions)[_definitions].values());
|
|
36
|
+
}
|
|
37
|
+
forEach(callback) {
|
|
38
|
+
_class_private_field_loose_base(this, _definitions)[_definitions].forEach(callback);
|
|
39
|
+
}
|
|
40
|
+
constructor(capability){
|
|
41
|
+
Object.defineProperty(this, _definitions, {
|
|
42
|
+
writable: true,
|
|
43
|
+
value: void 0
|
|
44
|
+
});
|
|
45
|
+
_class_private_field_loose_base(this, _definitions)[_definitions] = new Map();
|
|
46
|
+
this.capability = capability;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
export { McpCapabilityDefinitionRegistry };
|
|
51
|
+
//# sourceMappingURL=McpCapabilityDefinitionRegistry.mjs.map
|