How to Capture Every UTM Touchpoint in Salesforce

The Concept

If a lead or a contact’s fields for UTM Source, UTM Medium and UTM Campaign have a value, run a Salesforce Flow to create a record in a custom object. Once the record is created, set the UTM fields for the lead or contact back to blank. The process will run again whenever the UTM information is updated.

UTM touchpoints displayed on the lead layout

Record detail page for a UTM touchpoint

Report preview

Dashboard preview


In order for this approach to work, there are 2 things you need to plan for:

  1. UTM fields for the Lead and Contact MUST be set up to be overwritten every time.
  2. What to do if there’s EXISTING UTM data in these fields to prevent data loss.

I recommend you review how your UTM fields are currently populated, what data currently exists in these fields and what reports/automations, etc rely on these fields. You should be able to answer these questions before getting started:

  1. How are the UTM fields populated?
  2. Do the UTM fields get overwritten?
  3. What are we going to do with existing data?

What to do if you have existing data

There are plenty of options on how to get this to work if you have existing data in your UTM fields. It all depends on your current setup. Here are some ideas:

  1. Create new fields named “First UTM Source”, “First UTM Medium”, etc. Rename your CURRENT UTM field labels (not API names) as “Last UTM Source, “Last UTM Medium”, etc. Populate the “First UTM” fields with your current data and use the “Last UTM” fields in your Flow.
  2. Once the UTM custom object is set up, use to create records using all the existing UTM values.

Create the custom object

Create the custom object. I named by object “UTM Touchpoint”.

Create your fields

Next, create the custom fields for your custom object.

Field name Field type
Lead Lookup (Lead)
Contact Lookup (Contact)
UTM Source Text
UTM Campaign Text
UTM Medium Text
Touchpoint Date Date

You can also create any other fields you want to track using this object. For example, UTM Term or UTM Content.

Create the Flow for Leads

Navigate to the Flow builder and create a new Flow. Select Record-Triggered Flow as your Flow type.

Configure the trigger to run when a a record is created or updated and after the record is saved

Select the Lead object as the starting object and add in the filters that will trigger your flow. For this example, I want to trigger the flow when UTM Source, UTM Medium AND UTM Campaign have values.

Add a create records element to the Flow that will take the UTM values from the lead and set the values for the UTM Touchpoint object.

Add a update records element to the Flow that will set the values for UTM Source, UTM Medium, etc for the lead back to empty.

Here’s what my completed flow looks like for leads.

Create the flow for contacts

To create the flow for contacts, click save as on the lead flow and select save as new flow.

Edit the flow to start on the contact object instead of the lead object.

Edit the create records step to update the contact rather than the lead.

Update the edit records element to update the contact fields instead.

Here’s what my completed flow looks like for contacts.

Creating reports

You can create reports by using one of the predefined UTM report types. The report type “UTM Touchpoints” will allow you to pull a report of ALL UTM touchpoints for both leads and contacts.

You can group by UTM Touchpoint Date to view all the touchpoints for a specific month, day, quarter, year, etc.


Send me a tweet @jennamolby, or leave a comment below.