ghl-mcp

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.

Category
Visit Server

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/sdk v1.x
  • Strict TypeScript configuration
  • Zod-validated tool inputs with descriptions on every field
  • Automatic locationId injection 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 token
  • GHL_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 add registers 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 filters
  • get_contact: Retrieve one contact by ID
  • create_contact: Create a contact
  • update_contact: Update contact fields
  • delete_contact: Delete a contact
  • add_contact_tags: Add tags to a contact
  • remove_contact_tags: Remove tags from a contact
  • get_contact_notes: List notes for a contact
  • create_contact_note: Create a note on a contact

Opportunities

  • search_opportunities: Search deals by query, pipeline, stage, status, contact, or owner
  • get_opportunity: Retrieve one opportunity by ID
  • create_opportunity: Create an opportunity
  • update_opportunity: Update opportunity fields
  • delete_opportunity: Delete an opportunity
  • update_opportunity_status: Change status to open, won, lost, or abandoned
  • list_pipelines: List pipelines and fetch their stages

Conversations

  • search_conversations: Search conversations
  • get_conversation: Retrieve one conversation by ID
  • get_conversation_messages: List messages in a conversation
  • send_message: Send SMS, email, WhatsApp, or similar messages
  • create_conversation: Start a new conversation

Calendars

  • list_calendars: List calendars
  • list_events: List events or appointments
  • create_event: Create an event
  • get_available_slots: Retrieve available booking slots

Workflows

  • list_workflows: List workflows
  • trigger_workflow: Trigger a workflow for a contact

Users

  • list_users: List users in the configured location
  • get_user: Retrieve one user by ID

Invoices And Payments

  • list_invoices: List invoices
  • create_invoice: Create an invoice
  • list_transactions: List payment transactions
  • list_orders: List payment orders
  • list_subscriptions: List subscriptions

Social

  • list_social_posts: List social posts
  • create_social_post: Create or schedule a social post
  • list_social_accounts: List connected social accounts
  • get_social_stats: Retrieve social statistics

Forms And Funnels

  • list_forms: List forms
  • list_funnels: List funnels
  • list_funnel_pages: List funnel pages

Tasks

  • list_tasks: List tasks for a contact
  • create_task: Create a task for a contact

Products

  • list_products: List products
  • list_product_prices: List prices for a product

Emails

  • list_email_templates: List email templates
  • list_email_schedules: List scheduled emails

Campaigns

  • list_campaigns: List campaigns

Documents

  • list_contracts: List contracts or documents
  • send_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

  1. Call search_contacts with query: "jane@company.com"
  2. Call get_contact with the selected contactId
  3. Call create_contact_note with the contactId and note text

Create and advance an opportunity

  1. Call list_pipelines to find the target pipeline and stage IDs
  2. Call create_opportunity with contactId, pipelineId, pipelineStageId, and name
  3. Call update_opportunity or update_opportunity_status as the deal progresses

Book an appointment

  1. Call get_available_slots with a calendarId and date range
  2. Call create_event with the selected time slot and optional contactId

Publishing

npm publish --access public

The published package installs the ghl-mcp binary from dist/index.js.

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured