MCP Hub
Back to servers

WAHA MCP Server

Bridges the WhatsApp HTTP API with AI assistants to enable full control over messaging, chat management, and interactive workflows through 63 specialized tools. It allows users to automate WhatsApp tasks and receive real-time AI feedback directly on their mobile devices.

Stars
3
Updated
Jan 28, 2026
Validated
Feb 9, 2026
WAHA MCP Logo

WAHA MCP Server

WhatsApp HTTP API integration for Claude Desktop & MCP-compatible clients

License: MIT Node.js Version MCP Compatible TypeScript

DocumentationInstallationConfiguration🤖 Claude Code SetupTools Reference


🚀 What is WAHA MCP?

WAHA MCP Server bridges the powerful WAHA (WhatsApp HTTP API) with AI assistants like Claude Desktop, enabling seamless WhatsApp automation through the Model Context Protocol (MCP).

✨ Key Features

  • 📱 Complete WhatsApp Control - Send/receive messages, manage chats, create groups
  • 🎯 63 Tools - Comprehensive API coverage for sessions, messaging, contacts, groups, and interactive workflows
  • 🔄 Smart Media Handling - Auto-conversion for voice/video, support for URLs & local files
  • 🤖 AI-Native - Built specifically for LLM integration via MCP
  • 🔒 Secure - Environment-based API key management
  • Fast & Reliable - TypeScript-powered with robust error handling

📋 Prerequisites

Before you begin, ensure you have:


🛠️ Installation

1. Clone & Install

git clone https://github.com/dudu1111685/waha-mcp.git
cd waha-mcp
npm install
npm run build

2. Set Environment Variables

Create a .env file or export variables:

export WAHA_API_KEY="your-api-key-here"
export WAHA_URL="http://localhost:3001"  # Optional, defaults to localhost:3001

⚙️ Configuration

Claude Desktop

Add to claude_desktop_config.json:

Linux: ~/.config/claude/claude_desktop_config.json
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json

{
  "mcpServers": {
    "waha": {
      "command": "node",
      "args": ["/absolute/path/to/waha-mcp/dist/index.js"],
      "env": {
        "WAHA_API_KEY": "your-api-key-here",
        "WAHA_URL": "http://localhost:3001"
      }
    }
  }
}

Cline / VS Code

Add to your Cline MCP settings (~/.vscode/mcp.json or workspace settings):

{
  "mcpServers": {
    "waha": {
      "command": "node",
      "args": ["/absolute/path/to/waha-mcp/dist/index.js"],
      "env": {
        "WAHA_API_KEY": "your-api-key-here"
      }
    }
  }
}

Claude Code (Autonomous Development)

🤖 Enable truly autonomous AI development:

Instead of Claude stopping when it needs user input, it can ask questions via WhatsApp and continue working!

🚀 Complete Setup Guide: CLAUDE_CODE_SETUP.md

Quick config example:

{
  "mcpServers": {
    "waha": {
      "command": "node",
      "args": ["/path/to/waha-mcp/dist/index.js"],
      "env": {
        "WAHA_API_KEY": "your-key",
        "USER_WHATSAPP_CHAT_ID": "1234567890@c.us"
      }
    }
  },
  "globalInstructions": "When you need user input during development, use ask_user_via_whatsapp tool. Never stop and wait for manual console input."
}

How it works:

  1. Claude hits a question → asks via WhatsApp
  2. You reply from your phone
  3. Claude continues working immediately
  4. Zero downtime! ⚡

📖 See also:

Other MCP Clients

Use the mcporter CLI for quick testing:

mcporter call 'waha-mcp.waha_list_sessions()'
mcporter call 'waha-mcp.waha_send_text(chatId: "1234567890@c.us", text: "Hello from MCP!")'

🧰 Tools Reference

📂 Categories

Session Management (8 tools)
ToolDescription
waha_list_sessionsList all sessions and their statuses
waha_get_sessionGet detailed info about a session
waha_create_sessionCreate a new session
waha_start_sessionStart a stopped session
waha_stop_sessionStop a running session
waha_restart_sessionRestart a session
waha_delete_sessionDelete a session permanently
waha_logout_sessionDisconnect WhatsApp account from session
Authentication (3 tools)
ToolDescription
waha_get_qr_codeGet QR code for WhatsApp authentication
waha_request_pairing_codeRequest phone number pairing code
waha_check_auth_statusCheck session authentication status
Messaging (14 tools)
ToolDescription
waha_send_textSend a text message
waha_send_imageSend an image (local file or URL)
waha_send_videoSend a video with auto-conversion
waha_send_voiceSend a voice message with auto-conversion
waha_send_fileSend any document/file
waha_send_locationSend a location pin
waha_send_contactSend a contact vCard
waha_send_pollCreate and send a poll
waha_react_to_messageReact with emoji 👍❤️😂
waha_forward_messageForward a message
waha_get_messagesGet messages with pagination
waha_delete_messageDelete a message
waha_edit_messageEdit a sent message
waha_mark_as_readMark messages as read
waha_star_messageStar/unstar a message

