booking_chest
MCP server for Cal.com scheduling, providing ~70 tools to manage schedules, event types, bookings, calendars, webhooks, and teams. Enables natural language control of Cal.com from Claude or any MCP-compatible client.
README
booking_chest — Cal.com MCP Server
A Model Context Protocol server for Cal.com open-source scheduling. Exposes ~70 MCP tools across 10 resource modules — create schedules, manage event types, book meetings, integrate calendars, configure webhooks, and manage teams — all controllable directly from Claude or any MCP-compatible client.
Features
- ~70 tools covering the Cal.com API v2
- Clean two-layer architecture: pure
calcom_client/package + thin MCP wrapper - Static Bearer token auth (no refresh needed)
- Typed exception hierarchy (
APIError,NotFoundError,ValidationError,AuthenticationError) - API quirks baked in (correct parameter names, required fields, response envelope unwrapping)
Resource Modules (10)
| Module | Tools | Description |
|---|---|---|
me |
2 | Profile get/update |
timezones |
1 | List all 7,072 city/timezone entries |
api_keys |
1 | Rotate API key (warning: invalidates immediately) |
schedules |
5 | Availability schedule CRUD |
event_types |
9 | Event type CRUD + per-type webhooks + private links (Enterprise) |
slots |
3 | Available slots, reserve, delete reservation |
bookings |
6 | List, get, create, cancel, reschedule, mark no-show |
calendars |
9 | Connect, busy times, destination, selected, ICS feeds |
webhooks |
5 | User-level webhook CRUD (21 trigger types) |
teams |
19 | Team CRUD + memberships + event types + event-type webhooks + invite |
Installation
git clone https://github.com/dsddet/booking_chest
cd booking_chest
pip install -e ".[mcp]"
Or with uv (recommended):
uv pip install -e ".[mcp]"
Environment Variables
| Variable | Required | Description |
|---|---|---|
CALCOM_API_KEY |
Yes | Cal.com API key (starts with cal_) |
CALCOM_BASE_URL |
No | Cal.com instance URL (default: https://api.cal.com) |
Create a .env file:
CALCOM_API_KEY=cal_your_api_key_here
CALCOM_BASE_URL=https://api.cal.com
For self-hosted Cal.com instances, set CALCOM_BASE_URL to your instance URL (e.g., http://192.168.0.214).
Getting an API Key
- Log into Cal.com Settings → Developer → API Keys
- Click "Generate API Key"
- Copy the key (starts with
cal_) — it cannot be retrieved later
Claude Desktop Configuration
Add to ~/Library/Application Support/Claude/claude_desktop_config.json (macOS) or %APPDATA%\Claude\claude_desktop_config.json (Windows):
{
"mcpServers": {
"booking_chest": {
"command": "uv",
"args": [
"--directory", "/path/to/booking_chest",
"run", "--extra", "mcp", "mcp_server.py"
],
"env": {
"CALCOM_API_KEY": "cal_your_api_key_here",
"CALCOM_BASE_URL": "https://api.cal.com"
}
}
}
}
Replace /path/to/booking_chest with the absolute path to your cloned directory.
Usage Examples
Once connected, you can ask Claude:
- "Create a 30-minute consultation event type"
- "What slots are available this week for event type 1?"
- "Book a meeting with john@example.com on March 5th at 2pm Eastern"
- "List all my upcoming bookings"
- "Cancel booking 42 — attendee has a conflict"
- "Connect my Google Calendar and set it as the destination"
- "Create a webhook to notify Zapier when bookings are created or cancelled"
- "List all team members and their roles"
Architecture
calcom_client/ # Pure API client (no MCP dependency)
├── http.py # httpx + Bearer token auth + response envelope unwrap
├── exceptions.py # APIError, NotFoundError, ValidationError, AuthenticationError
├── me.py # Profile get/update
├── timezones.py # List all timezones
├── api_keys.py # API key rotation
├── schedules.py # Availability schedule CRUD
├── event_types.py # Event type CRUD + webhooks + private links
├── slots.py # Available slots, reserve, delete
├── bookings.py # Booking CRUD (cancel, reschedule, no-show)
├── calendars.py # Calendar integrations (Google, Office 365, Apple)
├── webhooks.py # User-level webhook CRUD
├── teams.py # Team CRUD + memberships + event types + invite
└── __init__.py # CalcomClient facade composing all modules
mcp_server.py # ~70 @mcp.tool() functions
Cal.com API Quirks (baked into client code)
- API version: Use
cal-api-version: 2024-06-14(broadest support —2024-08-13misses some endpoints) - Response envelope: All responses wrapped in
{"status": "success", "data": ...}— unwrapped automatically - Slots params: Use
start/end(NOTstartTime/endTime— those cause 400 errors) - Webhook triggers: Use
triggersfield (NOTeventTriggers— old doc error) - Calendar connect: Use
google,office365,apple(NOTgoogle-calendar,office365calendar) calendarsToLoadis REQUIRED for busy-times endpoint (400 error without it)isDefaultis REQUIRED when creating schedules (400 error without it)slotIdis REQUIRED when reserving slots- API key refresh: Old key invalidated immediately — update env before next request
- Team creation needs Stripe — use existing teams or configure Stripe billing
- metadata PATCH: Returns null in response but IS saved (verify via team memberships)
- No team-level webhooks — webhooks are always scoped to specific event types
License
MIT
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.