ManyContacts MCP Server
OfficialThe ManyContacts MCP Server enables AI agents to programmatically manage a WhatsApp Business CRM, covering contacts, messaging, campaigns, teams, pipelines, and AI auto-reply agents.
Account & Organization
Get a full account overview (channels, counts, features)
Retrieve and update organization settings (timezone, auto-reply, webhooks)
Get business hours and REST API key
List connected WhatsApp Business and Instagram channels
Contact Management
List contacts with advanced filters (open/closed, tags, teams, stages, date range, unread, blacklisted, scheduled)
Get detailed contact info (tags, teams, funnel stages, custom fields)
Create, update, and delete contacts
Assign/unassign contacts to team members, open/close conversations
Add/remove tags and teams, move contacts through funnel stages
Bulk operations (close, open, assign, tag, team) on multiple contacts at once
Messaging
View conversation history, send text messages, create internal notes
Send pre-approved WhatsApp Business template messages (for outbound or outside the 24h window)
Templates
List, get details of, and sync WhatsApp Business message templates (filter by approval status)
Campaigns
List, create, and delete bulk WhatsApp messaging campaigns with scheduled delivery
Tags
List, create, update, and delete contact tags (with color support)
Teams
List, create, and delete teams; add/remove members
Sales Funnels / Pipelines
List, create, and delete funnels; add/update stages; list contacts by funnel or stage
Users / Team Members
List, get, update, invite, and delete team members
AI Agents
List, get details for, enable/disable, and update AI auto-reply agent configurations
View feedback and conversation logs for AI agents
Provides integration with Instagram channels for contact management and messaging through the ManyContacts CRM platform.
Integrates with Meta Cloud API for WhatsApp message template synchronization and management within the ManyContacts CRM.
Provides comprehensive WhatsApp Business CRM capabilities including contact management, messaging, template handling, and campaign management through ManyContacts.
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., "@ManyContacts MCP Serverlist my recent unread contacts and tag them as 'follow-up'"
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.
ManyContacts MCP Server
MCP (Model Context Protocol) server for ManyContacts — the WhatsApp Business CRM. Enables AI agents (Claude, Cursor, Windsurf, etc.) to manage contacts, send WhatsApp messages, run campaigns, configure AI auto-replies, and perform all CRM operations programmatically.
Quick Start
1. Get your CLI token
npm install -g @manycontacts/cliAlready have an account? Log in:
mc auth login --email user@example.com --password mypassword
mc auth whoami # verify it worksNew to ManyContacts? Create an account and connect your WhatsApp channel:
# Register a new account
mc auth register --email user@example.com --name "My Company"
# Connect a WhatsApp Business channel (choose one method):
mc channels connect whatsapp-api # WhatsApp Cloud API (recommended)
mc channels connect coexistence # ManyContacts coexistence mode
mc channels connect qr # QR code pairing
# Verify everything is set up
mc auth whoami
mc channels list2. Configure in your MCP client
Claude Desktop / Claude Code
Add to your MCP settings (~/.claude/claude_desktop_config.json or similar):
{
"mcpServers": {
"manycontacts": {
"command": "npx",
"args": ["@manycontacts/mcp"],
"env": {
"MC_CLI_TOKEN": "your-cli-token-here"
}
}
}
}Cursor
Add to .cursor/mcp.json:
{
"mcpServers": {
"manycontacts": {
"command": "npx",
"args": ["@manycontacts/mcp"],
"env": {
"MC_CLI_TOKEN": "your-cli-token-here"
}
}
}
}Tip: If you've already logged in via the CLI (
mc auth login), the token is stored in~/.manycontacts/config.jsonand the MCP server will pick it up automatically — noMC_CLI_TOKENenv var needed.
Available Tools (55 total)
Account & Context
manycontacts.context
Get a full overview of your ManyContacts account: connected WhatsApp Business channels, contact/user/tag counts, active AI agents, and enabled features. Use this first to understand the account state before performing other operations.
Parameter | Type | Required | Description |
(none) | — | — | No parameters needed |
manycontacts.org.get
Get WhatsApp Business organization/account information including name, timezone, and all configuration settings.
Parameter | Type | Required | Description |
(none) | — | — | No parameters needed |
manycontacts.org.update
Update organization-level settings such as timezone, auto-reply messages, auto-close behavior, and webhook configuration.
Parameter | Type | Required | Description |
|
| No | Timezone identifier (e.g. |
|
| No | Enable auto-reply when a new chat is opened |
|
| No | Auto-reply message text when chat opens |
|
| No | Enable auto-reply when a chat is closed |
|
| No | Auto-reply message text when chat closes |
|
| No | Minutes of inactivity before auto-close |
|
| No | Enable away/out-of-hours auto-reply |
|
| No | Away auto-reply message text |
|
| No | Enable webhook forwarding to an external URL |
|
| No | External URL to forward webhook events to |
manycontacts.org.schedule.get
Get the business hours schedule. Returns the configured working hours for each day of the week, used to determine when the "away" auto-reply activates.
Parameter | Type | Required | Description |
(none) | — | — | No parameters needed |
manycontacts.org.apikey
Get the organization's REST API key for direct API integrations.
Parameter | Type | Required | Description |
(none) | — | — | No parameters needed |
manycontacts.channels.list
List all connected WhatsApp Business and Instagram channels. For WhatsApp channels, shows the phone number and connection status. For Instagram channels, shows the username.
Parameter | Type | Required | Description |
(none) | — | — | No parameters needed |
Contacts
All contact operations use phone numbers as identifiers (with country code, no + prefix, e.g. 34600000000).
manycontacts.contacts.list
List WhatsApp Business contacts with advanced filters. Returns paginated results with has_more indicator. Filters can be combined freely.
Parameter | Type | Required | Description |
|
| No | Page number (default: |
|
| No | Results per page, max |
|
| No | Filter by conversation open/closed status |
|
| No | Filter by assigned user ID |
|
| No | Comma-separated tag IDs — contacts must have all specified tags |
|
| No | Filter by team ID |
|
| No | Comma-separated funnel stage IDs |
|
| No | Filter contacts updated after this date ( |
|
| No | Filter contacts updated before this date ( |
|
| No | Only contacts with unread messages |
|
| No | Only blacklisted contacts |
|
| No | Only contacts with pending scheduled messages |
Note: When using
date_fromanddate_totogether, the range cannot exceed 90 days.
Response:
{
"ok": true,
"data": [
{
"name": "John Doe",
"number": "34600000000",
"open": true,
"last_user_id": "uuid-of-assigned-user",
"source": "whatsapp",
"notes": "VIP customer",
"customFields": {},
"createdAt": "2026-01-15T10:30:00Z"
}
],
"pagination": { "page": 1, "limit": 50, "has_more": true }
}manycontacts.contacts.get
Get detailed information about a specific contact including their tags, teams, funnel stages, and custom fields.
Parameter | Type | Required | Description |
|
| Yes | Phone number with country code (e.g. |
manycontacts.contacts.create
Create a new WhatsApp Business contact in the CRM. The phone number will be normalized automatically (leading + removed).
Parameter | Type | Required | Description |
|
| Yes | Phone number with country code (e.g. |
|
| No | Contact display name |
|
| No | Free-text notes for the contact |
manycontacts.contacts.update
Update an existing contact's name, notes, or custom fields.
Parameter | Type | Required | Description |
|
| Yes | Phone number of the contact to update |
|
| No | New contact name |
|
| No | New contact notes |
|
| No | Custom fields as a JSON string (e.g. |
manycontacts.contacts.delete
Permanently delete a contact from the CRM.
Parameter | Type | Required | Description |
|
| Yes | Phone number of the contact to delete |
manycontacts.contacts.assign
Assign a contact to a specific team member. The assigned user will see this contact in their personal inbox.
Parameter | Type | Required | Description |
|
| Yes | Phone number of the contact |
|
| Yes | User ID to assign the contact to (use |
manycontacts.contacts.unassign
Remove the current user assignment from a contact. The contact returns to the general unassigned inbox.
Parameter | Type | Required | Description |
|
| Yes | Phone number of the contact |
manycontacts.contacts.close
Close a WhatsApp conversation. Closed conversations are archived and won't appear in the active inbox.
Parameter | Type | Required | Description |
|
| Yes | Phone number of the contact |
manycontacts.contacts.open
Reopen a previously closed WhatsApp conversation. The contact will appear again in the active inbox.
Parameter | Type | Required | Description |
|
| Yes | Phone number of the contact |
manycontacts.contacts.tag.add
Add a tag to a contact. Use manycontacts.tags.list to get available tag IDs.
Parameter | Type | Required | Description |
|
| Yes | Phone number of the contact |
|
| Yes | Tag ID to add |
manycontacts.contacts.tag.remove
Remove a tag from a contact.
Parameter | Type | Required | Description |
|
| Yes | Phone number of the contact |
|
| Yes | Tag ID to remove |
manycontacts.contacts.team.add
Add a team to a contact. Use manycontacts.teams.list to get available team IDs.
Parameter | Type | Required | Description |
|
| Yes | Phone number of the contact |
|
| Yes | Team ID to add |
manycontacts.contacts.team.remove
Remove a team from a contact.
Parameter | Type | Required | Description |
|
| Yes | Phone number of the contact |
|
| Yes | Team ID to remove |
manycontacts.contacts.set_stage
Move a contact to a specific stage within a sales funnel/pipeline. Use manycontacts.funnels.list to get funnel and stage IDs.
Parameter | Type | Required | Description |
|
| Yes | Phone number of the contact |
|
| Yes | Funnel ID |
|
| Yes | Target stage ID within the funnel |
manycontacts.contacts.bulk
Perform bulk operations on multiple contacts at once. Supports closing, opening, assigning, tagging, and team assignment.
Parameter | Type | Required | Description |
|
| Yes | Bulk action to perform |
|
| Yes | Comma-separated phone numbers (e.g. |
|
| No | Value required by the action: user ID for |
Messaging
manycontacts.messages.list
List WhatsApp conversation messages for a contact. Returns messages in a conversation-friendly format with timestamps, status, and sender information.
Parameter | Type | Required | Description |
|
| Yes | Phone number of the contact |
|
| No | Page number (default: |
|
| No | Messages per page (default: |
manycontacts.messages.send.text
Send a WhatsApp text message to a contact. Only works within the 24-hour conversation window. Use manycontacts.messages.send.template to initiate conversations outside this window.
Parameter | Type | Required | Description |
|
| Yes | Phone number to send the message to |
|
| Yes | Message text content |
manycontacts.messages.send.note
Create an internal note on a contact's conversation. Notes are only visible to team members and are not sent to the WhatsApp contact.
Parameter | Type | Required | Description |
|
| Yes | Phone number of the contact |
|
| Yes | Internal note text |
manycontacts.messages.send.template
Send a WhatsApp Business template message. Templates are required to initiate conversations outside the 24-hour window or for bulk outbound messaging. Templates must be pre-approved by Meta.
Parameter | Type | Required | Description |
|
| Yes | Phone number to send the template to |
|
| Yes | Template ID (use |
|
| No | Template variables as a JSON array string (e.g. |
Templates
WhatsApp Business templates are pre-approved message formats required for outbound messaging outside the 24-hour conversation window.
manycontacts.templates.list
List all WhatsApp Business message templates. Shows template name, code, status, components, and media flags.
Parameter | Type | Required | Description |
|
| No | Filter templates by approval status |
manycontacts.templates.get
Get full details of a specific template including its components (header, body, footer, buttons), configuration, and media attachments.
Parameter | Type | Required | Description |
|
| Yes | Template ID |
manycontacts.templates.sync
Sync WhatsApp Business templates from Meta Cloud API. Fetches the latest templates from the connected WhatsApp Business account. Useful after creating or modifying templates in the Meta Business Manager.
Parameter | Type | Required | Description |
(none) | — | — | No parameters needed |
Campaigns
Campaigns allow bulk sending of WhatsApp template messages to a list of phone numbers at a scheduled time.
manycontacts.campaigns.list
List all WhatsApp Business bulk messaging campaigns with statistics (sent, delivered, read, and failed counts), template names, and scheduled dates.
Parameter | Type | Required | Description |
(none) | — | — | No parameters needed |
manycontacts.campaigns.create
Create a new WhatsApp Business bulk messaging campaign. The campaign will send a template message to the specified phone numbers at the scheduled time.
Parameter | Type | Required | Description |
|
| Yes | Campaign name |
|
| Yes | WhatsApp template ID to use (must be |
|
| Yes | Comma-separated phone numbers (e.g. |
|
| Yes | Scheduled send date in ISO format (e.g. |
|
| No | Template variables as a JSON array string (e.g. |
manycontacts.campaigns.delete
Delete a WhatsApp Business campaign. Only pending (not yet sent) campaigns can be deleted.
Parameter | Type | Required | Description |
|
| Yes | Campaign ID to delete |
Tags
Tags are colored labels used to categorize and filter WhatsApp Business contacts (e.g. "VIP", "Support", "Lead").
manycontacts.tags.list
List all available tags with their names, colors, and IDs.
Parameter | Type | Required | Description |
(none) | — | — | No parameters needed |
manycontacts.tags.create
Create a new tag for categorizing contacts.
Parameter | Type | Required | Description |
|
| Yes | Tag name |
|
| No | Tag color as hex code (e.g. |
manycontacts.tags.update
Update an existing tag's name or color.
Parameter | Type | Required | Description |
|
| Yes | Tag ID to update |
|
| No | New tag name |
|
| No | New tag color as hex code |
manycontacts.tags.delete
Delete a tag. The tag will be removed from all contacts that have it.
Parameter | Type | Required | Description |
|
| Yes | Tag ID to delete |
Teams
Teams group users together for assignment routing and contact organization.
manycontacts.teams.list
List all teams in the organization.
Parameter | Type | Required | Description |
(none) | — | — | No parameters needed |
manycontacts.teams.create
Create a new team.
Parameter | Type | Required | Description |
|
| Yes | Team name |
manycontacts.teams.add_member
Add a user to a team.
Parameter | Type | Required | Description |
|
| Yes | Team ID |
|
| Yes | User ID to add to the team |
manycontacts.teams.remove_member
Remove a user from a team.
Parameter | Type | Required | Description |
|
| Yes | Team ID |
|
| Yes | User ID to remove from the team |
manycontacts.teams.delete
Delete a team. Team members are not deleted, only the team grouping.
Parameter | Type | Required | Description |
|
| Yes | Team ID to delete |
Sales Funnels / Pipelines
Funnels allow you to track contacts through a multi-stage sales or support pipeline (e.g. "New Lead" -> "Qualified" -> "Proposal" -> "Won").
manycontacts.funnels.list
List all sales funnels/pipelines with their stages.
Parameter | Type | Required | Description |
(none) | — | — | No parameters needed |
manycontacts.funnels.create
Create a new sales funnel/pipeline.
Parameter | Type | Required | Description |
|
| Yes | Funnel name |
manycontacts.funnels.add_stage
Add a new stage to an existing funnel.
Parameter | Type | Required | Description |
|
| Yes | Funnel ID |
|
| Yes | Stage name (e.g. "Qualified", "Proposal Sent") |
|
| Yes | Stage position in the pipeline (0-based) |
manycontacts.funnels.update_stage
Update a stage's name within a funnel.
Parameter | Type | Required | Description |
|
| Yes | Funnel ID |
|
| Yes | Stage ID to update |
|
| No | New stage name |
manycontacts.funnels.contacts
List contacts currently in a specific funnel, optionally filtered by stage. Returns paginated results.
Parameter | Type | Required | Description |
|
| Yes | Funnel ID |
|
| No | Filter by specific stage ID |
|
| No | Page number |
|
| No | Results per page |
manycontacts.funnels.delete
Delete a sales funnel/pipeline and all its stages. Contacts in the funnel are not deleted.
Parameter | Type | Required | Description |
|
| Yes | Funnel ID to delete |
Users / Team Members
Manage the team members who have access to the WhatsApp Business CRM.
manycontacts.users.list
List all team members/users in the organization with their roles and details.
Parameter | Type | Required | Description |
(none) | — | — | No parameters needed |
manycontacts.users.get
Get details of a specific team member.
Parameter | Type | Required | Description |
|
| Yes | User ID |
manycontacts.users.update
Update a team member's profile information.
Parameter | Type | Required | Description |
|
| Yes | User ID to update |
|
| No | New user display name |
manycontacts.users.invite
Invite a new team member to the organization by email. They will receive an invitation email to join.
Parameter | Type | Required | Description |
|
| Yes | Email address to send the invitation to |
manycontacts.users.delete
Remove a team member from the organization. Their assigned contacts will become unassigned.
Parameter | Type | Required | Description |
|
| Yes | User ID to remove |
AI Agents
AI agents auto-respond to incoming WhatsApp messages using configurable instructions and scenarios. Only active agents are listed.
manycontacts.ai_agents.list
List all active AI auto-reply agents with their configuration.
Parameter | Type | Required | Description |
(none) | — | — | No parameters needed |
manycontacts.ai_agents.get
Get full details of a specific AI agent including its scenarios (conversation flows), instruction blocks, and configuration.
Parameter | Type | Required | Description |
|
| Yes | AI Agent ID (UUID) |
manycontacts.ai_agents.update
Update an AI agent's configuration. You can enable/disable the agent or modify its instruction blocks.
Parameter | Type | Required | Description |
|
| Yes | AI Agent ID (UUID) |
|
| No | Enable ( |
|
| No | Agent instructions — block 1 |
|
| No | Agent instructions — block 2 |
|
| No | Agent instructions — block 3 |
manycontacts.ai_agents.feedback
Get feedback and conversation logs for an AI agent. Shows how the agent has been responding and user satisfaction data.
Parameter | Type | Required | Description |
|
| Yes | AI Agent ID (UUID) |
Available Prompts (6 total)
Pre-built prompts that guide AI agents through common workflows. Use these to quickly accomplish multi-step tasks.
contact-lookup
Look up a WhatsApp contact and get a complete summary of their profile, tags, funnel stage, and recent messages.
Argument | Required | Description |
| Yes | Phone number in international format (e.g. |
send-campaign
Step-by-step guide to creating a WhatsApp bulk campaign: lists available templates, asks for recipients and schedule, then creates the campaign.
Argument | Required | Description |
(none) | — | Interactive guided workflow |
daily-dashboard
Generates a complete overview of your ManyContacts account including channels, open conversations, team structure, and sales funnels.
Argument | Required | Description |
(none) | — | No arguments needed |
reply-to-contact
Reviews recent conversation history with a contact, then sends a WhatsApp message with full context.
Argument | Required | Description |
| Yes | Phone number in international format (e.g. |
| Yes | The message text to send |
manage-funnel
Displays all sales funnels with their stages and contact counts per stage, giving a visual pipeline overview.
Argument | Required | Description |
(none) | — | No arguments needed |
bulk-tag-contacts
Tags multiple contacts at once — finds or creates the tag, then applies it in bulk.
Argument | Required | Description |
| Yes | Comma-separated phone numbers (e.g. |
| Yes | Name of the tag to apply |
Environment Variables
Variable | Required | Description |
| Yes* | ManyContacts CLI authentication token. Get one via |
| No | API base URL (default: |
*If you've logged in via the CLI, the token is stored locally at
~/.manycontacts/config.jsonand the MCP server reads it automatically.
Authentication
The MCP server authenticates using CLI tokens. Each token is scoped to an organization and has configurable permissions.
# Login to get a token
mc auth login --email user@example.com --password mypassword
# The token is stored at ~/.manycontacts/config.json
# Or set it explicitly via environment variable:
export MC_CLI_TOKEN=your-token-hereRate Limits
Paying accounts: 60 requests/minute
Free/trial accounts: 10 requests/minute
When rate limited, the server returns a 429 error with a link to upgrade.
License
MIT
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/ManyContacts/mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server