loading…
Search for a command to run...
loading…
MCP server for Odoo 18 that provides 85 tools for CRUD operations, business actions, and migration workflows, enabling natural language interaction with Odoo ER
MCP server for Odoo 18 that provides 85 tools for CRUD operations, business actions, and migration workflows, enabling natural language interaction with Odoo ERP.
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-mcpodoo-mcp-serverodoo-18-mcp-serverpip install odooclaw-mcp
From source:
git clone https://github.com/nicolasramos/odooclaw-mcp.git
cd odooclaw-mcp
pip install -e .
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
odooclaw-mcp --check-config
odooclaw-mcp
Alternative:
python -m odoo_mcp
{
"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"
}
}
}
}
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.
The server currently exposes 85 MCP tools.
Note: the grouped tables below focus on common/high-value tools. Use MCP
list_toolsto inspect the full live tool catalog for your installed version.
| 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. |
| 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. |
| 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. |
| 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. |
| 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. |
| Tool | Purpose |
|---|---|
odoo_get_model_schema |
Inspect the fields and schema of a model such as res.partner or account.move. |
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. |
unlink is blocked.ODOO_MCP_DEFAULT_LIMIT, ODOO_MCP_MAX_LIMIT).sender_id is treated as audit/context metadata; execution runs as the authenticated Odoo session user.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.
stdio MCP server, not an HTTP API service.ODOO_DB is currently required by the authentication flow.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/*
MIT - see LICENSE.
Run in your terminal:
claude mcp add odooclaw-mcp -- npx Security
Low riskAutomated heuristic from public metadata — not a security guarantee.