- event.refresh_token : Fournit des renseignements pertinents pour les refresh_tokens existants, y compris les données
id
,created_at
,expires_at
,idle_expires_at
,clients_id
, des données liées àdevice
, commeASN
,IP
etUser_agent
, et pour les flux basés sur le navigateur,session_id
. Cet objet est rempli par des flux d’échange de jetons d’actualisation. - api.refreshToken : Vous permet de gérer les jetons d’actualisation existants en révoquant des sessions ou en modifiant les dates d’expiration.
event.refresh_token
pour examiner la propriété last_exchange_at
et évaluer les risques associés aux transactions en cours. Vous pouvez également combiner l’objet event.refresh_token
avec d’autres objets d’événement, tels que event.authentication
.
Vous pouvez ensuite utiliser l’objet api.refreshToken
pour définir des dates d’expiration du jeton d’actualisation ou révoquer le jeton d’actualisation.
Pour en savoir plus sur ces objets, consultez :
- Objet événement : En savoir plus sur l’objet et les propriétés d’événement de jeton d’actualisation.
- Objet API : En savoir plus sur l’objet API du jeton d’actualisation et ses méthodes.
Révoquer les jetons d’actualisation à l’aide d’actions
La méthode post-connexion api.refreshToken.revoke(reason) vous permet de réagir aux risques associés à une transaction. Révoquer le jeton d’actualisation invalide celui-ci, renvoie un code d’état HTTP 403 pour refuser la transaction en cours et enregistre un événement révoqué de jeton d’actualisation dans les journaux du client (srrt
).
Si vous souhaitez utiliser la méthode
api.refreshToken.revoke(reason)
, assurez-vous que l’objet event.refresh_token existe.Surveiller les événements de révocation du journal
L’opération de révocation ajoute l’événement de journal suivant dans vos journaux du locataire : Un code d’événementsrrt
indiquant qu’un jeton d’actualisation a été révoqué.
Si le jeton d’actualisation est lié à une session précédemment authentifiée, le journal inclura une référence à la session authentifiée dans l’attribut session_id
.
Cas d’utilisation des jetons d’actualisation avec les Actions
Vous pouvez modifier les dates d’expiration des jetons d’actualisation avec les méthodes de post-connexion suivantes :- api.refreshToken.setExpiresAt(absolute) vous permet de définir une nouvelle date d’expiration absolue pour un jeton d’actualisation spécifié.
- api.refreshToken.setIdleExpiresAt(idle) vous permet de définir une nouvelle date d’expiration du délai d’inactivité pour un jeton d’actualisation spécifié.
- L’organisation d’un utilisateur
- La connexion Auth0 d’un utilisateur
- L’adhésion ou le profil de groupe d’un utilisateur spécifique
- L’évaluation des risques
- Tout autre critère dynamique disponible lors de l’exécution de l’Action
api.refreshToken.setExpiresAt(absolute)
et api.refreshToken.setIdleExpiresAt(idle)
permettent de définir l’expiration d’un jeton d’actualisation, avant son émission, ou de modifier l’expiration d’un jeton d’actualisation existant au cours d’un flux échange de jetons d’actualisation.api.refreshToken.setExpiresAt(absolute)
et api.refreshToken.setIdleExpiresAt(idle)
convertissent les jetons d’actualisation qui n’expirent pas en jetons d’actualisation expirant en utilisant les paramètres par défaut Refresh Token Expirations (Expirations du jeton d’actualisation) comme valeurs maximales.api.refreshToken.setIdleExpiresAt(idle)
définit le délai d’inactivité pour les jetons d’actualisation. Si la méthode n’est pas appelée dans tous les échanges réussis, le délai d’inactivité sera écrasé à l’aide des paramètres de l’application de durée de vie du jeton d’actualisation.Limites
Les jetons d’actualisation émis à partir du 21-09-2023 (22-02-2024 pour les locataires de la région US-3) contiennent la propriété identification de session (session_id
) avec la valeur appropriée. Les jetons d’actualisation émis avant cette date contiennent cette propriété avec une valeur null
.
Les jetons d’actualisation émis avant la publication de la méthode API post-connexion api.refreshToken.revoke(reason)
ne contiendront pas les données event.refresh_token.device
.
Les jetons d’actualisation qui n’expirent pas ou les jetons d’actualisation qui n’ont pas été échangés ne contiendront pas la propriété event.refresh_token.last_exchanged_at
.
Pour des raisons de sécurité, les délais d’inactivité et absolu ne peuvent pas être définis au-dessus des paramètres du jeton d’actualisation de l’application définis dans les dates d’ expiration du jeton d’actualisation. Si vous tentez de définir une date au-dessus des paramètres d’expiration, les méthodes de l’API la mettront à jour en fonction des dates d’ expiration des jetons d’actualisation et enregistreront un événement d’avertissement ( w
) dans les journaux du locataire.
Cas d’utilisation : Révocation d’un jeton d’actualisation
Vous pouvez utiliser les Actions pour configurer les détections de risques et révoquer les jetons d’actualisation avec la méthodeapi.refreshToken.revoke(reason)
et les objets d’événement.
Révoquer les jetons d’actualisation en raison d’ImpossibleTravel
Vous pouvez utiliser l’objet évaluations de l’authentification multifacteur () adaptative pour déterminer si un utilisateur se connecte à partir d’un lieu qui indique ImpossibleTravel et révoquer le jeton d’actualisation associé à la transaction.event.authentication.ImpossibleTravel.code
est égal à impossible_travel_from_last_login property
. Si la valeur est true
, l’Action appelle api.refreshToken.revoke()
pour :
- refuser la transaction;
- Révoquer le jeton d’actualisation
- renvoyer une erreur « 403 access_denied »;
- émettre l’erreur « Jeton d’actualisation révoqué en raison d’un voyage impossible »
Révoquer les jetons d’actualisation en raison d’une liaison IP
Si vous utilisez les propriétés des objets post-connexionevent.refresh_token.device.initial_ip
et event.request.ip
, vous pouvez vous assurer qu’une transaction de jeton d’actualisation conserve la même adresse IP pendant toute sa durée. Dans ce scénario, tout changement d’IP est considéré comme un risque et un nouveau jeton d’actualisation est nécessaire.
event.refresh_token.device.initial_ip
et event.request.ip
. L’Action détermine si l’adresse IP de la transaction a changé. Si la valeur est true
, l’Action appelle api.refreshToken.revoke()
pour :
- refuser la transaction;
- Révoquer le jeton d’actualisation
- renvoyer une
erreur
403access_denied
- émettre l’erreur «
Invalid IP change
» (Changement d’adresse IP invalide)
request.asn
et event.refresh_token.device.initial_asn
pour surveiller les changements d’ASN au lieu des changements d’IP.
Cas d’utilisation : Personnaliser les dates d’expiration des jetons d’actualisation
Vous pouvez utiliser des Actions pour personnaliser la durée de vie et les dates d’inactivité des jetons d’actualisation. Plus précisément, vous pouvez configurer les dates d’expiration d’inactivité et absolue du jeton d’actualisation pour une transaction particulière à l’aide des méthodes post-connexionapi.refreshToken.setExpiresAt(absolute)
et api.refreshToken.setIdleExpiresAt(idle)
Personnalisation de la date d’expiration absolue du jeton d’actualisation en fonction de l’organisation
Vous pouvez utiliser l’Action post-connexion pour définir une durée de vie du jeton d’actualisation par organisation. L’exemple ci-dessous utilise les métadonnéesrefresh_token_timeout
de l’Organization pour définir l’heure d’expiration du jeton d’actualisation.
- Jetons nouvellement émis :
current_time
plusorganization_refresh_token_lifetime
- Jetons existants :
event.refresh_token.created_at
plusorganization_refresh_token_lifetime
Personnalisation du délai d’inactivité du jeton d’actualisation en fonction du rôle d’adhésion
Vous pouvez utiliser l’action post-connexion pour définir un délai d’inactivité du jeton d’actualisation à l’aide des métadonnées de l’application et de l’utilisateur. L’exemple ci-dessous utilise les rôles de métadonnées de l’utilisateur pour définir le rôle d’adhésion de l’utilisateur et les métadonnées de l’application pour définir le délai d’inactivité du jeton d’actualisation attendu.current_time
plus le refresh_token_idle_timeout
. Notez que nous modifions le délai d’expiration des jetons nouvellement émis et des jetons existants lors de l’échange de jetons d’actualisation.