Passer au contenu

API E-mail

createEmailMessage

Anchor link to

Crée un message e-mail.

POST https://api.pushwoosh.com/json/1.3/createEmailMessage

Paramètres du corps de la requête

Anchor link to
NomType
RequisDescription
authstringOuiJeton d’accès API depuis le Panneau de Contrôle Pushwoosh.
applicationstringOuiCode d’application Pushwoosh
notificationsarrayOuiTableau JSON contenant les détails du message e-mail. Voir le tableau Paramètres des notifications ci-dessous.

Paramètres des notifications

Anchor link to
NomType
RequisDescription
send_datestringOuiDéfinit quand envoyer l’e-mail. Format : AAAA-MM-JJ HH:mm ou "now".
presetstringOuiCode de préréglage d’e-mail. Copiez depuis la barre d’URL de l’Éditeur de contenu d’e-mail dans le Panneau de Contrôle Pushwoosh.
subjectstring ou objectNonLigne d’objet de l’e-mail. L’e-mail sera toujours dans la langue du contenu. Si subject ne contient pas de langue correspondante pour content, l’objet sera vide.
contentstring ou objectNonLe contenu du corps de l’e-mail. Peut être une chaîne de caractères pour du contenu HTML simple ou un objet pour des versions localisées.
attachmentsarrayNonLes pièces jointes de l’e-mail. Seules deux pièces jointes sont disponibles. Chaque pièce jointe ne doit pas dépasser 1 Mo (encodée en base64).
list_unsubscribestringNonPermet de définir une URL personnalisée pour l’en-tête “Link-Unsubscribe”.
campaignstringNonCode de campagne pour associer l’e-mail à une campagne spécifique.
ignore_user_timezonebooleanNonSi true, envoie l’e-mail immédiatement, en ignorant les fuseaux horaires des utilisateurs.
timezonestringNonEnvoie l’e-mail en fonction du fuseau horaire de l’utilisateur. Exemple : "America/New_York".
filterstringNonEnvoie l’e-mail aux utilisateurs correspondant à une condition de filtre spécifique.
devicesarrayNonListe d’adresses e-mail (max 1000) pour envoyer des e-mails ciblés. S’il est utilisé, le message n’est envoyé qu’à ces adresses. Ignoré si le Groupe d’Applications est utilisé.
use_auto_registrationbooleanNonSi true, enregistre automatiquement les e-mails du paramètre devices.
usersarrayNonS’il est défini, le message e-mail ne sera livré qu’aux ID utilisateur spécifiés (enregistrés via l’appel /registerEmail). Pas plus de 1000 ID utilisateur dans un tableau. Si le paramètre “devices” est spécifié, le paramètre “users” sera ignoré.
dynamic_content_placeholdersobjectNonVariables pour le contenu dynamique à la place des valeurs de tag de l’appareil.
conditionsarrayNonConditions de segmentation utilisant des tags. Exemple : [["Country", "EQ", "BR"]].
fromobjectNonSpécifiez un nom d’expéditeur et un e-mail personnalisés, remplaçant les valeurs par défaut dans les propriétés de l’application.
reply-toobjectNonSpécifiez un e-mail de réponse personnalisé, remplaçant la valeur par défaut dans les propriétés de l’application.
email_typestringNonSpécifiez le type d’e-mail : "marketing" ou "transactional".
email_categorystringRequis lorsque email_type est "marketing".Spécifiez l’un des noms de catégorie configurés dans le centre de préférences d’abonnement (par ex. Newsletter, Promotionnel, Mises à jour produit).
transactionIdstringNonIdentifiant de message unique pour éviter le renvoi en cas de problèmes réseau. Conservé du côté de Pushwoosh pendant 5 minutes.
capping_daysintegerNonLe nombre de jours (max 30) pour appliquer le plafonnement de fréquence par appareil. Note : Assurez-vous que le Plafonnement de fréquence global est configuré dans le Panneau de Contrôle.
capping_countintegerNonLe nombre maximum d’e-mails pouvant être envoyés depuis une application spécifique à un appareil particulier pendant une période de capping_days. Si le message créé dépasse la limite capping_count pour un appareil, il ne sera pas envoyé à cet appareil.
capping_excludebooleanNonSi défini sur true, cet e-mail ne sera pas comptabilisé pour le plafonnement des futurs e-mails.
capping_avoidbooleanNonSi défini sur true, le plafonnement ne sera pas appliqué à cet e-mail spécifique.
send_rateintegerNonLimite le nombre de messages pouvant être envoyés par seconde à tous les utilisateurs. Aide à prévenir la surcharge du backend lors d’envois à grand volume.
send_rate_avoidbooleanNonSi défini sur true, la limite de régulation ne sera pas appliquée à cet e-mail spécifique.

