Provides comprehensive integration with Basecamp 3, offering 46 tools for managing projects, todo lists, campfire messages, card tables, documents, webhooks, and daily check-ins. Supports full CRUD operations for cards, columns, and card steps, along with search functionality across projects and messages.
Basecamp MCP Integration
A modern TypeScript MCP server for Basecamp 3, providing seamless integration with Claude Desktop and Cursor IDE through the Model Context Protocol. Built with the official @modelcontextprotocol/sdk and ready for NPX installation.
✅ TypeScript-First: Modern, type-safe implementation with full async/await support
🚀 NPX Ready: Install and run with npx @basecamp/mcp-server
⚡ 46 API Tools: Complete Basecamp 3 integration with all major features
Quick Setup
NPX Installation (Recommended)
Prerequisites
- Node.js 18+ (required for ES modules)
- A Basecamp 3 account
- A Basecamp OAuth application (create one at https://launchpad.37signals.com/integrations)
Local Development Setup
For Development
- Clone and build the project:
- Run setup script:The setup script automatically:
- ✅ Installs all TypeScript dependencies
- ✅ Builds the project to
dist/
- ✅ Creates
.env
template file - ✅ Tests MCP server functionality
- Configure OAuth credentials:
Edit the generated
.env
file: - Authenticate with Basecamp:Visit http://localhost:8000 and complete the OAuth flow.
- Generate configurations:
- Restart your AI assistant completely (quit and reopen)
- Verify in your AI assistant:
- Cursor: Go to Settings → MCP, look for "basecamp" with a green checkmark
- Claude Desktop: Look for tools icon (🔍) in chat interface
- Available tools: 46 tools for complete Basecamp control
Test Your Setup
For Claude Desktop Users
Based on the official MCP quickstart guide, Claude Desktop integration follows these steps:
Setup Steps
- Complete the basic setup (steps 1-4 from development setup above):
- Generate Claude Desktop configuration:
- Restart Claude Desktop completely (quit and reopen the application)
- Verify in Claude Desktop:
- Look for the "Search and tools" icon (🔍) in the chat interface
- You should see "basecamp" listed with all 46 tools available
- Toggle the tools on to enable Basecamp integration
Claude Desktop Configuration
The configuration is automatically created at:
- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json
- Windows:
~/AppData/Roaming/Claude/claude_desktop_config.json
- Linux:
~/.config/claude-desktop/claude_desktop_config.json
Example configuration generated:
Usage in Claude Desktop
Ask Claude things like:
- "What are my current Basecamp projects?"
- "Show me the latest campfire messages from the Technology project"
- "Create a new card in the Development column with title 'Fix login bug'"
- "Get all todo items from the Marketing project"
- "Search for messages containing 'deadline'"
Troubleshooting Claude Desktop
Check Claude Desktop logs (following official debugging guide):
Common issues:
- Tools not appearing: Verify configuration file syntax and restart Claude Desktop
- Connection failures: Check that Node.js path and script path are absolute paths
- Authentication errors: Ensure OAuth flow completed successfully (
oauth_tokens.json
exists)
Available MCP Tools
Once configured, you can use these tools in Cursor:
get_projects
- Get all Basecamp projectsget_project
- Get details for a specific projectget_todolists
- Get todo lists for a projectget_todos
- Get todos from a todo listsearch_basecamp
- Search across projects, todos, and messagesget_comments
- Get comments for a Basecamp itemget_campfire_lines
- Get recent messages from a Basecamp campfireget_daily_check_ins
- Get project's daily check-in questionsget_question_answers
- Get answers to daily check-in questionscreate_attachment
- Upload a file as an attachmentget_events
- Get events for a recordingget_webhooks
- List webhooks for a projectcreate_webhook
- Create a webhookdelete_webhook
- Delete a webhookget_documents
- List documents in a vaultget_document
- Get a single documentcreate_document
- Create a documentupdate_document
- Update a documenttrash_document
- Move a document to trash
Card Table Tools
get_card_table
- Get the card table details for a projectget_columns
- Get all columns in a card tableget_column
- Get details for a specific columncreate_column
- Create a new column in a card tableupdate_column
- Update a column titlemove_column
- Move a column to a new positionupdate_column_color
- Update a column colorput_column_on_hold
- Put a column on hold (freeze work)remove_column_hold
- Remove hold from a column (unfreeze work)watch_column
- Subscribe to notifications for changes in a columnunwatch_column
- Unsubscribe from notifications for a columnget_cards
- Get all cards in a columnget_card
- Get details for a specific cardcreate_card
- Create a new card in a columnupdate_card
- Update a cardmove_card
- Move a card to a new columncomplete_card
- Mark a card as completeuncomplete_card
- Mark a card as incompleteget_card_steps
- Get all steps (sub-tasks) for a cardcreate_card_step
- Create a new step (sub-task) for a cardget_card_step
- Get details for a specific card stepupdate_card_step
- Update a card stepdelete_card_step
- Delete a card stepcomplete_card_step
- Mark a card step as completeuncomplete_card_step
- Mark a card step as incomplete
Example Cursor Usage
Ask Cursor things like:
- "Show me all my Basecamp projects"
- "What todos are in project X?"
- "Search for messages containing 'deadline'"
- "Get details for the Technology project"
- "Show me the card table for project X"
- "Create a new card in the 'In Progress' column"
- "Move this card to the 'Done' column"
- "Update the color of the 'Urgent' column to red"
- "Mark card as complete"
- "Show me all steps for this card"
- "Create a sub-task for this card"
- "Mark this card step as complete"
Architecture
The project uses the official @modelcontextprotocol/sdk for maximum reliability and compatibility:
- MCP Server (
src/index.ts
) - Official MCP SDK with 46 tools, compatible with both Cursor and Claude Desktop - OAuth App (
src/lib/oauth-app.ts
) - Handles OAuth 2.0 flow with Basecamp - Token Storage (
src/lib/token-storage.ts
) - Securely stores OAuth tokens - Basecamp Client (
src/lib/basecamp-client.ts
) - Basecamp API client library - Type Definitions (
src/types/basecamp.ts
) - Complete TypeScript interfaces - Configuration Scripts:
- NPM scripts for setup, authentication, and config generation
- Built-in TypeScript compilation and testing
Troubleshooting
Common Issues (Both Clients)
- 🔴 Red/Yellow indicator: Run
npm run setup
to build the project and dependencies - 🔴 "0 tools available": Project not built or dependencies missing - run setup script
- ���� "Tool not found" errors: Restart your client (Cursor/Claude Desktop) completely
- ⚠️ Missing BASECAMP_ACCOUNT_ID: Add to
.env
file, then re-run the config generator
Quick Fixes
Problem: Server won't start
Problem: Wrong Node.js version
Problem: Authentication fails
Manual Configuration (Last Resort)
Cursor config location: ~/.cursor/mcp.json
(macOS/Linux) or %APPDATA%\Cursor\mcp.json
(Windows)
Claude Desktop config location: ~/Library/Application Support/Claude/claude_desktop_config.json
(macOS)
Finding Your Account ID
If you don't know your Basecamp account ID:
- Log into Basecamp in your browser
- Look at the URL - it will be like
https://3.basecamp.com/4389629/projects
- The number (4389629 in this example) is your account ID
Security Notes
- Keep your
.env
file secure and never commit it to version control - The OAuth tokens are stored locally in
oauth_tokens.json
- This setup is designed for local development use
Acknowledgments
This TypeScript implementation was inspired by and built upon the excellent foundation provided by the original Python Basecamp MCP Server.
Thank you to the original Python project maintainers for creating a solid foundation that enabled this TypeScript adaptation! 🙏
License
This project is licensed under the MIT License.
This server cannot be installed
hybrid server
The server is able to function both locally and remotely, depending on the configuration or use case.
Enables seamless integration with Basecamp 3 through 46 comprehensive API tools, allowing users to manage projects, todos, card tables, documents, campfire messages, and other Basecamp features through natural language interactions in Claude Desktop and Cursor IDE.
Related MCP Servers
- -securityAlicense-qualityFacilitates integration with the Cursor code editor by enabling real-time code indexing, analysis, and bi-directional communication with Claude, supporting concurrent sessions and automatic reconnection.Last updated -2238TypeScriptMIT License
- -securityAlicense-qualityActs as a bridge between Claude's desktop application and the Cursor editor, enabling seamless AI-powered automation and multi-instance management across platforms with standardized communication and secure token-based authentication.Last updated -267TypeScriptMIT License
- -securityAlicense-qualityConnects Claude Desktop directly to databases, allowing it to explore database structures, write SQL queries, analyze datasets, and create reports through an API layer with tools for table exploration and query execution.Last updated -290PythonMozilla Public License 2.0
Base MCP Serverofficial
-securityAlicense-qualityProvides onchain tools for Claude AI to interact with the Base blockchain and Coinbase API, enabling wallet management, fund transfers, and smart contract deployment.Last updated -14273TypeScriptMIT License