Jairajmehra/wati_whatsapp_mcp
If you are the rightful owner of wati_whatsapp_mcp and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.
The WATI MCP Server is a Model Context Protocol server that integrates with the WATI WhatsApp Business API, enabling AI assistants to manage messaging, contacts, and media through WhatsApp Business accounts.
WATI MCP Server
A Model Context Protocol (MCP) server that provides seamless integration with the WATI WhatsApp Business API. This server enables AI assistants to send messages, manage contacts, retrieve conversation data, and handle media files through WhatsApp Business accounts.
Features
- Message Management: Send and receive WhatsApp messages
- Contact Management: Add, update, and search contacts with custom attributes
- Template Messages: Send pre-approved template messages and broadcasts
- Media Handling: Send and receive media files (images, documents, etc.)
- Conversation History: Retrieve message history with pagination and filtering
- Bulk Operations: Send messages to multiple recipients via CSV upload
- Real-time Integration: Works with any MCP-compatible AI assistant
Installation
Step 1: Install the Package
Recommended: Using pipx (best for CLI tools)
pipx install wati-mcp-server
Alternative: Using pip with virtual environment
python3 -m venv mcp-env
source mcp-env/bin/activate
pip install wati-mcp-server
Step 2: Find Installation Path
Find where the command was installed:
which wati-mcp-server
This will show a path like /Users/username/.local/bin/wati-mcp-server
(pipx) or /path/to/mcp-env/bin/wati-mcp-server
(venv).
Step 3: Configure Your MCP Client
For Claude Desktop: Edit ~/Library/Application Support/Claude/claude_desktop_config.json
(macOS) or %APPDATA%\Claude\claude_desktop_config.json
(Windows)
For Cursor: Edit your Cursor MCP configuration file
Add this configuration:
{
"mcpServers": {
"wati": {
"command": "/full/path/from/which/command",
"env": {
"API_ENDPOINT": "https://live-mt-server.wati.io/YOUR_TENANT_ID",
"ACCESS_TOKEN": "Bearer YOUR_WATI_ACCESS_TOKEN"
}
}
}
}
Or if pipx added it to your PATH, you can use:
{
"mcpServers": {
"wati": {
"command": "wati-mcp-server",
"env": {
"API_ENDPOINT": "https://live-mt-server.wati.io/YOUR_TENANT_ID",
"ACCESS_TOKEN": "Bearer YOUR_WATI_ACCESS_TOKEN"
}
}
}
}
Step 4: Get Your WATI Credentials
- Sign up for a WATI account
- Get your WhatsApp Business API approved
- Find your API endpoint and access token in the WATI dashboard
- Replace
YOUR_TENANT_ID
andYOUR_WATI_ACCESS_TOKEN
in the config above
Step 5: Restart Your MCP Client
After updating the configuration, completely restart Claude Desktop or Cursor.
Available Tools
The server provides the following MCP tools:
Message Operations
get_messages
- Retrieve WhatsApp messages for a specific numbersend_message_to_opened_session
- Send a message to an open WhatsApp sessionsend_template_message
- Send a pre-approved template messagesend_template_messages
- Send template messages to multiple recipientssend_template_messages_from_csv
- Bulk send template messages from CSV file
Contact Management
get_contacts_list
- Retrieve contacts with filtering optionsadd_contact
- Add a new WhatsApp contactupdate_contact_attributes
- Update custom attributes for a contact
Templates and Media
get_message_templates
- Retrieve available message templatesget_media_by_filename
- Get media file detailssend_file_to_opened_session
- Send files to WhatsApp sessions
Utility
get_weather
- Demo weather function (for testing)
Usage Examples
Send a Template Message
# The AI assistant can use this tool:
send_template_message(
whatsapp_number=919909000282,
template_name="welcome_message",
broadcast_name="new_user_welcome",
parameters=[
{"name": "customer_name", "value": "John Doe"},
{"name": "company_name", "value": "ACME Corp"}
]
)
Search Contacts
# Find contacts in a specific city
get_contacts_list(
attribute='[{"name":"city","operator":"=","value":"Mumbai"}]',
page_size=20
)
Send Bulk Messages
# Send to multiple recipients
send_template_messages(
template_name="promotional_offer",
broadcast_name="summer_sale_2024",
receivers=[
{
"whatsappNumber": "919909000282",
"customParams": [{"name": "offer_code", "value": "SUMMER25"}]
},
{
"whatsappNumber": "919909000283",
"customParams": [{"name": "offer_code", "value": "SUMMER30"}]
}
]
)
Configuration
Environment Variables
Variable | Description | Required |
---|---|---|
API_ENDPOINT | Your WATI API endpoint URL | Yes |
ACCESS_TOKEN | Your WATI API access token | Yes |
Development
Setting up for Development
# Clone the repository
git clone https://github.com/Jairajmehra/wati_whatsapp_mcp.git
cd wati_whatsapp_mcp
# Install in development mode
pip install -e ".[dev]"
# Install pre-commit hooks
pre-commit install
Running Tests
pytest
Code Formatting
black wati_mcp/
flake8 wati_mcp/
mypy wati_mcp/
Building for Distribution
python -m build
API Reference
WATIClient Class
The core client class that handles all API interactions:
from wati_mcp.server import WATIClient
client = WATIClient(api_endpoint="...", access_token="...")
Server Creation
from wati_mcp.server import create_server
# Create a configured MCP server
server = create_server()
Error Handling
The server includes comprehensive error handling:
- API request failures are caught and returned as structured error responses
- File operations include existence checks and proper error messages
- Environment variable validation with helpful error messages
- Structured logging for debugging and monitoring
Contributing
We welcome contributions! Please see our for details.
- Fork the repository
- Create a feature branch (
git checkout -b feature/amazing-feature
) - Commit your changes (
git commit -m 'Add some 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 file for details.
Support
- Documentation: GitHub Repository
- Issues: GitHub Issues
- WATI Documentation: WATI API Docs
Changelog
v0.1.0
- Initial release
- Core WhatsApp messaging functionality
- Contact management features
- Template message support
- Media file handling
- Bulk messaging capabilities
Built with ❤️ for the MCP ecosystem