commonroom-mcp
MCP server for integrating Common Room API with Amazon Q CLI and Claude Code, enabling management of activities, segments, and organizations through natural language queries.
README
Common Room MCP Server
⚠️ Note: This is an unofficial MCP server for Common Room
Here's a self-hosted MCP for integrating the Common Room API with Amazon Q CLI and Claude Code. The goal is to be able to ask questions and make updates easily for your own instance. Hope this makes it easier to keep your activities, segments, and organizations up to date! 🥳
How It Works
This MCP server exposes Common Room API functionality as tools that Q CLI can use:
- MCP Protocol: Server communicates with Q CLI via Model Context Protocol
- Tool Registration: Each Common Room API endpoint becomes a callable tool
- Authentication: Uses your Common Room API key from environment variables
- JSON Responses: All data returned as formatted JSON for easy reading
Common Room MCP Architecture
%%{init: {'flowchart': {'curve': 'basis'}}}%%
graph LR
A["💻<br/>Q CLI"] -.-> B["🔌<br/>MCP Server"]
C["💻<br/>Claude Code"] -.-> B
B <--> D["☁️<br/>Common Room API"]
style A fill:#6366f1,stroke:#000,stroke-width:3px,color:#fff
style C fill:#ff9900,stroke:#000,stroke-width:3px,color:#000
style B fill:#C11C84,stroke:#000,stroke-width:3px,color:#fff
style D fill:#10b981,stroke:#000,stroke-width:3px,color:#000
When you ask Q CLI or Claude Code to "get Common Room activity types", it:
- Calls the
commonroom_get_activity_typestool - Server makes API request to Common Room
- Returns formatted results to Q CLI
- The agent presents the data to you in context
Quick Setup
- Clone/download this repository
- Install dependencies:
pip install -r requirements.txt - Create API Signal: Go to
https://app.commonroom.io/community/YOUR-COMMUNITY-ID/settings/sources/apito create an API signal and get yourdestinationSourceId(see Common Room docs) - Configure environment: Copy
.env.exampleto.envand add your API key and destination ID - Configure MCP client (see INSTALL.md for detailed instructions)
Claude Code
Add to ~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"commonroom": {
"command": "python",
"args": ["/path/to/commonroom-mcp/server.py"],
"env": {"COMMONROOM_KEY": "${COMMONROOM_KEY}"}
}
}
}
Amazon Q CLI
q chat --mcp-config ~/.config/amazon-q/mcp-config.json
📖 Complete Installation Guide
🔧 Detailed Setup Guide
Setup
-
Install dependencies:
cd /path/to/commonroom-mcp pip install -r requirements.txt -
Get Common Room API Token:
- Go to your Common Room community settings:
https://app.commonroom.io/community/YOUR-COMMUNITY-ID/settings/api-tokens - Click "Create API Token"
- Give it a name (e.g., "MCP Server")
- Copy the generated token
- See Common Room API Token docs for details
- Go to your Common Room community settings:
-
Find your Destination ID (for adding activities/users):
- Go to Sources settings:
https://app.commonroom.io/community/YOUR-COMMUNITY-ID/settings/sources - Click on "API" source:
https://app.commonroom.io/community/YOUR-COMMUNITY-ID/settings/sources/api - If no API signal exists: Create one first (see Common Room API Signal docs)
- Copy the Destination ID number (e.g.,
138683)
- Go to Sources settings:
-
Configure environment:
cp .env.example .env # Edit .env file with your credentials: # COMMONROOM_KEY=your_api_token_here # COMMONROOM_BASE_URL=https://app.commonroom.io/community/your-community-id # COMMONROOM_DESTINATION_ID=your_destination_id_here # COMMONROOM_SIGNAL_ID=your_signal_id_here (optional) -
Test server:
python server.py
Available Tools
commonroom_get_activity_types- List all activity typescommonroom_get_segments- List all segmentscommonroom_get_tags- List all tagscommonroom_get_user- Get user by email (includes dashboard_url)commonroom_add_activity- Add activitycommonroom_add_user- Add usercommonroom_get_dashboard_urls- Get dashboard section URLscommonroom_get_member_url- Get individual member page URLcommonroom_get_organization_url- Get individual organization page URLcommonroom_get_segment_url- Get individual segment page URL
Usage in Q CLI
Once configured, you can use Common Room tools in Q CLI:
Get all Common Room activity types
Get segments for my team
Add a new blog post activity to Common Room
Show me the URL for user ID 12345
Example Queries
Get activity types:
Show me all Common Room activity types
Find user:
Get Common Room user data for trag@example.com
Get member URL:
What's the URL for Common Room member 226882839?
Add activity:
Add a blog post activity to Common Room by chris@trag.dev with title "Fire TV Development Guide"
Add webinar activity by Sarah Johnson (sarah@startup.com, Twitter: @sarahj, Company: TechCorp) with title "Building Smart TV Apps"
📋 Click here for more examples prompts >>
Key Features
Auto-Generated IDs
- No manual ID management - Server automatically generates unique IDs for activities and users
- Format:
activity_1703123456_a1b2c3d4anduser_1703123456_e5f6g7h8 - Deduplication - Common Room handles user merging based on email/social handles
Flexible User Data
Provide any combination of user information:
- Email address (recommended for deduplication)
- Social handles (Twitter, LinkedIn, GitHub, Discord, Slack)
- Company details (name, job title)
- Personal info (full name, location, bio)
Example: Just say "Add blog post by john@company.com (Twitter: @johndev)" and the server handles the rest!
Tool Details
commonroom_get_activity_types- Returns all available activity types (article, webinar, etc.)commonroom_get_segments- Returns audience segments in your Common Roomcommonroom_get_tags- Returns all tags for categorizationcommonroom_get_user- Finds user by email address (includes dashboard_url)commonroom_add_activity- Creates new activity recordcommonroom_add_user- Creates new user recordcommonroom_get_dashboard_urls- Returns URLs for all dashboard sections (requires COMMONROOM_BASE_URL)commonroom_get_member_url- Returns URL for individual member pagecommonroom_get_organization_url- Returns URL for individual organization pagecommonroom_get_segment_url- Returns URL for individual segment page
Documentation
- INSTALL.md - Complete installation guide for Claude Code and Amazon Q CLI
- SETUP.md - Detailed credential setup with screenshots and links
- EXAMPLES.md - Sample prompts and queries to test the MCP server
- SPEC.md - Technical specification and requirements
- openapi.json - Common Room API specification
Keeping Up to Date
The server automatically checks for changes to Common Room's OpenAPI spec updates 30 seconds after startup and logs any available updates.
Manual update:
./update_spec.sh
Check for updates:
python version_checker.py
Security
- Never commit your
.envfile or API keys - Use environment variables for sensitive data
- Keep your Common Room API token secure
- This server runs locally and doesn't send data to third parties
Support
Looking for support? Check out the Common Room docs or join the Uncommon community for product help.
For Common Room platform support, visit: https://www.commonroom.io/contact/
This MCP server is not officially supported by Common Room.
Contributing
See CONTRIBUTING.md for development guidelines.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.