Biscuit
Token d'authentification et d'autorisation
cryptographique à droits atténuables
hors ligne
@_Akanoa_
https://lafor.ge
Yannick Guern
Requêter une ressource
Requête d'une ressource privilégiée
Authentification par mot de passe
à chaque fois ! 😡
Conserver l'authentification : session et cookie de session
Utilisation du cookie
Cookie de session utilisé sur une API sans session
Problème de session
non partagée
Première solution :
Cache partagé
Deuxième solution :
Les droits dans le cookie ...
... une très mauvaise idée !!
Clefs asymétriques
Token : Signature de données
Vérification d'authenticité
du Token
Prérogatives d'un Token
Un token possédant tous les droits d'un utilisateur
Un token à droits limités
Atténuation de droits
Requête valide
Tentative d'écriture avec un Biscuit en lecture seul
Tentative de lecture d'une ressource interdite
Atténuation
Atténuation offline ...
... oui mais
Geoffroy
Couprie
Clément
Delafargue
Les créateurs de Biscuit
Les briques de base de Biscuit
Du token ...
... au Biscuit
Validation de l'authenticité d'un Biscuit
Création de l'Autorité
Anatomie d'un Biscuit
Création d'un Bloc
Blockchain !!
Un Biscuit atténué
Validation d'un Biscuit
Falsification de Biscuit
Autorisateur
Processus d'autorisation
Scénarios d'échecs d'autorisation
Scénario 1 d'échec de check
Scénario 2 d'échec de check
Scénario 3 d'échec de check
Scénario 4 : check réussi
Le check d'un bloc 1 verra les faits de l'Autorité et du bloc 1
Le check d'un bloc 2 verra les faits de l'Autorité et du bloc 2
Un check de l'Autorité ne verra pas les fait des blocs
Datalog de l'Autorisateur
L'autorisateur ne s'occupe que des faits de l'Autorité et des siens
Un check dans un bloc verra les faits du bloc lui-même, de l'Autorité et de l'Autorisateur
Un check de l'autorité verra les faits de l'Autorité et de l'Autorisateur
Impossibilité de s'augmenter ses droits
Processus d'authentification par Biscuit
Un datalog simpliste ...
... trop simpliste!
Comment gérer des milliers d'utilisateurs ?
Concept de lookup
Contenu de la BDD de droits
Création du fait rights
Processus de validation par l'autorisateur
Échec de création du fait
Échec de validation: le fait rights n'existe pas
Bloc d'atténuation
Jane requête avec son Biscuit atténué fourni par Jack
Processus de validation supplémentaire fourni par le bloc
Jane tente d'accéder à des ressources interdites
Le bloc l'empêche de le faire
Bilan
Playground
Mon article de vulgarisation
Le site officiel
Merci à toutes et tous 😃
@_Akanoa_
https://lafor.ge
Biscuit Touraine Tech
By akanoa
Biscuit Touraine Tech
- 248