A professional Model Context Protocol (MCP) server for seamless Odoo ERP integration. Supports both HTTP and STDIO transports for maximum flexibility.
- HTTP Mode: REST API with Express.js for web applications and remote access
- STDIO Mode: Direct stdin/stdout communication for Claude Desktop and local AI assistants
- Authentication: Automatic login with environment variables or manual connect
- CRUD Operations: Full Create, Read, Update, Delete on any Odoo model
- Advanced Search: Complex domain filtering with Odoo's powerful search syntax
- Method Calls: Execute any custom method on Odoo models
- Multi-Protocol: XML-RPC and JSON-RPC support
- TypeScript: Full type safety and modern ES modules
- MCP Protocol: Compliant with Model Context Protocol 2024-11-05
- Error Handling: Comprehensive error handling and logging
- Modular Design: Clean separation of concerns
- Production Ready: Battle-tested with real Odoo deployments
npm install -g @mweinheimer/odoo-mcp-server
git clone https://github.com/heimerle/odoo-mcp-server.git
cd odoo-mcp-server
npm install
npm run build
Create a .env.local
file or set these environment variables:
# Odoo Connection (Required)
ODOO_URL=http://your-odoo-instance:8069
ODOO_DB=your_database # or ODOO_DATABASE
ODOO_USERNAME=your_username
ODOO_PASSWORD=your_password
# Transport Mode
MCP_TRANSPORT=stdio # 'http' or 'stdio' (default: http)
# Odoo Protocol
ODOO_TRANSPORT=jsonrpc # 'jsonrpc' or 'xmlrpc' (default: jsonrpc)
# HTTP Mode Settings (only for MCP_TRANSPORT=http)
MCP_HTTP_PORT=3001 # HTTP server port (default: 3001)
Add to your claude_desktop_config.json
:
{
"mcpServers": {
"odoo": {
"command": "node",
"args": [
"/path/to/odoo-mcp-server/dist/stdio-server.js"
],
"env": {
"ODOO_URL": "http://your-odoo:8069",
"ODOO_DB": "your_database",
"ODOO_USERNAME": "your_username",
"ODOO_PASSWORD": "your_password"
}
}
}
}
Or use the global installation:
{
"mcpServers": {
"odoo": {
"command": "odoo-mcp-server",
"args": ["--stdio"],
"env": {
"ODOO_URL": "http://your-odoo:8069",
"ODOO_DB": "your_database",
"ODOO_USERNAME": "your_username",
"ODOO_PASSWORD": "your_password",
"MCP_TRANSPORT": "stdio"
}
}
}
}
# Using environment variables
ODOO_URL=http://localhost:8069 \
ODOO_DB=mydb \
ODOO_USERNAME=admin \
ODOO_PASSWORD=admin \
MCP_TRANSPORT=http \
node dist/http-mcp-server.js
# Server starts on http://localhost:3001
# Using the dedicated STDIO entry point
ODOO_URL=http://localhost:8069 \
ODOO_DB=mydb \
ODOO_USERNAME=admin \
ODOO_PASSWORD=admin \
node dist/stdio-server.js
The server provides 13 MCP tools for Odoo interaction:
- odoo_ping - Test Odoo connection and get server info
- odoo_connect - Manual login to Odoo (when auto-login is not configured)
- odoo_search_read - Search and read records with domain filters
- odoo_create - Create new records in any model
- odoo_write - Update existing records
- odoo_unlink - Delete records
- odoo_call_method - Execute custom methods on models
- odoo_get_fields - Get field definitions for a model
- odoo_read - Read specific records by ID
- odoo_search - Search for record IDs
- odoo_search_count - Count records matching criteria
- odoo_name_get - Get display names for records
- odoo_name_search - Search records by name
curl -X POST http://localhost:3001/mcp \
-H "Content-Type: application/json" \
-d '{
"jsonrpc": "2.0",
"method": "tools/call",
"params": {
"name": "odoo_search_read",
"arguments": {
"model": "res.partner",
"domain": [["is_company", "=", true]],
"fields": ["name", "email", "phone"],
"limit": 10
}
},
"id": 1
}'
Simply ask Claude:
"Create a new contact in Odoo with name 'John Doe', email 'john@example.com'"
Claude will use the odoo_create
tool automatically.
curl -X POST http://localhost:3001/mcp \
-H "Content-Type: application/json" \
-d '{
"jsonrpc": "2.0",
"method": "tools/call",
"params": {
"name": "odoo_write",
"arguments": {
"model": "res.partner",
"ids": [42],
"values": {
"phone": "+1234567890"
}
}
},
"id": 1
}'
git clone https://github.com/heimerle/odoo-mcp-server.git
cd odoo-mcp-server
npm install
npm run build
npm run dev # Watch mode with auto-recompile
npm run lint # Run ESLint
npm run test # Run tests
src/
βββ http-mcp-server.ts # Main HTTP/STDIO server
βββ stdio-server.ts # Dedicated STDIO entry point
βββ models/
β βββ odoo-client.ts # Odoo API client
β βββ odoo-tools.ts # MCP tool definitions
βββ utils/
β βββ odoo-sanitizer.ts # Response sanitization
βββ types/
βββ index.ts # TypeScript type definitions
- Quick Start Guide - Get started in 5 minutes
- Examples - Detailed usage examples
- Transport Modes - HTTP vs STDIO explained
- MCP Setup - Claude Desktop integration
- Testing Guide - How to test the server
- Changelog - Version history
Make sure you're using the correct environment variable names:
- Use
ODOO_DB
orODOO_DATABASE
(both work) - All credentials must be provided for auto-login
# Check what's using port 3001
lsof -i :3001
# Kill the process
pkill -f "node.*http-mcp-server"
# Or use a different port
MCP_HTTP_PORT=3002 node dist/http-mcp-server.js
Check that your Odoo instance is accessible:
curl http://your-odoo-instance:8069/web/database/selector
Contributions are welcome! Please:
- Fork the repository
- Create a feature branch (
git checkout -b feature/amazing-feature
) - Commit your changes (
git commit -m 'Add amazing feature'
) - Push to the branch (
git push origin feature/amazing-feature
) - Open a Pull Request
MIT License - see LICENSE file for details.
- GitHub: https://github.com/heimerle/odoo-mcp-server
- NPM: https://www.npmjs.com/package/@mweinheimer/odoo-mcp-server
- Issues: https://github.com/heimerle/odoo-mcp-server/issues
- Built with Model Context Protocol
- Powered by Odoo ERP
- TypeScript and Node.js
Made with β€οΈ for the Odoo and AI community