Last modified: September 3, 2025
To send a series of targeted, timed email templates to nurture contacts over time, you can create a sequence. You can use the sequences tool to automatically create tasks to remind you to follow up with your contacts.
To use this API, the user must have an assigned Sales Hub Professional or Enterprise or Service Hub Professional or Enterprise seat.
With the sequences API, you can:
- Get a list of sequences
- Get a specific sequence
- Enroll a contact in a sequence
- View a contact’s enrollment status
- Get a list of sequences
- Enroll a contact in a sequence
- Review the enrollment status
Fetch a sequence
To get details about a specific sequence in your account, make aGET
request to /automation/v4/sequences/{sequenceId}?userId={userId}
, where the sequenceId is the ID of an existing sequence in your account.
For example, to get details about a sequence that ID is 123456789
and your user ID is 2222222
, make a GET
request to /automation/v4/sequences/123456789?userId=2222222
. Use the ID of the specific sequence as the sequenceId in the request URL and use your userId as a query parameter.
The response for fetching a sequence would resemble the following:
Please note:If you’ve enrolled into the Sequences unenrollment configuration beta, when retrieving a specific sequence, the
"sellingStrategy": "LEAD_BASED"
value may not actually match the sequence. This is expected behavior.Field | Type | Description |
---|---|---|
id | String | The sequence ID. |
name | String | The name of the sequence. |
steps | Array | The list of steps in your sequence. Each step is an object that includes details like the type, priority, and creation details. |
List sequences
To get details about a specific sequence in your account, make aGET
request to /automation/v4/sequences/?limit=#&userId={userId}
. Use the amount of sequences you want returned as the limit in the request URL and use your userID as a query parameter.
For example, to get a list of four sequences and your user ID is 2222222
, make a GET
request to /automation/v4/sequences?limit=4&userId=2222222
.
The response for fetching a list of sequences would resemble the following:
Field | Type | Description |
---|---|---|
total | String | The number of sequences in your account. |
id | String | The sequence ID. |
name | String | The name of the sequence. |
createdAt | String | The time the sequence was created in UTC format. |
updatedAt | String | The time the sequence was last updated in UTC format. |
userID | String | The userID of the user who created the sequence. |
Enroll a contact in a sequence
To enroll a contact in a sequence, make aPOST
request to /automation/v4/sequences/enrollments/
. Use your user ID as the query parameter. Specify the sequenceId, contactId, and senderEmail in the body. The senderEmail must be an email address that’s connected to your HubSpot account.
For example, to enroll a contact whose ID is 33333
in sequence that’s ID is 44444444
, you’d make a POST
request to /automation/v4/sequences/enrollments
.
The body would resemble the following:
Field | Type | Description |
---|---|---|
id | String | The ID for the enrollment object. |
toEmail | String | The email of the contact |
enrolledAt | String | The time the contact was enrolled in the sequence in UTC format. |
updatedAt | String | The last time the enrollment was updated (paused, unpaused, etc.) |
Please note:There is a limit of 1000 enrollments per portal inbox per day.
View a contact’s sequence enrollment status
A contact’s enrollment status will indicate if the contact is enrolled in any sequences at the time of the request. To get a contact’s enrollment status, make aGET
request to /automation/v4/sequences/enrollments/contact/{contactId}
.
For example, to view the enrollment status of a contact whose contact ID is 33333
, make a GET
request to /automation/v4/sequences/enrollments/contact/33333
. Use the contact ID as the query parameter.
The response for viewing a contact’s sequence enrollment status would resemble the following:
Field | Type | Description |
---|---|---|
id | String | The ID for the enrollment object. |
toEmail | String | The email of the contact |
enrolledAt | String | The time the contact was enrolled in the sequence in UTC format. |
updatedAt | String | The last time the enrollment was updated (paused, unpaused, etc.) |
sequenceID | String | The ID of the sequence the contact is enrolled in. |
sequenceName | String | The title of the sequence the contact is enrolled in. |
enrolledBy | String | The userId of the user who enrolled the contact in the sequence. |
enrolledByEmail | String | The email of the user who enrolled the contact in the sequence or the email address that email messages are sent from. |