WhatsApp MCP Server
Allows AI assistants to manage WhatsApp, including listing chats, searching contacts, sending text messages and files, downloading media, transcribing voice notes, and syncing contacts.
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., "@WhatsApp MCP Serversend a message to John Doe saying 'See you at 5pm'"
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.
WhatsApp MCP Server
A Model Context Protocol (MCP) server that connects to WhatsApp via Baileys, providing AI with the ability to manage WhatsApp. This is a security-hardened fork of karlfoster/whatsapp-mcp-2.0.
⚠️ WARNING
This project uses the UNOFFICIAL WhatsApp Web API (Baileys). WhatsApp may ban accounts using unofficial clients. USE A DEDICATED BURNER NUMBER — never use your personal number. The authors take no responsibility for account bans or any other consequences of using this software.
What This Is
This is a fork of karlfoster/whatsapp-mcp-2.0 with significant security hardening and operational improvements. It allows an AI assistant (like Claude) to:
List and search chats, contacts, and messages.
Send text messages and files (images, videos, documents, audio).
Download media from received messages.
Transcribe voice notes via Whisper-compatible APIs.
Sync phone contacts from VCF files.
Setup
Clone the repository:
git clone <repo-url> cd whatsapp-mcpInstall dependencies:
npm ciConfigure environment variables: Create a
.envfile or set them in your MCP client configuration (see below).Run the server:
npm run devScan the QR code: On first run, a QR code will appear in your terminal. Scan it with WhatsApp on your phone: WhatsApp > Settings > Linked Devices > Link a Device
Environment Variables
Variable | Default | Description |
|
| Directory for outbound file sends. |
|
| Max file size for |
|
| Directory for downloaded media. |
|
| Base directory for VCF imports. |
| (none) | Whisper API endpoint for transcription. |
| (none) | API key for Whisper. |
|
| Model name for transcription. |
|
| Silence before zombie connection detection. |
|
| Consecutive failures before reconnect. |
|
| Minimum delay between sends. |
|
| Random jitter added to send delay. |
|
| Max reconnect attempts before giving up. |
Storage Locations
auth_info/: WhatsApp authentication credentials (DO NOT commit).data/: SQLite database containing messages, chats, and contacts.store/: Baileys message store and.whatsapp.lockfile.uploads/: Files to send (only files in this directory can be sent viasend_file).downloads/: Downloaded media files.contacts/: VCF files for contact import.
Running Tests
This project uses Vitest for testing.
# Run all tests
npx vitest run
# Run tests with coverage
npx vitest run --coverageKnown Limitations
No FTS5: SQLite full-text search is not used; substring search (
LIKE) is used instead.No Read Receipts: The server does not send read receipts.
No Reactions: Message reactions are not supported.
No Stories: WhatsApp Stories/Status updates are not accessible.
Security Changes (What changed from upstream)
Path Traversal Protection: Strict containment checks for
send_fileanddownload_mediausing resolved paths.SSRF Validation:
WHISPER_API_URLis validated to prevent SSRF attacks (rejects localhost and private IP ranges).Atomic Lock File: Prevents multiple instances from connecting to the same WhatsApp account simultaneously.
Strict Filename Sanitization: All filenames are sanitized to prevent injection and traversal.
Bounded Memory Caches: Prevents unbounded memory growth in Baileys message retry and device tracking.
Pre-key Pruning: Automatically prunes old pre-keys to prevent disk bloat.
Removed
reply_spam: Removed the UAE-specific spam reply tool for better general-purpose use.Streamed Uploads:
send_fileuses streams instead of loading full files into memory.
Available Tools
list_chats: List chats sorted by last activity.get_chat: Get chat details with recent messages.list_messages: Get messages from a chat.search_messages: Substring search across messages.search_contacts: Find contacts by name or phone number.get_message_context: Get messages surrounding a specific message.get_my_profile: Get your own JID and profile info.update_contact: Update a contact's display name.sync_contacts: Import phone contacts from a VCF file.send_message: Send a text message (requires confirmation).send_file: Send a media file (requires confirmation).delete_message: Delete a message (requires confirmation).delete_chat: Delete an entire chat (requires confirmation).download_media: Download media from a message to disk.transcribe_voice_note: Transcribe a voice note to text.
License
MIT
This 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/sjawhar/whatsapp-mcp-2.0'
If you have feedback or need assistance with the MCP directory API, please join our Discord server