Secure Tunnels for Constrained Environments

Total Page:16

File Type:pdf, Size:1020Kb

Secure Tunnels for Constrained Environments THESE DE DOCTORAT DE L’INSA RENNES COMUE UNIVERSITE BRETAGNE LOIRE ECOLE DOCTORALE N° 601 Mathématiques et Sciences et Technologies de l'Information et de la Communication Spécialité : Informatique Par Loïc FERREIRA Tunnels sécurisés pour environnements contraints Thèse présentée et soutenue à Rennes, le 18 novembre 2019 Unité de recherche : IRISA Thèse N° : 19ISAR 18 / D19 - 18 Rapporteurs avant soutenance : Céline Chevalier Maître de conférences, Université Panthéon-Assas Paris 2 Henri Gilbert Directeur du laboratoire de cryptographie, ANSSI Composition du Jury : Président Serge Vaudenay Professeur, EPFL Examinateurs Céline Chevalier Maître de conférences, Université Panthéon-Assas Paris 2 Henri Gilbert Directeur du laboratoire de cryptographie, ANSSI Gildas Avoine Professeur, INSA Rennes Sébastien Canard Ingénieur de recherche, Orange Labs Caroline Fontaine Directrice de recherche CNRS, ENS Paris-Saclay María Naya-Plasencia Directrice de recherche Inria, Inria Paris David Pointcheval Directeur de recherche CNRS, ENS Directeur de thèse Gildas Avoine Professeur, INSA Rennes Co-directeur de thèse Sébastien Canard Ingénieur de recherche, Orange Labs Intitulé de la thèse : Secure Tunnels for Constrained Environments Loïc FERREIRA En partenariat avec : Document protégé par les droits d’auteur Secure Tunnels for Constrained Environments Loïc Ferreira Supervisors: Gildas Avoine and Sébastien Canard In memoriam Maria da Luz Résumé en français tablir une communication sécurisée entre des entités distantes est l’un des objectifs auxquels la cryptographie cherche à répondre. De tels tunnels sécurisés impliquent la Émise en œuvre d’algorithmes cryptographiques de nature (symétrique, asymétrique) et de complexité diérentes. Le besoin de communications sécurisées se manifeste particulièrement avec l’apparition d’objets connectés aux usages très divers et la multiplication des interactions entre ces objets. Le développement de l’Internet des Objets entraîne le déploiement accéléré d’objets dits « à bas coût ». Contrairement à un ordinateur personnel ou un smartphone, ces objets ont des capacités très limitées notamment en termes de calcul, de communication et d’alimentation en énergie. Néanmoins, ces objets participent à la gestion d’infrastructures et d’équipements parfois très sensibles (fourniture d’eau, d’électricité, pacemaker ou débrillateur implanté dans le corps humain, etc.). Les données échangées (dont les commandes reçues) par ces objets doivent donc être protégées à la hauteur de ces usages. Cela requiert un haut niveau de sécurité, permis en général par des mécanismes cryptographiques de relativement grande complexité calculatoire. Or les algorithmes usuellement implémentés sur un ordinateur ou un smartphone ne sont pas fonctionnels sur des objets connectés étant données les capacités réduites de ces derniers. Cette partie introduit les problématiques des protocoles de sécurité destinés aux objets à bas coût. Elle présente également les résultats obtenus au cours de ce travail de doctorat, dont l’objectif est d’analyser la sécurité de protocoles existants et de produire des mécanismes d’échange de clé applicables aux objets à bas coût, sans compromis entre sécurité et ecacité. Contexte L’un des buts de la cryptographie est de permettre à deux entités distantes de communiquer de manière sécurisée. Cet objectif est rempli quotidiennement et de manière transparente lorsque l’on utilise un ordinateur personnel ou un smartphone pour, par exemple, consulter un service bancaire ou parler avec une personne éloignée. La mise en œuvre d’un tel tunnel sécurisé est rendue possible par l’utilisation conjointe d’algorithmes cryptographiques qui ont chacun une fonction diérente. La cryptographie asymétrique intervient alors lors d’une phase qui précède la communication proprement dite. Les algorithmes asymétriques sont utilisés pour que les deux parties impliquées puissent mutuellement s’authentier (i.e. : avoir la garantie de leur identité respective) et permettre de partager des paramètres secrets. Ces paramètres sont ensuite manipulés par des algorithmes symétriques qui vont concrètement protéger les messages (par exemple vocaux, visuels) échangés entre les deux parties. Ils garantissent que ces messages ne sont accessibles qu’aux deux parties légitimes (propriété de condentialité) et qu’il est impossible de modier ces messages à l’insu des deux parties prenant part à la iv Résumé en français communication (propriété d’intégrité). Ces algorithmes qui remplissent des fonctions distinctes ont des caractéristiques techniques diérentes. D’une manière générale, les algorithmes symétriques sont beaucoup plus rapides que les algorithmes asymétriques. Mais, comme indiqué plus haut, les algorithmes asymétriques permettent de garantir des propriétés de sécurité que ne peuvent orir les algorithmes symé- triques. C’est la raison pour laquelle les deux types d’algorithmes sont généralement utilisés dans les protocoles de sécurité : bénéciant pleinement de leur complémentarité, ces protocoles atteignent un niveau de sécurité supérieur. L’une des propriétés de sécurité, fondamentale, rendue possible par la cryptographie asymétrique est la condentialité persistante (ou forward secrecy [Gün90; DvW92]) généralement obtenue par le protocole Die-Hellman (DH) [DH76]. Cette propriété garantit que la divulgation d’un paramètre secret permanent ne compromet pas la sécurité des communications eectuées antérieurement à cette divulgation. Cela permet donc de maintenir la sécurité des communications passées en dépit de la compromission d’un paramètre secret important et réduit l’étendue des conséquences d’une telle compromission. Avec l’émergence de l’Internet des Objets (Internet of Things ou IoT), une multitude d’« objets connectés » sont déployés. Ces objets à bas coût de production ont des capacités de calcul et de communication restreintes. De même ils disposent d’une ressource limitée en termes d’alimenta- tion électrique (ainsi ils peuvent être alimentés à l’aide d’une batterie dont il s’agit d’économiser la consommation, voire ne recevoir d’énergie que lorsqu’ils entrent en communication avec un lecteur). Parmi les cas d’usage impliquant ces objets, on peut citer les réseaux de senseurs sans l (Wireless Sensor Networks ou WSN), la radio-identication (Radio Frequency Identication ou RFID), les cartes à puce, les unités de contrôle véhiculaires (Controller Area Network ou CAN), la domotique, l’IoT industriel et la téléphonie mobile. Ces objets participent à la gestion ou au fonctionnement d’infrastructures ou d’équipements qui rendent des services sensibles tels que la fourniture d’eau, d’électricité ou l’assistance médicale par le biais de pacemakers et de débrillateurs implantés dans le corps humain. Les commandes transmises à ces objets et les données récupérées auprès de ces derniers impliquent donc un niveau de sécurité à la mesure du service qu’ils contribuent à rendre. Or le niveau de sécurité d’un algorithme cryptographique est généralement lié à sa complexité. Si les ordinateurs personnels et les smartphones peuvent exécuter des algorithmes cryptographiques « lourds » et complexes, il n’en est pas de même des objets connectés. Se pose alors, pour ces objets, la diculté de résoudre la contradiction induite par une attente élevée en termes de sécurité et une faible capacité en termes de fonctionnalité et d’ecacité. Un champ de la cryptographie s’attache, approximativement depuis le début du millénaire, à concevoir des algorithmes cryptographiques fonctionnels pour des objets à bas coût. La grande majorité de ces algorithmes sont symétriques. S’agissant de la cryptographie asymétrique, à part quelques exceptions, les eorts tendent, avec des succès mitigés, à optimiser l’implémentation d’algorithmes usuels an de les rendre fonctionnels sur ces objets. Ces travaux constituent une étape importante et nécessaire. Néanmoins, l’établissement d’un tunnel sécurisé suppose plus de fonctionnalités et de propriétés de sécurité qu’un simple algorithme de chirement ou de hachage. Objectifs Etant données les capacités réduites des objets connectés, le choix peut être fait de réduire les fonctionnalités des protocoles de sécurité existants et de choisir des mécanismes cryptogra- phiques peu « coûteux » an que le résultat soit implémentable et fonctionnel dans un objet disposant de faibles capacités. Cette démarche, bien qu’intéressante, n’est toutefois pas com- Contributions v plètement satisfaisante puisqu’elle pose notamment les questions de la souplesse du protocole ainsi obtenu et celle de la sécurité globale oerte. Ainsi, les protocoles existants destinés à l’établissement de communications sécurisées avec ces objets s’appuient sur deux principes généraux. Tout d’abord une seule fonction symétrique est mise en œuvre. Ensuite la sécurité s’appuie sur un unique paramètre secret, exploité par l’objet tout au long de sa vie. Cela ne permet pas de garantir les mêmes propriétés et donc le même niveau de sécurité rendus possibles par l’utilisation additionnelle de mécanismes cryp- tographiques asymétriques. En particulier, la divulgation de cette clé symétrique permanente aboutit à la compromission de toutes les communications futures mais aussi passées que l’objet a établies. L’objectif principal de cette thèse est de concevoir des protocoles d’échange de clé, destinés à permettre l’établissement de tunnels sécurisés entre objets à bas coût, orant un niveau de sécurité plus élevé que les protocoles existants tout en étant fonctionnels sur ces objets. Nous tentons
Recommended publications
  • Scalable Scanning and Automatic Classification of TLS Padding Oracle Vulnerabilities
    Scalable Scanning and Automatic Classification of TLS Padding Oracle Vulnerabilities Robert Merget and Juraj Somorovsky, Ruhr University Bochum; Nimrod Aviram, Tel Aviv University; Craig Young, Tripwire VERT; Janis Fliegenschmidt and Jörg Schwenk, Ruhr University Bochum; Yuval Shavitt, Tel Aviv University https://www.usenix.org/conference/usenixsecurity19/presentation/merget This paper is included in the Proceedings of the 28th USENIX Security Symposium. August 14–16, 2019 • Santa Clara, CA, USA 978-1-939133-06-9 Open access to the Proceedings of the 28th USENIX Security Symposium is sponsored by USENIX. Scalable Scanning and Automatic Classification of TLS Padding Oracle Vulnerabilities Robert Merget1, Juraj Somorovsky1, Nimrod Aviram2, Craig Young3, Janis Fliegenschmidt1, Jörg Schwenk1, and Yuval Shavitt2 1Ruhr University Bochum 2Department of Electrical Engineering, Tel Aviv University 3Tripwire VERT Abstract the encryption key. The attack requires a server that decrypts a message and responds with 1 or 0 based on the message va- The TLS protocol provides encryption, data integrity, and lidity. This behavior essentially provides the attacker with a authentication on the modern Internet. Despite the protocol’s cryptographic oracle which can be used to mount an adaptive importance, currently-deployed TLS versions use obsolete chosen-ciphertext attack. The attacker exploits this behavior cryptographic algorithms which have been broken using var- to decrypt messages by executing adaptive queries.Vaudenay ious attacks. One prominent class of such attacks is CBC exploited a specific form of vulnerable behavior, where im- padding oracle attacks. These attacks allow an adversary to plementations validate the CBC padding structure and re- decrypt TLS traffic by observing different server behaviors spond with 1 or 0 accordingly.
    [Show full text]
  • Arxiv:1911.09312V2 [Cs.CR] 12 Dec 2019
    Revisiting and Evaluating Software Side-channel Vulnerabilities and Countermeasures in Cryptographic Applications Tianwei Zhang Jun Jiang Yinqian Zhang Nanyang Technological University Two Sigma Investments, LP The Ohio State University [email protected] [email protected] [email protected] Abstract—We systematize software side-channel attacks with three questions: (1) What are the common and distinct a focus on vulnerabilities and countermeasures in the cryp- features of various vulnerabilities? (2) What are common tographic implementations. Particularly, we survey past re- mitigation strategies? (3) What is the status quo of cryp- search literature to categorize vulnerable implementations, tographic applications regarding side-channel vulnerabili- and identify common strategies to eliminate them. We then ties? Past work only surveyed attack techniques and media evaluate popular libraries and applications, quantitatively [20–31], without offering unified summaries for software measuring and comparing the vulnerability severity, re- vulnerabilities and countermeasures that are more useful. sponse time and coverage. Based on these characterizations This paper provides a comprehensive characterization and evaluations, we offer some insights for side-channel of side-channel vulnerabilities and countermeasures, as researchers, cryptographic software developers and users. well as evaluations of cryptographic applications related We hope our study can inspire the side-channel research to side-channel attacks. We present this study in three di- community to discover new vulnerabilities, and more im- rections. (1) Systematization of literature: we characterize portantly, to fortify applications against them. the vulnerabilities from past work with regard to the im- plementations; for each vulnerability, we describe the root cause and the technique required to launch a successful 1.
    [Show full text]
  • A Security Analysis of the WPA-TKIP and TLS Security Protocols
    ARENBERG DOCTORAL SCHOOL Faculty of Engineering Science A Security Analysis of the WPA-TKIP and TLS Security Protocols Mathy Vanhoef Supervisor: Dissertation presented in partial Prof. dr. ir. F. Piessens fulfillment of the requirements for the degree of Doctor in Engineering Science: Computer Science July 2016 A Security Analysis of the WPA-TKIP and TLS Security Protocols Mathy VANHOEF Examination committee: Dissertation presented in partial Prof. dr. ir. P. Van Houtte, chair fulfillment of the requirements for Prof. dr. ir. F. Piessens, supervisor the degree of Doctor in Engineering Prof. dr. ir. C. Huygens Science: Computer Science Prof. dr. D. Hughes Prof. dr. ir. B. Preneel Prof. dr. K. Paterson (Royal Holloway, University of London) July 2016 © 2016 KU Leuven – Faculty of Engineering Science Uitgegeven in eigen beheer, Mathy Vanhoef, Celestijnenlaan 200A box 2402, B-3001 Leuven (Belgium) Alle rechten voorbehouden. Niets uit deze uitgave mag worden vermenigvuldigd en/of openbaar gemaakt worden door middel van druk, fotokopie, microfilm, elektronisch of op welke andere wijze ook zonder voorafgaande schriftelijke toestemming van de uitgever. All rights reserved. No part of the publication may be reproduced in any form by print, photoprint, microfilm, electronic or any other means without written permission from the publisher. Preface When I started my PhD four years ago, I thought people were exaggerating when they said that doing a PhD was a unique and special experience. Turns out I was wrong: it is indeed quite the journey! It was a roller coaster of exciting and sometimes no so exciting research results, late-night deadline races, moments of doubt, enriching and rewarding travels, grueling dilemmas, facing your own limitations,.
    [Show full text]
  • Directed Greybox Fuzzing
    Directed Greybox Fuzzing Marcel Böhme Van-Thuan Pham∗ National University of Singapore, Singapore National University of Singapore, Singapore [email protected] [email protected] Manh-Dung Nguyen Abhik Roychoudhury National University of Singapore, Singapore National University of Singapore, Singapore [email protected] [email protected] ABSTRACT However, existing greybox fuzzers cannot be effectively directed.1 Existing Greybox Fuzzers (GF) cannot be effectively directed, for Directed fuzzers are important tools in the portfolio of a security instance, towards problematic changes or patches, towards critical reseacher. Unlike undirected fuzzers, a directed fuzzer spends most system calls or dangerous locations, or towards functions in the of its time budget on reaching specific target locations without stacktrace of a reported vulnerability that we wish to reproduce. wasting resources stressing unrelated program components. Typical In this paper, we introduce Directed Greybox Fuzzing (DGF) applications of directed fuzzers may include which generates inputs with the objective of reaching a given set • patch testing [4, 21] by setting changed statements as targets. of target program locations efficiently. We develop and evaluate When a critical component is changed, we would like to check a simulated annealing-based power schedule that gradually as- whether this introduced any vulnerabilities. Figure 1 shows the signs more energy to seeds that are closer to the target locations commit introducing Heartbleed [49]. A fuzzer that focusses on while reducing energy for seeds that are further away. Experiments those changes has a higher chance of exposing the regression. with our implementation AFLGo demonstrate that DGF outper- • crash reproduction [18, 29] by setting method calls in the forms both directed symbolic-execution-based whitebox fuzzing stack-trace as targets.
    [Show full text]
  • The Rocky Road To
    The Rocky Road to Hanno Böck https://hboeck.de @hanno 1 Transport Layer Security A protocol to create an encrypted and authenticated layer around other protocols 2 TLS 1.3 was published in August 2018 3 How did we get there? 4 In 1995 Netscape introduced Secure Socket Layer or SSL version 2 5 In 1996 it was followed up with SSL version 3 6 In 1999 the IETF took over and renamed it to TLS 7 SSL/TLS History 1995: SSL 2 1996: SSL 3 1999: TLS 1.0 2006: TLS 1.1 2008: TLS 1.2 2018: TLS 1.3 8 Vulnerabilities C C S 9 Padding Oracles in CBC mode 10 Plaintext Plaintext Plaintext Initialization Vector (IV) block cipher block cipher block cipher Key Key Key encryption encryption encryption Ciphertext Ciphertext Ciphertext WhiteTimberwolf, Wikimedia Commons, Public Domain 11 CBC Padding for Block Ciphers (AES) Encryption of data blocks means we have to fill up space 12 CBC in TLS MAC-then-Pad-then-Encrypt 13 Valid Padding 00 01 01 02 02 02 03 03 03 03 ... 14 We assume a situation where the attacker can see whether the padding is valid 15 Ciphertext Ciphertext block cipher block cipher Key Key decryption decryption Initialization Vector (IV) ?== 00 -> padding valid Plaintext Plaintext Attacker wants to decrypt Attacker manipulates / XOR with guess 16 Ciphertext Ciphertext block cipher block cipher Key Key decryption decryption Initialization Vector (IV) ?== 01 01 -> padding valid Plaintext Plaintext Attacker knows Attacker manipulates to 01 Attacker wants to know Attacker manipulates to guess 01 17 2002: Serge Vaudenay discovers Padding Oracle Vaudenay,
    [Show full text]
  • An Analysis of the Transport Layer Security Protocol
    An Analysis of the Transport Layer Security Protocol Thyla van der Merwe Thesis submitted to the University of London for the degree of Doctor of Philosophy Information Security Group School of Mathematics and Information Security Royal Holloway, University of London 2018 Declaration These doctoral studies were conducted under the supervision of Professor Kenneth G. Paterson. The work presented in this thesis is the result of original research I conducted, in collabo- ration with others, whilst enrolled in the School of Mathematics and Information Security as a candidate for the degree of Doctor of Philosophy. This work has not been submitted for any other degree or award in any other university or educational establishment. Thyla van der Merwe March, 2018 2 Dedication To my niece, Emma. May you always believe in your abilities, no matter what anybody tells you, and may you draw on the strength of our family for support, as I have done (especially your Gogo, she’s one tough lady). “If you’re going through hell, keep going.” Winston Churchill 3 Abstract The Transport Layer Security (TLS) protocol is the de facto means for securing commu- nications on the World Wide Web. Originally developed by Netscape Communications, the protocol came under the auspices of the Internet Engineering Task Force (IETF) in the mid 1990s and today serves millions, if not billions, of users on a daily basis. The ubiquitous nature of the protocol has, especially in recent years, made the protocol an attractive target for security researchers. Since the release of TLS 1.2 in 2008, the protocol has suffered many high-profile, and increasingly practical, attacks.
    [Show full text]
  • IETF Hackathon
    IETF 106 TEEP Hackathon Report Akira Tsukamoto, Nov. 19, 2019 IETF 106 Hackathon - TEEP 1 What we planned • Open Trust Protocol: • Evaluate OTrPv1 vs TEEP (aka OTrPv2) proposal • Test implementations of OTrP-over-HTTP • draft-ietf-teep-otrp-over-http-02 • Brought prototypes of TAM and TEEP device • TAM with node-js by Isobe-san • TAM with SGX by Dave Thaler • TEEP device on OP-TEE by Akira Tsukamoto • TEEP device on SGX by Dave Thaler IETF 106 Hackathon - TEEP 2 Great TEEm IETF 106 Hackathon - TEEP 3 What got done • First time to interop OTrP/TEEP protocol implementations built from specs. • See pictures on following pages. IETF 106 Hackathon - TEEP 4 On the Table IETF 106 Hackathon - TEEP 5 TAM`s UI for uploading TA IETF 106 Hackathon - TEEP 6 TEEP device IETF 106 Hackathon - TEEP 7 Hacking, Debugging! IETF 106 Hackathon - TEEP 8 TEEP Device installing TA IETF 106 Hackathon - TEEP 9 What we learned • Filed issues • draft-ietf-teep-otrp-over-http-03 • #5: demuxing TEEP vs OTrP • draft-tschofenig-teep-protocol-00.txt • Would like to have JSON example • A lot of implementation action items • Prerequisite required for OTrP/TEEP • HTTP, JSON, CBOR stack must be completely working • Understand TEE concepts, such as SGX, Arm TrustZone, knowledge of implementation details (e.g. OP-TEE) IETF 106 Hackathon - TEEP 10 What went well • Constructing stand alone wired network on Hackathon table for TAMs and TEEP devices but having uplink • This will prevent harming IETF network when sending broken packets. • My TEEP device needs to talk to ntp, since does not have RTC.
    [Show full text]
  • Coming of Age: a Longitudinal Study of TLS Deployment
    Coming of Age: A Longitudinal Study of TLS Deployment Platon Kotzias Abbas Razaghpanah Johanna Amann IMDEA Software Institute Stony Brook University ICSI/Corelight/LBNL Universidad Politécnica de Madrid Kenneth G. Paterson Narseo Vallina-Rodriguez Juan Caballero Royal Holloway, University of London IMDEA Networks Institute IMDEA Software Institue ICSI ABSTRACT of each new attack and vulnerability that is discovered. Over the The Transport Layer Security (TLS) protocol is the de-facto standard last few years various TLS vulnerabilities such as BEAST, Lucky for encrypted communication on the Internet. However, it has been 13, POODLE, Heartbleed, FREAK, Logjam, and multiple attacks plagued by a number of different attacks and security issues over against RC4 have been discovered. The Snowden revelations have the last years. Addressing these attacks requires changes to the also highlighted weaknesses in TLS, specifically the reliance on protocol, to server- or client-software, or to all of them. In this RSA key transport for establishing keying material, a method that paper we conduct the first large-scale longitudinal study examining can be passively broken by an entity in possession of the server’s the evolution of the TLS ecosystem over the last six years. We RSA private key. Addressing these attacks requires changes to place a special focus on the ecosystem’s evolution in response to the protocol, to server-, or to client-software, or to all of them high-profile attacks. simultaneously. For our analysis, we use a passive measurement dataset with Prior work highlights different parts of the TLS ecosystem like more than 319.3B connections since February 2012, and an active specific attacks [6, 9, 10, 17, 41, 44, 44, 63, 74, 82], problems ofthe dataset that contains TLS and SSL scans of the entire IPv4 address PKI [7, 46, 54, 60] or problems of TLS usage in specific areas like on space since August 2015.
    [Show full text]
  • Coming of Age: a Longitudinal Study of TLS Deployment
    Coming of Age: A Longitudinal Study of TLS Deployment Platon Kotzias Abbas Razaghpanah Johanna Amann IMDEA Software Institute Stony Brook University ICSI/Corelight/LBNL Universidad Politécnica de Madrid Kenneth G. Paterson Narseo Vallina-Rodriguez Juan Caballero Royal Holloway, University of London IMDEA Networks Institute IMDEA Software Institue ICSI ABSTRACT of each new attack and vulnerability that is discovered. Over the The Transport Layer Security (TLS) protocol is the de-facto standard last few years various TLS vulnerabilities such as BEAST, Lucky for encrypted communication on the Internet. However, it has been 13, POODLE, Heartbleed, FREAK, Logjam, and multiple attacks plagued by a number of different attacks and security issues over against RC4 have been discovered. The Snowden revelations have the last years. Addressing these attacks requires changes to the also highlighted weaknesses in TLS, specifically the reliance on protocol, to server- or client-software, or to all of them. In this RSA key transport for establishing keying material, a method that paper we conduct the first large-scale longitudinal study examining can be passively broken by an entity in possession of the server’s the evolution of the TLS ecosystem over the last six years. We RSA private key. Addressing these attacks requires changes to place a special focus on the ecosystem’s evolution in response to the protocol, to server-, or to client-software, or to all of them high-profile attacks. simultaneously. For our analysis, we use a passive measurement dataset with Prior work highlights different parts of the TLS ecosystem like more than 319.3B connections since February 2012, and an active specific attacks [6, 9, 10, 17, 41, 44, 44, 63, 74, 82], problems ofthe dataset that contains TLS and SSL scans of the entire IPv4 address PKI [7, 46, 54, 60] or problems of TLS usage in specific areas like on space since August 2015.
    [Show full text]
  • Projektzusammenfassung
    Ein Entwicklungsvorhaben im Auftrag des Bundesamtes für Sicherheit in der Informationstechnik (BSI) Projekt 197 Sichere Implementierung einer allgemeinen Kryptobibliothek Projektzusammenfassung Version 1.0.0 / 27.03.2017 Zusammenfassung In diesem Projekt wird die sichere Implementierung einer allgemeinen Kryptobibliothek realisiert, die alle gängigen und für den breiten kryptographischen Einsatz notwendigen kryptographischen Primitive beinhaltet. Dazu zählen unter anderem symmetrische und asymmetrische Verschlüsselungs- und Signaturverfahren, PRFs, Hashfunktionen und RNGs. Zusätzlich müssen verbreitete Sicherheitsstandards wie X.509-Zertifikate oder SSL/TLS und der Einsatz von kryptographischer Spezialhardware unterstützt werden. Die Bibliothek stellt dann außerdem eine umfangreiche Testsuite und eine ausführliche Dokumentation bereit, die eine Evaluierung der Kryptographie im Einsatz erleichtert. Dieser Bericht fasst die Projektinhalte zusammen. Autoren Daniel Neus (DN), Rohde & Schwarz Cybersecurity Kai Michaelis (KM), Rohde & Schwarz Cybersecurity René Korthaus (RK), Rohde & Schwarz Cybersecurity Philipp Weber (PW), Rohde & Schwarz Cybersecurity Christian Mainka (CM), Hackmanit GmbH Matthias Gierlings (MG), Hackmanit GmbH Jörg Schwenk (JSc), Hackmanit GmbH Juraj Somorovsky (JSo), Hackmanit GmbH Tobias Niemann (TN), Hackmanit GmbH Copyright Das Werk einschließlich aller seiner Teile ist urheberrechtlich geschützt. Jede Verwertung außerhalb der engen Grenzen des Urhebergesetzes ist ohne Zustimmung des BSI unzulässig und strafbar. Dies
    [Show full text]
  • The 9 Lives of Bleichenbacher's CAT: New Cache Attacks on TLS
    The 9 Lives of Bleichenbacher’s CAT: New Cache ATtacks on TLS Implementations Eyal Ronen∗, Robert Gillhamy, Daniel Genkinz, Adi Shamir∗, David Wongx, and Yuval Yaromy∗∗ ∗Weizmann Institute yUniversity of Adelaide zUniversity of Michigan xNCC Group ∗∗Data61 Abstract—At CRYPTO’98, Bleichenbacher published his sem- Since its publication, multiple Bleichenbacher-like attacks inal paper which described a padding oracle attack against have been demonstrated, exploiting a large variety of oracles, RSA implementations that follow the PKCS #1 v1.5 standard. including error messages [12, 41], timing variations [39, 47] Over the last twenty years researchers and implementors had spent a huge amount of effort in developing and deploying and memory access patterns [69]. After each attack, imple- numerous mitigation techniques which were supposed to plug all mentors had adopted some mitigation techniques to ensure the possible sources of Bleichenbacher-like leakages. However, that the use of PKCS #1 v1.5 does not leak information as we show in this paper most implementations are still vul- on the padding, but these mitigation techniques had become nerable to several novel types of attack based on leakage from increasingly difficult to understand, to implement, and to various microarchitectural side channels: Out of nine popular implementations of TLS that we tested, we were able to break the maintain. Considering the number of demonstrated attacks and security of seven implementations with practical proof-of-concept the ongoing mitigation efforts, we set out in this paper to attacks. We demonstrate the feasibility of using those Cache-like answer the following basic question: ATacks (CATs) to perform a downgrade attack against any TLS connection to a vulnerable server, using a BEAST-like Man in the Are modern implementations of PKCS #1 v1.5 secure against Browser attack.
    [Show full text]
  • Investigating the Multi-Ciphersuite and Backwards-Compatibility Security of the Upcoming TLS 1.3
    This article has been accepted for publication in a future issue of this journal, but has not been fully edited. Content may change prior to final publication. Citation information: DOI 10.1109/TDSC.2017.2685382, IEEE Transactions on Dependable and Secure Computing IEEE TRANSACTIONS ON DEPENDABLE AND SECURE COMPUTING 1 Investigating the Multi-Ciphersuite and Backwards-Compatibility Security of the Upcoming TLS 1.3 Xiao Lan, Jing Xu, Zhen-Feng Zhang, and Wen-Tao Zhu, Senior Member, IEEE Abstract—Transport Layer Security (TLS) is one of the most widely used Internet protocols for secure communications. TLS 1.3, the next-generation protocol, is currently under development, with the latest candidate being draft-18. For flexibility and compatibility, TLS supports various ciphersuites and offers configurable selection of multiple protocol versions, which unfortunately opens the door to practical attacks. For example, although TLS 1.3 is now proven secure separately, coexisting with previous versions may be subject to backwards compatibility attacks. In this paper, we present a formal treatment of the multi-ciphersuite and backwards-compatibility security of TLS 1.3 (specifically, draft-18). We introduce a multi-stage security model, covering all known kinds of compositional interactions (w.r.t. ciphersuites and protocol versions) and reasonably strong security notions. Then we dissect the cross-ciphersuite attack regarding TLS 1.2 in our model, and show that the TLS 1.3 handshake protocol satisfies the multi-ciphersuite security, highlighting the strict necessity of including more information in the signature. Furthermore, we demonstrate how the backwards compatibility attack by Jager et al. can be identified owing to our model, and prove that the handshake protocol can achieve our desired strong security if certain countermeasures are adopted.
    [Show full text]