内容管理工具添加福利群:解决AI开发者的「MCP实战痛点」
github这是一个社区驱动的服务器!Contentful 已经发布了一个官方服务器,您可以在这里找到:官方服务器
一个与 Contentful 的内容管理 API 集成的 MCP 服务器实现,提供全面的内容管理功能。
为了防止 LLM 中的上下文窗口溢出,列表操作(如 search_entries 和 list_assets)每次请求限制为 3 个项目。每个响应包括:
此分页系统允许 LLM 在处理大数据集时保持上下文窗口限制。
批量操作功能提供了同时管理多个内容项的高效方式:
这些批量操作工具非常适合内容迁移、大规模更新或批量发布工作流。
评论支持线程功能,以启用结构化对话并绕过 512 字符限制:
create_comment 中使用 parent 参数回复现有评论示例用法:
create_comment 带有 entryId、body 和 statuscreate_comment 带有 entryId、body、status 和 parent(您要回复的评论的 ID)parent 回复线程中的任何评论bulk_publish,但从交付 API 中移除内容。该项目包含一个 MCP 检查器工具,有助于开发和调试:
npm run inspect 启动检查器,您可以通过访问 http://localhost:5173 打开检查器npm run inspect:watch 在文件更改时自动重新启动检查器该项目还包含一个 npm run dev 命令,该命令在每次更改时重新构建并重新加载 MCP 服务器。
这些变量也可以作为参数设置
CONTENTFUL_HOST / --host:Contentful 管理 API 端点(默认为 https://api.contentful.com)CONTENTFUL_MANAGEMENT_ACCESS_TOKEN / --management-token:您的内容管理 API 令牌ENABLE_HTTP_SERVER / --http:设置为 "true" 以启用 HTTP/SSE 模式HTTP_PORT / --port:HTTP 服务器端口(默认:3000)HTTP_HOST / --http-host:HTTP 服务器主机(默认:localhost)您可以设置 spaceId 和 EnvironmentId 的范围,以确保 LLM 仅在定义的空间/环境 ID 上执行操作。这主要是为了支持在特定空间内操作的代理。如果同时设置了 SPACE_ID 和 ENVIRONMENT_ID 环境变量,工具将不会报告需要这些值,并且处理程序将使用环境变量执行 CMA 操作。您还将失去对空间处理程序中工具的访问权限,因为这些工具是跨空间的。您还可以通过使用参数 --space-id 和 --environment-id 添加 SPACE_ID 和 ENVIRONMENT_ID。
您还可以利用 应用身份 来处理身份验证,而不是提供管理令牌。您必须设置并安装一个 Contentful 应用,并在调用 MCP 服务器时设置以下参数:
--app-id = 提供 AppToken 的应用 ID--private-key = 您在用户界面中创建的与应用绑定的私钥--space-id = 应用安装的空间 ID--environment-id = 应用安装的环境 ID(在空间内)通过这些值,MCP 服务器将请求一个临时的 AppToken 以在定义的空间/环境 ID 中执行内容操作。这在将 MCP 服务器用作 MCP 客户端(如聊天代理)的后端系统中尤其有用。
您不需要克隆此仓库来使用此 MCP,您只需将其添加到您的 claude_desktop_config.json 中:
添加或编辑 ~/Library/Application Support/Claude/claude_desktop_config.json 并添加以下行:
{
"mcpServers": {
"contentful": {
"command": "npx",
"args": ["-y", "@ivotoby/contentful-management-mcp-server"],
"env": {
"CONTENTFUL_MANAGEMENT_ACCESS_TOKEN": "<您的 CMA 令牌>"
}
}
}
}

如果您的 MCPClient 不支持设置环境变量,您也可以使用参数设置管理令牌,如下所示:
{
"mcpServers": {
"contentful": {
"command": "npx",
"args": [
"-y",
"@ivotoby/contentful-management-mcp-server",
"--management-token",
"<您的令牌>",
"--host",
"http://api.contentful.com"
]
}
}
}

要通过 Smithery 自动为 Claude Desktop 安装 Contentful Management Server,请执行以下命令:
npx -y @smithery/cli install @ivotoby/contentful-management-mcp-server --client claude
如果你想贡献代码并测试 Claude 对你的修改的反应;
npm run dev,这将启动监听器,每次更改时都会重新构建 MCP 服务器claude_desktop_config.json 以直接引用项目,例如:{ "mcpServers": { "contentful": { "command": "node", "args": ["/Users/ivo/workspace/contentful-mcp/bin/mcp-server.js"], "env": { "CONTENTFUL_MANAGEMENT_ACCESS_TOKEN": "<你的 CMA Token>" } } } }
这将允许你直接在 Claude 中测试 MCP 服务器的任何修改,但是;如果你添加了新的工具/资源,你需要重新启动 Claude Desktop。
MCP 服务器支持两种传输模式:
默认的传输模式使用标准输入/输出流进行通信。这非常适合与支持 stdio 传输的 MCP 客户端(如 Claude Desktop)集成。
要使用 stdio 模式,只需运行服务器时不带 --http 标志:
npx -y contentful-mcp --management-token YOUR_TOKEN
# 或者
npx -y @ivotoby/contentful-management-mcp-server --management-token YOUR_TOKEN

服务器还支持 MCP 协议中定义的 StreamableHTTP 传输。此模式适用于基于 Web 的集成或将服务器作为独立服务运行。
要使用 StreamableHTTP 模式,请使用 --http 标志运行:
npx -y contentful-mcp --management-token YOUR_TOKEN --http --port 3000
# 或者
npx -y @ivotoby/contentful-management-mcp-server --management-token YOUR_TOKEN --http --port 3000

该实现遵循标准的 MCP 协议规范,允许任何 MCP 客户端连接到服务器而无需特殊处理。
服务器实现了全面的错误处理,包括:
MIT 许可证
此 MCP 服务器使 Claude(或可以消费 MCP 资源的其他代理)能够更新、删除内容、空间和内容模型。因此,请确保你允许 Claude 对你的 Contentful 空间执行的操作!
此 MCP 服务器尚未得到 Contentful 的官方支持。