📤 Media Upload Features:

  • ✅ Local files & URLs supported
  • ✅ Auto MIME type detection
  • ✅ Auto video/voice conversion to WhatsApp format
  • ✅ 50+ file types supported
  • ✅ Base64 encoding handled automatically
Chat Management (7 tools)
ToolDescription
waha_list_chatsList all chats
waha_get_chatGet detailed chat info
waha_archive_chatArchive/unarchive a chat
waha_pin_chatPin/unpin a chat
waha_mute_chatMute/unmute a chat
waha_delete_chatDelete a chat
waha_clear_chatClear all messages
Contacts (5 tools)
ToolDescription
waha_get_contactsGet all contacts
waha_get_contactGet info about a contact
waha_check_number_existsCheck if number is on WhatsApp
waha_block_contactBlock/unblock a contact
waha_get_profile_pictureGet profile picture URL
Groups (13 tools)
ToolDescription
waha_create_groupCreate a new group
waha_list_groupsList all groups
waha_get_groupGet detailed group info
waha_get_group_participantsList group participants
waha_add_group_participantsAdd participants
waha_remove_group_participantsRemove participants
waha_promote_group_participantPromote to admin
waha_demote_group_participantDemote from admin
waha_update_group_subjectUpdate group name
waha_update_group_descriptionUpdate group description
waha_update_group_pictureSet group profile picture
waha_leave_groupLeave a group
waha_get_group_invite_codeGet invite link
waha_revoke_group_inviteRevoke & regenerate link
Presence & Status (5 tools)
ToolDescription
waha_set_presenceSet online/offline status
waha_get_presenceGet contact's presence
waha_start_typingShow typing indicator
waha_stop_typingStop typing indicator
waha_send_statusPost a text status/story
Labels (5 tools)
ToolDescription
waha_get_labelsGet all labels
waha_create_labelCreate a new label
waha_delete_labelDelete a label
waha_add_label_to_chatAdd label to chat
waha_remove_label_from_chatRemove label from chat
🆕 Interactive Workflows (1 tool)
ToolDescription
ask_user_via_whatsapp🚀 NEW! Send a question and WAIT for user reply (blocking operation). Perfect for Claude Code workflows that need user input mid-execution.

Use Case Example:

// Claude Code is building a feature and needs clarification
const reply = await ask_user_via_whatsapp({
  question: "Should I use REST or GraphQL for the API?",
  chatId: "1234567890@c.us",
  timeoutMinutes: 30
});
// User replies from phone: "Use GraphQL"
// Claude Code continues with GraphQL implementation

How it works:

  1. Sends your question via WhatsApp
  2. Polls for new messages from the user
  3. Returns the reply text when received
  4. Includes timeout handling (default: 60 minutes)

Perfect for:

  • 🤖 Claude Code asking questions mid-workflow
  • 💡 Getting user input while you're away from the computer
  • 🔄 Building truly interactive AI automations
  • 📱 Answering from your phone while AI continues working

📚 Chat ID Formats

Understanding WhatsApp ID formats:

TypeFormatExample
User{phone}@c.us1234567890@c.us
Group{id}@g.us1234567890-1234567890@g.us
Channel{id}@newsletter1234567890@newsletter
Statusstatus@broadcaststatus@broadcast

Note: Phone numbers should exclude the + prefix.


🎯 Quick Examples

Send a Text Message

mcporter call 'waha-mcp.waha_send_text(
  chatId: "1234567890@c.us",
  text: "Hello from WAHA MCP!"
)'

Send an Image from URL

mcporter call 'waha-mcp.waha_send_image(
  chatId: "1234567890@c.us",
  imageUrl: "https://example.com/photo.jpg",
  caption: "Check this out!"
)'

Create a Group & Add Participants

# Create group
mcporter call 'waha-mcp.waha_create_group(
  name: "Team Chat",
  participants: ["1111111111@c.us", "2222222222@c.us"]
)'

# Add more participants
mcporter call 'waha-mcp.waha_add_group_participants(
  chatId: "{group_id}@g.us",
  participants: ["3333333333@c.us"]
)'

List All Chats

mcporter call 'waha-mcp.waha_list_chats()'

🧪 Development

Run in Watch Mode

npm run dev  # Recompiles on file changes

Run Tests

npm test

Build for Production

npm run build

📖 Documentation

For detailed documentation, see the docs folder:


🤝 Contributing

Contributions are welcome! Please feel free to submit issues or pull requests.

  1. Fork the repository
  2. Create a feature branch (git checkout -b feature/amazing-feature)
  3. Commit your changes (git commit -m 'Add amazing feature')
  4. Push to the branch (git push origin feature/amazing-feature)
  5. Open a Pull Request

📄 License

This project is licensed under the MIT License - see the LICENSE file for details.


🙏 Acknowledgments


Built with ❤️ for the MCP community

⭐ Star this repo🐛 Report Bug💡 Request Feature

Reviews

No reviews yet

Sign in to write a review