Skip to content

Facebook Lead Ads via Zapier integration

With the Facebook Lead Ads integration via Zapier, you can import your leads from Facebook into Braze and track a custom event when leads are captured.

Facebook Lead Ads is an ad format that allows businesses to collect lead information directly in Facebook. These ads are designed to make the lead generation process easy and seamless. By leveraging a Zapier integration and Braze, you can automate the transfer of lead data from Facebook to Braze, enabling real-time engagement and personalized follow-up actions.

Prerequisites

Integration

Step 1: Create a Lead Ads campaign with an instant form

From Facebook Ads Manager, create a Facebook Leads campaign and Facebook Lead Ads form.

You can use either an email address or phone number when making a request to the /users/track endpoint to update or create the user profile. For this reason, include a Contact field for email or phone in your lead ad form. If you’re collecting first names or last names, collect those separately in your form instead of using full names.

Step 2: Connect your Facebook account to Zapier

Step 2a: Select your connection method in Zapier

In Zapier, go to Apps to search for available Facebook apps. Select either Facebook Lead Ads or Facebook Lead Ads (for Business admins).

For more information on these two methods of connecting your Facebook account to Zapier, refer to:

Step 2b: Add Zapier to Leads Access in Facebook Business Manager

In your Facebook Business Manager, go to Integrations > Leads Access on the left-hand menu. Select your Facebook Page, then click CRMs. On the CRM tab, select Assign CRMs and add Zapier.

For steps to assign Zapier as a CRM integration, refer to Facebook’s documentation.

Step 3: Create your Zap

Step 3a: Create the trigger

Once you have connected your Facebook account, you can proceed to create a Zap. For the Trigger, select Facebook Lead Ads or Facebook Lead Ads (for Business Admins) based on your choice from step 2.

For the Event, select New Leads > Continue.

Select your Facebook account, then Continue.

Select your Facebook Page and instant form you previously created, then Continue.

Next, test this trigger. After validating your form output, select Continue with selected record.

Step 3b: Create an action

Add a new step, then select Webhooks by Zapier. Next, select Custom Request for the Event field, then click Continue.

Lastly, set up your custom request by inserting fields in your payload. The following code snippet shows an example payload.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
{
    "attributes": [
        {
            "email": "<insert_email_field>",
            "first_name": "<insert_first_name_field>",
            "last_name": "<insert_last_name_field>",
            "lead_form": "<insert_form_name_field>",
            "fb_campaign": "<insert_campaign_id_field>",
            "fb_ad_set": "<insert_campaign_id_field>",
            "fb_ad": "<insert_campaign_id_field>",
            "email_subscribe": "subscribed",
            "subscription_groups" : [{
                "subscription_group_id": "<subscription_group_id>",
                "subscription_state": "subscribed"
                }
            ]
        }
    ],
    "events": [
        {
            "email": "<insert_email_field>",
            "name": "<insert_custom_event_name>",
            "time": "<insert_timestamp_field>",
            "_update_existing_only": false
        }
    ]
}`

Here’s an example of what this looks like in Zapier:

After configuring your webhook, select Continue and test. If the test is successful, you can publish your Zap.

Step 4: Test your Facebook Lead Ads Zap

To test this end-to-end, use Facebook’s Leads Ads Testing Tool in your Facebook Developer Console. For more information, see Testing and Troubleshooting.

User identity management

This integration allows you to attribute your Facebook leads by email through the /users/track endpoint.

  • If the email matches an existing user profile, Braze will update the profile with Facebook leads data.
  • If there are multiple user profiles with the same email, Braze will prioritize the most recently updated profile with an external ID for updates.
  • If the external ID doesn’t exist, Braze will prioritize the most recently updated profile with the matching email.
  • If no profile exists with the provided email, Braze will create a new profile and a new alias user profile will be created. To identify the newly created alias user profiles, use the /users/identify endpoint.

Troubleshooting

I tested the Trigger and Action successfully, so why am I unable to publish my Zapier Zap?

To use this integration, you must have a Zapier plan that supports premium apps.

Why aren’t Facebook leads syncing to Braze?
  1. Check that you have administrator access to your Facebook Page, ad account, and lead access. Then, reconnect your account in Zapier.
  2. Verify that the instant form you created in Facebook maps to the form selected in your Trigger step.
  3. Check that you have assigned Zapier to Leads Access by going to Facebook Business Manager > Integrations > Lead Access.
Why am I seeing duplicate user profiles with the same email?

There are unique ways of creating and managing user profiles in Braze based on their user profile lifecycle.

Depending on your internal processes and when you are triggering customers to be created within Braze, you may encounter duplicate user profiles due to a race condition of the user profile being created by the integration and when the user is created from your system. You can merge user profiles in Braze.

I don’t have a Zapier account. How can I trigger Facebook Lead Ads webhooks into Braze?

If you don’t use Zapier and don’t plan on using Zapier, you can build the integration directly from Facebook into Braze. Refer to Lead Ads documentation for more information.

For retrieving leads from Facebook, use webhooks. Refer to Webhooks documentation to get started with webhooks in Facebook.

After establishing the webhooks URL in Facebook, work with your team to determine the best path to forward the data to the /users/track endpoint. Similar to the Zapier approach, we’d recommend making a request by email through the users/track endpoint.

HOW HELPFUL WAS THIS PAGE?
New Stuff!