HubSpot MCP

Integrations

  • Provides a standardized interface for accessing and managing HubSpot CRM data, including operations for companies, contacts, deals, tickets, and other CRM objects. Supports advanced association management, batch operations, search functionality, and property validation for efficient CRM data management.

  • Leverages Zod for type-safe parameter validation across all HubSpot API operations, ensuring data integrity when working with CRM objects and their properties.

HubSpot MCP

A Model Context Protocol (MCP) implementation for the HubSpot API, providing a standardized interface for accessing and managing CRM data.

Features

  • Complete coverage of the HubSpot CRM API
  • Support for all standard CRM objects (companies, contacts, deals, etc.)
  • Advanced association management with CRM Associations v4
  • Company-specific endpoints with property validation
  • Batch operations for efficient data management
  • Advanced search and filtering capabilities
  • Type-safe parameter validation with Zod

Prerequisites

If you don't have an API key, follow the steps here to obtain an access token. OAuth support is planned as a future enhancement.

Client Configuration

There are several options to configure your MCP client with the server. For hosted/remote server setup, use Smithery's CLI with a Smithery API Key. For local installation, use npx or build from source. Each of these options is explained below.

To add a remote server to your MCP client config.json, run the following command from Smithery CLI:

npx -y @smithery/cli install @shinzo-labs/hubspot-mcp

Enter your HUBSPOT_ACCESS_TOKEN when prompted.

Smithery SDK

If you are developing your own agent application, you can use the boilerplate code here.

NPX Local Install

To install the server locally with npx, add the following to your MCP client config.json:

{ "mcpServers": { "hubspot": { "command": "npx", "args": [ "@shinzolabs/hubspot-mcp" ], "env": { "HUBSPOT_ACCESS_TOKEN": "your-access-token-here" } } } }

Build from Source

  1. Download the repo:
git clone https://github.com/shinzo-labs/hubspot-mcp.git
  1. Install packages (inside cloned repo):
pnpm i
  1. Add the following to your MCP client config.json:
{ "mcpServers": { "hubspot": { "command": "node", "args": [ "/path/to/hubspot-mcp/index.js" ], "env": { "HUBSPOT_ACCESS_TOKEN": "your-access-token-here" } } } }

Config Variables

VariableDescriptionRequired?Default
HUBSPOT_ACCESS_TOKENAccess Token for Hubspot ApplicationYes
PORT Port for Streamable HTTP transport methodNo3000

Supported Tools

Core CRM Objects

Basic Object Operations
  • crm_list_objects: List CRM objects with optional filtering and pagination
  • crm_get_object: Get a single CRM object by ID
  • crm_create_object: Create a new CRM object
  • crm_update_object: Update an existing CRM object
  • crm_delete_object: Delete a CRM object
Search and Batch Operations
  • crm_search_objects: Search CRM objects using advanced filters
  • crm_batch_create_objects: Create multiple objects in a single request
  • crm_batch_update_objects: Update multiple objects in a single request
  • crm_batch_delete_objects: Delete multiple objects in a single request

CRM Records Management

Companies
  • Basic Operations:
    • crm_create_company: Create a new company with validated properties
    • crm_update_company: Update an existing company
    • crm_get_company: Get a single company by ID
    • crm_search_companies: Search companies with specific filters
  • Batch Operations:
    • crm_batch_create_companies: Create multiple companies in a single request
    • crm_batch_update_companies: Update multiple companies in a single request
  • Property Management:
    • crm_get_company_properties: Get all available company properties
    • crm_create_company_property: Create a new company property
Contacts
  • Basic Operations:
    • crm_create_contact: Create a new contact with validated properties
    • crm_update_contact: Update an existing contact's information
    • crm_get_contact: Get a single contact by ID
    • crm_search_contacts: Search contacts with specific filters
  • Batch Operations:
    • crm_batch_create_contacts: Create multiple contacts in a single request
    • crm_batch_update_contacts: Update multiple contacts in a single request
  • Property Management:
    • crm_get_contact_properties: Get all available contact properties
    • crm_create_contact_property: Create a new contact property
Leads
  • Basic Operations:
    • crm_create_lead: Create a new lead with validated properties
    • crm_update_lead: Update an existing lead's information
    • crm_get_lead: Get a single lead by ID
    • crm_search_leads: Search leads with specific filters
  • Batch Operations:
    • crm_batch_create_leads: Create multiple leads in a single request
    • crm_batch_update_leads: Update multiple leads in a single request
  • Property Management:
    • crm_get_lead_properties: Get all available lead properties
    • crm_create_lead_property: Create a new lead property

Engagement Management

Engagement Details
  • Basic Operations:
    • engagement_details_get: Get details of a specific engagement
    • engagement_details_create: Create a new engagement
    • engagement_details_update: Update an existing engagement
    • engagement_details_delete: Delete an engagement
    • engagement_details_list: List all engagements with filtering
    • engagement_details_get_associated: Get associated engagements
