How to integrate Calendly MCP with ChatGPT

Trusted by
AWS
Glean
Zoom
Airtable

30 min · no commitment · see it on your stack

Calendly logo
ChatGPT logo
divider

How to integrate Calendly MCP with ChatGPT

ChatGPT is one of the most popular AI tools today, with capabilities ranging from deep research and image generation to writing, coding, and everyday productivity.

In this guide, I will explain the easiest and most secure way to connect your Calendly account to ChatGPT via Composio Connect, so it can summarize unread updates from this morning, create draft replies to urgent messages, fetch contact details for recent senders, and more without ever putting your account credentials at risk.

Also integrate Calendly with

Why use Composio over default connectors?

  • Apps with read and write access. Default connectors mostly can read your data. Composio's Calendly integration lets ChatGPT take actions like creating drafts, sending updates, labeling records, and more.
  • 1,000+ SaaS toolkits out of the box. Composio gives you instant access to a vast catalog of pre-built connectors, from Gmail and Slack to Notion, Linear, and Salesforce.
  • One MCP server for every app. Connect any of your applications on demand through a single endpoint, rather than juggling a separate server for each app.
  • Smart, context-aware tool loading. Unlike traditional MCP servers that dump every available tool into the LLM context window, Composio searches for and loads only the tools relevant to the task at hand.
  • Cross-app automation. Chain actions across multiple apps in a single run - fetch a thread, summarize it in Notion, and post highlights to Slack without leaving the conversation.

Prerequisites

  • A ChatGPT account with Plus subscription or higher (Business, Enterprise, Edu, or Pro). We will use ChatGPT Web.
  • Access to the Calendly workspace you want to connect.
  • Composio MCP.

Note: Composio connects through OAuth. You will be asked to sign in and approve specific permissions. Review the permission screen carefully if you are using a work account.

Step-by-step: Connect Calendly to ChatGPT

1. Enable Developer Mode

In ChatGPT, go to Settings > Apps > Advanced settings and turn on Developer Mode.

ChatGPT settings showing Developer Mode toggle

2. Add the MCP server

Click Create app, then paste the Composio MCP server URL:

bash
https://connect.composio.dev/mcp
ChatGPT create app flow with Composio MCP URL

3. Authorize in your browser

A browser window will open automatically. Sign in to authorize ChatGPT to access your Composio account.

Composio authorization screen for ChatGPT MCP setup

4. Start using Composio

Composio tools are now available in ChatGPT chats and Deep Research. In every new chat, click the + icon at the bottom, click More, and select Composio to enable tools for that conversation.

What you can do after connecting Calendly

  • Create a single-use scheduling link for your next meeting
  • Cancel your 2pm event with a reason
  • Mark an invitee as no-show for today's appointment
  • Delete all invitee data for privacy compliance

Security + privacy notes (important)

  • Use least-privilege access: Only grant permissions you actually need.
  • Review OAuth permissions before approving: Make sure requested scopes match what you expect Composio and ChatGPT to do.
  • Keep write actions human-reviewed: For actions like sending messages, creating labels, or editing drafts, keep manual confirmation enabled.
  • Be careful with sensitive data: Avoid using this setup with highly sensitive information unless allowed by your personal, company, or client policies.

Supported Tools & Triggers

