MCP Odoo Bridge Server

MCP Odoo Bridge Server

Enables AI assistants to interact with Odoo data using natural language to search, read, create, and update records. It acts as a secure bridge between MCP clients and Odoo instances version 17.0 through 19.0.

Category
Visit Server

README

MCP Odoo Bridge Server

MCP Odoo Python License

Licensed under the Apache License, Version 2.0 - See LICENSE for details.

A Model Context Protocol (MCP) server that enables AI assistants like Claude to interact with Odoo data using natural language.

๐ŸŽฏ What is MCP?

The Model Context Protocol is an open standard by Anthropic that enables AI assistants to securely connect to external data sources. This server acts as a bridge between Claude (or other MCP clients) and your Odoo instance.

Learn more: MCP Documentation


โœจ Features

Feature Description
๐Ÿ” Search Records Find records using natural language or Odoo domain syntax
๐Ÿ“– Read Records Get detailed record information by ID
๐Ÿ“Š Count Records Get counts matching criteria
โž• Create Records Create new records (with permission)
โœ๏ธ Update Records Modify existing records (with permission)
๐Ÿ—‘๏ธ Delete Records Remove records (with permission)
๐Ÿ“‹ List Models Discover available models
๐Ÿ”ง Get Fields Understand model structure
โšก Execute Methods Run custom methods (if enabled)
๐Ÿ” API Key Auth Secure authentication via API keys
๐Ÿ“ Audit Logging All operations logged for compliance

๐Ÿ“‹ Prerequisites

  1. Odoo instance (17.0, 18.0, or 19.0 recommended)
  2. Python 3.10+ installed
  3. AD Odoo MCP Bridge module installed in Odoo (see Odoo Module)

๐Ÿš€ Installation

1. Clone the Repository

git clone https://github.com/yourusername/ad-mcp-bridge-server.git
cd ad-mcp-bridge-server

2. Install Dependencies

pip install -e .

Or with uv:

uv pip install -e .

3. Install the Odoo Module

Install the ad_odoo_mcp_bridge module in your Odoo instance:

  1. Add the module folder to your Odoo addons path
  2. Go to Apps โ†’ Install "AD Odoo MCP Bridge"

โš™๏ธ Configuration

Environment Variables

The server requires the following environment variables:

Variable Required Description Example
ODOO_URL Yes Your Odoo instance URL https://mycompany.odoo.com
ODOO_API_KEY Yes* API key for authentication 0ef5b399e9ee9c11b053dfb6eeba8de473c29fcd
ODOO_USER Yes* Username (if not using API key) admin
ODOO_PASSWORD Yes* Password (if not using API key) admin
ODOO_DB No Database name (auto-detected if not set) mycompany
ODOO_MAX_RECORDS No Default max records per query (default: 100) 200
ODOO_TIMEOUT No Request timeout in seconds (default: 30) 60
ODOO_YOLO No YOLO mode - bypasses MCP security (โš ๏ธ DEV ONLY) off, read, true

* Authentication: You must provide either ODOO_API_KEY or both ODOO_USER and ODOO_PASSWORD.

MCP Transport Options

Variable Required Description Example
MCP_TRANSPORT No Transport type: stdio or streamable-http (default: stdio) streamable-http
MCP_HOST No Host for HTTP transport (default: localhost) 0.0.0.0
MCP_PORT No Port for HTTP transport (default: 8000) 8080

YOLO Mode Values

Value Description
off All operations require explicit MCP Bridge permissions (default)
read Allows read-only operations on all models without configuration
true โš ๏ธ DANGEROUS - Allows all operations including write/delete without restrictions

โš ๏ธ Warning: YOLO mode bypasses security checks and should NEVER be used in production. It's intended only for local development and testing.

Create a .env File (Optional)

ODOO_URL=https://mycompany.odoo.com
ODOO_DB=mycompany
ODOO_API_KEY=your-api-key-here

๐Ÿ”Œ Usage with Claude Desktop

Step 1: Generate API Key in Odoo

  1. Go to MCP Bridge โ†’ Configuration โ†’ API Keys
  2. Click Create โ†’ Select user โ†’ Generate Key
  3. Copy the key (shown only once!)

Step 2: Configure Claude Desktop

Edit claude_desktop_config.json:

Windows: %APPDATA%\Claude\claude_desktop_config.json
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json

{
  "mcpServers": {
    "odoo": {
      "command": "python",
      "args": ["-m", "ad_mcp_bridge_server"],
      "cwd": "/path/to/ad-mcp-bridge-server/src",
      "env": {
        "ODOO_URL": "http://localhost:8069",
        "ODOO_DB": "your_database",
        "ODOO_API_KEY": "your-api-key"
      }
    }
  }
}

Windows Note: Use the full Python path if needed:

"command": "C:\\path\\to\\venv\\Scripts\\python.exe"

