Creating coupons via Braze
In this tutorial, let's set up Braze to automatically generate coupons inside Talon.One and deliver the coupon codes to specific customer segments.
To do so, we will rely on the Create coupons endpoint for Braze that will generate coupons, and we'll send requests to it from Braze through the Connected Content feature.
Talon.One requirements
- You are an Admin user.
- You have set up an Application.
- Your Application contains a running campaign with the Coupons feature enabled.
You can edit the default format of the coupon codes in the campaign's Settings section.
Braze requirements
- You have created a campaign or canvas in Braze.
- You have a way to identify a given customer across Talon.One and Braze.
In this tutorial, we assume a customer's Talon.One
integrationId
is always equal to Braze'suser_id
. You can also create a new property on your Braze customer profiles to store Talon.One's integration ID.
Creating an API key in Talon.One
In the Campaign Manager, create a Braze-specific API key:
-
In your Talon.One Application, click Settings > Developer settings.
-
Click Create API Key.
-
For Do you want to use this API Key with a 3rd party service?, select Yes.
-
From Platform, select Braze.
-
Select an expiration date, and click Create API Key.
-
Copy the key for later use.
noteYou cannot display the API key after this step. If you lose the value, create a new API key.
We will use the API key in the Braze campaign template.
Creating the coupon code
To generate a coupon from Braze, we call the following endpoint:
https://integration.talon.one/braze/coupon
See API Docs
To trigger the endpoint, we must use Braze's Connected Content feature.
We assume that your customer profile in Braze contains a unique identifier that is equal to the customer integration ID in Talon.One.
In this tutorial, we use ${user_id}
. Ensure the user ID matches the integration ID in Talon.One.
-
Open your Braze campaign or canvas for editing.
-
Add the following Connected Content call to the body of your message, where:
YOUR_DEPLOYMENT_URL
is the base URL of your Talon.One deployment.YOUR_APPLICATION_ID
is the ID of your Application in Talon.One.YOUR_CAMPAIGN_ID
is the ID of your campaign in Talon.One.YOUR_API_KEY
is the API key you created.
{% capture postbody %}
{"deploymentUrl": "YOUR_DEPLOYMENT_URL", "applicationId":YOUR_APPLICATION_ID,
"campaignId":YOUR_CAMPAIGN_ID, "identifier":"{{ 'now' | date: '%Y-%m-%d %H:%M:%S.%N' }}", "integrationId":"{{${user_id}}}"}
{% endcapture %}
{% connected_content https://integration.talon.one/braze/coupon
:headers {
"Authorization": "ApiKey-v1 YOUR_API_KEY"
}
:method post
:body {{postbody}}
:content_type application/json
:save result
:retry
%}
Your coupon code is: {{result.Value}}note- In the example above, we use a timestamp for the
identifier
parameter. This ensures that a new coupon code is generated for each email during testing. In production, consider using one of the available personalization tags, for example, the dispatch ID. result.Value
must be written with a capitalV
, according to the response of the Create coupon endpoint.
-
To test your request:
- In the sidebar, click Preview & Test.
- In Preview message as user, select Search User and search for an existing user in Braze.
You should see a coupon code.
Your coupon codes are now generated automatically when your campaign is running.
Customizing the coupon call
You can customize the Braze call with the following form.
This form does not cover all the available options for creating coupon codes. See the API docs for an exhaustive list.