loading…
Search for a command to run...
loading…
An MCP server that connects Claude Desktop and Claude Code to your Calendly account, enabling natural-language scheduling management.
An MCP server that connects Claude Desktop and Claude Code to your Calendly account, enabling natural-language scheduling management.
An MCP (Model Context Protocol) server that connects Claude Desktop and Claude Code to your Calendly account, enabling natural-language scheduling management.
pip install calendly-mcp
Add the following to your claude_desktop_config.json:
~/Library/Application Support/Claude/claude_desktop_config.json%APPDATA%\Claude\claude_desktop_config.json{
"mcpServers": {
"calendly": {
"command": "calendly-mcp",
"env": {
"CALENDLY_ACCESS_TOKEN": "your-token-here",
"LICENSE_KEY": "optional-premium-key"
}
}
}
}
Set the environment variable before starting Claude Code:
export CALENDLY_ACCESS_TOKEN="your-token-here"
export LICENSE_KEY="optional-premium-key" # only if you have a premium license
Then add the MCP server:
claude mcp add calendly -- calendly-mcp
Or add it to your project's .mcp.json:
{
"mcpServers": {
"calendly": {
"command": "calendly-mcp",
"env": {
"CALENDLY_ACCESS_TOKEN": "your-token-here"
}
}
}
}
| Variable | Required | Description |
|---|---|---|
CALENDLY_ACCESS_TOKEN |
Yes | Calendly Personal Access Token or OAuth2 token |
LICENSE_KEY |
No | Lemon Squeezy premium license key |
LOG_LEVEL |
No | Logging level: DEBUG, INFO, WARNING, ERROR (default: INFO) |
CALENDLY_BASE_URL |
No | Override the Calendly API base URL (for testing) |
| Tool | Description | Required Parameters |
|---|---|---|
list_upcoming_events |
List upcoming scheduled events with optional filters | None (optional: count, min_start_time, max_start_time, status) |
get_event_details |
Get full details of a specific event including invitees and location | event_uuid |
search_events |
Search events by invitee name or email (case-insensitive partial match) | query (optional: min_start_time, max_start_time) |
check_availability |
Check available time slots from your availability schedules | date_range_start, date_range_end |
get_busy_times |
Get busy/unavailable time periods for a date range | start_time, end_time |
list_event_types |
List all configured event types with name, duration, and status | None |
get_event_type_details |
Get detailed configuration of a specific event type | event_type_uuid |
| Tool | Description | Required Parameters |
|---|---|---|
create_one_off_event |
Create a single-use scheduling link for a meeting | event_type_uuid, invitee_email, invitee_name, start_time |
cancel_event |
Cancel an existing scheduled event (invitees are notified) | event_uuid (optional: reason) |
reschedule_event |
Reschedule an event to a new time | event_uuid, new_start_time |
get_scheduling_stats |
Get scheduling analytics: total meetings, avg duration, popular times | min_start_time, max_start_time |
get_invitee_insights |
Analyze meeting patterns with a specific contact | invitee_email |
| Feature | Free | Premium |
|---|---|---|
| View upcoming events | Yes | Yes |
| Get event details | Yes | Yes |
| Search events by invitee | Yes | Yes |
| Check availability | Yes | Yes |
| View busy times | Yes | Yes |
| List event types | Yes | Yes |
| Get event type details | Yes | Yes |
| Create scheduling links | -- | Yes |
| Cancel events | -- | Yes |
| Reschedule events | -- | Yes |
| Scheduling analytics | -- | Yes |
| Invitee insights | -- | Yes |
| Price | Free | $12/month |
Upgrade at nyxtools.lemonsqueezy.com/checkout
Once connected, talk to Claude naturally:
git clone https://github.com/nyxtools/calendly-mcp-server.git
cd calendly-mcp-server
python -m venv venv
source venv/bin/activate # or venv\Scripts\activate on Windows
pip install -e ".[dev]"
pytest
pytest --cov=calendly_mcp # with coverage
ruff check src/ tests/
ruff format src/ tests/
mypy src/
You have not set the CALENDLY_ACCESS_TOKEN environment variable. Make sure it is configured in your claude_desktop_config.json (under env) or exported in your shell before running Claude Code.
Your Calendly Personal Access Token is invalid or has been revoked. Generate a new token at Settings > Integrations & Apps > API in Calendly and update your configuration.
The Calendly API enforces rate limits. The MCP server automatically retries with exponential backoff, but if you see persistent rate limit errors, reduce the frequency of requests or wait a few minutes.
api.calendly.com is reachable from your networkhttpx can reach the Calendly APILICENSE_KEY is set correctly in the environmentLOG_LEVEL=DEBUG)command path is correct (calendly-mcp must be on your PATH)calendly-mcp directly in a terminal to check for errorsMIT -- see LICENSE for details.
Copyright (c) 2026 NyxTools
Выполни в терминале:
claude mcp add calendly-mcp-server -- npx Безопасность
Низкий рискАвтоматическая эвристика по публичным данным — не гарантия безопасности.