loading…
Search for a command to run...
loading…
MCP server that integrates Evolution API to enable WhatsApp messaging, chat management, group operations, and instance control through natural language tools.
MCP server that integrates Evolution API to enable WhatsApp messaging, chat management, group operations, and instance control through natural language tools.
TypeScript MCP server for Evolution API (WhatsApp) with instance pinning.
This server implements the Model Context Protocol:
McpServer class from the official TypeScript SDK, which handles capability negotiation and session lifecycle automatically.registerTool() with Zod-validated input schemas — the SDK enforces types before the handler runs.All three connection parameters (API URL, API key, instance name) are pinned at startup via environment variables. The AI caller cannot switch instances mid-conversation.
| Tool | Description |
|---|---|
send_text |
Send a plain text message |
send_media |
Send an image, video, audio, or document |
send_audio |
Send a WhatsApp audio (PTT voice note) |
send_sticker |
Send a sticker (webp) |
send_location |
Send a location pin |
send_contact |
Share one or more contacts (vCards) |
send_reaction |
React to a message with an emoji |
send_poll |
Send a poll message |
send_list |
Send an interactive list/menu message |
send_button |
Send an interactive button message |
send_status |
Post a WhatsApp Status (story) update |
| Tool | Description |
|---|---|
find_chats |
Find chats, optionally filtered with a Prisma-style where clause |
find_contacts |
Find contacts, optionally filtered |
find_messages |
Find messages by remoteJid with optional limit |
get_chat_history |
Get message history for a contact or group JID |
mark_as_read |
Mark one or more messages as read |
archive_chat |
Archive or unarchive a chat |
delete_message |
Delete a message for everyone |
fetch_profile_picture |
Fetch a contact's profile picture URL |
download_media |
Download media from a message as base64 |
send_presence |
Send a presence update (typing, recording, etc.) |
check_number |
Check whether phone numbers have WhatsApp accounts |
| Tool | Description |
|---|---|
fetch_business_profile |
Fetch a contact's WhatsApp Business profile |
update_profile_name |
Update the instance's display name |
update_profile_status |
Update the instance's about/status text |
update_profile_picture |
Update the instance's profile picture |
remove_profile_picture |
Remove the instance's profile picture |
fetch_privacy |
Fetch current privacy settings |
update_privacy |
Update privacy settings |
update_block_status |
Block or unblock a contact |
| Tool | Description |
|---|---|
list_groups |
List all WhatsApp groups for the pinned instance |
get_group_info |
Get detailed info for a specific group by JID |
create_group |
Create a new WhatsApp group |
update_group_subject |
Update a group's name |
update_group_description |
Update a group's description |
update_group_picture |
Update a group's profile picture |
fetch_invite_code |
Fetch the invite code/link for a group |
revoke_invite_code |
Revoke and regenerate a group's invite code |
accept_invite |
Accept a group invite by code |
send_group_invite |
Send a group invite link to specific contacts |
update_participants |
Add, remove, promote, or demote group participants |
update_group_setting |
Update group settings (announcement mode, locked) |
leave_group |
Leave a group |
find_group_by_invite |
Get group info from an invite code without joining |
| Tool | Description |
|---|---|
connection_state |
Get the current connection state of the instance |
restart_instance |
Restart the instance (reconnects without logging out) |
logout_instance |
Logout the instance (clears session) |
get_settings |
Get current instance settings |
set_settings |
Update instance settings |
| Tool | Description |
|---|---|
find_webhook |
Get the current webhook configuration |
set_webhook |
Configure the webhook |
| Tool | Description |
|---|---|
find_labels |
List all labels (requires WhatsApp Business) |
handle_label |
Add or remove a label from a chat |
EVOLUTION_API_URL=http://localhost:8080 \
EVOLUTION_API_KEY=your-key \
EVOLUTION_INSTANCE=your-instance \
npx mcp-evolution
| Variable | Required | Description |
|---|---|---|
EVOLUTION_API_URL |
Yes | Base URL of your Evolution API (e.g. http://localhost:8080) |
EVOLUTION_API_KEY |
Yes | Global API key from Evolution API config |
EVOLUTION_INSTANCE |
Yes | Instance name created in Evolution API |
Copy .env.example to .env for local development.
Add to ~/.claude/claude_desktop_config.json or project .mcp.json:
{
"mcpServers": {
"whatsapp": {
"command": "npx",
"args": ["mcp-evolution"],
"env": {
"EVOLUTION_API_URL": "http://localhost:8080",
"EVOLUTION_API_KEY": "your-evolution-api-key",
"EVOLUTION_INSTANCE": "your-instance-name"
}
}
}
}
Or point directly at the built binary if running from a local checkout:
{
"mcpServers": {
"whatsapp": {
"command": "node",
"args": ["/absolute/path/to/mcp-evolution/dist/index.js"],
"env": {
"EVOLUTION_API_URL": "http://localhost:8080",
"EVOLUTION_API_KEY": "your-evolution-api-key",
"EVOLUTION_INSTANCE": "your-instance-name"
}
}
}
}
# Install dependencies
npm install
# Run in dev mode (no build step)
npm run dev
# Build TypeScript → dist/
npm run build
# Run tests
npm test
# Start from built output
npm start
| Tool | Method | Path |
|---|---|---|
send_text |
POST | /message/sendText/{instance} |
send_media |
POST | /message/sendMedia/{instance} |
send_audio |
POST | /message/sendWhatsAppAudio/{instance} |
send_sticker |
POST | /message/sendSticker/{instance} |
send_location |
POST | /message/sendLocation/{instance} |
send_contact |
POST | /message/sendContact/{instance} |
send_reaction |
POST | /message/sendReaction/{instance} |
send_poll |
POST | /message/sendPoll/{instance} |
send_list |
POST | /message/sendList/{instance} |
send_button |
POST | /message/sendButtons/{instance} |
send_status |
POST | /message/sendStatus/{instance} |
find_chats |
POST | /chat/findChats/{instance} |
find_contacts |
POST | /chat/findContacts/{instance} |
find_messages / get_chat_history |
POST | /chat/findMessages/{instance} |
mark_as_read |
POST | /chat/markMessageAsRead/{instance} |
archive_chat |
POST | /chat/archiveChat/{instance} |
delete_message |
DELETE | /chat/deleteMessageForEveryone/{instance} |
fetch_profile_picture |
POST | /chat/fetchProfilePictureUrl/{instance} |
download_media |
POST | /chat/getBase64FromMediaMessage/{instance} |
send_presence |
POST | /chat/sendPresence/{instance} |
check_number |
POST | /chat/whatsappNumbers/{instance} |
fetch_business_profile |
POST | /chat/fetchBusinessProfile/{instance} |
update_profile_name |
POST | /chat/updateProfileName/{instance} |
update_profile_status |
POST | /chat/updateProfileStatus/{instance} |
update_profile_picture |
POST | /chat/updateProfilePicture/{instance} |
remove_profile_picture |
DELETE | /chat/removeProfilePicture/{instance} |
fetch_privacy |
GET | /chat/fetchPrivacySettings/{instance} |
update_privacy |
POST | /chat/updatePrivacySettings/{instance} |
update_block_status |
POST | /chat/updateBlockStatus/{instance} |
list_groups |
GET | /group/fetchAllGroups/{instance} |
get_group_info |
GET | /group/findGroupInfos/{instance} |
create_group |
POST | /group/create/{instance} |
update_group_subject |
POST | /group/updateGroupSubject/{instance}?groupJid= |
update_group_description |
POST | /group/updateGroupDescription/{instance}?groupJid= |
update_group_picture |
POST | /group/updateGroupPicture/{instance}?groupJid= |
fetch_invite_code |
GET | /group/inviteCode/{instance}?groupJid= |
revoke_invite_code |
POST | /group/revokeInviteCode/{instance}?groupJid= |
accept_invite |
GET | /group/acceptInviteCode/{instance}?inviteCode= |
send_group_invite |
POST | /group/sendInvite/{instance} |
update_participants |
POST | /group/updateParticipant/{instance}?groupJid= |
update_group_setting |
POST | /group/updateSetting/{instance}?groupJid= |
leave_group |
DELETE | /group/leaveGroup/{instance}?groupJid= |
find_group_by_invite |
GET | /group/inviteInfo/{instance}?inviteCode= |
connection_state |
GET | /instance/connectionState/{instance} |
restart_instance |
POST | /instance/restart/{instance} |
logout_instance |
DELETE | /instance/logout/{instance} |
get_settings |
GET | /settings/find/{instance} |
set_settings |
POST | /settings/set/{instance} |
find_webhook |
GET | /webhook/find/{instance} |
set_webhook |
POST | /webhook/set/{instance} |
find_labels |
GET | /label/findLabels/{instance} |
handle_label |
POST | /label/handleLabel/{instance} |
Requires Evolution API v2.
MIT — see LICENSE.
Community software, not affiliated with Evolution API or any WhatsApp entity.
Добавь это в claude_desktop_config.json и перезапусти Claude Desktop.
{
"mcpServers": {
"mcp-evolution": {
"command": "npx",
"args": []
}
}
}Read, send and search emails from Claude
Send, search and summarize Slack messages
No-code MCP client for team chat platforms, such as Slack, Microsoft Teams, and Discord.
A community discord server dedicated to MCP by [Frank Fiegel](https://github.com/punkpeye)