| Size: 4504 Comment: privacytools.io |  ← Revision 100 as of 2025-08-27 17:57:35  ⇥ Size: 9579 Comment: Changed information about Mailbox because of https://lists.gnupg.org/pipermail/gnupg-users/2025-July/067758.html and own test | 
| Deletions are marked like this. | Additions are marked like this. | 
| Line 5: | Line 5: | 
| Web Key Directories provide an easy way to discover public keys through H~T~T~P~S. They provide an important piece to the infrastructure **to improve the user experience | A Web Key Directory (WKD) provides an easy way to provide and get the current public key for a given email address through H~T~T~P~S. Thus it is infrastructure **to improve the user experience | 
| Line 9: | Line 11: | 
| In contrast to the public keyservers a Web Key Directory does not publish mail addresses. And it is an authoritative pubkey source for its domain. | Because the email address is needed to ask for a public key, using a Web Key Directory preserves the privacy of this address. If a public key is found, it can be used to encrypt to the email address right away. | 
| Line 12: | Line 16: | 
| == How does it work? | == for Users * Explanations: [[/forUsers]] * Usage: See section [[https://wiki.gnupg.org/WKD#Implementations|Implementations]] | 
| Line 14: | Line 20: | 
| # The sender's mail client checks a "well known" U~R~L on the domain of the recipient. # If a public key is available for that mail address, will be downloaded via H~T~T~P~S. # The downloaded pubkey can now be used without further user interaction. | == How does an email client use WKD? | 
| Line 20: | Line 22: | 
| Such an URL looks like: {{{https://intevation.de/.well-known/openpgpkey/hu/g8td9rsyatrazsoiho37j9n3g5ypp34h}}} for the mail address "aheinecke@intevation.de" | # A user selects a recipient for an email. # The email client uses the domain part of the email address to construct which server to ask. # HTT~PS is used to get the current public key. # The email client is ready to encrypt and send now. An example: {{{https://intevation.de/.well-known/openpgpkey/hu/it5sewh54rxz33fwmr8u6dy4bbz8itz4?l=bernhard.reiter}}} is the //direct method// URL for "bernhard.reiter@intevation.de". {{{gpg-wks-client}}} command can be used to generate wkd hash or wkd url for any email address, though it seems to prefer the subdomain method url over direct url. {{{ $ gpg-wks-client --print-wkd-hash bernhard.reiter@intevation.de it5sewh54rxz33fwmr8u6dy4bbz8itz4 bernhard.reiter@intevation.de }}} {{{ $ gpg-wks-client --print-wkd-url bernhard.reiter@intevation.de https://openpgpkey.intevation.de/.well-known/openpgpkey/intevation.de/hu/it5sewh54rxz33fwmr8u6dy4bbz8itz4?l=bernhard.reiter }}} | 
| Line 26: | Line 46: | 
| default the encryption state of that mail will toggle if all recipients can be found in a Web Key Directory. | default the encryption state of that mail will toggle if encryption keys can be found for all of them. | 
| Line 36: | Line 56: | 
| If you want to set up a Web Key Directory for your organisation you can find documentation in this wiki. You only need access to a webserver for your domain. See: WKDHosting | If you want to set up a Web Key Directory for your own server or your own server you only need access to a webserver for your domain. See: WKDHosting | 
| Line 40: | Line 59: | 
| For a larger organisation it is recommended to set up a complete Web Key | For a larger organization it is recommended to set up a complete Web Key | 
| Line 43: | Line 62: | 
| === Stopgap method - temporary central keyserver Not recommended - but a temporary workaround - is to use "WKD~aaS" and delegate delivery of your pubkey to a central service. Doing this you'll expose all people that want to use crypto when communication with you towards another party of the central service or monitoring the central service. This third party can then see the communication pattern. However this maybe a temporary solution until you will convince your mail provider to enable at least the WKD serving part or to switch to a more privacy aware mail provider. One service is keys.openpgp.org, where you can set the ~C~N~A~M~E record of the "openpgpkey" subdomainto "wkd.keys.openpgp.org" the CNAME entry should look like this. {{{ openpgpkey.example.org. 300 IN CNAME wkd.keys.openpgp.org. }}} In addition you need to register your pubkey with them. Other drawbacks: * As any WKD service, they'll be able to serve a different pubkey to some domains at some time, however opposed to your email provider you do not have a contractual relationship with them. * Elder Gnu~PGs like the some on Debian Stretch do not offer the necessary modern WKD implementation for a successful request, so you are reaching less communication partners with this compared to real WKD. * (For the overall ecosystem, we need more decentral services instead, it is at the core of Open~PGP security promise. So you are missing to set a good example. ;) ) | |
| Line 60: | Line 102: | 
| === Troubleshooting If you have arrived here after receiving an email saying: {{{ The web page https://gnupg.org/faq/wkd.html explains how you can process this message anyway in a few manual steps. }}} you can find further instructions at WKSManualConfirmation. | |
| Line 63: | Line 120: | 
| * WKD lookup is implemented in GnuPG since v2.1.12. It is enabled by default since 2.1.23.. | * WKD lookup is implemented in GnuPG since v2.1.12. It is enabled by default since 2.1.23. ** Use {{{gpg --locate-external-keys user@example.com}}} to fetch Open~PGP-Keys via WKD. | 
| Line 73: | Line 130: | 
| * Thunderbird/[[https://www.enigmail.net/index.php/en/download/changelog|Enigmail 2.0]] * KMail since Version 5.6 * Outlook with GpgOL since Version 2.2.0 * Mailvelope since Version 3.0.0 (Dez 2018) | * Desktop: ** Thunderbird/[[https://www.enigmail.net/index.php/en/download/changelog|Enigmail 2.0]] ** KMail since Version 5.6 ** Outlook with GpgOL since Version 2.2.0 ** Claws Mail since [[https://www.claws-mail.org/news.php|3.18.0 / 4.0.0]] ** Balsa has no official release - which is supporting WKD - yet but the feature was [[https://gitlab.gnome.org/GNOME/balsa/-/commit/03272a0e053002c7b5cf53d3dc8f87229b8552a4|merged]] into the main branch * Browser-Extensions: ** Mailvelope since Version 3.0.0 (Dez 2018) * Android: ** [[https://k9mail.app/|K9Mail]] with OpenKeyChain since Version 5.1 (Jun 2018) ** [[https://email.faircode.eu/|FairEmail]] with OpenKeyChain since OpenKeyChain 5.4 ([[https://github.com/M66B/FairEmail/blob/master/FAQ.md#user-content-faq12|FAQ, (12) How does encryption/decryption work?]]) [[/DistributionOfWKD|Progress of WKD]] in different mail clients | 
| Line 84: | Line 150: | 
| === Self-hosted email setups offering WKD + WKS: * [[https://github.com/vedetta-com/caesonia/|caesonia - OpenBSD email service]]. * [[https://github.com/Excision-Mail/Excision-Mail/| Excision Mail - OpenBSD email service using ansible]]: Has multiple-domain WKS support. * [[https://github.com/systemli/userli|Userli - Web application to (self-) manage e-mail users and encrypt their mailboxes.]]. === Online checkers (external services, your mileage my wary) * [[https://WebKeyDirectory.com|WebKeyDirectory.com]] (source code not public, and some recommendations differ a bit from the specification (2025-02-19)) * [[https://wkd.chimbosonic.com/|wkd.chimbosonic.com]] (source code at https://github.com/chimbosonic/wkd-tester ) | |
| Line 85: | Line 162: | 
| * [[https://posteo.de/en/|Posteo]] offers web key directory lookup and service for {{{@posteo.de}}}-addresses (**Since 2016-12**) * [[https://protonmail.com|Protonmail]] supports web key directory lookup (**Since ~2018-11**) | * [[https://forwardemail.net/faq#do-you-support-openpgpmime-end-to-end-encryption-e2ee-and-web-key-directory-wkd|Forward Email]] has WKD support for inbound, outbound, and forwarded mail. (**Since 2023-12-27**) * [[https://posteo.de/en/|Posteo]] offers web key directory lookup and service for {{{@posteo.de}}}-addresses (**Since 2016-12**) ** [[https://posteo.de/en/help/publishing-public-pgp-key-for-posteo-email-address|How do I publish the public PGP key for my Posteo email address in the Posteo key directory?]] * [[https://protonmail.com|Protonmail]] supports web key directory lookup (**Since ~2018-11**) in [[https://protonmail.com/blog/security-updates-2019/|both ways]]. | 
| Line 89: | Line 167: | 
| * [[https://mailbox.org/en/|mailbox.org]] **plans** to offer web key directory lookup in Q2 2018 (coming with [[https://knowledgebase.open-xchange.com/roadmap.html#21|OX Guard 2.10]]). * (Self)-hosted email servers that run [[https://github.com/vedetta-com/caesonia/|caesonia - an OpenBSD Email Service]] setup. | * [[https://systemli.org|systemli.org]] offers web key directory lookup and service for all hosted domains (**Since 2020-10-15**) * [[https://mailbox.org/en/|mailbox.org]] offers web key directory lookup ([[https://mailbox.org/en/post/the-keyserver-is-dead-long-live-the-keyserver|Announcement 2019)]]. * [[https://mail.de/|mail.de]] maintains a WKD server (Screenshot: [[attachment:mailde_wkd.png]]) * [[https://mailfence.com/|Mailfence]] supports web key directory lookup (**Since ~2021-11-18**) in [[https://blog.mailfence.com/improving-security/|both ways]]. | 
| Line 97: | Line 175: | 
| * [[https://www.cotech.de|cotech.de]] | * [[https://www.credativ.de/blog/aktuelles/credativde-pgp-schluessel-ueber-wkd-abrufen/|Credativ GmbH, DE]] | 
| Line 103: | Line 181: | 
| * [[https://nikkasystems.com|Nikka Systems]] | |
| Line 107: | Line 186: | 
| * [[https://privacytools.io|privacytools.io]] * (Several smaller organizations. Like - unsurprisingly - g10code.com and intevation.de. //Let us know if you want to be publicly listed.//) | * [[https://www.privacyguides.org|privacyguides.org]] * [[https://univention.de/wkd/|Univention GmbH]] * (Several unlisted organisations. And of course the main designers of WKD - g10code.com, intevation.de.) (//Add yourself or let us know if you want to be publicly listed.//) == Misc * [[/BachelorThesisIncreaseWKDUsage2021|Bachelor thesis: How to increase the usage of WKD? (2021, Christoph Klassen)]] | 
Contents
What is a Web Key Directory?
A Web Key Directory (WKD) provides an easy way to provide and get the current public key for a given email address through HTTPS. Thus it is infrastructure to improve the user experience for exchanging secure emails and files.
Because the email address is needed to ask for a public key, using a Web Key Directory preserves the privacy of this address. If a public key is found, it can be used to encrypt to the email address right away.
for Users
- Explanations: /forUsers
- Usage: See section Implementations
How does an email client use WKD?
- A user selects a recipient for an email.
- The email client uses the domain part of the email address to construct which server to ask.
- HTTPS is used to get the current public key.
- The email client is ready to encrypt and send now.
An example: https://intevation.de/.well-known/openpgpkey/hu/it5sewh54rxz33fwmr8u6dy4bbz8itz4?l=bernhard.reiter is the direct method URL for "bernhard.reiter@intevation.de".
gpg-wks-client command can be used to generate wkd hash or wkd url for any email address, though it seems to prefer the subdomain method url over direct url.
$ gpg-wks-client --print-wkd-hash bernhard.reiter@intevation.de it5sewh54rxz33fwmr8u6dy4bbz8itz4 bernhard.reiter@intevation.de
$ gpg-wks-client --print-wkd-url bernhard.reiter@intevation.de https://openpgpkey.intevation.de/.well-known/openpgpkey/intevation.de/hu/it5sewh54rxz33fwmr8u6dy4bbz8itz4?l=bernhard.reiter
What does it mean for users?
A user just selects the recipients of a message and by default the encryption state of that mail will toggle if encryption keys can be found for all of them.
For a basic level of security the user does not need to check a fingerprint or do any key management manually.
How to set it up?
If you want to set up a Web Key Directory for your own server or your own server you only need access to a webserver for your domain. See: WKDHosting
For a larger organization it is recommended to set up a complete Web Key Service, which will help to automate Web Key Directory publishing.
Stopgap method - temporary central keyserver
Not recommended - but a temporary workaround - is to use "WKDaaS" and delegate delivery of your pubkey to a central service. Doing this you'll expose all people that want to use crypto when communication with you towards another party of the central service or monitoring the central service. This third party can then see the communication pattern.
However this maybe a temporary solution until you will convince your mail provider to enable at least the WKD serving part or to switch to a more privacy aware mail provider.
One service is keys.openpgp.org, where you can set the CNAME record of the "openpgpkey" subdomainto "wkd.keys.openpgp.org" the CNAME entry should look like this.
openpgpkey.example.org. 300 IN CNAME wkd.keys.openpgp.org.
In addition you need to register your pubkey with them.
Other drawbacks:
- As any WKD service, they'll be able to serve a different pubkey to some domains at some time, however opposed to your email provider you do not have a contractual relationship with them.
- Elder GnuPGs like the some on Debian Stretch do not offer the necessary modern WKD implementation for a successful request, so you are reaching less communication partners with this compared to real WKD.
- (For the overall ecosystem, we need more decentral services instead, it is at the core of OpenPGP security promise. So you are missing to set a good example. ;) )
Web Key Directory (WKD) / Web Key Service (WKS) what is the difference?
The Web Key Directory is the HTTPS directory from which keys can be fetched.
The Web Key Service is a tool / protocol to automatically publish and update keys in the Web Key Directory. It is optional to reduce the administrative effort of a Web Key Directory.
Documentation how to set up a Web Key Service can be found on the Web Key Service page.
Technical Details
You can find the concepts / technical details under WKDDetails.
Trust and security considerations are outlined as part of the AutomatedEncryption concept.
Troubleshooting
If you have arrived here after receiving an email saying:
The web page
       https://gnupg.org/faq/wkd.html
explains how you can process this message anyway in
a few manual steps.you can find further instructions at WKSManualConfirmation.
Implementations
GnuPG
- WKD lookup is implemented in GnuPG since v2.1.12. It is enabled by default since 2.1.23.- Use gpg --locate-external-keys user@example.com to fetch OpenPGP-Keys via WKD.
 
- WKS server and client tools are part of GnuPG since v2.1.14
Mail Clients
Any mail client which uses the --locate-keys option of GnuPG will automatically do WKD requests.
Known mail clients with WKD Support:
- Desktop:- Thunderbird/Enigmail 2.0
- KMail since Version 5.6
- Outlook with GpgOL since Version 2.2.0
- Claws Mail since 3.18.0 / 4.0.0
- Balsa has no official release - which is supporting WKD - yet but the feature was merged into the main branch
 
- Browser-Extensions:- Mailvelope since Version 3.0.0 (Dez 2018)
 
- Android:- K9Mail with OpenKeyChain since Version 5.1 (Jun 2018)
- FairEmail with OpenKeyChain since OpenKeyChain 5.4 (FAQ, (12) How does encryption/decryption work?)
 
Progress of WKD in different mail clients
Known mail clients with WKS Support:
- Thunderbird/Enigmail 2.0
- KMail since Version 5.6
- Outlook with GpgOL (basic, pre-release) since Version 2.2.1 asyGpg2016)
Self-hosted email setups offering WKD + WKS:
- caesonia - OpenBSD email service.
- Excision Mail - OpenBSD email service using ansible: Has multiple-domain WKS support.
- Userli - Web application to (self-) manage e-mail users and encrypt their mailboxes..
Online checkers
(external services, your mileage my wary)
- WebKeyDirectory.com (source code not public, and some recommendations differ a bit from the specification (2025-02-19))
- wkd.chimbosonic.com (source code at https://github.com/chimbosonic/wkd-tester )
Mail Service Providers offering WKD
- Forward Email has WKD support for inbound, outbound, and forwarded mail. (Since 2023-12-27)
- Posteo offers web key directory lookup and service for @posteo.de-addresses (Since 2016-12)
- Protonmail supports web key directory lookup (Since 2018-11) in both ways.
- netzguerilla offers web key directory lookup. (Since 2017-10-11)
- systemli.org offers web key directory lookup and service for all hosted domains (Since 2020-10-15)
- mailbox.org offers web key directory lookup (Announcement 2019).
- mail.de maintains a WKD server (Screenshot: attachment:mailde_wkd.png)
- Mailfence supports web key directory lookup (Since 2021-11-18) in both ways.
Organizations using WKD
- C3S
- Credativ GmbH, DE
- debian.org
- gentoo.org
- gnupg.org (Testing accounts available for developers implementing WKD in MUAs.)
- KDAB.com
- kernel.org
- Nikka Systems
- occrp.org
- torproject.org
- f-droid.org
- guardianproject.info
- privacyguides.org
- Univention GmbH
- (Several unlisted organisations. And of course the main designers of WKD - g10code.com, intevation.de.)
(Add yourself or let us know if you want to be publicly listed.)
