Librelamp Server Stack Documentation

Total Page:16

File Type:pdf, Size:1020Kb

Librelamp Server Stack Documentation LIBRELAMP SERVER STACK DOCUMENTATION A publication of Pipfrosch Press Alice Wonder (Editor and Author Pseudonym) May 27, 2019 Legal Stuff The instructions in this document and the software packages referred to provided AS IS NO WAR- RANTY WITH NO GUARANTEE OF FITNESS FOR USE. Use at your own risk, but I AM NOT LIABLE FOR ANY DAMAGE THAT RESULTS. That being said, if you do encounter a problem, please contact me and if I have the time, I may be able to help resolve the issue. No guarantees though. With the exception of the licenses that are included in Part III (page 38) and the UNIX man pages that are included in PartIV (page 74), this documentation is released under the terms of the GNU Free Document License (FDL) version 1.3. © 2019 Michael A. Peters Permission is granted to copy, distribute and/or modify this document under the terms of the GNU Free Documentation License, Version 1.3 or any later version published by the Free Software Foundation; with no Invariant Sections, no Front-Cover Texts, and one Back-Cover Text: “Extensive amounts of blood, sweat, tears, and time went into the authoring of this manual. The author as of 2019 is living well below the poverty line. Please consider a financial contribution at https://www.paypal.me/pipfrosch.” (see page 112) A copy of the license is included in the section entitled “GNU Free Documentation License” on page 38. The man pages in PartIV have authorship and license information included at the end of each man page that is included. 1 The LATEX source files for this document are maintained at gitlab . The sections below refer to software included in LibreLAMP. 1. OpenSSL API This product includes software developed by the OpenSSL Project for use in the OpenSSL Toolkit (https://www.openssl.org/) 1https://gitlab.com/Pipfrosch/librelampdocumentation ii Legal Stuff This product includes cryptographic software written by Eric Young ([email protected]) A copy of the OpenSSL license is included in the section entitled “Dual OpenSSL and SSLeay License” on page 46. 2. Apache This product includes software including but not limited to the Apache Web Server that are licensed under the terms of the Apache 2.0 license. A copy of the Apache 2.0 license is included in the section entitled “Apache 2.0 License” on page 49. 3. MariaDB This product includes software including but not limited to the MariaDB database server that are licensed under the terms of the GNU General Public License (GPL) version 2.0. A copy of the GNU GPL 2.0 is included in the section entitled “GNU General Public License version 2.0” on page 54. This product includes software libraries including but not limited to the MariaDB C Client library that are licensed under the terms of the GNU Lesser General Public License (LGPL) version 2.1. A copy of the GNU LGPL 2.1 is included in the section entitled “GNU Lesser General Public License version 2.1” on page 62. 4. PHP This product includes PHP software, freely available from https://www.php.net/software/ PHP is licended under the terms of The PHP License, version 3.01. A copy of The PHP License, version 3.01 is included in the secton entitled “The PHP License, version 3.01” on page 71. iii Contents Legal Stuff ii 1. OpenSSL API..................................... ii 2. Apache........................................ iii 3. MariaDB....................................... iii 4. PHP.......................................... iii 1. Introduction1 1.1. Software Version Philosophy.............................2 1.2. FIPS Disclosure....................................3 1.3. TLS 1.3 Disclosure..................................3 1.4. System Libraries...................................4 1.5. GnuTLS........................................4 1.6. Mail Stack.......................................5 1.7. DNS Stack......................................5 1.8. Other Servers.....................................6 2. LibreLAMP Installation7 2.1. Enable EPEL.....................................7 2.2. Install HAVEGED (optional).............................7 2.3. Backup and Stop MariaDB..............................8 2.4. Install LibreLAMP..................................8 2.4.1. YUM Bug Note................................8 I. Apache Web Server 10 3. Basic Apache Setup and Configuration 11 3.1. Apache Install..................................... 11 3.2. IP Network Note................................... 11 3.3. Webmaster Account.................................. 12 3.4. OCSP Stapling.................................... 12 3.5. Create the Document Root.............................. 13 3.6. Virtual Host Configuration.............................. 14 3.6.1. Port 80 Redirects............................... 15 3.6.2. Port 443 Redirects.............................. 15 3.7. Live Server Virtual Host............................... 16 iv Contents 4. Apache and TLS (SSL) 18 4.1. Server Certificate................................... 18 4.1.1. Server Private Key Generation........................ 19 4.1.2. Server CSR Generation............................ 20 4.2. Cipher Suite Configuration.............................. 23 4.2.1. The Cipher Spec............................... 24 4.2.2. Key Exchange................................ 25 4.2.3. Cipher Choice................................ 27 4.2.4. Authenticated Encryption with Associated Data (AEAD).......... 28 4.2.5. Cipher Block Size.............................. 30 4.2.6. Alice’s Recommended Cipher Spec..................... 30 4.3. Strict Transport Security............................... 31 4.3.1. The max-age Parameter........................... 32 4.3.2. The Optional includeSubdomains Parameter.............. 32 4.3.3. The Optional preload Parameter...................... 32 4.4. TLDR Nutshell Bullet List.............................. 33 II. General Appendices 34 A. 128-bit Block Ciphers 35 III. Licenses 37 GNU Free Documentation License 38 1. APPLICABILITY AND DEFINITIONS........................ 38 2. VERBATIM COPYING................................. 40 3. COPYING IN QUANTITY............................... 40 4. MODIFICATIONS.................................... 40 5. COMBINING DOCUMENTS.............................. 42 6. COLLECTIONS OF DOCUMENTS.......................... 43 7. AGGREGATION WITH INDEPENDENT WORKS.................. 43 8. TRANSLATION..................................... 43 9. TERMINATION..................................... 44 10. FUTURE REVISIONS OF THIS LICENSE...................... 44 11. RELICENSING..................................... 44 ADDENDUM: How to use this License for your documents............... 45 Dual OpenSSL and SSLeay License 46 LICENSE ISSUES..................................... 46 OpenSSL License...................................... 46 v Contents Original SSLeay License.................................. 47 Apache 2.0 License 49 1. Definitions........................................ 49 2. Grant of Copyright License............................... 50 3. Grant of Patent License................................. 50 4. Redistribution...................................... 50 5. Submission of Contributions............................... 51 6. Trademarks........................................ 51 7. Disclaimer of Warranty.................................. 52 8. Limitation of Liability.................................. 52 9. Accepting Warranty or Additional Liability....................... 52 APPENDIX: How to apply the Apache License to your work............... 53 GNU General Public License version 2.0 54 Terms and Conditions For Copying, Distribution and Modification............ 55 Appendix: How to Apply These Terms to Your New Programs.............. 60 GNU Lesser General Public License version 2.1 62 Terms and Conditions For Copying, Distribution and Modification............ 63 How to Apply These Terms to Your New Libraries.................... 70 The PHP License, version 3.01 71 IV. Man Pages 73 B. LibreSSL configuration files 75 B.1. DESCRIPTION.................................... 75 B.2. OPENSSL LIBRARY CONFIGURATION..................... 76 B.2.1. ASN1 Object Configuration Module..................... 76 B.2.2. Engine Configuration Module........................ 77 B.3. FILES......................................... 78 B.4. EXAMPLES..................................... 78 B.5. SEE ALSO...................................... 80 B.6. CAVEATS....................................... 80 B.7. BUGS......................................... 81 B.8. Man Page Notes and Legal.............................. 81 C. X.509 V3 certificate extension configuration format 83 C.1. DESCRIPTION.................................... 83 C.2. STANDARD EXTENSIONS............................. 84 C.2.1. Basic constraints............................... 84 vi Contents C.2.2. Key usage................................... 84 C.2.3. Extended key usage.............................. 84 C.2.4. Subject key identifier............................. 85 C.2.5. Authority key identifier............................ 85 C.2.6. Subject alternative name........................... 86 C.2.7. Issuer alternative name............................ 86 C.2.8. Authority info access............................. 87 C.2.9. CRL distribution points............................ 87 C.2.10. Issuing distribution point........................... 88 C.2.11. Certificate policies.............................. 88 C.2.12. Policy constraints............................... 89 C.2.13. Inhibit any policy............................... 90 C.2.14. Name constraints............................... 90 C.2.15. OCSP no check...............................
Recommended publications
  • Making Sense of Snowden, Part II: What's Significant in the NSA
    web extra Making Sense of Snowden, Part II: What’s Significant in the NSA Revelations Susan Landau, Google hen The Guardian began publishing a widely used cryptographic standard has vastly wider impact, leaked documents from the National especially because industry relies so heavily on secure Inter- Security Agency (NSA) on 6 June 2013, net commerce. Then The Guardian and Der Spiegel revealed each day brought startling news. From extensive, directed US eavesdropping on European leaders7 as the NSA’s collection of metadata re- well as broad surveillance by its fellow members of the “Five cords of all calls made within the US1 Eyes”: Australia, Canada, New Zealand, and the UK. Finally, to programs that collected and stored data of “non-US” per- there were documents showing the NSA targeting Google and W2 8,9 sons to the UK Government Communications Headquarters’ Yahoo’s inter-datacenter communications. (GCHQs’) interception of 200 transatlantic fiberoptic cables I summarized the initial revelations in the July/August is- at the point where they reached Britain3 to the NSA’s pene- sue of IEEE Security & Privacy.10 This installment, written in tration of communications by leaders at the G20 summit, the late December, examines the more recent ones; as a Web ex- pot was boiling over. But by late June, things had slowed to a tra, it offers more details on the teaser I wrote for the January/ simmer. The summer carried news that the NSA was partially February 2014 issue of IEEE Security & Privacy magazine funding the GCHQ’s surveillance efforts,4 and The Guardian (www.computer.org/security).
    [Show full text]
  • NSA's Efforts to Secure Private-Sector Telecommunications Infrastructure
    Under the Radar: NSA’s Efforts to Secure Private-Sector Telecommunications Infrastructure Susan Landau* INTRODUCTION When Google discovered that intruders were accessing certain Gmail ac- counts and stealing intellectual property,1 the company turned to the National Security Agency (NSA) for help in securing its systems. For a company that had faced accusations of violating user privacy, to ask for help from the agency that had been wiretapping Americans without warrants appeared decidedly odd, and Google came under a great deal of criticism. Google had approached a number of federal agencies for help on its problem; press reports focused on the company’s approach to the NSA. Google’s was the sensible approach. Not only was NSA the sole government agency with the necessary expertise to aid the company after its systems had been exploited, it was also the right agency to be doing so. That seems especially ironic in light of the recent revelations by Edward Snowden over the extent of NSA surveillance, including, apparently, Google inter-data-center communications.2 The NSA has always had two functions: the well-known one of signals intelligence, known in the trade as SIGINT, and the lesser known one of communications security or COMSEC. The former became the subject of novels, histories of the agency, and legend. The latter has garnered much less attention. One example of the myriad one could pick is David Kahn’s seminal book on cryptography, The Codebreakers: The Comprehensive History of Secret Communication from Ancient Times to the Internet.3 It devotes fifty pages to NSA and SIGINT and only ten pages to NSA and COMSEC.
    [Show full text]
  • Comments Received on Special Publication 800-90A, B and C
    Comments Received on SP 800-90A On 9/11/13 12:06 AM, "Robert Bushman" <[email protected]> wrote: "Draft Special Publication 800-90A, Recommendation for Random Number Generation Using Deterministic Random Bit Generators" cannot be trusted to secure our citizens and corporations from cyber-attack, for reasons that should be quite apparent. Please terminate it or replace the PRNG algorithm without the participation of the NSA. On 9/21/13 1:25 PM, "peter bachman" <[email protected]> wrote: See enclosed random.pdf for comment (A picture was attached) From: Mike Stephens <[email protected]> Date: Friday, October 18, 2013 2:47 PM Remove DUAL_EC_DRBG from SP 800-90. [MS] 1 10.3 Page 60 te Published cryptanalysis shows that Dual EC DRBG outputs are biased. This should disqualify the algorithm from inclusion in the standard.i ii [MS] 2 10.3 Page 60 ge Recent publications regarding Dual EC DRBG have significantly compromised public trust in the algorithm to the extent that correcting any mathematical properties of Remove DUAL_EC_DRBG from SP 800-90. the algorithm would not regenerate confidence in it. Continued inclusion of Dual EC DRBG will harm the credibility of the SP-800 series of standards. [MS] 3 11 Page 72 ge The SP-800 series standardizes algorithms, not implementation aspects. Self-test requirements should come from FIPS 140-2. The current self-test requirements in SP 800-90 do not align with or cooperate with FIPS 140-2 Remove self-test requirements from SP800-90. requirements. Should the self-test requirements remain in SP 800-90; then, harmonize these requirements with those in FIPS 140.
    [Show full text]
  • Crypto Won't Save You Either Sound Advice from The
    14/01/2016 Crypto Won’t Save You Either Peter Gutmann University of Auckland Sound Advice from the USG 1 14/01/2016 Saw Something, Said Something Saw Something, Said Something (ctd) You’re not paranoid, they really are out to get you 2 14/01/2016 BULLRUN Funded to the tune of $250-300M/year BULLRUN (ctd) This is fantastic value for money! Compare the BULLRUN cost to the JSF • $60 billion development • $260 billion procurement • $100-200 million each (lots of different cost estimates) • $600-700 million each over operational lifetime BULLRUN is a bargain by comparison 3 14/01/2016 BULLRUN (ctd) “capabilities against TLS/SSL, HTTPS, SSH, VPNs, VoIP, webmail, ...” BULLRUN (ctd) “aggressive effort to defeat network security and privacy” “defeat the encryption used in network communication technologies” 4 14/01/2016 BULLRUN (ctd) The first rule of BULLRUN club… What’s that NSAie? Crypto’s fallen in the well? 5 14/01/2016 I Know, Bigger Keys! We need to get bigger keys. BIG F**ING KEYS! — “Split Second”, 1992 Quick, do something! Cue the stannomillinery 6 14/01/2016 Crypto Won’t Save You Shamir’s Law: Crypto is bypassed, not penetrated Cryptography is usually bypassed. I am not aware of any major world-class security system employing cryptography in which the hackers penetrated the system by actually going through the cryptanalysis […] usually there are much simpler ways of penetrating the security system — Adi Shamir Example: Games Consoles All of the major consoles use fairly extensive amounts of sophisticated cryptography • PS3 • Wii • Xbox
    [Show full text]
  • How to (Pre-)Compute a Ladder
    How to (pre-)compute a ladder Improving the performance of X25519 and X448 Thomaz Oliveira1, Julio L´opez2, H¨useyinHı¸sıl3, Armando Faz-Hern´andez2, and Francisco Rodr´ıguez-Henr´ıquez1 1 Computer Science Department, Cinvestav-IPN [email protected], [email protected] 2 Institute of Computing, University of Campinas [email protected], [email protected] 3 Yasar University [email protected] Abstract. In the RFC 7748 memorandum, the Internet Research Task Force specified a Montgomery-ladder scalar multiplication function based on two recently adopted elliptic curves, \curve25519" and \curve448". The purpose of this function is to support the Diffie-Hellman key ex- change algorithm that will be included in the forthcoming version of the Transport Layer Security cryptographic protocol. In this paper, we describe a ladder variant that permits to accelerate the fixed-point mul- tiplication function inherent to the Diffie-Hellman key pair generation phase. Our proposal combines a right-to-left version of the Montgomery ladder along with the pre-computation of constant values directly de- rived from the base-point and its multiples. To our knowledge, this is the first proposal of a Montgomery ladder procedure for prime elliptic curves that admits the extensive use of pre-computation. In exchange of very modest memory resources and a small extra programming effort, the proposed ladder obtains significant speedups for software implemen- tations. Moreover, our proposal fully complies with the RFC 7748 spec- ification. A software implementation of the X25519 and X448 functions using our pre-computable ladder yields an acceleration factor of roughly 1.20, and 1.25 when implemented on the Haswell and the Skylake micro- architectures, respectively.
    [Show full text]
  • Chacha20-Poly1305 の実装性能調査
    ChaCha20-Poly1305 の実装性能調査 株式会社レピダム 2017 年 10 月 目 次 第 1 章 エグゼクティブサマリー 3 第 2 章 ChaCha20-Poly1305 について 4 2.1 概要 :::::::::::::::::::::::::::::: 4 2.2 歴史的背景 :::::::::::::::::::::::::: 5 2.3 アルゴリズムの構造 ::::::::::::::::::::: 5 2.3.1 ChaCha20 ::::::::::::::::::::::: 5 2.3.2 Poly1305 ::::::::::::::::::::::: 7 2.3.3 ChaCha20-Poly1305 ::::::::::::::::: 8 第 3 章 ChaCha20-Poly1305 の採用状況 11 3.1 標準化動向 :::::::::::::::::::::::::: 11 3.1.1 IETF ::::::::::::::::::::::::: 11 3.1.2 その他の標準化団体 ::::::::::::::::: 14 3.2 OSS コミュニティ動向 :::::::::::::::::::: 14 第 4 章 ChaCha20-Poly1305 の実装性能評価に関する既存文献調 査 17 4.1 論文調査 :::::::::::::::::::::::::::: 17 4.2 ベンチマーク実装評価調査 :::::::::::::::::: 18 4.2.1 Cloudflare 版 OpenSSL ::::::::::::::: 19 4.2.2 Edge Security の WireGuard :::::::::::: 20 4.2.3 Barco Silex の BA417 と Inside Secure の ChaCha- IP-13 / EIP-13, POLY-IP-53 / EIP-53 ::::::: 22 第 5 章 認証暗号方式の性能比較調査 24 5.1 性能比較調査方法 ::::::::::::::::::::::: 24 5.1.1 比較対象アルゴリズム :::::::::::::::: 24 5.1.2 実行環境 :::::::::::::::::::::::: 32 5.1.3 暗号ライブラリ :::::::::::::::::::: 34 5.2 実行コマンド ::::::::::::::::::::::::: 35 5.3 性能比較結果 ::::::::::::::::::::::::: 37 5.3.1 AES-NI 有効の場合 ::::::::::::::::: 37 1 5.3.2 AES-NI 無効の場合 ::::::::::::::::: 46 5.3.3 性能測定における注意点 ::::::::::::::: 51 5.4 考察 :::::::::::::::::::::::::::::: 52 5.4.1 Poly1305 によるオーバーヘッド ::::::::::: 52 5.4.2 AES-NI の影響 :::::::::::::::::::: 53 5.4.3 ChaCha20-Poly1305 と AES-GCM の比較 ::::: 53 第 6 章 まとめ 54 Arm, Cortex, mbed は Arm Limited の登録商標です。 Cloudflare は Cloudflare, Inc の登録商標です。 Google は Google LLC の登録商標です。 Inside Secure は Inside Secure またはその子会社の登録商標です。 Intel は Intel Corporation またはその子会社の登録商標です。 WireGuard は Jason A. Donenfeld の登録商標です。 AVR は Microchip Technology Incorporated の登録商標です。 OpenSSL は OpenSSL Software Foundation の登録商標です。 OpenVPN は OpenVPN Inc.
    [Show full text]
  • Cryptgenrandom()
    (Pseudo)Random Data PA193 – Secure coding Petr Švenda Zdeněk Říha Faculty of Informatics, Masaryk University, Brno, CZ Need for “random” data • Games • Simulations, … • Crypto – Symmetric keys – Asymmetric keys – Padding/salt – Initialization vectors – Challenges (for challenge – response protocols) – … “Random” data • Sometimes (games, simulations) we only need data with some statistical properties – Evenly distributed numbers (from an interval) – Long and complete cycle • Large number of different values • All values can be generated • In crypto we also need unpredictability – Even if you have seen all the “random” data generated until now you have no idea what will be the random data generated next “Random” data generators • Insecure random number generators – noncryptographic pseudo-random number generators – Often leak information about their internal state with each output • Cryptographic pseudo-random number generators (PRNGs) – Based on seed deterministically generate pseudorandom data • “True” random data generators – Entropy harvesters – gather entropy from other sources and present it directly What (pseudo)random data to use? • Avoid using noncryptographic random number generators • For many purposes the right way is to get the seed from the true random number generator and then use it in the pseudorandom number generator (PRNG) – PRNG are deterministic, with the same seed they produce the same pseudorandom sequence • There are situations, where PRNG are not enough – E.g. one time pad Noncryptographic generators • Standard rand()/srand(), random ()/srandom() functions – libc • “Mersenne Twister” • linear feedback shift registers • Anything else not labeled as cryptographic PRNG… • Not to be used for most purposes…. Noncryptographic generators Source: Writing secure code, 2nd edition Source: http://xkcd.com/ PRNG • Cryptographic pseudo-random number generators are still predictable if you somehow know their internal state.
    [Show full text]
  • Backdoors in Crypto the Problem with Castles
    Backdoors in Crypto The Problem with Castles. Treason Doors. Nottingham Castle. ● Roger Mortimer, 1st Earl of March ruled from Nottingham Castle. Nottingham Castle. ● Roger Mortimer, 1st Earl of March ruled from Nottingham Castle. ● Nottingham Castle had a secret tunnel that bypassed all the defenses. Nottingham Castle. ● Roger Mortimer, 1st Earl of March ruled from Nottingham Castle. ● Nottingham Castle had a secret tunnel that bypassed all the defenses. ● 1330 AD - Secret passage isn’t so secret. ○ Overseer of the castle betrays Mortimer. ○ Leads raid through secret tunnel. ○ kills Mortimer’s guards, arrests Mortimer. ○ Mortimer is executed soon after. Maginot Line Fortifications. ● French WW2 fortifications. ● Claim: Designed so that if captured, they would be easier to recapture. What does this have to do with Crypto? ● Can you design a cipher that would keep you secure but you could break if other people used it? ● How? ● What properties should such a backdoor have? Backdoors Definition: ● Backdoors are built-in methods of bypassing the security of a system. Dual EC DRBG Backdoor: Overview ● Dual Elliptic Curve Deterministic Random Bit Generator. ● Backdoored by the NSA. ● Deployed in commercial systems. ● Exposed by Academic Cryptographers and Snowden. Dual EC DRBG Backdoor: How ● Dual Elliptic Curve Deterministic Random Bit Generator. ● Like Blum-Micali, but generates many bits at a time. Dual EC DRBG Backdoor: The players ● NSA - National Security Agency ○ Offensive/Defensive mission: Makes & breaks codes/ciphers, ○ Captures, listens to & analyzes communications. ● NIST - National Institute of Standards and Technology ○ Creates & evaluates national technology standards. ○ Trusted as a fair player nationally & internationally. ● RSA ○ Technology company, created to commercialize public key encryption.
    [Show full text]
  • Practical State Recovery Attacks Against Legacy RNG Implementations
    Practical state recovery attacks against legacy RNG implementations Shaanan N. Cohney Matthew D. Green Nadia Heninger University of Pennsylvania Johns Hopkins University University of Pennsylvania [email protected] [email protected] [email protected] ABSTRACT 1 INTRODUCTION The ANSI X9.17/X9.31 pseudorandom number generator design was Random number generation is a vital component of any crypto- first standardized in 1985, with variants incorporated into numerous graphic system. While systems may survive subtle flaws in crypto- cryptographic standards over the next three decades. The design graphic algorithm implementation, the ability to predict the output uses timestamps together with a statically keyed block cipher to of a (pseudo)random number generator typically leads to the cata- produce pseudo-random output. It has been known since 1998 that strophic failure of any protocol built on top of it. In recent years the key must remain secret in order for the output to be secure. a number of cryptographic systems have been found to include However, neither the FIPS 140-2 standardization process nor NIST’s flawed random and pseudorandom number generation subsystems. later descriptions of the algorithm specified any process for key These flaws range from subtle weaknesses, e.g. biases that admit generation. sophisticated attacks against the protocol [49]; to catastrophic vul- We performed a systematic study of publicly available FIPS 140- nerabilities that allow for adversarial recovery of all random coins 2 certifications for hundreds of products that implemented the used in a protocol execution [16, 59]. In a particularly ominous ANSI X9.31 random number generator, and found twelve whose development, some of these flaws appear to have been deliberately certification documents use of static, hard-coded keys in source engineered.
    [Show full text]
  • Kleptography – Overview and a New Proof of Concept
    Aalto University School of Science Degree Programme in Engineering Physics and Mathematics Ferdinand Blomqvist Kleptography { Overview and a new proof of concept Master's Thesis Espoo, August 11, 2015 Supervisor: Professor Camilla Hollanti Advisor: Professor Kaisa Nyberg Aalto University School of Science ABSTRACT OF Degree Programme in Engineering Physics and Mathematics MASTER'S THESIS Author: Ferdinand Blomqvist Title: Kleptography { Overview and a new proof of concept Date: August 11, 2015 Pages: xiii + 78 Major: Mathematics Code: F3006 Supervisor: Professor Camilla Hollanti Advisor: Professor Kaisa Nyberg Kleptography is the study of stealing information securely and subliminally. A successful klep- tographic attack is undetectable, and, therefore, kleptographic attacks are only useful against so called black-box implementations of cryptographic primitives and protocols. The dangers of black-box cryptography have been publicly known for almost two decades. However, black- box cryptography is still widespread. The recent revelations of the United States National Security Agency's efforts to sabotage cryptographic standards and products have showed that kleptographic attacks constitute a real threat, and that countermeasures are needed. In this thesis we study known kleptographic primitives, and examine how they can be used to compromise the security of well known secure communication protocols. We also take an in depth look at the Dual EC DRBG, which is a kleptographic pseudorandom number generator designed by the NSA. Finally, we present a new proof of concept { a kleptographic pseudoran- dom number generator that can be used as a secure subliminal channel. The difference between our generator and the Dual EC DRBG is that the Dual EC DRBG leaks its own state while our generator can be used to leak any information.
    [Show full text]
  • Research on Cryptographic Backdoors
    Research on Cryptographic Backdoors Bancha Upanan Student ID: 1604026 Supervisor: Dr. David Galindo Submitted in conformity with the requirements for the degree of MSc Cyber Security School of Computer Science University of Birmingham September 2016 Abstract Cryptographic backdoors are the field of surreptitiously weakening cryptographic systems such as deliberately inserting vulnerabilities to a pseudorandom number gen- erator to make cryptanalysis easier. Therefore, the subsequent random numbers are predictable to the designer of backdoor. In this project we studied Dual EC DRBG which is the algorithm based on elliptic curve cryptography to generate random bits. It has been suspected that the designer could have chosen the parameters with backdoor in order to predict the random bits. The aims of this project are to realise how Dual EC DRBG and its corresponding backdoor work consisting of basic Dual EC DRBG, Dual EC DRBG version 2006 and 2007 according to NIST SP 800-90A. After that the attack was carried out on TLS by inserting the backdoor to OpenSSL to learn an ECDHE server private key and reproduce a TLS premaster secret. The implementation results show that all SageMath programs predicted the correct random bits. While the Python attack programs against TLS on OpenSSL successfully output the premaster secret file which could be used to decrypt data on Wireshark. Keywords: Dual EC DRBG, cryptographic backdoor, NIST SP 800-90A, TLS handshake, premaster secret Acknowledgements First of all, I would like to express my sincere gratitude and appreciation to my supervisor Dr. David Galindo for his immense guidance and assistance during the course of this project.
    [Show full text]
  • Trapping ECC : Invalid Curve Bug Attacks
    Trapping ECC with Invalid Curve Bug Attacks Renaud Dubois Thales Communications and Security 4, Avenue des Louvresses 92230 Gennevilliers { France fi[email protected] Abstract. In this paper we describe how to use a secret bug as a trapdoor to design trapped ellliptic curve E(Fp). This trapdoor can be used to mount an invalid curve attack on E(Fp). E(Fp) is designed to respect all ECC security criteria (prime order, high twist order, etc.) but for a secret exponent the point is projected on another unsecure curve. We show how to use this trap with a particular type of time/memory tradeoff to break the ECKCDSA verification process for any public key of the trapped curve. The process is highly undetectable : the chosen defender effort is quadratic in the saboter computational effort. This work provides a concrete hardly detectable and easily deniable example of cryptographic sabotage. While this proof of concept is very narrow, it highlights the necessity of the Full Verifiable Randomness of ECC. keywords:Bug Attacks, Fault Attacks, ECC, Invalid Curve Attack, ECKCDSA, Klep- tography, NSA, Paranoia, Verifiable Randomness, Sabotage-resilient Cryptography. 1 Introduction 1.1 Context According to the leak of NSA memos of E. Snowden (as reported in the New York Times in 2013 [9]) the NSA managed to become the sole editor of the Dual EC-DRBG Standard [2]. Using this status, the agency inserted a backdoor as part of the large scale bullrun decryption program [10]. This increased the concern about the capacity for an organization to specify trapped cryptosystems. Workshops [8] and Projects like [3] ask the question : "is there some trap we ignore in the widely used standardized elliptic curve ?".
    [Show full text]