A Model Context Protocol (MCP) server that provides seamless integration with the Twenty CRM API, enabling LLM agents to interact with your CRM data through well-defined, typed tools.
- Overview
- Prerequisites
- Quick Start
- Installation
- Configuration
- OAuth Authentication
- Verification
- IDE Integration
- Usage
- Troubleshooting
- Additional Resources
This MCP server transforms your Twenty CRM instance into a powerful tool accessible by Claude and other MCP-compatible AI assistants. It provides comprehensive access to contacts, companies, tasks, and notes with full TypeScript support and robust error handling.
- π€ Contact Management: Create, retrieve, update, and search contacts
- π’ Company Management: Full company lifecycle management
- πΌ Opportunity Tracking: Complete sales pipeline management
- π Activity Management: Unified timeline view with filtering
- β Task Management: Create and manage tasks
- π Relationship Management: Link entities and analyze connections
- π Metadata Discovery: Explore CRM schema and field definitions
- π OAuth 2.1 Authentication: Secure user-specific API key management
- π Full TypeScript Support: Type-safe operations with validation
Total: 29 MCP Tools providing comprehensive CRM automation capabilities. See full tool list β
MCP (Model Context Protocol) servers are tools that extend AI assistants like Claude with new capabilities. Once configured, this server allows Claude to:
- π Read your CRM data (contacts, companies, opportunities)
- βοΈ Create new records directly from conversations
- π Update existing information
- π€ Automate CRM workflows through natural language
Think of it as giving Claude direct access to your Twenty CRM, turning it into a powerful CRM assistant.
Before installing, ensure you have:
- β Node.js 18 or higher - Download from nodejs.org
- β npm (included with Node.js)
- β Git for cloning the repository
- β Twenty CRM instance with API access
- β Text editor for configuration files
# Check Node.js version (should be 18+)
node --version
# Check npm is installed
npm --version
# Check git is installed
git --version
β οΈ Windows Users: The quick install script requires Git Bash or WSL. See Windows Installation Guide for alternatives.
# Try instantly with npx - no installation needed!
npx twenty-mcp-server setup
# Test your configuration
npx twenty-mcp-server test
# Start the server
npx twenty-mcp-server startPerfect for trying Twenty MCP Server before committing to installation!
# Install globally with npm
npm install -g twenty-mcp-server
# Run the interactive setup wizard
twenty-mcp setup
# Start the server
twenty-mcp startThat's it! The CLI will guide you through everything else.
For experienced users who want to clone and modify the source:
# Clone, install, configure, and run
git clone https://github.com/jezweb/twenty-mcp.git && \
cd twenty-mcp && \
chmod +x install.sh && \
./install.sh && \
cp .env.example .env && \
echo "Now edit .env with your API key and base URL" && \
nano .envThen configure your IDE using the absolute path shown by the installer.
βββββββββββββββββββ ββββββββββββββββ ββββββββββββββββ βββββββββββββββ
β 1. Install β --> β 2. Configure β --> β 3. Verify β --> β 4. Connect β
β - Clone repo β β - API key β β - Validateβ β - IDE β
β - Build β β - Base URLβ β - Test β β - Use! β
βββββββββββββββββββ ββββββββββββββββ ββββββββββββββββ βββββββββββββββ
(~3 min) (~2 min) (~1 min) (~2 min)
| Method | When to Use | Time | Platform |
|---|---|---|---|
| β‘ npx Instant Trial | Try before installing - no commitment! | ~30 seconds | All platforms |
| π npm Global Install | Regular use and best performance | ~1 minute | All platforms |
| π― Git Clone + Install | Developers who want to modify code | ~3 minutes | Linux/macOS/Git Bash |
| π§ Manual Git Setup | Windows Command Prompt or custom needs | ~5 minutes | All platforms |
Experience Twenty MCP Server instantly without any installation:
# Try it right now - no installation required!
npx twenty-mcp-server setup
# Configuration is saved globally for future npx runs
npx twenty-mcp-server test
# Start using it immediately
npx twenty-mcp-server startBenefits:
- β Zero installation - try instantly
- β Always runs the latest version
- β Configuration persists between runs
- β Perfect for testing and evaluation
- β No global installation clutter
Ready to install permanently? Simply run: npm install -g twenty-mcp-server
For users who want Twenty MCP Server permanently installed:
# Install globally
npm install -g twenty-mcp-server
# Verify installation
twenty-mcp --version
# Run setup wizard
twenty-mcp setupBenefits:
- β Works on all platforms (Windows, macOS, Linux)
- β Automatic PATH configuration
- β Interactive setup wizard guides you through everything
- β No manual file management or path configuration
- β
Easy updates with
npm update -g twenty-mcp-server - β Built-in CLI commands for management and testing
- β Professional configuration management
What the setup wizard configures:
- π§ Twenty CRM API connection
- π OAuth 2.1 authentication (optional)
- π‘οΈ IP address protection (optional)
- βοΈ Server preferences and defaults
- π Cross-platform configuration storage
For developers who want to modify the source code:
# Step 1: Clone the repository
git clone https://github.com/jezweb/twenty-mcp.git
cd twenty-mcp
# Step 2: Make install script executable (Linux/macOS only)
chmod +x install.sh
# Step 3: Run the installation
./install.shThe install script will:
- β Check Node.js version (18+ required)
- β Install all dependencies
- β Build the TypeScript project
- β Run tests (if API key is configured)
- β Show your absolute path for IDE configuration
- β Provide next steps
π Note: Save the absolute path shown by the installer - you'll need it for IDE configuration!
Perfect for Windows Command Prompt users or those who prefer manual control:
# Step 1: Clone the repository
git clone https://github.com/jezweb/twenty-mcp.git
cd twenty-mcp
# Step 2: Install dependencies
npm install
# Step 3: Build the TypeScript project
npm run build
# Step 4: Verify the build succeeded
# Linux/macOS:
ls -la dist/index.js
# Windows:
dir dist\index.jsβ
If you see dist/index.js, the build succeeded!
π¨ Critical: You MUST use the absolute path to
dist/index.jsfor IDE configuration. Relative paths will NOT work!
π§ Linux/macOS
# Get your absolute path
pwd
# Example output: /home/username/twenty-mcp
# Your MCP server path will be:
# /home/username/twenty-mcp/dist/index.jsπͺ Windows
# Command Prompt
cd
# Example output: C:\Users\username\twenty-mcp
# Your path: C:\Users\username\twenty-mcp\dist\index.js
# PowerShell
Get-Location
# Example output: C:\Users\username\twenty-mcp
# Your path: C:\Users\username\twenty-mcp\dist\index.js
# Git Bash
pwd
# Example output: /c/Users/username/twenty-mcp
# Your path: C:/Users/username/twenty-mcp/dist/index.jsYour MCP server path will be: [absolute-path]/dist/index.js
Before proceeding to configuration, verify your installation:
# 1. Check Node modules installed
test -d node_modules && echo "β
Dependencies installed" || echo "β Run: npm install"
# 2. Check build completed
test -f dist/index.js && echo "β
Build successful" || echo "β Run: npm run build"
# 3. Check your path
echo "π Your MCP path: $(pwd)/dist/index.js"πͺ Windows Users: See our detailed Windows Installation Guide for step-by-step instructions with Command Prompt, PowerShell, and Git Bash options.
-
Log into your Twenty CRM instance
- For Twenty Cloud: https://app.twenty.com
- For self-hosted: Your instance URL
-
Navigate to Settings
- Click on your profile avatar (top right)
- Select "Settings" from the dropdown
-
Find API & Webhooks
- Look in the "Developers" section
- Click on "API & Webhooks"
-
Generate Your API Key
- Click "Generate API Key" button
- Important: Copy the key immediately - it won't be shown again!
- Store it securely (password manager recommended)
# Copy the example configuration
cp .env.example .env
# Edit with your favorite editor
nano .env # or vim, code, notepad, etc.Add your configuration to the .env file:
# Your Twenty CRM API Key (from Step 1)
TWENTY_API_KEY=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...
# Your Twenty instance URL (no trailing slash!)
TWENTY_BASE_URL=https://api.twenty.comCommon Base URLs:
- Twenty Cloud:
https://api.twenty.com - Self-hosted:
https://your-company.twenty.com - Local development:
http://localhost:3000
# Linux/macOS
export TWENTY_API_KEY="your-api-key-here"
export TWENTY_BASE_URL="https://api.twenty.com"
# Windows (Command Prompt)
set TWENTY_API_KEY=your-api-key-here
set TWENTY_BASE_URL=https://api.twenty.com
# Windows (PowerShell)
$env:TWENTY_API_KEY="your-api-key-here"
$env:TWENTY_BASE_URL="https://api.twenty.com"π Important: Environment variables must be loaded in your current shell session!
Understanding .env Files
.env files store configuration but don't automatically load into your shell:
- Linux/macOS: Must use
source .envto load variables - Windows: The npm scripts automatically read .env files
- IDE Configuration: Usually reads .env files directly
If using a .env file:
# Linux/macOS - Load variables into current session
source .env
# Verify they're loaded
echo $TWENTY_API_KEY # Should show your key
# Windows - npm scripts read .env automatically
# No manual loading needed for npm commandsThe Twenty MCP Server supports OAuth 2.1 authentication following the MCP Authentication Specification. This enables secure, user-specific API key management and multi-user deployments.
- π Secure API Key Storage: User API keys encrypted with AES-256-GCM
- π€ User-Specific Access: Each user manages their own Twenty CRM connection
- π Backward Compatible: Works alongside traditional API key configuration
- π‘οΈ Clerk Integration: Production-ready authentication provider
- π Discovery Endpoints: Full MCP OAuth specification compliance
Run the interactive OAuth setup CLI:
npm run setup:oauthThis will guide you through:
- Enabling OAuth authentication
- Configuring Clerk credentials
- Setting up encryption secrets
- Testing the integration
For detailed OAuth implementation guide, see OAUTH.md:
- Complete OAuth 2.1 Flow: Step-by-step implementation
- Security Best Practices: Encryption, token validation, CORS
- Client Integration Examples: JavaScript, Python, curl
- Production Deployment: Environment setup and troubleshooting
Test your OAuth setup:
# Run comprehensive OAuth test suite
npm run test:oauth
# Test specific OAuth endpoints
curl http://localhost:3000/.well-known/oauth-protected-resource
curl http://localhost:3000/.well-known/oauth-authorization-server| Feature | API Key Mode | OAuth Mode |
|---|---|---|
| Setup Complexity | Simple | Moderate |
| Security | Shared key | User-specific encrypted keys |
| Multi-user | β Single user | β Multiple users |
| Authentication | Query parameter | Bearer token |
| Key Storage | Environment variables | Encrypted in Clerk |
| Backward Compatibility | β Full | β Full (when auth disabled) |
Choose API Key mode for:
- Single-user deployments
- Simple integrations
- Quick prototyping
Choose OAuth mode for:
- Multi-user applications
- Production deployments
- Enhanced security requirements
Before configuring your IDE, verify everything is working:
npm run validateExpected output when everything is configured:
==================================================
Twenty MCP Server Configuration Validator
==================================================
[INFO] Checking environment variables...
[SUCCESS] TWENTY_API_KEY is set
[SUCCESS] API key appears to be in JWT format
[SUCCESS] TWENTY_BASE_URL is set: https://api.twenty.com
[SUCCESS] Base URL is valid
[INFO] Checking configuration files...
[SUCCESS] .env file exists
[INFO] Checking project build...
[SUCCESS] Project is built (dist/index.js exists)
[SUCCESS] Dependencies are installed
[INFO] Testing API connection...
[SUCCESS] API connection successful!
[INFO] Connected as: John Doe
==================================================
[SUCCESS] Configuration is valid! π
# Make sure environment is loaded
source .env # Linux/macOS only
# Run basic tests
npm testnpm startYou should see: Server running on http://localhost:3000
- Installation complete (
dist/index.jsexists) - Configuration valid (
npm run validatepasses) - Absolute path noted (from installation step)
- API key and base URL ready
Configure Claude Desktop to use your Twenty MCP server:
| Platform | Location |
|---|---|
| macOS | ~/Library/Application Support/Claude/claude_desktop_config.json |
| Windows | %APPDATA%\Claude\claude_desktop_config.json |
| Linux | ~/.config/Claude/claude_desktop_config.json |
If you installed via npm or use npx:
{
"mcpServers": {
"twenty-crm": {
"command": "twenty-mcp",
"args": ["start", "--stdio"],
"env": {}
}
}
}Note for npx users: Your configuration is automatically saved globally, so Claude Desktop will work seamlessly even when using npx!
If you cloned from Git:
{
"mcpServers": {
"twenty-crm": {
"command": "node",
"args": ["REPLACE_WITH_YOUR_ABSOLUTE_PATH/dist/index.js"],
"env": {
"TWENTY_API_KEY": "REPLACE_WITH_YOUR_API_KEY",
"TWENTY_BASE_URL": "REPLACE_WITH_YOUR_BASE_URL"
}
}
}
}
β οΈ Common Mistakes to Avoid:
- Using relative paths (e.g.,
./dist/index.js) - won't work!- Forgetting to restart Claude Desktop after changes
- Missing quotes around paths with spaces
- Using wrong slashes on Windows (use
/or\\)
npm Installation or npx Usage (All Platforms):
{
"mcpServers": {
"twenty-crm": {
"command": "twenty-mcp",
"args": ["start", "--stdio"],
"env": {}
}
}
}π‘ npx users: This same configuration works whether you use npx twenty-mcp-server or install globally!
Git Installation Examples:
macOS Example:
{
"mcpServers": {
"twenty-crm": {
"command": "node",
"args": ["/Users/johndoe/projects/twenty-mcp/dist/index.js"],
"env": {
"TWENTY_API_KEY": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...",
"TWENTY_BASE_URL": "https://api.twenty.com"
}
}
}
}Windows Example:
{
"mcpServers": {
"twenty-crm": {
"command": "node",
"args": ["C:\\Users\\johndoe\\projects\\twenty-mcp\\dist\\index.js"],
"env": {
"TWENTY_API_KEY": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...",
"TWENTY_BASE_URL": "https://api.twenty.com"
}
}
}
}- Restart Claude Desktop (required!)
- Ask Claude: "What MCP tools do you have available?"
- Test with: "Show me my contacts from Twenty CRM"
Cursor IDE
- Open Cursor Settings (
Cmd/Ctrl + ,) - Navigate to Extensions β MCP Servers
- Add configuration:
{ "name": "twenty-crm", "command": "node", "args": ["/absolute/path/to/twenty-mcp/dist/index.js"], "env": { "TWENTY_API_KEY": "your-api-key", "TWENTY_BASE_URL": "https://your-instance.com" } } - Restart Cursor
Smithery
Quick setup:
- Install Smithery:
npm install -g @smithery/cli - Run:
smithery devin the twenty-mcp directory - Configure credentials when prompted
Or use the deployed version:
- Visit smithery.ai
- Search for "Twenty MCP"
- Click "Use this server"
Cline (VS Code)
- Install Cline extension from VS Code marketplace
- Add to VS Code settings.json:
{ "cline.mcpServers": { "twenty-crm": { "command": "node", "args": ["/path/to/twenty-mcp/dist/index.js"], "env": { "TWENTY_API_KEY": "your-api-key", "TWENTY_BASE_URL": "https://your-instance.com" } } } }
HTTP Server Mode
For web integrations, run as HTTP server:
npm start
# Server available at http://localhost:3000/mcpConfigure via query parameters:
http://localhost:3000/mcp?apiKey=your-key&baseUrl=https://your-instance.com
Twenty MCP Server includes a powerful CLI for easy management:
# Interactive setup wizard (recommended for first-time setup)
twenty-mcp setup
# Setup with OAuth authentication
twenty-mcp setup --oauth
# Setup with IP protection
twenty-mcp setup --ip-protection
# Import existing .env configuration
twenty-mcp setup --import
# Reset to default configuration
twenty-mcp setup --reset# Start the server (HTTP mode, default port 3000)
twenty-mcp start
# Start with custom port
twenty-mcp start --port 8080
# Start in stdio mode (for direct MCP protocol communication)
twenty-mcp start --stdio
# Start with verbose logging
twenty-mcp start --verbose# Test configuration and connection
twenty-mcp test
# Run full test suite including API tests
twenty-mcp test --full
# Test OAuth authentication endpoints
twenty-mcp test --oauth
# Run smoke tests only (no API calls)
twenty-mcp test --smoke# Show server status and configuration
twenty-mcp status
# Show detailed status information
twenty-mcp status --verbose
# Output status in JSON format
twenty-mcp status --json
# Show help for all commands
twenty-mcp help
# Show version
twenty-mcp --versionOnce configured in your IDE, you can ask your AI assistant to:
- "Show me all contacts in Twenty CRM"
- "Create a new company called Acme Corp"
- "Find all opportunities in the proposal stage"
- "Add a task to follow up with John Doe"
- "Show me all activities from last week"
You: "Create a new contact for Jane Smith at jane@example.com"
Claude: I'll create a new contact for Jane Smith in your Twenty CRM...
You: "Find all opportunities worth over $10,000"
Claude: Let me search for high-value opportunities in your CRM...
You: "Show me companies without any contacts"
Claude: I'll find orphaned company records in your system...
See full tool documentation β
First, run the configuration validator:
npm run validateThis will identify most common issues and suggest fixes.
Error: "Node.js version 18+ is required"
Solution: Update Node.js
# Check current version
node --version
# Install Node.js 18+ from https://nodejs.org
# Or use nvm:
nvm install 18
nvm use 18Error: "Cannot find module 'dist/index.js'"
Solution: Build the project
npm run build
# Verify build succeeded
ls -la dist/index.jsError: "Permission denied" running install.sh
Solution: Make script executable
chmod +x install.sh
./install.shError: "TWENTY_API_KEY environment variable is required"
Solution: Set your environment variables
# Option 1: Load from .env file
source .env
# Option 2: Export directly
export TWENTY_API_KEY="your-key-here"
export TWENTY_BASE_URL="https://your-instance.com"Error: "401 Unauthorized" or "Authentication failed"
Solution:
- Verify API key is correct (no extra spaces)
- Check key hasn't expired
- Regenerate key in Twenty CRM Settings
- Ensure you're using the correct base URL
Error: "Network error" or "fetch failed"
Solution:
- Check base URL is correct (no trailing slash!)
- Verify Twenty instance is accessible
- Check firewall/proxy settings
- Test with curl:
curl -H "Authorization: Bearer YOUR_API_KEY" \ https://your-instance.com/graphql
Claude Desktop doesn't see the MCP server
Solution:
- Verify absolute path is correct:
# Get the correct path cd twenty-mcp && pwd
- Check config file location is correct for your OS
- Ensure JSON syntax is valid (no trailing commas!)
- Restart Claude Desktop (required!)
- Check Claude's developer console for errors
Windows path issues
Solution: Use proper Windows paths
// Correct Windows paths:
"args": ["C:\\Users\\name\\twenty-mcp\\dist\\index.js"]
// or
"args": ["C:/Users/name/twenty-mcp/dist/index.js"]
// Incorrect:
"args": ["~/twenty-mcp/dist/index.js"] // Won't work on WindowsEnable debug logging for more details:
# Enable all debug output
DEBUG=twenty-mcp:* npm start
# Test specific GraphQL queries
node test-graphql.jsIf you're still stuck:
- Check existing issues: GitHub Issues
- Read test documentation: TESTING.md
- Create a new issue with:
- Your OS and Node.js version
- Complete error message
- Output from
npm run validate - Steps to reproduce
- Full Tool Reference - Detailed documentation of all 29 tools
- Testing Guide - How to run and write tests
- Contributing Guide - How to contribute to the project
The Twenty MCP Server is built with:
- TypeScript for type safety
- GraphQL for Twenty API communication
- MCP SDK for protocol implementation
- Zod for runtime validation
We welcome contributions! Please see our Contributing Guide for details on:
- Setting up development environment
- Running tests
- Submitting pull requests
- Code style guidelines
MIT License - see LICENSE file for details.
- Twenty CRM for the open-source CRM platform
- Model Context Protocol for the integration standard
- Anthropic for Claude and the MCP framework
Architecture Details
twenty-mcp-server/
βββ src/
β βββ client/
β β βββ twenty-client.ts # GraphQL client for Twenty API
β βββ tools/
β β βββ index.ts # MCP tool implementations
β βββ types/
β β βββ twenty.ts # TypeScript interfaces
β βββ index.ts # Main server entry point
βββ tests/ # Test suites
βββ dist/ # Compiled JavaScript (after build)
βββ package.json
βββ tsconfig.json
βββ README.md
- TwentyClient: GraphQL client that handles API communication with Twenty CRM
- MCP Tools: 29 tools that provide comprehensive CRM functionality to AI assistants
- Type System: Comprehensive TypeScript definitions for Twenty's data structures
- Schema Transformation: Converts flat tool inputs to Twenty's nested GraphQL schema
Development Commands
# Install dependencies
npm install
# Run in development mode with hot reload
npm run dev
# Run development HTTP server
npm run dev:http
# Build for production
npm run build
# Run linting
npm run lint
# Type checking
npm run typecheck
# Run all tests
npm test
# Run specific test suites
npm run test:smoke # Quick tests (no API)
npm run test:full # Comprehensive tests