summaryrefslogtreecommitdiffstats
path: root/doc/gpg.1pod
blob: 1e9cdcfcfc2af08135deaad1832da382d03787cb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
=head1 NAME

gpg, gpgm - GNU Privacy Guard

=head1 SYNOPSIS

B<gpg> [--homedir name] [--options file] [options] command [args]

B<gpgm> [--homedir name] [--options file] [options] command [args]

=head1 DESCRIPTION

B<gpg> is the main program for the GnuPG system. B<gpgm> is a maintenance
tool which has some commands B<gpg> does not have; it is there because
it does not handle sensitive data and therefore has no need to allocate
secure memory.

=head1 COMMANDS

B<gpg> recognizes these commands:

B<-s>, B<--sign>
    Make a signature. This option may be combined
    with B<--encrypt>.

B<--clearsign>
    Make a clear text signature.

B<-b>, B<--detach-sign>
    Make a detached signature.

B<-e>, B<--encrypt>
    Encrypt data. This option may be combined with B<--sign>.

B<-c>, B<--symmetric>
    Encrypt with symmetric cipher only
    This command asks for a passphrase.

B<--store>
    store only (make a simple RFC1991 packet).

B<--decrypt> [I<file>]
    Decrypt file (or stdin if no file is specified) and
    write it to stdout (or the file specified with
    B<--output>). If the decrypted file is signed, the
    signature is also verified. This command differs
    from the default operation, as it never writes to the
    filename which is included in the file and it
    rejects files which don't begin with an encrypted
    message.

B<--verify> [[I<sigfile>] {I<signed-files>}]
    Assume that I<filename> is a signature and verify it
    without generating any output.  With no arguments,
    the signature packet is read from stdin (it may be a
    detached signature when not used in batch mode). If
    only a sigfile is given, it may be a complete
    signature or a detached signature, in which case
    the signed stuff is expected in a file without the
    I<.sig> or I<.asc> extension (if such a file does
    not exist it is expected at stdin - use B<-> as
    filename to force a read from stdin). With more than
    1 argument, the first should be a detached signature
    and the remaining files are the signed stuff.

B<-k> [I<username>] [I<keyring>]
    Kludge to be somewhat compatible with PGP.
    Without arguments, all public keyrings are listed.
    With one argument, only I<keyring> is listed.
    Special combinations are also allowed, but it may
    give strange results when combined with more options.
    B<-kv>    Same as B<-k>
    B<-kvv>   List the signatures with every key.
    B<-kvvv>  Additionally check all signatures.
    B<-kvc>   List fingerprints
    B<-kvvc>  List fingerprints and signatures

B<--list-keys>	[I<names>]
    List all keys from the public keyrings, or just the
    ones given on the command line.

B<--list-secret-keys> [I<names>]
    List all keys from the secret keyrings, or just the
    ones given on the command line.

B<--list-sigs>	[I<names>]
    Same as B<--list-keys>, but the signatures are listed
    too.

B<--check-sigs> [I<names>]
    Same as B<--list-sigs>, but the signatures are verified.

B<--fingerprint> [I<names>]
    List all keys with their fingerprints. This is the
    same output as B<list-keys> but with the additional output
    of a line with the fingerprint. May also be combined
    with B<--list-sigs> or B<--check-sigs>.

B<--list-packets>
    List only the sequence of packets. This is mainly
    useful for debugging.

B<--gen-key>
    Generate a new key pair. This command can only be
    used interactive.


B<--edit-key> I<name>
    Present a menu which enables you to do all key
    related tasks:
    B<sign>
      Make a signature on key of user I<name>.
      If the key is not yet signed by the default
      user (or the users given with B<-u>), the
      program displays the information of the key
      again, together with its fingerprint and
      asks whether it should be signed. This
      question is repeated for all users specified
      with B<-u>.
    B<trust>
      Change the owner trust value. This updates the
      trust-db immediately and no save is required.
    B<adduid>
      Create an alternate user id.
    B<deluid>
      Delete an user id.
    B<addkey>
       Add a subkey to this key.
    B<delkey>
       Remove a subkey.
    B<expire>
       Change the key expiration time.	If a key is
       select, the time of this key will be changed.
       With no selection the key expiration of the
       primary key is changed.
    B<passwd>
       Change the passphrase of the secret key.
    B<uid> I<n>
       Toggle selection of user id with index I<n>.
       Use 0 to deselect all.
    B<key> I<n>
       Toggle selection of subkey with index I<n>.
       Use 0 to deselect all.
    B<check>
       Check all selected user ids.
    B<pref>
       List preferences.
    B<toggle>
       Toggle between public and secret key listing.
    B<save>
       Save all changes to the key rings and quit.
    B<quit>
       Quit the program without updating the
       key rings.
    The listing shows you the key with its secondary
    keys and all user ids. Selected keys or user ids
    indicated by an asterisk. The trust value is
    displayed with the primary key: The first one is the
    assigned owner trust and the second the calculated
    trust value; letters are used for the values:
      B<->  No ownertrust assigned / not yet calculated.
      B<e>  Trust calculation has failed.
      B<q>  Not enough information for calculation.
      B<n>  Never trust this key.
      B<m>  Marginally trusted.
      B<f>  Fully trusted.
      B<u>  Ultimately trusted


