GoHighLevel MCP Server
Enables AI voice agents like RetellAI and Vapi to directly integrate with GoHighLevel for contact management, calendar availability, and appointment booking without middleware.
README
GoHighLevel MCP Server (Self-Hosted)
Use case: Connect AI apps like RetellAI and Vapi directly to GoHighLevel (GHL) for contact + booking workflows. This project may also work with other MCP-compatible apps.
No middleware required: direct RetellAI/Vapi -> GHL integration without apps like n8n or make.com.
If this is your first time using Vercel or MCP, setup typically takes 15-30 minutes.
You maybe asking why not just use GHL's native MCP? At the time of development they do not provide tooling for querying calendars for open slots or booking appointments.
Table of Contents
- What This Server Does
- Quick Start Checklist
- 1. Deploy on Vercel
- 2. Connect MCP in Your Agent Platform
- 3. Recommended Agent Flow
- 4. Troubleshooting
What This Server Does
- Create or update contacts (
ghl_create_contact) - Search contacts (
ghl_search_contacts) - Retrieve calendar free slots (
ghl_get_calendar_free_slots) - Create confirmed appointments (
ghl_create_appointment)
Endpoint:
POST /mcp
Quick Start Checklist
- Deploy this repo to Vercel
- Add required environment variables
- Copy your Vercel
/mcpURL - Add MCP in RetellAI with required headers
- Add all 4 tools to your Retell agent
- Run one end-to-end test call
1. Deploy on Vercel
1.1 Import this repo
- Go to Vercel.
- Create a new project.
- Import this GitHub repository.
- Deploy.
1.2 Add environment variables
In Vercel project settings, add the following:
| Variable | Required | What it is | How to get it |
|---|---|---|---|
GHL_PRIVATE_INTEGRATION_TOKEN |
Yes | GHL API token used by this MCP | GHL -> Settings -> Private Integrations -> create integration -> copy token |
DEFAULT_LOCATION_ID |
Yes | Sub-account location ID this server is scoped to | GHL sub-account -> Settings -> Business Information |
MCP_SHARED_SECRET |
Yes | Shared secret that authenticates MCP clients to your server | Choose your own secret (like a password) or generate with openssl rand -hex 32 |
DEFAULT_TIMEZONE |
No | Default timezone fallback | Optional, default is America/New_York |
ALLOWED_LOCATION_IDS |
No | Optional multi-tenant allowlist | Comma-separated list of location IDs |
Private Integration scopes required:
contacts.readonlycontacts.writecalendars.readonlycalendars/events.write
Hardcoded in app (no env needed):
- GHL base URL:
https://services.leadconnectorhq.com - GHL API version header:
2021-07-28
1.3 Confirm endpoint
Your MCP URL will be:
https://<your-vercel-domain>/mcp
2. Connect MCP in Your Agent Platform
Choose one platform below. RetellAI and Vapi are separate alternatives. This MCP server may also work with other MCP-capable platforms, but testing for this project was conducted using RetellAI and Vapi.
Option A: RetellAI
2.1 Add MCP (matches Retell UI)
In RetellAI -> Add MCP:
- Name:
GHL MCP(or any label) - URL:
https://<your-vercel-domain>/mcp - Timeout (ms):
10000
Under Headers, add:
Authorization=Bearer <GHL_PRIVATE_INTEGRATION_TOKEN>locationId=<DEFAULT_LOCATION_ID>X-MCP-KEY=<MCP_SHARED_SECRET>calendarId=<GHL_CALENDAR_ID>
Under Query Parameters:
- leave empty
Then click Save.
2.2 Add tools to your agent
In RetellAI -> Add Tool, add:
ghl_create_contactghl_search_contactsghl_get_calendar_free_slotsghl_create_appointment
Recommended toggles:
- Speak During Execution: off
- Speak After Execution: on
Optional variable mapping:
- Store
ghl_create_contact.contactIdascontact_id - Use
contact_idforghl_create_appointment.contactId
Important notes:
calendarIdheader is required for calendar tools.X-MCP-KEYmust exactly match your VercelMCP_SHARED_SECRET.- Get
calendarIdfrom GHL calendar settings.
Option B: Vapi
2.3 Create the MCP tool
In Vapi:
- Go to Tools (left menu).
- Click Create Tool.
- Select MCP.
Configure these fields:
- Tool Name:
ghl_mcp(or any label) - Description:
GHL MCP - Server URL:
https://<your-vercel-domain>/mcp - Timeout:
20seconds (recommended)
Under HTTP Headers, add:
Authorization=Bearer <GHL_PRIVATE_INTEGRATION_TOKEN>locationId=<DEFAULT_LOCATION_ID>X-MCP-KEY=<MCP_SHARED_SECRET>calendarId=<GHL_CALENDAR_ID>
Under MCP Settings:
- Select Streamable HTTP (SHTTP) (recommended)
- SSE is also supported if needed
Then click Save.
2.4 Assign the MCP tool to your assistant
After saving the MCP tool:
- Go to Assistants.
- Select your assistant.
- Open the Tools dropdown/menu.
- Assign the MCP tool you created.
Important:
- If the tool is not assigned to the assistant, calls will not use this MCP server.
X-MCP-KEYmust match your VercelMCP_SHARED_SECRETexactly.calendarIdheader is required for calendar tools.
3. Recommended Agent Flow
ghl_search_contactsghl_create_contact(only if no match)ghl_get_calendar_free_slotsghl_create_appointment
Copy/Paste system prompt tool policy
Use this in your Retell system prompt. You can customize it, but test with real calls before production.
Use MCP tools for all contact + booking actions.
Do not invent contact IDs, availability, or confirmations.
Never mention tool names, tool calls, or internal MCP/tool errors to the caller.
Flow:
1) Run ghl_search_contacts first using available phone/email/query.
2) If exactly one contact is found, use that contactId.
3) If no contact is found, collect missing phone/email and run ghl_create_contact.
4) If multiple contacts are found, disambiguate before booking.
5) Run ghl_get_calendar_free_slots and only offer returned slots.
6) Run ghl_create_appointment only with a confirmed contactId and an offered slot.
If no slots, ask for a different date range.
If tool error, say there is a technical issue and retry or escalate.
Confirm booking only after ghl_create_appointment succeeds.
4. Troubleshooting
401 AUTH_ERROR: a required header is missing or invalid.403location access error: verify token access andlocationId.- Empty free slots:
- verify
calendarIdheader - verify date range + timezone
- verify calendar availability in GHL
- verify
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.