zentao-mcp-server
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@zentao-mcp-serverlist my unresolved bugs"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
zentao-mcp-server(自建)
目标
提供一个可运行的 MCP Server(stdio),连接你的禅道 RESTful API v1。
最小功能:自动获取/缓存 Token + 常用 bug 工具。
非目标
不在仓库内存任何密钥/Token。
不暴露无边界的通用 REST 写接口。
不保证覆盖你禅道的全部 API;优先支持高频 bug 流程,再按你的流程补工具。
依赖
Node.js 18+(需要内置
fetch)
License
MIT - 详见 LICENSE 文件
配置
复制 .env.example 为 .env 并填写:
ZENTAO_BASE_URLZENTAO_ACCOUNTZENTAO_PASSWORD(可选)
ZENTAO_PRODUCT_ID:你的禅道实例若报Need product id时设置(可选)
ZENTAO_PROJECT_SET_ID:你的 bug 若在项目集视角,设置项目集 ID(可选)
ZENTAO_MY_BUGS_PATH:我的 bug 专用接口路径(如/my/bug)(可选)
ZENTAO_BUGS_FALLBACK_PATHS:bug 列表回退路径(逗号分隔)(可选)
ZENTAO_PROJECT_SET_BUGS_PATHS:项目集 bug 路径模板(支持{projectSetId})
注意:不同禅道版本/部署方式的 token 端点与返回结构可能不同;可通过
ZENTAO_TOKEN_PATH/ZENTAO_API_PREFIX调整。默认情况下不需要配置
ZENTAO_API_PREFIX(默认值是/api.php/v1)。安全约束:
ZENTAO_API_PREFIX/ZENTAO_TOKEN_PATH只支持相对路径;默认要求ZENTAO_BASE_URL使用 HTTPS。ZENTAO_BASE_URL可为根路径或子目录部署地址(如https://zentao.example.com/zentao)。
安装与运行
npm i
cp .env.example .env
npm startnpm 安装后的运行
发布到 npm 后,推荐用 npx 启动(适合 MCP 客户端配置):
npx -y @aipper/zentao-mcp-server验证(不依赖 MCP 客户端)
npm i
cp .env.example .env
set -a; source .env; set +a
npm run smoke期望结果:
输出一行
token: xxxx…yyyy source: ...输出
GET /projects status: 200(或你的禅道实际返回码)
Claude Desktop / Cursor 示例(stdio)
优先使用 npx(npm 发布版):
{
"mcpServers": {
"zentao": {
"command": "npx",
"args": ["-y", "@aipper/zentao-mcp-server"],
"env": {
"ZENTAO_BASE_URL": "https://zentao.example.com",
"ZENTAO_ACCOUNT": "your_account",
"ZENTAO_PASSWORD": "your_password"
}
}
}
}本地源码调试可继续用 node src/index.js:
示例(Claude Desktop 的 mcpServers 风格,按你的客户端实际字段为准):
{
"mcpServers": {
"zentao": {
"command": "node",
"args": ["src/index.js"],
"cwd": "/ABS/PATH/TO/zentao",
"env": {
"ZENTAO_BASE_URL": "https://zentao.example.com",
"ZENTAO_ACCOUNT": "your_account",
"ZENTAO_PASSWORD": "your_password"
}
}
}
}常见错误(-32000)
-32000 通常是客户端侧“通用 MCP 调用失败”映射码,优先检查:
env是否完整传入(尤其是ZENTAO_BASE_URL/ZENTAO_ACCOUNT/ZENTAO_PASSWORD)。默认要求 HTTPS;如果你的实例只能走 HTTP,必须显式设置
ZENTAO_ALLOW_INSECURE_HTTP=true,且只建议临时内网调试使用。若报
Need product id,请设置ZENTAO_PRODUCT_ID,或在get_my_bugs传productId。若你的 bug 在“项目集/我的视角”而非产品,建议设置
ZENTAO_PROJECT_SET_ID,并配置ZENTAO_MY_BUGS_PATH=/my/bug。项目集场景下,优先直接调用
get_my_bugs并传projectSetId,必要时再显式传path="/my/bug";不要先依赖list_my_projects找项目。有些项目集本身没有创建实际项目,但仍然存在“我的 bug”;这类数据可能不会出现在
list_my_projects结果里。get_my_bugs会按候选路径回退(包含项目集路径);即使首个路径返回空列表也会继续尝试,并会把多端点结果合并去重。get_my_bugs.total表示最终“我的 bug”总数;若需排查底层一共扫描了多少条,可看raw.scannedTotal。排查时看工具返回里的
raw.triedPaths/raw.paths,可确认每条路径的返回码与命中数量。ZENTAO_API_PREFIX/ZENTAO_TOKEN_PATH是否和你的禅道实例一致,且使用相对路径。MCP 客户端是否真的在执行
npx -y @aipper/zentao-mcp-server(而不是旧的本地命令)。客户端日志中是否有启动报错(如找不到命令、401、超时)。
已实现工具
get_token:获取/刷新 token(始终只回显脱敏后的 token 摘要)list_my_projects:示例:列出“我参与的项目”(字段匹配基于常见返回结构,可能需按你的实例微调;不适合作为项目集 bug 的唯一发现入口)get_my_bugs:获取“指派给我”的 bug(支持status/keyword/limit/page/productId/projectSetId,默认路径/bugs;path仅允许/bugs、/my/bug、/my/bugs)get_bug_detail:按id获取 bug 详情(固定读取/bugs/{id};返回安全裁剪后的 bug 摘要与同源图片链接,不直接透传外部图片地址或原始附件外链)resolve_bug:按id处理单个 bug 状态(默认resolution=fixed,支持solution解决说明)batch_resolve_my_bugs:批量处理“我的 bug”(默认筛选status=active,支持productId/projectSetId,默认遇错即停,maxItems上限 100)close_bug:按id关闭 bugverify_bug:验证结果处理(pass=关闭,fail=激活)comment_bug:按id添加备注
示例参数:
resolve_bug:{"id":123,"resolution":"fixed","comment":"根因已定位,已按最新字段映射调整处理逻辑"}resolve_bug(建议):{"id":123,"resolution":"fixed","solution":"补齐分页参数为空时的默认值分支,避免空值继续进入查询构造;同时收敛异常提示,防止前端重复触发提交"}batch_resolve_my_bugs:{"status":"active","maxItems":20,"comment":"统一补充非空校验并收敛异常分支"}batch_resolve_my_bugs(建议):{"status":"active","maxItems":20,"solution":"统一修正状态切换时的判空与分支顺序,避免旧数据触发空指针;保存前增加兜底校验,异常场景改为明确提示"}get_my_bugs(项目集):{"status":"active","projectSetId":1001,"limit":50}get_my_bugs(我的):{"status":"active","path":"/my/bug","limit":50}get_my_bugs(项目集 + 我的):{"status":"active","projectSetId":1001,"path":"/my/bug","limit":50}get_my_bugs(按产品):{"status":"active","productId":1,"limit":50}close_bug:{"id":123,"comment":"验证通过,关闭"}verify_bug:{"id":123,"result":"pass","comment":"验证通过"}comment_bug:{"id":123,"comment":"已复现,正在定位根因"}
solution / comment 建议直接写“根因 + 修复思路 + 改动逻辑 + 影响范围”,不要默认写 Evidence:、Verify:、文件路径、编译命令或“已修复并自测”这类无法说明改动内容的表述。
使用建议:如果用户提到“项目集”“我的 bug”“项目列表里找不到但禅道里能看到 bug”,优先走项目集视角的 get_my_bugs,不要先让用户证明项目已创建。
安全建议
默认要求使用 HTTPS:HTTP 会明文传输账号密码和数据,存在安全风险;如确需兼容老旧实例,需显式设置
ZENTAO_ALLOW_INSECURE_HTTP=true。使用最小权限账号(仅需要的项目权限),避免使用管理员账号。
get_token不再支持回显完整 token。调试日志会自动脱敏
query、body、comment、solution等敏感字段,但仍建议仅在排查问题时临时开启。
调试
如需查看详细日志,可设置环境变量:
ZENTAO_DEBUG=true npx -y @aipper/zentao-mcp-server日志会输出到 stderr,不影响 MCP 协议通信。
发布到 npm
脚本:scripts/release-npm.sh(参考 aiws 的发布流程,默认 dry-run)。
常用命令:
# dry-run:只检查 + npm pack --dry-run,不会发布
npm run release:npm
# 自动递增版本(patch/minor/major)+ commit + tag(不发布)
npm run release:npm -- --bump patch
# 发布(会二次确认;默认自动 patch 递增)
npm run release:npm -- --publish
# 版本对齐 + commit + tag(不发布)
npm run release:npm -- --release v0.1.0注意:
若
package.json为private: true,发布前请改成false并确认包名可用。可加
--require-tag要求 HEAD 上有匹配版本的 tag。若发布时报
403,通常是包名归属问题;建议改为 scoped 包名(如@yourname/zentao-mcp-server)。
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/aipper/zentao-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server