Calendly
STDIOMCP server for Calendly API integration with automated email invitations
MCP server for Calendly API integration with automated email invitations
A Model Context Protocol (MCP) server for integrating with the Calendly API. This server provides tools to interact with Calendly's scheduling platform, allowing you to retrieve user information, list events, manage invitees, cancel events, and schedule meetings directly via the new Scheduling API.
Run directly without installation:
npx calendly-mcp-server
git clone https://github.com/meAmitPatil/calendly-mcp-server.git cd calendly-mcp-server
npm install
npm run build
This server supports two authentication methods:
For internal applications or personal use:
export CALENDLY_API_KEY="your_personal_access_token_here"
For public applications that multiple users will use:
export CALENDLY_CLIENT_ID="your_client_id_here" export CALENDLY_CLIENT_SECRET="your_client_secret_here"
export CALENDLY_ACCESS_TOKEN="your_access_token_here" export CALENDLY_REFRESH_TOKEN="your_refresh_token_here"
For better performance and automatic defaults, you can set user-specific URIs:
export CALENDLY_USER_URI="https://api.calendly.com/users/your_user_id" export CALENDLY_ORGANIZATION_URI="https://api.calendly.com/organizations/your_org_id"
These can be obtained by running get_current_user after authentication. When set, the server will automatically use these as defaults for API calls that require user context.
Add the server to your MCP client configuration (e.g., Claude Desktop):
For Personal Access Token:
{ "mcpServers": { "calendly": { "command": "npx", "args": ["calendly-mcp-server"], "env": { "CALENDLY_API_KEY": "your_personal_access_token_here", "CALENDLY_USER_URI": "https://api.calendly.com/users/your_user_id", "CALENDLY_ORGANIZATION_URI": "https://api.calendly.com/organizations/your_org_id" } } } }
For OAuth 2.0:
{ "mcpServers": { "calendly": { "command": "npx", "args": ["calendly-mcp-server"], "env": { "CALENDLY_CLIENT_ID": "your_client_id_here", "CALENDLY_CLIENT_SECRET": "your_client_secret_here", "CALENDLY_ACCESS_TOKEN": "your_access_token_here", "CALENDLY_REFRESH_TOKEN": "your_refresh_token_here", "CALENDLY_USER_URI": "https://api.calendly.com/users/your_user_id", "CALENDLY_ORGANIZATION_URI": "https://api.calendly.com/organizations/your_org_id" } } } }
For Personal Access Token:
{ "mcpServers": { "calendly": { "command": "node", "args": ["path/to/calendly-mcp-server/dist/index.js"], "env": { "CALENDLY_API_KEY": "your_personal_access_token_here", "CALENDLY_USER_URI": "https://api.calendly.com/users/your_user_id", "CALENDLY_ORGANIZATION_URI": "https://api.calendly.com/organizations/your_org_id" } } } }
For OAuth 2.0:
{ "mcpServers": { "calendly": { "command": "node", "args": ["path/to/calendly-mcp-server/dist/index.js"], "env": { "CALENDLY_CLIENT_ID": "your_client_id_here", "CALENDLY_CLIENT_SECRET": "your_client_secret_here", "CALENDLY_ACCESS_TOKEN": "your_access_token_here", "CALENDLY_REFRESH_TOKEN": "your_refresh_token_here", "CALENDLY_USER_URI": "https://api.calendly.com/users/your_user_id", "CALENDLY_ORGANIZATION_URI": "https://api.calendly.com/organizations/your_org_id" } } } }
All tools work seamlessly through Claude Desktop or any MCP client
get_oauth_urlGenerate OAuth authorization URL for user authentication.
Parameters:
redirect_uri (required): The redirect URI for your OAuth applicationstate (optional): Optional state parameter for securityexchange_code_for_tokensExchange authorization code for access and refresh tokens.
Parameters:
code (required): The authorization code from OAuth callbackredirect_uri (required): The redirect URI used in authorizationrefresh_access_tokenRefresh access token using refresh token.
Parameters:
refresh_token (required): The refresh token to useget_current_userGet information about the currently authenticated user.
list_eventsList scheduled events with optional filtering.
Parameters:
user_uri (optional): URI of the user whose events to list (uses CALENDLY_USER_URI if not provided)organization_uri (optional): URI of the organization to filter eventsstatus (optional): Filter by status ("active" or "canceled")max_start_time (optional): Maximum start time (ISO 8601 format)min_start_time (optional): Minimum start time (ISO 8601 format)count (optional): Number of events to return (default 20, max 100)get_eventGet details of a specific event.
Parameters:
event_uuid (required): UUID of the event to retrievelist_event_inviteesList invitees for a specific event.
Parameters:
event_uuid (required): UUID of the eventstatus (optional): Filter by status ("active" or "canceled")email (optional): Filter by email addresscount (optional): Number of invitees to return (default 20, max 100)cancel_eventCancel a specific event.
Parameters:
event_uuid (required): UUID of the event to cancelreason (optional): Reason for cancellationlist_organization_membershipsList organization memberships for the authenticated user.
Parameters:
user_uri (optional): URI of the user (uses CALENDLY_USER_URI if not provided)organization_uri (optional): URI of the organizationemail (optional): Filter by emailcount (optional): Number of memberships to return (default 20, max 100)list_event_typesList available event types for scheduling meetings.
Parameters:
user (optional): URI of the user whose event types to listorganization (optional): URI of the organization to filter event typescount (optional): Number of event types to return (default 20, max 100)get_event_type_availabilityGet available time slots for a specific event type.
Parameters:
event_type (required): URI of the event type to check availability forstart_time (optional): Start time for availability window (ISO 8601 format)end_time (optional): End time for availability window (ISO 8601 format)schedule_eventSchedule a meeting by creating an invitee for a specific event type and time.
Requirements: Paid Calendly plan (Standard or higher)
Parameters:
event_type (required): URI of the event type to schedulestart_time (required): Start time for the event (ISO 8601 UTC format)invitee_email (required): Email address of the inviteeinvitee_timezone (required): Timezone of the invitee (e.g., America/New_York)invitee_name (optional): Full name of the inviteeinvitee_first_name (optional): First name of the inviteeinvitee_last_name (optional): Last name of the inviteeinvitee_phone (optional): Phone number for SMS reminders (E.164 format)location_kind (optional): Meeting location type (zoom_conference, google_conference, physical, etc.)location_details (optional): Location details (required for physical meetings)event_guests (optional): Array of additional email addresses (max 10)questions_and_answers (optional): Array of question/answer pairsutm_source, utm_campaign, utm_medium (optional): UTM tracking parametersOnce configured with your MCP client, you can use these tools:
Here's the MCP server in action with Claude Desktop:

