Autocrypt
Autocrypt is a cryptographic protocol for email clients aiming to simplify key exchange and enabling encryption. Version 1.0 of the Autocrypt specification was released in December 2017. Version 1.1 was released in January 2019. It is implemented on top of OpenPGP replacing its complex key management by fully automated exchange of cryptographic keys between peers .
Method
Autocrypt-capable email clients transparently negotiate encryption capabilities and preferences and exchange keys between users alongside sending regular emails. This is done by including the key material and encryption preferences in the header of each email, which allows encrypting any message to a contact who has previously sent the user email. This information is not signed or verified in any way even if the actual message is encrypted and verified.
No support is required from email providers other than preserving and not manipulating the Autocrypt specific header fields.
When a message is encrypted to a group of receivers, keys are also automatically sent to all receivers in this group. This ensures that a reply to a message can be encrypted without any further complications or work by the user.
Security model
Autocrypt is guided by the idea of opportunistic security from RFC 7435 but implementing something much less secure than a trust on first use (TOFU) model. Encryption of messages between Autocrypt-capable clients can be enabled without further need of user interaction. Traditional OpenPGP applications should display a noticeable warning if keys are not verified either manually or by a web of trust method before use. In contrast, Autocrypt completely resigns on any kind of key verification. Key exchange is during the initial handshake and valid or invalid keys of peers may be replaced anytime later without any user interaction or verification. This makes it very easy to exchange new key(s) if a user loses access to the key but also makes the protocol much more susceptible to man-in-the-middle attacks than clean TOFU. The underlying OpenPGP implementation makes it often possible for the user to perform manual out of band key verification, however by design users are never alerted if Autocrypt changed the keys of peers.
Autocrypt tries to maximize the possible opportunities for encryption, but is not aggressive about encrypting messages at all possible opportunities. Instead, encryption is only enabled by default if all communicating parties consent, allowing users to make themselves available for encrypted communication without getting in the way of their established workflows.[1]
Man-in-the-middle attacks are not preventable in this security model, which is controversial.[2]
Any attacker who can send emails with forged sender-address can cause encryption keys to be replaced by keys of his choice and/or deliberately turn off encryption.[3]
Technical details
Autocrypt uses the established OpenPGP specification as its underlying data format. With Version 1.1 support for Elliptic_Curve_Cryptography (ECC) has been introduced and is the standard for new keys, because it provides the same security with shorter keys.[4] For this Curve25519 is used.[5] Messages are encrypted using AES and RSA keys, with a recommended RSA key length of 3072 bits. These mechanisms are chosen for maximum compatibility with existing OpenPGP implementations. There are plans for moving to smaller Elliptic-curve keys when support is more widely available.[6]
The Autocrypt
header field features a tag=value
format common to several mechanisms (for example dkim), where the keydata
tag contains the public key. It is similar to an armored key export, except that it misses the -----BEGIN PGP PUBLIC KEY BLOCK-----
and -----END PGP PUBLIC KEY BLOCK-----
lines.[7]
For example:
Autocrypt: [email protected]; prefer-encrypt=mutual; keydata=
mDMEXEcE6RYJKwYBBAHaRw8BAQdArjWwk3FAqyiFbFBKT4TzXcVBqPTB3gmzlC/Ub7O1u12
0F2FsaWNlQGF1dG9jcnlwdC5leGFtcGxliJYEExYIAD4WIQTrhbtfozp14V6UTmPyMVUMT0
fjjgUCXEcE6QIbAwUJA8JnAAULCQgHAgYVCgkICwIEFgIDAQIeAQIXgAAKCRDyMVUMT0fjj
kqLAP9frlijw BJvA+HFnqCZcYIVxlyXzS5Gi5gMTpp37K73jgD/VbKYhkwk9iu689OYH4K
7q7LbmdeaJ+RX88Y/ ad9hZwy4OARcRwTpEgorBgEEAZdVAQUBAQdAQv8GIa2rSTzgqbXCp
DDYMiKRVitCsy203x3sE9+eviIDAQgHiHgEGBYIACAWIQTrhbtfozp14V6UTmPyMVUMT0fj
jgUCXEcE6QIbDAAKCRDyMVUMT0fjjlnQAQDFHUs6TIcxrNTtEZFjUFm1M0PJ1Dng/cDW4xN
80fsn0QEA22Kr7VkCjeAEC08VSTeV+QFsmz55/lntWkwYWhmvOgE=
Support
- Kontact since version 21.04.[8]
- Delta Chat messenger from Version 0.9.2.[9]
- K-9 Mail Android mail-app has support since Version 5.400[10] (reportedly broken until version 5.717[11]).
- SnappyMail webmail from Version 2.34.0.[12]
- Thunderbird partially supports AutoCrypt since version 78. Thunderbird generates, sends and receives AutoCrypt headers, but does not automatically install received public keys. User action is still required to approve and install a sender's public key.[13]
- The German email provider Posteo supports AutoCrypt, and improves its security by also cryptographically signing outbound Autocrypt header data via DKIM.[14]
- No longer functional: Autocrypt extension in Thunderbird.[15]
- No longer functional: Thunderbird extension Enigmail since version 2.0.[16]
Further reading
- Autocrypt - in: Bertram, Linda A. / Dooble, Gunther van / et al. (Eds.): Nomenclatura: Encyclopedia of modern Cryptography and Internet Security - From AutoCrypt and Exponential Encryption to Zero-Knowledge-Proof Keys, 2019, ISBN 9783746066684.
- OpenPGP
- Transformation of Cryptography: Fundamental concepts of Encryption[17]
- The New Era Of Exponential Encryption: - Beyond Cryptographic Routing[18]
External links
- Autocrypt Website
- Autocrypt 1.0 Specification
- Autocrypt mailing list
- Autocrypt github repo
- Bundesmann, Jan (18 April 2018), "Autocrypt automatisiert E-Mail-Kryptografie", Heise Select (in German), vol. 2018, no. 5, pp. 64–66, retrieved 24 April 2018
- iX. "Einfache Mail-Verschlüsselung: PGP-Helfer Autocrypt in Version 1.0 vorgestellt" (in German). Retrieved 24 April 2018.
References
- ^ "OpenPGP Considerations, Part III: Autocrypt and Encryption by Default | K-9 Mail". k9mail.github.io. Retrieved 28 April 2018.
- ^ "Bye-bye Enigmail!: OpenPGP wird in Thunderbird integriert - Golem.de". www.golem.de (in German). Retrieved 23 December 2019.
- ^ "Autocrypt FAQ — What about spammers accidentally downgrading encryption?". autocrypt.org. Retrieved 1 December 2019.
- ^ "Autocrypt Level 1: Enabling encryption, avoiding annoyances". Retrieved 2 January 2025.
- ^ "Autocrypt FAQ Frequently Asked Questions". Retrieved 2 January 2025.
- ^ "Autocrypt FAQ — Why RSA3072 and 25519 only later?". autocrypt.org. Retrieved 29 April 2018.
- ^ "The Autocrypt Header". autocrypt.org. Retrieved 29 May 2024.
- ^ Paul Brown, Carl Schwan, and Áron Kovács (22 April 2021). "KDE Gear 21.04 released". Retrieved 22 April 2021.
{{cite web}}
: CS1 maint: multiple names: authors list (link) - ^ "Delta Chat v0.9.2 feat. Autocrypt Level 1". Retrieved 26 April 2018.
- ^ "5.4 Release | K-9 Mail". Archived from the original on 21 December 2018. Retrieved 24 April 2018.
- ^ "K-9 mail fails to encrypt emails by default, even with "Autocrypt mutual mode" enabled". GitHub. Retrieved 27 February 2021.
- ^ "Releases: the-djmaze/snappymail". GitHub. Retrieved 17 February 2024.
- ^ "Does Thunderbird support Autocrypt?". Mozilla Support. 26 June 2022. Retrieved 25 June 2024.
- ^ "Vereinfachte E-Mail-Verschlüsselung mit Autocrypt- und OpenPGP-Header". Posteo.de (in German). 18 December 2017. Retrieved 24 April 2018. [Our contribution to security: We additionally secure the key exchange with Autocrypt with digital signatures (DKIM). This is not currently provided as standard with Autocrypt. Our provider-side DKIM signature ensures that public keys cannot be manipulated unnoticed during transport. We also sign Autocrypt headers that your local email program may add with DKIM. The signature is applied if the sender matches the mailbox. We save the key exchange with Autocrypt additionally with digital signatures (DKIM). This is not yet provided by default at Autocrypt. Our provider-side DKIM signing ensures that public keys cannot be manipulated unnoticed on transport. We also sign autocrypt header, which your local email program may add, with DKIM. The signature is made when the sender matches the mailbox.]
- ^ "Autocrypt". addons.thunderbird.net. Retrieved 8 October 2019.
- ^ Patrick Brunschwig. "Enigmail - 2018-03-25 Enigmail v2.0 released". Retrieved 24 April 2018.
- ^ Bertram, Linda A.; Dooble, Gunther van (31 July 2019). Transformation of Cryptography: Fundamental concepts of Encryption, Milestones, Mega-Trends and sustainable Change in regard to Secret Communications and its Nomenclatura. BoD – Books on Demand. ISBN 978-3-7494-5074-9.
- ^ Gasakis, Mele; Schmidt, Max (8 January 2019). The New Era Of Exponential Encryption: - Beyond Cryptographic Routing with the Echo Protocol [Paperback]. BoD – Books on Demand. ISBN 978-3-7481-5886-8.