calendly-mcp-server

meAmitPatil/calendly-mcp-server

3.3

If you are the rightful owner of calendly-mcp-server and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.

A Model Context Protocol (MCP) server for integrating with the Calendly API, providing tools to interact with Calendly's scheduling platform.

Tools
  1. get_oauth_url

    Generate OAuth authorization URL for user authentication.

  2. exchange_code_for_tokens

    Exchange authorization code for access and refresh tokens.

  3. refresh_access_token

    Refresh access token using refresh token.

  4. get_current_user

    Get information about the currently authenticated user.

  5. list_events

    List scheduled events with optional filtering.

  6. get_event

    Get details of a specific event.

  7. list_event_invitees

    List invitees for a specific event.

  8. cancel_event

    Cancel a specific event.

  9. list_organization_memberships

    List organization memberships for the authenticated user.

Calendly MCP Server

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 automatically send professional booking invitation emails.

Features

Core Calendly Integration

  • User Information: Get current authenticated user details
  • Event Management: List, retrieve, and cancel scheduled events
  • Invitee Management: List and manage event invitees
  • Organization: List organization memberships

šŸ†• Email Integration & Automation

  • Professional Email Invitations: Send beautiful, branded booking invitation emails
  • End-to-End Workflow: Create event types and automatically send invitations
  • Multiple Email Providers: Support for SendGrid, Resend, and SMTP/Nodemailer
  • Custom Templates: Professional HTML email templates with your branding
  • Personalization: Automatic host details, meeting info, and booking links

Installation

  1. Clone this repository:
git clone <repository-url>
cd calendly-mcp-server
  1. Install dependencies:
npm install
  1. Build the project:
npm run build

Configuration

Authentication

This server supports two authentication methods:

Option 1: Personal Access Token (PAT)

For internal applications or personal use:

  1. Get your Personal Access Token from your Calendly Integrations page
  2. Select API and webhooks → Get a token now
  3. Set the environment variable:
export CALENDLY_API_KEY="your_personal_access_token_here"
Option 2: OAuth 2.0

For public applications that multiple users will use:

  1. Create a developer account at developer.calendly.com
  2. Create an OAuth application to get your client credentials
  3. Set the environment variables:
export CALENDLY_CLIENT_ID="your_client_id_here"
export CALENDLY_CLIENT_SECRET="your_client_secret_here"
  1. Optionally, if you already have tokens:
export CALENDLY_ACCESS_TOKEN="your_access_token_here"
export CALENDLY_REFRESH_TOKEN="your_refresh_token_here"

Optional User Context (Recommended)

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.

MCP Configuration

Add the server to your MCP client configuration (e.g., Claude Desktop):

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"
      }
    }
  }
}

Available Tools (11 Total)

All tools work seamlessly through Claude Desktop or any MCP client

OAuth 2.0 Tools

get_oauth_url

Generate OAuth authorization URL for user authentication.

Parameters:

  • redirect_uri (required): The redirect URI for your OAuth application
  • state (optional): Optional state parameter for security
exchange_code_for_tokens

Exchange authorization code for access and refresh tokens.

Parameters:

  • code (required): The authorization code from OAuth callback
  • redirect_uri (required): The redirect URI used in authorization
refresh_access_token

Refresh access token using refresh token.

Parameters:

  • refresh_token (required): The refresh token to use

API Tools

get_current_user

Get information about the currently authenticated user.

list_events

List 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 events
  • status (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_event

Get details of a specific event.

Parameters:

  • event_uuid (required): UUID of the event to retrieve
list_event_invitees

List invitees for a specific event.

Parameters:

  • event_uuid (required): UUID of the event
  • status (optional): Filter by status ("active" or "canceled")
  • email (optional): Filter by email address
  • count (optional): Number of invitees to return (default 20, max 100)
cancel_event

Cancel a specific event.

Parameters:

  • event_uuid (required): UUID of the event to cancel
  • reason (optional): Reason for cancellation
list_organization_memberships

List 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 organization
  • email (optional): Filter by email
  • count (optional): Number of memberships to return (default 20, max 100)

šŸ†• Email Tools

send_booking_invitation

Send a professional booking invitation email to a recipient.

Parameters:

  • to_email (required): Email address of the recipient
  • to_name (optional): Name of the recipient
  • event_name (required): Name of the event/meeting
  • event_duration (required): Duration in minutes
  • available_days (required): Array of available days (e.g., ["Monday", "Tuesday"])
  • booking_link (required): Calendly booking link
  • custom_message (optional): Personal message to include
create_and_invite_workflow

šŸš€ Complete end-to-end automation: Create event type, generate booking link, and send invitation email.

Parameters:

  • event_name (required): Name of the event/meeting
  • duration (required): Duration in minutes
  • availability_days (required): Array of available days
  • invitee_email (required): Email address of person to invite
  • invitee_name (optional): Name of person to invite
  • event_description (optional): Description of the event
  • custom_message (optional): Personal message to include

Usage Examples

Once configured with your MCP client, you can use these tools:

Live Demo

Here's the MCP server in action with Claude Desktop:

Calendly MCP Server Demo

Example: User asks "Show me my Calendly events" and gets formatted event details including date, time, duration, location, and invitee information.

OAuth Flow Examples:

# 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"

API Examples:

# 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"

šŸ†• Email Examples:

# Complete end-to-end workflow (most popular)
create_and_invite_workflow event_name="Client Onboarding" duration=30 availability_days=["Tuesday","Thursday"] invitee_email="client@company.com" custom_message="Looking forward to welcoming you!"

# Send standalone invitation
send_booking_invitation to_email="prospect@startup.com" event_name="Strategy Session" event_duration=45 available_days=["Monday","Wednesday"] booking_link="https://calendly.com/amit/strategy"

# Bulk invitations with custom messages
create_and_invite_workflow event_name="Team Standup" duration=15 availability_days=["Monday","Tuesday","Wednesday","Thursday","Friday"] invitee_email="team@company.com" custom_message="Daily sync to align on priorities"

šŸŽÆ Claude Desktop Examples:

# Natural language commands that work in Claude Desktop:
"Create a 30-minute client onboarding call and invite john@company.com"
"Send a booking invitation for a strategy session to sarah@startup.com"
"Schedule a consultation call for Fridays and invite mike@agency.com"

API Limitations

  • The Calendly API does not currently support creating new events via API
  • Event rescheduling is not supported via API (only cancellation)
  • Some endpoints require paid Calendly subscriptions

Development

Scripts

  • npm run build: Build the TypeScript code
  • npm run dev: Run in development mode with auto-reload
  • npm start: Run the built server

Project Structure

src/
ā”œā”€ā”€ index.ts          # Main server implementation
ā”œā”€ā”€ types.ts          # TypeScript type definitions (if needed)
└── utils.ts          # Utility functions (if needed)

Contributing

  1. Fork the repository
  2. Create a feature branch
  3. Make your changes
  4. Test thoroughly
  5. Submit a pull request

License

MIT License - see LICENSE file for details.

Support

For issues with this MCP server, please create an issue in the repository. For Calendly API documentation, visit the Calendly Developer Portal.