- event.refresh_token : Fournit des renseignements pertinents sur les refresh_tokens existants, notamment
id,created_at,expires_at,idle_expires_at,clients_id, les renseignements surdevice, commeASN,IPetUser_agent, ainsi que, pour les flux basés sur le navigateur,session_id. Cet objet est alimenté par les flux d’échange de jeton 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 aussi combiner l’objet event.refresh_token avec d’autres objets d’événement, comme event.authentication.
Vous pouvez ensuite utiliser l’objet api.refreshToken pour définir les dates d’expiration du jeton d’actualisation ou révoquer le jeton d’actualisation.
Pour en savoir plus sur ces objets, consultez :
- objet d’événement : Découvrez l’objet d’événement du jeton d’actualisation et ses propriétés.
- objet API : Découvrez l’objet API du jeton d’actualisation et ses méthodes.
Révoquer les jetons d’actualisation avec Actions
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 journalisation de révocation
srrt indiquant qu’un jeton d’actualisation a été révoqué.
Si le jeton d’actualisation est lié à une session précédemment authentifiée, l’entrée de journal inclura une référence à la session authentifiée dans l’attribut session_id.
Modifier les dates d’expiration des jetons d’actualisation avec Actions
- api.refreshToken.setExpiresAt(absolute) vous permet de définir une nouvelle date d’expiration absolue pour un jeton d’actualisation donné.
- api.refreshToken.setIdleExpiresAt(idle) vous permet de définir une nouvelle date d’expiration liée au délai d’inactivité pour un jeton d’actualisation donné.
- l’organisation d’un utilisateur
- la connexion Auth0 d’un utilisateur
- l’appartenance d’un utilisateur à un groupe ou son profil
- l’évaluation du risque
- tout autre critère dynamique disponible lors de l’exécution de l’Action
Les méthodes
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 pendant un flux d’échange de jeton d’actualisation.Les méthodes api.refreshToken.setExpiresAt(absolute) et api.refreshToken.setIdleExpiresAt(idle) convertissent les jetons d’actualisation sans expiration en jetons d’actualisation avec expiration en utilisant comme valeurs maximales les paramètres par défaut de Refresh Token expirations.La méthode api.refreshToken.setIdleExpiresAt(idle) définit le délai d’expiration lié à l’inactivité des jetons d’actualisation. Si elle n’est pas appelée à chaque échange réussi, ce délai d’expiration sera remplacé par les paramètres de l’application pour la durée de vie du jeton d’actualisation.Limitations
-
Les jetons d’actualisation émis à compter du 21-09-2023 (du 22-02-2024 pour les locataires de la région US-3) contiennent la propriété d’identifiant de session (
session_id) avec la valeur correspondante. Les jetons d’actualisation émis avant cette date contiennent cette propriété avec la valeurnull. -
Les jetons d’actualisation émis avant la mise en disponibilité de la méthode d’API post-login
api.refreshToken.revoke(reason)ne contiennent pas l’informationevent.refresh_token.device. -
Les jetons d’actualisation sans expiration ou les jetons d’actualisation qui n’ont pas été échangés ne contiennent pas la propriété
event.refresh_token.last_exchanged_at. -
Pour des raisons de sécurité, les délais d’expiration d’inactivité et les délais d’expiration absolus ne peuvent pas être définis au-delà des paramètres d’expiration des jetons d’actualisation de l’application définis dans l’expiration des jetons d’actualisation. Si vous tentez de définir une valeur supérieure aux paramètres d’expiration, les méthodes d’API effectueront la mise à jour jusqu’aux valeurs de l’expiration des jetons d’actualisation et consigneront un événement d’avertissement (
w) dans les journaux du locataire. -
api.refreshToken.setExpiresAt()etapi.refreshToken.setIdleExpiresAt()peuvent uniquement raccourcir leur durée de validité respective par rapport aux valeurs actuelles. Elles ne peuvent pas la prolonger ni l’augmenter.
Cas d’utilisation : Révoquer un jeton d’actualisation
api.refreshToken.revoke(reason) ainsi que des objets d’événement.
Révoquer des jetons d’actualisation en cas d’ImpossibleTravel
event.authentication.ImpossibleTravel.code est égal à la propriété impossible_travel_from_last_login. Si la valeur est true, l’Action appelle api.refreshToken.revoke() pour :
- Refuser la transaction
- Révoquer le jeton d’actualisation
- Renvoyer une erreur
access_deniedavec une réponse 403 - Retourner l’erreur « Jeton d’actualisation révoqué en raison d’un déplacement impossible »
Révoquer les jetons d’actualisation en raison de la liaison à l’adresse IP
event.refresh_token.device.initial_ip et event.request.ip pour vous assurer qu’une transaction de jeton d’actualisation reste liée à la même adresse IP pendant toute sa durée de vie. Dans ce scénario, tout changement d’adresse IP est considéré comme un risque et exige un nouveau jeton d’actualisation.
event.refresh_token.device.initial_ip et event.request.ip. L’Action détermine si l’adresse IP de la transaction a changé. Si true, l’Action appelle api.refreshToken.revoke() pour :
- Refuser la transaction
- Révoquer le jeton d’actualisation
- Renvoyer une erreur
access_deniedavec une réponse403 - Produire l’erreur «
Invalid IP change»
request.asn et event.refresh_token.device.initial_asn afin de surveiller les changements d’ASN plutôt que les changements d’adresse IP.
Cas d’utilisation : Personnaliser les dates d’expiration des jetons d’actualisation
api.refreshToken.setExpiresAt(absolute) et api.refreshToken.setIdleExpiresAt(idle).
Personnaliser la date d’expiration absolue du jeton d’actualisation en fonction de l’Organisation
refresh_token_timeout de l’Organisation pour définir la date d’expiration du jeton d’actualisation.
- Jetons nouvellement émis :
current_timeplusorganization_refresh_token_lifetime - Jetons existants :
event.refresh_token.created_atplusorganization_refresh_token_lifetime
Personnaliser le délai d’expiration d’inactivité du jeton d’actualisation en fonction du rôle du membre
current_time plus refresh_token_idle_timeout. Notez que nous modifions ce délai d’expiration à la fois pour les jetons nouvellement émis et pour les jetons existants lors de l’échange du jeton d’actualisation.