Zoho Mail MCP Server
Enables AI assistants to manage Zoho Mail accounts, including sending/receiving emails, folder and label management, organization administration, and productivity tools like tasks and notes.
README
Zoho Mail MCP Server
A comprehensive Model Context Protocol (MCP) server for integrating with Zoho Mail API, providing seamless email management, organization administration, and productivity features through AI assistants like Claude.
🚀 Features
Core Email Functions
- Send & Receive: Send emails with/without attachments, list and search emails
- Email Management: Mark as read/unread, move between folders, delete emails
- Content Access: Get full email content and manage email threads
Organization Management
- Domain Management: Add, verify, and manage domains with DNS settings
- User Administration: Add users, manage permissions and storage limits
- Security: IP allowlists, spam management, and audit logging
Productivity Tools
- Folders & Labels: Create and organize email folders and labels
- Tasks: Manage group and personal tasks
- Bookmarks: Save and organize important links
- Notes: Create and manage notes within groups
Advanced Features
- Multi-region Support: Automatically adapts to different Zoho regions (.com, .in, .eu, etc.)
- Structured Responses: All API responses are structured with consistent error handling
- Comprehensive Logging: Detailed logging for debugging and monitoring
📋 Prerequisites
- Python 3.8 or higher
- Nango account with Zoho Mail integration configured
- Zoho Mail account with appropriate permissions
🛠️ Installation
-
Clone the repository
git clone <repository-url> cd zoho-mail-mcp-server -
Install dependencies
pip install -r requirements.txt -
Set up environment variables Create a
.envfile in the project root:NANGO_CONNECTION_ID=your_connection_id NANGO_INTEGRATION_ID=your_integration_id NANGO_BASE_URL=https://api.nango.dev NANGO_SECRET_KEY=your_nango_secret_key
⚙️ Configuration
Nango Setup
-
Create a Nango Account
- Visit Nango and create an account
- Set up a new integration for Zoho Mail
-
Configure Zoho Mail Integration
- In Nango dashboard, create a new Zoho Mail integration
- Configure the required scopes:
ZohoMail.messages.ALLZohoMail.folders.ALLZohoMail.accounts.READZohoMail.organization.ALL(for admin functions)
-
Get Connection Details
- Create a connection in Nango
- Note down your connection ID, integration ID, and secret key
- Ensure your connection config includes the correct extension (e.g.,
{'extension': 'in'})
Environment Variables
| Variable | Description | Required |
|---|---|---|
NANGO_CONNECTION_ID |
Your Nango connection identifier | ✅ |
NANGO_INTEGRATION_ID |
Your Nango integration identifier | ✅ |
NANGO_BASE_URL |
Nango API base URL | ✅ |
NANGO_SECRET_KEY |
Your Nango secret key | ✅ |
🚀 Usage
Starting the Server
python zoho_mail_mcp.py
The server will start and automatically detect your Zoho region based on your Nango configuration.
Using with Claude Desktop
-
Add to Claude Desktop Configuration
Edit your Claude Desktop config file (usually located at
~/.claude/claude_desktop_config.json):{ "mcpServers": { "zoho-mail": { "command": "python", "args": ["/path/to/your/zoho_mail_mcp.py"], "env": { "NANGO_CONNECTION_ID": "your_connection_id", "NANGO_INTEGRATION_ID": "your_integration_id", "NANGO_BASE_URL": "https://api.nango.dev", "NANGO_SECRET_KEY": "your_nango_secret_key" } } } } -
Restart Claude Desktop
-
Start Using
You can now use natural language commands with Claude:
"Send an email to john@example.com with subject 'Meeting Tomorrow'" "List my recent emails" "Create a new folder called 'Projects'" "Show me all users in my organization"
📚 Available Functions
Authentication
get_nango_auth_info()- Get current authentication status and user info
Email Management
send_email()- Send email with basic optionssend_email_with_attachments()- Send email with file attachmentslist_emails()- List emails in account or specific foldersearch_emails()- Search emails with custom parametersget_email_content()- Get full email contentmark_emails_as_read()/mark_emails_as_unread()- Change read statusmove_emails()- Move emails between foldersdelete_email()- Delete specific email
Folder & Label Management
create_folder()/delete_folder()- Manage email foldersget_all_folders()/get_folder_details()- Retrieve folder informationcreate_label()/update_label()/delete_label()- Manage email labels
Organization Management
get_organization_details()- Get organization informationadd_domain()/verify_domain()- Domain managementadd_user()/get_all_users()- User administrationcreate_group()/get_all_groups()- Group management
Security & Compliance
add_allowed_ips()/get_allowed_ips()- IP allowlist managementget_login_history()- Access login audit logsget_audit_records()- Get detailed audit records
Productivity Tools
add_task()/get_all_tasks_in_group()- Task managementcreate_bookmark()/get_all_bookmarks()- Bookmark managementcreate_note()/edit_note()- Note management
🌍 Multi-Region Support
The server automatically detects your Zoho region from Nango configuration:
- Global (.com):
https://mail.zoho.com/api - India (.in):
https://mail.zoho.in/api - Europe (.eu):
https://mail.zoho.eu/api - China (.com.cn):
https://mail.zoho.com.cn/api
No manual configuration needed - the server adapts automatically!
🔧 Troubleshooting
Common Issues
1. Authentication Errors
Error: Authentication failed: No access token found
- Verify your Nango environment variables are correct
- Check that your Nango connection is active and not expired
- Ensure your Zoho Mail integration has the required scopes
2. Wrong Region/Extension
Error: HTTP 404: Not Found
- Check your Nango connection config includes the correct extension
- Verify you're using the right Zoho region for your account
3. Permission Errors
Error: HTTP 403: Forbidden
- Ensure your Zoho account has the necessary permissions
- For organization functions, you need admin privileges
- Check that required scopes are granted in Nango
Debug Mode
Enable detailed logging by setting the log level:
logging.basicConfig(level=logging.DEBUG)
Testing Connection
Use the authentication info function to test your setup:
# This will show your current auth status
auth_info = get_nango_auth_info()
print(f"Connected as: {auth_info.user_email}")
print(f"Region: {auth_info.extension}")
print(f"Scopes: {auth_info.scopes}")
📖 API Response Format
All functions return structured ApiResponse objects:
{
"success": bool, # Whether operation succeeded
"data": dict, # Response data from Zoho API
"error": str, # Error message if any
"status_code": int # HTTP status code
}
🤝 Contributing
- 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
📄 License
This project is licensed under the MIT License - see the LICENSE file for details.
🆘 Support
- Issues: Open an issue on GitHub for bugs or feature requests
- Documentation: Check the Zoho Mail API Documentation
- Nango Help: Visit Nango Documentation for authentication issues
🏗️ Roadmap
- [ ] Real-time email notifications via webhooks
- [ ] Email template management
- [ ] Advanced search filters
- [ ] Bulk operations support
- [ ] Calendar integration
- [ ] Mobile push notifications setup
Made with ❤️ for seamless Zoho Mail integration
推荐服务器
Baidu Map
百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。
Playwright MCP Server
一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。
Magic Component Platform (MCP)
一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。
Audiense Insights MCP Server
通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。
VeyraX
一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。
graphlit-mcp-server
模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。
Kagi MCP Server
一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。
e2b-mcp-server
使用 MCP 通过 e2b 运行代码。
Neon MCP Server
用于与 Neon 管理 API 和数据库交互的 MCP 服务器
Exa MCP Server
模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。