GPG

GNU Privacy Guard (GPG) is an open-source software project implementing the OpenPGP protocol.

The primary entry point is the userland gpg2(1) utility.


Installation

Essentially all Linux or BSD distributions will include gpg in the base system.


Configuration

The various component programs of GPG look for configuration files in ~/.gnupg or, if set, in $GNUPGHOME.

GPG Agent

gpg-agent(1) manages keys for the user. It is configured with $GNUPGHOME/gpg-agent.conf.

For example, the program that prompts a user for a password is configured with:

pinentry-program /var/bin/pinentry-tty

On a headless system, this is often set to /var/bin/pinentry-ncurses instead.

To force reload gpg-agent(1), try gpg-connect-agent reloadagent /bye.


Usage

List Keys

To list public and private keys, use the --list-keys and list-secret-keys options, respectively.

Note that the output will differ between versions.

Compare the output of gpg(1):

pub 2048R/7A605FF0 2020-12-31
uid Your Name (Optional Comment) <[email protected]>
sub 2048R/7A605FF0 2020-12-31

To the output of gpg2(1), which is based on Libgcrypt:

pub   rsa2048 2020-12-31 [SC]
      CBD17F206CE430EC21BDD1DC5E2AEDAC7A605FF0
uid           [ultimate] Your Name (Optional Comment) <[email protected]>
sub   rsa2048 2020-12-31 [E]

There are additional options that get gpg2(1) output closer to that of gpg(1).

First, note that sub-key fingerprints are hidden. Use the --with-subkey-fingerprint option to show this.

Second, note that long keys are shown by default. To show short keys, use the --keyid-format short option.

Parsing Key Listings

Use the --with-colons option to produce a listing that is parseable.

tru::1:1661040534:0:3:1:5
pub:u:2048:1:5E2AEDAC7A605FF0:1609372800:::u:::scESC::::::23::0:
fpr:::::::::CBD17F206CE430EC21BDD1DC5E2AEDAC7A605FF0:
uid:u::::1513993480::845C5AF9215BDE349F97DB024D506AE729A36DC8::Dominic Ricottone (does anyone see this?) <[email protected]>::::::::::0:
sub:u:2048:1:BC8D5D2D234809BA:1609372800::::::e::::::23:
fpr:::::::::E172BF957B81824D95B0E765BC8D5D2D234809BA:

tru records are about the trust datebase.

pub records are about public keys.

sub records are about public subkeys. These fields mirror the pub records.

uid records are about user IDs.

fpr records are about key fingerprints, stored in field 10.

Export Keys

To export a private or public key, try:

gpg --armor --export-options export-minimal --export KEYID >pgp.pubkey
gpg --armor --export-secret-key KEYID >pgp.key

Update or Remove Password

Running gpg --edit-key KEYID starts a GPG REPL. To manage the password, enter the passwd command. The user is then prompted for the old and new passwords.

To remove a password from a private key, use L. Try:


CategoryRicottone