@payloadcms/plugin-mcp 4.0.0-internal.38b7f1d → 4.0.0-internal.c2b57ce
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/bin.js +39 -0
- package/dist/collection/getAccessField.d.ts +12 -0
- package/dist/collection/getAccessField.d.ts.map +1 -0
- package/dist/collection/getAccessField.js +57 -0
- package/dist/collection/getAccessField.js.map +1 -0
- package/dist/collection/index.d.ts +6 -0
- package/dist/collection/index.d.ts.map +1 -0
- package/dist/collection/index.js +59 -0
- package/dist/collection/index.js.map +1 -0
- package/dist/components/AccessField/index.client.d.ts +10 -0
- package/dist/components/AccessField/index.client.d.ts.map +1 -0
- package/dist/components/AccessField/index.client.js +305 -0
- package/dist/components/AccessField/index.client.js.map +1 -0
- package/dist/components/AccessField/index.css +93 -0
- package/dist/defineTool.d.ts +26 -0
- package/dist/defineTool.d.ts.map +1 -0
- package/dist/defineTool.js +37 -0
- package/dist/defineTool.js.map +1 -0
- package/dist/endpoint/access.d.ts +10 -0
- package/dist/endpoint/access.d.ts.map +1 -0
- package/dist/endpoint/access.js +106 -0
- package/dist/endpoint/access.js.map +1 -0
- package/dist/endpoint/index.d.ts +3 -0
- package/dist/endpoint/index.d.ts.map +1 -0
- package/dist/endpoint/index.js +36 -0
- package/dist/endpoint/index.js.map +1 -0
- package/dist/exports/client.d.ts +2 -0
- package/dist/exports/client.d.ts.map +1 -0
- package/dist/exports/client.js +4 -0
- package/dist/exports/client.js.map +1 -0
- package/dist/index.d.ts +4 -7
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +44 -67
- package/dist/index.js.map +1 -1
- package/dist/mcp/buildMcpServer.d.ts +19 -0
- package/dist/mcp/buildMcpServer.d.ts.map +1 -0
- package/dist/mcp/buildMcpServer.js +163 -0
- package/dist/mcp/buildMcpServer.js.map +1 -0
- package/dist/mcp/builtin/collections/authTools.d.ts +7 -0
- package/dist/mcp/builtin/collections/authTools.d.ts.map +1 -0
- package/dist/mcp/builtin/collections/authTools.js +250 -0
- package/dist/mcp/builtin/collections/authTools.js.map +1 -0
- package/dist/mcp/builtin/collections/createTool.d.ts +2 -0
- package/dist/mcp/builtin/collections/createTool.d.ts.map +1 -0
- package/dist/mcp/builtin/collections/createTool.js +87 -0
- package/dist/mcp/builtin/collections/createTool.js.map +1 -0
- package/dist/mcp/builtin/collections/deleteTool.d.ts +2 -0
- package/dist/mcp/builtin/collections/deleteTool.d.ts.map +1 -0
- package/dist/mcp/builtin/collections/deleteTool.js +117 -0
- package/dist/mcp/builtin/collections/deleteTool.js.map +1 -0
- package/dist/mcp/builtin/collections/findTool.d.ts +2 -0
- package/dist/mcp/builtin/collections/findTool.d.ts.map +1 -0
- package/dist/mcp/builtin/collections/findTool.js +159 -0
- package/dist/mcp/builtin/collections/findTool.js.map +1 -0
- package/dist/mcp/builtin/collections/updateTool.d.ts +2 -0
- package/dist/mcp/builtin/collections/updateTool.d.ts.map +1 -0
- package/dist/mcp/builtin/collections/updateTool.js +187 -0
- package/dist/mcp/builtin/collections/updateTool.js.map +1 -0
- package/dist/mcp/builtin/globals/findTool.d.ts +2 -0
- package/dist/mcp/builtin/globals/findTool.d.ts.map +1 -0
- package/dist/mcp/builtin/globals/findTool.js +76 -0
- package/dist/mcp/builtin/globals/findTool.js.map +1 -0
- package/dist/mcp/builtin/globals/updateTool.d.ts +2 -0
- package/dist/mcp/builtin/globals/updateTool.d.ts.map +1 -0
- package/dist/mcp/builtin/globals/updateTool.js +92 -0
- package/dist/mcp/builtin/globals/updateTool.js.map +1 -0
- package/dist/mcp/builtinTools.d.ts +37 -0
- package/dist/mcp/builtinTools.d.ts.map +1 -0
- package/dist/mcp/builtinTools.js +64 -0
- package/dist/mcp/builtinTools.js.map +1 -0
- package/dist/mcp/sanitizeMCPConfig.d.ts +17 -0
- package/dist/mcp/sanitizeMCPConfig.d.ts.map +1 -0
- package/dist/mcp/sanitizeMCPConfig.js +167 -0
- package/dist/mcp/sanitizeMCPConfig.js.map +1 -0
- package/dist/stdio.d.ts +8 -0
- package/dist/stdio.d.ts.map +1 -0
- package/dist/stdio.js +89 -0
- package/dist/stdio.js.map +1 -0
- package/dist/types.d.ts +262 -455
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js +6 -1
- package/dist/types.js.map +1 -1
- package/dist/utils/camelCase.d.ts.map +1 -1
- package/dist/utils/getLogger.d.ts +10 -0
- package/dist/utils/getLogger.d.ts.map +1 -0
- package/dist/utils/getLogger.js +22 -0
- package/dist/utils/getLogger.js.map +1 -0
- package/dist/utils/getPluginConfig.d.ts +12 -0
- package/dist/utils/getPluginConfig.d.ts.map +1 -0
- package/dist/utils/getPluginConfig.js +15 -0
- package/dist/utils/getPluginConfig.js.map +1 -0
- package/dist/utils/localAPIDefaults.d.ts +20 -0
- package/dist/utils/localAPIDefaults.d.ts.map +1 -0
- package/dist/utils/localAPIDefaults.js +19 -0
- package/dist/utils/localAPIDefaults.js.map +1 -0
- package/dist/utils/resolveProjectRoot.d.ts +7 -0
- package/dist/utils/resolveProjectRoot.d.ts.map +1 -0
- package/dist/utils/resolveProjectRoot.js +15 -0
- package/dist/utils/resolveProjectRoot.js.map +1 -0
- package/dist/utils/schemaConversion/prepareCollectionSchema.d.ts +7 -0
- package/dist/utils/schemaConversion/prepareCollectionSchema.d.ts.map +1 -0
- package/dist/utils/schemaConversion/prepareCollectionSchema.js +37 -0
- package/dist/utils/schemaConversion/prepareCollectionSchema.js.map +1 -0
- package/dist/utils/schemaConversion/removeVirtualFieldsFromSchema.d.ts +2 -2
- package/dist/utils/schemaConversion/removeVirtualFieldsFromSchema.d.ts.map +1 -1
- package/dist/utils/schemaConversion/removeVirtualFieldsFromSchema.js.map +1 -1
- package/dist/utils/schemaConversion/sanitizeJsonSchema.d.ts +2 -2
- package/dist/utils/schemaConversion/sanitizeJsonSchema.d.ts.map +1 -1
- package/dist/utils/schemaConversion/sanitizeJsonSchema.js.map +1 -1
- package/dist/utils/schemaConversion/simplifyRelationshipFields.d.ts +2 -2
- package/dist/utils/schemaConversion/simplifyRelationshipFields.d.ts.map +1 -1
- package/dist/utils/schemaConversion/simplifyRelationshipFields.js +7 -4
- package/dist/utils/schemaConversion/simplifyRelationshipFields.js.map +1 -1
- package/dist/utils/schemaConversion/transformPointFields.d.ts +2 -2
- package/dist/utils/schemaConversion/transformPointFields.d.ts.map +1 -1
- package/dist/utils/schemaConversion/transformPointFields.js +7 -1
- package/dist/utils/schemaConversion/transformPointFields.js.map +1 -1
- package/dist/utils/toStandardSchema.d.ts +5 -0
- package/dist/utils/toStandardSchema.d.ts.map +1 -0
- package/dist/utils/toStandardSchema.js +4 -0
- package/dist/utils/toStandardSchema.js.map +1 -0
- package/package.json +35 -10
- package/src/collection/getAccessField.ts +64 -0
- package/src/collection/index.ts +63 -0
- package/src/components/AccessField/index.client.tsx +344 -0
- package/src/components/AccessField/index.css +93 -0
- package/src/defineTool.ts +44 -0
- package/src/endpoint/access.ts +132 -0
- package/src/endpoint/index.ts +35 -0
- package/src/exports/client.ts +2 -0
- package/src/index.ts +35 -85
- package/src/mcp/buildMcpServer.ts +224 -0
- package/src/mcp/builtin/collections/authTools.ts +233 -0
- package/src/mcp/builtin/collections/createTool.ts +116 -0
- package/src/mcp/builtin/collections/deleteTool.ts +123 -0
- package/src/mcp/builtin/collections/findTool.ts +187 -0
- package/src/mcp/builtin/collections/updateTool.ts +205 -0
- package/src/mcp/builtin/globals/findTool.ts +96 -0
- package/src/mcp/builtin/globals/updateTool.ts +118 -0
- package/src/mcp/builtinTools.ts +84 -0
- package/src/mcp/sanitizeMCPConfig.ts +239 -0
- package/src/stdio.ts +98 -0
- package/src/types.ts +295 -490
- package/src/utils/getLogger.ts +22 -0
- package/src/utils/getPluginConfig.ts +24 -0
- package/src/utils/localAPIDefaults.ts +22 -0
- package/src/utils/resolveProjectRoot.ts +17 -0
- package/src/utils/schemaConversion/prepareCollectionSchema.ts +39 -0
- package/src/utils/schemaConversion/removeVirtualFieldsFromSchema.ts +3 -3
- package/src/utils/schemaConversion/sanitizeJsonSchema.ts +4 -4
- package/src/utils/schemaConversion/simplifyRelationshipFields.ts +11 -6
- package/src/utils/schemaConversion/transformPointFields.ts +6 -5
- package/src/utils/toStandardSchema.ts +9 -0
- package/dist/collections/createApiKeysCollection.d.ts +0 -7
- package/dist/collections/createApiKeysCollection.d.ts.map +0 -1
- package/dist/collections/createApiKeysCollection.js +0 -317
- package/dist/collections/createApiKeysCollection.js.map +0 -1
- package/dist/defaults.d.ts +0 -4
- package/dist/defaults.d.ts.map +0 -1
- package/dist/defaults.js +0 -5
- package/dist/defaults.js.map +0 -1
- package/dist/endpoints/mcp.d.ts +0 -4
- package/dist/endpoints/mcp.d.ts.map +0 -1
- package/dist/endpoints/mcp.js +0 -71
- package/dist/endpoints/mcp.js.map +0 -1
- package/dist/mcp/createRequest.d.ts +0 -3
- package/dist/mcp/createRequest.d.ts.map +0 -1
- package/dist/mcp/createRequest.js +0 -14
- package/dist/mcp/createRequest.js.map +0 -1
- package/dist/mcp/getMcpHandler.d.ts +0 -4
- package/dist/mcp/getMcpHandler.d.ts.map +0 -1
- package/dist/mcp/getMcpHandler.js +0 -231
- package/dist/mcp/getMcpHandler.js.map +0 -1
- package/dist/mcp/helpers/config.d.ts +0 -22
- package/dist/mcp/helpers/config.d.ts.map +0 -1
- package/dist/mcp/helpers/config.js +0 -153
- package/dist/mcp/helpers/config.js.map +0 -1
- package/dist/mcp/helpers/fields.d.ts +0 -19
- package/dist/mcp/helpers/fields.d.ts.map +0 -1
- package/dist/mcp/helpers/fields.js +0 -102
- package/dist/mcp/helpers/fields.js.map +0 -1
- package/dist/mcp/helpers/fileValidation.d.ts +0 -67
- package/dist/mcp/helpers/fileValidation.d.ts.map +0 -1
- package/dist/mcp/helpers/fileValidation.js +0 -267
- package/dist/mcp/helpers/fileValidation.js.map +0 -1
- package/dist/mcp/registerTool.d.ts +0 -6
- package/dist/mcp/registerTool.d.ts.map +0 -1
- package/dist/mcp/registerTool.js +0 -18
- package/dist/mcp/registerTool.js.map +0 -1
- package/dist/mcp/tools/auth/auth.d.ts +0 -4
- package/dist/mcp/tools/auth/auth.d.ts.map +0 -1
- package/dist/mcp/tools/auth/auth.js +0 -57
- package/dist/mcp/tools/auth/auth.js.map +0 -1
- package/dist/mcp/tools/auth/forgotPassword.d.ts +0 -4
- package/dist/mcp/tools/auth/forgotPassword.d.ts.map +0 -1
- package/dist/mcp/tools/auth/forgotPassword.js +0 -48
- package/dist/mcp/tools/auth/forgotPassword.js.map +0 -1
- package/dist/mcp/tools/auth/login.d.ts +0 -4
- package/dist/mcp/tools/auth/login.d.ts.map +0 -1
- package/dist/mcp/tools/auth/login.js +0 -51
- package/dist/mcp/tools/auth/login.js.map +0 -1
- package/dist/mcp/tools/auth/resetPassword.d.ts +0 -4
- package/dist/mcp/tools/auth/resetPassword.d.ts.map +0 -1
- package/dist/mcp/tools/auth/resetPassword.js +0 -49
- package/dist/mcp/tools/auth/resetPassword.js.map +0 -1
- package/dist/mcp/tools/auth/unlock.d.ts +0 -4
- package/dist/mcp/tools/auth/unlock.d.ts.map +0 -1
- package/dist/mcp/tools/auth/unlock.js +0 -48
- package/dist/mcp/tools/auth/unlock.js.map +0 -1
- package/dist/mcp/tools/auth/verify.d.ts +0 -4
- package/dist/mcp/tools/auth/verify.d.ts.map +0 -1
- package/dist/mcp/tools/auth/verify.js +0 -45
- package/dist/mcp/tools/auth/verify.js.map +0 -1
- package/dist/mcp/tools/collection/create.d.ts +0 -10
- package/dist/mcp/tools/collection/create.d.ts.map +0 -1
- package/dist/mcp/tools/collection/create.js +0 -139
- package/dist/mcp/tools/collection/create.js.map +0 -1
- package/dist/mcp/tools/collection/delete.d.ts +0 -10
- package/dist/mcp/tools/collection/delete.d.ts.map +0 -1
- package/dist/mcp/tools/collection/delete.js +0 -154
- package/dist/mcp/tools/collection/delete.js.map +0 -1
- package/dist/mcp/tools/collection/find.d.ts +0 -10
- package/dist/mcp/tools/collection/find.d.ts.map +0 -1
- package/dist/mcp/tools/collection/find.js +0 -165
- package/dist/mcp/tools/collection/find.js.map +0 -1
- package/dist/mcp/tools/collection/update.d.ts +0 -10
- package/dist/mcp/tools/collection/update.d.ts.map +0 -1
- package/dist/mcp/tools/collection/update.js +0 -209
- package/dist/mcp/tools/collection/update.js.map +0 -1
- package/dist/mcp/tools/config/find.d.ts +0 -10
- package/dist/mcp/tools/config/find.d.ts.map +0 -1
- package/dist/mcp/tools/config/find.js +0 -97
- package/dist/mcp/tools/config/find.js.map +0 -1
- package/dist/mcp/tools/config/update.d.ts +0 -10
- package/dist/mcp/tools/config/update.d.ts.map +0 -1
- package/dist/mcp/tools/config/update.js +0 -215
- package/dist/mcp/tools/config/update.js.map +0 -1
- package/dist/mcp/tools/global/find.d.ts +0 -5
- package/dist/mcp/tools/global/find.d.ts.map +0 -1
- package/dist/mcp/tools/global/find.js +0 -82
- package/dist/mcp/tools/global/find.js.map +0 -1
- package/dist/mcp/tools/global/update.d.ts +0 -6
- package/dist/mcp/tools/global/update.d.ts.map +0 -1
- package/dist/mcp/tools/global/update.js +0 -124
- package/dist/mcp/tools/global/update.js.map +0 -1
- package/dist/mcp/tools/job/create.d.ts +0 -10
- package/dist/mcp/tools/job/create.d.ts.map +0 -1
- package/dist/mcp/tools/job/create.js +0 -293
- package/dist/mcp/tools/job/create.js.map +0 -1
- package/dist/mcp/tools/job/run.d.ts +0 -10
- package/dist/mcp/tools/job/run.d.ts.map +0 -1
- package/dist/mcp/tools/job/run.js +0 -129
- package/dist/mcp/tools/job/run.js.map +0 -1
- package/dist/mcp/tools/job/update.d.ts +0 -11
- package/dist/mcp/tools/job/update.d.ts.map +0 -1
- package/dist/mcp/tools/job/update.js +0 -186
- package/dist/mcp/tools/job/update.js.map +0 -1
- package/dist/mcp/tools/resource/create.d.ts +0 -6
- package/dist/mcp/tools/resource/create.d.ts.map +0 -1
- package/dist/mcp/tools/resource/create.js +0 -124
- package/dist/mcp/tools/resource/create.js.map +0 -1
- package/dist/mcp/tools/resource/delete.d.ts +0 -5
- package/dist/mcp/tools/resource/delete.d.ts.map +0 -1
- package/dist/mcp/tools/resource/delete.js +0 -151
- package/dist/mcp/tools/resource/delete.js.map +0 -1
- package/dist/mcp/tools/resource/find.d.ts +0 -5
- package/dist/mcp/tools/resource/find.d.ts.map +0 -1
- package/dist/mcp/tools/resource/find.js +0 -170
- package/dist/mcp/tools/resource/find.js.map +0 -1
- package/dist/mcp/tools/resource/update.d.ts +0 -6
- package/dist/mcp/tools/resource/update.d.ts.map +0 -1
- package/dist/mcp/tools/resource/update.js +0 -256
- package/dist/mcp/tools/resource/update.js.map +0 -1
- package/dist/mcp/tools/schemas.d.ts +0 -457
- package/dist/mcp/tools/schemas.d.ts.map +0 -1
- package/dist/mcp/tools/schemas.js +0 -243
- package/dist/mcp/tools/schemas.js.map +0 -1
- package/dist/utils/adminEntitySettings.d.ts +0 -17
- package/dist/utils/adminEntitySettings.d.ts.map +0 -1
- package/dist/utils/adminEntitySettings.js +0 -41
- package/dist/utils/adminEntitySettings.js.map +0 -1
- package/dist/utils/createApiKeyFields.d.ts +0 -15
- package/dist/utils/createApiKeyFields.d.ts.map +0 -1
- package/dist/utils/createApiKeyFields.js +0 -57
- package/dist/utils/createApiKeyFields.js.map +0 -1
- package/dist/utils/getEnabledSlugs.d.ts +0 -13
- package/dist/utils/getEnabledSlugs.d.ts.map +0 -1
- package/dist/utils/getEnabledSlugs.js +0 -32
- package/dist/utils/getEnabledSlugs.js.map +0 -1
- package/dist/utils/schemaConversion/convertCollectionSchemaToZod.d.ts +0 -3
- package/dist/utils/schemaConversion/convertCollectionSchemaToZod.d.ts.map +0 -1
- package/dist/utils/schemaConversion/convertCollectionSchemaToZod.js +0 -43
- package/dist/utils/schemaConversion/convertCollectionSchemaToZod.js.map +0 -1
- package/src/collections/createApiKeysCollection.ts +0 -373
- package/src/defaults.ts +0 -3
- package/src/endpoints/mcp.ts +0 -91
- package/src/mcp/createRequest.ts +0 -13
- package/src/mcp/getMcpHandler.ts +0 -545
- package/src/mcp/helpers/config.ts +0 -213
- package/src/mcp/helpers/fields.ts +0 -154
- package/src/mcp/helpers/fileValidation.ts +0 -362
- package/src/mcp/registerTool.ts +0 -22
- package/src/mcp/tools/auth/auth.ts +0 -71
- package/src/mcp/tools/auth/forgotPassword.ts +0 -70
- package/src/mcp/tools/auth/login.ts +0 -72
- package/src/mcp/tools/auth/resetPassword.ts +0 -61
- package/src/mcp/tools/auth/unlock.ts +0 -64
- package/src/mcp/tools/auth/verify.ts +0 -57
- package/src/mcp/tools/collection/create.ts +0 -210
- package/src/mcp/tools/collection/delete.ts +0 -211
- package/src/mcp/tools/collection/find.ts +0 -224
- package/src/mcp/tools/collection/update.ts +0 -290
- package/src/mcp/tools/config/find.ts +0 -128
- package/src/mcp/tools/config/update.ts +0 -280
- package/src/mcp/tools/global/find.ts +0 -128
- package/src/mcp/tools/global/update.ts +0 -207
- package/src/mcp/tools/job/create.ts +0 -416
- package/src/mcp/tools/job/run.ts +0 -167
- package/src/mcp/tools/job/update.ts +0 -274
- package/src/mcp/tools/resource/create.ts +0 -211
- package/src/mcp/tools/resource/delete.ts +0 -218
- package/src/mcp/tools/resource/find.ts +0 -246
- package/src/mcp/tools/resource/update.ts +0 -383
- package/src/mcp/tools/schemas.ts +0 -520
- package/src/utils/adminEntitySettings.ts +0 -40
- package/src/utils/createApiKeyFields.ts +0 -72
- package/src/utils/getEnabledSlugs.ts +0 -42
- package/src/utils/schemaConversion/convertCollectionSchemaToZod.ts +0 -52
package/dist/defaults.js
DELETED
package/dist/defaults.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/defaults.ts"],"sourcesContent":["export const defaults = {\n userCollection: 'users',\n}\n"],"names":["defaults","userCollection"],"mappings":"AAAA,OAAO,MAAMA,WAAW;IACtBC,gBAAgB;AAClB,EAAC"}
|
package/dist/endpoints/mcp.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"mcp.d.ts","sourceRoot":"","sources":["../../src/endpoints/mcp.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,cAAc,EAAiD,MAAM,SAAS,CAAA;AAE5F,OAAO,KAAK,EAAqB,eAAe,EAAE,MAAM,aAAa,CAAA;AAKrE,eAAO,MAAM,oBAAoB,kBAAmB,eAAe,mBAkFlE,CAAA"}
|
package/dist/endpoints/mcp.js
DELETED
|
@@ -1,71 +0,0 @@
|
|
|
1
|
-
import crypto from 'crypto';
|
|
2
|
-
import { UnauthorizedError } from 'payload';
|
|
3
|
-
import { createRequestFromPayloadRequest } from '../mcp/createRequest.js';
|
|
4
|
-
import { getMCPHandler } from '../mcp/getMcpHandler.js';
|
|
5
|
-
export const initializeMCPHandler = (pluginOptions)=>{
|
|
6
|
-
const mcpHandler = async (req)=>{
|
|
7
|
-
const { payload } = req;
|
|
8
|
-
const MCPOptions = pluginOptions.mcp || {};
|
|
9
|
-
const MCPHandlerOptions = MCPOptions.handlerOptions || {};
|
|
10
|
-
const useVerboseLogs = MCPHandlerOptions.verboseLogs ?? false;
|
|
11
|
-
req.payloadAPI = 'MCP';
|
|
12
|
-
const getDefaultMcpAccessSettings = async (overrideApiKey)=>{
|
|
13
|
-
const apiKey = overrideApiKey ?? req.headers.get('Authorization')?.startsWith('Bearer ') ? req.headers.get('Authorization')?.replace('Bearer ', '').trim() : null;
|
|
14
|
-
if (apiKey === null) {
|
|
15
|
-
throw new UnauthorizedError();
|
|
16
|
-
}
|
|
17
|
-
const sha256APIKeyIndex = crypto.createHmac('sha256', payload.secret).update(apiKey || '').digest('hex');
|
|
18
|
-
const where = {
|
|
19
|
-
apiKeyIndex: {
|
|
20
|
-
equals: sha256APIKeyIndex
|
|
21
|
-
}
|
|
22
|
-
};
|
|
23
|
-
const { docs } = await payload.find({
|
|
24
|
-
collection: 'payload-mcp-api-keys',
|
|
25
|
-
depth: 1,
|
|
26
|
-
limit: 1,
|
|
27
|
-
pagination: false,
|
|
28
|
-
where
|
|
29
|
-
});
|
|
30
|
-
if (docs.length === 0) {
|
|
31
|
-
throw new UnauthorizedError();
|
|
32
|
-
}
|
|
33
|
-
if (useVerboseLogs) {
|
|
34
|
-
payload.logger.info('[payload-mcp] API Key is valid');
|
|
35
|
-
}
|
|
36
|
-
const user = docs[0]?.user;
|
|
37
|
-
user.collection = pluginOptions.userCollection;
|
|
38
|
-
user._strategy = 'mcp-api-key';
|
|
39
|
-
return docs[0];
|
|
40
|
-
};
|
|
41
|
-
const mcpAccessSettings = pluginOptions.overrideAuth ? await pluginOptions.overrideAuth(req, getDefaultMcpAccessSettings) : await getDefaultMcpAccessSettings();
|
|
42
|
-
// @modelcontextprotocol/sdk's StreamableHTTPServerTransport uses @hono/node-server's
|
|
43
|
-
// getRequestListener, which replaces global.Request and global.Response with Hono
|
|
44
|
-
// custom classes. Unfortunately, we cannot pass overrideGlobalObjects: false because the option is
|
|
45
|
-
// consumed inside the SDK transport and is not exposed to callers.
|
|
46
|
-
// Save originals here and restore after the handler resolves so that Next.js
|
|
47
|
-
// instanceof Response checks on subsequent route handlers keep working.
|
|
48
|
-
const globals = globalThis;
|
|
49
|
-
const originalResponse = globals['Response'];
|
|
50
|
-
const originalRequest = globals['Request'];
|
|
51
|
-
const handler = getMCPHandler(pluginOptions, mcpAccessSettings, req);
|
|
52
|
-
const request = createRequestFromPayloadRequest(req);
|
|
53
|
-
try {
|
|
54
|
-
return await handler(request);
|
|
55
|
-
} finally{
|
|
56
|
-
if (globals['Response'] !== originalResponse) {
|
|
57
|
-
Object.defineProperty(globalThis, 'Response', {
|
|
58
|
-
value: originalResponse
|
|
59
|
-
});
|
|
60
|
-
}
|
|
61
|
-
if (globals['Request'] !== originalRequest) {
|
|
62
|
-
Object.defineProperty(globalThis, 'Request', {
|
|
63
|
-
value: originalRequest
|
|
64
|
-
});
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
};
|
|
68
|
-
return mcpHandler;
|
|
69
|
-
};
|
|
70
|
-
|
|
71
|
-
//# sourceMappingURL=mcp.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/endpoints/mcp.ts"],"sourcesContent":["import crypto from 'crypto'\nimport { type PayloadHandler, type TypedUser, UnauthorizedError, type Where } from 'payload'\n\nimport type { MCPAccessSettings, MCPPluginConfig } from '../types.js'\n\nimport { createRequestFromPayloadRequest } from '../mcp/createRequest.js'\nimport { getMCPHandler } from '../mcp/getMcpHandler.js'\n\nexport const initializeMCPHandler = (pluginOptions: MCPPluginConfig) => {\n const mcpHandler: PayloadHandler = async (req) => {\n const { payload } = req\n const MCPOptions = pluginOptions.mcp || {}\n const MCPHandlerOptions = MCPOptions.handlerOptions || {}\n const useVerboseLogs = MCPHandlerOptions.verboseLogs ?? false\n\n req.payloadAPI = 'MCP' as const\n\n const getDefaultMcpAccessSettings = async (overrideApiKey?: null | string) => {\n const apiKey =\n (overrideApiKey ?? req.headers.get('Authorization')?.startsWith('Bearer '))\n ? req.headers.get('Authorization')?.replace('Bearer ', '').trim()\n : null\n\n if (apiKey === null) {\n throw new UnauthorizedError()\n }\n\n const sha256APIKeyIndex = crypto\n .createHmac('sha256', payload.secret)\n .update(apiKey || '')\n .digest('hex')\n\n const where: Where = {\n apiKeyIndex: {\n equals: sha256APIKeyIndex,\n },\n }\n\n const { docs } = await payload.find({\n collection: 'payload-mcp-api-keys',\n depth: 1,\n limit: 1,\n pagination: false,\n where,\n })\n\n if (docs.length === 0) {\n throw new UnauthorizedError()\n }\n\n if (useVerboseLogs) {\n payload.logger.info('[payload-mcp] API Key is valid')\n }\n\n const user = docs[0]?.user as TypedUser\n user.collection = pluginOptions.userCollection as string\n user._strategy = 'mcp-api-key' as const\n\n return docs[0] as unknown as MCPAccessSettings\n }\n\n const mcpAccessSettings = pluginOptions.overrideAuth\n ? await pluginOptions.overrideAuth(req, getDefaultMcpAccessSettings)\n : await getDefaultMcpAccessSettings()\n\n // @modelcontextprotocol/sdk's StreamableHTTPServerTransport uses @hono/node-server's\n // getRequestListener, which replaces global.Request and global.Response with Hono\n // custom classes. Unfortunately, we cannot pass overrideGlobalObjects: false because the option is\n // consumed inside the SDK transport and is not exposed to callers.\n // Save originals here and restore after the handler resolves so that Next.js\n // instanceof Response checks on subsequent route handlers keep working.\n const globals = globalThis as Record<string, unknown>\n const originalResponse = globals['Response']\n const originalRequest = globals['Request']\n\n const handler = getMCPHandler(pluginOptions, mcpAccessSettings, req)\n const request = createRequestFromPayloadRequest(req)\n\n try {\n return await handler(request)\n } finally {\n if (globals['Response'] !== originalResponse) {\n Object.defineProperty(globalThis, 'Response', { value: originalResponse })\n }\n if (globals['Request'] !== originalRequest) {\n Object.defineProperty(globalThis, 'Request', { value: originalRequest })\n }\n }\n }\n return mcpHandler\n}\n"],"names":["crypto","UnauthorizedError","createRequestFromPayloadRequest","getMCPHandler","initializeMCPHandler","pluginOptions","mcpHandler","req","payload","MCPOptions","mcp","MCPHandlerOptions","handlerOptions","useVerboseLogs","verboseLogs","payloadAPI","getDefaultMcpAccessSettings","overrideApiKey","apiKey","headers","get","startsWith","replace","trim","sha256APIKeyIndex","createHmac","secret","update","digest","where","apiKeyIndex","equals","docs","find","collection","depth","limit","pagination","length","logger","info","user","userCollection","_strategy","mcpAccessSettings","overrideAuth","globals","globalThis","originalResponse","originalRequest","handler","request","Object","defineProperty","value"],"mappings":"AAAA,OAAOA,YAAY,SAAQ;AAC3B,SAA8CC,iBAAiB,QAAoB,UAAS;AAI5F,SAASC,+BAA+B,QAAQ,0BAAyB;AACzE,SAASC,aAAa,QAAQ,0BAAyB;AAEvD,OAAO,MAAMC,uBAAuB,CAACC;IACnC,MAAMC,aAA6B,OAAOC;QACxC,MAAM,EAAEC,OAAO,EAAE,GAAGD;QACpB,MAAME,aAAaJ,cAAcK,GAAG,IAAI,CAAC;QACzC,MAAMC,oBAAoBF,WAAWG,cAAc,IAAI,CAAC;QACxD,MAAMC,iBAAiBF,kBAAkBG,WAAW,IAAI;QAExDP,IAAIQ,UAAU,GAAG;QAEjB,MAAMC,8BAA8B,OAAOC;YACzC,MAAMC,SACJ,AAACD,kBAAkBV,IAAIY,OAAO,CAACC,GAAG,CAAC,kBAAkBC,WAAW,aAC5Dd,IAAIY,OAAO,CAACC,GAAG,CAAC,kBAAkBE,QAAQ,WAAW,IAAIC,SACzD;YAEN,IAAIL,WAAW,MAAM;gBACnB,MAAM,IAAIjB;YACZ;YAEA,MAAMuB,oBAAoBxB,OACvByB,UAAU,CAAC,UAAUjB,QAAQkB,MAAM,EACnCC,MAAM,CAACT,UAAU,IACjBU,MAAM,CAAC;YAEV,MAAMC,QAAe;gBACnBC,aAAa;oBACXC,QAAQP;gBACV;YACF;YAEA,MAAM,EAAEQ,IAAI,EAAE,GAAG,MAAMxB,QAAQyB,IAAI,CAAC;gBAClCC,YAAY;gBACZC,OAAO;gBACPC,OAAO;gBACPC,YAAY;gBACZR;YACF;YAEA,IAAIG,KAAKM,MAAM,KAAK,GAAG;gBACrB,MAAM,IAAIrC;YACZ;YAEA,IAAIY,gBAAgB;gBAClBL,QAAQ+B,MAAM,CAACC,IAAI,CAAC;YACtB;YAEA,MAAMC,OAAOT,IAAI,CAAC,EAAE,EAAES;YACtBA,KAAKP,UAAU,GAAG7B,cAAcqC,cAAc;YAC9CD,KAAKE,SAAS,GAAG;YAEjB,OAAOX,IAAI,CAAC,EAAE;QAChB;QAEA,MAAMY,oBAAoBvC,cAAcwC,YAAY,GAChD,MAAMxC,cAAcwC,YAAY,CAACtC,KAAKS,+BACtC,MAAMA;QAEV,qFAAqF;QACrF,kFAAkF;QAClF,mGAAmG;QACnG,mEAAmE;QACnE,6EAA6E;QAC7E,wEAAwE;QACxE,MAAM8B,UAAUC;QAChB,MAAMC,mBAAmBF,OAAO,CAAC,WAAW;QAC5C,MAAMG,kBAAkBH,OAAO,CAAC,UAAU;QAE1C,MAAMI,UAAU/C,cAAcE,eAAeuC,mBAAmBrC;QAChE,MAAM4C,UAAUjD,gCAAgCK;QAEhD,IAAI;YACF,OAAO,MAAM2C,QAAQC;QACvB,SAAU;YACR,IAAIL,OAAO,CAAC,WAAW,KAAKE,kBAAkB;gBAC5CI,OAAOC,cAAc,CAACN,YAAY,YAAY;oBAAEO,OAAON;gBAAiB;YAC1E;YACA,IAAIF,OAAO,CAAC,UAAU,KAAKG,iBAAiB;gBAC1CG,OAAOC,cAAc,CAACN,YAAY,WAAW;oBAAEO,OAAOL;gBAAgB;YACxE;QACF;IACF;IACA,OAAO3C;AACT,EAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"createRequest.d.ts","sourceRoot":"","sources":["../../src/mcp/createRequest.ts"],"names":[],"mappings":"AAAA,OAAO,EAAuB,KAAK,cAAc,EAAE,MAAM,SAAS,CAAA;AAElE,eAAO,MAAM,+BAA+B,QAAS,cAAc,YAUlE,CAAA"}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { AuthenticationError } from 'payload';
|
|
2
|
-
export const createRequestFromPayloadRequest = (req)=>{
|
|
3
|
-
if (!req.url) {
|
|
4
|
-
throw new AuthenticationError();
|
|
5
|
-
}
|
|
6
|
-
return new Request(req.url, {
|
|
7
|
-
body: req.body,
|
|
8
|
-
duplex: 'half',
|
|
9
|
-
headers: req.headers,
|
|
10
|
-
method: req.method
|
|
11
|
-
});
|
|
12
|
-
};
|
|
13
|
-
|
|
14
|
-
//# sourceMappingURL=createRequest.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/mcp/createRequest.ts"],"sourcesContent":["import { AuthenticationError, type PayloadRequest } from 'payload'\n\nexport const createRequestFromPayloadRequest = (req: PayloadRequest) => {\n if (!req.url) {\n throw new AuthenticationError()\n }\n return new Request(req.url, {\n body: req.body,\n duplex: 'half',\n headers: req.headers,\n method: req.method,\n } as { duplex: 'half' } & RequestInit)\n}\n"],"names":["AuthenticationError","createRequestFromPayloadRequest","req","url","Request","body","duplex","headers","method"],"mappings":"AAAA,SAASA,mBAAmB,QAA6B,UAAS;AAElE,OAAO,MAAMC,kCAAkC,CAACC;IAC9C,IAAI,CAACA,IAAIC,GAAG,EAAE;QACZ,MAAM,IAAIH;IACZ;IACA,OAAO,IAAII,QAAQF,IAAIC,GAAG,EAAE;QAC1BE,MAAMH,IAAIG,IAAI;QACdC,QAAQ;QACRC,SAASL,IAAIK,OAAO;QACpBC,QAAQN,IAAIM,MAAM;IACpB;AACF,EAAC"}
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import { type PayloadRequest } from 'payload';
|
|
2
|
-
import type { MCPAccessSettings, MCPPluginConfig } from '../types.js';
|
|
3
|
-
export declare const getMCPHandler: (pluginOptions: MCPPluginConfig, mcpAccessSettings: MCPAccessSettings, req: PayloadRequest) => (request: Request) => Promise<Response>;
|
|
4
|
-
//# sourceMappingURL=getMcpHandler.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"getMcpHandler.d.ts","sourceRoot":"","sources":["../../src/mcp/getMcpHandler.ts"],"names":[],"mappings":"AAIA,OAAO,EAAgC,KAAK,cAAc,EAAkB,MAAM,SAAS,CAAA;AAE3F,OAAO,KAAK,EAAE,iBAAiB,EAAE,eAAe,EAAE,MAAM,aAAa,CAAA;AAuCrE,eAAO,MAAM,aAAa,kBACT,eAAe,qBACX,iBAAiB,OAC/B,cAAc,4CAgfpB,CAAA"}
|
|
@@ -1,231 +0,0 @@
|
|
|
1
|
-
import { createMcpHandler } from 'mcp-handler';
|
|
2
|
-
import { join } from 'path';
|
|
3
|
-
import { APIError, configToJSONSchema } from 'payload';
|
|
4
|
-
import { toCamelCase } from '../utils/camelCase.js';
|
|
5
|
-
import { getEnabledSlugs } from '../utils/getEnabledSlugs.js';
|
|
6
|
-
import { getCollectionVirtualFieldNames, getGlobalVirtualFieldNames } from '../utils/getVirtualFieldNames.js';
|
|
7
|
-
import { removeVirtualFieldsFromSchema } from '../utils/schemaConversion/removeVirtualFieldsFromSchema.js';
|
|
8
|
-
import { registerTool } from './registerTool.js';
|
|
9
|
-
// Tools
|
|
10
|
-
import { findGlobalTool } from './tools/global/find.js';
|
|
11
|
-
import { updateGlobalTool } from './tools/global/update.js';
|
|
12
|
-
import { createResourceTool } from './tools/resource/create.js';
|
|
13
|
-
import { deleteResourceTool } from './tools/resource/delete.js';
|
|
14
|
-
import { findResourceTool } from './tools/resource/find.js';
|
|
15
|
-
import { updateResourceTool } from './tools/resource/update.js';
|
|
16
|
-
// Experimental Tools
|
|
17
|
-
/**
|
|
18
|
-
* @experimental This tools are experimental and may change or be removed in the future.
|
|
19
|
-
*/ import { authTool } from './tools/auth/auth.js';
|
|
20
|
-
import { forgotPasswordTool } from './tools/auth/forgotPassword.js';
|
|
21
|
-
import { loginTool } from './tools/auth/login.js';
|
|
22
|
-
import { resetPasswordTool } from './tools/auth/resetPassword.js';
|
|
23
|
-
import { unlockTool } from './tools/auth/unlock.js';
|
|
24
|
-
import { verifyTool } from './tools/auth/verify.js';
|
|
25
|
-
import { createCollectionTool } from './tools/collection/create.js';
|
|
26
|
-
import { deleteCollectionTool } from './tools/collection/delete.js';
|
|
27
|
-
import { findCollectionTool } from './tools/collection/find.js';
|
|
28
|
-
import { updateCollectionTool } from './tools/collection/update.js';
|
|
29
|
-
import { findConfigTool } from './tools/config/find.js';
|
|
30
|
-
import { updateConfigTool } from './tools/config/update.js';
|
|
31
|
-
import { createJobTool } from './tools/job/create.js';
|
|
32
|
-
import { runJobTool } from './tools/job/run.js';
|
|
33
|
-
import { updateJobTool } from './tools/job/update.js';
|
|
34
|
-
export const getMCPHandler = (pluginOptions, mcpAccessSettings, req)=>{
|
|
35
|
-
const { payload } = req;
|
|
36
|
-
const configSchema = configToJSONSchema(payload.config, payload.db.defaultIDType, req.i18n, {
|
|
37
|
-
forceInlineBlocks: true
|
|
38
|
-
});
|
|
39
|
-
// Handler wrapper that injects req before the _extra argument
|
|
40
|
-
const wrapHandler = (handler)=>{
|
|
41
|
-
return async (...args)=>{
|
|
42
|
-
const _extra = args[args.length - 1];
|
|
43
|
-
const handlerArgs = args.slice(0, -1);
|
|
44
|
-
return await handler(...handlerArgs, req, _extra);
|
|
45
|
-
};
|
|
46
|
-
};
|
|
47
|
-
const payloadToolHandler = (handler)=>wrapHandler(handler);
|
|
48
|
-
const payloadPromptHandler = (handler)=>wrapHandler(handler);
|
|
49
|
-
const payloadResourceHandler = (handler)=>wrapHandler(handler);
|
|
50
|
-
// User
|
|
51
|
-
const user = mcpAccessSettings.user;
|
|
52
|
-
// MCP Server and Handler Options
|
|
53
|
-
const MCPOptions = pluginOptions.mcp || {};
|
|
54
|
-
const customMCPTools = MCPOptions.tools || [];
|
|
55
|
-
const customMCPPrompts = MCPOptions.prompts || [];
|
|
56
|
-
const customMCPResources = MCPOptions.resources || [];
|
|
57
|
-
const MCPHandlerOptions = MCPOptions.handlerOptions || {};
|
|
58
|
-
const serverOptions = MCPOptions.serverOptions || {};
|
|
59
|
-
const useVerboseLogs = MCPHandlerOptions.verboseLogs ?? false;
|
|
60
|
-
// Experimental MCP Tool Requirements
|
|
61
|
-
const isDevelopment = process.env.NODE_ENV === 'development';
|
|
62
|
-
const experimentalTools = pluginOptions?.experimental?.tools || {};
|
|
63
|
-
const collectionsPluginConfig = pluginOptions.collections || {};
|
|
64
|
-
const globalsPluginConfig = pluginOptions.globals || {};
|
|
65
|
-
const collectionsDirPath = experimentalTools && experimentalTools.collections?.collectionsDirPath ? experimentalTools.collections.collectionsDirPath : join(process.cwd(), 'src/collections');
|
|
66
|
-
const configFilePath = experimentalTools && experimentalTools.config?.configFilePath ? experimentalTools.config.configFilePath : join(process.cwd(), 'src/payload.config.ts');
|
|
67
|
-
const jobsDirPath = experimentalTools && experimentalTools.jobs?.jobsDirPath ? experimentalTools.jobs.jobsDirPath : join(process.cwd(), 'src/jobs');
|
|
68
|
-
try {
|
|
69
|
-
return createMcpHandler((server)=>{
|
|
70
|
-
// Get enabled collections
|
|
71
|
-
const enabledCollectionSlugs = getEnabledSlugs(collectionsPluginConfig, 'collection');
|
|
72
|
-
// Collection Operation Tools
|
|
73
|
-
enabledCollectionSlugs.forEach((enabledCollectionSlug)=>{
|
|
74
|
-
try {
|
|
75
|
-
const rawSchema = configSchema.definitions?.[enabledCollectionSlug];
|
|
76
|
-
const virtualFieldNames = getCollectionVirtualFieldNames(payload.config, enabledCollectionSlug);
|
|
77
|
-
const schema = removeVirtualFieldsFromSchema(JSON.parse(JSON.stringify(rawSchema)), virtualFieldNames);
|
|
78
|
-
const toolCapabilities = mcpAccessSettings?.[`${toCamelCase(enabledCollectionSlug)}`];
|
|
79
|
-
const allowCreate = toolCapabilities?.create;
|
|
80
|
-
const allowUpdate = toolCapabilities?.update;
|
|
81
|
-
const allowFind = toolCapabilities?.find;
|
|
82
|
-
const allowDelete = toolCapabilities?.delete;
|
|
83
|
-
if (allowCreate) {
|
|
84
|
-
registerTool(allowCreate, `Create ${enabledCollectionSlug}`, ()=>createResourceTool(server, req, user, useVerboseLogs, enabledCollectionSlug, collectionsPluginConfig, schema), payload, useVerboseLogs);
|
|
85
|
-
}
|
|
86
|
-
if (allowUpdate) {
|
|
87
|
-
registerTool(allowUpdate, `Update ${enabledCollectionSlug}`, ()=>updateResourceTool(server, req, user, useVerboseLogs, enabledCollectionSlug, collectionsPluginConfig, schema), payload, useVerboseLogs);
|
|
88
|
-
}
|
|
89
|
-
if (allowFind) {
|
|
90
|
-
registerTool(allowFind, `Find ${enabledCollectionSlug}`, ()=>findResourceTool(server, req, user, useVerboseLogs, enabledCollectionSlug, collectionsPluginConfig), payload, useVerboseLogs);
|
|
91
|
-
}
|
|
92
|
-
if (allowDelete) {
|
|
93
|
-
registerTool(allowDelete, `Delete ${enabledCollectionSlug}`, ()=>deleteResourceTool(server, req, user, useVerboseLogs, enabledCollectionSlug, collectionsPluginConfig), payload, useVerboseLogs);
|
|
94
|
-
}
|
|
95
|
-
} catch (error) {
|
|
96
|
-
throw new APIError(`Error registering tools for collection ${enabledCollectionSlug}: ${String(error)}`, 500);
|
|
97
|
-
}
|
|
98
|
-
});
|
|
99
|
-
// Global Operation Tools
|
|
100
|
-
const enabledGlobalSlugs = getEnabledSlugs(globalsPluginConfig, 'global');
|
|
101
|
-
enabledGlobalSlugs.forEach((enabledGlobalSlug)=>{
|
|
102
|
-
try {
|
|
103
|
-
const rawSchema = configSchema.definitions?.[enabledGlobalSlug];
|
|
104
|
-
const virtualFieldNames = getGlobalVirtualFieldNames(payload.config, enabledGlobalSlug);
|
|
105
|
-
const schema = removeVirtualFieldsFromSchema(JSON.parse(JSON.stringify(rawSchema)), virtualFieldNames);
|
|
106
|
-
const toolCapabilities = mcpAccessSettings?.[`${toCamelCase(enabledGlobalSlug)}`];
|
|
107
|
-
const allowFind = toolCapabilities?.['find'];
|
|
108
|
-
const allowUpdate = toolCapabilities?.['update'];
|
|
109
|
-
if (allowFind) {
|
|
110
|
-
registerTool(allowFind, `Find ${enabledGlobalSlug}`, ()=>findGlobalTool(server, req, user, useVerboseLogs, enabledGlobalSlug, globalsPluginConfig), payload, useVerboseLogs);
|
|
111
|
-
}
|
|
112
|
-
if (allowUpdate) {
|
|
113
|
-
registerTool(allowUpdate, `Update ${enabledGlobalSlug}`, ()=>updateGlobalTool(server, req, user, useVerboseLogs, enabledGlobalSlug, globalsPluginConfig, schema), payload, useVerboseLogs);
|
|
114
|
-
}
|
|
115
|
-
} catch (error) {
|
|
116
|
-
throw new APIError(`Error registering tools for global ${enabledGlobalSlug}: ${String(error)}`, 500);
|
|
117
|
-
}
|
|
118
|
-
});
|
|
119
|
-
// Custom tools
|
|
120
|
-
customMCPTools.forEach((tool)=>{
|
|
121
|
-
const camelCasedToolName = toCamelCase(tool.name);
|
|
122
|
-
const isToolEnabled = mcpAccessSettings['payload-mcp-tool']?.[camelCasedToolName] ?? false;
|
|
123
|
-
registerTool(isToolEnabled, tool.name, ()=>server.registerTool(tool.name, {
|
|
124
|
-
description: tool.description,
|
|
125
|
-
inputSchema: tool.parameters
|
|
126
|
-
}, payloadToolHandler(tool.handler)), payload, useVerboseLogs);
|
|
127
|
-
});
|
|
128
|
-
// Custom prompts
|
|
129
|
-
customMCPPrompts.forEach((prompt)=>{
|
|
130
|
-
const camelCasedPromptName = toCamelCase(prompt.name);
|
|
131
|
-
const isPromptEnabled = mcpAccessSettings['payload-mcp-prompt']?.[camelCasedPromptName] ?? false;
|
|
132
|
-
if (isPromptEnabled) {
|
|
133
|
-
server.registerPrompt(prompt.name, {
|
|
134
|
-
argsSchema: prompt.argsSchema,
|
|
135
|
-
description: prompt.description,
|
|
136
|
-
title: prompt.title
|
|
137
|
-
}, payloadPromptHandler(prompt.handler));
|
|
138
|
-
if (useVerboseLogs) {
|
|
139
|
-
payload.logger.info(`[payload-mcp] ✅ Prompt: ${prompt.title} Registered.`);
|
|
140
|
-
}
|
|
141
|
-
} else if (useVerboseLogs) {
|
|
142
|
-
payload.logger.info(`[payload-mcp] ⏭️ Prompt: ${prompt.title} Skipped.`);
|
|
143
|
-
}
|
|
144
|
-
});
|
|
145
|
-
// Custom resources
|
|
146
|
-
customMCPResources.forEach((resource)=>{
|
|
147
|
-
const camelCasedResourceName = toCamelCase(resource.name);
|
|
148
|
-
const isResourceEnabled = mcpAccessSettings['payload-mcp-resource']?.[camelCasedResourceName] ?? false;
|
|
149
|
-
if (isResourceEnabled) {
|
|
150
|
-
server.registerResource(resource.name, // @ts-expect-error - Overload type is not working however -- ResourceTemplate OR String is a valid type
|
|
151
|
-
resource.uri, {
|
|
152
|
-
description: resource.description,
|
|
153
|
-
mimeType: resource.mimeType,
|
|
154
|
-
title: resource.title
|
|
155
|
-
}, payloadResourceHandler(resource.handler));
|
|
156
|
-
if (useVerboseLogs) {
|
|
157
|
-
payload.logger.info(`[payload-mcp] ✅ Resource: ${resource.title} Registered.`);
|
|
158
|
-
}
|
|
159
|
-
} else if (useVerboseLogs) {
|
|
160
|
-
payload.logger.info(`[payload-mcp] ⏭️ Resource: ${resource.title} Skipped.`);
|
|
161
|
-
}
|
|
162
|
-
});
|
|
163
|
-
// Experimental - Collection Schema Modfication Tools
|
|
164
|
-
if (mcpAccessSettings.collections?.create && experimentalTools.collections?.enabled && isDevelopment) {
|
|
165
|
-
registerTool(mcpAccessSettings.collections.create, 'Create Collection', ()=>createCollectionTool(server, req, useVerboseLogs, collectionsDirPath, configFilePath), payload, useVerboseLogs);
|
|
166
|
-
}
|
|
167
|
-
if (mcpAccessSettings.collections?.delete && experimentalTools.collections?.enabled && isDevelopment) {
|
|
168
|
-
registerTool(mcpAccessSettings.collections.delete, 'Delete Collection', ()=>deleteCollectionTool(server, req, useVerboseLogs, collectionsDirPath, configFilePath), payload, useVerboseLogs);
|
|
169
|
-
}
|
|
170
|
-
if (mcpAccessSettings.collections?.find && experimentalTools.collections?.enabled && isDevelopment) {
|
|
171
|
-
registerTool(mcpAccessSettings.collections.find, 'Find Collection', ()=>findCollectionTool(server, req, useVerboseLogs, collectionsDirPath), payload, useVerboseLogs);
|
|
172
|
-
}
|
|
173
|
-
if (mcpAccessSettings.collections?.update && experimentalTools.collections?.enabled && isDevelopment) {
|
|
174
|
-
registerTool(mcpAccessSettings.collections.update, 'Update Collection', ()=>updateCollectionTool(server, req, useVerboseLogs, collectionsDirPath, configFilePath), payload, useVerboseLogs);
|
|
175
|
-
}
|
|
176
|
-
// Experimental - Payload Config Modification Tools
|
|
177
|
-
if (mcpAccessSettings.config?.find && experimentalTools.config?.enabled && isDevelopment) {
|
|
178
|
-
registerTool(mcpAccessSettings.config.find, 'Find Config', ()=>findConfigTool(server, req, useVerboseLogs, configFilePath), payload, useVerboseLogs);
|
|
179
|
-
}
|
|
180
|
-
if (mcpAccessSettings.config?.update && experimentalTools.config?.enabled && isDevelopment) {
|
|
181
|
-
registerTool(mcpAccessSettings.config.update, 'Update Config', ()=>updateConfigTool(server, req, useVerboseLogs, configFilePath), payload, useVerboseLogs);
|
|
182
|
-
}
|
|
183
|
-
// Experimental - Job Modification Tools
|
|
184
|
-
if (mcpAccessSettings.jobs?.create && experimentalTools.jobs?.enabled && isDevelopment) {
|
|
185
|
-
registerTool(mcpAccessSettings.jobs.create, 'Create Job', ()=>createJobTool(server, req, useVerboseLogs, jobsDirPath), payload, useVerboseLogs);
|
|
186
|
-
}
|
|
187
|
-
if (mcpAccessSettings.jobs?.update && experimentalTools.jobs?.enabled && isDevelopment) {
|
|
188
|
-
registerTool(mcpAccessSettings.jobs.update, 'Update Job', ()=>updateJobTool(server, req, useVerboseLogs, jobsDirPath), payload, useVerboseLogs);
|
|
189
|
-
}
|
|
190
|
-
if (mcpAccessSettings.jobs?.run && experimentalTools.jobs?.enabled && isDevelopment) {
|
|
191
|
-
registerTool(mcpAccessSettings.jobs.run, 'Run Job', ()=>runJobTool(server, req, useVerboseLogs), payload, useVerboseLogs);
|
|
192
|
-
}
|
|
193
|
-
// Experimental - Auth Modification Tools
|
|
194
|
-
if (mcpAccessSettings.auth?.auth && experimentalTools.auth?.enabled && isDevelopment) {
|
|
195
|
-
registerTool(mcpAccessSettings.auth.auth, 'Auth', ()=>authTool(server, req, useVerboseLogs), payload, useVerboseLogs);
|
|
196
|
-
}
|
|
197
|
-
if (mcpAccessSettings.auth?.login && experimentalTools.auth?.enabled && isDevelopment) {
|
|
198
|
-
registerTool(mcpAccessSettings.auth.login, 'Login', ()=>loginTool(server, req, useVerboseLogs), payload, useVerboseLogs);
|
|
199
|
-
}
|
|
200
|
-
if (mcpAccessSettings.auth?.verify && experimentalTools.auth?.enabled && isDevelopment) {
|
|
201
|
-
registerTool(mcpAccessSettings.auth.verify, 'Verify', ()=>verifyTool(server, req, useVerboseLogs), payload, useVerboseLogs);
|
|
202
|
-
}
|
|
203
|
-
if (mcpAccessSettings.auth?.resetPassword && experimentalTools.auth?.enabled) {
|
|
204
|
-
registerTool(mcpAccessSettings.auth.resetPassword, 'Reset Password', ()=>resetPasswordTool(server, req, useVerboseLogs), payload, useVerboseLogs);
|
|
205
|
-
}
|
|
206
|
-
if (mcpAccessSettings.auth?.forgotPassword && experimentalTools.auth?.enabled) {
|
|
207
|
-
registerTool(mcpAccessSettings.auth.forgotPassword, 'Forgot Password', ()=>forgotPasswordTool(server, req, useVerboseLogs), payload, useVerboseLogs);
|
|
208
|
-
}
|
|
209
|
-
if (mcpAccessSettings.auth?.unlock && experimentalTools.auth?.enabled) {
|
|
210
|
-
registerTool(mcpAccessSettings.auth.unlock, 'Unlock', ()=>unlockTool(server, req, useVerboseLogs), payload, useVerboseLogs);
|
|
211
|
-
}
|
|
212
|
-
if (useVerboseLogs) {
|
|
213
|
-
payload.logger.info('[payload-mcp] 🚀 MCP Server Ready.');
|
|
214
|
-
}
|
|
215
|
-
}, {
|
|
216
|
-
instructions: serverOptions.instructions,
|
|
217
|
-
serverInfo: serverOptions.serverInfo
|
|
218
|
-
}, {
|
|
219
|
-
basePath: MCPHandlerOptions.basePath || payload.config.routes?.api || '/api',
|
|
220
|
-
disableSse: MCPHandlerOptions.disableSse ?? true,
|
|
221
|
-
maxDuration: MCPHandlerOptions.maxDuration || 60,
|
|
222
|
-
onEvent: MCPHandlerOptions.onEvent,
|
|
223
|
-
redisUrl: MCPHandlerOptions.redisUrl,
|
|
224
|
-
verboseLogs: useVerboseLogs
|
|
225
|
-
});
|
|
226
|
-
} catch (error) {
|
|
227
|
-
throw new APIError(`Error initializing MCP handler: ${String(error)}`, 500);
|
|
228
|
-
}
|
|
229
|
-
};
|
|
230
|
-
|
|
231
|
-
//# sourceMappingURL=getMcpHandler.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/mcp/getMcpHandler.ts"],"sourcesContent":["import type { JSONSchema4 } from 'json-schema'\n\nimport { createMcpHandler } from 'mcp-handler'\nimport { join } from 'path'\nimport { APIError, configToJSONSchema, type PayloadRequest, type TypedUser } from 'payload'\n\nimport type { MCPAccessSettings, MCPPluginConfig } from '../types.js'\n\nimport { toCamelCase } from '../utils/camelCase.js'\nimport { getEnabledSlugs } from '../utils/getEnabledSlugs.js'\nimport {\n getCollectionVirtualFieldNames,\n getGlobalVirtualFieldNames,\n} from '../utils/getVirtualFieldNames.js'\nimport { removeVirtualFieldsFromSchema } from '../utils/schemaConversion/removeVirtualFieldsFromSchema.js'\nimport { registerTool } from './registerTool.js'\n\n// Tools\nimport { findGlobalTool } from './tools/global/find.js'\nimport { updateGlobalTool } from './tools/global/update.js'\nimport { createResourceTool } from './tools/resource/create.js'\nimport { deleteResourceTool } from './tools/resource/delete.js'\nimport { findResourceTool } from './tools/resource/find.js'\nimport { updateResourceTool } from './tools/resource/update.js'\n\n// Experimental Tools\n/**\n * @experimental This tools are experimental and may change or be removed in the future.\n */\nimport { authTool } from './tools/auth/auth.js'\nimport { forgotPasswordTool } from './tools/auth/forgotPassword.js'\nimport { loginTool } from './tools/auth/login.js'\nimport { resetPasswordTool } from './tools/auth/resetPassword.js'\nimport { unlockTool } from './tools/auth/unlock.js'\nimport { verifyTool } from './tools/auth/verify.js'\nimport { createCollectionTool } from './tools/collection/create.js'\nimport { deleteCollectionTool } from './tools/collection/delete.js'\nimport { findCollectionTool } from './tools/collection/find.js'\nimport { updateCollectionTool } from './tools/collection/update.js'\nimport { findConfigTool } from './tools/config/find.js'\nimport { updateConfigTool } from './tools/config/update.js'\nimport { createJobTool } from './tools/job/create.js'\nimport { runJobTool } from './tools/job/run.js'\nimport { updateJobTool } from './tools/job/update.js'\n\nexport const getMCPHandler = (\n pluginOptions: MCPPluginConfig,\n mcpAccessSettings: MCPAccessSettings,\n req: PayloadRequest,\n) => {\n const { payload } = req\n const configSchema = configToJSONSchema(payload.config, payload.db.defaultIDType, req.i18n, {\n forceInlineBlocks: true,\n })\n\n // Handler wrapper that injects req before the _extra argument\n const wrapHandler = (handler: (...args: any[]) => any) => {\n return async (...args: any[]) => {\n const _extra = args[args.length - 1]\n const handlerArgs = args.slice(0, -1)\n return await handler(...handlerArgs, req, _extra)\n }\n }\n\n const payloadToolHandler = (\n handler: NonNullable<NonNullable<MCPPluginConfig['mcp']>['tools']>[number]['handler'],\n ) => wrapHandler(handler)\n\n const payloadPromptHandler = (\n handler: NonNullable<NonNullable<MCPPluginConfig['mcp']>['prompts']>[number]['handler'],\n ) => wrapHandler(handler)\n\n const payloadResourceHandler = (\n handler: NonNullable<NonNullable<MCPPluginConfig['mcp']>['resources']>[number]['handler'],\n ) => wrapHandler(handler)\n\n // User\n const user = mcpAccessSettings.user\n\n // MCP Server and Handler Options\n const MCPOptions = pluginOptions.mcp || {}\n const customMCPTools = MCPOptions.tools || []\n const customMCPPrompts = MCPOptions.prompts || []\n const customMCPResources = MCPOptions.resources || []\n const MCPHandlerOptions = MCPOptions.handlerOptions || {}\n const serverOptions = MCPOptions.serverOptions || {}\n const useVerboseLogs = MCPHandlerOptions.verboseLogs ?? false\n\n // Experimental MCP Tool Requirements\n const isDevelopment = process.env.NODE_ENV === 'development'\n const experimentalTools: NonNullable<MCPPluginConfig['experimental']>['tools'] =\n pluginOptions?.experimental?.tools || {}\n const collectionsPluginConfig = pluginOptions.collections || {}\n const globalsPluginConfig = pluginOptions.globals || {}\n const collectionsDirPath =\n experimentalTools && experimentalTools.collections?.collectionsDirPath\n ? experimentalTools.collections.collectionsDirPath\n : join(process.cwd(), 'src/collections')\n const configFilePath =\n experimentalTools && experimentalTools.config?.configFilePath\n ? experimentalTools.config.configFilePath\n : join(process.cwd(), 'src/payload.config.ts')\n const jobsDirPath =\n experimentalTools && experimentalTools.jobs?.jobsDirPath\n ? experimentalTools.jobs.jobsDirPath\n : join(process.cwd(), 'src/jobs')\n\n try {\n return createMcpHandler(\n (server) => {\n // Get enabled collections\n const enabledCollectionSlugs = getEnabledSlugs(collectionsPluginConfig, 'collection')\n\n // Collection Operation Tools\n enabledCollectionSlugs.forEach((enabledCollectionSlug) => {\n try {\n const rawSchema = configSchema.definitions?.[enabledCollectionSlug] as JSONSchema4\n\n const virtualFieldNames = getCollectionVirtualFieldNames(\n payload.config,\n enabledCollectionSlug,\n )\n const schema = removeVirtualFieldsFromSchema(\n JSON.parse(JSON.stringify(rawSchema)) as JSONSchema4,\n virtualFieldNames,\n )\n\n const toolCapabilities = mcpAccessSettings?.[\n `${toCamelCase(enabledCollectionSlug)}`\n ] as Record<string, unknown>\n const allowCreate: boolean | undefined = toolCapabilities?.create as boolean\n const allowUpdate: boolean | undefined = toolCapabilities?.update as boolean\n const allowFind: boolean | undefined = toolCapabilities?.find as boolean\n const allowDelete: boolean | undefined = toolCapabilities?.delete as boolean\n\n if (allowCreate) {\n registerTool(\n allowCreate,\n `Create ${enabledCollectionSlug}`,\n () =>\n createResourceTool(\n server,\n req,\n user,\n useVerboseLogs,\n enabledCollectionSlug,\n collectionsPluginConfig,\n schema,\n ),\n payload,\n useVerboseLogs,\n )\n }\n if (allowUpdate) {\n registerTool(\n allowUpdate,\n `Update ${enabledCollectionSlug}`,\n () =>\n updateResourceTool(\n server,\n req,\n user,\n useVerboseLogs,\n enabledCollectionSlug,\n collectionsPluginConfig,\n schema,\n ),\n payload,\n useVerboseLogs,\n )\n }\n if (allowFind) {\n registerTool(\n allowFind,\n `Find ${enabledCollectionSlug}`,\n () =>\n findResourceTool(\n server,\n req,\n user,\n useVerboseLogs,\n enabledCollectionSlug,\n collectionsPluginConfig,\n ),\n payload,\n useVerboseLogs,\n )\n }\n if (allowDelete) {\n registerTool(\n allowDelete,\n `Delete ${enabledCollectionSlug}`,\n () =>\n deleteResourceTool(\n server,\n req,\n user,\n useVerboseLogs,\n enabledCollectionSlug,\n collectionsPluginConfig,\n ),\n payload,\n useVerboseLogs,\n )\n }\n } catch (error) {\n throw new APIError(\n `Error registering tools for collection ${enabledCollectionSlug}: ${String(error)}`,\n 500,\n )\n }\n })\n\n // Global Operation Tools\n const enabledGlobalSlugs = getEnabledSlugs(globalsPluginConfig, 'global')\n\n enabledGlobalSlugs.forEach((enabledGlobalSlug) => {\n try {\n const rawSchema = configSchema.definitions?.[enabledGlobalSlug] as JSONSchema4\n\n const virtualFieldNames = getGlobalVirtualFieldNames(payload.config, enabledGlobalSlug)\n const schema = removeVirtualFieldsFromSchema(\n JSON.parse(JSON.stringify(rawSchema)) as JSONSchema4,\n virtualFieldNames,\n )\n\n const toolCapabilities = mcpAccessSettings?.[\n `${toCamelCase(enabledGlobalSlug)}`\n ] as Record<string, unknown>\n const allowFind: boolean | undefined = toolCapabilities?.['find'] as boolean\n const allowUpdate: boolean | undefined = toolCapabilities?.['update'] as boolean\n\n if (allowFind) {\n registerTool(\n allowFind,\n `Find ${enabledGlobalSlug}`,\n () =>\n findGlobalTool(\n server,\n req,\n user,\n useVerboseLogs,\n enabledGlobalSlug,\n globalsPluginConfig,\n ),\n payload,\n useVerboseLogs,\n )\n }\n if (allowUpdate) {\n registerTool(\n allowUpdate,\n `Update ${enabledGlobalSlug}`,\n () =>\n updateGlobalTool(\n server,\n req,\n user,\n useVerboseLogs,\n enabledGlobalSlug,\n globalsPluginConfig,\n schema,\n ),\n payload,\n useVerboseLogs,\n )\n }\n } catch (error) {\n throw new APIError(\n `Error registering tools for global ${enabledGlobalSlug}: ${String(error)}`,\n 500,\n )\n }\n })\n\n // Custom tools\n customMCPTools.forEach((tool) => {\n const camelCasedToolName = toCamelCase(tool.name)\n const isToolEnabled = mcpAccessSettings['payload-mcp-tool']?.[camelCasedToolName] ?? false\n\n registerTool(\n isToolEnabled,\n tool.name,\n () =>\n server.registerTool(\n tool.name,\n {\n description: tool.description,\n inputSchema: tool.parameters,\n },\n payloadToolHandler(tool.handler),\n ),\n payload,\n useVerboseLogs,\n )\n })\n\n // Custom prompts\n customMCPPrompts.forEach((prompt) => {\n const camelCasedPromptName = toCamelCase(prompt.name)\n const isPromptEnabled =\n mcpAccessSettings['payload-mcp-prompt']?.[camelCasedPromptName] ?? false\n\n if (isPromptEnabled) {\n server.registerPrompt(\n prompt.name,\n {\n argsSchema: prompt.argsSchema,\n description: prompt.description,\n title: prompt.title,\n },\n payloadPromptHandler(prompt.handler),\n )\n if (useVerboseLogs) {\n payload.logger.info(`[payload-mcp] ✅ Prompt: ${prompt.title} Registered.`)\n }\n } else if (useVerboseLogs) {\n payload.logger.info(`[payload-mcp] ⏭️ Prompt: ${prompt.title} Skipped.`)\n }\n })\n\n // Custom resources\n customMCPResources.forEach((resource) => {\n const camelCasedResourceName = toCamelCase(resource.name)\n const isResourceEnabled =\n mcpAccessSettings['payload-mcp-resource']?.[camelCasedResourceName] ?? false\n\n if (isResourceEnabled) {\n server.registerResource(\n resource.name,\n // @ts-expect-error - Overload type is not working however -- ResourceTemplate OR String is a valid type\n resource.uri,\n {\n description: resource.description,\n mimeType: resource.mimeType,\n title: resource.title,\n },\n payloadResourceHandler(resource.handler),\n )\n\n if (useVerboseLogs) {\n payload.logger.info(`[payload-mcp] ✅ Resource: ${resource.title} Registered.`)\n }\n } else if (useVerboseLogs) {\n payload.logger.info(`[payload-mcp] ⏭️ Resource: ${resource.title} Skipped.`)\n }\n })\n\n // Experimental - Collection Schema Modfication Tools\n if (\n mcpAccessSettings.collections?.create &&\n experimentalTools.collections?.enabled &&\n isDevelopment\n ) {\n registerTool(\n mcpAccessSettings.collections.create,\n 'Create Collection',\n () =>\n createCollectionTool(server, req, useVerboseLogs, collectionsDirPath, configFilePath),\n payload,\n useVerboseLogs,\n )\n }\n if (\n mcpAccessSettings.collections?.delete &&\n experimentalTools.collections?.enabled &&\n isDevelopment\n ) {\n registerTool(\n mcpAccessSettings.collections.delete,\n 'Delete Collection',\n () =>\n deleteCollectionTool(server, req, useVerboseLogs, collectionsDirPath, configFilePath),\n payload,\n useVerboseLogs,\n )\n }\n\n if (\n mcpAccessSettings.collections?.find &&\n experimentalTools.collections?.enabled &&\n isDevelopment\n ) {\n registerTool(\n mcpAccessSettings.collections.find,\n 'Find Collection',\n () => findCollectionTool(server, req, useVerboseLogs, collectionsDirPath),\n payload,\n useVerboseLogs,\n )\n }\n\n if (\n mcpAccessSettings.collections?.update &&\n experimentalTools.collections?.enabled &&\n isDevelopment\n ) {\n registerTool(\n mcpAccessSettings.collections.update,\n 'Update Collection',\n () =>\n updateCollectionTool(server, req, useVerboseLogs, collectionsDirPath, configFilePath),\n payload,\n useVerboseLogs,\n )\n }\n\n // Experimental - Payload Config Modification Tools\n if (mcpAccessSettings.config?.find && experimentalTools.config?.enabled && isDevelopment) {\n registerTool(\n mcpAccessSettings.config.find,\n 'Find Config',\n () => findConfigTool(server, req, useVerboseLogs, configFilePath),\n payload,\n useVerboseLogs,\n )\n }\n\n if (\n mcpAccessSettings.config?.update &&\n experimentalTools.config?.enabled &&\n isDevelopment\n ) {\n registerTool(\n mcpAccessSettings.config.update,\n 'Update Config',\n () => updateConfigTool(server, req, useVerboseLogs, configFilePath),\n payload,\n useVerboseLogs,\n )\n }\n\n // Experimental - Job Modification Tools\n if (mcpAccessSettings.jobs?.create && experimentalTools.jobs?.enabled && isDevelopment) {\n registerTool(\n mcpAccessSettings.jobs.create,\n 'Create Job',\n () => createJobTool(server, req, useVerboseLogs, jobsDirPath),\n payload,\n useVerboseLogs,\n )\n }\n\n if (mcpAccessSettings.jobs?.update && experimentalTools.jobs?.enabled && isDevelopment) {\n registerTool(\n mcpAccessSettings.jobs.update,\n 'Update Job',\n () => updateJobTool(server, req, useVerboseLogs, jobsDirPath),\n payload,\n useVerboseLogs,\n )\n }\n\n if (mcpAccessSettings.jobs?.run && experimentalTools.jobs?.enabled && isDevelopment) {\n registerTool(\n mcpAccessSettings.jobs.run,\n 'Run Job',\n () => runJobTool(server, req, useVerboseLogs),\n payload,\n useVerboseLogs,\n )\n }\n\n // Experimental - Auth Modification Tools\n if (mcpAccessSettings.auth?.auth && experimentalTools.auth?.enabled && isDevelopment) {\n registerTool(\n mcpAccessSettings.auth.auth,\n 'Auth',\n () => authTool(server, req, useVerboseLogs),\n payload,\n useVerboseLogs,\n )\n }\n\n if (mcpAccessSettings.auth?.login && experimentalTools.auth?.enabled && isDevelopment) {\n registerTool(\n mcpAccessSettings.auth.login,\n 'Login',\n () => loginTool(server, req, useVerboseLogs),\n payload,\n useVerboseLogs,\n )\n }\n\n if (mcpAccessSettings.auth?.verify && experimentalTools.auth?.enabled && isDevelopment) {\n registerTool(\n mcpAccessSettings.auth.verify,\n 'Verify',\n () => verifyTool(server, req, useVerboseLogs),\n payload,\n useVerboseLogs,\n )\n }\n\n if (mcpAccessSettings.auth?.resetPassword && experimentalTools.auth?.enabled) {\n registerTool(\n mcpAccessSettings.auth.resetPassword,\n 'Reset Password',\n () => resetPasswordTool(server, req, useVerboseLogs),\n payload,\n useVerboseLogs,\n )\n }\n\n if (mcpAccessSettings.auth?.forgotPassword && experimentalTools.auth?.enabled) {\n registerTool(\n mcpAccessSettings.auth.forgotPassword,\n 'Forgot Password',\n () => forgotPasswordTool(server, req, useVerboseLogs),\n payload,\n useVerboseLogs,\n )\n }\n\n if (mcpAccessSettings.auth?.unlock && experimentalTools.auth?.enabled) {\n registerTool(\n mcpAccessSettings.auth.unlock,\n 'Unlock',\n () => unlockTool(server, req, useVerboseLogs),\n payload,\n useVerboseLogs,\n )\n }\n\n if (useVerboseLogs) {\n payload.logger.info('[payload-mcp] 🚀 MCP Server Ready.')\n }\n },\n {\n instructions: serverOptions.instructions,\n serverInfo: serverOptions.serverInfo,\n },\n {\n basePath: MCPHandlerOptions.basePath || payload.config.routes?.api || '/api',\n disableSse: MCPHandlerOptions.disableSse ?? true,\n maxDuration: MCPHandlerOptions.maxDuration || 60,\n onEvent: MCPHandlerOptions.onEvent,\n redisUrl: MCPHandlerOptions.redisUrl,\n verboseLogs: useVerboseLogs,\n },\n )\n } catch (error) {\n throw new APIError(`Error initializing MCP handler: ${String(error)}`, 500)\n }\n}\n"],"names":["createMcpHandler","join","APIError","configToJSONSchema","toCamelCase","getEnabledSlugs","getCollectionVirtualFieldNames","getGlobalVirtualFieldNames","removeVirtualFieldsFromSchema","registerTool","findGlobalTool","updateGlobalTool","createResourceTool","deleteResourceTool","findResourceTool","updateResourceTool","authTool","forgotPasswordTool","loginTool","resetPasswordTool","unlockTool","verifyTool","createCollectionTool","deleteCollectionTool","findCollectionTool","updateCollectionTool","findConfigTool","updateConfigTool","createJobTool","runJobTool","updateJobTool","getMCPHandler","pluginOptions","mcpAccessSettings","req","payload","configSchema","config","db","defaultIDType","i18n","forceInlineBlocks","wrapHandler","handler","args","_extra","length","handlerArgs","slice","payloadToolHandler","payloadPromptHandler","payloadResourceHandler","user","MCPOptions","mcp","customMCPTools","tools","customMCPPrompts","prompts","customMCPResources","resources","MCPHandlerOptions","handlerOptions","serverOptions","useVerboseLogs","verboseLogs","isDevelopment","process","env","NODE_ENV","experimentalTools","experimental","collectionsPluginConfig","collections","globalsPluginConfig","globals","collectionsDirPath","cwd","configFilePath","jobsDirPath","jobs","server","enabledCollectionSlugs","forEach","enabledCollectionSlug","rawSchema","definitions","virtualFieldNames","schema","JSON","parse","stringify","toolCapabilities","allowCreate","create","allowUpdate","update","allowFind","find","allowDelete","delete","error","String","enabledGlobalSlugs","enabledGlobalSlug","tool","camelCasedToolName","name","isToolEnabled","description","inputSchema","parameters","prompt","camelCasedPromptName","isPromptEnabled","registerPrompt","argsSchema","title","logger","info","resource","camelCasedResourceName","isResourceEnabled","registerResource","uri","mimeType","enabled","run","auth","login","verify","resetPassword","forgotPassword","unlock","instructions","serverInfo","basePath","routes","api","disableSse","maxDuration","onEvent","redisUrl"],"mappings":"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"}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import type { AdminConfig, DatabaseConfig, PluginUpdates } from '../../types.js';
|
|
2
|
-
/**
|
|
3
|
-
* Adds a collection to the payload.config.ts file
|
|
4
|
-
*/
|
|
5
|
-
export declare function addCollectionToConfig(content: string, collectionName: string): string;
|
|
6
|
-
/**
|
|
7
|
-
* Removes a collection from the payload.config.ts file
|
|
8
|
-
*/
|
|
9
|
-
export declare function removeCollectionFromConfig(content: string, collectionName: string): string;
|
|
10
|
-
/**
|
|
11
|
-
* Updates admin configuration in payload.config.ts
|
|
12
|
-
*/
|
|
13
|
-
export declare function updateAdminConfig(content: string, adminConfig: AdminConfig): string;
|
|
14
|
-
/**
|
|
15
|
-
* Updates database configuration in payload.config.ts
|
|
16
|
-
*/
|
|
17
|
-
export declare function updateDatabaseConfig(content: string, databaseConfig: DatabaseConfig): string;
|
|
18
|
-
/**
|
|
19
|
-
* Updates plugins configuration in payload.config.ts
|
|
20
|
-
*/
|
|
21
|
-
export declare function updatePluginsConfig(content: string, pluginUpdates: PluginUpdates): string;
|
|
22
|
-
//# sourceMappingURL=config.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../../src/mcp/helpers/config.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAA;AAEhF;;GAEG;AACH,wBAAgB,qBAAqB,CAAC,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,GAAG,MAAM,CAwCrF;AAED;;GAEG;AACH,wBAAgB,0BAA0B,CAAC,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,GAAG,MAAM,CAgC1F;AAED;;GAEG;AACH,wBAAgB,iBAAiB,CAAC,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,WAAW,GAAG,MAAM,CAoDnF;AAED;;GAEG;AACH,wBAAgB,oBAAoB,CAAC,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,cAAc,GAAG,MAAM,CAkB5F;AAED;;GAEG;AACH,wBAAgB,mBAAmB,CAAC,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,aAAa,GAAG,MAAM,CA6CzF"}
|