loading…
Search for a command to run...
loading…
An MCP server that interfaces with the Missive API, enabling Claude to manage email conversations, contacts, and team collaboration.
An MCP server that interfaces with the Missive API, enabling Claude to manage email conversations, contacts, and team collaboration.
An MCP (Model Context Protocol) server that interfaces with the Missive API, enabling Claude to manage email conversations, contacts, and team collaboration.
npm install
npm run build
The server runs in two modes: stdio for local single-user use, and remote for hosted multi-user deployments.
Set the MISSIVE_API_TOKEN environment variable:
export MISSIVE_API_TOKEN="your_api_token_here"
npm start
To get your API token: open Missive, go to Settings > API, click "Create a new token".
Add to your Claude Desktop configuration (claude_desktop_config.json):
{
"mcpServers": {
"missive": {
"command": "/path/to/node",
"args": ["/path/to/missive-mcp/dist/index.js"],
"env": {
"MISSIVE_API_TOKEN": "your_api_token_here"
}
}
}
}
Important: Use the full path to node (run which node to find it). Claude Desktop has a restricted PATH and may not find node otherwise.
Runs an HTTP server with OAuth. Each user provides their own Missive PAT through a browser-based authorization flow.
export ENCRYPTION_KEY="$(openssl rand -hex 32)"
export BASE_URL="https://missive-mcp.example.com"
npm run remote
| Variable | Required | Description |
|---|---|---|
ENCRYPTION_KEY |
Yes | 32-byte hex string for AES-256-GCM PAT encryption |
BASE_URL |
Yes | Public URL of the server |
PORT |
No | HTTP port (default 3000) |
DATA_DIR |
No | Directory for storage files (default ./data) |
Point MCP clients at {BASE_URL}/mcp. The server handles OAuth automatically:
/.well-known/oauth-authorization-server/register/mcpPATs are encrypted at rest with AES-256-GCM. OAuth tokens expire after 1 hour (refresh tokens last 30 days).
| Tool | Description |
|---|---|
list_organizations |
List organizations you belong to |
list_teams |
List teams (for assignments) |
list_users |
List users (for assignments) |
list_contact_books |
List contact books (required before creating contacts) |
list_shared_labels |
List labels (for filtering and tagging) |
| Tool | Description |
|---|---|
list_conversations |
List conversations with filters (inbox, assigned, closed, team, label, email, domain) |
get_conversation |
Get a single conversation by ID |
| Tool | Description |
|---|---|
get_conversation_timeline |
Get all messages, posts, and comments as a unified chronological timeline |
get_message |
Get full message content (with body truncation options) |
| Tool | Description |
|---|---|
list_drafts |
List drafts in a conversation |
create_draft |
Create a draft (not sent) |
send_message |
Send a message immediately (rate limited) |
delete_draft |
Delete an unsent draft |
| Tool | Description |
|---|---|
list_contacts |
List contacts in a book (with search) |
get_contact |
Get a single contact |
create_contact |
Create a new contact |
update_contact |
Update an existing contact |
| Tool | Description |
|---|---|
create_post |
Add a post to a conversation; close, label, assign, or move to team |
Use list_conversations with inbox=true to see recent conversations.
1. Use list_conversations to find the conversation
2. Use get_conversation_timeline to see the full thread (messages + team activity)
3. Use send_message with the conversation ID to reply
Use list_conversations with domain="example.com"
1. Use list_users to find the user ID
2. Use list_organizations to get the org ID
3. Use create_post with add_assignees=[user_id]
send_message: 10 per minute, 100 per hour (client-enforced)MIT
Выполни в терминале:
claude mcp add missive-mcp-server -- npx Безопасность
Низкий рискАвтоматическая эвристика по публичным данным — не гарантия безопасности.