Agent skill
hubspot
HubSpot CRM API for marketing and sales. Use when user mentions "HubSpot", "CRM", "HubSpot contacts", or asks about marketing automation.
Install this agent skill to your Project
npx add-skill https://github.com/vm0-ai/vm0-skills/tree/main/hubspot
SKILL.md
HubSpot CRM API
Manage contacts, companies, deals, tickets, and their associations with the HubSpot CRM API v3.
Official docs:
https://developers.hubspot.com/docs/api/overview
When to Use
- Create, update, and search contacts
- Manage companies, deals, and tickets
- Create associations between CRM objects
- Search and filter CRM records
- List pipeline stages for deals and tickets
Core APIs
List Contacts
curl -s "https://api.hubapi.com/crm/v3/objects/contacts?limit=10&properties=firstname,lastname,email" --header "Authorization: Bearer $(printenv HUBSPOT_TOKEN)" | jq '.results[] | {id, properties: {firstname: .properties.firstname, lastname: .properties.lastname, email: .properties.email}}'
Docs: https://developers.hubspot.com/docs/api/crm/contacts
Get Contact
Replace <contact-id> with the actual contact ID:
curl -s "https://api.hubapi.com/crm/v3/objects/contacts/<contact-id>?properties=firstname,lastname,email,phone,company" --header "Authorization: Bearer $(printenv HUBSPOT_TOKEN)" | jq '{id, properties}'
Create Contact
Write to /tmp/hubspot_request.json:
{
"properties": {
"firstname": "John",
"lastname": "Doe",
"email": "john.doe@example.com",
"phone": "+1-555-0100",
"company": "Acme Corp"
}
}
curl -s -X POST "https://api.hubapi.com/crm/v3/objects/contacts" --header "Authorization: Bearer $(printenv HUBSPOT_TOKEN)" --header "Content-Type: application/json" -d @/tmp/hubspot_request.json | jq '{id, properties: {firstname: .properties.firstname, lastname: .properties.lastname, email: .properties.email}}'
Docs: https://developers.hubspot.com/docs/api/crm/contacts
Update Contact
Replace <contact-id> with the actual contact ID.
Write to /tmp/hubspot_request.json:
{
"properties": {
"phone": "+1-555-0200",
"company": "New Corp"
}
}
curl -s -X PATCH "https://api.hubapi.com/crm/v3/objects/contacts/<contact-id>" --header "Authorization: Bearer $(printenv HUBSPOT_TOKEN)" --header "Content-Type: application/json" -d @/tmp/hubspot_request.json | jq '{id, properties}'
Search Contacts
Write to /tmp/hubspot_request.json:
{
"filterGroups": [
{
"filters": [
{
"propertyName": "email",
"operator": "CONTAINS_TOKEN",
"value": "example.com"
}
]
}
],
"properties": ["firstname", "lastname", "email"],
"limit": 10
}
curl -s -X POST "https://api.hubapi.com/crm/v3/objects/contacts/search" --header "Authorization: Bearer $(printenv HUBSPOT_TOKEN)" --header "Content-Type: application/json" -d @/tmp/hubspot_request.json | jq '.results[] | {id, properties}'
Docs: https://developers.hubspot.com/docs/api/crm/search
Delete Contact
Replace <contact-id> with the actual contact ID:
curl -s -X DELETE "https://api.hubapi.com/crm/v3/objects/contacts/<contact-id>" --header "Authorization: Bearer $(printenv HUBSPOT_TOKEN)" -w "\nHTTP Status: %{http_code}\n"
List Companies
curl -s "https://api.hubapi.com/crm/v3/objects/companies?limit=10&properties=name,domain,industry" --header "Authorization: Bearer $(printenv HUBSPOT_TOKEN)" | jq '.results[] | {id, properties: {name: .properties.name, domain: .properties.domain, industry: .properties.industry}}'
Create Company
Write to /tmp/hubspot_request.json:
{
"properties": {
"name": "Acme Corp",
"domain": "acme.com",
"industry": "Technology"
}
}
curl -s -X POST "https://api.hubapi.com/crm/v3/objects/companies" --header "Authorization: Bearer $(printenv HUBSPOT_TOKEN)" --header "Content-Type: application/json" -d @/tmp/hubspot_request.json | jq '{id, properties: {name: .properties.name, domain: .properties.domain}}'
List Deals
curl -s "https://api.hubapi.com/crm/v3/objects/deals?limit=10&properties=dealname,amount,dealstage,closedate" --header "Authorization: Bearer $(printenv HUBSPOT_TOKEN)" | jq '.results[] | {id, properties: {dealname: .properties.dealname, amount: .properties.amount, dealstage: .properties.dealstage}}'
Create Deal
Write to /tmp/hubspot_request.json:
{
"properties": {
"dealname": "Enterprise License",
"amount": "50000",
"dealstage": "appointmentscheduled",
"pipeline": "default"
}
}
curl -s -X POST "https://api.hubapi.com/crm/v3/objects/deals" --header "Authorization: Bearer $(printenv HUBSPOT_TOKEN)" --header "Content-Type: application/json" -d @/tmp/hubspot_request.json | jq '{id, properties: {dealname: .properties.dealname, amount: .properties.amount, dealstage: .properties.dealstage}}'
List Tickets
curl -s "https://api.hubapi.com/crm/v3/objects/tickets?limit=10&properties=subject,content,hs_pipeline_stage" --header "Authorization: Bearer $(printenv HUBSPOT_TOKEN)" | jq '.results[] | {id, properties: {subject: .properties.subject, stage: .properties.hs_pipeline_stage}}'
Create Ticket
Write to /tmp/hubspot_request.json:
{
"properties": {
"subject": "Login issue",
"content": "User cannot log in after password reset",
"hs_pipeline": "0",
"hs_pipeline_stage": "1"
}
}
curl -s -X POST "https://api.hubapi.com/crm/v3/objects/tickets" --header "Authorization: Bearer $(printenv HUBSPOT_TOKEN)" --header "Content-Type: application/json" -d @/tmp/hubspot_request.json | jq '{id, properties: {subject: .properties.subject}}'
Get Deal Pipelines
curl -s "https://api.hubapi.com/crm/v3/pipelines/deals" --header "Authorization: Bearer $(printenv HUBSPOT_TOKEN)" | jq '.results[] | {id, label, stages: [.stages[] | {id, label, displayOrder}]}'
Get Ticket Pipelines
curl -s "https://api.hubapi.com/crm/v3/pipelines/tickets" --header "Authorization: Bearer $(printenv HUBSPOT_TOKEN)" | jq '.results[] | {id, label, stages: [.stages[] | {id, label}]}'
Create Association
Associate a contact with a company. Replace <contact-id> and <company-id>:
Write to /tmp/hubspot_request.json:
[
{
"associationCategory": "HUBSPOT_DEFINED",
"associationTypeId": 1
}
]
curl -s -X PUT "https://api.hubapi.com/crm/v4/objects/contacts/<contact-id>/associations/companies/<company-id>" --header "Authorization: Bearer $(printenv HUBSPOT_TOKEN)" --header "Content-Type: application/json" -d @/tmp/hubspot_request.json | jq '{fromObjectTypeId, fromObjectId, toObjectTypeId, toObjectId}'
Common association type IDs: 1 (contact→company), 3 (deal→contact), 5 (deal→company)
Get Account Info
curl -s "https://api.hubapi.com/account-info/v3/details" --header "Authorization: Bearer $(printenv HUBSPOT_TOKEN)" | jq '{portalId, accountType, timeZone, companyCurrency}'
Guidelines
- CRM object types: contacts, companies, deals, tickets, line_items, quotes — all follow the same CRUD pattern at
/crm/v3/objects/{objectType} - Properties: Always specify
propertiesquery param to control which fields are returned - Search operators: EQ, NEQ, LT, LTE, GT, GTE, CONTAINS_TOKEN, NOT_CONTAINS_TOKEN, HAS_PROPERTY, NOT_HAS_PROPERTY
- Pagination: Use
aftercursor from responsepaging.next.afterfor next page - Rate limits: 100 requests per 10 seconds for OAuth apps
Didn't find tool you were looking for?