Envoyer des messages de campagne via une livraison déclenchée par API
Utilisez cet endpoint pour envoyer des messages immédiats et ponctuels à des utilisateurs désignés via une réception/distribution déclenchée par l’API.
La livraison déclenchée par API vous permet de stocker le contenu d’un message dans le tableau de bord de Braze, tout en indiquant quand et à qui un message est envoyé via votre API.
Si vous souhaitez cibler un segment, un enregistrement de votre requête sera stocké dans la console de développement. Pour envoyer des messages avec cet endpoint, vous devez disposer d’un ID de campagne créé lorsque vous créez une campagne déclenchée par l’API.
Conditions préalables
Pour utiliser cet endpoint, vous devrez générer une clé API avec l’autorisation campaigns.trigger.send
.
Limite de débit
When specifying a segment or Connected Audience in your request, we apply a rate limit of 250 requests per minute to this endpoint. Otherwise, if specifying an external_id
, this endpoint has a default rate limit of 250,000 requests per hour shared between /messages/send
, /campaigns/trigger/send
, and /canvas/trigger/send
, as documented in API rate limits.
Braze endpoints support batching API requests. A single request to the messaging endpoints can reach any of the following:
- Up to 50 specific
external_ids
, each with individual message parameters - A segment of any size created in the Braze dashboard, specified by its
segment_id
- An audience segment of any size, defined in the request as a connected audience object
Corps de la demande
1
2
Content-Type: application/json
Authorization: Bearer YOUR-REST-API-KEY
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
28
{
"campaign_id": (required, string) see campaign identifier,
"send_id": (optional, string) see send identifier,
"trigger_properties": (optional, object) personalization key-value pairs that will apply to all users in this request,
"broadcast": (optional, boolean) see broadcast -- defaults to false on 8/31/17, must be set to true if "recipients" is omitted,
"audience": (optional, connected audience object) see connected audience,
// Including 'audience' will only send to users in the audience
"recipients": (optional, array; if not provided and broadcast is not set to `false`, message will send to the entire segment targeted by the campaign)
[
{
// Either "external_user_id" or "user_alias" or "email" is required. Requests must specify only one.
"user_alias": (optional, user alias object) user alias of user to receive message,
"external_user_id": (optional, string) external identifier of user to receive message,
"email": (optional, string) email address of user to receive message,
"prioritization": (optional, array) prioritization array; required when using email,
"trigger_properties": (optional, object) personalization key-value pairs that will apply to this user (these key-value pairs will override any keys that conflict with the parent trigger_properties),
"send_to_existing_only": (optional, boolean) defaults to true, can't be used with user aliases; if set to `false`, an attributes object must also be included,
"attributes": (optional, object) fields in the attributes object will create or update an attribute of that name with the given value on the specified user profile before the message is sent and existing values will be overwritten
}
],
"attachments": (optional, array) array of JSON objects that define the files you need attached, defined by "file_name" and "url",
[
{
"file_name": (required, string) the name of the file you want to attach to your email, excluding the extension (for example, ".pdf"). Attach files up to 2 MB. This is required if you use "attachments",
"url": (required, string) the corresponding URL of the file you want to attach to your email. The file name's extension will be detected automatically from the URL defined, which should return the appropriate "Content-Type" as a response header. This is required if you use "attachments",
}
]
}
Paramètres de demande
Paramètre | Requis | Type de données | Description |
---|---|---|---|
campaign_id |
Requis | Chaîne de caractères | Voir identifiant de campagne. |
send_id |
Facultatif | Chaîne de caractères | Voir identifiant d’envoi. |
trigger_properties |
Facultatif | Objet | Voir les propriétés du déclencheur. Les paires clé-valeur de personnalisation qui s’appliquent à tous les utilisateurs de cette demande. |
broadcast |
Facultatif | Valeur booléenne | Vous devez définir broadcast sur « true » lorsque vous envoyez un message à un segment entier qui est ciblé par une campagne ou un Canvas. Ce paramètre est défini sur Faux par défaut (au 31 août 2017). Si broadcast est défini sur « true », une liste recipients ne peut pas être incluse. Cependant, faites attention lors de la configuration de broadcast: true car en configurant involontairement cet indicateur, vous pourriez envoyer votre message à une audience plus importante que prévue. |
audience |
Facultatif | Objet Audience connectée | Voir audience connectée. |
recipients |
Facultatif | Tableau | Voir objet destinataire. Si send_to_existing_only est false , un objet Attribut doit être inclus.Si recipients n’est pas fourni et que broadcast a la valeur “true”, le message sera envoyé à l’ensemble du segment ciblé par la campagne. |
attachments |
Facultatif | Tableau | Si broadcast est défini comme vrai, la liste attachments ne peut pas être incluse. |
- Le tableau des destinataires peut contenir jusqu’à 50 objets, avec chaque objet contenant une seule chaîne de caractères
external_user_id
et objettrigger_properties
. - Quand
send_to_existing_only
est défini surtrue
, Braze envoie uniquement le message aux utilisateurs existants. Cependant, cet indicateur ne peut pas être utilisé avec les alias utilisateur. - Lorsque
send_to_existing_only
estfalse
, un attribut doit être inclus. Braze créera un utilisateur avec le siteid
et les attributs avant d’envoyer le message.
La spécification d’un destinataire par son adresse e-mail est actuellement en accès anticipé. Contactez votre gestionnaire de satisfaction client si vous souhaitez participer à cet accès anticipé.
Le statut du groupe d’abonnement d’un utilisateur peut être mis à jour en incluant un paramètre subscription_groups
dans l’objet attributes
. Pour plus de détails, consultez Objet Attributs d’utilisateur.
Exemple de demande
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
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
curl --location --request POST 'https://rest.iad-01.braze.com/campaigns/trigger/send' \
--header 'Content-Type: application/json' \
--header 'Authorization: Bearer YOUR-REST-API-KEY' \
--data-raw '{
"campaign_id": "campaign_identifier",
"send_id": "send_identifier",
"trigger_properties": "",
"broadcast": false,
"audience": {
"AND": [
{
"custom_attribute": {
"custom_attribute_name": "eye_color",
"comparison": "equals",
"value": "blue"
}
},
{
"custom_attribute": {
"custom_attribute_name": "favorite_foods",
"comparison": "includes_value",
"value": "pizza"
}
},
{
"OR": [
{
"custom_attribute": {
"custom_attribute_name": "last_purchase_time",
"comparison": "less_than_x_days_ago",
"value": 2
}
},
{
"push_subscription_status": {
"comparison": "is",
"value": "opted_in"
}
}
]
},
{
"email_subscription_status": {
"comparison": "is_not",
"value": "subscribed"
}
},
{
"last_used_app": {
"comparison": "after",
"value": "2019-07-22T13:17:55+0000"
}
}
]
},
"recipients": [
{
"user_alias": {
"alias_name" : "example_name",
"alias_label" : "example_label"
},
"external_user_id": "external_user_identifier",
"trigger_properties": "",
"send_to_existing_only": true,
"attributes": {
"first_name" : "Alex"
}
}
],
"attachments": [
{
"file_name" : "YourFileName",
"url" : "https://exampleurl.com/YourFileName.pdf"
}
]
}'
Informations relatives à la réponse
Les réponses des endpoints d’envoi de messages incluront le dispatch_id
du message pour y faire référence lors de l’envoi. Le dispatch_id
est l’ID de l’envoi de messages, un ID unique pour chaque transmission envoyée depuis Braze. Lorsque vous utilisez cet endpoint, vous recevez un seul dispatch_id
pour un ensemble complet d’utilisateurs regroupés. Pour plus d’informations sur dispatch_id
, consultez notre documentation sur le comportement du Dispatch ID.
Si votre demande rencontre une erreur fatale, reportez-vous à la section Erreurs et réponses pour connaître le code d’erreur et sa description.
Objet d’attributs pour les campagnes
Braze dispose d’un objet d’envoi de messages appelé attributes
qui vous permettra d’ajouter, de créer ou de mettre à jour les attributs et les valeurs d’un utilisateur avant de lui envoyer une campagne déclenchée par l’API. En utilisant l’endpoint campaign/trigger/send
car cet appel d’API traitera l’objet Attributs d’utilisateur avant de traiter et d’envoyer la campagne. Cela permet de minimiser le risque de problèmes causés par des conditions de concurrence.
Vous recherchez la version Canvas de cet endpoint ? Consultez la rubrique Envoi de messages canvas via la réception/distribution déclenchée par l’API.