Enables AI-powered SMS and MMS messaging through Twilio's API, with features for sending/receiving messages, tracking delivery status, managing conversation threads, and processing webhooks for inbound communications.
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., "@Twilio MCP Serversend a text to +15551234567 saying 'Your appointment is confirmed for tomorrow at 2 PM'"
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.
Twilio MCP Server
A Model Context Protocol (MCP) server for Twilio that enables AI-powered SMS messaging with intelligent conversation management.
Features
Send SMS - Send text messages via Twilio with automatic conversation threading
Receive SMS - Process inbound messages via webhooks with automatic storage
Conversation Management - Track and manage multi-turn SMS conversations
Message Status - Check delivery status of sent messages
Thread Association - Automatically link messages to conversation threads
MMS Support - Send and receive multimedia messages (optional)
Installation
# Clone the repository
git clone <repository-url>
cd twilio-mcp
# Install dependencies
npm install
# Build the project
npm run buildConfiguration
Copy the environment template:
cp .env.example .envFill in your Twilio credentials in
.env:
# Get these from https://console.twilio.com
TWILIO_ACCOUNT_SID=ACxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
TWILIO_AUTH_TOKEN=your_auth_token_here
TWILIO_PHONE_NUMBER=+1234567890
# Webhook configuration
WEBHOOK_PORT=3000
WEBHOOK_BASE_URL=https://your-domain.com
# Database path
DATABASE_PATH=./data/twilio.dbSetting Up Webhooks
For the server to receive inbound SMS, you need to configure Twilio webhooks:
Development (Using ngrok)
Install ngrok: https://ngrok.com/download
Start the webhook server:
npm run devIn another terminal, start ngrok:
ngrok http 3000Copy the HTTPS URL from ngrok (e.g.,
https://abc123.ngrok.io)Configure Twilio webhook:
Go to https://console.twilio.com/us1/develop/phone-numbers/manage/incoming
Select your phone number
Under "Messaging Configuration":
Webhook URL:
https://abc123.ngrok.io/webhooks/twilio/smsHTTP Method: POST
Under "Status Callback URL":
URL:
https://abc123.ngrok.io/webhooks/twilio/status
Save
Production
Deploy the webhook server to a production environment with HTTPS and configure the Twilio webhook URLs accordingly.
Usage with Claude Code
Add this server to your Claude Code MCP configuration:
{
"mcpServers": {
"twilio": {
"command": "node",
"args": ["/path/to/twilio-mcp/dist/index.js"],
"env": {
"TWILIO_ACCOUNT_SID": "ACxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",
"TWILIO_AUTH_TOKEN": "your_auth_token",
"TWILIO_PHONE_NUMBER": "+1234567890",
"WEBHOOK_PORT": "3000",
"WEBHOOK_BASE_URL": "https://your-webhook-url.com",
"DATABASE_PATH": "./data/twilio.db"
}
}
}
}MCP Tools
send_sms
Send an SMS message via Twilio.
Parameters:
to(required): Recipient phone number in E.164 format (+1234567890)message(required): SMS content (1-1600 characters)from(optional): Sender phone number (uses default if not provided)conversationId(optional): UUID of existing conversation
Example:
{
"to": "+1234567890",
"message": "Hello from Twilio MCP!"
}Response:
{
"messageSid": "SMxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",
"status": "queued",
"to": "+1234567890",
"from": "+1987654321",
"conversationId": "550e8400-e29b-41d4-a716-446655440000",
"timestamp": "2025-01-15T10:30:00.000Z"
}get_inbound_messages
Query received SMS/MMS messages from storage.
Parameters:
from(optional): Filter by sender phone numberto(optional): Filter by recipient phone numberconversationId(optional): Filter by conversation UUIDsince(optional): ISO 8601 timestamp to filter messages after this datelimit(optional): Maximum messages to return (default: 50)
Example:
{
"from": "+1234567890",
"limit": 10
}create_conversation
Initialize a new conversation thread.
Parameters:
participants(required): Array of phone numbers in E.164 format (min 2)metadata(optional): Custom metadata object
Example:
{
"participants": ["+1234567890", "+1987654321"],
"metadata": {
"campaign": "support",
"priority": "high"
}
}get_conversation_thread
Retrieve full conversation history with all messages.
Parameters:
conversationId(required): UUID of the conversationincludeContext(optional): Include AI context summary (default: false)
Example:
{
"conversationId": "550e8400-e29b-41d4-a716-446655440000",
"includeContext": true
}get_message_status
Check the delivery status of a sent message.
Parameters:
messageSid(required): Twilio message SID
Example:
{
"messageSid": "SMxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"
}Response:
{
"messageSid": "SMxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",
"status": "delivered",
"timestamp": "2025-01-15T10:31:00.000Z",
"to": "+1234567890",
"from": "+1987654321"
}Conversation Threading
The server automatically creates and manages conversation threads:
Outbound Messages: When sending an SMS:
If
conversationIdis provided, the message is linked to that conversationIf not provided, the server finds an existing conversation by participant pair
If no conversation exists and
AUTO_CREATE_CONVERSATIONS=true, a new one is created
Inbound Messages: When receiving an SMS via webhook:
The server matches by participant pair (from/to numbers)
If no conversation exists and
AUTO_CREATE_CONVERSATIONS=true, a new one is createdMessages are automatically stored and linked to the conversation
Participant Matching: Conversations are identified by normalized participant pairs:
[+1234567890, +1987654321]matches the same conversation regardless of direction
Architecture
twilio-mcp/
├── src/
│ ├── index.ts # MCP server entry point
│ ├── server.ts # MCP server with tool registry
│ ├── webhook-server.ts # Express server for webhooks
│ ├── config/
│ │ └── env.ts # Environment configuration
│ ├── services/
│ │ └── twilio-client.ts # Twilio SDK wrapper
│ ├── storage/
│ │ ├── conversation-store.ts # Conversation persistence
│ │ └── message-store.ts # Message persistence
│ ├── tools/
│ │ ├── send-sms.ts
│ │ ├── get-inbound-messages.ts
│ │ ├── create-conversation.ts
│ │ ├── get-conversation-thread.ts
│ │ └── get-message-status.ts
│ └── types/
│ └── models.ts # TypeScript type definitions
└── data/ # SQLite database storageDevelopment
# Run in development mode
npm run dev
# Build TypeScript
npm run build
# Run tests
npm test
# Run tests in watch mode
npm run test:watch
# Run tests with coverage report
npm run test:coverage
# Type check
npm run lintTesting
The project includes a comprehensive test suite using Jest with TypeScript support.
Test Structure
tests/
├── setup.ts # Test environment setup
├── config/
│ └── env.test.ts # Environment configuration validation tests
├── services/
│ └── twilio-client.test.ts # Twilio client service tests
├── storage/
│ ├── conversation-store.test.ts # Conversation persistence tests
│ └── message-store.test.ts # Message persistence tests
├── tools/
│ ├── send-sms.test.ts # SMS sending schema validation
│ ├── create-conversation.test.ts # Conversation creation tests
│ ├── get-conversation-thread.test.ts
│ ├── get-inbound-messages.test.ts
│ └── get-message-status.test.ts
└── webhook-server.test.ts # Webhook endpoint testsWhat's Tested
Schema Validation: All MCP tool input schemas are tested for valid/invalid inputs
Storage Operations: SQLite conversation and message stores (CRUD operations)
Webhook Handlers: Inbound SMS and status callback endpoints with signature validation
Environment Config: All environment variable validation rules
Twilio Client: Client instantiation and method signatures
Running Tests
# Run all tests
npm test
# Watch mode for development
npm run test:watch
# Generate coverage report
npm run test:coverageTest Environment
Tests use an in-memory SQLite database and mock environment variables configured in tests/setup.ts.
Security
No Hardcoded Secrets: All credentials are stored in environment variables
Webhook Validation: All Twilio webhooks are validated using signature verification
Input Validation: All tool inputs are validated using Zod schemas
HTTPS Required: Webhook endpoints must use HTTPS in production
Database
The server uses SQLite for storing conversations and messages:
Conversations: Thread metadata, participants, timestamps
Messages: SMS/MMS content, delivery status, media URLs
Database file location: ./data/twilio.db (configurable via DATABASE_PATH)
Environment Variables
Variable | Required | Default | Description |
| Yes | - | Twilio Account SID (starts with AC) |
| Yes | - | Twilio Auth Token |
| Yes | - | Your Twilio phone number (E.164 format) |
| No | 3000 | Port for webhook server |
| Yes | - | Public HTTPS URL for webhooks |
| No | ./data/twilio.db | SQLite database file path |
| No | info | Logging level (debug, info, warn, error) |
| No | true | Auto-create conversations for new threads |
| No | true | Enable AI context generation |
| No | true | Enable MMS support |
License
MIT
Support
For issues and questions:
Twilio Documentation: https://www.twilio.com/docs
MCP Documentation: https://modelcontextprotocol.io
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.