basicmachines-co
MCP Serverbasicmachines-copublic

open ghl mcp

An open source Model Context Protocol server for GoHighLevel API v2 with OAuth

Repository Info

29
Stars
16
Forks
29
Watchers
3
Issues
Python
Language
GNU Affero General Public License v3.0
License

About This Server

An open source Model Context Protocol server for GoHighLevel API v2 with OAuth

Model Context Protocol (MCP) - This server can be integrated with AI applications to provide additional context and capabilities, enabling enhanced AI interactions and functionality.

Documentation

Automated Tests

GoHighLevel MCP Server

A Model Context Protocol (MCP) server that provides seamless integration with the GoHighLevel API v2. This server enables AI assistants to interact with GoHighLevel's CRM functionality, starting with comprehensive contact management.

Features

  • 🔐 OAuth 2.0 Authentication: Full OAuth flow with automatic token management by default
  • 🏢 Multi-location Support: Works with agency accounts to manage multiple sub-accounts
  • 👥 Contact Management: Complete CRUD operations for contacts
  • 💬 Conversations: Search conversations, view messages, and manage messaging
  • 📝 Forms & Submissions: List forms, view submissions, test form submissions like a website visitor
  • 🏷️ Tag Management: Add and remove tags from contacts
  • 🔄 Automatic Token Refresh: Handles token expiration seamlessly
  • 🛠️ MCP Tools & Resources: Both tools and resources for flexible integration

Prerequisites

  • Python 3.12+
  • uv package manager (or pip)
  • One of the following:
    • Standard Mode Configuration: Access via our hosted GoHighLevel app (coming soon)
    • Custom Mode Configuration: Your own GoHighLevel Marketplace App credentials

Getting Started - Installation

  1. Clone the repository:
git clone https://github.com/basicmachines-co/open-ghl-mcp.git
cd open-ghl-mcp
  1. Install dependencies:
uv venv
source .venv/bin/activate
uv pip install -r requirements.txt
  1. Start the server:
python -m src.main

1. Configuration

Use your own GoHighLevel Marketplace App:

  1. Create your own GoHighLevel Marketplace App
  2. Set the redirect URL to: http://localhost:8080/oauth/callback
  3. Set the permissions you want for the tools and resources below

2. Usage

Running the MCP Server

  1. Start the server:
python -m src.main
  1. Complete the setup wizard.

  2. Configure your LLM to use the MCP server

First-time Authentication

Custom Mode Setup

  1. The server will ask you for your GHL Marketplace App Client ID and Secret
  2. Install your App to generate an OAuth Token

API Reference

This MCP server provides comprehensive access to GoHighLevel API v2 through both Tools (for actions) and Resources (for data browsing). All endpoints are fully tested and validated.

🛠️ MCP Tools (Actions)

👥 Contact Management

ToolGoHighLevel EndpointDescription
create_contactPOST /contactsCreate a new contact
update_contactPUT /contacts/{id}Update existing contact
delete_contactDELETE /contacts/{id}Delete a contact
get_contactGET /contacts/{id}Get a single contact
search_contactsGET /contactsSearch contacts with filters
add_contact_tagsPOST /contacts/{id}/tagsAdd tags to a contact
remove_contact_tagsDELETE /contacts/{id}/tagsRemove tags from a contact

💬 Conversations & Messaging

ToolGoHighLevel EndpointDescription
get_conversationsGET /conversations/searchSearch and list conversations
get_conversationGET /conversations/{id}Get a single conversation
get_messagesGET /conversations/{id}/messagesGet messages from a conversation
send_messagePOST /conversations/{id}/messagesSend messages (SMS ✅, Email ✅, WhatsApp, IG, FB, Custom, Live_Chat)
update_message_statusPUT /conversations/messages/{messageId}/statusUpdate message delivery status

🎯 Opportunities & Sales Pipeline

ToolGoHighLevel EndpointDescription
get_opportunitiesGET /opportunities/searchSearch opportunities with filters
get_opportunityGET /opportunities/{id}Get a single opportunity
create_opportunityPOST /opportunitiesCreate new opportunity
update_opportunityPUT /opportunities/{id}Update existing opportunity
delete_opportunityDELETE /opportunities/{id}Delete opportunity
update_opportunity_statusPUT /opportunities/{id}/statusUpdate opportunity status
get_pipelinesGET /opportunities/pipelinesList all pipelines

📅 Calendar & Appointments

ToolGoHighLevel EndpointDescription
get_calendarsGET /calendars/?locationId={id}List all calendars for location
get_calendarGET /calendars/{id}Get calendar details (54+ fields)
get_appointmentsGET /contacts/{contactId}/appointmentsGet appointments for contact
get_free_slotsGET /calendars/{id}/free-slotsGet available time slots

📝 Forms & Submissions

ToolGoHighLevel EndpointDescription
get_formsGET /formsList all forms (basic info: id, name, locationId)
get_all_form_submissionsGET /forms/submissionsGet all submissions with filtering
upload_form_filePOST /forms/upload-custom-filesUpload file to custom field