Calls
  • Basic Operations:
    • calls_create: Create a new call record
    • calls_get: Get call details
    • calls_update: Update a call record
    • calls_archive: Archive a call
    • calls_list: List all calls
    • calls_search: Search calls
  • Batch Operations:
    • calls_batch_create: Create multiple calls
    • calls_batch_read: Read multiple calls
    • calls_batch_update: Update multiple calls
    • calls_batch_archive: Archive multiple calls
Emails
  • Basic Operations:
    • emails_create: Create a new email record
    • emails_get: Get email details
    • emails_update: Update an email
    • emails_archive: Archive an email
    • emails_list: List all emails
    • emails_search: Search emails
  • Batch Operations:
    • emails_batch_create: Create multiple emails
    • emails_batch_read: Read multiple emails
    • emails_batch_update: Update multiple emails
    • emails_batch_archive: Archive multiple emails
Meetings
  • Basic Operations:
    • meetings_create: Create a new meeting
    • meetings_get: Get meeting details
    • meetings_update: Update a meeting
    • meetings_delete: Delete a meeting
    • meetings_list: List all meetings
    • meetings_search: Search meetings
  • Batch Operations:
    • meetings_batch_create: Create multiple meetings
    • meetings_batch_update: Update multiple meetings
    • meetings_batch_archive: Archive multiple meetings
Notes
  • Basic Operations:
    • notes_create: Create a new note
    • notes_get: Get note details
    • notes_update: Update a note
    • notes_archive: Archive a note
    • notes_list: List all notes
    • notes_search: Search notes
  • Batch Operations:
    • notes_batch_create: Create multiple notes
    • notes_batch_read: Read multiple notes
    • notes_batch_update: Update multiple notes
    • notes_batch_archive: Archive multiple notes
Tasks
  • Basic Operations:
    • tasks_create: Create a new task
    • tasks_get: Get task details
    • tasks_update: Update a task
    • tasks_archive: Archive a task
    • tasks_list: List all tasks
    • tasks_search: Search tasks
  • Batch Operations:
    • tasks_batch_create: Create multiple tasks
    • tasks_batch_read: Read multiple tasks
    • tasks_batch_update: Update multiple tasks
    • tasks_batch_archive: Archive multiple tasks

Associations and Relationships

CRM Associations v4
  • Basic Operations:
    • crm_list_association_types: List available association types
    • crm_get_associations: Get all associations between objects
    • crm_create_association: Create an association
    • crm_delete_association: Delete an association
  • Batch Operations:
    • crm_batch_create_associations: Create multiple associations
    • crm_batch_delete_associations: Delete multiple associations

Communication Preferences

Subscription Management
  • Basic Operations:
    • communications_get_preferences: Get contact preferences
    • communications_update_preferences: Update contact preferences
    • communications_unsubscribe_contact: Global unsubscribe
    • communications_subscribe_contact: Global subscribe
    • communications_get_subscription_definitions: Get subscription definitions
  • Bulk Operations:
    • communications_get_subscription_status: Get status for multiple contacts
    • communications_update_subscription_status: Update status for multiple contacts

Contributing

Contributions are welcomed and encouraged! Please read CONTRIBUTING.md for guidelines on issues, contributions, and contact information.

You must be authenticated.

A
security – no known vulnerabilities
A
license - permissive license
A
quality - confirmed to work

hybrid server

The server is able to function both locally and remotely, depending on the configuration or use case.

Access and manage your CRM data seamlessly with 100+ tools in our HubSpot MCP implementation including manipulation of Contacts, Companies, and Associations.

  1. Features
    1. Prerequisites
      1. Client Configuration
        1. Smithery Remote Server (Recommended)
        2. Smithery SDK
        3. NPX Local Install
        4. Build from Source
      2. Config Variables
        1. Supported Tools
          1. Core CRM Objects
          2. CRM Records Management
          3. Engagement Management
          4. Associations and Relationships
          5. Communication Preferences
        2. Contributing

          Related MCP Servers

          • A
            security
            A
            license
            A
            quality
            Enables AI models to interact with HubSpot CRM data and operations through a standardized interface, supporting contact and company management.
            Last updated -
            5
            56
            Python
            MIT License
            • Linux
          • A
            security
            A
            license
            A
            quality
            A central hub that aggregates multiple MCP resource servers into a single unified interface, enabling users to access tools and capabilities from multiple backend servers through one connection point.
            Last updated -
            30
            TypeScript
            MIT License
            • Apple
          • -
            security
            A
            license
            -
            quality
            A server that enables AI models to interact with HubSpot CRM data and operations through a standardized interface, supporting contact and company management with multi-user token-based authentication.
            Last updated -
            Python
            MIT License
            • Linux
          • -
            security
            A
            license
            -
            quality
            A Model Context Protocol server that provides tools for interacting with HubSpot CRM, allowing users to create, update, delete, and fetch summary records stored as Note engagements in HubSpot.
            Last updated -
            JavaScript
            MIT License

          View all related MCP servers

          ID: rvn6na254i