ghl-mcp
MCP server for GoHighLevel API v2 that provides 50+ tools for CRM, billing, marketing, and operations workflows, enabling natural language interaction with contacts, opportunities, conversations, and more.
README
GoHighLevel MCP Server
ghl-mcp is a Model Context Protocol server for GoHighLevel API v2. It exposes contacts, opportunities, conversations, calendars, workflows, users, invoices, payments, social, forms, funnels, tasks, products, emails, campaigns, and documents as MCP tools over stdio so Claude Code, Cursor, Codex, OpenClaw, VS Code, and other MCP clients can work directly with GoHighLevel CRM data.
Features
- 50 MCP tools covering high-value GoHighLevel CRM, billing, marketing, and operations workflows
- Built on
@modelcontextprotocol/sdkv1.x - Strict TypeScript configuration
- Zod-validated tool inputs with descriptions on every field
- Automatic
locationIdinjection from environment variables - Basic request pacing to stay under GoHighLevel rate limits
- Human-readable tool error payloads instead of raw stack traces
Requirements
- Node.js 18+
- A GoHighLevel API token
- A GoHighLevel location ID
Installation
Local development
npm install
npm run build
node dist/index.js
Run with npx
npx -y ghl-mcp
Configuration
Set these environment variables in the MCP client configuration:
GHL_API_TOKEN: Private Integration token or OAuth access tokenGHL_LOCATION_ID: GoHighLevel location or sub-account ID
The server sends these headers on every request:
Authorization: Bearer {GHL_API_TOKEN}
Content-Type: application/json
Version: 2021-07-28
MCP Client Setup
Claude Code
Note:
claude mcp addregisters a local server name — it doesn't download from a registry. The part after--is the actual command that runs the server.
# After npm publish (recommended):
claude mcp add gohighlevel --scope user \
--env GHL_API_TOKEN="your-token" \
--env GHL_LOCATION_ID="your-location-id" \
-- npx -y ghl-mcp
# Local development (before publishing):
claude mcp add gohighlevel --scope user \
--env GHL_API_TOKEN="your-token" \
--env GHL_LOCATION_ID="your-location-id" \
-- node /absolute/path/to/ghl-mcp/dist/index.js
Cursor / VS Code / Codex style config
{
"mcpServers": {
"gohighlevel": {
"command": "npx",
"args": ["-y", "ghl-mcp"],
"env": {
"GHL_API_TOKEN": "your-token-here",
"GHL_LOCATION_ID": "your-location-id"
}
}
}
}
MCP Inspector
npx @modelcontextprotocol/inspector node dist/index.js
Tool List
Contacts
search_contacts: Search contacts by text, tag, pagination, or advanced filtersget_contact: Retrieve one contact by IDcreate_contact: Create a contactupdate_contact: Update contact fieldsdelete_contact: Delete a contactadd_contact_tags: Add tags to a contactremove_contact_tags: Remove tags from a contactget_contact_notes: List notes for a contactcreate_contact_note: Create a note on a contact
Opportunities
search_opportunities: Search deals by query, pipeline, stage, status, contact, or ownerget_opportunity: Retrieve one opportunity by IDcreate_opportunity: Create an opportunityupdate_opportunity: Update opportunity fieldsdelete_opportunity: Delete an opportunityupdate_opportunity_status: Change status toopen,won,lost, orabandonedlist_pipelines: List pipelines and fetch their stages
Conversations
search_conversations: Search conversationsget_conversation: Retrieve one conversation by IDget_conversation_messages: List messages in a conversationsend_message: Send SMS, email, WhatsApp, or similar messagescreate_conversation: Start a new conversation
Calendars
list_calendars: List calendarslist_events: List events or appointmentscreate_event: Create an eventget_available_slots: Retrieve available booking slots
Workflows
list_workflows: List workflowstrigger_workflow: Trigger a workflow for a contact
Users
list_users: List users in the configured locationget_user: Retrieve one user by ID
Invoices And Payments
list_invoices: List invoicescreate_invoice: Create an invoicelist_transactions: List payment transactionslist_orders: List payment orderslist_subscriptions: List subscriptions
Social
list_social_posts: List social postscreate_social_post: Create or schedule a social postlist_social_accounts: List connected social accountsget_social_stats: Retrieve social statistics
Forms And Funnels
list_forms: List formslist_funnels: List funnelslist_funnel_pages: List funnel pages
Tasks
list_tasks: List tasks for a contactcreate_task: Create a task for a contact
Products
list_products: List productslist_product_prices: List prices for a product
Emails
list_email_templates: List email templateslist_email_schedules: List scheduled emails
Campaigns
list_campaigns: List campaigns
Documents
list_contracts: List contracts or documentssend_contract_link: Send a contract link for signing
Development
npm run dev
Build output goes to dist/.
Architecture
src/
├── index.ts
├── client.ts
├── types.ts
└── tools/
├── calendars.ts
├── campaigns.ts
├── contacts.ts
├── conversations.ts
├── documents.ts
├── emails.ts
├── forms.ts
├── invoices.ts
├── opportunities.ts
├── products.ts
├── social.ts
├── tasks.ts
├── users.ts
└── workflows.ts
Implementation Notes
- Most endpoints require
locationId. This server injects it automatically into request query strings and JSON bodies unless a value is already provided. - The client applies a minimum delay between requests to reduce the chance of hitting GoHighLevel's rate limits.
- Tool responses are returned as JSON text blocks with a short summary and the raw API payload.
- Pipeline listing fetches pipeline stage details for each returned pipeline so agents get usable stage metadata in one call.
Example Workflows
Find a contact and add a note
- Call
search_contactswithquery: "jane@company.com" - Call
get_contactwith the selectedcontactId - Call
create_contact_notewith thecontactIdand note text
Create and advance an opportunity
- Call
list_pipelinesto find the target pipeline and stage IDs - Call
create_opportunitywithcontactId,pipelineId,pipelineStageId, andname - Call
update_opportunityorupdate_opportunity_statusas the deal progresses
Book an appointment
- Call
get_available_slotswith acalendarIdand date range - Call
create_eventwith the selected time slot and optionalcontactId
Publishing
npm publish --access public
The published package installs the ghl-mcp binary from dist/index.js.
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.