odooclaw-mcp

odooclaw-mcp

MCP server for Odoo 18 that provides 85 tools for CRUD operations, business actions, and migration workflows, enabling natural language interaction with Odoo ERP.

Category
Visit Server

README

OdooClaw MCP

Standalone MCP (Model Context Protocol) server for Odoo 18 over stdio.

MCP name: io.github.nicolasramos/odooclaw-mcp
PyPI package: odooclaw-mcp
Official CLI: odooclaw-mcp

Backward-compatible aliases are also installed:

  • odoo-mcp
  • odoo-mcp-server
  • odoo-18-mcp-server

Quick Start

1) Install

pip install odooclaw-mcp

From source:

git clone https://github.com/nicolasramos/odooclaw-mcp.git
cd odooclaw-mcp
pip install -e .

2) Configure environment

cp .env.example .env

Required:

ODOO_URL=https://yourcompany.odoo.com
ODOO_DB=your_database
ODOO_USERNAME=your_username
ODOO_PASSWORD=your_password

Optional:

ODOO_MCP_DEFAULT_LIMIT=50
ODOO_MCP_MAX_LIMIT=80
LOG_LEVEL=INFO

3) Validate and run

odooclaw-mcp --check-config
odooclaw-mcp

Alternative:

python -m odoo_mcp

MCP Client Configuration (stdio)

{
  "mcpServers": {
    "odoo": {
      "command": "odooclaw-mcp",
      "env": {
        "ODOO_URL": "https://yourcompany.odoo.com",
        "ODOO_DB": "your_database",
        "ODOO_USERNAME": "your_username",
        "ODOO_PASSWORD": "your_password",
        "ODOO_MCP_DEFAULT_LIMIT": "50",
        "ODOO_MCP_MAX_LIMIT": "80"
      }
    }
  }
}

Tool call payload contract

When calling tools through the MCP protocol, arguments must be wrapped in a top-level payload object.

Valid shape:

{
  "name": "odoo_search",
  "arguments": {
    "payload": {
      "model": "res.partner",
      "domain": [["customer_rank", ">", 0]],
      "limit": 3
    }
  }
}

If payload is omitted, validation fails with an error equivalent to Field required: payload.

Scope

  • 85 MCP tools for Odoo operations (CRUD + business actions + migration workflows)
  • Pydantic validation for all tool payloads
  • Odoo 18 compatibility helpers (customer_rank / supplier_rank / payment_state)
  • Security guards (model allowlist, denylisted fields, action guard, unlink blocked)
  • Structured logging and audit actions

Available Tools

The server currently exposes 85 MCP tools.

Note: the grouped tables below focus on common/high-value tools. Use MCP list_tools to inspect the full live tool catalog for your installed version.

Core record operations

Tool Purpose
odoo_search Search records in an allowed model using Odoo domain syntax.
odoo_read Read selected fields from specific record IDs.
odoo_search_read Combined search + read for efficient retrieval.
odoo_create Create a new record in an allowed model.
odoo_write Update existing records in an allowed model.
odoo_invoke_action Invoke an Odoo model method such as action_* or button_*.
odoo_get_record_summary Return a compact, human-friendly summary for a record.

Partners, sales, and CRM

Tool Purpose
odoo_find_partner Find a customer or vendor by name, VAT, or email.
odoo_get_partner_summary Get a partner overview with useful business context.
odoo_find_sale_order Search sale orders by name, partner, or state.
odoo_get_sale_order_summary Retrieve a sale order summary including lines.
odoo_create_sale_order Create a quotation / sale order with product lines.
odoo_confirm_sale_order Confirm a quotation into a sale order.
odoo_create_lead Create a CRM lead / opportunity.

Accounting, purchasing, and payments

Tool Purpose
odoo_create_purchase_order Create a purchase order from partner and line data.
odoo_create_vendor_invoice Create a vendor bill.
odoo_find_pending_invoices Find posted invoices or bills pending payment using Odoo 18 semantics.
odoo_get_invoice_summary Get a detailed summary of an invoice or bill.
odoo_register_payment Register a payment for a specific invoice.

Projects, activities, and chatter

Tool Purpose
odoo_find_task Search project tasks by name, project, or stage.
odoo_create_task Create a new project task.
odoo_update_task Update task stage, assignee, or deadline.
odoo_create_activity Schedule an activity on a record.
odoo_list_pending_activities List pending activities, optionally filtered by model or assignee.
odoo_mark_activity_done Mark an activity as completed.
odoo_post_chatter_message Post a chatter message on a record.
odoo_create_activity_summary Create a summary-style activity for follow-up.
odoo_close_activity_with_reason Close an activity and record the reason.
odoo_log_timesheet Log a timesheet entry for a project or task.

Support, contracts, stock, and instance capabilities

Tool Purpose
odoo_get_capabilities Report which modules and capabilities are available in the connected instance.
odoo_create_helpdesk_ticket Create a helpdesk ticket directly.
odoo_create_helpdesk_ticket_from_partner Create a helpdesk ticket linked to a partner.
odoo_draft_ticket_email Prepare a draft support email from a ticket context.
odoo_create_contract_line Add a line to a contract.
odoo_replace_contract_line Replace an existing contract line with a new one.
odoo_close_contract_line Close a contract line with a reason and close date.
odoo_get_product_stock Inspect stock quantities for a product.
odoo_create_calendar_event Create a meeting or appointment with attendees.

Introspection

Tool Purpose
odoo_get_model_schema Inspect the fields and schema of a model such as res.partner or account.move.

Available Resources

The server also exposes 5 MCP resources for discovery and context:

Resource Purpose
odoo://context/odoo18-fields-reference Odoo 18 field reference for common model/domain pitfalls such as customer_rank, supplier_rank, and payment_state.
odoo://models JSON list of models currently allowed by the security policy.
odoo://model/{model_name}/schema Technical schema for a specific Odoo model.
odoo://record/{model}/{id}/summary JSON summary of a specific record.
odoo://record/{model}/{id}/chatter_summary Summary of the chatter history for a specific record.

Guardrails and Runtime Behavior

  • Uses standard Odoo JSON-RPC endpoints; it does not depend on OdooClaw delegation.
  • Tool payloads are validated with Pydantic before execution.
  • Model access is restricted by an allowlist defined in the server configuration.
  • Sensitive write fields are denylisted and unlink is blocked.
  • Search-style tools use default and maximum limits (ODOO_MCP_DEFAULT_LIMIT, ODOO_MCP_MAX_LIMIT).
  • sender_id is treated as audit/context metadata; execution runs as the authenticated Odoo session user.
  • Some tools require the corresponding Odoo apps/modules to be installed (CRM, Helpdesk, Projects, Contracts, Inventory, etc.).

Security Model

The server uses standard Odoo JSON-RPC endpoints and executes operations as the configured Odoo session user.

For production, use a dedicated least-privilege Odoo account.

Production Notes

  • This is a stdio MCP server, not an HTTP API service.
  • Docker/Compose support is mainly for packaging or controlled runtime scenarios.
  • In normal usage, your MCP client launches the server process directly.
  • Keep Odoo credentials in environment variables or a secrets manager.

Known Limitations

  • One Odoo credential context per MCP process.
  • ODOO_DB is currently required by the authentication flow.
  • Some tools require specific Odoo apps/modules (CRM, Helpdesk, Project, etc.).
  • Designed for Odoo 18 field semantics.

Development

pip install -e .[dev]
ruff check src tests
black --check src tests
mypy src --ignore-missing-imports
pytest tests -v
python -m build
twine check dist/*

Docs

License

MIT - see LICENSE.

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured