huddle-mcp
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., "@huddle-mcpbook my agent briefings"
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.
huddle-mcp
An MCP server that lets your parallel coding agents schedule briefings on your real calendar instead of interrupting you. They queue their plans and questions; the queue batches them by urgency into time-blocks booked when you're free.
When you run a fleet of agents, the bottleneck is you. Three plans and two questions land at once, on their schedule, and the context-switching wrecks your decisions. huddle-mcp is the fix real employees already use: don't barge in — book a meeting.
auth-agent → request_meeting("JWT vs sessions", type=plan, urgency=blocker)
ui-agent → request_meeting("dark-mode default?", type=question)
db-agent → request_meeting("migration applied", type=fyi)
You: "book my agent briefings"
→ 🚨 Blocker · auth-agent: JWT vs sessions 11:05–11:15
→ 📋 Agent briefing · 2 items 14:00–14:20 (the question + the FYI)You review at the booked time; the agents wait and unblock once you've decided.
The idea: a broker, not another calendar wrapper
Wrapping a calendar is a solved problem (Google ships an official Calendar MCP; there are mature OSS ones). The value here is the coordination layer in front of it:
a shared queue any agent can drop a request into,
an urgency-aware batching policy (blockers get booked ASAP; routine items bundle into the next briefing; FYIs ride along and reserve no time),
a briefing renderer that aggregates everything into one agenda you skim.
So huddle-mcp is auth-free and provider-agnostic — it never touches your calendar. It emits the agenda + a desired time window, and the actual freebusy lookup + event creation is delegated to whatever calendar MCP you already have connected (Google, Outlook, …). Install = one line, zero new credentials.
Related MCP server: @calmesh/mcp-server
Tools
Tool | Who calls it | What it does |
| worker agent | Queue a plan/question/decision/fyi. Returns a |
| worker agent | Poll a |
| worker agent | Withdraw a ticket you resolved on your own. |
| orchestrator | Batch the queue into proposed meetings + rendered briefings. |
| orchestrator | Record a booked calendar event; marks its tickets scheduled. |
| orchestrator | The rendered agenda + full tickets for a meeting. |
| orchestrator | Record the user's decision for one ticket → unblocks the worker. |
| orchestrator | Parse the user's answers out of the event description and resolve every answered ticket at once. |
| orchestrator | Undo a decision and re-open the ticket (you changed your mind). |
| orchestrator | Drop a meeting, re-queue its open tickets (stale proposals auto-expire after 24h). |
| orchestrator | What's queued / scheduled / answered. |
How it fits together
The calendar event is two-way: huddle writes the briefing into it, and the user answers right there.
worker agents ──request_meeting──▶ [ huddle-mcp queue ] (local JSON, file-locked)
(auth, ui, db…) │ batch by urgency + render briefing
▼
plan_meetings → proposed meetings (window + duration + briefing)
│
your orchestrator ──▶ your Calendar MCP: freebusy → create_event(description = briefing + answer block)
│
confirm_meeting(meetingId, eventId, start, end)
▼
┌── you answer in the event: "tkt_3f9a → use server sessions"
│
└─▶ orchestrator reads the event back ──▶ ingest_answers(description)
▲ (or resolve(ticketId, decision) in chat)
worker agents ──check_response(ticketId)─┘ poll, unblock, proceedThe briefing that lands in the event ends with a writable answer block:
— ✍️ Your answers —
Reply after each → then tell your agent "read my huddle answers".
tkt_3f9a2c1d → use server sessions
tkt_8b7e0a44 → ship dark mode as the defaultWhen you say "read my huddle answers", the bundled huddle skill (in skills/huddle/) fetches the event via your calendar MCP, passes its description to ingest_answers, and every answered ticket resolves — the agents unblock. The same skill drives the booking side: "book my agent briefings" runs plan_meetings, finds free slots, and creates the events. huddle itself never touches the calendar — the skill bridges it.
Requirements
Node.js ≥ 20
A calendar MCP connected in the same client (e.g. Google Calendar) for the actual booking. huddle-mcp itself needs no account and no auth.
Install — Claude Code
{
"mcpServers": {
"huddle": {
"command": "npx",
"args": ["-y", "huddle-mcp"]
}
}
}That's it — no env vars. (Prefer the bleeding edge? Use "github:marcoloco23/huddle-mcp" instead of "huddle-mcp".) Connect a Google Calendar MCP alongside it for booking, and (optionally) copy skills/huddle/ into ~/.claude/skills/ so "book my agent briefings" and "read my huddle answers" just work.
From source
git clone https://github.com/marcoloco23/huddle-mcp.git
cd huddle-mcp
pnpm install # builds via the prepare hook
node dist/index.jsFor agent authors
Worker agents should queue and wait, never block the user inline:
request_meeting({ agent, title, body, type, urgency?, estimated_minutes? })
→ { ticketId }
# do other work, then:
check_response({ ticket_id }) → { answered, response } # proceed once answeredtype:question(needs an answer) ·plan(review a plan) ·decision(pick an option) ·fyi(no action).urgency:blocker(book ASAP) ·normal/low(bundle into the next briefing). Defaultnormal.
Storage
The queue is a single JSON file shared by every agent process, at
~/.config/huddle-mcp/queue.json (honors XDG_CONFIG_HOME; override with
HUDDLE_HOME). Concurrent writes from parallel agents are guarded by an atomic
cross-process lock.
Developing & releasing
npm install # builds via the prepare hook
npm test # node:test — pure units + a stdio server integration suiteCI runs the suite on every push/PR. Releases are automated: bump the version in
package.json, then cut a GitHub Release — the publish workflow builds, tests,
and pushes to npm. It needs an npm automation token (which bypasses 2FA) saved
once as the NPM_TOKEN repo secret (Settings → Secrets and variables → Actions).
Roadmap
Where this is headed — autonomy (agents book themselves), closing the last mile (answered → agent actually resumes), notifications, smarter briefings, Outlook, and more — is in ROADMAP.md, ranked by how much it protects your attention.
License
MIT
Maintenance
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
- Why MCP Servers Need Execution Sandboxing (And Why Your Current Stack Isn't Enough)By Om-Shree-0709 on .Agentic AiPrompt InjectionWebAssembly
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/marcoloco23/huddle-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server