Kleptography is the study of stealing information securely and subliminally. The term was introduced by Adam Young and Moti Yung in the Proceedings of Advances in Cryptology – Crypto '96.[1] Kleptography is a subfield of cryptovirology and is a natural extension of the theory of subliminal channels that was pioneered by Gus Simmons while at Sandia National Laboratory.[2][3][4] A kleptographic backdoor is synonymously referred to as an asymmetric backdoor. Kleptography encompasses secure and covert communications through cryptosystems and cryptographic protocols. This is reminiscent of, but not the same as steganography that studies covert communications through graphics, video, digital audio data, and so forth.
Kleptographic attack
editMeaning
editA kleptographic attack is an attack which uses asymmetric cryptography to implement a cryptographic backdoor.[5] For example, one such attack could be to subtly modify how the public and private key pairs are generated by the cryptosystem so that the private key could be derived from the public key using the attacker's private key. In a well-designed attack, the outputs of the infected cryptosystem would be computationally indistinguishable from the outputs of the corresponding uninfected cryptosystem.[6][7] If the infected cryptosystem is a black-box implementation such as a hardware security module, a smartcard, or a Trusted Platform Module, a successful attack could go completely unnoticed.
A reverse engineer might be able to uncover a backdoor inserted by an attacker, and when it is a symmetric backdoor, even use it themself.[5] However, by definition a kleptographic backdoor is asymmetric and the reverse-engineer cannot use it. A kleptographic attack (asymmetric backdoor) requires a private key known only to the attacker in order to use the backdoor. In this case, even if the reverse engineer was well-funded and gained complete knowledge of the backdoor, it would remain useless for them to extract the plaintext without the attacker's private key.[5]
Construction
editKleptographic attacks can be constructed as a cryptotrojan that infects a cryptosystem and opens a backdoor for the attacker,[citation needed] or can be implemented by the manufacturer of a cryptosystem. The attack does not necessarily have to reveal the entirety of the cryptosystem's output; a more complicated attack technique may alternate between producing uninfected output and insecure data with the backdoor present.[8]
Design
editKleptographic attacks have been designed for RSA key generation, the Diffie–Hellman key exchange, the Digital Signature Algorithm, and other cryptographic algorithms and protocols.[8] SSL, SSH, and IPsec protocols are vulnerable to kleptographic attacks.[9] In each case, the attacker is able to compromise the particular cryptographic algorithm or protocol by inspecting the information that the backdoor information is encoded in (e.g., the public key, the digital signature, the key exchange messages, etc.) and then exploiting the logic of the asymmetric backdoor using their secret key (usually a private key).
A. Juels and J. Guajardo[10] proposed a method (KEGVER) through which a third party can verify RSA key generation. This is devised as a form of distributed key generation in which the secret key is only known to the black box itself. This assures that the key generation process was not modified and that the private key cannot be reproduced through a kleptographic attack.[10]
Examples
editFour practical examples of kleptographic attacks (including a simplified SETUP attack against RSA) can be found in JCrypTool 1.0,[11] the platform-independent version of the open-source CrypTool project.[12] A demonstration of the prevention of kleptographic attacks by means of the KEGVER method is also implemented in JCrypTool.
The Dual_EC_DRBG cryptographic pseudo-random number generator from the NIST SP 800-90A is thought to contain a kleptographic backdoor. Dual_EC_DRBG utilizes elliptic curve cryptography, and NSA is thought to hold a private key which, together with bias flaws in Dual_EC_DRBG, allows NSA to decrypt SSL traffic between computers using Dual_EC_DRBG for example.[13] The algebraic nature of the attack follows the structure of the repeated Dlog Kleptogram in the work of Young and Yung.
References
edit- ^ Young, A.; Yung, M. (1996). "The Dark Side of Black-Box Cryptography, or: Should we trust Capstone?". In Koblitz, Neal (ed.). Advances in Cryptology — CRYPTO '96: 16th Annual International Cryptology Conference, Santa Barbara, California, USA, August 18–22, 1996, Proceedings. Lecture Notes in Computer Science. Springer Berlin Heidelberg. pp. 89–103. ISBN 978-3-540-68697-2.89-103&rft.pub=Springer Berlin Heidelberg&rft.date=1996&rft.isbn=978-3-540-68697-2&rft.aulast=Young&rft.aufirst=A.&rft.au=Yung, M.&rft_id=https://books.google.com/books?id=9lurCAAAQBAJ&pg=PA89&rfr_id=info:sid/en.wikipedia.org:Kleptography" class="Z3988">
- ^ Simmons, G. J. (1984). "The Prisoners' Problem and the Subliminal Channel". In Chaum, D. (ed.). Proceedings of Crypto '83. Plenum Press. pp. 51–67. doi:10.1007/978-1-4684-4730-9_5. ISBN 978-1-4684-4732-3.51-67&rft.pub=Plenum Press&rft.date=1984&rft_id=info:doi/10.1007/978-1-4684-4730-9_5&rft.isbn=978-1-4684-4732-3&rft.aulast=Simmons&rft.aufirst=G. J.&rfr_id=info:sid/en.wikipedia.org:Kleptography" class="Z3988">
- ^ Simmons, G. J. (1985). "The Subliminal Channel and Digital Signatures". In Beth, T.; Cot, N.; Ingemarsson, I. (eds.). Proceedings of Eurocrypt '84. Lecture Notes in Computer Science. Vol. 209. Springer-Verlag. pp. 364–378. doi:10.1007/3-540-39757-4_25. ISBN 978-3-540-16076-2.364-378&rft.pub=Springer-Verlag&rft.date=1985&rft_id=info:doi/10.1007/3-540-39757-4_25&rft.isbn=978-3-540-16076-2&rft.aulast=Simmons&rft.aufirst=G. J.&rfr_id=info:sid/en.wikipedia.org:Kleptography" class="Z3988">
- ^ Simmons, G. J. (1993). "Subliminal Communication is Easy Using the DSA". In Helleseth, T. (ed.). Proceedings of Eurocrypt '93. Lecture Notes in Computer Science. Vol. 765. Springer-Verlag. pp. 218–232. doi:10.1007/3-540-48285-7_18. ISBN 978-3-540-57600-6.218-232&rft.pub=Springer-Verlag&rft.date=1993&rft_id=info:doi/10.1007/3-540-48285-7_18&rft.isbn=978-3-540-57600-6&rft.aulast=Simmons&rft.aufirst=G. J.&rfr_id=info:sid/en.wikipedia.org:Kleptography" class="Z3988">
- ^ a b c Esslinger, Bernhard; Vacek, Patrick (20 February 2013). "The Dark Side of Cryptography: Kleptography in Black-Box Implementations". Infosecurity Magazine. Retrieved 18 March 2014.
- ^ Young, Adam (2006). "Cryptovirology FAQ". Cryptovirology.com. Archived from the original on 9 May 2017. Retrieved 18 March 2014.
- ^ Easttom, Chuck (May 2018). "A Study of Cryptographic Backdoors in Cryptographic Primitives". Electrical Engineering (ICEE), Iranian Conference on. pp. 1664–1669. doi:10.1109/ICEE.2018.8472465. ISBN 978-1-5386-4914-5. S2CID 52896242.1664-1669&rft.date=2018-05&rft_id=https://api.semanticscholar.org/CorpusID:52896242#id-name=S2CID&rft_id=info:doi/10.1109/ICEE.2018.8472465&rft.isbn=978-1-5386-4914-5&rft.aulast=Easttom&rft.aufirst=Chuck&rfr_id=info:sid/en.wikipedia.org:Kleptography" class="Z3988">
- ^ a b Young, A.; Yung, M. (2004). Malicious Cryptography: Exposing Cryptovirology. Wiley. ISBN 978-0-7645-6846-6.
- ^ Zagórski, Filip; Kutyłowski, Mirosław. "Bezpieczeństwo protokołów SSL/TLS i SSL w kontekście ataków kleptograficznych" [Security of SSL/TLS and SSL protocols in the context of kleptographic attacks]. kleptografia.im.pwr.wroc.pl (in Polish). Archived from the original on 2006-04-23.
- ^ a b Juels, Ari; Guajardo, Jorge (2002). "RSA Key Generation with Verifiable Randomness" (PDF). In Naccache, D.; Pallier, P. (eds.). Public Key Cryptography: 4th International Workshop on Practice and Theory in Public Key Cryptosystems. Springer Berlin Heidelberg. pp. 357–374. doi:10.1007/3-540-45664-3_26. ISBN 978-3-540-43168-8. ISSN 0302-9743. Archived from the original (PDF) on 2013-05-12.357-374&rft.pub=Springer Berlin Heidelberg&rft.date=2002&rft.issn=0302-9743&rft_id=info:doi/10.1007/3-540-45664-3_26&rft.isbn=978-3-540-43168-8&rft.aulast=Juels&rft.aufirst=Ari&rft.au=Guajardo, Jorge&rft_id=http://www.rsa.com/rsalabs/staff/bios/ajuels/publications/kegver/kv-extended.pdf&rfr_id=info:sid/en.wikipedia.org:Kleptography" class="Z3988">
- ^ https://github.com/jcryptool JCrypTool project website
- ^ Esslinger, B. (2010). "Die dunkle Seite der Kryptografie – Kleptografie bei Black-Box-Implementierungen". <kes> (in German). No. 4. p. 6. Archived from the original on 2011-07-21.
- ^ Green, Matthew (September 18, 2016). "The Many Flaws of Dual_EC_DRBG". Retrieved November 19, 2016.