首页
学习
活动
专区
圈层
工具
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
首页
学习
活动
专区
圈层
工具
MCP广场
MCP广场 >详情页
mcp-odoo2025-05-300分享
github
一种集成Odoo ERP系统的MCP服务器实现,使AI助手能够通过模型上下文协议与Odoo的数据和功能进行交互。
By tuanle96
2025-05-300
github
详情内容

Odoo MCP 服务器

一个与 Odoo ERP 系统集成的 MCP 服务器实现,使 AI 助手能够通过模型上下文协议与 Odoo 数据和功能进行交互。

功能

  • 全面的 Odoo 集成:完全访问 Odoo 模型、记录和方法
  • XML-RPC 通信:通过 XML-RPC 安全连接到 Odoo 实例
  • 灵活的配置:支持配置文件和环境变量
  • 资源模式系统:基于 URI 访问 Odoo 数据结构
  • 错误处理:为常见的 Odoo API 问题提供清晰的错误信息
  • 无状态操作:干净的请求/响应循环,确保可靠的集成

工具

  • execute_method

    • 在 Odoo 模型上执行自定义方法
    • 输入:
      • model(字符串):模型名称(例如 'res.partner')
      • method(字符串):要执行的方法名称
      • args(可选数组):位置参数
      • kwargs(可选对象):关键字参数
    • 返回:包含方法结果和成功指示符的字典
  • search_employee

    • 按名称搜索员工
    • 输入:
      • name(字符串):要搜索的名称(或部分名称)
      • limit(可选数字):返回的最大结果数(默认 20)
    • 返回:包含成功指示符、匹配员工名称和 ID 列表以及任何错误信息的对象
  • search_holidays

    • 在指定日期范围内搜索假期
    • 输入:
      • start_date(字符串):开始日期,格式为 YYYY-MM-DD
      • end_date(字符串):结束日期,格式为 YYYY-MM-DD
      • employee_id(可选数字):可选的员工 ID,用于过滤假期
    • 返回:包含成功指示符、找到的假期列表以及任何错误信息的对象

资源

  • odoo://models

    • 列出 Odoo 系统中所有可用的模型
    • 返回:模型信息的 JSON 数组
  • odoo://model/{model_name}

    • 获取特定模型的信息,包括字段
    • 示例:odoo://model/res.partner
    • 返回:包含模型元数据和字段定义的 JSON 对象
  • odoo://record/{model_name}/{record_id}

    • 按 ID 获取特定记录
    • 示例:odoo://record/res.partner/1
    • 返回:包含记录数据的 JSON 对象
  • odoo://search/{model_name}/{domain}

    • 搜索匹配域的记录
    • 示例:odoo://search/res.partner/[["is_company","=",true]]
    • 返回:匹配记录的 JSON 数组(默认限制为 10 条)

配置

Odoo 连接设置

  1. 创建一个名为 odoo_config.json 的配置文件:
{
  "url": "https://your-odoo-instance.com",
  "db": "your-database-name",
  "username": "your-username",
  "password": "your-password-or-api-key"
}
  1. 或者使用环境变量:
    • ODOO_URL:您的 Odoo 服务器 URL
    • ODOO_DB:数据库名称
    • ODOO_USERNAME:登录用户名
    • ODOO_PASSWORD:密码或 API 密钥
    • ODOO_TIMEOUT:连接超时时间(秒,默认:30)
    • ODOO_VERIFY_SSL:是否验证 SSL 证书(默认:true)
    • HTTP_PROXY:强制 ODOO 连接使用 HTTP 代理

与 Claude Desktop 一起使用

将此添加到您的 claude_desktop_config.json

{
  "mcpServers": {
    "odoo": {
      "command": "python",
      "args": [
        "-m",
        "odoo_mcp"
      ],
      "env": {
        "ODOO_URL": "https://your-odoo-instance.com",
        "ODOO_DB": "your-database-name",
        "ODOO_USERNAME": "your-username",
        "ODOO_PASSWORD": "your-password-or-api-key"
      }
    }
  }
}

Docker

{
  "mcpServers": {
    "odoo": {
      "command": "docker",
      "args": [
        "run",
        "-i",
        "--rm",
        "-e",
        "ODOO_URL",
        "-e",
        "ODOO_DB",
        "-e",
        "ODOO_USERNAME",
        "-e",
        "ODOO_PASSWORD",
        "mcp/odoo"
      ],
      "env": {
        "ODOO_URL": "https://your-odoo-instance.com",
        "ODOO_DB": "your-database-name",
        "ODOO_USERNAME": "your-username",
        "ODOO_PASSWORD": "your-password-or-api-key"
      }
    }
  }
}

安装

Python 包

pip install odoo-mcp

运行服务器

# 使用已安装的包
odoo-mcp

# 使用 MCP 开发工具
mcp dev odoo_mcp/server.py

# 带额外依赖项
mcp dev odoo_mcp/server.py --with pandas --with numpy

# 挂载本地代码进行开发
mcp dev odoo_mcp/server.py --with-editable .

构建

Docker 构建:

docker build -t mcp/odoo:latest -f Dockerfile .

参数格式化指南

使用 MCP 工具处理 Odoo 时,请注意以下参数格式化指南:

  1. 域参数

    • 支持以下域格式:
      • 列表格式:[["field", "operator", value], ...]
      • 对象格式:{"conditions": [{"field": "...", "operator": "...", "value": "..."}]}
      • 任意格式的 JSON 字符串
    • 示例:
      • 列表格式:[["is_company", "=", true]]
      • 对象格式:{"conditions": [{"field": "date_order", "operator": ">=", "value": "2025-03-01"}]}
      • 多条件:[["date_order", ">=", "2025-03-01"], ["date_order", "<=", "2025-03-31"]]
  2. 字段参数

    • 应为字段名称数组:["name", "email", "phone"]
    • 服务器将尝试将字符串输入解析为 JSON

许可证

此 MCP 服务器根据 MIT 许可证授权。

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档