Unified MCP server for Mingdao — v1 collaboration API + HAP gateway (worksheets, records, apps)
Project description
mdymcp
一键安装
macOS / Linux
curl -LsSf https://raw.githubusercontent.com/andyleimc-source/mdymcp/main/install.sh | sh
Windows(PowerShell)
powershell -c "irm https://raw.githubusercontent.com/andyleimc-source/mdymcp/main/install.ps1 | iex"
脚本做三件事:
- 检测
uv,没装就从官方源装上(uv 会自己拉合适的 Python,你机器上是 3.14 / 3.9 还是没装都没关系) uv tool install mdymcp- 启动
mdymcp-install交互向导 —— 浏览器 OAuth 拿 v1 凭据 → 自动跳出 HAP 授权页拿 HAP token → 让你选范围(用户级/项目级/两个都要)+ 编号多选要注册的 IDE
配置写在 ~/.mdymcp/.env(Windows: %USERPROFILE%\.mdymcp\.env),跨目录都能用。
装完后想重跑:mdymcp-install
功能
明道(Mingdao)统一 MCP Server —— 一次安装,98 个工具:
- v1 协作 API(50 个,本地实现):动态 / 日程 / 私信 / 收件箱 / 群组 / 用户 / 组织 / 个人账户
- HAP 网关(48 个,透明代理
api2.mingdao.com/mcp):应用 / 工作表 / 记录 / 角色成员 / 工作流审批 / 图表 / 选项集 / 知识库 / 地区组织
HAP 工具由远端网关动态提供;具体参数 schema 以启动时 tools/list 返回的为准。
支持的 AI IDE
| IDE | 配置文件 | 支持范围 |
|---|---|---|
| Claude Code | ~/.claude.json(通过 claude mcp add) |
用户级 + 项目级 .mcp.json |
| Codex CLI | ~/.codex/config.toml |
用户级 |
| Cursor | ~/.cursor/mcp.json |
用户级 + 项目级 .cursor/mcp.json |
| Windsurf | ~/.codeium/windsurf/mcp_config.json |
用户级 |
| Gemini Antigravity | ~/.gemini/antigravity/mcp_config.json |
用户级 |
| Trae(含国内版 Trae CN) | mac: ~/Library/Application Support/Trae/User/mcp.jsonwin: %APPDATA%\Trae\User\mcp.jsonlinux: ~/.config/Trae/User/mcp.json |
用户级 |
| VS Code(Copilot Chat) | .vscode/mcp.json |
项目级 |
mdymcp-install 会自动检测已装的 IDE,范围 + 客户端两个问题你挑完即可。手动指定:mdymcp-install --client=cursor,windsurf,trae(--client=all 全装)。
Antigravity:写完后去 IDE 里「Manage MCP Servers → Refresh」一下才能看到 mdymcp。
Cursor / Windsurf / Trae / VS Code:通常需要重启 IDE 或在 MCP 设置里手动刷新。
怎么拿 HAP 的 refresh_token 和 access_token
mdymcp-install走到 HAP 步骤时会自动开浏览器到授权页,你按下面截图复制粘贴即可,此段是备份参考。
授权页:https://www.mingdao.com/integrationConnect/69bcae07257900ec41aa2733
第 1 步:集成中心 → API 库 → HAP API(个人授权)→ 立即授权
第 2 步:「我的连接 → 授权」tab,找到刚授权的连接
第 3 步:进入连接,在账户行点 ... → 查看日志
第 4 步:在日志列表中找一条「获取 token」→ 点查看详情
第 5 步:在「返回值」标签里复制 access_token 和 refresh_token
在向导提示时分别粘到:
MD_HAP_TOKEN:← 粘access_tokenMD_HAP_REFRESH_TOKEN:← 粘refresh_token
这两个 token 只在装机时用一次(把你的账号绑定到服务端,换出长期
hap_key)。绑定完成后运行时只用hap_key+account_id,不再需要它们。
架构与 Token
┌──────────────────────┐ stdio ┌──────────────────────────────┐
│ Claude Code / Cursor │──────▶│ mdymcp.server │
│ / Codex / Windsurf / │ ├──────────────────────────────┤
│ Antigravity / Trae / │ │ [静态注册] 50 个 v1 工具 │──┐
│ VS Code Copilot │ ├──────────────────────────────┤ │HTTP
└──────────────────────┘ │ [动态注册] HapGateway │──┤
│ 48 个 HAP 工具(透明代理) │ │
└──────────────────────────────┘ ▼
┌──────────────────────────────────────┐
│ api.mingdao.com/v1/* (v1 API) │
│ api2.mingdao.com/mcp (HAP gateway) │
└──────────────────────────────────────┘
| v1 access_token | HAP token | |
|---|---|---|
| install 时 | OAuth → MD_KEY 写入 .env |
register(一次性)→ MD_HAP_KEY 写入 .env |
| 运行时 | 1 次请求:v1 token hook | 1 次请求:HAP token hook |
| 缓存 TTL | 到本地次日 00:00 | 到本地次日 00:00 |
每天首次调用时拉一次 token、缓存到本地次日 00:00;不持久化到磁盘。HAP 网关握手失败时不崩 server,仅跳过远端工具注册,v1 工具仍可用。
配置
~/.mdymcp/.env(或各 IDE 的 MCP JSON 里的 env 块):
# 必填:v1 协作 API
MD_ACCOUNT_ID=你的明道账号 UUID
MD_KEY=你的接入 key
# HAP 网关(mdymcp-install 自动写入)
MD_HAP_REFRESH_TOKEN= # install 时粘贴
MD_HAP_TOKEN= # install 时粘贴
MD_HAP_KEY= # mdymcp-install 自动写入
# 可选(通常不用动)
# MD_HOOK_URL=<自部署 v1 token hook>
# MD_HAP_REGISTER_HOOK=<自部署 HAP register hook>
# MD_HAP_TOKEN_HOOK=<自部署 HAP token hook>
# MD_APP_KEY=<自定义 OAuth app_key>
# MD_REGISTER_URL=<自定义 v1 OAuth 注册 hook>
# MD_CALLBACK_PORT=8080
故障排查
| 现象 | 解决 |
|---|---|
command not found: uv |
重开终端;或 export PATH="$HOME/.local/bin:$PATH" |
| curl / irm 拉 astral.sh 失败 | 走代理;或从 https://github.com/astral-sh/uv/releases 下载 tarball 手动解压到 ~/.local/bin/ |
Windows 下 irm | iex 报执行策略错误 |
管理员 PowerShell:Set-ExecutionPolicy -Scope CurrentUser RemoteSigned |
Missing MD_ACCOUNT_ID or MD_KEY |
重跑 mdymcp-install |
Missing MD_ACCOUNT_ID or MD_HAP_KEY |
重跑 mdymcp-install 走 HAP 步骤 |
| IDE 里看不到 mdymcp | 重启 IDE;或在 IDE 的 MCP 设置里点 Refresh。GUI 启动找不到 uvx 时改从终端启动 IDE(默认写绝对路径应该已规避这个) |
HAP token 接口返回空 |
hap_key 在服务端失效,重新拿一对 token 并重跑 mdymcp-install |
启动显示 HAP 网关工具 0 个 |
/mcp 握手失败(多半是网络);v1 工具不受影响 |
HAP 工具返回 Http Headers verification failed |
HAP 后端既有问题(Node 版也有),非 mdymcp bug |
API 参考
明道开放平台:https://open.mingdao.com/document
License
MIT
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file mdymcp-0.2.3.tar.gz.
File metadata
- Download URL: mdymcp-0.2.3.tar.gz
- Upload date:
- Size: 37.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.26 {"installer":{"name":"uv","version":"0.9.26","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a902480aca0f03b9d108d35f0441d25581ed3d48d0bece85c2da1588cd705c1c
|
|
| MD5 |
51a645b010b623d399e98da14db43237
|
|
| BLAKE2b-256 |
0e0385908f9271d21a11db934869c6662083876e7759de18f7ff4584b085d32e
|
File details
Details for the file mdymcp-0.2.3-py3-none-any.whl.
File metadata
- Download URL: mdymcp-0.2.3-py3-none-any.whl
- Upload date:
- Size: 41.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.26 {"installer":{"name":"uv","version":"0.9.26","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
acdef2c285fec738d1fac5c90eeb4ad81eac987890c8bfb63b54edc5629093a6
|
|
| MD5 |
bde244bae55c1baf2477e37f1296dc41
|
|
| BLAKE2b-256 |
2ab96a88e8f4a27147661dc71708f18c9d9072fa7b74a440831bb7229e73646f
|