MCP server for Odoo 18 with 38 business tools
Valid MCP server (0 strong, 4 medium validity signals). 5 known CVEs in dependencies (1 critical, 3 high severity) ⚠️ Package registry links to a different repository than scanned source. Imported from the Official MCP Registry.
8 files analyzed · 6 issues found
Security scores are indicators to help you make informed decisions, not guarantees. Always review permissions before connecting any MCP server.
This plugin requests these system permissions. Most are normal for its category.
Unverified package source
We couldn't verify that the installable package matches the reviewed source code. Proceed with caution.
Set these up before or after installing:
Environment variable: ODOO_URL
Environment variable: ODOO_DB
Environment variable: ODOO_USERNAME
Environment variable: ODOO_PASSWORD
Environment variable: ODOO_MCP_DEFAULT_LIMIT
Environment variable: ODOO_MCP_MAX_LIMIT
Add this to your MCP configuration file:
{
"mcpServers": {
"io-github-nicolasramos-odoo-mcp": {
"env": {
"ODOO_DB": "your-odoo-db-here",
"ODOO_URL": "your-odoo-url-here",
"ODOO_PASSWORD": "your-odoo-password-here",
"ODOO_USERNAME": "your-odoo-username-here",
"ODOO_MCP_MAX_LIMIT": "your-odoo-mcp-max-limit-here",
"ODOO_MCP_DEFAULT_LIMIT": "your-odoo-mcp-default-limit-here"
},
"args": [
"-y",
"@nicolasramos/odoo-mcp-server"
],
"command": "npx"
}
}
}From the project's GitHub README.
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 39 MCP tools.
| 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.
Be the first to review this server!
by Modelcontextprotocol · Developer Tools
Read, search, and manipulate Git repositories programmatically
by Toleno · Developer Tools
Toleno Network MCP Server — Manage your Toleno mining account with Claude AI using natural language.
by mcp-marketplace · Developer Tools
Create, build, and publish Python MCP servers to PyPI — conversationally.
by Microsoft · Content & Media
Convert files (PDF, Word, Excel, images, audio) to Markdown for LLM consumption
by mcp-marketplace · Developer Tools
Scaffold, build, and publish TypeScript MCP servers to npm — conversationally
by mcp-marketplace · Finance
Free stock data and market news for any MCP-compatible AI assistant.