Basecamp
Interact with Basecamp 3 to manage projects, to-dos, and messages.
Basecamp MCP Integration
This project provides a FastMCP-powered integration for Basecamp 3, allowing AI clients to interact with Basecamp directly through the MCP protocol.
ā Migration Complete: Successfully migrated to official Anthropic FastMCP framework with 100% feature parity (all 75 tools) š Ready for Production: Full protocol compliance with MCP 2025-06-18
Quick Setup
This server works with Cursor, Codex, and Claude Desktop. Choose your preferred client:
Prerequisites
- Python 3.10+ (required for MCP SDK) ā or use
uvwhich auto-downloads the correct version - A Basecamp 3 account
- A Basecamp OAuth application (create one at https://launchpad.37signals.com/integrations)
For Cursor Users
One-Command Setup
-
Clone and set up with uv (recommended):
git clone <repository-url> cd Basecamp-MCP-Server # Using uv (recommended - auto-downloads Python 3.12) uv venv --python 3.12 venv source venv/bin/activate # or venv\Scripts\activate on Windows uv pip install -r requirements.txt uv pip install mcpAlternative: Using pip (requires Python 3.10+ already installed):
python setup.pyThe setup automatically:
- ā Creates virtual environment
- ā Installs all dependencies (FastMCP SDK, etc.)
- ā
Creates
.envtemplate file - ā Tests MCP server functionality
-
Configure OAuth credentials: Edit the generated
.envfile:BASECAMP_CLIENT_ID=your_client_id_here BASECAMP_CLIENT_SECRET=your_client_secret_here BASECAMP_ACCOUNT_ID=your_account_id_here USER_AGENT="Your App Name ([email protected])" -
Authenticate with Basecamp:
python oauth_app.pyVisit http://localhost:8000 and complete the OAuth flow.
-
Generate Cursor configuration:
python generate_cursor_config.py -
Restart Cursor completely (quit and reopen, not just reload)
-
Verify in Cursor:
- Go to Cursor Settings ā MCP
- You should see "basecamp" with a green checkmark
- Available tools: 75 tools for complete Basecamp control
Test Your Setup
# Quick test the FastMCP server (works with both clients)
echo '{"jsonrpc":"2.0","id":1,"method":"initialize","params":{"protocolVersion":"2025-06-18","capabilities":{},"clientInfo":{"name":"test","version":"1.0"}}}
{"jsonrpc":"2.0","method":"notifications/initialized","params":{}}
{"jsonrpc":"2.0","id":2,"method":"tools/list","params":{}}' | python basecamp_fastmcp.py
# Run automated tests
python -m pytest tests/ -v
For Codex Users
Codex integration is fully automated with a local path-agnostic script. The script computes all paths from this repository root, so it works no matter where the repo is installed.
Setup Steps
-
Complete the basic setup (same as Cursor steps 1-3 above):
git clone <repository-url> cd Basecamp-MCP-Server python setup.py # Configure .env file with OAuth credentials python oauth_app.py -
Generate Codex configuration automatically:
python generate_codex_config.pyOptional flags:
# Preview commands only (no changes): python generate_codex_config.py --dry-run # Use legacy server instead of FastMCP: python generate_codex_config.py --legacy -
Verify in Codex:
codex mcp get basecamp codex mcp list
Codex Configuration
The script writes to Codex global config:
~/.codex/config.toml
It creates this MCP server entry shape:
[mcp_servers.basecamp]
command = "/path/to/your/project/venv/bin/python"
args = ["/path/to/your/project/basecamp_fastmcp.py"]
[mcp_servers.basecamp.env]
PYTHONPATH = "/path/to/your/project"
VIRTUAL_ENV = "/path/to/your/project/venv"
BASECAMP_ACCOUNT_ID = "your_account_id"
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-3 from Cursor setup above):
git clone <repository-url> cd Basecamp-MCP-Server python setup.py # Configure .env file with OAuth credentials python oauth_app.py -
Generate Claude Desktop configuration:
python generate_claude_desktop_config.py -
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 75 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:
{
"mcpServers": {
"basecamp": {
"command": "/path/to/your/project/venv/bin/python",
"args": ["/path/to/your/project/basecamp_fastmcp.py"],
"env": {
"PYTHONPATH": "/path/to/your/project",
"VIRTUAL_ENV": "/path/to/your/project/venv",
"BASECAMP_ACCOUNT_ID": "your_account_id"
}
}
}
}
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):
# macOS/Linux - Monitor logs in real-time
tail -n 20 -f ~/Library/Logs/Claude/mcp*.log
# Check for specific errors
ls ~/Library/Logs/Claude/mcp-server-basecamp.log
Common issues:
- Tools not appearing: Verify configuration file syntax and restart Claude Desktop
- Connection failures: Check that Python path and script path are absolute paths
- Authentication errors: Ensure OAuth flow completed successfully (
oauth_tokens.jsonexists)
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_todolist- Get a specific todo list by IDcreate_todolist- Create a new todo list in a projectupdate_todolist- Update an existing todo list (name and/or description)trash_todolist- Move a todo list to the trash (recoverable within 30 days)get_todos- Get todos from a todo list (returns all pages; handles Basecamp pagination transparently)get_todo- Get a single todo item by its IDcreate_todo- Create a new todo item in a todo list (with assignees, due dates, descriptions)update_todo- Update an existing todo item (content, description, assignees, due date, etc.)delete_todo- Move a todo item to the trash (recoverable within 30 days)complete_todo- Mark a todo item as completeuncomplete_todo- Mark a todo item as incompletereposition_todo- Reposition a todo within its list, or move it to another list or grouparchive_todo- Archive a todo item (hidden from active list, accessible via web UI)search_basecamp- Search across projects, todos, and messagesglobal_search- Search projects, todos, and campfire messages across all projectsget_comments- Get comments for a Basecamp itemcreate_comment- Create a comment on a Basecamp itemget_campfire_lines- Get recent messages from a Basecamp campfireget_message_board- Get the message board for a projectget_messages- Get all messages from a project's message boardget_message- Get a specific message by IDget_message_categories- Get available message categories (types) for a project (e.g. Announcement, FYI, Heartbeat, Pitch, Question)create_message- Create a new message on a project's message board, with optional categoryget_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_uploads- List uploads in a project or vaultget_upload- Get details for a specific uploadget_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
Todo List Group Tools
get_todolist_groups- Get all groups in a todo list (named sections like "Phase 1", "Backlog")create_todolist_group- Create a new group inside a todo list (supports colors: white, red, orange, yellow, green, blue, aqua, purple, gray, pink, brown)reposition_todolist_group- Reposition a todo list group to a new location within its list
Inbox Tools (Email Forwards)
get_inbox- Get the inbox for a project (email forwards container)get_forwards- Get all forwarded emails from a project's inboxget_forward- Get a specific forwarded email by IDget_inbox_replies- Get all replies to a forwarded emailget_inbox_reply- Get a specific reply to a forwarded emailtrash_forward- Move a forwarded email to trash
Card Table Tools
get_card_tables- Get all card tables for a projectget_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?"
- "Create a new todo 'Review PR' in the Sprint Backlog list"
- "Mark the 'Deploy v2' todo as complete"
- "Show me the messages from the message board in project X"
- "What message categories are available in project X?"
- "Post a new Announcement to the message board in project X: 'We shipped v2.0!'"
- "Create a Heartbeat message in project X with a weekly progress update"
- "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 Anthropic FastMCP framework for maximum reliability and compatibility:
- FastMCP Server (
basecamp_fastmcp.py) - Official MCP SDK with 75 tools, compatible with Cursor, Codex, and Claude Desktop - OAuth App (
oauth_app.py) - Handles OAuth 2.0 flow with Basecamp - Token Storage (
token_storage.py) - Securely stores OAuth tokens - Basecamp Client (
basecamp_client.py) - Basecamp API client library - Search Utilities (
search_utils.py) - Search across Basecamp resources - Setup Automation (
setup.py) - One-command installation - Configuration Generators:
generate_cursor_config.py- For Cursor IDE integrationgenerate_codex_config.py- For Codex CLI integrationgenerate_claude_desktop_config.py- For Claude Desktop integration
Troubleshooting
Common Issues (Both Clients)
- š“ Red/Yellow indicator: Run
python setup.pyto create proper virtual environment - š“ "0 tools available": Virtual environment missing MCP packages - run setup script
- š“ "Tool not found" errors: Restart your client (Cursor/Codex/Claude Desktop) completely
- ā ļø Missing BASECAMP_ACCOUNT_ID: Add to
.envfile, then re-run the config generator
Quick Fixes
Problem: Server won't start
# Test if FastMCP server works:
./venv/bin/python -c "import mcp; print('ā
MCP available')"
# If this fails, run: python setup.py
Problem: Wrong Python version
python --version # Must be 3.10+
# If too old, use uv which auto-downloads the correct Python:
uv venv --python 3.12 venv && source venv/bin/activate && uv pip install -r requirements.txt && uv pip install mcp
Problem: Authentication fails
# Check OAuth flow:
python oauth_app.py
# Visit http://localhost:8000 and complete login
Manual Configuration (Last Resort)
Cursor config location: ~/.cursor/mcp.json (macOS/Linux) or %APPDATA%\Cursor\mcp.json (Windows)
Codex config location: ~/.codex/config.toml
Claude Desktop config location: ~/Library/Application Support/Claude/claude_desktop_config.json (macOS)
{
"mcpServers": {
"basecamp": {
"command": "/full/path/to/your/project/venv/bin/python",
"args": ["/full/path/to/your/project/basecamp_fastmcp.py"],
"cwd": "/full/path/to/your/project",
"env": {
"PYTHONPATH": "/full/path/to/your/project",
"VIRTUAL_ENV": "/full/path/to/your/project/venv",
"BASECAMP_ACCOUNT_ID": "your_account_id"
}
}
}
}
Codex equivalent:
[mcp_servers.basecamp]
command = "/full/path/to/your/project/venv/bin/python"
args = ["/full/path/to/your/project/basecamp_fastmcp.py"]
[mcp_servers.basecamp.env]
PYTHONPATH = "/full/path/to/your/project"
VIRTUAL_ENV = "/full/path/to/your/project/venv"
BASECAMP_ACCOUNT_ID = "your_account_id"
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
.envfile 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
License
This project is licensed under the MIT License.
Related Servers
Linear
Interact with the Linear API to manage issues, projects, and teams.
Claw2Immich
claw2immich is a Python MCP (Model Context Protocol) server that exposes selected Immich Picture App,
Notion
Notion official MCP server
SSE Calculator
A stateful calculator server using Server-Sent Events (SSE) for real-time communication.
Browser Use MCP Server
Automate browser actions using natural language commands. Powered by Playwright and supports multiple LLM providers.
MCP Data Analizer
Analyze and visualize data from .xlsx and .csv files using matplotlib and plotly.
ITGlue
Unofficial MCP server for the ITGlue API
Browser MCP
An MCP server that allows AI applications to control your browser.
MIE - Memory Intelligence Engine
Persistent knowledge graph MCP server that gives AI agents shared memory across sessions and providers. Stores facts, decisions, entities, and events with typed relationships.
P-Link.io
HTTP402 implementation - Gives agents the capacity to pay 402 links and send money to any email, request money