Example: User asks "Show me my Calendly events" and gets formatted event details including date, time, duration, location, and invitee information.
# Generate OAuth URL
get_oauth_url redirect_uri="https://myapp.com/auth/callback"
# Exchange code for tokens (after user authorizes)
exchange_code_for_tokens code="AUTHORIZATION_CODE" redirect_uri="https://myapp.com/auth/callback"
# Refresh access token
refresh_access_token refresh_token="REFRESH_TOKEN"
# Get current user information
get_current_user
# List recent events
list_events count=10
# Get specific event details
get_event event_uuid="EVENT_UUID_HERE"
# List invitees for an event
list_event_invitees event_uuid="EVENT_UUID_HERE"
# Cancel an event
cancel_event event_uuid="EVENT_UUID_HERE" reason="Meeting no longer needed"
# List available event types
list_event_types
# Check availability for a specific event type
get_event_type_availability event_type="https://api.calendly.com/event_types/AAAAAAAAAAAAAAAA"
# Schedule a meeting (requires paid plan)
schedule_event event_type="https://api.calendly.com/event_types/AAAAAAAAAAAAAAAA" start_time="2025-10-21T19:00:00Z" invitee_email="[email protected]" invitee_name="John Smith" invitee_timezone="America/New_York" location_kind="zoom_conference"
# Natural language commands that work in Claude Desktop:
"Show me my event types"
"Check availability for my 30-minute consultation next week"
"Schedule a meeting with [email protected] for tomorrow at 2 PM"
"Book a client onboarding call for Friday"
npm config get cache)npx --offline calendly-mcp-server to use cached versionCALENDLY_API_KEY environment variablelist_events: Set CALENDLY_USER_URI environment variable or provide user_uri parameterschedule_event: Requires paid Calendly plan (Standard or higher)get_event_type_availability to verify the time slot is availablenpm run build if using local installation# Test with NPX (recommended for users) npx calendly-mcp-server # Test with MCP Inspector npx @modelcontextprotocol/inspector npx calendly-mcp-server # Clone for development git clone <repository-url> cd calendly-mcp-server npm install npm run build
npm run build: Build the TypeScript codenpm run dev: Run in development mode with auto-reloadnpm start: Run the built serversrc/
├── index.ts          # Main server implementation
├── types.ts          # TypeScript type definitions (if needed)
└── utils.ts          # Utility functions (if needed)
MIT License - see LICENSE file for details.
For issues with this MCP server, please create an issue in the repository. For Calendly API documentation, visit the Calendly Developer Portal.