Convercus
Convercus est une plateforme SaaS de fidélité et de coupons qui aide les marques et les enseignes à augmenter la fréquence d’achat, la valeur du panier et les taux de réachat grâce à des programmes de fidélité omnicanaux et des campagnes de coupons personnalisées.
Cette intégration est maintenue par Convercus.
À propos de l’intégration
L’intégration entre Braze et Convercus est bidirectionnelle : les données de fidélité sont transmises à Braze en temps réel sous forme d’attributs personnalisés, d’événements personnalisés et d’achats, et les Canvas et Campaigns Braze peuvent déclencher des actions de fidélité dans Convercus via des webhooks. Utilisez le niveau de membre synchronisé, le solde de points, les achats et l’activité des coupons dans les Segments, Liquid et le Contenu connecté. Depuis les parcours Braze, vous pouvez également attribuer des coupons, enregistrer, créditer et débiter des transactions de points, et mettre à jour les préférences d’abonnement e-mail dans Convercus.
Convercus héberge l’intégration, vous n’avez donc pas d’infrastructure supplémentaire à installer. Là où la plupart des connecteurs de fidélité ne transmettent les données que dans un sens, Convercus boucle la boucle : réagissez dans Braze à un événement de fidélité, effectuez une action dans Convercus et mesurez le résultat dans Braze.
Cas d’utilisation
- Célébration de montée en niveau : Lorsqu’un membre monte d’un niveau de fidélité dans Convercus, déclenchez un Canvas Braze personnalisé avec un message de bienvenue, un avantage exclusif au niveau et le nouveau niveau et solde de points du membre.
- Bonus d’anniversaire et de jalon : Depuis un parcours Braze, créditez des points bonus dans Convercus pour l’anniversaire ou la date anniversaire d’un membre, puis envoyez un message de célébration confirmant le nouveau solde.
- Reconquête de membres inactifs : Pour les membres inactifs, faites en sorte que Braze attribue un coupon personnalisé dans Convercus via un webhook et le diffuse par e-mail, notification push et messages in-app.
- Solde de points en temps réel dans les messages : Utilisez le Contenu connecté pour récupérer le solde de points en temps réel d’un membre dans Braze Liquid, alimentant des cadences telles que « il ne vous manque que X points pour votre prochaine récompense ».
Conditions préalables
Avant de commencer, vous avez besoin des éléments suivants :
| Condition préalable | Description |
|---|---|
| Un compte Convercus | Un programme Convercus actif. Contactez votre gestionnaire de compte Convercus si vous n’êtes pas encore client. |
| Une clé API REST Braze | Une clé API REST Braze avec la permission users.track. Créez cette clé dans le tableau de bord de Braze depuis Paramètres > Clés API. |
| Un endpoint REST Braze | L’URL de votre endpoint REST. Votre endpoint dépend de l’URL Braze de votre instance. |
Vous avez besoin d’un identifiant utilisateur cohérent entre les systèmes : la valeur utilisée comme external_id (ou le type d’identifiant choisi) dans Braze doit correspondre à l’identifiant membre correspondant dans Convercus. Sinon, les événements ne sont pas attribués au bon profil.
Intégration
Étape 1 : Configurer Braze dans Convercus Selfservice
Dans Convercus Selfservice (l’interface d’administration destinée aux clients — ouvrez-la à l’aide de l’URL fournie par votre gestionnaire de compte Convercus), ouvrez le programme que vous souhaitez connecter à Braze et utilisez la carte d’intégration Braze pour :
-
Configurer la connexion Braze en remplissant le formulaire d’intégration :
Champ Description apiKeyVotre clé API REST Braze (avec la permission users.track).apiEndpointVotre endpoint REST Braze, par exemple https://rest.iad-01.braze.com.Type d’identifiant Soit external_id, soituser_alias. Détermine comment les membres Convercus sont associés aux profils utilisateur Braze.defaultOptinsSélection multiple des canaux d’abonnement du programme (depuis membershipOptins). Utilisé comme valeur par défaut pour le webhook d’abonnement e-mail lorsque la requête ometoptins. La configuration Braze est considérée comme incomplète tant qu’au moins un canal n’est pas sélectionné. -
Créer une clé API pour les appels entrants. Créez un identifiant
X-Convercus-Keypar programme. La clé brute est affichée une seule fois lors de la création, préfixéecvc_(format :cvc_<base64url>). Enregistrez-la dans Braze lorsque vous configurez les Campaigns webhook et les blocs de Contenu connecté à l’étape 2. Les clés peuvent être révoquées à tout moment depuis la même carte ; la révocation prend effet immédiatement.
Après avoir enregistré la connexion Braze, Convercus commence immédiatement à transmettre les événements de fidélité de ce programme à Braze. Aucune configuration d’infrastructure supplémentaire n’est requise.