Tools
Cancel scheduled eventTool to cancel a scheduled Calendly event by creating a cancellation record.
Create Event TypeTool to create a new one-on-one event type (kind: solo) in Calendly.
Create One-Off Event TypeCreates a temporary Calendly one-off event type for unique meetings outside regular availability, requiring valid host/co-host URIs, a future date/range for `date_setting`, and a positive `duration`.
Create scheduling linkCreate a single-use scheduling link.
Create shareCreates a customizable, one-time share link for a Calendly event type, allowing specific overrides to its settings (e.
Create single use scheduling linkCreates a one-time, single-use scheduling link for an active Calendly event type, expiring after one booking.
Create webhook subscriptionTool to create a webhook subscription for receiving Calendly event notifications.
Delete invitee dataPermanently removes all invitee data associated with the provided emails from past organization events, for data privacy compliance (requires Enterprise subscription; deletion may take up to one week).
Delete invitee no showDeletes an Invitee No-Show record by its `uuid` to reverse an invitee's 'no-show' status; the `uuid` must refer to an existing record.
Delete organization membershipTool to remove a user from a Calendly organization by membership UUID.
Delete scheduled event dataFor Enterprise users, initiates deletion of an organization's scheduled event data between a `start_time` and `end_time` (inclusive, where `start_time` must be <= `end_time`); actual data deletion may take up to 7 days to complete.
Delete webhook subscriptionDeletes an existing webhook subscription to stop Calendly sending event notifications to its registered callback URL; this operation is idempotent.
Get eventUse to retrieve a specific Calendly scheduled event by its UUID, provided the event exists in the user's Calendly account.
Get event inviteeRetrieves detailed information about a specific invitee of a scheduled event, using their unique UUIDs.
Get event typeRetrieves details for a specific Calendly event type, identified by its UUID, which must be valid and correspond to an existing event type.
Get event type availabilityTool to retrieve availability schedules configured for a specific Calendly event type.
Get groupRetrieves all attributes of a specific Calendly group by its UUID; the group must exist.
Get group relationshipRetrieves a specific Calendly group relationship by its valid and existing UUID, providing details on user-group associations and membership.
Get invitee no showRetrieves details for a specific Invitee No Show record by its UUID; an Invitee No Show is marked when an invitee does not attend a scheduled event.
Get organizationTool to retrieve information about a specific Calendly organization.
Get organization invitationRetrieves a specific Calendly organization invitation using its UUID and the parent organization's UUID.
Get organization membershipRetrieves a specific Calendly organization membership by its UUID, returning all its attributes.
Get routing formRetrieves a specific routing form by its UUID, providing its configuration details including questions and routing logic.
Get routing form submissionTool to retrieve details about a specific routing form submission by its UUID.
Get sample webhook dataTool to retrieve sample webhook payload data for testing webhook subscriptions.
Get userRetrieves comprehensive details for an existing Calendly user.
Get user availability scheduleRetrieves an existing user availability schedule by its UUID; this schedule defines the user's default hours of availability.
Get webhook subscriptionRetrieves the details of an existing webhook subscription, identified by its UUID, including its callback URL, subscribed events, scope, and state.
Mark invitee as no-showTool to mark an invitee as a no-show for a scheduled event.
List activity log entriesRetrieves a list of activity log entries for a specified Calendly organization (requires an active Enterprise subscription), supporting filtering, sorting, and pagination.
List event inviteesRetrieves a list of invitees for a specified Calendly event UUID, with options to filter by status or email, and sort by creation time.
List event type available timesFetches available time slots for a Calendly event type within a specified time range; results are not paginated.
List event type hostsTool to retrieve a list of event type hosts (memberships) for a specific event type.
List Event TypesTool to list all Event Types associated with a specified User or Organization.
List group relationshipsRetrieves a list of group relationships defining an owner's role (e.
List groupsReturns a list of groups for a specified Calendly organization URI, supporting pagination.
List organization invitationsRetrieves a list of invitations for a specific organization, identified by its UUID.
List organization membershipsRetrieves a list of organization memberships.
List outgoing communicationsRetrieves a list of outgoing SMS communications for a specified organization; requires an Enterprise subscription and if filtering by creation date, both `min_created_at` and `max_created_at` must be provided to form a valid range.
List routing formsRetrieves routing forms for a specified organization; routing forms are questionnaires used to direct invitees to appropriate booking pages or external URLs.
List scheduled eventsTool to retrieve a list of scheduled Calendly events.
List user availability schedulesRetrieves all availability schedules for the specified Calendly user.
List user busy timesFetches a user's busy time intervals (internal and external calendar events) in ascending order for a period up to 7 days; keyset pagination is not supported.
List User Meeting LocationsTool to retrieve configured meeting location information for a given Calendly user.
List webhook subscriptionsRetrieves webhook subscriptions for a Calendly organization; `scope` determines if `user` or `group` URI is also required for filtering.
Invite user to organizationTool to invite a user to a Calendly organization via email.
Create Event InviteeTool to create a new Event Invitee with standard notifications, calendar invites, reschedules, and workflows.
Remove user from organizationRemoves a user (who is not an owner) from an organization by their membership UUID, requiring administrative privileges.
Revoke a user's organization invitationRevokes a pending and revokable (not yet accepted or expired) organization invitation using its UUID and the organization's UUID, rendering the invitation link invalid.
Update Event TypeTool to update an existing one-on-one event type (kind: solo) in Calendly.
Update Event Type AvailabilityTool to update an event type availability schedule in Calendly.

How to build Calendly MCP Agent with another framework

FAQ

What are the differences in Tool Router MCP and Calendly MCP?

With a standalone Calendly MCP server, the agents and LLMs can only access a fixed set of Calendly tools tied to that server. However, with the Composio Tool Router, agents can dynamically load tools from Calendly and many other apps based on the task at hand, all through a single MCP endpoint.

Can I use Tool Router MCP with ChatGPT?

Yes, you can. ChatGPT fully supports MCP integration. You get structured tool calling, message history handling, and model orchestration while Tool Router takes care of discovering and serving the right Calendly tools.

Can I manage the permissions and scopes for Calendly while using Tool Router?

Yes, absolutely. You can configure which Calendly scopes and actions are allowed when connecting your account to Composio. You can also bring your own OAuth credentials or API configuration so you keep full control over what the agent can do.

How safe is my data with Composio Tool Router?

All sensitive data such as tokens, keys, and configuration is fully encrypted at rest and in transit. Composio is SOC 2 Type 2 compliant and follows strict security practices so your Calendly data and credentials are handled as safely as possible.

Used by agents from

Context
Letta
glean
HubSpot
Agent.ai
Altera
DataStax
Entelligence
Rolai
Context
Letta
glean
HubSpot
Agent.ai
Altera
DataStax
Entelligence
Rolai
Context
Letta
glean
HubSpot
Agent.ai
Altera
DataStax
Entelligence
Rolai

Never worry about agent reliability

We handle tool reliability, observability, and security so you never have to second-guess an agent action.