B<--delete-key>
    Remove key from the public keyring

B<--delete-secret-key>
    Remove key from the secret and public keyring

B<--gen-revoke>
    Generate a revocation certificate.

B<--export> [I<names>]
    Either export all keys from all keyrings (default
    keyrings and those registered via option B<--keyring>),
    or if at least one name is given, those of the given
    name. The new keyring is written to F<stdout> or to
    the file given with option "output".  Use together
    with B<-a> to mail those keys.

B<--send-keys> [I<names>]
    Same as B<--export> but sends the keys to a keyserver.
    Option B<--keyserver> must be used to give the name
    of this keyserver. Don't send your complete keyring
    to a keyserver - select only those keys which are new
    or changed by you.

B<--export-all> [I<names>]
    Same as B<--export> but does also export keys which
    are not compatible to OpenPGP.

B<--export-secret-keys> [I<names>]
    Same as B<--export>, but does export the secret keys.
    This is normally not very useful.

B<--import>, B<--fast-import>
    Import/merge keys.	The fast version does not build
    the trustdb; this can be deon at anytime with the
    command B<--update-trustdb>.

B<--export-ownertrust>
    List the assigned ownertrust values in ascii format
    for backup purposes [B<gpgm> only].

B<--import-ownertrust> [I<filename>]
    Update the trustdb with the ownertrust values stored
    in I<filename> (or stdin if not given); existing
    values will be overwritten. [B<gpgm> only].

=head1 OPTIONS

Long options can be put in an options file (default F<~/.gnupg/options>);
do not write the 2 dashes, but simply the name of the option and any
arguments if required.	Lines with a hash as the first non-white-space
character are ignored. Commands may be put in this file too, but that
does not make sense.

B<gpg> recognizes these options:


B<-a>, B<--armor>
    Create ASCII armored output.

B<-o> I<file>, B<--output> I<file>
    Write output to I<file>.

B<-u> I<name>, B<--local-user> I<name>
    Use I<name> as the user-id to sign.
    This option is silently ignored for the list commands,
    so that it can be used in an options file.

B<--default-key>  I<name>
    Use I<name> as default user-id for signatures.  If this
    is not used the default user-id is the first user-id
    from the secret keyring.

B<--trusted-key>  I<keyid>
    Assume that the key with the I<keyid> (which must be
    a full (8 byte) keyid) is as trustworthy as one of
    your own secret keys.  This may be used to make keys
    valid which are not directly certified by you but
    by a CA you trust.	The advantage of this option is
    that it shortens the path of certification.

    You may also use this option to skip the verification
    of your own secret keys which is normally done every
    time GnuPG starts up:  Use for I<keyid> the one of
    your key.

B<-r>  I<name>, B<--remote-user>  I<name>
    Use I<name> as the user-id for encryption.
    This option is silently ignored for the list commands,
    so that it can be used in an options file.

B<-v>, B<--verbose>
    Give more information during processing. If used
    twice, the input data is listed in detail.

B<-q>, B<--quiet>
    Be somewhat more quiet in some cases.

B<-z> I<n>
    Set compress level to I<n>. A value of 0 for I<n>
    disables compression. Default is to use the default
    compression level of zlib (which is 6).

B<-t>, B<--textmode>
    Use canonical text mode.  If B<-t> (but not
    B<--textmode>) is used together with armoring
    and signing, this enables clearsigned messages.
    This kludge is needed for PGP compatibility;
    normally you would use B<--sign> or B<--clearsign>
    to selected the type os signatures.

B<-n>, B<--dry-run>
    Don't make any changes (not yet implemented).

B<--batch>
    Batch mode; never ask, do not allow interactive
    commands.

