- IPsec
-
IPsec (Internet Protocol Security), défini par l'IETF comme un cadre de standards ouverts pour assurer des communications privées et protégées sur des réseaux IP, par l'utilisation des services de sécurité cryptographiques[1], est un ensemble de protocoles utilisant des algorithmes permettant le transport de données sécurisées sur un réseau IP. IPSec se différencie des standards de sécurité antérieurs en n'étant pas limité à une seule méthode d'authentification ou d'algorithme et c'est la raison pour laquelle il est considéré comme un cadre de standards ouverts[1]. De plus IPSec opère à la couche réseau (couche 3 du modèle OSI) contrairement aux standards antérieurs qui opéraient à la couche application (couche 7 du modèle OSI), ce qui le rend indépendant des applications, et veut dire que les utilisateurs n'ont pas besoin de configurer chaque application aux standards IPSec[1].
Sommaire
Présentation
Réalisée dans le but de fonctionner avec le protocole IPv6, la suite de protocoles IPsec fut adaptée pour l'actuel protocole IP (IPv4).
Son objectif est d'authentifier et de chiffrer les données : le flux ne pourra être compréhensible que par le destinataire final (chiffrement) et la modification des données par des intermédiaires ne pourra être possible (intégrité).
IPsec est souvent un composant de VPN, il est à l'origine de son aspect sécurité (canal sécurisé ou tunneling).
La mise en place d'une architecture sécurisée à base d'IPsec est détaillée dans la RFC 4301.
Fonctionnement
Lors de l'établissement d'une connexion IPsec, plusieurs opérations sont effectuées :
- Échange des clés
- un canal d'échange de clés, sur une connexion UDP depuis et vers le port 500 (ISAKMP pour Internet Security Association and Key Management Protocol).
Le protocole IKE (Internet Key Exchange) est chargé de négocier la connexion. Avant qu'une transmission IPSec puisse être possible, IKE est utilisé pour authentifier les deux extrémités d'un tunnel sécurisé en échangeant des clés partagées. Ce protocole permet deux types d'authentifications, PSK (Pre-Shared Key ou secret partagé) pour la génération de clefs de sessions ou à l'aide de certificats/signatures RSA. Une signature est un certificat signé par une tierce-partie appelée Autorité de certification (AC ou CA) qui offre l'Authentification et la non-répudiation. Sans cette signature, une partie peut simplement nier la responsabilité de messages envoyés.
Sachant que l'usage de la cryptographie asymétrique (clés publiques) peut être utilisé avec IPSec, il ne permet pas la non-répudiation. IPSec utilise une association de sécurité (Security association) pour dicter comment les parties vont faire usage de AH et de l'encapsulation de la charge utile d'un paquet.
- Une association de sécurité (SA) est l'établissement d'information de sécurité partagée entre deux entités de réseau pour soutenir la communication protégée. Une SA peut être établie par une intervention manuelle ou par ISAKMP (Internet Security Association and Key Management Protocol).
- ISAKMP est défini comme un cadre pour établir, négocier, modifier et supprimer des SA entre deux parties. En centralisant la gestion des SA, ISAKMP réduit la quantité de fonctionnalité reproduite dans chaque protocole de sécurité. ISAKMP réduit également le nombre d'heures exigé par l'installation de communications, en négociant tous les services simultanément[2].
- Transfert des données
un ou plusieurs canaux de données par lesquels le trafic du réseau privé est véhiculé, deux protocoles sont possibles :
- le protocole no 51, AH, (Authentication Header) fournit l'intégrité et l'authentification. AH authentifie les paquets en les signant, ce qui assure l'intégrité de l'information. Une signature unique est créée pour chaque paquet envoyé et empêche que l'information soit modifiée[2].
- le protocole no 50, ESP (Encapsulating Security Payload) fournit également l'intégrité mais aussi la confidentialité par l'entremise de la cryptographie.
Modes de fonctionnement
IPsec peut fonctionner dans un mode transport hôte à hôte ou bien dans un mode tunnel réseau.
- Mode transport
Dans le mode transport, ce sont uniquement les données transférées (la partie payload du paquet IP) qui sont chiffrées et/ou authentifiées. Le reste du paquet IP est inchangé et de ce fait le routage des paquets n'est pas impacté. Néanmoins, les adresses IP ne pouvant pas être modifiées sans corrompre le hash de l'en-tête, pour traverser un NAT il faut avoir recours à l'encapsulation NAT-T. Le mode transport est utilisé pour les communications dites hôte à hôte (Host-to-Host).
- Mode tunnel
En mode tunnel, c'est la totalité du paquet IP qui est chiffré et/ou authentifié. Le paquet est ensuite encapsulé dans un nouveau paquet IP avec une nouvelle en-tête IP. Au contraire du mode transport, ce mode supporte donc bien la traversée de NAT. Le mode tunnel est utilisé pour créer des réseaux privés virtuels (VPN) permettant la communication de réseau à réseau (e.g. entre deux sites distants), d'hôte à réseau (e.g. accès à distance d'un utilisateur) ou bien d'hôte à hôte (e.g. messagerie privée.)
Algorithmes cryptographiques
Pour que les réalisations d'IPsec interopèrent, elles doivent avoir un ou plusieurs algorithmes de sécurité en commun. Les algorithmes de sécurité utilisés pour une association de sécurité ESP ou AH sont déterminés par un mécanisme de négociation, tel que Internet Key Exchange (IKE)[3].
Les algorithmes de chiffrement et d'authentification pour IPsec encapsulant le protocole ESP et AH sont :
En référence avec la RFC 4835
Liste des RFC relatives à IPsec
- RFC 2367 : PF_KEY Interface
- RFC 2401 (remplacée par la RFC 4301) : Security Architecture for the Internet Protocol
- RFC 2402 (remplacée par les RFC 4302 et RFC 4305) : Authentication Header
- RFC 2403 : The Use of HMAC-MD5-96 within ESP and AH
- RFC 2404 : The Use of HMAC-SHA-1-96 within ESP and AH
- RFC 2405 : The ESP DES-CBC Cipher Algorithm With Explicit IV
- RFC 2406 (remplacée par les RFC 4303 et RFC 4305) : Encapsulating Security Payload
- RFC 2407 (remplacée par la RFC 4306) : IPsec Domain of Interpretation for ISAKMP (IPsec DoI)
- RFC 2408 (remplacée par la RFC 4306) : Internet Security Association and Key Management Protocol (ISAKMP)
- RFC 2409 (remplacée par la RFC 4306) : Internet Key Exchange (IKE)
- RFC 2410 : The NULL Encryption Algorithm and Its Use With IPsec
- RFC 2411 : IP Security Document Roadmap
- RFC 2412 : The OAKLEY Key Determination Protocol
- RFC 2451 : The ESP CBC-Mode Cipher Algorithms
- RFC 2857 : The Use of HMAC-RIPEMD-160-96 within ESP and AH
- RFC 3526 : More Modular Exponential (MODP) Diffie-Hellman groups for Internet Key Exchange (IKE)
- RFC 3706 : A Traffic-Based Method of Detecting Dead Internet Key Exchange (IKE) Peers
- RFC 3715 : IPsec-Network Address Translation (NAT) Compatibility Requirements
- RFC 3947 : Negotiation of NAT-Traversal in the IKE
- RFC 3948 : UDP Encapsulation of IPsec ESP Packets
- RFC 4106 : The Use of Galois/Counter Mode (GCM) in IPsec Encapsulating Security Payload (ESP)
- RFC 4301 (remplace la RFC 2401) : Security Architecture for the Internet Protocol
- RFC 4302 (remplace la RFC 2402) : IP Authentication Header
- RFC 4303 (remplace la RFC 2406) : IP Encapsulating Security Payload (ESP)
- RFC 4304 : Extended Sequence Number (ESN) Addendum to IPsec Domain of Interpretation (DOI) for Internet Security Association and Key Management Protocol (ISAKMP)
- RFC 4305 : Cryptographic Algorithm Implementation Requirements for Encapsulating Security Payload (ESP) and Authentication Header (AH)
- RFC 4306 (remplace les RFC 2407, RFC 2408, et RFC 2409) : Internet Key Exchange (IKEv2) Protocol
- RFC 4307 : Cryptographic Algorithms for Use in the Internet Key Exchange Version 2 (IKEv2)
- RFC 4308 : Cryptographic Suites for IPsec
- RFC 4309 : Using Advanced Encryption Standard (AES) CCM Mode with IPsec Encapsulating Security Payload (ESP)
- RFC 4478 : Repeated Authentication in Internet Key Exchange (IKEv2) Protocol
- RFC 4543 : The Use of Galois Message Authentication Code (GMAC) in IPsec ESP and AH
- RFC 4555 : IKEv2 Mobility and Multihoming Protocol (MOBIKE)
- RFC 4621 : Design of the IKEv2 Mobility and Multihoming (MOBIKE) Protocol
- RFC 4718 : IKEv2 Clarifications and Implementation Guidelines
- RFC 4806 : Online Certificate Status Protocol (OCSP) Extensions to IKEv2
- RFC 4809 : Requirements for an IPsec Certificate Management Profile
- RFC 4835 (remplace la RFC 4305) : Cryptographic Algorithm Implementation Requirements for Encapsulating Security Payload (ESP) and Authentication Header (AH)
- RFC 4945 : The Internet IP Security PKI Profile of IKEv1/ISAKMP, IKEv2, and PKIX
Controverse
En décembre 2010, Gregory Perry (ex directeur technique de la société NETSEC) a prétendu que des portes dérobées auraient été placées dans le framework OCF d'OpenBSD à la demande du FBI dans les années 2000[4]. Après le respect d'une clause de confidentialité de 10 ans, il a pris contact avec les équipes de développement d'OpenBSD. Cette pile a été réutilisée dans d'autres projet, bien que largement modifiée depuis.
Notes et références
- ISBN 978-1-59749-231-7) How to Cheat at Securing Your Network, Dubrawski, Ido – Burlington, MA : Elsevier, 2007. – p 83. (
- Ibid., p. 85
- RFC 4835
- [1] Le FBI aurait fait placer des backdoors dans le code de la pile IPSec d'OPENBSD
Voir aussi
Articles connexes
Catégories :- TCP/IP
- Sécurité du réseau informatique
- Protocole de communication chiffrée
Wikimedia Foundation. 2010.