Simple Authentication and Security Layer
Simple Authentication and Security Layer (signifiant « Couche d'authentification et de sécurité simple » ou SASL) est un cadre d'authentification et d'autorisation standardisé par l'IETF.
Le cadre découple les mécanismes d'authentification des protocoles d'application, permettant en théorie à n'importe quel mécanisme d'authentification pris en charge par SASL d'être employé à partir de n'importe quel protocole d'application capable d'utiliser SASL. Les mécanismes d'authentification peuvent également opérer l'autorisation par serveur mandataire, une technique permettant à un utilisateur d'agir au nom d'un autre. Les mécanismes d'authentification peuvent également fournir une couche d'intégrité des données laquelle permet d'offrir des services de sécurité des données et de confidentialité des données. Un exemple connu d'une telle couche d'intégrité des données est DIGEST-MD5. Les protocoles d'application qui proposent SASL prennent très souvent en charge le protocole de sécurisation des échanges TLS en complément des services offerts par SASL.
SASL est au départ apparu dans le RFC 2222[1], écrit par John Meyers alors à l'Université de Carnegie Mellon. La spécification actuelle se trouve dans le RFC 4422[2], écrit par Alexey Melnikov et Kurt Zeilenga. Le RFC 4422[3] rend le RFC 2222[4] obsolète. SASL est actuellement un standard proposé de l'IETF.
Mécanismes SASL
[modifier | modifier le code]Un mécanisme SASL est conçu comme une série de demandes d'accès et de réponses. Quelques-uns des mécanismes actuellement définis[5] sont :
- "EXTERNAL", l'authentification est dérivée du contexte (par exemple pour les protocoles employant déjà IPsec ou TLS)
- "ANONYMOUS", accès anonyme sans authentification.
- "PLAIN", mot de passe en clair. (PLAIN rend obsolète le mécanisme LOGIN.)
- "OTP", mécanisme de mot de passe à usage unique. (OTP rend obsolète le mécanisme SKEY.)
- "SKEY", mécanisme de mot de passe à usage unique S/KEY.
- "CRAM-MD5", mécanisme basé sur HMAC-MD5.
- "DIGEST-MD5", mécanisme basé sur MD5 et compatible HTTP. (DIGEST-MD5 fournit une couche d'intégrité des données.)
- "SCRAM", mécanisme moderne utilisant une authentification challenge-réponse supportant la liaison de canal (RFC 5802[6]).
- "NTLM", mécanisme d'authentification pour réseau local NT.
- "GSSAPI", pour l'authentification Kerberos V via GSSAPI. (GSSAPI fournit une couche d'intégrité des données.)
Un ensemble de mécanismes SASL est conçu de manière à pouvoir reconnaître n'importe quel mécanisme GSSAPI.
Applications compatibles SASL
[modifier | modifier le code]Les protocoles d'application définissent leur représentation des échanges via SASL au moyen d'un profil. Un protocole a un nom de service tel que « ldap » dans une base de registre partagée avec GSSAPI et Kerberos. Les protocoles gérant actuellement SASL incluent BEEP, IMAP, LDAP, POP, SMTP, XMPP ou encore IRC.
Implémentations
[modifier | modifier le code]Notes et références
[modifier | modifier le code]- (en) « Simple Authentication and Security Layer (SASL) », Request for comments no 2222,
- (en) « Simple Authentication and Security Layer (SASL) », Request for comments no 4422,
- (en) Request for comments no 4422
- (en) Request for comments no 2222
- IANA : Simple Authentication and Security Layer (SASL) Mechanisms
- (en) Request for comments no 5802
- (en) Dovecot SASL
- (en) Cyrus SASL, bibliothèque développée et maintenue par l'université Carnegie-Mellon.
Article connexe
[modifier | modifier le code]Liens externes
[modifier | modifier le code]- (en) RFC 2222[1] (obsolète)
- (en) RFC 4422[2]
- (en) RFC 4505[3]
- (en) Le SASL Working Group de l'IETF