Step 3: Restart Claude Desktop

Close and reopen Claude Desktop. You should see the ๐Ÿ”ง Tools icon.

Step 4: Start Chatting!

Try these prompts:

  • "Show me all customers from the United States"
  • "What's the status of order SO/2024/0153?"
  • "Create a new lead for ABC Company"
  • "How many unpaid invoices do we have?"

๐Ÿ”Œ Usage with VS Code

Create .vscode/mcp.json in your workspace:

{
  "servers": {
    "odoo": {
      "command": "python",
      "args": ["-m", "ad_mcp_bridge_server"],
      "cwd": "/path/to/ad-mcp-bridge-server/src",
      "env": {
        "ODOO_URL": "http://localhost:8069",
        "ODOO_DB": "your_database",
        "ODOO_API_KEY": "your-api-key"
      }
    }
  }
}

๐Ÿงช Testing with MCP Inspector

Use the official MCP debugging tool:

npx @modelcontextprotocol/inspector python -m ad_mcp_bridge_server

This opens a web UI to test all tools interactively.


๐Ÿ—๏ธ Odoo Module

This MCP server requires the AD Odoo MCP Bridge module installed in Odoo.

Compatibility

Odoo Version Status
19.0 โœ… Fully Supported
18.0 โœ… Supported
17.0 โœ… Supported
16.0 โœ… Supported

Module Features

  • Model Configuration: Choose which models AI can access
  • Permission Control: Set read/create/update/delete per model
  • API Key Management: Generate and manage API keys
  • Audit Logging: Track all AI operations
  • Rate Limiting: Control request frequency
  • YOLO Mode: Quick access mode for development

Module Installation

  1. Copy ad_odoo_mcp_bridge folder to your Odoo addons path
  2. Restart Odoo
  3. Go to Apps โ†’ Remove "Apps" filter โ†’ Search "MCP" โ†’ Install

๐Ÿ” Security

  • API Key Authentication: All requests require a valid API key
  • Permission Inheritance: AI inherits Odoo user's permissions
  • Audit Trail: All operations logged with IP, timestamp, and details
  • Rate Limiting: Configurable per-key request limits
  • Field Exclusions: Sensitive fields can be blocked

๐Ÿ“š API Endpoints (Odoo Module)

The Odoo module exposes these JSON-RPC endpoints:

Endpoint Description
GET /mcp/health Health check
POST /mcp/info Server information
POST /mcp/models List enabled models
POST /mcp/fields Get model fields
POST /mcp/search Search records
POST /mcp/read Read record by ID
POST /mcp/count Count records
POST /mcp/create Create record
POST /mcp/write Update record
POST /mcp/unlink Delete record
POST /mcp/execute Execute method

๐Ÿ› ๏ธ Development

Run Locally

cd src
export ODOO_URL=http://localhost:8069
export ODOO_DB=mydb
export ODOO_API_KEY=your-key
python -m ad_mcp_bridge_server

Project Structure

ad-mcp-bridge-server/
โ”œโ”€โ”€ src/
โ”‚   โ””โ”€โ”€ ad_mcp_bridge_server/
โ”‚       โ”œโ”€โ”€ __init__.py
โ”‚       โ”œโ”€โ”€ __main__.py      # Entry point
โ”‚       โ”œโ”€โ”€ config.py        # Pydantic settings
โ”‚       โ”œโ”€โ”€ odoo_client.py   # Odoo HTTP client
โ”‚       โ””โ”€โ”€ server.py        # MCP server & tools
โ”œโ”€โ”€ pyproject.toml
โ”œโ”€โ”€ README.md
โ””โ”€โ”€ .env.example

๐Ÿ“– MCP Resources


๐Ÿค Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/amazing-feature)
  3. Commit your changes (git commit -m 'Add some amazing feature')
  4. Push to the branch (git push origin feature/amazing-feature)
  5. Open a Pull Request

โ˜• Support

Thank you for using this project! If you find it helpful and would like to support my work, kindly consider buying me a coffee. Your support is greatly appreciated!

<a href="https://ko-fi.com/aadilakbar" target="_blank"> <img src="https://ko-fi.com/img/githubbutton_sm.svg" alt="Buy Me a Coffee at ko-fi.com" /> </a>

And don't forget to give the project a โญ star if you like it!


๐Ÿ“„ License

This project is licensed under the Apache License 2.0 - see the LICENSE file for details.


๐Ÿ™ Acknowledgments

  • Anthropic for Claude and MCP
  • Odoo for the amazing ERP platform
  • FastMCP for the Python MCP framework

๐Ÿ“ About

A Model Context Protocol (MCP) server that enables AI assistants to securely interact with Odoo ERP systems through standardized resources and tools for data retrieval and manipulation.

Made with โค๏ธ for the Odoo and AI community

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
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
Qdrant Server

Qdrant Server

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

Official
Featured