Si vous avez installé Messenger sur votre site pour les users connectés, il est essentiel de le sécuriser et d'empêcher les acteurs malveillants d'usurper l'identité de vos users ou d'envoyer des données non autorisées.
Pour améliorer la sécurité et la flexibilité pour nos clients, nous avons introduit JSON Web Tokens (JWTs) comme méthode plus sûre et évolutive pour authentifier les users dans Messenger.
Si vous utilisez actuellement Identity Verification (IDV) pour vérifier les users, passer aux JWTs vous offrira :
Un meilleur contrôle de l'authentification – Gérez vous-même l'expiration et la révocation des sessions, plutôt que de dépendre de configurations fixes.
Une sécurité renforcée – Les JWTs permettent des tokens signés et limités dans le temps, réduisant le risque d'attaques par rejeu.
Une meilleure sécurité des données – Définissez précisément quels attributs users peuvent être mis à jour, réduisant l'exposition des données sensibles.
Une solution pérenne – Les JWTs sont le remplacement recommandé pour IDV, garantissant que votre système d'authentification reste conforme aux meilleures pratiques.
Qui doit migrer ?
Cette migration concerne tous les clients utilisant actuellement IDV, surtout si vous :
✅ Avez besoin d'un meilleur contrôle de l'expiration des sessions et de la révocation des tokens
✅ Souhaitez appliquer des mises à jour sécurisées et spécifiques aux users des attributs
✅ Gérez des données clients sensibles et exigez une authentification renforcée
✅ Prévoyez des améliorations de sécurité à long terme dans votre espace de travail
Bien que IDV continue de fonctionner pour l'instant, les JWTs offrent une approche plus moderne et sécurisée, conforme aux meilleures pratiques d'authentification. Ce guide vous accompagnera étape par étape dans le processus de migration.
Principales différences entre Identity Verification et la sécurité Messenger avec JWTs
| Identity Verification | Sécurité Messenger avec JWTs |
Méthode de vérification | Hachage signé HMAC-SHA256 | Token JWT signé HMAC-SHA256 |
Supporte l'expiration ? | Non | Oui |
Supporte les mises à jour sécurisées des données ? | Non | Oui |
Recommandé pour | Vérification d'identité basique dans Messenger | Authentification sécurisée avec meilleur contrôle des sessions et gestion sécurisée des données |
Étapes de migration
Étape 1 : Mettez à jour votre intégration pour générer des JWTs au lieu de hachages
Cessez de générer des signatures HMAC-SHA256 (alias user_hashes) pour Identity Verification.
[optionnel] Générez une nouvelle clé secrète pour votre Messenger, en choisissant les plateformes auxquelles elle s'applique
Générez un JWT en utilisant votre clé secrète.
Si Identity Verification est déjà activé pour votre espace de travail (indiqué par les paramètres Messenger affichant « installé en toute sécurité »), Intercom n'acceptera que les requêtes contenant soit un user hash valide, soit un JWT valide.
Si vous souhaitez vérifier que votre implémentation JWT fonctionne comme prévu avant de basculer, nous recommandons de faire l'intégration d'abord sur votre espace de test.
Note : les espaces de test et de production ont des clés secrètes Messenger différentes et génèrent donc des user hashes et JSON web tokens différents.
Voici un exemple de configuration côté serveur pour Node.js :
const jwt = require("jsonwebtoken");
const payload = {
user_id: "USER_ID_HERE", // Required
email: "EMAIL_ADDRESS_HERE", // Optional
data_attribute: "YOUR_DATA", // Optional
exp: Math.floor(Date.now() / 1000) + 3600 // Expires in 1hr
};
const secret = process.env.MESSENGER_SECRET_KEY || "YOUR_MESSENGER_SECRET_KEY"; // Secure key storage
const intercomUserJwt = jwt.sign(payload, secret, { algorithm: "HS256" });Que mettre dans la charge utile de votre JWT :
user_idpour identifier le user. Ce champ est obligatoire.Un horodatage optionnel (
exp) pour l'expirationTout autre attribut de données que vous souhaitez envoyer de manière sécurisée pour vos users
Pour des instructions détaillées sur la génération des JWTs pour votre espace de travail, consultez notre article principal du help center ou visitez vos paramètres de sécurité.
Étape 1a : Une note sur les attributs de données
Si vous envoyez actuellement des attributs de données concernant vos users via Messenger, vous devez mettre à jour votre intégration pour envoyer ces attributs de manière sécurisée dans votre JWT user. Pour ce faire, ajoutez les attributs à votre charge utile et assurez-vous que toute requête Messenger non sécurisée soit bloquée.
Dans l'exemple de code ci-dessus, notre charge utile signe le user_id et le email. Elle inclut également une expiration, qui doit aussi être incluse dans la charge utile.
Pour ces attributs, nous devrions maintenant désactiver les mises à jour Messenger non sécurisées pour ces attributs. Cela signifie qu'ils ne peuvent être mis à jour que via un JWT valide et jamais autrement.
Nous vous recommandons d'activer ce bouton pour tout attribut que vous envoyez dans votre JWT. Vous pouvez consulter les attributs de votre espace de travail sous Paramètres > Données > Personnes
Note : Ce bouton de mise à jour des attributs ne vous empêche pas de collecter des données directement auprès des leads avec un bot. Ces données proviennent directement du user.
Étape 2 : Mettez à jour votre extrait frontend pour envoyer des JWTs pour les users
Au lieu de passer une signature HMAC pour IDV, passez le JWT dans les paramètres Messenger sous intercom_user_jwt
Pour le Web (JavaScript SDK) :
window.Intercom("boot", {
api_base: "https://api-iam.intercom.io",
app_id: "<YOUR_APP_ID_HERE",
intercom_user_jwt: "<YOUR_USER_JWT_HERE>"
};
Comme indiqué dans la section précédente, nous envoyons maintenant nos attributs de données dans le JWT et ils ont été retirés de l'extrait.
Pour des instructions détaillées sur la génération des JWTs pour votre espace de travail, consultez notre article principal du help center ou visitez vos paramètres de sécurité. Pour les instructions mobiles, veuillez consulter notre documentation développeur pour iOS et Android.
Dépannage
Il existe des journaux d'échec détaillés et un outil de débogage de token dans vos paramètres de sécurité pour faciliter la transition vers les JWTs.
FAQ
Que se passe-t-il si je ne migre pas ?
Identity Verification continuera de fonctionner pour l'instant, mais les JWTs offrent une sécurité renforcée et un meilleur contrôle.
Comment révoquer une session JWT ?
Vous pouvez définir une courte expiration (exp) ou faire tourner les clés de signature pour invalider les anciens tokens.
Puis-je utiliser Identity Verification et les JWTs ensemble ?
Une fois l'authentification JWT activée pour une plateforme, Identity Verification n'est plus nécessaire. Cependant, vous pouvez utiliser les JWTs et Identity Verification indépendamment sur le web, iOS et Android car ils sont tous configurés individuellement.

