{{Header}}
{{#seo:
|description=OpenPGP, gpg, Related Tools, Links, Advanced Topics, The OpenPGP Web of Trust, Bootstrapping OpenPGP keys from the web
|image=GnuPG-Logo.svg
}}
{{verification_tools_mininav}}
[[File:GnuPG-Logo.svg|thumb|100px|GnuPG logo]]
{{intro|
OpenPGP, gpg, Related Tools, Links, Advanced Topics, The OpenPGP Web of Trust, Bootstrapping OpenPGP keys from the web
}}
[[File:hauke_laging_gepruefter_artikel.en.png|400px|link=http://www.openpgp-schulungen.de/fuer/webautoren/|[https://www.hauke-laging.de/ Hauke Laging]'s clearsigned version of this text can be found here: [[OpenPGP_Certified]].
The [http://www.openpgp-schulungen.de/fuer/webautoren/ certification] image ([https://www.whonix.org/wiki/File:Hauke_laging_gepruefter_artikel.en.png hauke_laging_gepruefter_artikel.en.png]) is copyrighted by [https://www.hauke-laging.de/ Hauke Laging].|thumb]]
= Introduction =
OpenPGP is: https://www.openpgp.org/about/ https://www.openpgp.org/
... a non-proprietary protocol for encrypting email communication using public key cryptography. It is based on the original PGP (Pretty Good Privacy) software. The OpenPGP protocol defines standard formats for encrypted messages, signatures, and certificates for exchanging public keys.
OpenPGP is the most widely used email encryption standard. ... OpenPGP was originally derived from the PGP software, created by [https://philzimmermann.com/EN/background/index.html Phil Zimmermann].The primary purpose of OpenPGP relates to end-to-end encrypted email communication, but it is also utilized for encrypted messaging, password managers and other use cases. OpenPGP provides support for all major operating systems like Windows, macOS, GNU/Linux, Android and iOS. The openPGP standard was proposed to the Internet Engineering Task Force (IETF) and accepted as a standard in 1997. The standard has been continuously improved since that time and there is no suggestion intelligence agencies can break it. https://en.wikipedia.org/wiki/Pretty_Good_Privacy#OpenPGP OpenPGP has an impressive resume and a host of applications, developer libraries and miscellaneous tools have implemented the OpenPGP standard either directly or with additional software. Applicable domains include: * [https://www.openpgp.org/software/ Email encryption]: for various platforms, browser plugins, webmail providers with browser plugins, and webmail providers with in-browser cryptography * [https://www.openpgp.org/software/server/ Server software]: webmail clients, keyservers, mailing list software and password managers * [https://www.openpgp.org/software/developer/ Developer libraries]: various OpenPGP libraries, libraries supporting OpenPGP smartcards, and developer tools * [https://www.openpgp.org/software/misc/ Miscellaneous tools]: web-based tools and other applications '''Figure:''' ''How PGP Works'' https://en.wikipedia.org/wiki/File:PGP_diagram.svg [[File:HowPGPworks.png|border]] To learn more about this topic, refer to the following resources: * [https://www.openpgp.org/ OpenPGP website] * [https://github.com/openpgp OpenPGP on GitHub] * [https://en.wikipedia.org/wiki/Pretty_Good_Privacy Pretty Good Privacy on Wikipedia] * [[Verifying Software Signatures]] To search for keys by email address, Key ID or Fingerprint, visit the [https://keys.openpgp.org/
keys.openpgpg.org
server] ([http://zkaan2xfbuxia2wpf7ofnkbz6r5zdbbvxbunvp5g2iebopbfc4iqmbad.onion/ .onion]). This publicly available service ("keyserver") enables the uploading, discovery, distribution and management of OpenPGP-compatible keys.
= Common Misconceptions =
{{gpg_signature_timestamp}}
{{GnuPG_file_names}}
= Key Servers =
{{Box|text=
'''1.''' Test gpg.
For example, run.
{{CodeSelect|code=
gpg --keyserver keys.openpgp.org --recv A3C4F0F979CAA22CDBA8F512EE8CBC9E886DDD89
}}
'''2.''' Note: The use of --recv
or --recv-key
is deprecated.
Instead, it is recommended to [[Secure Downloads|securely download]] the key from a source that is logically connected to the owner, if possible, outside the keyserver model.
'''3.''' If a keyserver is required, utilize the onion address for keys.openpgp.org
.
At the time of writing, the following onion address is consistently functional: http://zkaan2xfbuxia2wpf7ofnkbz6r5zdbbvxbunvp5g2iebopbfc4iqmbad.onion
'''4.''' Learn more about gpg configuration basics for use with keys.openpgp.org
.
Instructions are available [https://keys.openpgp.org/about/usage here] [http://zkaan2xfbuxia2wpf7ofnkbz6r5zdbbvxbunvp5g2iebopbfc4iqmbad.onion/about/usage (.onion)].
Also see:
* [https://forums.whonix.org/t/gpg-recv-keys-fails-no-longer-use-keyservers-for-anything/5607 gpg --recv-keys fails / no longer use keyservers for anything]
* [https://forums.whonix.org/t/new-fixed-keyserver-keys-openpgp-org/11761 new, fixed keyserver - keys.openpgp.org]
}}
= Related Tools =
Encrypt, decrypt, sign, and verify text using [[Software#OpenPGP_.28GnuPG_Frontend.29| OpenPGP (GnuPG Frontend)]].
= Issues with PGP =
PGP has very bad usability and cryptography. Common PGP clients such as GnuPG are also not very secure. Thus, it is recommended against by many cryptography experts.
* [https://blog.cryptographyengineering.com/2014/08/13/whats-matter-with-pgp/ What's the matter with PGP?]
* [https://latacora.micro.blog/2019/07/16/the-pgp-problem.html The PGP Problem]
* [https://words.filippo.io/giving-up-on-long-term-pgp/ I'm giving up on PGP]
* [https://moxie.org/2015/02/24/gpg-and-me.html GPG And Me]
* [https://secushare.org/PGP 15 reasons not to start using PGP]
* [https://buttondown.email/cryptography-dispatches/archive/505a859e-964d-4d15-9ad8-7ad0f45e1345 Cryptography Dispatches: Replace PGP With an HTTPS Form]
* [https://www.openbsd.org/papers/bsdcan-signify.html signify: Securing OpenBSD From Us To You]
Not yet reviewed: .onion
domain. Of course, this presupposes the visitor is aware what kind of transportation mechanism is provided. In this case, the adversary would have to:
* break the TLS or onion encryption where someone wants to obtain the key or fingerprint; or
* compromise the server
Depending on the adversary this may take more resources. It should be noted that both the public CA system of TLS and Tor onion services have security issues; see [[SSL|TLS]] and [[Onion_Services#Onion_Services_Security|Onion Services Security]] for further information.
Based on the preceding discussion, it is safest if the same website is accessible over both http'''s''' and .onion
. This configuration allows the user to visit both sites and then check if the OpenPGP fingerprint/key results match.
To further improve the situation the key holder can spread its fingerprint and/or OpenPGP key to other websites. Some key holders attach their OpenPGP fingerprint to their email signature (a short attachment to any mail) and to public mailing lists they are participating in. This behavior makes it difficult for an adversary to successfully spoof all these information avenues. Spreading the fingerprint and/or key in various domains is only helpful if the person searching is either aware of that fact or has undertaken research on their own initiative.
https://api.github.com/users/Smart cards can be physically disassembled by using acid, abrasives, or some other technique to obtain unrestricted access to the on-board microprocessor. Although such techniques involve a fairly high risk of permanent damage to the chip, and irrecoverable loss of the secret keys therein, they permit much more detailed information (e.g. photomicrographs of encryption hardware) to be extracted.Other, non-OpenPGP smartcards have been cracked in the past using ultra-expensive electron-scanning microscopes. Source: theguardian, [https://www.theguardian.com/technology/2002/mar/13/media.citynews How codebreakers cracked the secrets of the smart card] https://www.cl.cam.ac.uk/~sps32/mcu_lock.html More information is required on how realistic, difficult and expensive these attacks are. Additional reader contributions on this issue are most welcome. |- | style="height:35px;width:70px;background-color: #f9f9f9"| OpenPGP private key cannot be used by malware If the machine in use has been compromised by malware like a trojan horse. when key attached On storage (HDD, SSD, USB etc.) vs on token or smartcard. and passphrase stolen By keylogger or extracted from memory once cached. or pin cached | {{No}} | {{No}} |- | style="height:35px;width:70px;background-color: #f9f9f9"| OpenPGP private key cannot be extracted, deleted or revoked by malware | {{No}} Therefore make sure to have a backup on storage that is never attached to that machine. | {{Yes}} |- | style="height:35px;width:70px;background-color: #f9f9f9"| Encryption of user's data is still effective once malware infected | {{No}} An adversary who managed to compromise the user's machine can use a keylogger to sniff the OpenPGP private key password once it is entered next time or extract it from memory if it is still cached. Any of the user's encrypted email, files, etc. (that are read from the user's devices or that have been extracted from other sources, such as by man-in-the-middle attacks or obtained from the user's mail provider and so forth) can then be decrypted. | {{No}} An adversary who managed to compromise the user's machine can wait until the user caches its pin next time. Otherwise, same as above. Once a machine has been compromised, nothing it shows can be trusted anymore, even if the PIN is never cached. If the PIN is cached or not is up to the software on the user's machine which can be no longer trusted once compromised. The adversary could install their own key caching software (gnupg-agent). Instead of the user's request "decrypt mail X", malware can also intercept this and make it "decrypt mail Y and X". |- | style="height:35px;width:70px;background-color: #f9f9f9"| Signatures cannot be created by malware | {{No}} | {{No}} |- | style="height:35px;width:70px;background-color: #f9f9f9"| Signature counter on hardware device | {{No}} | {{Yes}} Users could attach their smartcard to other computers, perhaps non-compromised, perhaps offline machines and check the signature counter. For example output, see: [https://spin.atomicobject.com/2014/02/09/gnupg-openpgp-smartcard/ Using an OpenPGP Smartcard with GnuPG]. |- | style="height:35px;width:70px;background-color: #f9f9f9"| Signature counter on computer display trustworthy if attached on malware infected computer | Not applicable | {{No}} Once malware is running on a machine, nothing the machine displays can be trusted. It could be manipulated by the malware. |- | style="height:35px;width:70px;background-color: #f9f9f9"| Signature counter trustworthy if attached on malware-free machine Assumption: The token or card reader has not been compromised by malware running on the user's machine. | Not applicable | {{Yes}} |- |} In conclusion, both options have unique advantages. Unfortunately, it is not yet possible to combine both options. = FAQ = '''Why aren't the SKS keyserver wiki steps always functional?''' The SKS keyserver network has recently come under attack after a critical vulnerability was discovered which allows certificates to be spammed using a flaw in the OpenPGP protocol itself. Future releases of OpenPGP software will likely mitigate this flaw, but high profile contributors to the protocol suggest that data should not be retrieved form the network at present if possible. For more details, see [https://gist.github.com/rjhansen/67ab921ffb4084c865b3618d6955275f here]. New, experimental keyservers have been established which afford protection against this attack. The author notes the potential downsides of this attack:
* If you fetch a poisoned certificate from the keyserver network, you will break your GnuPG installation. * Poisoned certificates cannot be deleted from the keyserver network. * The number of deliberately poisoned certificates, currently at only a few, will only rise over time. * We do not know whether the attackers are intent on poisoning other certificates. * We do not even know the scope of the damage.----- '''Is the OpenPGP keyserver part of the SKS pool?''' The [https://keys.openpgp.org/about/faq OpenPGP keyserver FAQ] notes:
No. The federation model of the SKS pool has various problems in terms of reliability, abuse-resistance, privacy, and usability. We might do something similar to it, but keys.openpgp.org will never be part of the SKS pool itself.----- '''Why can't I receive a key using the new keyserver
keys.openpgp.org
?'''
At the time of writing, the clearnet keyserver will sometimes lead to the following error:
gpg: keyserver receive failed: No keyserver availableAs recommended [[#Key_Servers|here]], either: * Securely download the key from a source outside the keyserver model; or * If that is not possible, utilize the keyserver v3 onion address instead:
http://zkaan2xfbuxia2wpf7ofnkbz6r5zdbbvxbunvp5g2iebopbfc4iqmbad.onion
= See Also =
* [[Verifying Software Signatures]]
* [[OpenPGP]]
* [[Verify the images]]
* [[Signing Key|{{project_name_short}} Signing Key]]
* [[Software Signature Verification Usability Issues and Proposed Solutions]]
= Footnotes =
{{reflist|close=1}}
= License =
The [http://www.openpgp-schulungen.de/fuer/webautoren/ certification] image ([https://www.whonix.org/wiki/File:Hauke_laging_gepruefter_artikel.en.png hauke_laging_gepruefter_artikel.en.png]) is copyrighted by [https://www.hauke-laging.de/ Hauke Laging].
The rest of this page is under the following license.
{{project_name_short}} OpenPGP wiki page Copyright (C) Amnesia{{Footer}} [[Category:Documentation]]{{project_name_short}} OpenPGP wiki page Copyright (C) 2012 - 2025 ENCRYPTED SUPPORT LLC This program comes with ABSOLUTELY NO WARRANTY; for details see the wiki source code. This is free software, and you are welcome to redistribute it under certain conditions; see the wiki source code for details.