@payloadcms/plugin-mcp 3.65.0-internal.ef3958a → 3.65.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.
Files changed (39) hide show
  1. package/dist/endpoints/mcp.js.map +1 -1
  2. package/dist/mcp/getMcpHandler.d.ts.map +1 -1
  3. package/dist/mcp/getMcpHandler.js +14 -3
  4. package/dist/mcp/getMcpHandler.js.map +1 -1
  5. package/dist/mcp/helpers/fileValidation.js +22 -22
  6. package/dist/mcp/helpers/fileValidation.js.map +1 -1
  7. package/dist/mcp/tools/resource/create.d.ts.map +1 -1
  8. package/dist/mcp/tools/resource/create.js +22 -6
  9. package/dist/mcp/tools/resource/create.js.map +1 -1
  10. package/dist/mcp/tools/resource/delete.d.ts.map +1 -1
  11. package/dist/mcp/tools/resource/delete.js +11 -5
  12. package/dist/mcp/tools/resource/delete.js.map +1 -1
  13. package/dist/mcp/tools/resource/find.d.ts.map +1 -1
  14. package/dist/mcp/tools/resource/find.js +18 -6
  15. package/dist/mcp/tools/resource/find.js.map +1 -1
  16. package/dist/mcp/tools/resource/update.d.ts.map +1 -1
  17. package/dist/mcp/tools/resource/update.js +24 -6
  18. package/dist/mcp/tools/resource/update.js.map +1 -1
  19. package/dist/mcp/tools/schemas.d.ts +33 -9
  20. package/dist/mcp/tools/schemas.d.ts.map +1 -1
  21. package/dist/mcp/tools/schemas.js +21 -4
  22. package/dist/mcp/tools/schemas.js.map +1 -1
  23. package/dist/types.d.ts +39 -4
  24. package/dist/types.d.ts.map +1 -1
  25. package/dist/types.js.map +1 -1
  26. package/dist/utils/convertCollectionSchemaToZod.d.ts.map +1 -1
  27. package/dist/utils/convertCollectionSchemaToZod.js +1 -2
  28. package/dist/utils/convertCollectionSchemaToZod.js.map +1 -1
  29. package/package.json +3 -3
  30. package/src/endpoints/mcp.ts +1 -1
  31. package/src/mcp/getMcpHandler.ts +31 -4
  32. package/src/mcp/helpers/fileValidation.ts +22 -22
  33. package/src/mcp/tools/resource/create.ts +40 -4
  34. package/src/mcp/tools/resource/delete.ts +8 -4
  35. package/src/mcp/tools/resource/find.ts +10 -4
  36. package/src/mcp/tools/resource/update.ts +26 -5
  37. package/src/mcp/tools/schemas.ts +49 -3
  38. package/src/types.ts +58 -9
  39. package/src/utils/convertCollectionSchemaToZod.ts +1 -2
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/mcp/tools/schemas.ts"],"sourcesContent":["import { z } from 'zod'\n\nexport const toolSchemas = {\n findResources: {\n description: 'Find documents in a collection by ID or where clause using Find or FindByID.',\n parameters: z.object({\n id: z\n .string()\n .optional()\n .describe(\n 'Optional: specific document ID to retrieve. If not provided, returns all documents',\n ),\n limit: z\n .number()\n .int()\n .min(1, 'Limit must be at least 1')\n .max(100, 'Limit cannot exceed 100')\n .optional()\n .default(10)\n .describe('Maximum number of documents to return (default: 10, max: 100)'),\n page: z\n .number()\n .int()\n .min(1, 'Page must be at least 1')\n .optional()\n .default(1)\n .describe('Page number for pagination (default: 1)'),\n sort: z\n .string()\n .optional()\n .describe('Field to sort by (e.g., \"createdAt\", \"-updatedAt\" for descending)'),\n where: z\n .string()\n .optional()\n .describe(\n 'Optional JSON string for where clause filtering (e.g., \\'{\"title\": {\"contains\": \"test\"}}\\')',\n ),\n }),\n },\n\n createResource: {\n description: 'Create a document in a collection.',\n parameters: z.object({\n data: z.string().describe('JSON string containing the data for the new document'),\n draft: z\n .boolean()\n .optional()\n .default(false)\n .describe('Whether to create the document as a draft'),\n }),\n },\n\n updateResource: {\n description: 'Update documents in a collection by ID or where clause.',\n parameters: z.object({\n id: z.string().optional().describe('Optional: specific document ID to update'),\n data: z.string().describe('JSON string containing the data to update'),\n depth: z\n .number()\n .int()\n .min(0)\n .max(10)\n .optional()\n .default(0)\n .describe('Depth of population for relationships'),\n draft: z.boolean().optional().default(false).describe('Whether to update as a draft'),\n filePath: z.string().optional().describe('Optional: absolute file path for file uploads'),\n overrideLock: z\n .boolean()\n .optional()\n .default(true)\n .describe('Whether to override document locks'),\n overwriteExistingFiles: z\n .boolean()\n .optional()\n .default(false)\n .describe('Whether to overwrite existing files'),\n where: z\n .string()\n .optional()\n .describe('Optional: JSON string for where clause to update multiple documents'),\n }),\n },\n\n deleteResource: {\n description: 'Delete documents in a collection by ID or where clause.',\n parameters: z.object({\n id: z.string().optional().describe('Optional: specific document ID to delete'),\n depth: z\n .number()\n .int()\n .min(0)\n .max(10)\n .optional()\n .default(0)\n .describe('Depth of population for relationships in response'),\n where: z\n .string()\n .optional()\n .describe('Optional: JSON string for where clause to delete multiple documents'),\n }),\n },\n\n // Experimental Below This Line\n createCollection: {\n description: 'Creates a new collection with specified fields and configuration.',\n parameters: z.object({\n collectionDescription: z\n .string()\n .optional()\n .describe('Optional description for the collection'),\n collectionName: z.string().describe('The name of the collection to create'),\n fields: z.array(z.any()).describe('Array of field definitions for the collection'),\n hasUpload: z\n .boolean()\n .optional()\n .describe('Whether the collection should have upload capabilities'),\n }),\n },\n\n findCollections: {\n description: 'Finds and lists collections with optional content and document counts.',\n parameters: z.object({\n collectionName: z\n .string()\n .optional()\n .describe('Optional: specific collection name to retrieve'),\n includeContent: z\n .boolean()\n .optional()\n .default(false)\n .describe('Whether to include collection file content'),\n includeCount: z\n .boolean()\n .optional()\n .default(false)\n .describe('Whether to include document counts for each collection'),\n }),\n },\n\n updateCollection: {\n description:\n 'Updates an existing collection with new fields, modifications, or configuration changes.',\n parameters: z.object({\n collectionName: z.string().describe('The name of the collection to update'),\n configUpdates: z.any().optional().describe('Configuration updates (for update_config type)'),\n fieldModifications: z\n .array(z.any())\n .optional()\n .describe('Field modifications (for modify_field type)'),\n fieldNamesToRemove: z\n .array(z.string())\n .optional()\n .describe('Field names to remove (for remove_field type)'),\n newContent: z\n .string()\n .optional()\n .describe('New content to replace entire collection (for replace_content type)'),\n newFields: z.array(z.any()).optional().describe('New fields to add (for add_field type)'),\n updateType: z\n .enum(['add_field', 'remove_field', 'modify_field', 'update_config', 'replace_content'])\n .describe('Type of update to perform'),\n }),\n },\n\n deleteCollection: {\n description: 'Deletes a collection and optionally updates the configuration.',\n parameters: z.object({\n collectionName: z.string().describe('The name of the collection to delete'),\n confirmDeletion: z.boolean().describe('Confirmation flag to prevent accidental deletion'),\n updateConfig: z\n .boolean()\n .optional()\n .default(false)\n .describe('Whether to update payload.config.ts to remove collection reference'),\n }),\n },\n\n findConfig: {\n description: 'Reads and displays the current configuration file.',\n parameters: z.object({\n includeMetadata: z\n .boolean()\n .optional()\n .default(false)\n .describe('Whether to include file metadata (size, modified date, etc.)'),\n }),\n },\n\n updateConfig: {\n description: 'Updates the configuration file with various modifications.',\n parameters: z.object({\n adminConfig: z\n .any()\n .optional()\n .describe('Admin configuration updates (for update_admin type)'),\n collectionName: z\n .string()\n .optional()\n .describe('Collection name (required for add_collection and remove_collection)'),\n databaseConfig: z\n .any()\n .optional()\n .describe('Database configuration updates (for update_database type)'),\n generalConfig: z.any().optional().describe('General configuration updates'),\n newContent: z\n .string()\n .optional()\n .describe('New configuration content (for replace_content type)'),\n pluginUpdates: z\n .any()\n .optional()\n .describe('Plugin configuration updates (for update_plugins type)'),\n updateType: z\n .enum([\n 'add_collection',\n 'remove_collection',\n 'update_admin',\n 'update_database',\n 'update_plugins',\n 'replace_content',\n ])\n .describe('Type of configuration update to perform'),\n }),\n },\n\n auth: {\n description: 'Checks authentication status for the current user.',\n parameters: z.object({\n headers: z\n .string()\n .optional()\n .describe(\n 'Optional JSON string containing custom headers to send with the authentication request',\n ),\n }),\n },\n\n login: {\n description: 'Authenticates a user with email and password.',\n parameters: z.object({\n collection: z.string().describe('The collection containing the user (e.g., \"users\")'),\n depth: z\n .number()\n .int()\n .min(0)\n .max(10)\n .optional()\n .default(0)\n .describe('Depth of population for relationships'),\n email: z.string().email().describe('The user email address'),\n overrideAccess: z\n .boolean()\n .optional()\n .default(false)\n .describe('Whether to override access controls'),\n password: z.string().describe('The user password'),\n showHiddenFields: z\n .boolean()\n .optional()\n .default(false)\n .describe('Whether to show hidden fields in the response'),\n }),\n },\n\n verify: {\n description: 'Verifies a user email with a verification token.',\n parameters: z.object({\n collection: z.string().describe('The collection containing the user (e.g., \"users\")'),\n token: z.string().describe('The verification token sent to the user email'),\n }),\n },\n\n resetPassword: {\n description: 'Resets a user password with a reset token.',\n parameters: z.object({\n collection: z.string().describe('The collection containing the user (e.g., \"users\")'),\n password: z.string().describe('The new password for the user'),\n token: z.string().describe('The password reset token sent to the user email'),\n }),\n },\n\n forgotPassword: {\n description: 'Sends a password reset email to a user.',\n parameters: z.object({\n collection: z.string().describe('The collection containing the user (e.g., \"users\")'),\n disableEmail: z\n .boolean()\n .optional()\n .default(false)\n .describe('Whether to disable sending the email (for testing)'),\n email: z.string().email().describe('The user email address'),\n }),\n },\n\n unlock: {\n description: 'Unlocks a user account that has been locked due to failed login attempts.',\n parameters: z.object({\n collection: z.string().describe('The collection containing the user (e.g., \"users\")'),\n email: z.string().email().describe('The user email address'),\n }),\n },\n\n createJob: {\n description: 'Creates a new job (task or workflow) with specified configuration.',\n parameters: z.object({\n description: z.string().describe('Description of what the job does'),\n inputSchema: z.record(z.any()).optional().default({}).describe('Input schema for the job'),\n jobData: z\n .record(z.any())\n .optional()\n .default({})\n .describe('Additional job configuration data'),\n jobName: z\n .string()\n .min(1, 'Job name cannot be empty')\n .regex(/^[a-z][\\w-]*$/i, 'Job name must be alphanumeric and can contain underscores/dashes')\n .describe('The name of the job to create'),\n jobSlug: z\n .string()\n .min(1, 'Job slug cannot be empty')\n .regex(/^[a-z][a-z0-9-]*$/, 'Job slug must be kebab-case')\n .describe('The slug for the job (kebab-case format)'),\n jobType: z\n .enum(['task', 'workflow'])\n .describe('Whether to create a task (individual unit) or workflow (orchestrates tasks)'),\n outputSchema: z.record(z.any()).optional().default({}).describe('Output schema for the job'),\n }),\n },\n\n updateJob: {\n description: 'Updates an existing job with new configuration, schema, or handler code.',\n parameters: z.object({\n configUpdate: z.record(z.any()).optional().describe('New configuration for the job'),\n handlerCode: z\n .string()\n .optional()\n .describe('New handler code to replace the existing handler'),\n inputSchema: z.record(z.any()).optional().describe('New input schema for the job'),\n jobSlug: z.string().describe('The slug of the job to update'),\n outputSchema: z.record(z.any()).optional().describe('New output schema for the job'),\n taskSequence: z.array(z.any()).optional().describe('New task sequence for workflows'),\n updateType: z\n .enum(['modify_schema', 'update_tasks', 'change_config', 'replace_handler'])\n .describe('Type of update to perform on the job'),\n }),\n },\n\n runJob: {\n description: 'Runs a job with specified input data and queue options.',\n parameters: z.object({\n delay: z\n .number()\n .int()\n .min(0)\n .optional()\n .describe('Delay in milliseconds before job execution'),\n input: z.record(z.any()).describe('Input data for the job execution'),\n jobSlug: z.string().describe('The slug of the job to run'),\n priority: z\n .number()\n .int()\n .min(1)\n .max(10)\n .optional()\n .describe('Job priority (1-10, higher is more important)'),\n queue: z\n .string()\n .optional()\n .describe('Queue name to use for job execution (default: \"default\")'),\n }),\n },\n}\n"],"names":["z","toolSchemas","findResources","description","parameters","object","id","string","optional","describe","limit","number","int","min","max","default","page","sort","where","createResource","data","draft","boolean","updateResource","depth","filePath","overrideLock","overwriteExistingFiles","deleteResource","createCollection","collectionDescription","collectionName","fields","array","any","hasUpload","findCollections","includeContent","includeCount","updateCollection","configUpdates","fieldModifications","fieldNamesToRemove","newContent","newFields","updateType","enum","deleteCollection","confirmDeletion","updateConfig","findConfig","includeMetadata","adminConfig","databaseConfig","generalConfig","pluginUpdates","auth","headers","login","collection","email","overrideAccess","password","showHiddenFields","verify","token","resetPassword","forgotPassword","disableEmail","unlock","createJob","inputSchema","record","jobData","jobName","regex","jobSlug","jobType","outputSchema","updateJob","configUpdate","handlerCode","taskSequence","runJob","delay","input","priority","queue"],"mappings":"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"}
1
+ {"version":3,"sources":["../../../src/mcp/tools/schemas.ts"],"sourcesContent":["import { z } from 'zod'\n\nexport const toolSchemas = {\n findResources: {\n description: 'Find documents in a collection by ID or where clause using Find or FindByID.',\n parameters: z.object({\n id: z\n .union([z.string(), z.number()])\n .optional()\n .describe(\n 'Optional: specific document ID to retrieve. If not provided, returns all documents',\n ),\n fallbackLocale: z\n .string()\n .optional()\n .describe('Optional: fallback locale code to use when requested locale is not available'),\n limit: z\n .number()\n .int()\n .min(1, 'Limit must be at least 1')\n .max(100, 'Limit cannot exceed 100')\n .optional()\n .default(10)\n .describe('Maximum number of documents to return (default: 10, max: 100)'),\n locale: z\n .string()\n .optional()\n .describe(\n 'Optional: locale code to retrieve data in (e.g., \"en\", \"es\"). Use \"all\" to retrieve all locales for localized fields',\n ),\n page: z\n .number()\n .int()\n .min(1, 'Page must be at least 1')\n .optional()\n .default(1)\n .describe('Page number for pagination (default: 1)'),\n sort: z\n .string()\n .optional()\n .describe('Field to sort by (e.g., \"createdAt\", \"-updatedAt\" for descending)'),\n where: z\n .string()\n .optional()\n .describe(\n 'Optional JSON string for where clause filtering (e.g., \\'{\"title\": {\"contains\": \"test\"}}\\')',\n ),\n }),\n },\n\n createResource: {\n description: 'Create a document in a collection.',\n parameters: z.object({\n data: z.string().describe('JSON string containing the data for the new document'),\n draft: z\n .boolean()\n .optional()\n .default(false)\n .describe('Whether to create the document as a draft'),\n fallbackLocale: z\n .string()\n .optional()\n .describe('Optional: fallback locale code to use when requested locale is not available'),\n locale: z\n .string()\n .optional()\n .describe(\n 'Optional: locale code to create the document in (e.g., \"en\", \"es\"). Defaults to the default locale',\n ),\n }),\n },\n\n updateResource: {\n description: 'Update documents in a collection by ID or where clause.',\n parameters: z.object({\n id: z\n .union([z.string(), z.number()])\n .optional()\n .describe('Optional: specific document ID to update'),\n data: z.string().describe('JSON string containing the data to update'),\n depth: z\n .number()\n .int()\n .min(0)\n .max(10)\n .optional()\n .default(0)\n .describe('Depth of population for relationships'),\n draft: z.boolean().optional().default(false).describe('Whether to update as a draft'),\n fallbackLocale: z\n .string()\n .optional()\n .describe('Optional: fallback locale code to use when requested locale is not available'),\n filePath: z.string().optional().describe('Optional: absolute file path for file uploads'),\n locale: z\n .string()\n .optional()\n .describe(\n 'Optional: locale code to update the document in (e.g., \"en\", \"es\"). Defaults to the default locale',\n ),\n overrideLock: z\n .boolean()\n .optional()\n .default(true)\n .describe('Whether to override document locks'),\n overwriteExistingFiles: z\n .boolean()\n .optional()\n .default(false)\n .describe('Whether to overwrite existing files'),\n where: z\n .string()\n .optional()\n .describe('Optional: JSON string for where clause to update multiple documents'),\n }),\n },\n\n deleteResource: {\n description: 'Delete documents in a collection by ID or where clause.',\n parameters: z.object({\n id: z\n .union([z.string(), z.number()])\n .optional()\n .describe('Optional: specific document ID to delete'),\n depth: z\n .number()\n .int()\n .min(0)\n .max(10)\n .optional()\n .default(0)\n .describe('Depth of population for relationships in response'),\n fallbackLocale: z\n .string()\n .optional()\n .describe('Optional: fallback locale code to use when requested locale is not available'),\n locale: z\n .string()\n .optional()\n .describe(\n 'Optional: locale code for the operation (e.g., \"en\", \"es\"). Defaults to the default locale',\n ),\n where: z\n .string()\n .optional()\n .describe('Optional: JSON string for where clause to delete multiple documents'),\n }),\n },\n\n // Experimental Below This Line\n createCollection: {\n description: 'Creates a new collection with specified fields and configuration.',\n parameters: z.object({\n collectionDescription: z\n .string()\n .optional()\n .describe('Optional description for the collection'),\n collectionName: z.string().describe('The name of the collection to create'),\n fields: z.array(z.any()).describe('Array of field definitions for the collection'),\n hasUpload: z\n .boolean()\n .optional()\n .describe('Whether the collection should have upload capabilities'),\n }),\n },\n\n findCollections: {\n description: 'Finds and lists collections with optional content and document counts.',\n parameters: z.object({\n collectionName: z\n .string()\n .optional()\n .describe('Optional: specific collection name to retrieve'),\n includeContent: z\n .boolean()\n .optional()\n .default(false)\n .describe('Whether to include collection file content'),\n includeCount: z\n .boolean()\n .optional()\n .default(false)\n .describe('Whether to include document counts for each collection'),\n }),\n },\n\n updateCollection: {\n description:\n 'Updates an existing collection with new fields, modifications, or configuration changes.',\n parameters: z.object({\n collectionName: z.string().describe('The name of the collection to update'),\n configUpdates: z.any().optional().describe('Configuration updates (for update_config type)'),\n fieldModifications: z\n .array(z.any())\n .optional()\n .describe('Field modifications (for modify_field type)'),\n fieldNamesToRemove: z\n .array(z.string())\n .optional()\n .describe('Field names to remove (for remove_field type)'),\n newContent: z\n .string()\n .optional()\n .describe('New content to replace entire collection (for replace_content type)'),\n newFields: z.array(z.any()).optional().describe('New fields to add (for add_field type)'),\n updateType: z\n .enum(['add_field', 'remove_field', 'modify_field', 'update_config', 'replace_content'])\n .describe('Type of update to perform'),\n }),\n },\n\n deleteCollection: {\n description: 'Deletes a collection and optionally updates the configuration.',\n parameters: z.object({\n collectionName: z.string().describe('The name of the collection to delete'),\n confirmDeletion: z.boolean().describe('Confirmation flag to prevent accidental deletion'),\n updateConfig: z\n .boolean()\n .optional()\n .default(false)\n .describe('Whether to update payload.config.ts to remove collection reference'),\n }),\n },\n\n findConfig: {\n description: 'Reads and displays the current configuration file.',\n parameters: z.object({\n includeMetadata: z\n .boolean()\n .optional()\n .default(false)\n .describe('Whether to include file metadata (size, modified date, etc.)'),\n }),\n },\n\n updateConfig: {\n description: 'Updates the configuration file with various modifications.',\n parameters: z.object({\n adminConfig: z\n .any()\n .optional()\n .describe('Admin configuration updates (for update_admin type)'),\n collectionName: z\n .string()\n .optional()\n .describe('Collection name (required for add_collection and remove_collection)'),\n databaseConfig: z\n .any()\n .optional()\n .describe('Database configuration updates (for update_database type)'),\n generalConfig: z.any().optional().describe('General configuration updates'),\n newContent: z\n .string()\n .optional()\n .describe('New configuration content (for replace_content type)'),\n pluginUpdates: z\n .any()\n .optional()\n .describe('Plugin configuration updates (for update_plugins type)'),\n updateType: z\n .enum([\n 'add_collection',\n 'remove_collection',\n 'update_admin',\n 'update_database',\n 'update_plugins',\n 'replace_content',\n ])\n .describe('Type of configuration update to perform'),\n }),\n },\n\n auth: {\n description: 'Checks authentication status for the current user.',\n parameters: z.object({\n headers: z\n .string()\n .optional()\n .describe(\n 'Optional JSON string containing custom headers to send with the authentication request',\n ),\n }),\n },\n\n login: {\n description: 'Authenticates a user with email and password.',\n parameters: z.object({\n collection: z.string().describe('The collection containing the user (e.g., \"users\")'),\n depth: z\n .number()\n .int()\n .min(0)\n .max(10)\n .optional()\n .default(0)\n .describe('Depth of population for relationships'),\n email: z.string().email().describe('The user email address'),\n overrideAccess: z\n .boolean()\n .optional()\n .default(false)\n .describe('Whether to override access controls'),\n password: z.string().describe('The user password'),\n showHiddenFields: z\n .boolean()\n .optional()\n .default(false)\n .describe('Whether to show hidden fields in the response'),\n }),\n },\n\n verify: {\n description: 'Verifies a user email with a verification token.',\n parameters: z.object({\n collection: z.string().describe('The collection containing the user (e.g., \"users\")'),\n token: z.string().describe('The verification token sent to the user email'),\n }),\n },\n\n resetPassword: {\n description: 'Resets a user password with a reset token.',\n parameters: z.object({\n collection: z.string().describe('The collection containing the user (e.g., \"users\")'),\n password: z.string().describe('The new password for the user'),\n token: z.string().describe('The password reset token sent to the user email'),\n }),\n },\n\n forgotPassword: {\n description: 'Sends a password reset email to a user.',\n parameters: z.object({\n collection: z.string().describe('The collection containing the user (e.g., \"users\")'),\n disableEmail: z\n .boolean()\n .optional()\n .default(false)\n .describe('Whether to disable sending the email (for testing)'),\n email: z.string().email().describe('The user email address'),\n }),\n },\n\n unlock: {\n description: 'Unlocks a user account that has been locked due to failed login attempts.',\n parameters: z.object({\n collection: z.string().describe('The collection containing the user (e.g., \"users\")'),\n email: z.string().email().describe('The user email address'),\n }),\n },\n\n createJob: {\n description: 'Creates a new job (task or workflow) with specified configuration.',\n parameters: z.object({\n description: z.string().describe('Description of what the job does'),\n inputSchema: z.record(z.any()).optional().default({}).describe('Input schema for the job'),\n jobData: z\n .record(z.any())\n .optional()\n .default({})\n .describe('Additional job configuration data'),\n jobName: z\n .string()\n .min(1, 'Job name cannot be empty')\n .regex(/^[a-z][\\w-]*$/i, 'Job name must be alphanumeric and can contain underscores/dashes')\n .describe('The name of the job to create'),\n jobSlug: z\n .string()\n .min(1, 'Job slug cannot be empty')\n .regex(/^[a-z][a-z0-9-]*$/, 'Job slug must be kebab-case')\n .describe('The slug for the job (kebab-case format)'),\n jobType: z\n .enum(['task', 'workflow'])\n .describe('Whether to create a task (individual unit) or workflow (orchestrates tasks)'),\n outputSchema: z.record(z.any()).optional().default({}).describe('Output schema for the job'),\n }),\n },\n\n updateJob: {\n description: 'Updates an existing job with new configuration, schema, or handler code.',\n parameters: z.object({\n configUpdate: z.record(z.any()).optional().describe('New configuration for the job'),\n handlerCode: z\n .string()\n .optional()\n .describe('New handler code to replace the existing handler'),\n inputSchema: z.record(z.any()).optional().describe('New input schema for the job'),\n jobSlug: z.string().describe('The slug of the job to update'),\n outputSchema: z.record(z.any()).optional().describe('New output schema for the job'),\n taskSequence: z.array(z.any()).optional().describe('New task sequence for workflows'),\n updateType: z\n .enum(['modify_schema', 'update_tasks', 'change_config', 'replace_handler'])\n .describe('Type of update to perform on the job'),\n }),\n },\n\n runJob: {\n description: 'Runs a job with specified input data and queue options.',\n parameters: z.object({\n delay: z\n .number()\n .int()\n .min(0)\n .optional()\n .describe('Delay in milliseconds before job execution'),\n input: z.record(z.any()).describe('Input data for the job execution'),\n jobSlug: z.string().describe('The slug of the job to run'),\n priority: z\n .number()\n .int()\n .min(1)\n .max(10)\n .optional()\n .describe('Job priority (1-10, higher is more important)'),\n queue: z\n .string()\n .optional()\n .describe('Queue name to use for job execution (default: \"default\")'),\n }),\n },\n}\n"],"names":["z","toolSchemas","findResources","description","parameters","object","id","union","string","number","optional","describe","fallbackLocale","limit","int","min","max","default","locale","page","sort","where","createResource","data","draft","boolean","updateResource","depth","filePath","overrideLock","overwriteExistingFiles","deleteResource","createCollection","collectionDescription","collectionName","fields","array","any","hasUpload","findCollections","includeContent","includeCount","updateCollection","configUpdates","fieldModifications","fieldNamesToRemove","newContent","newFields","updateType","enum","deleteCollection","confirmDeletion","updateConfig","findConfig","includeMetadata","adminConfig","databaseConfig","generalConfig","pluginUpdates","auth","headers","login","collection","email","overrideAccess","password","showHiddenFields","verify","token","resetPassword","forgotPassword","disableEmail","unlock","createJob","inputSchema","record","jobData","jobName","regex","jobSlug","jobType","outputSchema","updateJob","configUpdate","handlerCode","taskSequence","runJob","delay","input","priority","queue"],"mappings":"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"}
package/dist/types.d.ts CHANGED
@@ -1,4 +1,4 @@
1
- import type { CollectionConfig, CollectionSlug, PayloadRequest } from 'payload';
1
+ import type { CollectionConfig, CollectionSlug, PayloadRequest, TypedUser } from 'payload';
2
2
  import type { z } from 'zod';
3
3
  import { type ResourceTemplate } from '@modelcontextprotocol/sdk/server/mcp.js';
4
4
  export type PluginMCPServerConfig = {
@@ -121,7 +121,23 @@ export type PluginMCPServerConfig = {
121
121
  /**
122
122
  * Set the handler of the prompt. This is the function that will be called when the prompt is used.
123
123
  */
124
- handler: (...args: any) => any;
124
+ handler: (args: Record<string, unknown>, req: PayloadRequest, _extra: unknown) => {
125
+ messages: Array<{
126
+ content: {
127
+ text: string;
128
+ type: 'text';
129
+ };
130
+ role: 'assistant' | 'user';
131
+ }>;
132
+ } | Promise<{
133
+ messages: Array<{
134
+ content: {
135
+ text: string;
136
+ type: 'text';
137
+ };
138
+ role: 'assistant' | 'user';
139
+ }>;
140
+ }>;
125
141
  /**
126
142
  * Set the function name of the prompt.
127
143
  */
@@ -142,8 +158,19 @@ export type PluginMCPServerConfig = {
142
158
  description: string;
143
159
  /**
144
160
  * Set the handler of the resource. This is the function that will be called when the resource is used.
161
+ * The handler can have either 3 arguments (when no args are passed) or 4 arguments (when args are passed).
145
162
  */
146
- handler: (...args: any) => any;
163
+ handler: (...args: any[]) => {
164
+ contents: Array<{
165
+ text: string;
166
+ uri: string;
167
+ }>;
168
+ } | Promise<{
169
+ contents: Array<{
170
+ text: string;
171
+ uri: string;
172
+ }>;
173
+ }>;
147
174
  /**
148
175
  * Set the mime type of the resource.
149
176
  * example: 'text/plain'
@@ -177,11 +204,18 @@ export type PluginMCPServerConfig = {
177
204
  /**
178
205
  * Set the handler of the tool. This is the function that will be called when the tool is used.
179
206
  */
180
- handler: (args: Record<string, unknown>) => Promise<{
207
+ handler: (args: Record<string, unknown>, req: PayloadRequest, _extra: unknown) => {
208
+ content: Array<{
209
+ text: string;
210
+ type: 'text';
211
+ }>;
212
+ role?: string;
213
+ } | Promise<{
181
214
  content: Array<{
182
215
  text: string;
183
216
  type: 'text';
184
217
  }>;
218
+ role?: string;
185
219
  }>;
186
220
  /**
187
221
  * Set the name of the tool. This is the name that will be used to identify the tool. LLMs will interperate the name to determine when to use the tool.
@@ -284,6 +318,7 @@ export type MCPAccessSettings = {
284
318
  'payload-mcp-prompt'?: Record<string, boolean>;
285
319
  'payload-mcp-resource'?: Record<string, boolean>;
286
320
  'payload-mcp-tool'?: Record<string, boolean>;
321
+ user: TypedUser;
287
322
  } & Record<string, unknown>;
288
323
  export type FieldDefinition = {
289
324
  description?: string;
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"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"}
package/dist/types.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/types.ts"],"sourcesContent":["import type { CollectionConfig, CollectionSlug, PayloadRequest } from 'payload'\nimport type { z } from 'zod'\n\nimport { type ResourceTemplate } from '@modelcontextprotocol/sdk/server/mcp.js'\n\nexport type PluginMCPServerConfig = {\n /**\n * Set the collections that should be available as resources via MCP.\n */\n collections?: Partial<\n Record<\n CollectionSlug,\n {\n /**\n * Set the description of the collection. This is used by MCP clients to determine when to use the collecton as a resource.\n */\n description?: string\n /**\n * Set the enabled capabilities of the collection. Admins can then allow or disallow the use of the capability by MCP clients.\n */\n enabled:\n | {\n create?: boolean\n delete?: boolean\n find?: boolean\n update?: boolean\n }\n | boolean\n\n /**\n * Override the response generated by the MCP client. This allows you to modify the response that is sent to the MCP client. This is useful for adding additional data to the response, data normalization, or verifying data.\n */\n overrideResponse?: (\n response: {\n content: Array<{\n text: string\n type: string\n }>\n },\n doc: Record<string, unknown>,\n req: PayloadRequest,\n ) => {\n content: Array<{\n text: string\n type: string\n }>\n }\n }\n >\n >\n /**\n * Disable the MCP plugin.\n */\n disabled?: boolean\n /**\n * Experimental features\n * **These features are for experimental purposes -- They are Disabled in Production by Default**\n */\n experimental?: {\n /**\n * These are MCP tools that can be used by a client to modify Payload.\n */\n tools: {\n /**\n * **Experimental** -- Auth MCP tools allow a client to change authentication priviliages for users. This is for developing ideas that help Admins with authentication tasks.\n */\n auth?: {\n /**\n * Enable the auth MCP tools. This allows Admins to enable or disable the auth capabilities.\n * @default false\n */\n enabled: boolean\n }\n /**\n * **Experimental** -- Collection MCP tools allow for the creation, modification, and deletion of Payload collections. This is for developing ideas that help Developers with collection tasks.\n */\n collections?: {\n /**\n * Set the directory path to the collections directory. This can be a directory outside of your default directory, or another Payload project.\n */\n collectionsDirPath: string\n /**\n * Enable the collection MCP tools. This allows Admins to enable or disable the Collection modification capabilities.\n * @default false\n */\n enabled: boolean\n }\n /**\n * **Experimental** -- Config MCP tools allow for the modification of a Payload Config. This is for developing ideas that help Developers with config tasks.\n */\n config?: {\n /**\n * Set the directory path to the config directory. This can be a directory outside of your default directory, or another Payload project.\n */\n configFilePath: string\n /**\n * Enable the config MCP tools. This allows Admins to enable or disable the Payload Config modification capabilities.\n * @default false\n */\n enabled: boolean\n }\n /**\n * **Experimental** -- Jobs MCP tools allow for the modification of Payload jobs. This is for developing ideas that help Developers with job tasks.\n */\n jobs?: {\n /**\n * Enable the jobs MCP tools. This allows Admins to enable or disable the Job modification capabilities.\n * @default false\n */\n enabled: boolean\n /**\n * Set the directory path to the jobs directory. This can be a directory outside of your default directory, or another Payload project.\n */\n jobsDirPath: string\n }\n }\n }\n /**\n * MCP Server options.\n */\n mcp?: {\n handlerOptions?: MCPHandlerOptions\n /**\n * Add custom MCP Prompts.\n */\n prompts?: {\n /**\n * Set the args schema of the prompt. This is the args schema that will be passed to the prompt. This is used by MCP clients to determine the arguments that will be passed to the prompt.\n */\n argsSchema: z.ZodRawShape\n /**\n * Set the description of the prompt. This is used by MCP clients to determine when to use the prompt.\n */\n description: string\n /**\n * Set the handler of the prompt. This is the function that will be called when the prompt is used.\n */\n handler: (...args: any) => any\n /**\n * Set the function name of the prompt.\n */\n name: string\n /**\n * Set the title of the prompt. LLMs will interperate the title to determine when to use the prompt.\n */\n title: string\n }[]\n\n /**\n * Add custom MCP Resource.\n */\n resources?: {\n /**\n * Set the description of the resource. This is used by MCP clients to determine when to use the resource.\n * example: 'Data is a resource that contains special data.'\n */\n description: string\n /**\n * Set the handler of the resource. This is the function that will be called when the resource is used.\n */\n handler: (...args: any) => any\n /**\n * Set the mime type of the resource.\n * example: 'text/plain'\n */\n mimeType: string\n /**\n * Set the function name of the resource.\n * example: 'data'\n */\n name: string\n /**\n * Set the title of the resource. LLMs will interperate the title to determine when to use the resource.\n * example: 'Data'\n */\n title: string\n /**\n * Set the uri of the resource.\n * example: 'data://app'\n */\n uri: ResourceTemplate | string\n }[]\n serverOptions?: MCPServerOptions\n /**\n * Add custom MCP Tools.\n */\n tools?: {\n /**\n * Set the description of the tool. This is used by MCP clients to determine when to use the tool.\n */\n description: string\n /**\n * Set the handler of the tool. This is the function that will be called when the tool is used.\n */\n handler: (args: Record<string, unknown>) => Promise<{\n content: Array<{\n text: string\n type: 'text'\n }>\n }>\n /**\n * Set the name of the tool. This is the name that will be used to identify the tool. LLMs will interperate the name to determine when to use the tool.\n */\n name: string\n /**\n * Set the parameters of the tool. This is the parameters that will be passed to the tool.\n */\n parameters: z.ZodRawShape\n }[]\n }\n\n /**\n * Override the API key collection.\n * This allows you to add fields to the API key collection or modify the collection in any way you want.\n * @param collection - The API key collection.\n * @returns The modified API key collection.\n */\n overrideApiKeyCollection?: (collection: CollectionConfig) => CollectionConfig\n\n /**\n * Override the authentication method.\n * This allows you to use a custom authentication method instead of the default API key authentication.\n * @param req - The request object.\n * @returns The MCP access settings.\n */\n overrideAuth?: (\n req: PayloadRequest,\n getDefaultMcpAccessSettings: (overrideApiKey?: null | string) => Promise<MCPAccessSettings>,\n ) => MCPAccessSettings | Promise<MCPAccessSettings>\n\n /**\n * Set the users collection that API keys should be associated with.\n */\n userCollection?: CollectionConfig | string\n}\n\n/**\n * MCP Handler options.\n */\nexport type MCPHandlerOptions = {\n /**\n * Set the base path of the MCP handler. This is the path that will be used to access the MCP handler.\n * @default /api\n */\n basePath?: string\n /**\n * Set the maximum duration of the MCP handler. This is the maximum duration that the MCP handler will run for.\n * @default 60\n */\n maxDuration?: number\n /**\n * Set the Redis URL for the MCP handler. This is the URL that will be used to access the Redis server.\n * @default process.env.REDIS_URL\n * INFO: Disabled until developer clarity is reached for server side streaming and we have an auth pattern for all SSE patterns\n */\n // redisUrl?: string\n /**\n * Set verbose logging.\n * @default false\n */\n verboseLogs?: boolean\n}\n\n/**\n * MCP Server options.\n */\nexport type MCPServerOptions = {\n /**\n * Set the server info of the MCP server.\n */\n serverInfo?: {\n /**\n * Set the name of the MCP server.\n * @default 'Payload MCP Server'\n */\n name: string\n /**\n * Set the version of the MCP server.\n * @default '1.0.0'\n */\n version: string\n }\n}\n\nexport type MCPAccessSettings = {\n auth?: {\n auth?: boolean\n forgotPassword?: boolean\n login?: boolean\n resetPassword?: boolean\n unlock?: boolean\n verify?: boolean\n }\n collections?: {\n create?: boolean\n delete?: boolean\n find?: boolean\n update?: boolean\n }\n config?: {\n find?: boolean\n update?: boolean\n }\n jobs?: {\n create?: boolean\n run?: boolean\n update?: boolean\n }\n 'payload-mcp-prompt'?: Record<string, boolean>\n 'payload-mcp-resource'?: Record<string, boolean>\n 'payload-mcp-tool'?: Record<string, boolean>\n} & Record<string, unknown>\n\nexport type FieldDefinition = {\n description?: string\n name: string\n options?: { label: string; value: string }[]\n position?: 'main' | 'sidebar'\n required?: boolean\n type: string\n}\n\nexport type FieldModification = {\n changes: {\n description?: string\n options?: { label: string; value: string }[]\n position?: 'main' | 'sidebar'\n required?: boolean\n type?: string\n }\n fieldName: string\n}\n\nexport type CollectionConfigUpdates = {\n access?: {\n create?: string\n delete?: string\n read?: string\n update?: string\n }\n description?: string\n slug?: string\n timestamps?: boolean\n versioning?: boolean\n}\n\nexport type AdminConfig = {\n avatar?: string\n css?: string\n dateFormat?: string\n inactivityRoute?: string\n livePreview?: {\n breakpoints?: Array<{\n height: number\n label: string\n name: string\n width: number\n }>\n }\n logoutRoute?: string\n meta?: {\n favicon?: string\n ogImage?: string\n titleSuffix?: string\n }\n user?: string\n}\n\nexport type DatabaseConfig = {\n connectOptions?: string\n type?: 'mongodb' | 'postgres'\n url?: string\n}\n\nexport type PluginUpdates = {\n add?: string[]\n remove?: string[]\n}\n\nexport type GeneralConfig = {\n cookiePrefix?: string\n cors?: string\n csrf?: string\n graphQL?: {\n disable?: boolean\n schemaOutputFile?: string\n }\n rateLimit?: {\n max?: number\n skip?: string\n window?: number\n }\n secret?: string\n serverURL?: string\n typescript?: {\n declare?: boolean\n outputFile?: string\n }\n}\n\nexport interface SchemaField {\n description?: string\n name: string\n options?: string[]\n required?: boolean\n type: string\n}\n\nexport interface TaskSequenceItem {\n description?: string\n retries?: number\n taskId: string\n taskSlug: string\n timeout?: number\n}\n\nexport interface JobConfigUpdate {\n description?: string\n queue?: string\n retries?: number\n timeout?: number\n}\n"],"names":[],"mappings":"AAgaA,WAKC"}
1
+ {"version":3,"sources":["../src/types.ts"],"sourcesContent":["import type { CollectionConfig, CollectionSlug, PayloadRequest, TypedUser } from 'payload'\nimport type { z } from 'zod'\n\nimport { type ResourceTemplate } from '@modelcontextprotocol/sdk/server/mcp.js'\n\nexport type PluginMCPServerConfig = {\n /**\n * Set the collections that should be available as resources via MCP.\n */\n collections?: Partial<\n Record<\n CollectionSlug,\n {\n /**\n * Set the description of the collection. This is used by MCP clients to determine when to use the collecton as a resource.\n */\n description?: string\n /**\n * Set the enabled capabilities of the collection. Admins can then allow or disallow the use of the capability by MCP clients.\n */\n enabled:\n | {\n create?: boolean\n delete?: boolean\n find?: boolean\n update?: boolean\n }\n | boolean\n\n /**\n * Override the response generated by the MCP client. This allows you to modify the response that is sent to the MCP client. This is useful for adding additional data to the response, data normalization, or verifying data.\n */\n overrideResponse?: (\n response: {\n content: Array<{\n text: string\n type: string\n }>\n },\n doc: Record<string, unknown>,\n req: PayloadRequest,\n ) => {\n content: Array<{\n text: string\n type: string\n }>\n }\n }\n >\n >\n /**\n * Disable the MCP plugin.\n */\n disabled?: boolean\n /**\n * Experimental features\n * **These features are for experimental purposes -- They are Disabled in Production by Default**\n */\n experimental?: {\n /**\n * These are MCP tools that can be used by a client to modify Payload.\n */\n tools: {\n /**\n * **Experimental** -- Auth MCP tools allow a client to change authentication priviliages for users. This is for developing ideas that help Admins with authentication tasks.\n */\n auth?: {\n /**\n * Enable the auth MCP tools. This allows Admins to enable or disable the auth capabilities.\n * @default false\n */\n enabled: boolean\n }\n /**\n * **Experimental** -- Collection MCP tools allow for the creation, modification, and deletion of Payload collections. This is for developing ideas that help Developers with collection tasks.\n */\n collections?: {\n /**\n * Set the directory path to the collections directory. This can be a directory outside of your default directory, or another Payload project.\n */\n collectionsDirPath: string\n /**\n * Enable the collection MCP tools. This allows Admins to enable or disable the Collection modification capabilities.\n * @default false\n */\n enabled: boolean\n }\n /**\n * **Experimental** -- Config MCP tools allow for the modification of a Payload Config. This is for developing ideas that help Developers with config tasks.\n */\n config?: {\n /**\n * Set the directory path to the config directory. This can be a directory outside of your default directory, or another Payload project.\n */\n configFilePath: string\n /**\n * Enable the config MCP tools. This allows Admins to enable or disable the Payload Config modification capabilities.\n * @default false\n */\n enabled: boolean\n }\n /**\n * **Experimental** -- Jobs MCP tools allow for the modification of Payload jobs. This is for developing ideas that help Developers with job tasks.\n */\n jobs?: {\n /**\n * Enable the jobs MCP tools. This allows Admins to enable or disable the Job modification capabilities.\n * @default false\n */\n enabled: boolean\n /**\n * Set the directory path to the jobs directory. This can be a directory outside of your default directory, or another Payload project.\n */\n jobsDirPath: string\n }\n }\n }\n /**\n * MCP Server options.\n */\n mcp?: {\n handlerOptions?: MCPHandlerOptions\n /**\n * Add custom MCP Prompts.\n */\n prompts?: {\n /**\n * Set the args schema of the prompt. This is the args schema that will be passed to the prompt. This is used by MCP clients to determine the arguments that will be passed to the prompt.\n */\n argsSchema: z.ZodRawShape\n /**\n * Set the description of the prompt. This is used by MCP clients to determine when to use the prompt.\n */\n description: string\n /**\n * Set the handler of the prompt. This is the function that will be called when the prompt is used.\n */\n handler: (\n args: Record<string, unknown>,\n req: PayloadRequest,\n _extra: unknown,\n ) =>\n | {\n messages: Array<{\n content: {\n text: string\n type: 'text'\n }\n role: 'assistant' | 'user'\n }>\n }\n | Promise<{\n messages: Array<{\n content: {\n text: string\n type: 'text'\n }\n role: 'assistant' | 'user'\n }>\n }>\n /**\n * Set the function name of the prompt.\n */\n name: string\n /**\n * Set the title of the prompt. LLMs will interperate the title to determine when to use the prompt.\n */\n title: string\n }[]\n\n /**\n * Add custom MCP Resource.\n */\n resources?: {\n /**\n * Set the description of the resource. This is used by MCP clients to determine when to use the resource.\n * example: 'Data is a resource that contains special data.'\n */\n description: string\n /**\n * Set the handler of the resource. This is the function that will be called when the resource is used.\n * The handler can have either 3 arguments (when no args are passed) or 4 arguments (when args are passed).\n */\n handler: (...args: any[]) =>\n | {\n contents: Array<{\n text: string\n uri: string\n }>\n }\n | Promise<{\n contents: Array<{\n text: string\n uri: string\n }>\n }>\n /**\n * Set the mime type of the resource.\n * example: 'text/plain'\n */\n mimeType: string\n /**\n * Set the function name of the resource.\n * example: 'data'\n */\n name: string\n /**\n * Set the title of the resource. LLMs will interperate the title to determine when to use the resource.\n * example: 'Data'\n */\n title: string\n /**\n * Set the uri of the resource.\n * example: 'data://app'\n */\n uri: ResourceTemplate | string\n }[]\n serverOptions?: MCPServerOptions\n /**\n * Add custom MCP Tools.\n */\n tools?: {\n /**\n * Set the description of the tool. This is used by MCP clients to determine when to use the tool.\n */\n description: string\n /**\n * Set the handler of the tool. This is the function that will be called when the tool is used.\n */\n handler: (\n args: Record<string, unknown>,\n req: PayloadRequest,\n _extra: unknown,\n ) =>\n | {\n content: Array<{\n text: string\n type: 'text'\n }>\n role?: string\n }\n | Promise<{\n content: Array<{\n text: string\n type: 'text'\n }>\n role?: string\n }>\n /**\n * Set the name of the tool. This is the name that will be used to identify the tool. LLMs will interperate the name to determine when to use the tool.\n */\n name: string\n /**\n * Set the parameters of the tool. This is the parameters that will be passed to the tool.\n */\n parameters: z.ZodRawShape\n }[]\n }\n\n /**\n * Override the API key collection.\n * This allows you to add fields to the API key collection or modify the collection in any way you want.\n * @param collection - The API key collection.\n * @returns The modified API key collection.\n */\n overrideApiKeyCollection?: (collection: CollectionConfig) => CollectionConfig\n\n /**\n * Override the authentication method.\n * This allows you to use a custom authentication method instead of the default API key authentication.\n * @param req - The request object.\n * @returns The MCP access settings.\n */\n overrideAuth?: (\n req: PayloadRequest,\n getDefaultMcpAccessSettings: (overrideApiKey?: null | string) => Promise<MCPAccessSettings>,\n ) => MCPAccessSettings | Promise<MCPAccessSettings>\n\n /**\n * Set the users collection that API keys should be associated with.\n */\n userCollection?: CollectionConfig | string\n}\n\n/**\n * MCP Handler options.\n */\nexport type MCPHandlerOptions = {\n /**\n * Set the base path of the MCP handler. This is the path that will be used to access the MCP handler.\n * @default /api\n */\n basePath?: string\n /**\n * Set the maximum duration of the MCP handler. This is the maximum duration that the MCP handler will run for.\n * @default 60\n */\n maxDuration?: number\n /**\n * Set the Redis URL for the MCP handler. This is the URL that will be used to access the Redis server.\n * @default process.env.REDIS_URL\n * INFO: Disabled until developer clarity is reached for server side streaming and we have an auth pattern for all SSE patterns\n */\n // redisUrl?: string\n /**\n * Set verbose logging.\n * @default false\n */\n verboseLogs?: boolean\n}\n\n/**\n * MCP Server options.\n */\nexport type MCPServerOptions = {\n /**\n * Set the server info of the MCP server.\n */\n serverInfo?: {\n /**\n * Set the name of the MCP server.\n * @default 'Payload MCP Server'\n */\n name: string\n /**\n * Set the version of the MCP server.\n * @default '1.0.0'\n */\n version: string\n }\n}\n\nexport type MCPAccessSettings = {\n auth?: {\n auth?: boolean\n forgotPassword?: boolean\n login?: boolean\n resetPassword?: boolean\n unlock?: boolean\n verify?: boolean\n }\n collections?: {\n create?: boolean\n delete?: boolean\n find?: boolean\n update?: boolean\n }\n config?: {\n find?: boolean\n update?: boolean\n }\n jobs?: {\n create?: boolean\n run?: boolean\n update?: boolean\n }\n 'payload-mcp-prompt'?: Record<string, boolean>\n 'payload-mcp-resource'?: Record<string, boolean>\n 'payload-mcp-tool'?: Record<string, boolean>\n user: TypedUser\n} & Record<string, unknown>\n\nexport type FieldDefinition = {\n description?: string\n name: string\n options?: { label: string; value: string }[]\n position?: 'main' | 'sidebar'\n required?: boolean\n type: string\n}\n\nexport type FieldModification = {\n changes: {\n description?: string\n options?: { label: string; value: string }[]\n position?: 'main' | 'sidebar'\n required?: boolean\n type?: string\n }\n fieldName: string\n}\n\nexport type CollectionConfigUpdates = {\n access?: {\n create?: string\n delete?: string\n read?: string\n update?: string\n }\n description?: string\n slug?: string\n timestamps?: boolean\n versioning?: boolean\n}\n\nexport type AdminConfig = {\n avatar?: string\n css?: string\n dateFormat?: string\n inactivityRoute?: string\n livePreview?: {\n breakpoints?: Array<{\n height: number\n label: string\n name: string\n width: number\n }>\n }\n logoutRoute?: string\n meta?: {\n favicon?: string\n ogImage?: string\n titleSuffix?: string\n }\n user?: string\n}\n\nexport type DatabaseConfig = {\n connectOptions?: string\n type?: 'mongodb' | 'postgres'\n url?: string\n}\n\nexport type PluginUpdates = {\n add?: string[]\n remove?: string[]\n}\n\nexport type GeneralConfig = {\n cookiePrefix?: string\n cors?: string\n csrf?: string\n graphQL?: {\n disable?: boolean\n schemaOutputFile?: string\n }\n rateLimit?: {\n max?: number\n skip?: string\n window?: number\n }\n secret?: string\n serverURL?: string\n typescript?: {\n declare?: boolean\n outputFile?: string\n }\n}\n\nexport interface SchemaField {\n description?: string\n name: string\n options?: string[]\n required?: boolean\n type: string\n}\n\nexport interface TaskSequenceItem {\n description?: string\n retries?: number\n taskId: string\n taskSlug: string\n timeout?: number\n}\n\nexport interface JobConfigUpdate {\n description?: string\n queue?: string\n retries?: number\n timeout?: number\n}\n"],"names":[],"mappings":"AAidA,WAKC"}
@@ -1 +1 @@
1
- {"version":3,"file":"convertCollectionSchemaToZod.d.ts","sourceRoot":"","sources":["../../src/utils/convertCollectionSchemaToZod.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,aAAa,CAAA;AAM9C,eAAO,MAAM,4BAA4B,WAAY,WAAW,QA4B/D,CAAA"}
1
+ {"version":3,"file":"convertCollectionSchemaToZod.d.ts","sourceRoot":"","sources":["../../src/utils/convertCollectionSchemaToZod.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,aAAa,CAAA;AAM9C,eAAO,MAAM,4BAA4B,WAAY,WAAW,QA2B/D,CAAA"}
@@ -23,8 +23,7 @@ export const convertCollectionSchemaToZod = (schema)=>{
23
23
  * 4. The resulting Zod schema is used only for parameter validation in MCP tools, not for data processing
24
24
  * 5. No user input or external data is involved in the schema generation process
25
25
  */ // eslint-disable-next-line @typescript-eslint/no-implied-eval
26
- const zodSchema = new Function('z', `return ${transpileResult.outputText}`)(z);
27
- return zodSchema;
26
+ return new Function('z', `return ${transpileResult.outputText}`)(z);
28
27
  };
29
28
 
30
29
  //# sourceMappingURL=convertCollectionSchemaToZod.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/utils/convertCollectionSchemaToZod.ts"],"sourcesContent":["import type { JSONSchema4 } from 'json-schema'\n\nimport { jsonSchemaToZod } from 'json-schema-to-zod'\nimport * as ts from 'typescript'\nimport { z } from 'zod'\n\nexport const convertCollectionSchemaToZod = (schema: JSONSchema4) => {\n // Remove properties that should not be included in the Zod schema\n delete schema?.properties?.createdAt\n delete schema?.properties?.updatedAt\n\n const zodSchemaAsString = jsonSchemaToZod(schema)\n\n // Transpile TypeScript to JavaScript\n const transpileResult = ts.transpileModule(zodSchemaAsString, {\n compilerOptions: {\n module: ts.ModuleKind.CommonJS,\n removeComments: true,\n strict: false,\n target: ts.ScriptTarget.ES2018,\n },\n })\n\n /**\n * This Function evaluation is safe because:\n * 1. The input schema comes from Payload's collection configuration, which is controlled by the application developer\n * 2. The jsonSchemaToZod library converts JSON Schema to Zod schema definitions, producing only type validation code\n * 3. The transpiled output contains only Zod schema definitions (z.string(), z.number(), etc.) - no executable logic\n * 4. The resulting Zod schema is used only for parameter validation in MCP tools, not for data processing\n * 5. No user input or external data is involved in the schema generation process\n */\n // eslint-disable-next-line @typescript-eslint/no-implied-eval\n const zodSchema = new Function('z', `return ${transpileResult.outputText}`)(z)\n return zodSchema\n}\n"],"names":["jsonSchemaToZod","ts","z","convertCollectionSchemaToZod","schema","properties","createdAt","updatedAt","zodSchemaAsString","transpileResult","transpileModule","compilerOptions","module","ModuleKind","CommonJS","removeComments","strict","target","ScriptTarget","ES2018","zodSchema","Function","outputText"],"mappings":"AAEA,SAASA,eAAe,QAAQ,qBAAoB;AACpD,YAAYC,QAAQ,aAAY;AAChC,SAASC,CAAC,QAAQ,MAAK;AAEvB,OAAO,MAAMC,+BAA+B,CAACC;IAC3C,kEAAkE;IAClE,OAAOA,QAAQC,YAAYC;IAC3B,OAAOF,QAAQC,YAAYE;IAE3B,MAAMC,oBAAoBR,gBAAgBI;IAE1C,qCAAqC;IACrC,MAAMK,kBAAkBR,GAAGS,eAAe,CAACF,mBAAmB;QAC5DG,iBAAiB;YACfC,QAAQX,GAAGY,UAAU,CAACC,QAAQ;YAC9BC,gBAAgB;YAChBC,QAAQ;YACRC,QAAQhB,GAAGiB,YAAY,CAACC,MAAM;QAChC;IACF;IAEA;;;;;;;GAOC,GACD,8DAA8D;IAC9D,MAAMC,YAAY,IAAIC,SAAS,KAAK,CAAC,OAAO,EAAEZ,gBAAgBa,UAAU,EAAE,EAAEpB;IAC5E,OAAOkB;AACT,EAAC"}
1
+ {"version":3,"sources":["../../src/utils/convertCollectionSchemaToZod.ts"],"sourcesContent":["import type { JSONSchema4 } from 'json-schema'\n\nimport { jsonSchemaToZod } from 'json-schema-to-zod'\nimport * as ts from 'typescript'\nimport { z } from 'zod'\n\nexport const convertCollectionSchemaToZod = (schema: JSONSchema4) => {\n // Remove properties that should not be included in the Zod schema\n delete schema?.properties?.createdAt\n delete schema?.properties?.updatedAt\n\n const zodSchemaAsString = jsonSchemaToZod(schema)\n\n // Transpile TypeScript to JavaScript\n const transpileResult = ts.transpileModule(zodSchemaAsString, {\n compilerOptions: {\n module: ts.ModuleKind.CommonJS,\n removeComments: true,\n strict: false,\n target: ts.ScriptTarget.ES2018,\n },\n })\n\n /**\n * This Function evaluation is safe because:\n * 1. The input schema comes from Payload's collection configuration, which is controlled by the application developer\n * 2. The jsonSchemaToZod library converts JSON Schema to Zod schema definitions, producing only type validation code\n * 3. The transpiled output contains only Zod schema definitions (z.string(), z.number(), etc.) - no executable logic\n * 4. The resulting Zod schema is used only for parameter validation in MCP tools, not for data processing\n * 5. No user input or external data is involved in the schema generation process\n */\n // eslint-disable-next-line @typescript-eslint/no-implied-eval\n return new Function('z', `return ${transpileResult.outputText}`)(z)\n}\n"],"names":["jsonSchemaToZod","ts","z","convertCollectionSchemaToZod","schema","properties","createdAt","updatedAt","zodSchemaAsString","transpileResult","transpileModule","compilerOptions","module","ModuleKind","CommonJS","removeComments","strict","target","ScriptTarget","ES2018","Function","outputText"],"mappings":"AAEA,SAASA,eAAe,QAAQ,qBAAoB;AACpD,YAAYC,QAAQ,aAAY;AAChC,SAASC,CAAC,QAAQ,MAAK;AAEvB,OAAO,MAAMC,+BAA+B,CAACC;IAC3C,kEAAkE;IAClE,OAAOA,QAAQC,YAAYC;IAC3B,OAAOF,QAAQC,YAAYE;IAE3B,MAAMC,oBAAoBR,gBAAgBI;IAE1C,qCAAqC;IACrC,MAAMK,kBAAkBR,GAAGS,eAAe,CAACF,mBAAmB;QAC5DG,iBAAiB;YACfC,QAAQX,GAAGY,UAAU,CAACC,QAAQ;YAC9BC,gBAAgB;YAChBC,QAAQ;YACRC,QAAQhB,GAAGiB,YAAY,CAACC,MAAM;QAChC;IACF;IAEA;;;;;;;GAOC,GACD,8DAA8D;IAC9D,OAAO,IAAIC,SAAS,KAAK,CAAC,OAAO,EAAEX,gBAAgBY,UAAU,EAAE,EAAEnB;AACnE,EAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@payloadcms/plugin-mcp",
3
- "version": "3.65.0-internal.ef3958a",
3
+ "version": "3.65.0",
4
4
  "description": "MCP (Model Context Protocol) capabilities with Payload",
5
5
  "keywords": [
6
6
  "plugin",
@@ -45,10 +45,10 @@
45
45
  },
46
46
  "devDependencies": {
47
47
  "@payloadcms/eslint-config": "3.28.0",
48
- "payload": "3.65.0-internal.ef3958a"
48
+ "payload": "3.65.0"
49
49
  },
50
50
  "peerDependencies": {
51
- "payload": "3.65.0-internal.ef3958a"
51
+ "payload": "3.65.0"
52
52
  },
53
53
  "homepage:": "https://payloadcms.com",
54
54
  "scripts": {
@@ -57,7 +57,7 @@ export const initializeMCPHandler = (pluginOptions: PluginMCPServerConfig) => {
57
57
  payload.logger.info('[payload-mcp] API Key is valid')
58
58
  }
59
59
 
60
- return docs[0] as MCPAccessSettings
60
+ return docs[0] as unknown as MCPAccessSettings
61
61
  }
62
62
 
63
63
  const mcpAccessSettings = pluginOptions.overrideAuth
@@ -43,8 +43,29 @@ export const getMCPHandler = (
43
43
  const { payload } = req
44
44
  const configSchema = configToJSONSchema(payload.config)
45
45
 
46
+ // Handler wrapper that injects req before the _extra argument
47
+ const wrapHandler = (handler: (...args: any[]) => any) => {
48
+ return async (...args: any[]) => {
49
+ const _extra = args[args.length - 1]
50
+ const handlerArgs = args.slice(0, -1)
51
+ return await handler(...handlerArgs, req, _extra)
52
+ }
53
+ }
54
+
55
+ const payloadToolHandler = (
56
+ handler: NonNullable<NonNullable<PluginMCPServerConfig['mcp']>['tools']>[number]['handler'],
57
+ ) => wrapHandler(handler)
58
+
59
+ const payloadPromptHandler = (
60
+ handler: NonNullable<NonNullable<PluginMCPServerConfig['mcp']>['prompts']>[number]['handler'],
61
+ ) => wrapHandler(handler)
62
+
63
+ const payloadResourceHandler = (
64
+ handler: NonNullable<NonNullable<PluginMCPServerConfig['mcp']>['resources']>[number]['handler'],
65
+ ) => wrapHandler(handler)
66
+
46
67
  // User
47
- const user = mcpAccessSettings.user as TypedUser
68
+ const user = mcpAccessSettings.user
48
69
 
49
70
  // MCP Server and Handler Options
50
71
  const MCPOptions = pluginOptions.mcp || {}
@@ -202,7 +223,13 @@ export const getMCPHandler = (
202
223
  registerTool(
203
224
  isToolEnabled,
204
225
  tool.name,
205
- () => server.tool(tool.name, tool.description, tool.parameters, tool.handler),
226
+ () =>
227
+ server.tool(
228
+ tool.name,
229
+ tool.description,
230
+ tool.parameters,
231
+ payloadToolHandler(tool.handler),
232
+ ),
206
233
  payload,
207
234
  useVerboseLogs,
208
235
  )
@@ -222,7 +249,7 @@ export const getMCPHandler = (
222
249
  description: prompt.description,
223
250
  title: prompt.title,
224
251
  },
225
- prompt.handler,
252
+ payloadPromptHandler(prompt.handler),
226
253
  )
227
254
  if (useVerboseLogs) {
228
255
  payload.logger.info(`[payload-mcp] ✅ Prompt: ${prompt.title} Registered.`)
@@ -248,7 +275,7 @@ export const getMCPHandler = (
248
275
  mimeType: resource.mimeType,
249
276
  title: resource.title,
250
277
  },
251
- resource.handler,
278
+ payloadResourceHandler(resource.handler),
252
279
  )
253
280
 
254
281
  if (useVerboseLogs) {
@@ -202,14 +202,14 @@ function getWorkflowConfig(importedModule: Record<string, unknown>): undefined |
202
202
  * Validate collection configuration structure
203
203
  */
204
204
  function validateCollectionConfig(config: CollectionConfig): ValidationResult<CollectionConfig> {
205
- if (!config || typeof config !== 'object') {
205
+ if (!config) {
206
206
  return {
207
207
  error: 'Collection config is not a valid object',
208
208
  success: false,
209
209
  }
210
210
  }
211
211
 
212
- if (!config.slug || typeof config.slug !== 'string') {
212
+ if (!config.slug) {
213
213
  return {
214
214
  error: 'Collection config must have a valid slug property',
215
215
  success: false,
@@ -220,7 +220,7 @@ function validateCollectionConfig(config: CollectionConfig): ValidationResult<Co
220
220
  if (config.fields) {
221
221
  for (let i = 0; i < config.fields.length; i++) {
222
222
  const field = config.fields[i] as Record<string, unknown>
223
- if (!field || typeof field !== 'object') {
223
+ if (!field) {
224
224
  return {
225
225
  error: `Field at index ${i} is not a valid object`,
226
226
  success: false,
@@ -228,7 +228,7 @@ function validateCollectionConfig(config: CollectionConfig): ValidationResult<Co
228
228
  }
229
229
 
230
230
  // Check if field has type property
231
- if ('type' in field && field.type && typeof field.type !== 'string') {
231
+ if ('type' in field && field.type) {
232
232
  return {
233
233
  error: `Field at index ${i} has invalid type property`,
234
234
  success: false,
@@ -244,21 +244,21 @@ function validateCollectionConfig(config: CollectionConfig): ValidationResult<Co
244
244
  * Validate task configuration structure
245
245
  */
246
246
  function validateTaskConfig(config: TaskConfig): ValidationResult<TaskConfig> {
247
- if (!config || typeof config !== 'object') {
247
+ if (!config) {
248
248
  return {
249
249
  error: 'Task config is not a valid object',
250
250
  success: false,
251
251
  }
252
252
  }
253
253
 
254
- if (!config.slug || typeof config.slug !== 'string') {
254
+ if (!config.slug) {
255
255
  return {
256
256
  error: 'Task config must have a valid slug property',
257
257
  success: false,
258
258
  }
259
259
  }
260
260
 
261
- if (!config.handler || typeof config.handler !== 'function') {
261
+ if (!config.handler) {
262
262
  return {
263
263
  error: 'Task config must have a valid handler function',
264
264
  success: false,
@@ -266,7 +266,7 @@ function validateTaskConfig(config: TaskConfig): ValidationResult<TaskConfig> {
266
266
  }
267
267
 
268
268
  // Validate optional properties
269
- if (config.retries !== undefined && (typeof config.retries !== 'number' || config.retries < 0)) {
269
+ if (config.retries !== undefined && config.retries < 0) {
270
270
  return {
271
271
  error: 'Task config retries must be a non-negative number',
272
272
  success: false,
@@ -277,21 +277,21 @@ function validateTaskConfig(config: TaskConfig): ValidationResult<TaskConfig> {
277
277
  if (config.inputSchema && Array.isArray(config.inputSchema)) {
278
278
  for (let i = 0; i < config.inputSchema.length; i++) {
279
279
  const field = config.inputSchema[i]
280
- if (!field || typeof field !== 'object') {
280
+ if (!field) {
281
281
  return {
282
282
  error: `Input schema field at index ${i} is not a valid object`,
283
283
  success: false,
284
284
  }
285
285
  }
286
286
 
287
- if (!field.name || typeof field.name !== 'string') {
287
+ if (!field.name) {
288
288
  return {
289
289
  error: `Input schema field at index ${i} must have a valid name property`,
290
290
  success: false,
291
291
  }
292
292
  }
293
293
 
294
- if (!field.type || typeof field.type !== 'string') {
294
+ if (!field.type) {
295
295
  return {
296
296
  error: `Input schema field at index ${i} must have a valid type property`,
297
297
  success: false,
@@ -303,21 +303,21 @@ function validateTaskConfig(config: TaskConfig): ValidationResult<TaskConfig> {
303
303
  if (config.outputSchema && Array.isArray(config.outputSchema)) {
304
304
  for (let i = 0; i < config.outputSchema.length; i++) {
305
305
  const field = config.outputSchema[i]
306
- if (!field || typeof field !== 'object') {
306
+ if (!field) {
307
307
  return {
308
308
  error: `Output schema field at index ${i} is not a valid object`,
309
309
  success: false,
310
310
  }
311
311
  }
312
312
 
313
- if (!field.name || typeof field.name !== 'string') {
313
+ if (!field.name) {
314
314
  return {
315
315
  error: `Output schema field at index ${i} must have a valid name property`,
316
316
  success: false,
317
317
  }
318
318
  }
319
319
 
320
- if (!field.type || typeof field.type !== 'string') {
320
+ if (!field.type) {
321
321
  return {
322
322
  error: `Output schema field at index ${i} must have a valid type property`,
323
323
  success: false,
@@ -333,21 +333,21 @@ function validateTaskConfig(config: TaskConfig): ValidationResult<TaskConfig> {
333
333
  * Validate workflow configuration structure
334
334
  */
335
335
  function validateWorkflowConfig(config: WorkflowConfig): ValidationResult<WorkflowConfig> {
336
- if (!config || typeof config !== 'object') {
336
+ if (!config) {
337
337
  return {
338
338
  error: 'Workflow config is not a valid object',
339
339
  success: false,
340
340
  }
341
341
  }
342
342
 
343
- if (!config.slug || typeof config.slug !== 'string') {
343
+ if (!config.slug) {
344
344
  return {
345
345
  error: 'Workflow config must have a valid slug property',
346
346
  success: false,
347
347
  }
348
348
  }
349
349
 
350
- if (!config.handler || typeof config.handler !== 'function') {
350
+ if (!config.handler) {
351
351
  return {
352
352
  error: 'Workflow config must have a valid handler function',
353
353
  success: false,
@@ -355,14 +355,14 @@ function validateWorkflowConfig(config: WorkflowConfig): ValidationResult<Workfl
355
355
  }
356
356
 
357
357
  // Validate optional properties
358
- if (config.queue && typeof config.queue !== 'string') {
358
+ if (config.queue) {
359
359
  return {
360
360
  error: 'Workflow config queue must be a string',
361
361
  success: false,
362
362
  }
363
363
  }
364
364
 
365
- if (config.retries !== undefined && (typeof config.retries !== 'number' || config.retries < 0)) {
365
+ if (config.retries !== undefined && config.retries < 0) {
366
366
  return {
367
367
  error: 'Workflow config retries must be a non-negative number',
368
368
  success: false,
@@ -373,21 +373,21 @@ function validateWorkflowConfig(config: WorkflowConfig): ValidationResult<Workfl
373
373
  if (config.inputSchema && Array.isArray(config.inputSchema)) {
374
374
  for (let i = 0; i < config.inputSchema.length; i++) {
375
375
  const field = config.inputSchema[i]
376
- if (!field || typeof field !== 'object') {
376
+ if (!field) {
377
377
  return {
378
378
  error: `Input schema field at index ${i} is not a valid object`,
379
379
  success: false,
380
380
  }
381
381
  }
382
382
 
383
- if (!field.name || typeof field.name !== 'string') {
383
+ if (!field.name) {
384
384
  return {
385
385
  error: `Input schema field at index ${i} must have a valid name property`,
386
386
  success: false,
387
387
  }
388
388
  }
389
389
 
390
- if (!field.type || typeof field.type !== 'string') {
390
+ if (!field.type) {
391
391
  return {
392
392
  error: `Input schema field at index ${i} must have a valid type property`,
393
393
  success: false,