A Model Context Protocol (MCP) server implementation for the HubSpot API, providing a standardized interface for accessing and managing CRM data.
- 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
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.
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.
If you are developing your own agent application, you can use the boilerplate code here.
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"
}
}
}
}
- Download the repo:
git clone https://github.com/shinzo-labs/hubspot-mcp.git
- Install packages (inside cloned repo):
pnpm i
- 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"
}
}
}
}
Variable | Description | Required? | Default |
---|---|---|---|
HUBSPOT_ACCESS_TOKEN |
Access Token for Hubspot Application | Yes | |
PORT |
Port for Streamable HTTP transport method | No | 3000 |
TELEMETRY_ENABLED |
Enable telemetry | No | true |
-
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_archive_object
: Archive (delete) a CRM object -
crm_search_objects
: Search CRM objects using advanced filters -
crm_batch_create_objects
: Create multiple objects in a single request -
crm_batch_read_objects
: Read multipl objects in a single request -
crm_batch_update_objects
: Update multiple objects in a single request -
crm_batch_archive_objects
: Archive (delete) multiple objects in a single request
-
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 -
crm_batch_create_companies
: Create multiple companies in a single request -
crm_batch_update_companies
: Update multiple companies in a single request -
crm_get_company_properties
: Get all available company properties -
crm_create_company_property
: Create a new company property
-
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 -
crm_batch_create_contacts
: Create multiple contacts in a single request -
crm_batch_update_contacts
: Update multiple contacts in a single request -
crm_get_contact_properties
: Get all available contact properties -
crm_create_contact_property
: Create a new contact property
-
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 -
crm_batch_create_leads
: Create multiple leads in a single request -
crm_batch_update_leads
: Update multiple leads in a single request -
crm_get_lead_properties
: Get all available lead properties -
crm_create_lead_property
: Create a new lead property
-
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_archive
: Archive (delete) an engagement -
engagement_details_list
: List all engagements with filtering -
engagement_details_get_associated
: Get associated engagements
-
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 -
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_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 -
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_create
: Create a new meeting -
meetings_get
: Get meeting details -
meetings_update
: Update a meeting -
meetings_archive
: Archive (delete) a meeting -
meetings_list
: List all meetings -
meetings_search
: Search meetings -
meetings_batch_create
: Create multiple meetings -
meetings_batch_update
: Update multiple meetings -
meetings_batch_archive
: Archive multiple meetings
-
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 -
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_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 -
tasks_batch_create
: Create multiple tasks -
tasks_batch_read
: Read multiple tasks -
tasks_batch_update
: Update multiple tasks -
tasks_batch_archive
: Archive multiple tasks
-
crm_list_association_types
: List available association types -
crm_get_associations
: Get all associations between objects -
crm_create_association
: Create an association -
crm_archive_association
: Archive (delete) an association -
crm_batch_create_associations
: Create multiple associations -
crm_batch_archive_associations
: Archive (delete) multiple associations
-
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 -
communications_get_subscription_status
: Get status for multiple contacts -
communications_update_subscription_status
: Update status for multiple contacts
-
products_create
: Create a product with the given properties and return a copy of the object, including the ID. -
products_read
: Read an Object identified by ID -
products_update
: Perform a partial update of an Object identified by ID. Read-only and non-existent properties will result in an error. Properties values can be cleared by passing an empty string. -
products_archive
: Move an Object identified by ID to the recycling bin. -
products_list
: Read a page of products. Control what is returned via theproperties
query param.after
is the paging cursor token of the last successfully read resource will be returned as thepaging.next.after
JSON property of a paged response containing more results. -
products_search
: Search products -
products_batch_create
: Create a batch of products -
products_batch_read
: Read a batch of products by internal ID, or unique property values. Retrieve records by theidProperty
parameter to retrieve records by a custom unique value property. -
products_batch_update
: Update a batch of products by internal ID, or unique values specified by theidProperty
query param. -
products_batch_archive
: Archive a batch of products by ID
Contributions are welcomed and encouraged! Please read CONTRIBUTING.md for guidelines on issues, contributions, and contact information.
Shinzo Labs collects limited anonymous telemetry from this server to help improve our products and services. No personally identifiable information is collected as part of this process. Please review the Privacy Policy for more details on the types of data collected and how to opt-out of this telemetry.
MIT