HubSpot Module Basics - Steps
  • 18 Jun 2021
  • 6 Minutes to read
  • Dark
    Light
  This documentation version is deprecated, please click here for the latest version.

HubSpot Module Basics - Steps

  • Dark
    Light

Article summary

Overview

The HubSpot Module in Decisions allows users to access and update HubSpot data using steps in a Flow that hides the complexities of working with the HubSpot API directly. Before using these steps, install the HubSpot Module and set up an Authentication Token. Instructions on how to do that are listed here: HubSpot Module Basics - Setup.

Supported HubSpot Features

Currently, the HubSpot Module provides steps for working with Contacts and Companies.

  • Contacts:
    • Create Contact
    • Get All Contacts
    • Get Contact By Id
    • Get Contact By Email Address
    • Get Recently Created Contacts
    • Get Recently Modified Contacts
    • Update Contact
  • Company:
    • Create a Company
    • Get All Companies
    • Get Company By Id
    • Get Recently Created Companies
    • Get Recently Modified Companies
    • Update Company

The Module also provides Advanced steps that allow users to send API calls to HubSpot and receive JSON that can be processed.

  • If a user receives an authentication error during any of these steps, the HubSpot OAuth token that was created may have an expired Access Token.  To correct this, under System > Integrations > OAuth > Tokens, select the HubSpot Token and choose the Refresh Access Token action.
  • If the Get Company By Id, Get Contact By Id, or Get Contact By Email Address are passed an Id or Email Address that isn't in HubSpot, those steps will return the HubSpot error as an exception.  For those steps, enable the Add Outcome for Exception checkbox under Outcomes and test whether the Exception Full Trace contains the text "contact does not exist" or "company does not exist".


Example: Displaying Companies

  1. In a Designer Project, click CREATE FLOW, select Default under Flow, and click CREATE. Name the Flow and select CREATE.
  2. Click the Done path on the Start step and navigate to Integrations > All Integrations > HubSpot. Select the Get All Companies step and click ADD.
  3. In the Properties tab, set the Count, Extra Properties To Get, and Offset fields to Null mapping type. Set the Token Id to Constant and choose a HubSpot token. Set the name of the Output to "Companies List".

  4. Add a Show Form step and connect the Done path of the Get All Companies to step to it. Then, select the Pick or Create Form from the Properties tab. Name the Form and click CREATE to make a new Form. 
  5. In the Form Designer, configure the Form to have a Button component and Data Grid.

  6. On the Properties panel for the Data Grid, enter "company" in the search box for Type under the Input Data category. Select Company [Decisions.HubSpot.DataTypes].
  7. Click Save then close the Form. 
  8. From the Flow Designer, click Edit Input Mapping.
  9. Edit the Form's Input Mapping by connecting the output of the Get All Companies step to the Data Grid. Click OK to save.
  10. Connect the Close path to the End step. Click Save to save changes to the Flow.



    Running the Flow in the debugger will display a list of the companies that are defined in the HubSpot account.



Example: Custom HubSpot Properties

HubSpot allows the creation of custom Properties for Contacts and Companies. By default, the HubSpot steps in Decisions only receive a default set of Properties from the HubSpot API for each Contact or Company. If additional properties are required, they can be specified in the Extra Properties To Get Input on the appropriate steps. Here is an example of a Get All Contacts step with a Constant list of Extra Properties To Get:


When the steps run, each of the Contact results will contain the lifecycle stage value in the Properties Array for that result. 

HubSpot_Steps9.png

Example: Reading and Writing Extra Properties

The HubSpot Module provides a set of steps for reading and writing property values, even custom ones, in a simple fashion. These steps all operate on an individual Contact or Company.

  • Get HubSpot Date Property
  • Get HubSpot Number Property
  • Get HubSpot String Property
  • Set HubSpot Date Property
  • Set HubSpot Number Property
  • Set HubSpot String Property

While the ability to retrieve this extra information is useful, it would be better if the entities being processed were in a form that allows the user to easily map their Properties between steps in Decisions. This example shows one way to accomplish that.

  1. In the Datatypes/Integrations menu, choose User Defined Types > Defined Data Structure.

  2. Name it "Contact" and fill in the various needed Properties, including any extra custom ones. Then click SAVE. This Data Structure is useful because it contains the exact wanted Properties without the need to include an extra step or look them up through an Array.
  3. Next, from a Designer Folder, Create a Flow, and add a Get All Contacts step. Set the Count, Extra Properties To Get, and Offset to Null and choose an appropriate Token.
  4. Add a Run Flows For List step to the Done path of the Get All Contacts step.
  5. Under the Data category on the Properties panel for the Run Flow For List step, set the Input Type and Output Type. The Input Type should be Contact [Decisions.HubSpot.Datatypes] and the Output Type should be the custom Defined Data Structure created.
  6. Click the Edit link under the Item Workflow property to set up the Flow that will process each Contact. In the New Flow Editor that appears add a Create Data step. From its Properties tab, click Show Editor under the Data Definitions. Define an object for the Defined Data Structure that will be returned from the Flow by clicking Edit and selecting the ellipses icon next to Value. Click OK to save input data and close the panel to save the object and return to the Flow Designer.

  7. Next, add a Data Pair To Object step; connect the Done path to the Data Pair To Object step, and the Data Pair To Object step to the End step. Set up the Properties for the Data Pair To Object step as follows:
    • The Data Pairs value comes from the Properties Array of the Input entity for this Flow.
    • The Target is the entity that the previous Create Data step created.
    • The Source Names are the property names as they appear in HubSpot that a user wants to be copied into the output entity.
    • The Destination Names are the property names in the Defined Data Structure that a user wants copied into.  The order must match the order in the Source Names.

  8. Connect the Done path to the End step. Click Save and close the Flow.
  9. From the Previous Flow's Flow Designer, click Edit Input Mappings for the Run Flows For List step and connect the list of Contacts from the Get All Contacts step to the Input List of the Run Flows For List step.


At this point, the Output from the Run Flows For List step is a list of entities in an easy-to-use Form, ready for additional processing.

Handling Large Output

By default HubSpot only returns 100 Companies and 20 Contacts when asked for Lists of those items. If more than that number is required, then any objects past that limit will NOT appear in the Output of the HubSpot Module steps.  There are two Properties on those steps which can help manage in retrieving large amounts of data.

The Count Property

The Count property establishes the number of results that HubSpot will return. In the previous examples, setting the Count property to Null or Ignore causes the HubSpot steps to request the default result count. Setting the Count to a higher number than the default will cause HubSpot to return additional data.

If more information is needed than HubSpot's set maximum of 250 Companies and 100 Contacts from a single API call, users must request it in batches.

The Offset Property

To request the first batch of results, set the Offset property to Null or Ignored.  To request the next batch, set the Offset property to the ID of the last entry in the Array that was returned from the previous batch.  HubSpot will return the next group of results (an amount equal to the Count value) that occurs after that ID in its database.


Was this article helpful?

What's Next