Pour améliorer la sécurité et la flexibilité pour nos clients, nous avons introduit les 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 sur l'expiration des sessions et 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 qu'IDV fonctionne encore pour l'instant, les JWTs offrent une approche plus moderne et sécurisée, conforme aux meilleures pratiques d'authentification. Ce guide vous accompagne pas à pas dans la 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 signé JWT |
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 |
Support SDK mobile : À ce jour, l'authentification JWT est disponible uniquement pour les implémentations Messenger web. Pour les SDK iOS et Android, vous devez continuer à utiliser Identity Verification.
É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 pour Identity Verification.
Générez une nouvelle clé secrète pour votre Messenger, en choisissant les plateformes auxquelles elle doit s'appliquer
À la place, générez un JWT en utilisant votre clé secrète.
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'expirationTous les autres attributs 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 documentation principale.
Note : Si vous envoyez actuellement des attributs de données concernant vos users via Zendesk ou Fin Messenger, vous devez mettre à jour votre intégration pour envoyer ces attributs de manière sécurisée dans votre JWT user. Pour cela, ajoutez les attributs à votre charge utile et assurez-vous que toutes les requêtes Messenger non sécurisées soient bloquées.
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.
É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 (SDK JavaScript) :
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 désormais les 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 documentation.
Mobile (SDK iOS/Android) : Les JWTs ne sont pas encore supportés sur les SDK mobiles. Vous devez continuer à utiliser Identity Verification pour l'instant.
Dépannage
Il existe des journaux d'échec détaillés et un outil de débogage de token dans Paramètres > Messenger > Sécurité pour faciliter la transition vers les JWTs.
Pour plus d'informations, consultez notre guide d'installation ici.
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 JWTs ensemble ?
Une fois l'authentification JWT activée, Identity Verification n'est plus nécessaire. Cependant, vous pouvez utiliser JWTs et Identity Verification indépendamment sur le web, iOS et Android car ils sont configurés individuellement.


