zoho-crm-mcp
Provides tools for querying and managing Zoho CRM data, including modules, fields, records, and related lists, with support for COQL queries and metadata discovery.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@zoho-crm-mcpshow deals closing this month"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Zoho CRM MCP
MCP server and optional FastAPI wrapper for live Zoho CRM data access.
This project does not sync CRM data into a database or knowledge graph. Zoho remains the source of truth. The server discovers your Zoho modules, fields, and related lists, then exposes generic tools that can query standard modules, custom modules, subforms, and linking modules through Zoho's API names.
What This Provides
MCP server for agent/client integrations.
FastAPI
/docsUI for manual testing.Single plain-text
/queryendpoint for simple natural-language CRM lookups.Zoho metadata discovery for modules, fields, and related lists.
Generic module-aware tools instead of hardcoded Contacts/Deals-only logic.
Related MCP server: Zoho CRM MCP Server
Repository Safety
These files are intentionally ignored and should not be committed:
.envzoho_metadata.jsonknowledge_graph.db__pycache__/
zoho_metadata.json contains schema metadata from your Zoho org. It does not contain synced CRM records, but it can still reveal internal module and field names, so keep it local.
Setup
Create a local .env:
ZOHO_CLIENT_ID=...
ZOHO_CLIENT_SECRET=...
ZOHO_REFRESH_TOKEN=...
OPENAI_API_KEY=...Optional, depending on your Zoho data center:
ZOHO_ACCOUNTS_URL=https://accounts.zoho.in
ZOHO_API_DOMAIN=https://www.zohoapis.in
OPENAI_MODEL=gpt-4o-miniInstall dependencies:
python3 -m pip install -r requirements.txtDiscover modules, fields, and related lists:
python3 discover_zoho.pyThis creates local zoho_metadata.json.
Run MCP Server
python3 zoho_mcp_server.pyExample MCP client config:
{
"mcpServers": {
"zoho-crm": {
"command": "python3",
"args": [
"/absolute/path/to/zoho_mcp_server.py"
]
}
}
}MCP Tools
refresh_metadatalist_modulesget_module_fieldsget_related_listssearch_recordsget_recordsget_recordget_related_recordsquery_coql
Note: query_coql requires a Zoho refresh token with the correct COQL scope. If the token does not include that scope, normal record tools still work.
Optional Swagger UI
Start FastAPI:
uvicorn api:app --host 127.0.0.1 --port 8000Open:
http://127.0.0.1:8000/docsUseful endpoints:
POST /queryGET /queryGET /modulesGET /modules/{module}/fieldsGET /modules/{module}/related-listsGET /records/{module}POST /recordsGET /records/{module}/searchPOST /records/searchGET /record/{module}/{record_id}POST /related-recordsPOST /coql
Plain-Text Query Endpoint
POST /query takes a raw text body and returns plain text. By default it uses the LLM agent wrapper above the MCP tools.
Example body:
latest contactsOther examples:
find contacts matching Amit
top 5 revenue accounts
deals closing this month
what fields are in Accounts
what related lists are in Contacts
latest invoicesThe /query endpoint is intentionally pragmatic. It handles common CRM lookups and a few analytical shortcuts. For deep analytics, add COQL scope or later add a materialized analytical store such as Postgres or DuckDB.
Use the deterministic rule-based fallback if needed:
POST /query?mode=rulesUse the LLM tool-calling agent:
POST /query?mode=agentThis server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/5ivatej/zoho-crm-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server