POST request to your specified endpoint whenever subscribed events occur. Your application receives the event payload, processes it, and returns a 2xx status code to acknowledge receipt.
When to use webhooks
Use webhooks when you need to:- Sync data in real-time between HubSpot and external systems (e.g., updating a contact in your database when they’re modified in HubSpot).
- Trigger automated workflows based on HubSpot events (e.g., sending a Slack notification when a deal closes).
- Monitor specific changes without constant API polling (e.g., tracking when contacts unsubscribe from emails).
Project structure
To define a set of webhook subscriptions for an app, create awebhooks directory within src/app/. Then, add a configuration file to that directory using the naming convention *-hsmeta.json.
Webhook configuration
Below are the available configuration options for the*-hsmeta.json file.
Fields marked with * are required.
| Field | Type | Description |
|---|---|---|
uid* | String | An internal unique identifier for the webhook component. |
type* | String | The type of component, which should be webhooks in this case. |
settings* | Object | An object that specifies two fields: targetUrl, which is the publicly available URL for HubSpot to call where event payloads will be delivered, and maxConcurrentRequests, which is the upper threshold of HTTP requests that HubSpot will make in a given time frame. |
subscriptions* | Object | An object that specifies the subscription types your app will subscribe to. |
crmObjects | Array | An array containing event subscription definitions. This is the standard array to include, and should be used for all events in the new format ( Classic webhook subscription types should instead be included in |
legacyCrmObjects | Array | An array containing classic subscription types, such as contact.creation and deal.deletion. |
hubEvents | Array | An array containing the classic subscription types contact.privacyDeletion and conversation.* |
subscription object, the following fields can be specified, based on the subscription definition type you’re subscribed to (i.e., crmObjects, legacyCrmObjects, or hubEvents) or whether you’re subscribing to a specific property change (e.g., contact.propertyChange).
| Field | Type | Description |
|---|---|---|
subscriptionType | String | The type of event being subscribed to. |
objectType | String | For subscriptions specified within the crmObjects array, this specifies the CRM object your app is subscribing to. |
propertyName | String | For property change subscriptions, this specifies which property will trigger the webhook event. |
active | Boolean | Whether webhook events will be triggered for this subscription. |