๐งญ Compass MCP
The missing bridge between Claude Chat, Cowork, and Code.
Compass is an MCP server that gives Claude shared operational state across all three surfaces. Add a task in Chat, check it off in Code, filter by project in Cowork โ same data, zero re-explaining.
โโโโโโโโโโโโโ โโโโโโโโโโโโโ โโโโโโโโโโโโโ
โ Chat โ โ Cowork โ โ Code โ
โโโโโโโฌโโโโโโ โโโโโโโฌโโโโโโ โโโโโโโฌโโโโโโ
โ โ โ
โโโโโโโโโโฌโโโโโโโโดโโโโโโโโโฌโโโโโโโโ
โ โ
โโโโโโโโโผโโโโโโโโโโโโโโโโโผโโโโโโโโ
โ Compass MCP โ
โ โ
โ โโโโโโโโโโโโโโโโโโโโโโโโ โ
โ โ ~/compass-data/ โ โ
โ โ tasks.md โ โ
โ โ contexts/ โ โ
โ โโโโโโโโโโโโโโโโโโโโโโโโ โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
Why?
Claude Chat, Cowork, and Code don't share state. Each session starts from zero. There's no way to ask in Chat "what did I finish in Code?" or tell Cowork "here's the context for this project" without re-explaining everything.
Compass fixes that. One MCP server, visible to all three surfaces, backed by plain markdown files.
This is not another todo app. It's the operational layer that connects how you think (Chat), how you execute (Cowork), and how you build (Code).
Install
git clone https://github.com/richlira/compass-mcp.git
cd compass-mcp
npm install
npm run build
Connect to Claude Desktop
Add to ~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"compass": {
"command": "node",
"args": ["/absolute/path/to/compass-mcp/build/index.js"]
}
}
}
Restart Claude Desktop. All three tabs (Chat, Cowork, Code) will see Compass.
Usage
No commands to memorize. Just talk:
| You say | Compass does |
|---|---|
| "Set up my workspace" | init_workspace โ creates ~/compass-data/ |
| "Add task: write copy for landing page, deadline April 5" | add_task โ adds to tasks.md |
| "I finished the workshop slides" | complete_task โ marks it done |
| "What's still pending?" | get_tasks โ returns filtered tasks |
| "Save context for Impact Lab: April 18, hackathon format" | save_context โ creates contexts/impact-lab.md |
| "What do we know about the workshop?" | get_context โ reads contexts/workshop.md |
Works in English, Spanish, Spanglish โ whatever. Claude matches your intent to the right tool automatically.
Tools
init_workspace
Creates ~/compass-data/ with tasks.md and contexts/ directory. Safe to run multiple times.
add_task
Adds a task to tasks.md.
- title (required) โ what needs to be done
- tags โ project or category tags (e.g.
["cancun", "marketing"]) - deadline โ due date
- section โ
"active"(default) or"backlog"
complete_task
Marks a task as completed in tasks.md.
- title (required) โ task to complete (fuzzy matched)
- notes โ optional completion notes
get_tasks
Returns tasks filtered by status, tags, or deadline.
- status โ
"active","backlog","completed", or"all" - tags โ filter by tags
- deadline_before โ show tasks due before a date
save_context
Creates or updates a project context file in contexts/.
- project (required) โ project name (becomes the filename)
- content (required) โ markdown content with project details
get_context
Reads a project context file.
- project (required) โ project name to look up
Storage
Everything lives in ~/compass-data/:
~/compass-data/
โโโ tasks.md โ all tasks with status, tags, deadlines
โโโ contexts/
โโโ cancun.md โ project-specific context
โโโ workshop.md
โโโ ...
Plain markdown. Human-readable. Git-versionable. No database.
The workspace path is configurable via the COMPASS_DATA_DIR environment variable.
How the three surfaces use Compass
Chat โ your thinking space. Plan the day, add tasks, check status, save project context. Chat is where you decide.
Cowork โ your execution space. Cowork reads the same tasks and contexts. It can check what's pending, mark things done as it works, and read project context to understand what to do.
Code โ your building space. Code checks for build-related tasks, marks them complete when done, and reads project context for specs and decisions. Code is also where you maintain and improve Compass itself.
All three read and write the same tasks.md and contexts/ โ that's the bridge.
Pro tip: combine with Google Calendar
If you have the Google Calendar connector enabled, Claude can combine Compass tasks with your calendar:
"Check my tasks and my calendar for today, and block time for what I can get done"
Claude reads your tasks from Compass, finds free slots in your calendar, estimates duration, and creates focus blocks. No extra code needed โ just Claude orchestrating two tools together.
Requirements
- Node.js 18+
- Claude Desktop (macOS or Windows)
- Claude Pro, Max, Team, or Enterprise plan
Development
# Build
npm run build
# Test with MCP Inspector
npx @modelcontextprotocol/inspector node build/index.js
# Watch mode
npm run watch
Philosophy
Compass is intentionally minimal. Six tools, two file types, zero database. Decisions, progress tracking, and daily recaps are left to Claude's memory โ that's what it's good at. Compass only handles what Claude can't do alone: queryable task state and structured project context that persists across all surfaces.
If you need more, add it. If you don't, enjoy the simplicity.
License
MIT
Chat, Cowork, Code โ and Compass. ๐งญ