Exemple de requête

Anchor link to
{
"request": {
"auth": "API_ACCESS_TOKEN", // requis. Jeton d'accès API depuis le Panneau de Contrôle Pushwoosh
"application": "APPLICATION_CODE", // requis. Code d'application Pushwoosh.
"notifications": [{
"send_date": "now", // requis. AAAA-MM-JJ HH:mm OU 'now'
"preset": "ERXXX-32XXX", // requis. Copiez le code de préréglage d'e-mail depuis la barre d'URL de
// la page de l'éditeur de contenu d'e-mail dans le Panneau de Contrôle Pushwoosh.
"subject": { // optionnel. Ligne d'objet du message e-mail.
"de": "subject de",
"en": "subject en"
},
"content": { // optionnel. Contenu du corps de l'e-mail.
"de": "<html><body>de Hello, moto</body></html>",
"default": "<html><body>default Hello, moto</body></html>"
},
"attachments": [{ // optionnel. Pièces jointes de l'e-mail
"name": "image.png", // "name" - nom du fichier
"content": "iVBANA...AFTkuQmwC" // "content" - contenu du fichier encodé en base64
}, {
"name": "file.pdf",
"content": "JVBERi...AFTarEGC"
}],
"list_unsubscribe": "URL", // optionnel. Permet de définir une URL personnalisée pour l'en-tête "Link-Unsubscribe"
"campaign": "CAMPAIGN_CODE", // optionnel. Pour assigner ce message e-mail à une campagne particulière,
// ajoutez un code de campagne ici.
"ignore_user_timezone": true, // optionnel.
"timezone": "America/New_York", // optionnel. Spécifiez pour envoyer le message en fonction du
// fuseau horaire défini sur l'appareil de l'utilisateur.
"filter": "FILTER_NAME", // optionnel. Envoyer le message à des utilisateurs spécifiques remplissant les conditions du filtre.
"devices": [ // optionnel. Spécifiez les adresses e-mail pour envoyer des messages e-mail ciblés.
"email_address1", // Pas plus de 1000 adresses dans un tableau.
"email_address2" // S'il est défini, le message ne sera envoyé qu'aux adresses de
], // la liste. Ignoré si le Groupe d'Applications est utilisé.
"use_auto_registration": true, // optionnel. Enregistre automatiquement les e-mails spécifiés dans le paramètre "devices"
"users": [ // optionnel. S'il est défini, le message e-mail ne sera livré qu'aux
"userId1", // ID utilisateur spécifiés (enregistrés via l'appel /registerEmail).
"userId2" // Pas plus de 1000 ID utilisateur dans un tableau.
], // Si le paramètre "devices" est spécifié,
// le paramètre "users" sera ignoré.
"dynamic_content_placeholders": { // optionnel. Variables pour le contenu dynamique à la place des valeurs de tag de l'appareil.
"firstname": "John",
"firstname_en": "John"
},
"conditions": [ // optionnel. Conditions de segmentation, voir la remarque ci-dessous.
["Country", "EQ", "BR"],
["Language", "EQ", "pt"]
],
"from": { // optionnel. Spécifiez un nom d'expéditeur et une adresse e-mail d'expéditeur
"name": "alias from", // pour remplacer les "Nom d'expéditeur" et "E-mail d'expéditeur" par défaut
"email": "from-email@email.com" // configurés dans les propriétés de l'application.
},
"reply-to": { // optionnel. Spécifiez une adresse e-mail pour remplacer
"name": "alias reply to ", // le "Répondre à" par défaut configuré dans les propriétés de l'application.
"email": "reply-to@email.com"
},
"email_type": "marketing", // optionnel. "marketing" ou "transactional".
"email_category": "category name",// requis lorsque email_type est "marketing". Nom de la catégorie.
"transactionId": "unique UUID", // optionnel. Identifiant de message unique pour éviter le renvoi
// en cas de problèmes réseau. Conservé du côté
// de Pushwoosh pendant 5 minutes.
// Paramètres de plafonnement de fréquence. Assurez-vous que le Plafonnement de fréquence global est configuré dans le Panneau de Contrôle.
"capping_days": 30, // optionnel. Nombre de jours pour le plafonnement de fréquence (max 30 jours)
"capping_count": 10, // optionnel. Le nombre maximum d'e-mails pouvant être envoyés depuis une
// application spécifique à un appareil particulier pendant une période de 'capping_days'
// . Si le message créé dépasse la
// limite 'capping_count' pour un appareil, il ne
// sera pas envoyé à cet appareil.
"capping_exclude": true, // optionnel. Si défini sur true, cet e-mail ne sera pas
// comptabilisé pour le plafonnement des futurs e-mails.
"capping_avoid": true, // optionnel. Si défini sur true, le plafonnement ne sera pas appliqué à
// cet e-mail spécifique.
"send_rate": 100, // optionnel. Limite de régulation.
// Limite le nombre de messages pouvant être envoyés par seconde à tous les utilisateurs.
// Aide à prévenir la surcharge du backend lors d'envois à grand volume.
"send_rate_avoid": true, // optionnel. Si défini sur true, la limite de régulation ne sera pas appliquée à
// cet e-mail spécifique.
}]
}
}