Chaque programme Convercus est configuré indépendamment. Un seul tenant Convercus peut connecter différents programmes à différents espaces de travail Braze, chacun avec sa propre clé API.
Étape 2 : Configurer les webhooks dans Braze
Pour déclencher des actions Convercus depuis un Canvas ou une Campaign, créez des actions webhook Braze qui appellent le service d’intégration Convercus. Toutes les requêtes doivent inclure les en-têtes suivants :
X-Convercus-Key: cvc_…— la clé API générée à l’étape 1.Content-Type: application/json
Tous les endpoints se trouvent sous l’URL de base <SERVICE_HOST>/v1/programs/{programId}. Remplacez <SERVICE_HOST> par l’hôte fourni par votre gestionnaire de compte Convercus et {programId} par l’ID de votre programme Convercus.
| Action | Endpoint |
|---|---|
| Attribuer un coupon à un membre | POST /campaigns/{couponId}/assign — renvoie { "couponCode": "..." }. |
| Attribuer un coupon à plusieurs membres | POST /campaigns/{couponId}/assign/batch — jusqu’à 500 membres en un seul appel ; le corps accepte les paramètres optionnels valid_from / valid_to. Renvoie { "batchId": "..." }. |
| Enregistrer un crédit / débit de points | POST /members/{accountId}/bookings — crée un EARNBOOKING ou un BURNBOOKING sur un compte membre. Renvoie { "bookingId": "..." }. |
| Synchroniser les préférences d’abonnement e-mail | POST /subscriptions/email — définit les abonnements du membre sur allowed ou declined. Les canaux d’abonnement sont résolus selon la priorité : optins de la requête > defaultOptins. Renvoie 200 (tout OK), 207 (partiel — voir succeeded / failed), ou 400 (abonnements inconnus ou non configurés). |
Exemple — attribuer un coupon à un membre :
1
2
3
4
5
6
7
8
POST <SERVICE_HOST>/v1/programs/{programId}/campaigns/{couponId}/assign
X-Convercus-Key: cvc_…
Content-Type: application/json
{
"account_id": "{{custom_attribute.${convercus_account_id}}}",
"braze_campaign_id": "{{campaign.${api_id}}}"
}
Les autres actions suivent le même schéma, en changeant uniquement l’endpoint et le corps. Par exemple, un enregistrement de points est envoyé à /members/{accountId}/bookings avec booking_type (EARNBOOKING ou BURNBOOKING), booking_type_code, points et reason ; le webhook d’abonnement e-mail est envoyé à /subscriptions/email avec account_id et status (allowed ou declined).
Réponses d’erreur et nouvelles tentatives
| État | Signification |
|---|---|
200 |
Réussi. |
207 |
Multi-Status — uniquement pour le webhook d’abonnement e-mail, lorsque certains abonnements ont été mis à jour et d’autres ont échoué. |
400 |
Le corps de la requête n’a pas passé la validation. |
401 |
X-Convercus-Key est manquant ou invalide. |
5xx |
L’appel en amont vers Convercus a échoué. |

Les réponses 5xx ne sont pas sûres pour une nouvelle tentative sans confirmation de succès — ces opérations ne sont pas idempotentes, et les nouvelles tentatives peuvent entraîner une double attribution de coupons ou un double crédit de points. Désactivez la nouvelle tentative automatique de Braze sur les 5xx pour ces webhooks, ou configurez un nombre maximum de tentatives très faible.
Étape 3 : Vérifier les données dans Braze
- Déclenchez un événement de fidélité dans Convercus — par exemple, un changement de niveau de statut, une transaction de points ou un échange de coupon.
- Ouvrez l’utilisateur correspondant dans Braze et confirmez que l’attribut personnalisé, l’événement personnalisé ou l’achat attendu apparaît sur le profil. Les utilisateurs sont associés par
external_id(ou le type d’identifiant choisi à l’étape 1). - Pour vérifier la direction opposée, effectuez un envoi test Braze qui appelle l’un des webhooks de l’étape 2 et confirmez l’action dans Convercus (coupon attribué, points enregistrés ou abonnement mis à jour).
Utiliser Convercus avec Braze
Étape 1 : Personnaliser les messages avec les données de fidélité synchronisées
Une fois l’intégration active, les événements Convercus arrivent sur chaque profil utilisateur dans Braze via l’endpoint /users/track et peuvent être utilisés comme n’importe quelle autre donnée native :
- Utilisez les attributs personnalisés de fidélité (par exemple,
convercus_status_level,convercus_balance) dans les Segments pour cibler les détenteurs de niveaux, les membres à solde élevé ou les utilisateurs récemment rétrogradés. - Utilisez les événements personnalisés (par exemple,
convercus_status_level_changed, événements de coupons et d’adhésion) comme étapes de déclenchement dans Canvas ou comme filtres dans les Campaigns de réengagement. - Référencez n’importe lequel de ces champs dans Liquid pour la personnalisation des messages (lignes d’objet, corps du message, titres de notification push).
- Utilisez les événements
purchasetransmis depuis Convercus pour alimenter des parcours orientés produit (réapprovisionnement, vente incitative par catégorie, demandes d’avis post-achat).
Attributs personnalisés
| Attribut | Description |
|---|---|
convercus_account_id |
L’ID de compte Convercus du membre — unique au sein d’un programme Convercus / espace de travail Braze. |
convercus_user_id |
L’ID utilisateur Convercus identifiant la personne sous-jacente à travers plusieurs programmes Convercus. |
convercus_partner_id |
Identifiant du partenaire Convercus (commerçant/marque) par lequel ce membre s’est inscrit. Utile pour la segmentation dans les programmes de coalition. |
convercus_member_role |
Le rôle du membre au sein du programme de fidélité. |
convercus_status_level |
Le niveau ou statut actuel du membre. |
convercus_balance |
Objet contenant les points, lockedPoints et statusPoints actuels du membre. |
email_subscribe |
État d’abonnement e-mail dérivé des abonnements Convercus (opted_in, subscribed ou unsubscribed). |
push_subscribe |
État d’abonnement push dérivé des événements de jeton de notification push Convercus (opted_in ou unsubscribed). |
| Champs de profil standard | email, phone, first_name, last_name, dob, gender, home_city, country. |
| Propriétés utilisateur personnalisées | Toutes les propriétés personnalisées définies sur l’objet utilisateur Convercus sont transmises en tant qu’attributs personnalisés Braze. |

