Qu’est-ce qu’un jeton d’accès ?
Un jeton d’accès (aussi appelé
access_token) est une chaîne opaque qui représente une autorisation accordée à l’application. Il peut s’agir d’un identifiant utilisé pour récupérer les renseignements d’autorisation, ou contenir lui-même ces renseignements (par exemple, l’identité de l’utilisateur, les autorisations, etc.) de manière vérifiable.Il est très courant que les jetons d’accès soient implémentés sous forme de JSON Web Tokens.Pour en savoir plus sur les jetons d’accès Auth0, consultez Access Token.scope.
Par la suite, lorsque l’application cliente transmet le jeton d’accès dans ses requêtes à l’API, l’API peut inspecter la revendication scope pour s’assurer que les autorisations requises ont bien été accordées afin d’appeler le point de terminaison d’API en question.
Que sont les scopes ?
Chaque jeton d’accès peut inclure une liste des autorisations qui ont été accordées à l’application cliente. Lorsqu’une application cliente s’authentifie auprès d’Auth0, elle précise la liste des scopes (ou autorisations) qu’elle demande. Si ces scopes sont autorisés, le jeton d’accès contiendra une liste des scopes autorisés.Par exemple, l’API des feuilles de temps peut accepter quatre niveaux d’autorisation différents : lecture des feuilles de temps (scope
read:timesheets), création de feuilles de temps (scope create:timesheets), suppression de feuilles de temps (scope delete:timesheets) et approbation de feuilles de temps (scope approve:timesheets).Lorsqu’une application cliente demande à l’API de créer une nouvelle entrée de feuille de temps, le jeton d’accès doit contenir le scope create:timesheets. De même, pour supprimer des feuilles de temps existantes, le jeton d’accès doit contenir le scope delete:timesheets.Pour en savoir plus sur les scopes, consultez Scopes.Rôles OAuth
Dans tout flux OAuth 2.0, on peut distinguer les rôles suivants :
- Propriétaire de la ressource : l’entité qui peut accorder l’accès à une ressource protégée. Il s’agit généralement de l’utilisateur final.
- Serveur de ressources : le serveur qui héberge les ressources protégées. Il s’agit de l’API à laquelle vous souhaitez accéder.
- Application : une application qui demande l’accès à une ressource protégée au nom du propriétaire de la ressource.
- Serveur d’autorisation : le serveur qui authentifie le propriétaire de la ressource et émet des jetons d’accès après avoir obtenu l’autorisation appropriée. Dans ce cas, il s’agit de l’API d’authentification d’Auth0.
Clé de preuve pour l’échange de code (PKCE)
authorization_code renvoyé par Auth0 et l’échanger contre un Jeton d’accès (et éventuellement un Jeton d’actualisation).
La clé de preuve pour l’échange de code (PKCE) (définie dans la RFC 7636) est une technique utilisée pour atténuer cette attaque par interception du code d’autorisation.
Avec PKCE, l’application crée, pour chaque demande d’autorisation, une clé aléatoire cryptographiquement sécurisée appelée code_verifier et sa valeur transformée appelée code_challenge, qui est envoyée à Auth0 pour obtenir le authorization_code. Lorsque l’application reçoit le authorization_code, elle envoie le code et le code_verifier au d’Auth0 pour les échanger contre les jetons demandés.

- L’application native lance le flux et redirige l’utilisateur vers Auth0 (plus précisément vers le point de terminaison /authorize), en envoyant les paramètres
code_challengeetcode_challenge_method. - Auth0 redirige l’utilisateur vers l’application native avec un
authorization_codedans la chaîne de requête. - L’application native envoie le
authorization_codeet lecode_verifier, ainsi que leredirect_uriet leclient_id, à Auth0. Cela se fait à l’aide du point de terminaison /oauth/token. - Auth0 valide ces renseignements et renvoie un Jeton d’accès (et, facultativement, un Jeton d’actualisation).
- L’application native peut utiliser le Jeton d’accès pour appeler l’API au nom de l’utilisateur.
Si la rotation des Jetons d’actualisation est activée, un nouveau Jeton d’actualisation est généré à chaque demande et émis avec le Jeton d’accès. Lorsqu’un Jeton d’actualisation est échangé, le Jeton d’actualisation précédent est invalidé, mais les renseignements sur cette relation sont conservés par le serveur d’autorisation.