Exemples de réponse

Anchor link to
{
"status_code": 200,
"status_message": "OK",
"response": null
}

Conditions des tags

Anchor link to

Chaque condition de tag est un tableau de type [tagName, operator, operand]

  • tagName : nom d’un tag
  • operator : “EQ” | “IN” | “NOTEQ” | “NOTIN” | “LTE” | “GTE” | “BETWEEN”
  • operand : string | integer | array | date

Description de l’opérande

Anchor link to
  • EQ : la valeur du tag est égale à l’opérande ;
  • IN : la valeur du tag croise l’opérande (l’opérande doit toujours être un tableau) ;
  • NOTEQ : la valeur du tag n’est pas égale à un opérande ;
  • NOTIN : la valeur du tag ne croise pas l’opérande (l’opérande doit toujours être un tableau) ;
  • GTE : la valeur du tag est supérieure ou égale à l’opérande ;
  • LTE : la valeur du tag est inférieure ou égale à l’opérande ;
  • BETWEEN : la valeur du tag est supérieure ou égale à la valeur minimale de l’opérande mais inférieure ou égale à la valeur maximale de l’opérande (l’opérande doit toujours être un tableau).

Tags de type chaîne de caractères

Anchor link to

Opérateurs valides : EQ, IN, NOTEQ, NOTIN
Opérandes valides :

  • EQ, NOTEQ : l’opérande doit être une chaîne de caractères ;
  • IN, NOTIN : l’opérande doit être un tableau de chaînes de caractères comme ["valeur 1", "valeur 2", "valeur N"] ;

Tags de type entier

Anchor link to

Opérateurs valides : EQ, IN, NOTEQ, NOTIN, BETWEEN, GTE, LTE
Opérandes valides :

  • EQ, NOTEQ, GTE, LTE : l’opérande doit être un entier ;
  • IN, NOTIN : l’opérande doit être un tableau d’entiers comme [valeur 1, valeur 2, valeur N] ;
  • BETWEEN : l’opérande doit être un tableau d’entiers comme [valeur_min, valeur_max].

Tags de type date

Anchor link to

Opérateurs valides : EQ, IN, NOTEQ, NOTIN, BETWEEN, GTE, LTE
Opérandes valides :

  • "AAAA-MM-JJ 00:00" (chaîne de caractères)
  • timestamp unix 1234567890 (entier)
  • "Il y a N jours" (chaîne de caractères) pour les opérateurs EQ, BETWEEN, GTE, LTE

Tags de type booléen

Anchor link to

Opérateurs valides : EQ
Opérandes valides : 0, 1, true, false

Tags de type liste

Anchor link to

Opérateurs valides : IN
Opérandes valides : l’opérande doit être un tableau de chaînes de caractères comme ["valeur 1", "valeur 2", "valeur N"].

registerEmail

Anchor link to

Enregistre une adresse e-mail pour l’application.

POST https://api.pushwoosh.com/json/1.3/registerEmail

En-têtes de la requête

Anchor link to
NomRequisValeurDescription
AuthorizationOuiToken XXXXJeton d’appareil API pour accéder à l’API Appareil. Remplacez XXXX par votre véritable jeton d’appareil API.

Corps de la requête