Note: Limited API support for forms. The following are NOT available:

  • GET /forms/{id} (401 "Route not supported")
  • GET /forms/{id}/submissions (404 Not Found)
  • POST /forms/submit (401 Unauthorized)

📖 MCP Resources (Data Browsing)

👥 Contact Resources

Resource URIGoHighLevel EndpointDescription
contacts://{location_id}GET /contactsBrowse all contacts for location
contact://{location_id}/{contact_id}GET /contacts/{id}View single contact details

💬 Conversation Resources

Resource URIGoHighLevel EndpointDescription
conversations://{location_id}GET /conversations/searchBrowse all conversations for location
conversation://{location_id}/{conversation_id}GET /conversations/{id}View conversation with messages

🎯 Opportunity Resources

Resource URIGoHighLevel EndpointDescription
opportunities://{location_id}GET /opportunities/searchBrowse all opportunities for location
opportunity://{location_id}/{opportunity_id}GET /opportunities/{id}View single opportunity details
pipelines://{location_id}GET /opportunities/pipelinesBrowse all pipelines with stages

📅 Calendar Resources

Resource URIGoHighLevel EndpointDescription
calendars://{location_id}GET /calendars/Browse all calendars for location
calendar://{location_id}/{calendar_id}GET /calendars/{id}View calendar details
appointments://{location_id}/{contact_id}GET /contacts/{id}/appointmentsBrowse appointments for contact

🔐 Authentication Requirements

All endpoints require proper authentication:

  • Company Token: Used for location token exchange
  • Location Token: Required for all location-specific operations (expires every 24 hours)
  • Automatic Refresh: The MCP server handles token refresh automatically

📋 Example Usage

# Get all contacts for your location
contacts://YOUR_LOCATION_ID

# Get specific contact details
contact://YOUR_LOCATION_ID/YOUR_CONTACT_ID

# Browse appointments for a contact
appointments://YOUR_LOCATION_ID/YOUR_CONTACT_ID

# Browse opportunities for your location
opportunities://YOUR_LOCATION_ID

# View conversation details
conversation://YOUR_LOCATION_ID/YOUR_CONVERSATION_ID

Development

Testing

For local testing with real GoHighLevel accounts, you'll need:

  • A GoHighLevel account with API access
  • At least one sub-account (location) for testing
  • Test contacts and data in your GoHighLevel instance

Create your own testing guidelines and keep sensitive data like location IDs and contact IDs in local files that are not committed to the repository.

Running Tests

# Run all tests
uv run pytest

# Run tests with coverage report
uv run pytest --cov=src --cov-report=term-missing

# Run specific test file
uv run pytest tests/test_api_client.py -v

Code Quality

This project uses automated code quality tools. Before committing changes:

# Format code with Black
uv run black src/ tests/

# Check linting with flake8
uv run flake8 src/ tests/

# Run type checking with mypy
uv run mypy src/ --ignore-missing-imports

# Run all checks at once
uv run black src/ tests/ && uv run flake8 src/ tests/ && uv run mypy src/ --ignore-missing-imports

Pre-commit Hook (optional)

To automatically format code before commits:

# Create a git pre-commit hook
echo '#!/bin/sh
uv run black src/ tests/
uv run flake8 src/ tests/
' > .git/hooks/pre-commit
chmod +x .git/hooks/pre-commit

Continuous Integration

The project uses GitHub Actions for CI/CD:

  • Tests run automatically on all pushes and pull requests
  • Tested with Python 3.12 and 3.13
  • Includes linting, type checking, and test coverage
  • Coverage reports are uploaded to Codecov (if configured)

Architecture

The server follows a modular architecture:

  • OAuth Service: Handles authentication and token management
  • API Client: Manages communication with GoHighLevel API
  • MCP Server: FastMCP-based server exposing tools and resources
  • Data Models: Pydantic models for data validation

License

This project is licensed under the GNU Affero General Public License v3.0 - see the LICENSE file for details.

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

Support

For issues and feature requests, please use the GitHub issues tracker.

Quick Start

1

Clone the repository

git clone https://github.com/basicmachines-co/open-ghl-mcp
2

Install dependencies

cd open-ghl-mcp
npm install
3

Follow the documentation

Check the repository's README.md file for specific installation and usage instructions.

Repository Details

Ownerbasicmachines-co
Repoopen-ghl-mcp
LanguagePython
LicenseGNU Affero General Public License v3.0
Last fetched8/10/2025

Recommended MCP Servers

💬

Discord MCP

Enable AI assistants to seamlessly interact with Discord servers, channels, and messages.

integrationsdiscordchat
🔗

Knit MCP

Connect AI agents to 200+ SaaS applications and automate workflows.

integrationsautomationsaas
🕷️

Apify MCP Server

Deploy and interact with Apify actors for web scraping and data extraction.

apifycrawlerdata
🌐

BrowserStack MCP

BrowserStack MCP Server for automated testing across multiple browsers.

testingqabrowsers

Zapier MCP

A Zapier server that provides automation capabilities for various apps.

zapierautomation