Managing consent records in Marketing Cloud on Core (aka Marketing Cloud Growth or Advanced Edition) has raised many questions. While most agree with the concept of consent, generating individual consent records each time a sales team member adds a new lead in Salesforce can be tedious. I’ve been asked many times if I could just create a flow to add consent when new leads are created. The answer is “Yes” and here’s how you can do it too.
Disclaimer
I’ve been called a marketer, consultant, and Salesforce Admin over my career, but I’ve never been called a lawyer. Privacy policies and opt-in requirements vary from country-to-country and even state-to-state. Before implementing this solution, consult with your legal team to ensure that you are in compliance with your organization’s legal requirements.
Consent Fields
Before creating consent records, we first need to understand the requirements. When doing a consent import, the following fields are captured in the wizard and through the import template. This process is very simple and the magic happens behind the scenes.
- Channel – Communication delivery method (Email or SMS)
- Communication Subscription – The individual subscription name (ex. Newsletter)
- Consent Status – Indicates whether an individual has “Opted In” or “Opted Out” at the subscription level.
- Email – Email address of the individual captured on the consent record.
- Consent Date – The date/time that consent was captured.
When digging in a bit more, I found a field named Communication Subscription Consent Id. This field combines the email address and the Communication Subscription Channel Type Id with “#” between them to create a new field. This field is the key to creating a consent record.
Example
- [email protected]#0eBHs0000010zyOMAQ
Communication Subscription vs. Communication Subscription Chnl Type Id
It’s important to know the difference between these fields and where to find them. When creating your Communication Subscription Consent Id field in your flow, you’ll need to be sure to use the correct value.
The difference between these fields is that Communication Subscription Chnl Type Id references the email subscription and the channel. Communication Subscription is channel agnostic and only references the subscription.
Example
- Communication Subscription – 0XlHs00000111ZZKAY
- Refers to the Newsletter subscription
- Communication Subscription Chnl Type Id – 0eBHs00000111n0MAA
- Refers to the Newsletter subscription and email channel
You can find these values by creating a Salesforce report using the Communication Subscription Channel Type report type. You’ll see one record for each subscription and channel. In this example, I have four subscriptions on my preference page as I’m just using the email channel. If the SMS channel was in use, there would be 8 records.
data:image/s3,"s3://crabby-images/595e6/595e6a679be34336072eaad245fca300ee367464" alt="A screenshot showing the New Report of the Communication Subscription Channel Type"
Both of these values are going to be needed when creating your flow, so make a report in your org and be sure to save it. You can also view these values by accessing the records from the Communication Subscriptions and Communication Subscription Channel Types objects if you prefer.
Record-Triggered Flow Build
We’re finally to the fun part. But before we get started, consider a few questions.
- Which object should trigger the flow?
- When should the flow trigger?
- What entry conditions should be used?
- Are there any countries or states where double opt-in is required?
Start Element
I want my flow to only run when new leads are created. I also want to exclude leads that were created from a form submission. Marketing Cloud on Core forms require a consent element, so we don’t need to update these leads. Your start criteria will differ based on your needs.
data:image/s3,"s3://crabby-images/68e45/68e45cdc9796ed6197fe7bc3226f7de65a8fb6b3" alt="A screenshot of the start element of the Flow."
Scheduled Path
Record-triggered flow can’t execute actions that make external callouts in a path that runs immediately. You can address this by adding a scheduled path with a slight delay. My path has a 1-minute delay from when the lead was created.
data:image/s3,"s3://crabby-images/7e391/7e39194e8f6f247d24c6648304ff2f4c461e4b4f" alt="A screenshot of configuring the scheduled paths"
Decision Element
I did not exclude countries that require double opt-in from my start element intentionally. I decided to let them enter the flow and use a decision element to route them down a second path. The idea is that I can later add an action to send a transactional email to these leads encouraging them to update their subscription preferences.
data:image/s3,"s3://crabby-images/ae0ac/ae0ac79e4776a79e3cde9bbc34bbce2309d5e84a" alt="A screenshot of the decision element of the Flow."
Action Elements
Salesforce set us up for success by including the MessagingConsent.MessagingConsent action. All we need to do is configure it correctly and our consent records will be created. Like consent imports, you’ll need action for each of your subscriptions by channel.
When configuring actions, you’ll need to set values for the inputs below.
- CommunicationSubscriptionChannelType*
- This is the id that relates to the communication subscription and channel.
- ConsentCapturedDateTime
- Date/time that consent was captured.
- ConsentId
- This is the concatenated field that we discussed earlier that includes the email address and the Communication Subscription Channel Type Id.
- ConsentStatus
- Set value to OPT_IN or OPT_OUT.
- ContactPointValue
- The email address of the triggering record.
- Name*
- The communication subscription (id) from the report that we created earlier. This is the id that relates to the subscription only (does not include the channel).
- The communication subscription (id) from the report that we created earlier. This is the id that relates to the subscription only (does not include the channel).
*Note: You can create content records without these values, but I prefer to include them to more closely resemble the records created from consent imports.
Formula Resources
Next, we need to generate the consentid field that will be needed in the action elements. This can be done using a formula to generate the value using the email address (of the triggering record) and the Communication Subscription Chnl Type Id. You’ll need one resource per Communication Subscription Chnl Type Id.
Example Formula
- {!$Record.Email} & “#” & “0eBHs00000111n0MAA”
Configured Action Element
Here’s an example of an action element that has been fully configured.
Final Flow
Here’s a look at the final flow.
Testing
After activating your flow, create a new lead in Salesforce. Upon creation, the consent values will be set to Opt Out. After a few minutes (allowing time for the scheduled path to run), verify the consent record was created by viewing the Communication Subscription Consent DMO in Data Explorer in Data Cloud.
data:image/s3,"s3://crabby-images/64467/644677c2010bd2d10edccf84eb8cc1becba0faa8" alt="A screenshot of the Data Cloud Data Explorer Objects."
Once the data from Data Cloud syncs back to the lead record, the consent values will be updated to Opt In in the Privacy Consent Status component.
Respect Consent & Be Responsible
The best practice recommendation is to create consent records using the consent element on form-triggered flows or by completing consent imports. While these recommendations make sense, generating consent records for individual records created by users can present challenges.
Record-triggered flows offer a good solution for automating consent records, but organizations must ensure compliance with regional, state, and company legal requirements. When in doubt, err on the side of caution and prioritize transparency in consent management.