Anchor link to
NomTypeDescription
application*stringCode d’application Pushwoosh
email*stringAdresse e-mail.
languagestringLocale de langue de l’appareil. Doit être un code de deux lettres en minuscules conforme à la norme ISO-639-1.
userIdstringID utilisateur à associer à l’adresse e-mail.
tz_offsetintegerDécalage de fuseau horaire en secondes.
tagsobjectValeurs de tag à assigner à l’appareil enregistré.
{
"status_code": 200,
"status_message": "OK",
"response": null
}
Exemple
{
"request": {
"application": "APPLICATION_CODE", // requis. Code d'application Pushwoosh.
"email":"email@domain.com", // requis. Adresse e-mail à enregistrer.
"language": "en", // optionnel. Locale de langue.
"userId": "userId", // optionnel. ID utilisateur à associer à l'adresse e-mail.
"tz_offset": 3600, // optionnel. Décalage de fuseau horaire en secondes.
"tags": { // optionnel. Valeurs de tag à définir pour l'appareil enregistré.
"StringTag": "valeur chaîne",
"IntegerTag": 42,
"ListTag": ["chaîne1","chaîne2"], // définit la liste de valeurs pour les Tags de type Liste
"DateTag": "2024-10-02 22:11", // notez que l'heure doit être en UTC
"BooleanTag": true // les valeurs valides sont : true, false
}
}
}

deleteEmail

Anchor link to

Supprime une adresse e-mail de votre base d’utilisateurs.

POST https://api.pushwoosh.com/json/1.3/deleteEmail

En-têtes de la requête

Anchor link to
NomRequisValeurDescription
AuthorizationOuiToken XXXXJeton d’appareil API pour accéder à l’API Appareil. Remplacez XXXX par votre véritable jeton d’appareil API.

Corps de la requête

Anchor link to
NomTypeDescription
applicationstringCode d’application Pushwoosh
emailstringAdresse e-mail utilisée dans la requête /registerEmail.
{
"status_code": 200,
"status_message": "OK",
"response": null
}
Exemple
{
"request": {
"application": "APPLICATION_CODE", // requis. Code d'application Pushwoosh
"email": "email@domain.com" // requis. E-mail à supprimer des abonnés de l'application.
}
}

setEmailTags

Anchor link to

Définit les valeurs des tags pour l’adresse e-mail.

POST https://api.pushwoosh.com/json/1.3/setEmailTags

En-têtes de la requête

Anchor link to
NomRequisValeurDescription
AuthorizationOuiToken XXXXJeton d’appareil API pour accéder à l’API Appareil. Remplacez XXXX par votre véritable jeton d’appareil API.

Corps de la requête

Anchor link to
NomTypeDescription
applicationstringCode d’application Pushwoosh
emailstringAdresse e-mail.
tagsobjectObjet JSON des tags à définir, envoyez ‘null’ pour supprimer la valeur.
userIdstringID utilisateur associé à l’adresse e-mail.
{
"status_code": 200,
"status_message": "OK",
"response": {
"skipped": []
}
}
Exemple
{
"request": {
"email": "email@domain.com", // requis. Adresse e-mail pour laquelle définir les tags.
"application": "APPLICATION_CODE", // requis. Code d'application Pushwoosh.
"tags": {
"StringTag": "valeur chaîne",
"IntegerTag": 42,
"ListTag": ["chaîne1", "chaîne2"],
"DateTag": "2024-10-02 22:11", // heure en UTC
"BooleanTag": true // les valeurs valides sont : true, false
},
"userId": "userId" // optionnel. ID utilisateur associé à l'adresse e-mail.
}
}

registerEmailUser

Anchor link to

Associe un ID utilisateur externe à une adresse e-mail spécifiée.

POST https://api.pushwoosh.com/json/1.3/registerEmailUser

Peut être utilisé dans l’appel API /createEmailMessage (le paramètre ‘users’).

En-têtes de la requête

Anchor link to
NomRequisValeurDescription
AuthorizationOuiToken XXXXJeton d’appareil API pour accéder à l’API Appareil. Remplacez XXXX par votre véritable jeton d’appareil API.

Corps de la requête

Anchor link to
NomTypeDescription
application*stringCode d’application Pushwoosh
email*stringAdresse e-mail.
userId*stringID utilisateur à associer à l’adresse e-mail.
tz_offsetintegerDécalage de fuseau horaire en secondes.
{
"status_code": 200,
"status_message": "OK",
"response": null
}
Exemple
{
"request": {
"application": "APPLICATION_CODE", // requis. Code d'application Pushwoosh.
"email": "email@domain.com", // requis. Adresse e-mail de l'utilisateur.
"userId": "userId", // requis. ID utilisateur à associer à l'adresse e-mail.
"tz_offset": 3600 // optionnel. Décalage de fuseau horaire en secondes.
}
}