Au sein d’un espace de travail Braze, les membres sont identifiés de manière unique par convercus_account_id. convercus_user_id identifie la personne sous-jacente à travers plusieurs programmes Convercus et est fourni pour l’analyse inter-programmes ; pour la segmentation dans Braze, utilisez convercus_account_id.
Mappage de email_subscribe
| État Convercus | email_subscribe Braze |
|---|---|
Entrée allowedOptins pour email consent ou newsletter |
opted_in |
Entrée declinedOptIns pour ces canaux (et aucune entrée autorisée) |
unsubscribed |
| Aucun enregistrement dans un sens ou l’autre | subscribed (valeur neutre par défaut de Braze) |
Événements personnalisés
| Événement | Déclenché lorsque |
|---|---|
convercus_account_created |
Un nouveau compte est créé dans Convercus. |
convercus_membership_added |
Un compte existant rejoint un programme de fidélité. |
convercus_membership_created |
Une nouvelle adhésion est créée. |
convercus_membership_changed |
Les données d’une adhésion changent. |
convercus_membership_optins_changed |
Les préférences d’abonnement d’un membre changent. |
convercus_membership_terminated |
Une adhésion prend fin. |
convercus_status_level_changed |
Le niveau ou statut d’un membre change. |
convercus_balance_changed |
Le solde de points d’un membre change. |
convercus_account_transaction |
Une transaction de fidélité est évaluée. |
convercus_coupon_assigned |
Un coupon est attribué au membre. |
convercus_coupon_redeemed |
Le membre échange un coupon. |
convercus_user_logged_in |
Le membre se connecte à une interface alimentée par Convercus. |
convercus_user_logged_out |
Le membre se déconnecte. |
convercus_user_created |
Un nouvel utilisateur est créé. |
convercus_user_changed |
Les données de profil d’un utilisateur changent. |
convercus_push_token_created |
Un jeton de notification push est enregistré pour le membre. |
convercus_push_token_deleted |
Un jeton de notification push est supprimé. |
Achats
Les transactions Convercus de type EARNTRANSACTION (points gagnés à partir des dépenses client) sont signalées à Braze en tant qu’achats et comptabilisées dans l’analyse du chiffre d’affaires Braze, la segmentation RFM et les fonctionnalités prédictives — en utilisant l’ID de transaction comme identifiant produit et le montant et la devise de la transaction comme prix et devise.
Les transactions de type PAYWITHPOINTSTRANSACTION (débit de points) ne sont pas signalées comme des achats — elles sont transmises en tant qu’événement personnalisé convercus_account_transaction afin de rester disponibles pour la segmentation. Les annulations et les inversions de transactions de crédit sont signalées comme des achats à prix négatif, maintenant l’alignement du chiffre d’affaires Braze avec Convercus.
Étape 2 : Récupérer les données de fidélité en temps réel avec le Contenu connecté
Pour les valeurs qui doivent être à jour au moment de l’envoi — solde de points actuel, coupons actifs, dernier niveau — appelez Convercus depuis Braze en utilisant le Contenu connecté au lieu de vous fier à l’attribut synchronisé le plus récent. Les deux endpoints se trouvent sous la même URL de base que les webhooks et nécessitent l’en-tête X-Convercus-Key.
| Données | Endpoint | Renvoie |
|---|---|---|
| Profil du membre | GET /members/{accountId}/profile |
member_id, first_name, last_name, email, tier_name, tier_id, points_balance, enrollment_date. |
| Coupons du membre | GET /members/{accountId}/coupons |
Liste des coupons actifs et échangeables (statut, valeur, fenêtre de validité, titre, description). Ajoutez ?lang=<code> (par exemple, ?lang=de) pour localiser title/description ; la valeur par défaut est en. |
Les endpoints de Contenu connecté renvoient toujours HTTP 200 en cas d’échecs attendus afin que les modèles Liquid puissent se brancher sur le champ error :
| Réponse | Signification |
|---|---|
200 + payload |
Réussi. |
200 { "error": "member_not_found" } |
Le compte n’existe pas dans ce programme. |
200 { "error": "internal_error" } |
Échec en amont ou inattendu. |
401 |
X-Convercus-Key est manquant ou invalide (à gérer lors de la configuration de l’intégration, pas dans Liquid). |
Exemple — afficher le statut de fidélité d’un membre (niveau, points et offres actives) :
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
{% connected_content
https://<SERVICE_HOST>/v1/programs/{programId}/members/{{custom_attribute.${convercus_account_id}}}/profile
:headers { "X-Convercus-Key": "cvc_…" }
:content_type application/json
:cache_max_age 300
:retry
:save member
%}
{% connected_content
https://<SERVICE_HOST>/v1/programs/{programId}/members/{{custom_attribute.${convercus_account_id}}}/coupons?lang=en
:headers { "X-Convercus-Key": "cvc_…" }
:content_type application/json
:cache_max_age 0
:retry
:save coupon_data
%}
{% unless member.error %}
<h2>Your Loyalty Status</h2>
<p>Hi {{member.first_name}}, you're a <strong>{{member.tier_name}}</strong> member.</p>
<p>Points balance: <strong>{{member.points_balance}}</strong></p>
{% if coupon_data.coupons.size > 0 %}
<h3>Your Active Offers</h3>
{% for coupon in coupon_data.coupons %}
<p><strong>{{coupon.title}}</strong> — valid until {{coupon.valid_to}}</p>
{% endfor %}
{% endif %}
{% endunless %}
Encadrez toujours le Contenu connecté dans des conditions (vérifiez member.error et les coupons vides) afin qu’un échec temporaire de recherche n’envoie jamais un message cassé. Mettez en cache le profil (cache_max_age 300) mais pas les coupons (cache_max_age 0), car le statut des coupons peut changer entre les envois.
Considérations
- Latence : Les événements Convercus vers Braze se propagent via Kafka et atteignent Braze en quelques secondes en charge normale.
- Limites de débit Braze : L’intégration effectue automatiquement de nouvelles tentatives sur les réponses
429, en respectant l’en-têtex-ratelimit-retry-afterde Braze avec des délais exponentiels. - Mise en cache du Contenu connecté : Braze met en cache les réponses du Contenu connecté pendant plusieurs minutes par défaut. Pour les valeurs qui doivent être exactes au moment de l’envoi (comme le solde de points), réduisez ou contournez la fenêtre de cache dans l’appel de Contenu connecté.
- Une configuration par programme : Chaque programme de fidélité correspond à un seul espace de travail Braze. Pour connecter un second espace de travail, configurez-le sur un programme distinct.
- Observabilité : Les statistiques d’appels API par programme et l’historique des erreurs (dans les deux sens) sont conservés pendant 90 jours et disponibles depuis la carte d’intégration Braze dans Selfservice.
Résolution des problèmes
- Les événements n’apparaissent pas dans Braze : Vérifiez que la valeur utilisée comme identifiant (sélectionnée à l’étape 1) correspond à l’
external_id(ou au type d’identifiant choisi) de l’utilisateur dans Braze. Des identifiants non concordants entraînent l’attribution des événements au mauvais profil ou leur rejet. - Le webhook renvoie
401: L’en-têteX-Convercus-Keyest manquant ou la clé APIcvc_…a été révoquée. Régénérez la clé dans Selfservice et mettez à jour l’action webhook dans Braze. - Le webhook renvoie
400: La requête ne contient pasContent-Type: application/json, ou le payload ne correspond pas au schéma documenté. Pour le webhook d’abonnement e-mail, un400signifie également que les abonnements demandés sont inconnus du programme ou qu’aucun n’est configuré. - Débogage approfondi : Consultez les statistiques d’appels API par programme et l’historique des erreurs sur la carte d’intégration Braze dans Selfservice, ou contactez votre conseiller Convercus.