Basecamp MCP Server
Provides comprehensive tools for managing Basecamp projects, todos, messages, documents, team, campfire chats, schedules, card tables, comments, webhooks, and search/analytics via the Basecamp 4 API.
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., "@Basecamp MCP ServerList my active projects"
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.
🏕️ Basecamp MCP Server
A professional Model Context Protocol (MCP) server that provides complete programmatic access to Basecamp 4 API. Perfect for AI agents, workflow automation, and custom integrations.
🚀 NEW in v7.5.0: Claude.ai Compatible!
The most comprehensive AND most compatible Basecamp MCP server available!
What's New in v7.5:
✅ Full Claude.ai compatibility - Works perfectly in Claude web interface
✅ Latest MCP protocol - Supports 2025-06-18 specification
✅ Session management - Proper connection tracking for modern clients
✅ Auto-discovery - MCP config endpoint for automatic setup
✅ Simplified authentication - No KV storage, just OAuth + environment variables
✅ 55+ specialized tools - Complete Basecamp API coverage
🔥 Upgrade from v6.0? See UPGRADE-TO-V75.md for migration guide.
✅ 8 Project Management tools - Complete project lifecycle management
✅ 11 Todo Management tools - Advanced task automation with auto-lookup
✅ 6 Communication tools - Messages and discussions
✅ 6 Documents & Files tools - Content management and file handling
✅ 4 Team Management tools - Access control and permissions
✅ 3 Campfire Chat tools - Real-time communication
✅ 3 Schedule Management tools - Calendar and events
✅ 4 Card Tables tools - Kanban workflows
✅ 5 Comments System tools - Universal collaboration
✅ 4 Webhooks tools - Real-time notifications
✅ 2 Search & Analytics tools - Data insights
🆕 3 Enhanced Features - Auto-lookup, URL parsing, OAuth flow
Enhanced Features:
Auto-lookup functionality - No more 404 errors! Automatically finds resource IDs
OAuth 2.0 integration - Complete authentication flow with setup UI
Multiple authentication methods - Bearer token, arguments, environment variables
Production-ready deployment - Cloudflare Workers optimized
✨ Features
🛠️ Complete Tool Coverage (59 Tools)
Project Management (8 tools): Full CRUD operations, archiving, construction
Todo Management (11 tools): Lists, items, assignments, completion, positioning
Communication (6 tools): Messages, replies, discussions, archiving
Documents & Files (6 tools): Create, edit, upload, manage attachments
Team Management (4 tools): Add/remove people, permissions, access control
Comments & Collaboration (5 tools): Universal commenting system across all content
Campfire Chat (3 tools): Real-time chat messages and history
Schedule Management (3 tools): Events, milestones, calendar entries
Card Tables (4 tools): Kanban boards, cards, columns, positioning
Webhooks (4 tools): Real-time notifications and event subscriptions
Search & Analytics (2 tools): Content search and activity tracking
🔐 Authentication & Security
OAuth 2.0 complete authentication flow with setup UI
Multi-authentication support with token priorities:
access_tokenin arguments (highest priority)Authorization: Bearer TOKENheaderBASECAMP_ACCESS_TOKENenvironment variable (fallback)
Individual user tokens while sharing infrastructure
Secure token handling with proper validation
Simplified deployment - No KV storage required (v7.5+)
🚀 Production Ready
Edge deployment on Cloudflare Workers
Global CDN with sub-100ms response times worldwide
Automatic scaling handles any traffic volume
Rate limiting compliance with Basecamp API limits
Comprehensive error handling with meaningful messages
Auto-lookup functionality prevents 404 errors
🚀 Quick Start
1. Deploy to Cloudflare Workers
# Clone the repository
git clone https://github.com/QusaiiSaleem/basecamp-mcp-server.git
cd basecamp-mcp-server
# Install dependencies
npm install
# Configure your environment
cp wrangler.toml.example wrangler.toml
# Edit wrangler.toml with your account ID
# Deploy to Cloudflare Workers
npm run deploy2. Set Up Basecamp OAuth Integration
Create Integration: Visit Basecamp Integrations
Configure Settings:
Application Name: "Your Basecamp MCP Server"
Redirect URI:
https://your-worker.workers.dev/auth/callbackClient Type: Web Application
Set Environment Variables:
echo "your_client_id" | wrangler secret put BASECAMP_CLIENT_ID
echo "your_client_secret" | wrangler secret put BASECAMP_CLIENT_SECRET
echo "your_account_id" | wrangler secret put BASECAMP_ACCOUNT_ID3. Get Your Access Token
Visit https://your-worker.workers.dev/setup and follow the OAuth flow to get your access token.
🌐 Claude.ai Integration
NEW in v7.5: Direct integration with Claude.ai web interface!
Quick Setup
Visit Claude.ai: Go to claude.ai
Open Settings: Click Settings → Connectors
Add Remote MCP Server:
Name:
Basecamp MCPURL:
https://your-worker.workers.devAuthentication:
Bearer YOUR_ACCESS_TOKEN
Enable Toggle: Turn on the connector ✅
Verify Tools: All 55 tools should appear in your conversation
Full Setup Guide
For detailed step-by-step instructions including screenshots and troubleshooting, see:
CLAUDE-AI-SETUP.md - Complete integration guide
Test Your Connection
In Claude.ai, try these commands:
"List all my Basecamp projects"
"Show me my current todo assignments"
"Create a new message in Project X"Compatibility Matrix
Client | v6.0 | v7.5 |
Claude.ai | ⚠️ Limited | ✅ Full |
Claude Desktop | ✅ Works | ✅ Works |
Smithery Playground | ⚠️ Limited | ✅ Full |
RelevanceAI | ✅ Works | ✅ Works |
n8n | ✅ Works | ✅ Works |
Make.com | ✅ Works | ✅ Works |
🔧 Usage Examples
With RelevanceAI
Agent Settings → MCP Server → Add remote MCP tools
Server URL:
https://your-worker.workers.devAuthentication:
Bearer your_access_token_here
With Claude Desktop
Add to your MCP configuration (~/.claude/mcp_servers.json):
{
"basecamp": {
"command": "node",
"args": ["path/to/mcp-server"],
"env": {
"BASECAMP_ACCESS_TOKEN": "your_token_here",
"BASECAMP_ACCOUNT_ID": "your_account_id"
}
}
}Direct API Usage
// Enhanced auto-lookup - no more resource ID hunting!
{
"tool": "get_todo_lists",
"arguments": {
"project_id": "123456" // That's it! Auto-finds todoset ID
}
}
// Create todos with full assignment control
{
"tool": "create_todo",
"arguments": {
"project_id": "123456",
"todolist_id": "789012",
"content": "Complete project setup",
"due_on": "2024-12-31",
"assignee_ids": [1001, 1002]
}
}
// Universal commenting system
{
"tool": "add_comment_to_recording",
"arguments": {
"project_id": "123456",
"recording_id": "789012", // Works with any content type
"content": "Great progress on this item!"
}
}
// Smart URL parsing
{
"tool": "parse_basecamp_url",
"arguments": {
"url": "https://3.basecamp.com/999999/buckets/123456/todolists/789012"
}
}📚 Complete Tool Reference
📋 Project Management (8 tools)
Tool | Description | Key Parameters |
| List all accessible projects | - |
| Create new project |
|
| Get project details |
|
| Update project info |
|
| Archive project |
|
| Unarchive project |
|
| Get project tools/features |
|
| Parse any Basecamp URL |
|
✅ Todo Management (11 tools)
Tool | Description | Key Parameters |
| Get todo lists (AUTO-LOOKUP) |
|
| Create todo list (AUTO-LOOKUP) |
|
| Get todos from list |
|
| Get ALL project todos |
|
| Create new todo |
|
| Update todo details |
|
| Mark todo complete |
|
| Mark todo incomplete |
|
| Get current user assignments | - |
| Get user's assignments |
|
| Change todo position |
|
💬 Communication (6 tools)
Tool | Description | Key Parameters |
| Get message board (AUTO-LOOKUP) |
|
| Get messages (AUTO-LOOKUP) |
|
| Create message (AUTO-LOOKUP) |
|
| Edit message |
|
| Get specific message |
|
| Archive message |
|
📄 Documents & Files (6 tools)
Tool | Description | Key Parameters |
| List documents (AUTO-LOOKUP) |
|
| Create document (AUTO-LOOKUP) |
|
| Edit document |
|
| Get specific document |
|
| Upload file |
|
| List project uploads |
|
👥 Team & People (4 tools)
Tool | Description | Key Parameters |
| Get project team |
|
| Get all account people | - |
| Grant project access |
|
| Revoke project access |
|
💭 Comments & Collaboration (5 tools)
Tool | Description | Key Parameters |
| Universal comment tool |
|
| Comment on todo |
|
| Reply to message |
|
| Comment on document |
|
| Comment on card |
|
💬 Campfire Chat (3 tools)
Tool | Description | Key Parameters |
| Get project chat |
|
| Get chat messages |
|
| Post chat message |
|
📅 Schedule Management (3 tools)
Tool | Description | Key Parameters |
| Get schedule (AUTO-LOOKUP) |
|
| Get schedule events |
|
| Create new event |
|
🎫 Card Tables (4 tools)
Tool | Description | Key Parameters |
| Get Kanban board |
|
| Get cards from table |
|
| Create new card |
|
| Update existing card |
|
🔗 Webhooks (4 tools)
Tool | Description | Key Parameters |
| List all webhooks | - |
| Create webhook |
|
| Update webhook |
|
| Delete webhook |
|
🔍 Search & Analytics (2 tools)
Tool | Description | Key Parameters |
| Search content |
|
| Get activity/events |
|
🔍 Smart Features
🧠 Auto-Lookup Intelligence
The server automatically finds required resource IDs, eliminating 404 errors:
// Before: Complex resource ID hunting
{
"tool": "get_todo_lists",
"arguments": {
"project_id": "123456",
"todoset_id": "789012" // ← Hard to find manually
}
}
// After: Simple auto-lookup
{
"tool": "get_todo_lists",
"arguments": {
"project_id": "123456" // ← Auto-finds todoset ID
}
}📈 URL Intelligence
Parse any Basecamp URL to extract project and resource information:
// Input: https://3.basecamp.com/999999/buckets/123456/todolists/789012
// Output:
{
"account_id": "999999",
"project_id": "123456",
"resource_type": "todolists",
"resource_id": "789012",
"suggested_tools": ["get_todos", "create_todo"]
}🔄 Multi-Authentication Support
Flexible authentication with priority order:
Arguments:
access_tokenparameter (highest priority)Headers:
Authorization: Bearer TOKENEnvironment:
BASECAMP_ACCESS_TOKEN(fallback)
⚙️ Configuration
Environment Variables
Variable | Description | Required |
| Your Basecamp account ID | ✅ |
| OAuth client ID | ✅ (for OAuth) |
| OAuth client secret | ✅ (for OAuth) |
| Fallback access token | ⚠️ (optional) |
wrangler.toml Example
name = "my-basecamp-mcp-server"
main = "index.ts"
compatibility_date = "2024-08-05"
[vars]
BASECAMP_ACCOUNT_ID = "999999999"
# Note: v7.5 no longer requires KV namespace binding
# All authentication is handled via environment variables🔒 Security Best Practices
Authentication Security
Individual Tokens: Each user maintains their own OAuth token
Secure Headers: All requests use proper authorization headers
Token Validation: Automatic token validation and error handling
Environment Isolation: Production secrets separate from code
API Security
Rate Limiting: Automatic compliance with Basecamp API limits
Request Validation: Input sanitization and type checking
Error Handling: Secure error messages without data leaks
CORS Configuration: Proper cross-origin resource sharing
🚀 Deployment Options
Cloudflare Workers (Recommended)
Global Edge Network: Sub-100ms response times worldwide
Automatic Scaling: Handle unlimited traffic
Built-in Security: DDoS protection, WAF, SSL
Cost Effective: Pay per request, no idle costs
Alternative Platforms
Vercel Functions: Serverless deployment
AWS Lambda: Enterprise-grade infrastructure
Google Cloud Functions: Google ecosystem integration
Azure Functions: Microsoft ecosystem integration
Self-Hosted Options
Node.js Server: Traditional server deployment
Docker Container: Containerized deployment
Kubernetes: Container orchestration
🤝 Contributing
We welcome contributions! Here's how to get started:
Development Setup
# Clone the repository
git clone https://github.com/QusaiiSaleem/basecamp-mcp-server.git
cd basecamp-mcp-server
# Install dependencies
npm install
# Set up environment
cp wrangler.toml.example wrangler.toml
# Start development server
npm run devAdding New Tools
Define Tool Schema: Add tool definition to
getAllBasecampTools()Implement Handler: Add case to
callBasecampTool()switch statementTest Implementation: Verify with Basecamp API endpoints
Update Documentation: Add to README tool reference
Submit Pull Request: Include tests and examples
📊 Performance & Monitoring
Performance Metrics
Response Time: Average <100ms globally
Availability: 99.9% uptime SLA
Throughput: 10,000+ requests per second capability
Error Rate: <0.1% error rate
Monitoring Features
Cloudflare Analytics: Request metrics and performance
Custom Logging: Detailed operation tracking
Error Reporting: Automated error notifications
Health Checks: Continuous availability monitoring
❓ Troubleshooting
Common Issues
Authentication Errors
Error: Authentication requiredSolution: Ensure your access token is valid. Visit /setup for OAuth flow.
Configuration Missing
Error: BASECAMP_ACCESS_TOKEN not configuredSolution: Set up OAuth credentials or provide token in request headers.
Auto-lookup Failures
Error: Todo lists are not enabled for this projectSolution: Enable todo lists in your Basecamp project settings.
Getting Help
GitHub Issues: Report bugs and request features
Discussions: Community support and questions
Documentation: Comprehensive guides and examples
📄 License
This project is licensed under the MIT License - see the LICENSE file for details.
🏆 Acknowledgments
Basecamp Team: For providing an excellent API
MCP Community: For the Model Context Protocol standard
Cloudflare: For the edge computing platform
Contributors: Thank you to all contributors!
📋 Version History
v7.5.0 (2025-09-30): Claude.ai compatibility + protocol updates - CHANGELOG.md
v6.0.0 (2024-12-15): Complete 59-tool implementation
v5.0.0 (2024-10-01): Initial public release
🔗 Links
🏠 Homepage: GitHub Repository
📖 Documentation: Complete API Reference
🚀 Upgrade Guide: UPGRADE-TO-V75.md
📝 Changelog: CHANGELOG.md
🤖 Claude.ai Setup: CLAUDE-AI-SETUP.md
🐛 Issues: Bug Reports
💬 Discussions: Community Forum
🏕️ Basecamp API: Official Documentation
🤖 MCP Protocol: Specification
Transform your Basecamp workflow with complete API automation! 🚀
Now with full Claude.ai compatibility in v7.5! ✨
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.
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/QusaiiSaleem/basecamp-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server