B<--no-batch>
    Disable batch mode; this may be used if B<batch>
    is used in the options file.

B<--yes>
    Assume "yes" on most questions.

B<--no>
    Assume "no" on most questions.

B<--keyserver> I<name>
    Use I<name> to lookup keys which are not yet in
    your keyring; this is only done while verifying
    messages with signatures.  The option is also
    required for the command B<--send-keys> to
    specify the keyserver to where the keys should
    be send.  All keyservers synchronize with each
    other - so there is no need to send keys to more
    than one server.  Using the command
    "host -l pgp.net | grep wwwkeys" gives you a
    list of keyservers.  Because there is load
    balancing using round-robin-dns you may notice
    that you get different key servers.

B<--keyring> I<file>
    Add I<file> to the list of keyrings.
    If I<file> begins with a tilde and a slash, these
    are replaced by the HOME directory. If the filename
    does not contain a slash, it is assumed to be in the
    home-directory (F<~/.gnupg> if B<--homedir>) is not used.
    The filename may be prefixed with a scheme:
      "gnupg-ring:" is the default one.
      "gnupg-gdbm:" may be used for a GDBM ring.

B<--secret-keyring> I<file>
    Same as B<--keyring> but for secret keyrings.

B<--homedir> I<dir>
    Set the name of the home directory to I<dir>. If this
    option is not used it defaults to F<~/.gnupg>. It does
    not make sense to use this in a options file. This
    also overrides the environment variable C<GNUPGHOME>.

B<--charset> I<name>
    Set the name of the native character set.  This is used
    to convert some strings to proper UTF-8 encoding.
    Valid values for I<name> are:
      B<iso-8859-1>  This is the default.
      B<koi8-r>      The usual Russian set (rfc1489).

B<--options> I<file>
    Read options from I<file> and do not try to read
    them from the default options file in the homedir
    (see B<--homedir>). This option is ignored when used
    in an options file.

B<--no-options>
    Shortcut for B<--options> I</dev/null>.  This option is
    detected before an attempt to open an option file.

B<--load-extension> I<modulename>
    Load an extension module. If I<modulename> does not
    contain a slash it is searched in B</usr/local/lib/gnupg>
    See the manual for more information about extensions.

B<--debug> I<flags>
    Set debugging flags. All flags are or-ed and I<flags> may
    be given in C syntax (e.g. 0x0042).

B<--debug-all>
    Set all useful debugging flags.

B<--status-fd> I<n>
    Write special status strings to the file descriptor I<n>.

B<--no-comment>
    Do not write comment packets.  This option affects only
    the generation of secret keys.  Output of option packets
    is disabled since version 0.4.2.

B<--comment> I<string>
    Use I<string> as comment string in clear text signatures.

B<--set-filename> I<string>
    Use I<string> as the name of file which is stored in
    messages.

B<--completes-needed> I<n>
    Number of completely trusted users to introduce a new
    key signator (defaults to 1).

B<--marginals-needed> I<n>
    Number of marginally trusted users to introduce a new
    key signator (defaults to 3)

B<--max-cert-depth> I<n>
    Maximum depth of a certification chain (default is 5).

B<--cipher-algo> I<name>
    Use I<name> as cipher algorithm. Running the program
    with the command B<--version> yields a list of supported
    algorithms. If this is not used the cipher algorithm is
    selected from the preferences stored with the key.

B<--digest-algo> I<name>
    Use I<name> as message digest algorithm. Running the
    program with the command B<--version> yields a list of
    supported algorithms.  Please note that using this
    option may violate the OpenPGP requirement, that a
    160 bit hash is to be used for DSA.

B<--s2k-cipher-algo> I<name>
    Use I<name> as the cipher algorithm used to protect secret
    keys.  The default cipher is BLOWFISH.  This cipher is
    also used for conventional encryption if B<--cipher-algo>
    is not given.

B<--s2k-digest-algo> I<name>
    Use I<name> as the digest algorithm used to mangle the
    passphrases.  The default algorithm is RIPE-MD-160.
    This digest algorithm is also used for conventional
    encryption if B<--digest-algo> is not given.

B<--s2k-mode> I<number>
    Selects how passphrases are mangled: A number of I<0>
    uses the plain passphrase (which is not recommended),
    a I<1> (default) adds a salt to the passphrase and
    I<3> iterates the whole process a couple of times.
    Unless -B<--rfc1991> is used, this mode is also used
    for conventional encryption.

