Leave 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., "@Leave MCP ServerApply for annual leave from June 10 to 12"
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.
请假流程 MCP 服务
将 Dify 请假流程封装为 Model Context Protocol (MCP) 服务,让 LLM 客户端(Claude Desktop、Trae 等)通过标准 MCP 协议调用工具完成请假申请。
功能特性
6 个业务流程层工具:覆盖请假全流程(初始化、选岗、计算天数、附件检查、上传、提交)
环境切换:通过
API_ENV环境变量一键切换 UAT/PRD 环境,所有接口统一域名业务校验内置:年假/调休假余额校验、丧假 ≤3 天限制、7 类附件要求
附件上传:支持 base64 编码和本地文件路径两种方式
无状态设计:MCP 服务无状态,状态由 LLM 上下文保存,确认后再执行
流程引导 Prompt:内置
leave_flow_guide提示词,指导 LLM 按序调用工具
Related MCP server: leave-management
安装
# 克隆项目后安装(包含开发依赖)
pip install -e ".[dev]"环境变量配置
复制 .env.example 为 .env 并按需修改:
copy .env.example .env变量 | 说明 | 默认值 |
| 环境切换: |
|
| UAT 域名 |
|
| PRD 域名 |
|
切换生产环境只需设置 API_ENV=prd,所有接口自动指向 PRD 域名。
使用方式
1. MCP Inspector(开发调试)
mcp dev src/leave_mcp/server.py浏览器打开 Inspector 界面,可手动触发每个工具并查看返回结构。
2. Claude Desktop 配置
在 Claude Desktop 配置文件(claude_desktop_config.json)中添加:
{
"mcpServers": {
"leave-service": {
"command": "python",
"args": ["-m", "leave_mcp.server"],
"cwd": "D:\\子公司AI大赛PPT\\003",
"env": {
"PYTHONPATH": "D:\\子公司AI大赛PPT\\003\\src",
"API_ENV": "uat"
}
}
}
}
API_ENV设为uat或prd,不设置默认uat。切换到生产环境改为"prd"即可。
3. 直接运行
python -m leave_mcp.server工具列表
# | 工具名 | 功能 | 封装接口 |
1 |
| 初始化流程:获取用户信息、检查未销假、获取请假类型和余额 | 接口 1+4+2+3 |
2 |
| 从岗位列表中选择指定岗位(边界校验) | 无 |
3 |
| 计算实际休假天数 + 年假/调休假余额校验 | 接口 5 |
4 |
| 根据请假类型检查附件要求(7 类规则 + 丧假 ≤3 天) | 无 |
5 |
| 批量上传附件(支持 base64 编码或文件路径) | 接口 7 |
6 |
| 提交请假申请,返回申请单号 | 接口 8 |
Prompt
leave_flow_guide:请假流程引导,指导 LLM 按init → select → calculate → check_attachment → (upload) → submit顺序调用工具。
工具调用流程
用户发起请假请求
│
▼
init_leave_flow(user_token)
│
├── has_pending_leave=true → 提示用户先销假,结束
│
▼
select_organization(user_orgs, selected_index) [多岗位时]
│
▼
calculate_leave_days(...)
│
├── balance_sufficient=false → 提示余额不足
│
▼
check_attachment_requirement(leave_type, leave_days, has_attachment)
│
├── action=reject → 提示拒绝原因(如丧假超3天)
├── action=upload → upload_attachment(...) → submit_leave_application(...)
└── action=submit → submit_leave_application(...)附件要求速查
请假类型 | 所需附件 |
病假 | 诊断证明或病假条(二选一) |
产假 | 产检证明 |
工伤假 | 工伤情况证明 |
婚假 | 结婚证 |
丧假 | 死亡证明(且时长 ≤ 3 天) |
流产假 | 诊断证明或病假条(二选一) |
年休假 | 无需附件(但需校验余额) |
调休假 | 无需附件(但需校验余额) |
测试
# 运行所有测试
pytest tests/ -v
# 运行特定测试类
pytest tests/test_tools.py::TestCalculateLeaveDays -v测试覆盖:
test_client.py:8 个 REST 接口封装(respx mock httpx)test_tools.py:6 个工具的正常/异常分支(未销假拦截、余额不足、丧假超限、7 类附件规则、base64 解码)
项目结构
├── pyproject.toml # 项目配置 + 依赖
├── .env.example # 环境变量示例
├── src/leave_mcp/
│ ├── server.py # FastMCP 实例 + 6 个工具 + prompt
│ ├── config.py # 环境切换配置(API_ENV 控制 uat/prd)
│ ├── models.py # Pydantic 输入输出模型
│ ├── client.py # httpx 异步客户端,8 接口封装
│ ├── exceptions.py # 自定义异常
│ └── prompts.py # 流程引导提示词
└── tests/
├── conftest.py # pytest fixtures
├── test_client.py # 接口封装测试
└── test_tools.py # 工具逻辑测试关键设计决策
环境切换:通过
API_ENV变量控制(uat/prd),所有 8 个接口统一域名,UAT 用zhgr-mp-uat.huanhuigroup.cn,PRD 用zhgr-mp.huanhuigroup.cn。错误分层:业务可恢复结果(余额不足等)返回
{success: false, message}不中断对话;系统异常抛错。无状态:MCP 服务不保存会话状态,所需状态(如
selected_org、leave_types)由 LLM 在上下文中保存并作为参数传入。Token 传参:
user_token通过工具参数传入,不在服务端存储。Prompts 替代编排:Dify 的 22 节点状态机靠
leave_flow_guideprompt 指导 LLM 按序调用。附件双模式上传:支持
file_base64(跨客户端通用)和file_path(本地直读),优先file_path。
技术栈
Python ≥ 3.10
MCP Python SDK v1.0+
httpx(异步 HTTP 客户端)
Pydantic v2.0+(数据验证)
This server cannot be installed
Maintenance
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
- Why MCP Servers Need Execution Sandboxing (And Why Your Current Stack Isn't Enough)By Om-Shree-0709 on .Agentic AiPrompt InjectionWebAssembly
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/daomengKJ/leave_mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server