ghl-mcp
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@ghl-mcpsearch for contacts with tag 'lead'"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
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.xStrict TypeScript configuration
Zod-validated tool inputs with descriptions on every field
Automatic
locationIdinjection from environment variablesBasic 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.jsRun with npx
npx -y ghl-mcpConfiguration
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-28MCP 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.jsCursor / 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.jsTool 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 devBuild 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.tsImplementation 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 selectedcontactIdCall
create_contact_notewith thecontactIdand note text
Create and advance an opportunity
Call
list_pipelinesto find the target pipeline and stage IDsCall
create_opportunitywithcontactId,pipelineId,pipelineStageId, andnameCall
update_opportunityorupdate_opportunity_statusas the deal progresses
Book an appointment
Call
get_available_slotswith acalendarIdand date rangeCall
create_eventwith the selected time slot and optionalcontactId
Publishing
npm publish --access publicThe published package installs the ghl-mcp binary from dist/index.js.
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/Snack-JPG/ghl-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server