B<--compress-algo> I<number>
    Use compress algorithm I<number>. Default is I<2> which is
    RFC1950 compression; you may use I<1> to use the old zlib
    version which is used by PGP.
    The default algorithm may give better
    results because the window size is not limited to 8K.
    If this is not used the OpenPGP behavior is used; i.e.
    the compression algorithm is selected from the preferences.

B<--digest-algo> I<name>
    Use I<name> as message digest algorithm. Running the
    program with the command B<--version> yields a list of
    supported algorithms.


B<--throw-keyid>
    Do not put the keyid into encrypted packets.  This option
    hides the receiver of the message and is a countermeasure
    against traffic analysis.  It may slow down the decryption
    process because all available secret keys are tried.

B<--not-dash-escaped>
    This option changes the behavior of cleartext signature
    so that they can be used for patch files. You should not
    send such an armored file via email because all spaces
    and line endings are hashed too.  You can not use this
    option for data which has 5 dashes somewhere at the
    beginning of a line - patch files don't have this.
    A special armor header line tells GnuPG about this
    cleartext signature framework.

B<--escape-from-lines>
    Because some mailers change lines starting with "From "
    to ">From " it is good to handle such lines in a special
    way when creating cleartext signatures; all other PGP
    versions do it this way too.  Because this would violate
    rfc2440, this option is not enabled per default.

B<--passphrase-fd> I<n>
    Read the passphrase from file descriptor I<n>. If you use
    0 for I<n>, the passphrase will be read from stdin.  This
    can only be used if only one passphrase is supplied.
    B<Don't use this option if you can avoid it>

B<--rfc1991>
    Try to be more RFC1991 (PGP 2.x) compliant.

B<--force-v3-sigs>
    OpenPGP states that a implementation should generate
    v4 signatures but PGP 5.x does only recognize such
    signatures on key material.  This options forces
    v3 signatures for signatures on data.

B<--lock-once>
    Lock the file the first time a lock is requested
    and do not release the lock until the process
    terminates.

B<--no-verbose>
    Reset verbose level to 0.

B<--no-greeting>
    Suppress the initial copyright message but do not
    enter batch mode.

B<--no-armor>
    Assume the input data is not in ASCII armored format.

B<--no-default-keyring>
    Do not add the default keyrings to the list of
    keyrings.

B<--skip-verify>
    Skip the signature verification step.  This may be
    used to make the encryption faster if the signature
    verification is not needed.

B<--version>
    Print version information along with a list
    of supported algorithms.

B<--with-colons>
    Print key listings delimited by colons.

B<--warranty>
    Print warranty information.

B<-h>, B<--help>
    Print usage information.


=head1 RETURN VALUE

The Program returns 0 if everything was fine, 1 if at least
a signature was bad and other errorcode for fatal errors.

=head1 EXAMPLES

  -se -r Bob [file]	     sign and encrypt for user Bob
  -sat [file]		     make a clear text signature
  -sb  [file]		     make a detached signature
  -k   [userid] 	     show keys
  -kc  [userid] 	     show fingerprint

=head1 ENVIRONMENT

C<HOME>       Used to locate the default home directory.
C<GNUPGHOME>  If set directory used instead of F<~/.gnupg>.

=head1 FILES

F<~/.gnupg/secring.gpg>      The secret keyring
F<~/.gnupg/secring.gpg.lock> and the lock file

F<~/.gnupg/pubring.gpg>      The public keyring
F<~/.gnupg/pubring.gpg.lock> and the lock file

F<~/.gnupg/trustdb.gpg>      The trust database
F<~/.gnupg/trustdb.gpg.lock> and the lock file

F<~/.gnupg/options>	    May contain options
F</usr[/local]/share/gnupg/options.skel> Skeleton file

F</usr[/local]/lib/gnupg/>  Default location for extensions

=head1 SEE ALSO

gpg(1)	gpgm(1)


=head1 WARNINGS

Use a B<good> password for your user account and a B<good> passphrase
to protect your secret key.  This passphrase is the weakest part of the
whole system.  Programs to do dictionary attacks on your secret keyring
are very easy to write and so you should protect your B<~/.gnupg/>
directory very good.

Keep in mind that, if this program is used over a network (telnet), it
is B<very> easy to spy out your passphrase!

=head1 BUGS

On many systems this program should be installed as setuid(root); this
is necessary to lock some pages of memory. If you get no warning message
about insecure memory your OS kernel supports locking without being root;
setuid is dropped as soon as this memory is allocated.