Post release updates
[gnupg.git] / NEWS
1 Noteworthy changes in version 2.2.8 (unreleased)
2 ------------------------------------------------
3
4
5 Noteworthy changes in version 2.2.7 (2018-05-02)
6 ------------------------------------------------
7
8   * gpg: New option --no-symkey-cache to disable the passphrase cache
9     for symmetrical en- and decryption.
10
11   * gpg: The ERRSIG status now prints the fingerprint if that is part
12     of the signature.
13
14   * gpg: Relax emitting of FAILURE status lines
15
16   * gpg: Add a status flag to "sig" lines printed with --list-sigs.
17
18   * gpg: Fix "Too many open files" when using --multifile.  [#3951]
19
20   * ssh: Return an error for unknown ssh-agent flags.  [#3880]
21
22   * dirmngr: Fix a regression since 2.1.16 which caused corrupted CRL
23     caches under Windows.  [#2448,#3923]
24
25   * dirmngr: Fix a CNAME problem with pools and TLS.  Also use a fixed
26     mapping of keys.gnupg.net to sks-keyservers.net.  [#3755]
27
28   * dirmngr: Try resurrecting dead hosts earlier (from 3 to 1.5 hours).
29
30   * dirmngr: Fallback to CRL if no default OCSP responder is configured.
31
32   * dirmngr: Implement CRL fetching via https.  Here a redirection to
33     http is explictly allowed.
34
35   * dirmngr: Make LDAP searching and CRL fetching work under Windows.
36     This stopped working with 2.1.  [#3937]
37
38   * agent,dirmngr: New sub-command "getenv" for "getinfo" to ease
39     debugging.
40
41   See-also: gnupg-announce/2018q2/000422.html
42
43
44 Noteworthy changes in version 2.2.6 (2018-04-09)
45 ------------------------------------------------
46
47   * gpg,gpgsm: New option --request-origin to pretend requests coming
48     from a browser or a remote site.
49
50   * gpg: Fix race condition on trustdb.gpg updates due to too early
51     released lock.  [#3839]
52
53   * gpg: Emit FAILURE status lines in almost all cases.  [#3872]
54
55   * gpg: Implement --dry-run for --passwd to make checking a key's
56     passphrase straightforward.
57
58   * gpg: Make sure to only accept a certification capable key for key
59     signatures.  [#3844]
60
61   * gpg: Better user interaction in --card-edit for the factory-reset
62     sub-command.
63
64   * gpg: Improve changing key attributes in --card-edit by adding an
65     explicit "key-attr" sub-command.  [#3781]
66
67   * gpg: Print the keygrips in the --card-status.
68
69   * scd: Support KDF DO setup.  [#3823]
70
71   * scd: Fix some issues with PC/SC on Windows.  [#3825]
72
73   * scd: Fix suspend/resume handling in the CCID driver.
74
75   * agent: Evict cached passphrases also via a timer.  [#3829]
76
77   * agent: Use separate passphrase caches depending on the request
78     origin.  [#3858]
79
80   * ssh: Support signature flags.  [#3880]
81
82   * dirmngr: Handle failures related to missing IPv6 support
83     gracefully.  [#3331]
84
85   * Fix corner cases related to specified home directory with
86     drive letter on Windows.  [#3720]
87
88   * Allow the use of UNC directory names as homedir.  [#3818]
89
90   See-also: gnupg-announce/2018q2/000421.html
91
92
93 Noteworthy changes in version 2.2.5 (2018-02-22)
94 ------------------------------------------------
95
96   * gpg: Allow the use of the "cv25519" and "ed25519" short names in
97     addition to the canonical curve names in --batch --gen-key.
98
99   * gpg: Make sure to print all secret keys with option --list-only
100     and --decrypt.  [#3718]
101
102   * gpg: Fix the use of future-default with --quick-add-key for
103     signing keys.  [#3747]
104
105   * gpg: Select a secret key by checking availability under gpg-agent.
106     [#1967]
107
108   * gpg: Fix reversed prompt texts for --only-sign-text-ids.  [#3787]
109
110   * gpg,gpgsm: Fix detection of bogus keybox blobs on 32 bit systems.
111     [#3770]
112
113   * gpgsm: Fix regression since 2.1 in --export-secret-key-raw which
114     got $d mod (q-1)$ wrong.  Note that most tools automatically fixup
115     that parameter anyway.
116
117   * ssh: Fix a regression in getting the client'd PID on *BSD and
118     macOS.
119
120   * scd: Support the KDF Data Object of the OpenPGP card 3.3.  [#3152]
121
122   * scd: Fix a regression in the internal CCID driver for certain card
123     readers.  [#3508]
124
125   * scd: Fix a problem on NetBSD killing scdaemon on gpg-agent
126     shutdown.  [#3778]
127
128   * dirmngr: Improve returned error description on failure of DNS
129     resolving.  [#3756]
130
131   * wks: Implement command --install-key for gpg-wks-server.
132
133   * Add option STATIC=1 to the Speedo build system to allow a build
134     with statically linked versions of the core GnuPG libraries.  Also
135     use --enable-wks-tools by default by Speedo builds for Unix.
136
137   See-also: gnupg-announce/2018q1/000420.html
138
139
140 Noteworthy changes in version 2.2.4 (2017-12-20)
141 ------------------------------------------------
142
143   * gpg: Change default preferences to prefer SHA512.
144
145   * gpg: Print a warning when more than 150 MiB are encrypted using a
146     cipher with 64 bit block size.
147
148   * gpg: Print a warning if the MDC feature has not been used for a
149     message.
150
151   * gpg: Fix regular expression of domain addresses in trust
152     signatures. [#2923]
153
154   * agent: New option --auto-expand-secmem to help with high numbers
155     of concurrent connections.  Requires libgcrypt 1.8.2 for having
156     an effect.  [#3530]
157
158   * dirmngr: Cache responses of WKD queries.
159
160   * gpgconf: Add option --status-fd.
161
162   * wks: Add commands --check and --remove-key to gpg-wks-server.
163
164   * Increase the backlog parameter of the daemons to 64 and add
165     option --listen-backlog.
166
167   * New configure option --enable-run-gnupg-user-socket to first try a
168     socket directory which is not removed by systemd at session end.
169
170   See-also: gnupg-announce/2017q4/000419.html
171
172
173 Noteworthy changes in version 2.2.3 (2017-11-20)
174 ------------------------------------------------
175
176   * gpgsm: Fix initial keybox creation on Windows. [#3507]
177
178   * dirmngr: Fix crash in case of a CRL loading error. [#3510]
179
180   * Fix the name of the Windows registry key. [Git#4f5afaf1fd]
181
182   * gpgtar: Fix wrong behaviour of --set-filename. [#3500]
183
184   * gpg: Silence AKL retrieval messages. [#3504]
185
186   * agent: Use clock or clock_gettime for calibration. [#3056]
187
188   * agent: Improve robustness of the shutdown pending
189     state. [Git#7ffedfab89]
190
191   See-also: gnupg-announce/2017q4/000417.html
192
193
194 Noteworthy changes in version 2.2.2 (2017-11-07)
195 ------------------------------------------------
196
197   * gpg: Avoid duplicate key imports by concurrently running gpg
198     processes. [#3446]
199
200   * gpg: Fix creating on-disk subkey with on-card primary key. [#3280]
201
202   * gpg: Fix validity retrieval for multiple keyrings. [Debian#878812]
203
204   * gpg: Fix --dry-run and import option show-only for secret keys.
205
206   * gpg: Print "sec" or "sbb" for secret keys with import option
207     import-show. [#3431]
208
209   * gpg: Make import less verbose. [#3397]
210
211   * gpg: Add alias "Key-Grip" for parameter "Keygrip" and new
212     parameter "Subkey-Grip" to unattended key generation.  [#3478]
213
214   * gpg: Improve "factory-reset" command for OpenPGP cards.  [#3286]
215
216   * gpg: Ease switching Gnuk tokens into ECC mode by using the magic
217     keysize value 25519.
218
219   * gpgsm: Fix --with-colon listing in crt records for fields > 12.
220
221   * gpgsm: Do not expect X.509 keyids to be unique.  [#1644]
222
223   * agent: Fix stucked Pinentry when using --max-passphrase-days. [#3190]
224
225   * agent: New option --s2k-count.  [#3276 (workaround)]
226
227   * dirmngr: Do not follow https-to-http redirects. [#3436]
228
229   * dirmngr: Reduce default LDAP timeout from 100 to 15 seconds. [#3487]
230
231   * gpgconf: Ignore non-installed components for commands
232     --apply-profile and --apply-defaults. [#3313]
233
234   * Add configure option --enable-werror.  [#2423]
235
236   See-also: gnupg-announce/2017q4/000416.html
237
238
239 Noteworthy changes in version 2.2.1 (2017-09-19)
240 ------------------------------------------------
241
242   * gpg: Fix formatting of the user id in batch mode key generation
243     if only "name-email" is given.
244
245   * gpgv: Fix annoying "not suitable for" warnings.
246
247   * wks: Convey only the newest user id to the provider.  This is the
248     case if different names are used with the same addr-spec.
249
250   * wks: Create a complying user id for provider policy mailbox-only.
251
252   * wks: Add workaround for posteo.de.
253
254   * scd: Fix the use of large ECC keys with an OpenPGP card.
255
256   * dirmngr: Use system provided root certificates if no specific HKP
257     certificates are configured.  If build with GNUTLS, this was
258     already the case.
259
260   See-also: gnupg-announce/2017q3/000415.html
261
262
263 Noteworthy changes in version 2.2.0 (2017-08-28)
264 ------------------------------------------------
265
266   This is the new long term stable branch.  This branch will only see
267   bug fixes and no new features.
268
269   * gpg: Reverted change in 2.1.23 so that --no-auto-key-retrieve is
270     again the default.
271
272   * Fixed a few minor bugs.
273
274   See-also: gnupg-announce/2017q3/000413.html
275
276
277 Noteworthy changes in version 2.1.23 (2017-08-09)
278 -------------------------------------------------
279
280   * gpg: "gpg" is now installed as "gpg" and not anymore as "gpg2".
281     If needed, the new configure option --enable-gpg-is-gpg2 can be
282     used to revert this.
283
284   * gpg: Options --auto-key-retrieve and --auto-key-locate "local,wkd"
285     are now used by default.  Note: this enables keyserver and Web Key
286     Directory operators to notice when a signature from a locally
287     non-available key is being verified for the first time or when
288     you intend to encrypt to a mail address without having the key
289     locally.  This new behaviour will eventually make key discovery
290     much easier and mostly automatic.  Disable this by adding
291       no-auto-key-retrieve
292       auto-key-locate local
293     to your gpg.conf.
294
295   * agent: Option --no-grab is now the default.  The new option --grab
296     allows to revert this.
297
298   * gpg: New import option "show-only".
299
300   * gpg: New option --disable-dirmngr to entirely disable network
301     access for gpg.
302
303   * gpg,gpgsm: Tweaked DE-VS compliance behaviour.
304
305   * New configure flag --enable-all-tests to run more extensive tests
306     during "make check".
307
308   * gpgsm: The keygrip is now always printed in colon mode as
309     documented in the man page.
310
311   * Fixed connection timeout problem under Windows.
312
313   See-also: gnupg-announce/2017q3/000412.html
314
315
316 Noteworthy changes in version 2.1.22 (2017-07-28)
317 -------------------------------------------------
318
319   * gpg: Extend command --quick-set-expire to allow for setting the
320     expiration time of subkeys.
321
322   * gpg: By default try to repair keys during import.  New sub-option
323     no-repair-keys for --import-options.
324
325   * gpg,gpgsm: Improved checking and reporting of DE-VS compliance.
326
327   * gpg: New options --key-origin and --with-key-origin.  Store the
328     time of the last key update from keyservers, WKD, or DANE.
329
330   * agent: New option --ssh-fingerprint-digest.
331
332   * dimngr: Lower timeouts on keyserver connection attempts and made
333     it configurable.
334
335   * dirmngr: Tor will now automatically be detected and used.  The
336     option --no-use-tor disables Tor detection.
337
338   * dirmngr: Now detects a changed /etc/resolv.conf.
339
340   * agent,dirmngr: Initiate shutdown on removal of the GnuPG home
341     directory.
342
343   * gpg: Avoid caching passphrase for failed symmetric encryption.
344
345   * agent: Support for unprotected ssh keys.
346
347   * dirmngr: Fixed name resolving on systems using only v6
348     nameservers.
349
350   * dirmngr: Allow the use of TLS over http proxies.
351
352   * w32: Change directory of the daemons after startup.
353
354   * wks: New man pages for client and server.
355
356   * Many other bug fixes.
357
358   See-also: gnupg-announce/2017q3/000411.html
359
360
361 Noteworthy changes in version 2.1.21 (2017-05-15)
362 -------------------------------------------------
363
364   * gpg,gpgsm: Fix corruption of old style keyring.gpg files.  This
365     bug was introduced with version 2.1.20.  Note that the default
366     pubring.kbx format was not affected.
367
368   * gpg,dirmngr: Removed the skeleton config file support.  The
369     system's standard methods for providing default configuration
370     files should be used instead.
371
372   * w32: The Windows installer now allows installation of GnuPG
373     without Administrator permissions.
374
375   * gpg: Fixed import filter property match bug.
376
377   * scd: Removed Linux support for Cardman 4040 PCMCIA reader.
378
379   * scd: Fixed some corner case bugs in resume/suspend handling.
380
381   * Many minor bug fixes and code cleanup.
382
383   See-also: gnupg-announce/2017q2/000405.html
384
385
386 Noteworthy changes in version 2.1.20 (2017-04-03)
387 -------------------------------------------------
388
389   * gpg: New properties 'expired', 'revoked', and 'disabled' for the
390     import and export filters.
391
392   * gpg: New command --quick-set-primary-uid.
393
394   * gpg: New compliance field for the --with-colon key listing.
395
396   * gpg: Changed the key parser to generalize the processing of local
397     meta data packets.
398
399   * gpg: Fixed assertion failure in the TOFU trust model.
400
401   * gpg: Fixed exporting of zero length user ID packets.
402
403   * scd: Improved support for multiple readers.
404
405   * scd: Fixed timeout handling for key generation.
406
407   * agent: New option --enable-extended-key-format.
408
409   * dirmngr: Do not add a keyserver to a new dirmngr.conf.  Dirmngr
410     uses a default keyserver.
411
412   * dimngr: Do not treat TLS warning alerts as severe error when
413     building with GNUTLS.
414
415   * dirmngr: Actually take /etc/hosts in account.
416
417   * wks: Fixed client problems on Windows.  Published keys are now set
418     to world-readable.
419
420   * tests: Fixed creation of temporary directories.
421
422   * A socket directory for a non standard GNUGHOME is now created on
423     the fly under /run/user.  Thus "gpgconf --create-socketdir" is now
424     optional.  The use of "gpgconf --remove-socketdir" to clean up
425     obsolete socket directories is however recommended to avoid
426     cluttering /run/user with useless directories.
427
428   * Fixed build problems on some platforms.
429
430   See-also: gnupg-announce/2017q2/000404.html
431
432
433 Noteworthy changes in version 2.1.19 (2017-03-01)
434 -------------------------------------------------
435
436   * gpg: Print a warning if Tor mode is requested but the Tor daemon
437     is not running.
438
439   * gpg: New status code DECRYPTION_KEY to print the actual private
440     key used for decryption.
441
442   * gpgv: New options --log-file and --debug.
443
444   * gpg-agent: Revamp the prompts to ask for card PINs.
445
446   * scd: Support for multiple card readers.
447
448   * scd: Removed option --debug-disable-ticker.  Ticker is used
449     only when it is required to watch removal of device/card.
450
451   * scd: Improved detection of card inserting and removal.
452
453   * dirmngr: New option --disable-ipv4.
454
455   * dirmngr: New option --no-use-tor to explicitly disable the use of
456     Tor.
457
458   * dirmngr: The option --allow-version-check is now required even if
459     the option --use-tor is also used.
460
461   * dirmngr: Handle a missing nsswitch.conf gracefully.
462
463   * dirmngr: Avoid PTR lookups for keyserver pools.  The are only done
464     for the debug command "keyserver --hosttable".
465
466   * dirmngr: Rework the internal certificate cache to support classes
467     of certificates.  Load system provided certificates on startup.
468     Add options --tls, --no-crl, and --systrust to the "VALIDATE"
469     command.
470
471   * dirmngr: Add support for the ntbtls library.
472
473   * wks: Create mails with a "WKS-Phase" header.  Fix detection of
474     Draft-2 mode.
475
476   * The Windows installer is now build with limited TLS support.
477
478   * Many other bug fixes and new regression tests.
479
480   See-also: gnupg-announce/2017q1/000402.html
481
482
483 Noteworthy changes in version 2.1.18 (2017-01-23)
484 -------------------------------------------------
485
486   * gpg: Remove bogus subkey signature while cleaning a key (with
487     export-clean, import-clean, or --edit-key's sub-command clean)
488
489   * gpg: Allow freezing the clock with --faked-system-time.
490
491   * gpg: New --export-option flag "backup", new --import-option flag
492     "restore".
493
494   * gpg-agent: Fixed long delay due to a regression in the progress
495     callback code.
496
497   * scd: Lots of code cleanup and internal changes.
498
499   * scd: Improved the internal CCID driver.
500
501   * dirmngr: Fixed problem with the DNS glue code (removal of the
502     trailing dot in domain names).
503
504   * dirmngr: Make sure that Tor is actually enabled after changing the
505     conf file and sending SIGHUP or "gpgconf --reload dirmngr".
506
507   * dirmngr: Fixed Tor access to IPv6 addresses.  Note that current
508     versions of Tor may require that the flag "IPv6Traffic" is used
509     with the option "SocksPort" in torrc to actually allow IPv6
510     traffic.
511
512   * dirmngr: Fixed HKP for literally given IPv6 addresses.
513
514   * dirmngr: Enabled reverse DNS lookups via Tor.
515
516   * dirmngr: Added experimental SRV record lookup for WKD.
517     See commit 88dc3af3d4ae1afe1d5e136bc4c38bc4e7d4cd10 for details.
518
519   * dirmngr: For HKP use "pgpkey-hkps" and "pgpkey-hkp" in SRV record
520     lookups.  Avoid SRV record lookup when a port is explicitly
521     specified.  This fixes a regression from the 1.4 and 2.0 behavior.
522
523   * dirmngr: Gracefully handle a missing /etc/nsswitch.conf.  Ignore
524     negation terms (e.g. "[!UNAVAIL=return]" instead of bailing out.
525
526   * dirmngr: Better debug output for flags "dns" and "network".
527
528   * dirmngr: On reload mark all known HKP servers alive.
529
530   * gpgconf: Allow keyword "all" for --launch, --kill, and --reload.
531
532   * tools: gpg-wks-client now ignores a missing policy file on the
533     server.
534
535   * Avoid unnecessary ambiguity error message in the option parsing.
536
537   * Further improvements of the regression test suite.
538
539   * Fixed building with --disable-libdns configure option.
540
541   * Fixed a crash running the tests on 32 bit architectures.
542
543   * Fixed spurious failures on BSD system in the spawn functions.
544     This affected for example gpg-wks-client and gpgconf.
545
546   See-also: gnupg-announce/2017q1/000401.html
547
548
549 Noteworthy changes in version 2.1.17 (2016-12-20)
550 -------------------------------------------------
551
552  * gpg: By default new keys expire after 2 years.
553
554  * gpg: New command --quick-set-expire to conveniently change the
555    expiration date of keys.
556
557  * gpg: Option and command names have been changed for easier
558    comprehension.  The old names are still available as aliases.
559
560  * gpg: Improved the TOFU trust model.
561
562  * gpg: New option --default-new-key-algo.
563
564  * scd: Support OpenPGP card V3 for RSA.
565
566  * dirmngr: Support for the ADNS library has been removed.  Instead
567    William Ahern's Libdns is now source included and used on all
568    platforms.  This enables Tor support on all platforms.  The new
569    option --standard-resolver can be used to disable this code at
570    runtime.  In case of build problems the new configure option
571    --disable-libdns can be used to build without Libdns.
572
573  * dirmngr: Lazily launch ldap reaper thread.
574
575  * tools: New options --check and --status-fd for gpg-wks-client.
576
577  * The UTF-8 byte order mark is now skipped when reading conf files.
578
579  * Fixed many bugs and regressions.
580
581  * Major improvements to the test suite.  For example it is possible
582    to run the external test suite of GPGME.
583
584  See-also: gnupg-announce/2016q4/000400.html
585
586
587 Noteworthy changes in version 2.1.16 (2016-11-18)
588 -------------------------------------------------
589
590  * gpg: New algorithm for selecting the best ranked public key when
591    using a mail address with -r, -R, or --locate-key.
592
593  * gpg: New option --with-tofu-info to print a new "tfs" record in
594    colon formatted key listings.
595
596  * gpg: New option --compliance as an alternative way to specify
597    options like --rfc2440, --rfc4880, et al.
598
599  * gpg: Many changes to the TOFU implementation.
600
601  * gpg: Improve usability of --quick-gen-key.
602
603  * gpg: In --verbose mode print a diagnostic when a pinentry is
604    launched.
605
606  * gpg: Remove code which warns for old versions of gnome-keyring.
607
608  * gpg: New option --override-session-key-fd.
609
610  * gpg: Option --output does now work with --verify.
611
612  * gpgv: New option --output to allow saving the verified data.
613
614  * gpgv: New option --enable-special-filenames.
615
616  * agent, dirmngr: New --supervised mode for use by systemd and alike.
617
618  * agent: By default listen on all available sockets using standard
619    names.
620
621  * agent: Invoke scdaemon with --homedir.
622
623  * dirmngr: On Linux now detects the removal of its own socket and
624    terminates.
625
626  * scd: Support ECC key generation.
627
628  * scd: Support more card readers.
629
630  * dirmngr: New option --allow-version-check to download a software
631    version database in the background.
632
633  * dirmngr: Use system provided CAs if no --hkp-cacert is given.
634
635  * dirmngr: Use a default keyserver if none is explicitly set
636
637  * gpgconf: New command --query-swdb to check software versions
638    against an copy of an online database.
639
640  * gpgconf: Print the socket directory with --list-dirs.
641
642  * tools: The WKS tools now support draft version -02.
643
644  * tools: Always build gpg-wks-client and install under libexec.
645
646  * tools: New option --supported for gpg-wks-client.
647
648  * The log-file option now accepts a value "socket://" to log to the
649    socket named "S.log" in the standard socket directory.
650
651  * Provide fake pinentries for use by tests cases of downstream
652    developers.
653
654  * Fixed many bugs and regressions.
655
656  * Many changes and improvements for the test suite.
657
658  See-also: gnupg-announce/2016q4/000398.html
659
660
661 Noteworthy changes in version 2.1.15 (2016-08-18)
662 -------------------------------------------------
663
664  * gpg: Remove the --tofu-db-format option and support for the split
665    TOFU database.
666
667  * gpg: Add option --sender to prepare for coming features.
668
669  * gpg: Add option --input-size-hint to help progress indicators.
670
671  * gpg: Extend the PROGRESS status line with the counted unit.
672
673  * gpg: Avoid publishing the GnuPG version by default with --armor.
674
675  * gpg: Properly ignore legacy keys in the keyring cache.
676
677  * gpg: Always print fingerprint records in --with-colons mode.
678
679  * gpg: Make sure that keygrips are printed for each subkey in
680    --with-colons mode.
681
682  * gpg: New import filter "drop-sig".
683
684  * gpgsm: Fix a bug in the machine-readable key listing.
685
686  * gpg,gpgsm: Block signals during keyring updates to limits the
687    effects of a Ctrl-C at the wrong time.
688
689  * g13: Add command --umount and other fixes for dm-crypt.
690
691  * agent: Fix regression in SIGTERM handling.
692
693  * agent: Cleanup of the ssh-agent code.
694
695  * agent: Allow import of overly long keys.
696
697  * scd: Fix problems with card removal.
698
699  * dirmngr: Remove all code for running as a system service.
700
701  * tools: Make gpg-wks-client conforming to the specs.
702
703  * tests: Improve the output of the new regression test tool.
704
705  * tests: Distribute the standalone test runner.
706
707  * tests: Run each test in a clean environment.
708
709  * Spelling and grammar fixes.
710
711  See-also: gnupg-announce/2016q3/000396.html
712
713
714 Noteworthy changes in version 2.1.14 (2016-07-14)
715 -------------------------------------------------
716
717  * gpg: Removed options --print-dane-records and --print-pka-records.
718    The new export options "export-pka" and "export-dane" can instead
719    be used with the export command.
720
721  * gpg: New options --import-filter and --export-filter.
722
723  * gpg: New import options "import-show" and "import-export".
724
725  * gpg: New option --no-keyring.
726
727  * gpg: New command --quick-revuid.
728
729  * gpg: New options -f/--recipient-file and -F/--hidden-recipient-file
730    to directly specify encryption keys.
731
732  * gpg: New option --mimemode to indicate that the content is a MIME
733    part.  Does only enable --textmode right now.
734
735  * gpg: New option --rfc4880bis to allow experiments with proposed
736    changes to the current OpenPGP specs.
737
738  * gpg: Fix regression in the "fetch" sub-command of --card-edit.
739
740  * gpg: Fix regression since 2.1 in option --try-all-secrets.
741
742  * gpgv: Change default options for extra security.
743
744  * gpgsm: No more root certificates are installed by default.
745
746  * agent: "updatestartuptty" does now affect more environment
747    variables.
748
749  * scd: The option --homedir does now work with scdaemon.
750
751  * scd: Support some more GEMPlus card readers.
752
753  * gpgtar: Fix handling of '-' as file name.
754
755  * gpgtar: New commands --create and --extract.
756
757  * gpgconf: Tweak for --list-dirs to better support shell scripts.
758
759  * tools: Add programs gpg-wks-client and gpg-wks-server to implement
760    a Web Key Service.  The configure option --enable-wks-tools is
761    required to build them; they should be considered Beta software.
762
763  * tests: Complete rework of the openpgp part of the test suite.  The
764    test scripts have been changed from Bourne shell scripts to Scheme
765    programs.  A customized scheme interpreter (gpgscm) is included.
766    This change was triggered by the need to run the test suite on
767    non-Unix platforms.
768
769  * The rendering of the man pages has been improved.
770
771  See-also: gnupg-announce/2016q3/000393.html
772
773
774 Noteworthy changes in version 2.1.13 (2016-06-16)
775 -------------------------------------------------
776
777  * gpg: New command --quick-addkey.  Extend the --quick-gen-key
778    command.
779
780  * gpg: New --keyid-format "none" which is now also the default.
781
782  * gpg: New option --with-subkey-fingerprint.
783
784  * gpg: Include Signer's UID subpacket in signatures if the secret key
785    has been specified using a mail address and the new option
786    --disable-signer-uid is not used.
787
788  * gpg: Allow unattended deletion of a secret key.
789
790  * gpg: Allow export of non-passphrase protected secret keys.
791
792  * gpg: New status lines KEY_CONSIDERED and NOTATION_FLAGS.
793
794  * gpg: Change status line TOFU_STATS_LONG to use '~' as
795    a non-breaking-space character.
796
797  * gpg: Speedup key listings in Tofu mode.
798
799  * gpg: Make sure that the current and total values of a PROGRESS
800    status line are small enough.
801
802  * gpgsm: Allow the use of AES192 and SERPENT ciphers.
803
804  * dirmngr: Adjust WKD lookup to current specs.
805
806  * dirmngr: Fallback to LDAP v3 if v2 is is not supported.
807
808  * gpgconf: New commands --create-socketdir and --remove-socketdir,
809    new option --homedir.
810
811  * If a /run/user/$UID directory exists, that directory is now used
812    for IPC sockets instead of the GNUPGHOME directory.  This fixes
813    problems with NFS and too long socket names and thus avoids the
814    need for redirection files.
815
816  * The Speedo build systems now uses the new versions.gnupg.org server
817    to retrieve the default package versions.
818
819  * Fix detection of libusb on FreeBSD.
820
821  * Speedup fd closing after a fork.
822
823  See-also: gnupg-announce/2016q2/000390.html
824
825
826 Noteworthy changes in version 2.1.12 (2016-05-04)
827 -------------------------------------------------
828
829  * gpg: New --edit-key sub-command "change-usage" for testing
830    purposes.
831
832  * gpg: Out of order key-signatures are now systematically detected
833    and fixed by --edit-key.
834
835  * gpg: Improved detection of non-armored messages.
836
837  * gpg: Removed the extra prompt needed to create Curve25519 keys.
838
839  * gpg: Improved user ID selection for --quick-sign-key.
840
841  * gpg: Use the root CAs provided by the system with --fetch-key.
842
843  * gpg: Add support for the experimental Web Key Directory key
844    location service.
845
846  * gpg: Improve formatting of Tofu messages and emit new Tofu specific
847    status lines.
848
849  * gpgsm: Add option --pinentry-mode to support a loopback pinentry.
850
851  * gpgsm: A new pubring.kbx is now created with the header blob so
852    that gpg can detect that the keybox format needs to be used.
853
854  * agent: Add read support for the new private key protection format
855    openpgp-s2k-ocb-aes.
856
857  * agent: Add read support for the new extended private key format.
858
859  * agent: Default to --allow-loopback-pinentry and add option
860    --no-allow-loopback-pinentry.
861
862  * scd: Changed to use the new libusb 1.0 API for the internal CCID
863    driver.
864
865  * dirmngr: The dirmngr-client does now auto-detect the PEM format.
866
867  * g13: Add experimental support for dm-crypt.
868
869  * w32: Tofu support is now available with the Speedo build method.
870
871  * w32: Removed the need for libiconv.dll.
872
873  * The man pages for gpg and gpgv are now installed under the correct
874    name (gpg2 or gpg - depending on a configure option).
875
876  * Lots of internal cleanups and bug fixes.
877
878  See-also: gnupg-announce/2016q2/000387.html
879
880
881 Noteworthy changes in version 2.1.11 (2016-01-26)
882 -------------------------------------------------
883
884  * gpg: New command --export-ssh-key to replace the gpgkey2ssh tool.
885
886  * gpg: Allow to generate mail address only keys with --gen-key.
887
888  * gpg: "--list-options show-usage" is now the default.
889
890  * gpg: Make lookup of DNS CERT records holding an URL work.
891
892  * gpg: Emit PROGRESS status lines during key generation.
893
894  * gpg: Don't check for ambigious or non-matching key specification in
895    the config file or given to --encrypt-to.  This feature will return
896    in 2.3.x.
897
898  * gpg: Lock keybox files while updating them.
899
900  * gpg: Solve rare error on Windows during keyring and Keybox updates.
901
902  * gpg: Fix possible keyring corruption. (bug#2193)
903
904  * gpg: Fix regression of "bkuptocard" sub-command in --edit-key and
905    remove "checkbkupkey" sub-command introduced with 2.1.  (bug#2169)
906
907  * gpg: Fix internal error in gpgv when using default keyid-format.
908
909  * gpg: Fix --auto-key-retrieve to work with dirmngr.conf configured
910    keyservers. (bug#2147).
911
912  * agent: New option --pinentry-timeout.
913
914  * scd: Improve unplugging of USB readers under Windows.
915
916  * scd: Fix regression for generating RSA keys on card.
917
918  * dirmmgr: All configured keyservers are now searched.
919
920  * dirmngr: Install CA certificate for hkps.pool.sks-keyservers.net.
921    Use this certiticate even if --hkp-cacert is not used.
922
923  * gpgtar: Add actual encryption code.  gpgtar does now fully replace
924    gpg-zip.
925
926  * gpgtar: Fix filename encoding problem on Windows.
927
928  * Print a warning if a GnuPG component is using an older version of
929    gpg-agent, dirmngr, or scdaemon.
930
931  See-also: gnupg-announce/2016q1/000383.html
932
933
934 Noteworthy changes in version 2.1.10 (2015-12-04)
935 -------------------------------------------------
936
937  * gpg: New trust models "tofu" and "tofu+pgp".
938
939  * gpg: New command --tofu-policy.  New options --tofu-default-policy
940    and --tofu-db-format.
941
942  * gpg: New option --weak-digest to specify hash algorithms which
943    should be considered weak.
944
945  * gpg: Allow the use of multiple --default-key options; take the last
946    available key.
947
948  * gpg: New option --encrypt-to-default-key.
949
950  * gpg: New option --unwrap to only strip the encryption layer.
951
952  * gpg: New option --only-sign-text-ids to exclude photo IDs from key
953    signing.
954
955  * gpg: Check for ambigious or non-matching key specification in the
956    config file or given to --encrypt-to.
957
958  * gpg: Show the used card reader with --card-status.
959
960  * gpg: Print export statistics and an EXPORTED status line.
961
962  * gpg: Allow selecting subkeys by keyid in --edit-key.
963
964  * gpg: Allow updating the expiration time of multiple subkeys at
965    once.
966
967  * dirmngr: New option --use-tor.  For full support this requires
968    libassuan version 2.4.2 and a patched version of libadns
969    (e.g. adns-1.4-g10-7 as used by the standard Windows installer).
970
971  * dirmngr: New option --nameserver to specify the nameserver used in
972    Tor mode.
973
974  * dirmngr: Keyservers may again be specified by IP address.
975
976  * dirmngr: Fixed problems in resolving keyserver pools.
977
978  * dirmngr: Fixed handling of premature termination of TLS streams so
979    that large numbers of keys can be refreshed via hkps.
980
981  * gpg: Fixed a regression in --locate-key [since 2.1.9].
982
983  * gpg: Fixed another bug for keyrings with legacy keys.
984
985  * gpgsm: Allow combinations of usage flags in --gen-key.
986
987  * Make tilde expansion work with most options.
988
989  * Many other cleanups and bug fixes.
990
991  See-also: gnupg-announce/2015q4/000381.html
992
993
994 Noteworthy changes in version 2.1.9 (2015-10-09)
995 ------------------------------------------------
996
997  * gpg: Allow fetching keys via OpenPGP DANE (--auto-key-locate).  New
998    option --print-dane-records.  [Update: --print-dane-records replaced
999    in 2.1.4.]
1000
1001  * gpg: Fix for a problem with PGP-2 keys in a keyring.
1002
1003  * gpg: Fail with an error instead of a warning if a modern cipher
1004    algorithm is used without a MDC.
1005
1006  * agent: New option --pinentry-invisible-char.
1007
1008  * agent: Always do a RSA signature verification after creation.
1009
1010  * agent: Fix a regression in ssh-add-ing Ed25519 keys.
1011
1012  * agent: Fix ssh fingerprint computation for nistp384 and EdDSA.
1013
1014  * agent: Fix crash during passphrase entry on some platforms.
1015
1016  * scd: Change timeout to fix problems with some 2.1 cards.
1017
1018  * dirmngr: Displayed name is now Key Acquirer.
1019
1020  * dirmngr: Add option --keyserver.  Deprecate that option for gpg.
1021    Install a dirmngr.conf file from a skeleton for new installations.
1022
1023  See-also: gnupg-announce/2015q4/000380.html
1024
1025
1026 Noteworthy changes in version 2.1.8 (2015-09-10)
1027 ------------------------------------------------
1028
1029  * gpg: Sending very large keys to the keyservers works again.
1030
1031  * gpg: Validity strings in key listings are now again translatable.
1032
1033  * gpg: Emit FAILURE status lines to help GPGME.
1034
1035  * gpg: Does not anymore link to Libksba to reduce dependencies.
1036
1037  * gpgsm: Export of secret keys via Assuan is now possible.
1038
1039  * agent: Raise the maximum passphrase length from 100 to 255 bytes.
1040
1041  * agent: Fix regression using EdDSA keys with ssh.
1042
1043  * Does not anymore use a build timestamp by default.
1044
1045  * The fallback encoding for broken locale settings changed
1046    from Latin-1 to UTF-8.
1047
1048  * Many code cleanups and improved internal documentation.
1049
1050  * Various minor bug fixes.
1051
1052  See-also: gnupg-announce/2015q3/000379.html
1053
1054
1055 Noteworthy changes in version 2.1.7 (2015-08-11)
1056 ------------------------------------------------
1057
1058  * gpg: Support encryption with Curve25519 if Libgcrypt 1.7 is used.
1059
1060  * gpg: In the --edit-key menu: Removed the need for "toggle", changed
1061    how secret keys are indicated, new commands "fpr *" and "grip".
1062
1063  * gpg: More fixes related to legacy keys in a keyring.
1064
1065  * gpgv: Does now also work with a "trustedkeys.kbx" file.
1066
1067  * scd: Support some feature from the OpenPGP card 3.0 specs.
1068
1069  * scd: Improved ECC support
1070
1071  * agent: New option --force for the DELETE_KEY command.
1072
1073  * w32: Look for the Pinentry at more places.
1074
1075  * Dropped deprecated gpgsm-gencert.sh
1076
1077  * Various other bug fixes.
1078
1079  See-also: gnupg-announce/2015q3/000371.html
1080
1081
1082 Noteworthy changes in version 2.1.6 (2015-07-01)
1083 ------------------------------------------------
1084
1085  * agent: New option --verify for the PASSWD command.
1086
1087  * gpgsm: Add command option "offline" as an alternative to
1088    --disable-dirmngr.
1089
1090  * gpg: Do not prompt multiple times for a password in pinentry
1091    loopback mode.
1092
1093  * Allow the use of debug category names with --debug.
1094
1095  * Using gpg-agent and gpg/gpgsm with different locales will now show
1096    the correct translations in Pinentry.
1097
1098  * gpg: Improve speed of --list-sigs and --check-sigs.
1099
1100  * gpg: Make --list-options show-sig-subpackets work again.
1101
1102  * gpg: Fix an export problem for old keyrings with PGP-2 keys.
1103
1104  * scd: Support PIN-pads on more readers.
1105
1106  * dirmngr: Properly cleanup zombie LDAP helper processes and avoid
1107    hangs on dirmngr shutdown.
1108
1109  * Various other bug fixes.
1110
1111  See-also: gnupg-announce/2015q3/000370.html
1112
1113
1114 Noteworthy changes in version 2.1.5 (2015-06-11)
1115 ------------------------------------------------
1116
1117  * Support for an external passphrase cache.
1118
1119  * Support for the forthcoming version 3 OpenPGP smartcard.
1120
1121  * Manuals now show the actual used file names.
1122
1123  * Prepared for improved integration with Emacs.
1124
1125  * Code cleanups and minor bug fixes.
1126
1127  See-also: gnupg-announce/2015q2/000369.html
1128
1129
1130 Noteworthy changes in version 2.1.4 (2015-05-12)
1131 ------------------------------------------------
1132
1133  * gpg: Add command --quick-adduid to non-interactively add a new user
1134    id to an existing key.
1135
1136  * gpg: Do no enable honor-keyserver-url by default.  Make it work if
1137    enabled.
1138
1139  * gpg: Display the serial number in the --card-status output again.
1140
1141  * agent: Support for external password managers.
1142    Add option --no-allow-external-cache.
1143
1144  * scdaemon: Improved handling of extended APDUs.
1145
1146  * Make HTTP proxies work again.
1147
1148  * All network access including DNS as been moved to Dirmngr.
1149
1150  * Allow building without LDAP support.
1151
1152  * Fixed lots of smaller bugs.
1153
1154  See-also: gnupg-announce/2015q2/000366.html
1155
1156
1157 Noteworthy changes in version 2.1.3 (2015-04-11)
1158 ------------------------------------------------
1159
1160  * gpg: LDAP keyservers are now supported by 2.1.
1161
1162  * gpg: New option --with-icao-spelling.
1163
1164  * gpg: New option --print-pka-records.  Changed the PKA method to use
1165    CERT records and hashed names.  [Update: --print-pka-records
1166    replaced in 2.1.14.]
1167
1168  * gpg: New command --list-gcrypt-config.  New parameter "curve"
1169    for --list-config.
1170
1171  * gpg: Print a NEWSIG status line like gpgsm always did.
1172
1173  * gpg: Print MPI values with --list-packets and --verbose.
1174
1175  * gpg: Write correct MPI lengths with ECC keys.
1176
1177  * gpg: Skip legacy PGP-2 keys while searching.
1178
1179  * gpg: Improved searching for mail addresses when using a keybox.
1180
1181  * gpgsm: Changed default algos to AES-128 and SHA-256.
1182
1183  * gpgtar: Fixed extracting files with sizes of a multiple of 512.
1184
1185  * dirmngr: Fixed SNI handling for hkps pools.
1186
1187  * dirmngr: extra-certs and trusted-certs are now always loaded from
1188    the sysconfig dir instead of the homedir.
1189
1190  * Fixed possible problems due to compiler optimization, two minor
1191    regressions, and other bugs.
1192
1193  See-also: gnupg-announce/2015q2/000365.html
1194
1195
1196 Noteworthy changes in version 2.1.2 (2015-02-11)
1197 ------------------------------------------------
1198
1199  * gpg: The parameter 'Passphrase' for batch key generation works
1200    again.
1201
1202  * gpg: Using a passphrase option in batch mode now has the expected
1203    effect on --quick-gen-key.
1204
1205  * gpg: Improved reporting of unsupported PGP-2 keys.
1206
1207  * gpg: Added support for algo names when generating keys using
1208    --command-fd.
1209
1210  * gpg: Fixed DoS based on bogus and overlong key packets.
1211
1212  * agent: When setting --default-cache-ttl the value
1213    for --max-cache-ttl is adjusted to be not lower than the former.
1214
1215  * agent: Fixed problems with the new --extra-socket.
1216
1217  * agent: Made --allow-loopback-pinentry changeable with gpgconf.
1218
1219  * agent: Fixed importing of unprotected openpgp keys.
1220
1221  * agent: Now tries to use a fallback pinentry if the standard
1222    pinentry is not installed.
1223
1224  * scd: Added support for ECDH.
1225
1226  * Fixed several bugs related to bogus keyrings and improved some
1227    other code.
1228
1229  See-also: gnupg-announce/2015q1/000361.html
1230
1231
1232 Noteworthy changes in version 2.1.1 (2014-12-16)
1233 ------------------------------------------------
1234
1235  * gpg: Detect faulty use of --verify on detached signatures.
1236
1237  * gpg: New import option "keep-ownertrust".
1238
1239  * gpg: New sub-command "factory-reset" for --card-edit.
1240
1241  * gpg: A stub key for smartcards is now created by --card-status.
1242
1243  * gpg: Fixed regression in --refresh-keys.
1244
1245  * gpg: Fixed regresion in %g and %p codes for --sig-notation.
1246
1247  * gpg: Fixed best matching hash algo detection for ECDSA and EdDSA.
1248
1249  * gpg: Improved perceived speed of secret key listisngs.
1250
1251  * gpg: Print number of skipped PGP-2 keys on import.
1252
1253  * gpg: Removed the option aliases --throw-keyid and --notation-data;
1254    use --throw-keyids and --set-notation instead.
1255
1256  * gpg: New import option "keep-ownertrust".
1257
1258  * gpg: Skip too large keys during import.
1259
1260  * gpg,gpgsm: New option --no-autostart to avoid starting gpg-agent or
1261    dirmngr.
1262
1263  * gpg-agent: New option --extra-socket to provide a restricted
1264    command set for use with remote clients.
1265
1266  * gpgconf --kill does not anymore start a service only to kill it.
1267
1268  * gpg-pconnect-agent: Add convenience option --uiserver.
1269
1270  * Fixed keyserver access for Windows.
1271
1272  * Fixed build problems on Mac OS X
1273
1274  * The Windows installer does now install development files
1275
1276  * More translations (but most of them are not complete).
1277
1278  * To support remotely mounted home directories, the IPC sockets may
1279    now be redirected.  This feature requires Libassuan 2.2.0.
1280
1281  * Improved portability and the usual bunch of bug fixes.
1282
1283  See-also: gnupg-announce/2014q4/000360.html
1284
1285
1286 Noteworthy changes in version 2.1.0 (2014-11-06)
1287 ------------------------------------------------
1288
1289  This release introduces a lot of changes.  Most of them are internal
1290  and thus not user visible.  However, some long standing behavior has
1291  slightly changed and it is strongly suggested that an existing
1292  "~/.gnupg" directory is backed up before this version is used.
1293
1294  A verbose description of the major new features and changes can be
1295  found in the file doc/whats-new-in-2.1.txt.
1296
1297  * gpg: All support for v3 (PGP 2) keys has been dropped.  All
1298    signatures are now created as v4 signatures.  v3 keys will be
1299    removed from the keyring.
1300
1301  * gpg: With pinentry-0.9.0 the passphrase "enter again" prompt shows
1302    up in the same window as the "new passphrase" prompt.
1303
1304  * gpg: Allow importing keys with duplicated long key ids.
1305
1306  * dirmngr: May now be build without support for LDAP.
1307
1308  * For a complete list of changes see the lists of changes for the
1309    2.1.0 beta versions below.  Note that all relevant fixes from
1310    versions 2.0.14 to 2.0.26 are also applied to this version.
1311
1312
1313  [Noteworthy changes in version 2.1.0-beta864 (2014-10-03)]
1314
1315  * gpg: Removed the GPG_AGENT_INFO related code.  GnuPG does now
1316    always use a fixed socket name in its home directory.
1317
1318  * gpg: Renamed --gen-key to --full-gen-key and re-added a --gen-key
1319    command with less choices.
1320
1321  * gpg: Use SHA-256 for all signature types also on RSA keys.
1322
1323  * gpg: Default keyring is now created with a .kbx suffix.
1324
1325  * gpg: Add a shortcut to the key capabilies menu (e.g. "=e" sets the
1326    encryption capabilities).
1327
1328  * gpg: Fixed obsolete options parsing.
1329
1330  * Further improvements for the alternative speedo build system.
1331
1332
1333  [Noteworthy changes in version 2.1.0-beta834 (2014-09-18)]
1334
1335  * gpg: Improved passphrase caching.
1336
1337  * gpg: Switched to algorithm number 22 for EdDSA.
1338
1339  * gpg: Removed CAST5 from the default preferences.
1340
1341  * gpg: Order SHA-1 last in the hash preferences.
1342
1343  * gpg: Changed default cipher for --symmetric to AES-128.
1344
1345  * gpg: Fixed export of ECC keys and import of EdDSA keys.
1346
1347  * dirmngr: Fixed the KS_FETCH command.
1348
1349  * The speedo build system now downloads related packages and works
1350    for non-Windows platforms.
1351
1352
1353  [Noteworthy changes in version 2.1.0-beta783 (2014-08-14)]
1354
1355  * gpg: Add command --quick-gen-key.
1356
1357  * gpg: Make --quick-sign-key promote local key signatures.
1358
1359  * gpg: Added "show-usage" sub-option to --list-options.
1360
1361  * gpg: Screen keyserver responses to avoid importing unwanted keys
1362    from rogue servers.
1363
1364  * gpg: Removed the option --pgp2 and --rfc1991 and the ability to
1365    create PGP-2 compatible messages.
1366
1367  * gpg: Removed options --compress-keys and --compress-sigs.
1368
1369  * gpg: Cap attribute packets at 16MB.
1370
1371  * gpg: Improved output of --list-packets.
1372
1373  * gpg: Make with-colons output of --search-keys work again.
1374
1375  * gpgsm: Auto-create the ".gnupg" directory like gpg does.
1376
1377  * agent: Fold new passphrase warning prompts into one.
1378
1379  * scdaemon: Add support for the Smartcard-HSM card.
1380
1381  * scdaemon: Remove the use of the pcsc-wrapper.
1382
1383
1384  [Noteworthy changes in version 2.1.0-beta751 (2014-07-03)]
1385
1386  * gpg: Create revocation certificates during key generation.
1387
1388  * gpg: Create exported secret keys and revocation certifciates with
1389    mode 0700
1390
1391  * gpg: The validity of user ids is now shown by default.  To revert
1392    this add "list-options no-show-uid-validity" to gpg.conf.
1393
1394  * gpg: Make export of secret keys work again.
1395
1396  * gpg: The output of --list-packets does now print the offset of the
1397    packet and information about the packet header.
1398
1399  * gpg: Avoid DoS due to garbled compressed data packets. [CVE-2014-4617]
1400
1401  * gpg: Print more specific reason codes with the INV_RECP status.
1402
1403  * gpg: Cap RSA and Elgamal keysize at 4096 bit also for unattended
1404    key generation.
1405
1406  * scdaemon: Support reader Gemalto IDBridge CT30 and pinpad of SCT
1407    cyberJack go.
1408
1409  * The speedo build system has been improved.  It is now also possible
1410    to build a partly working installer for Windows.
1411
1412
1413  [Noteworthy changes in version 2.1.0-beta442 (2014-06-05)]
1414
1415  * gpg: Changed the format of key listings.  To revert to the old
1416    format the option --legacy-list-mode is available.
1417
1418  * gpg: Add experimental signature support using curve Ed25519 and
1419    with a patched Libgcrypt also encryption support with Curve25519.
1420    [Update: this encryption support has been removed from 2.1.0 until
1421    we have agreed on a suitable format.]
1422
1423  * gpg: Allow use of Brainpool curves.
1424
1425  * gpg: Accepts a space separated fingerprint as user ID.  This
1426    allows to copy and paste the fingerprint from the key listing.
1427
1428  * gpg: The hash algorithm is now printed for signature records in key
1429    listings.
1430
1431  * gpg: Reject signatures made using the MD5 hash algorithm unless the
1432    new option --allow-weak-digest-algos or --pgp2 are given.
1433
1434  * gpg: Print a warning if the Gnome-Keyring-Daemon intercepts the
1435    communication with the gpg-agent.
1436
1437  * gpg: New option --pinentry-mode.
1438
1439  * gpg: Fixed decryption using an OpenPGP card.
1440
1441  * gpg: Fixed bug with deeply nested compressed packets.
1442
1443  * gpg: Only the major version number is by default included in the
1444    armored output.
1445
1446  * gpg: Do not create a trustdb file if --trust-model=always is used.
1447
1448  * gpg: Protect against rogue keyservers sending secret keys.
1449
1450  * gpg: The format of the fallback key listing ("gpg KEYFILE") is now
1451    more aligned to the regular key listing ("gpg -k").
1452
1453  * gpg: The option--show-session-key prints its output now before the
1454    decryption of the bulk message starts.
1455
1456  * gpg: New %U expando for the photo viewer.
1457
1458  * gpg,gpgsm: New option --with-secret.
1459
1460  * gpgsm: By default the users are now asked via the Pinentry whether
1461    they trust an X.509 root key.  To prohibit interactive marking of
1462    such keys, the new option --no-allow-mark-trusted may be used.
1463
1464  * gpgsm: New commands to export a secret RSA key in PKCS#1 or PKCS#8
1465    format.
1466
1467  * gpgsm: Improved handling of re-issued CA certificates.
1468
1469  * agent: The included ssh agent does now support ECDSA keys.
1470
1471  * agent: New option --enable-putty-support to allow gpg-agent on
1472    Windows to act as a Pageant replacement with full smartcard support.
1473
1474  * scdaemon: New option --enable-pinpad-varlen.
1475
1476  * scdaemon: Various fixes for pinpad equipped card readers.
1477
1478  * scdaemon: Rename option --disable-pinpad (was --disable-keypad).
1479
1480  * scdaemon: Better support fo CCID readers.  Now, internal CCID
1481    driver supports readers with no auto configuration feature.
1482
1483  * dirmngr: Removed support for the original HKP keyserver which is
1484    not anymore used by any site.
1485
1486  * dirmngr: Improved support for keyserver pools.
1487
1488  * tools: New option --dirmngr for gpg-connect-agent.
1489
1490  * The GNU Pth library has been replaced by the new nPth library.
1491
1492  * Support installation as portable application under Windows.
1493
1494  * All kind of other improvements - see the git log.
1495
1496
1497  [Noteworthy changes in version 2.1.0beta3 (2011-12-20)]
1498
1499  * gpg: Fixed regression in the secret key export function.
1500
1501  * gpg: Allow generation of card keys up to 4096 bit.
1502
1503  * gpgsm: Preliminary support for the validation model "steed".
1504
1505  * gpgsm: Improved certificate creation.
1506
1507  * agent: Support the SSH confirm flag.
1508
1509  * agent: New option to select a passphrase mode.  The loopback
1510    mode may be used to bypass Pinentry.
1511
1512  * agent: The Assuan commands KILLAGENT and KILLSCD are working again.
1513
1514  * scdaemon: Does not anymore block after changing a card (regression
1515    fix).
1516
1517  * tools: gpg-connect-agent does now proberly display the help output
1518    for "SCD HELP" commands.
1519
1520
1521  [Noteworthy changes in version 2.1.0beta2 (2011-03-08)]
1522
1523  * gpg: ECC support as described by draft-jivsov-openpgp-ecc-06.txt
1524    [Update: now known as RFC-6637].
1525
1526  * gpg: Print "AES128" instead of "AES".  This change introduces a
1527    little incompatibility for tools using "gpg --list-config".  We
1528    hope that these tools are written robust enough to accept this new
1529    algorithm name as well.
1530
1531  * gpgsm: New feature to create certificates from a parameter file.
1532    Add prompt to the --gen-key UI to create self-signed certificates.
1533
1534  * agent: TMPDIR is now also honored when creating a socket using
1535    the --no-standard-socket option and with symcryptrun's temp files.
1536
1537  * scdaemon: Fixed a bug where scdaemon sends a signal to gpg-agent
1538    running in non-daemon mode.
1539
1540  * dirmngr: Fixed CRL loading under W32 (bug#1010).
1541
1542  * Dirmngr has taken over the function of the keyserver helpers.  Thus
1543    we now have a specified direct interface to keyservers via Dirmngr.
1544    LDAP, DNS and mail backends are not yet implemented.
1545
1546  * Fixed TTY management for pinentries and session variable update
1547    problem.
1548
1549
1550  [Noteworthy changes in version 2.1.0beta1 (2010-10-26)]
1551
1552  * gpg: secring.gpg is not anymore used but all secret key operations
1553    are delegated to gpg-agent.  The import command moves secret keys
1554    to the agent.
1555
1556  * gpg: The OpenPGP import command is now able to merge secret keys.
1557
1558  * gpg: Encrypted OpenPGP messages with trailing data (e.g. other
1559    OpenPGP packets) are now correctly parsed.
1560
1561  * gpg: Given sufficient permissions Dirmngr is started automagically.
1562
1563  * gpg: Fixed output of "gpgconf --check-options".
1564
1565  * gpg: Removed options --export-options(export-secret-subkey-passwd)
1566    and --simple-sk-checksum.
1567
1568  * gpg: New options --try-secret-key.
1569
1570  * gpg: Support DNS lookups for SRV, PKA and CERT on W32.
1571
1572  * gpgsm: The --audit-log feature is now more complete.
1573
1574  * gpgsm: The default for --include-cert is now to include all
1575    certificates in the chain except for the root certificate.
1576
1577  * gpgsm: New option --ignore-cert-extension.
1578
1579  * g13: The G13 tool for disk encryption key management has been
1580    added.
1581
1582  * agent: If the agent's --use-standard-socket option is active, all
1583    tools try to start and daemonize the agent on the fly.  In the past
1584    this was only supported on W32; on non-W32 systems the new
1585    configure option --disable-standard-socket may now be used to
1586    disable this new default.
1587
1588  * agent: New and changed passphrases are now created with an
1589    iteration count requiring about 100ms of CPU work.
1590
1591  * dirmngr: Dirmngr is now a part of this package.  It is now also
1592    expected to run as a system service and the configuration
1593    directories are changed to the GnuPG name space. [Update: 2.1.0
1594    starts dirmngr on demand as user daemon.]
1595
1596  * Support for Windows CE. [Update: This has not been tested for the
1597    2.1.0 release]
1598
1599  * Numerical values may now be used as an alternative to the
1600    debug-level keywords.
1601
1602  See-also: gnupg-announce/2014q4/000358.html
1603
1604
1605 Version 2.0.28 (2015-06-02)
1606 Version 2.0.27 (2015-02-18)
1607 Version 2.0.26 (2014-08-12)
1608 Version 2.0.25 (2014-06-30)
1609 Version 2.0.24 (2014-06-24)
1610 Version 2.0.23 (2014-06-03)
1611 Version 2.0.22 (2013-10-04)
1612 Version 2.0.21 (2013-08-19)
1613 Version 2.0.20 (2013-05-10)
1614 Version 2.0.19 (2012-03-27)
1615 Version 2.0.18 (2011-08-04)
1616 Version 2.0.17 (2011-01-13)
1617 Version 2.0.16 (2010-07-19)
1618 Version 2.0.15 (2010-03-09)
1619 Version 2.0.14 (2009-12-21)
1620
1621
1622 Noteworthy changes in version 2.0.13 (2009-09-04)
1623 -------------------------------------------------
1624
1625  * GPG now generates 2048 bit RSA keys by default.  The default hash
1626    algorithm preferences has changed to prefer SHA-256 over SHA-1.
1627    2048 bit DSA keys are now generated to use a 256 bit hash algorithm
1628
1629  * The envvars XMODIFIERS, GTK_IM_MODULE and QT_IM_MODULE are now
1630    passed to the Pinentry to make SCIM work.
1631
1632  * The GPGSM command --gen-key features a --batch mode and implements
1633    all features of gpgsm-gencert.sh in standard mode.
1634
1635  * New option --re-import for GPGSM's IMPORT server command.
1636
1637  * Enhanced writing of existing keys to OpenPGP v2 cards.
1638
1639  * Add hack to the internal CCID driver to allow the use of some
1640    Omnikey based card readers with 2048 bit keys.
1641
1642  * GPG now repeatly asks the user to insert the requested OpenPGP
1643    card.  This can be disabled with --limit-card-insert-tries=1.
1644
1645  * Minor bug fixes.
1646
1647  See-also: gnupg-announce/2009q3/000294.html
1648
1649
1650 Noteworthy changes in version 2.0.12 (2009-06-17)
1651 -------------------------------------------------
1652
1653  * GPGSM now always lists ephemeral certificates if specified by
1654    fingerprint or keygrip.
1655
1656  * New command "KEYINFO" for GPG_AGENT.  GPGSM now also returns
1657    information about smartcards.
1658
1659  * Made sure not to leak file descriptors if running gpg-agent with a
1660    command.  Restore the signal mask to solve a problem in Mono.
1661
1662  * Changed order of the confirmation questions for root certificates
1663    and store negative answers in trustlist.txt.
1664
1665  * Better synchronization of concurrent smartcard sessions.
1666
1667  * Support 2048 bit OpenPGP cards.
1668
1669  * Support Telesec Netkey 3 cards.
1670
1671  * The gpg-protect-tool now uses gpg-agent via libassuan.  Under
1672    Windows the Pinentry will now be put into the foreground.
1673
1674  * Changed code to avoid a possible Mac OS X system freeze.
1675
1676  See-also: gnupg-announce/2009q2/000288.html
1677
1678
1679 Noteworthy changes in version 2.0.11 (2009-03-03)
1680 -------------------------------------------------
1681
1682  * Fixed a problem in SCDAEMON which caused unexpected card resets.
1683
1684  * SCDAEMON is now aware of the Geldkarte.
1685
1686  * The SCDAEMON option --allow-admin is now used by default.
1687
1688  * GPGCONF now restarts SCdaemon if necessary.
1689
1690  * The default cipher algorithm in GPGSM is now again 3DES.  This is
1691    due to interoperability problems with Outlook 2003 which still
1692    can't cope with AES.
1693
1694  See-also: gnupg-announce/2009q1/000287.html
1695
1696
1697 Noteworthy changes in version 2.0.10 (2009-01-12)
1698 -------------------------------------------------
1699
1700  * [gpg] New keyserver helper gpg2keys_kdns as generic DNS CERT
1701    lookup.  Run with --help for a short description.  Requires the
1702    ADNS library.
1703
1704  * [gpg] New mechanisms "local" and "nodefault" for --auto-key-locate.
1705    Fixed a few problems with this option.
1706
1707  * [gpg] New command --locate-keys.
1708
1709  * [gpg] New options --with-sig-list and --with-sig-check.
1710
1711  * [gpg] The option "-sat" is no longer an alias for --clearsign.
1712
1713  * [gpg] The option --fixed-list-mode is now implicitly used and obsolete.
1714
1715  * [gpg] New control statement %ask-passphrase for the unattended key
1716    generation.
1717
1718  * [gpg] The algorithm to compute the SIG_ID status has been changed.
1719
1720  * [gpgsm] Now uses AES by default.
1721
1722  * [gpgsm] Made --output option work with --export-secret-key-p12.
1723
1724  * [gpg-agent] Terminate process if the own listening socket is not
1725    anymore served by ourself.
1726
1727  * [scdaemon] Made it more robust on W32.
1728
1729  * [gpg-connect-agent] Accept commands given as command line arguments.
1730
1731  * [w32] Initialized the socket subsystem for all keyserver helpers.
1732
1733  * [w32] The sysconf directory has been moved from a subdirectory of
1734    the installation directory to %CSIDL_COMMON_APPDATA%/GNU/etc/gnupg.
1735
1736  * [w32] The gnupg2.nls directory is not anymore used.  The standard
1737    locale directory is now used.
1738
1739  * [w32] Fixed a race condition between gpg and gpgsm in the use of
1740    temporary file names.
1741
1742  * The gpg-preset-passphrase mechanism works again.  An arbitrary
1743    string may now be used for a custom cache ID.
1744
1745  * Admin PINs are cached again (bug in 2.0.9).
1746
1747  * Support for version 2 OpenPGP cards.
1748
1749  * Libgcrypt 1.4 is now required.
1750
1751  See-also: gnupg-announce/2009q1/000284.html
1752
1753
1754 Noteworthy changes in version 2.0.9 (2008-03-26)
1755 ------------------------------------------------
1756
1757  * Gpgsm always tries to locate missing certificates from a running
1758    Dirmngr's cache.
1759
1760  * Tweaks for Windows.
1761
1762  * The Admin PIN for OpenPGP cards may now be entered with the pinpad.
1763
1764  * Improved certificate chain construction.
1765
1766  * Extended the PKITS framework.
1767
1768  * Fixed a bug in the ambigious name detection.
1769
1770  * Fixed possible memory corruption while importing OpenPGP keys (bug
1771    introduced with 2.0.8). [CVE-2008-1530]
1772
1773  * Minor bug fixes.
1774
1775
1776
1777 Noteworthy changes in version 2.0.8 (2007-12-20)
1778 ------------------------------------------------
1779
1780  * Enhanced gpg-connect-agent with a small scripting language.
1781
1782  * New option --list-config for gpgconf.
1783
1784  * Fixed a crash in gpgconf.
1785
1786  * Gpg-agent now supports the passphrase quality bar of the latest
1787    Pinentry.
1788
1789  * The envvars XAUTHORITY and PINENTRY_USER_DATA are now passed to the
1790    Pinentry.
1791
1792  * Fixed the auto creation of the key stub for smartcards.
1793
1794  * Fixed a rare bug in decryption using the OpenPGP card.
1795
1796  * Creating DSA2 keys is now possible.
1797
1798  * New option --extra-digest-algo for gpgsm to allow verification of
1799    broken signatures.
1800
1801  * Allow encryption with legacy Elgamal sign+encrypt keys with option
1802    --rfc2440.
1803
1804  * Windows is now a supported platform.
1805
1806  * Made sure that under Windows the file permissions of the socket are
1807    taken into account.  This required a change of our socket emulation
1808    code and changed the IPC protocol under Windows.
1809
1810  See-also: gnupg-announce/2007q4/000267.html
1811
1812
1813 Noteworthy changes in version 2.0.7 (2007-09-10)
1814 ------------------------------------------------
1815
1816  * Fixed encryption problem if duplicate certificates are in the
1817    keybox.
1818
1819  * Made it work on Windows Vista.  Note that the entire Windows port
1820    is still considered Beta.
1821
1822  * Add new options min-passphrase-nonalpha, check-passphrase-pattern,
1823    enforce-passphrase-constraints and max-passphrase-days to
1824    gpg-agent.
1825
1826  * Add command --check-components to gpgconf.  Gpgconf now uses the
1827    installed versions of the programs and does not anymore search via
1828    PATH for them.
1829
1830  See-also: gnupg-announce/2007q3/000259.html
1831
1832
1833 Noteworthy changes in version 2.0.6 (2007-08-16)
1834 ------------------------------------------------
1835
1836  * GPGSM does now grok --default-key.
1837
1838  * GPGCONF is now aware of --default-key and --encrypt-to.
1839
1840  * GPGSM does again correctly print the serial number as well the the
1841    various keyids.  This was broken since 2.0.4.
1842
1843  * New option --validation-model and support for the chain-model.
1844
1845  * Improved Windows support.
1846
1847  See-also: gnupg-announce/2007q3/000258.html
1848
1849
1850 Noteworthy changes in version 2.0.5 (2007-07-05)
1851 ------------------------------------------------
1852
1853  * Switched license to GPLv3.
1854
1855  * Basic support for Windows.  Run "./autogen.sh --build-w32" to build
1856    it.  As usual the mingw cross compiling toolchain is required.
1857
1858  * Fixed bug when using the --p12-charset without --armor.
1859
1860  * The command --gen-key may now be used instead of the
1861    gpgsm-gencert.sh script.
1862
1863  * Changed key generation to reveal less information about the
1864    machine.  Bug fixes for gpg2's card key generation.
1865
1866  See-also: gnupg-announce/2007q3/000255.html
1867
1868
1869 Noteworthy changes in version 2.0.4 (2007-05-09)
1870 ------------------------------------------------
1871
1872  * The server mode key listing commands are now also working for
1873    systems without the funopen/fopencookie API.
1874
1875  * PKCS#12 import now tries several encodings in case the passphrase
1876    was not utf-8 encoded.  New option --p12-charset for gpgsm.
1877
1878  * Improved the libgcrypt logging support in all modules.
1879
1880  See-also: gnupg-announce/2007q2/000254.html
1881
1882
1883 Noteworthy changes in version 2.0.3 (2007-03-08)
1884 ------------------------------------------------
1885
1886  * By default, do not allow processing multiple plaintexts in a single
1887    stream.  Many programs that called GnuPG were assuming that GnuPG
1888    did not permit this, and were thus not using the plaintext boundary
1889    status tags that GnuPG provides.  This change makes GnuPG reject
1890    such messages by default which makes those programs safe again.
1891    --allow-multiple-messages returns to the old behavior. [CVE-2007-1263].
1892
1893  * New --verify-option show-primary-uid-only.
1894
1895  * gpgconf may now reads a global configuration file to select which
1896    options are changeable by a frontend.  The new applygnupgdefaults
1897    tool may be used by an admin to set default options for all users.
1898
1899  * The PIN pad of the Cherry XX44 keyboard is now supported.  The
1900    DINSIG and the NKS applications are now also aware of PIN pads.
1901
1902  See-also: gnupg-announce/2007q1/000252.html
1903
1904
1905 Noteworthy changes in version 2.0.2 (2007-01-31)
1906 ------------------------------------------------
1907
1908  * Fixed a serious and exploitable bug in processing encrypted
1909    packages. [CVE-2006-6235].
1910
1911  * Added --passphrase-repeat to set the number of times GPG will
1912    prompt for a new passphrase to be repeated.  This is useful to help
1913    memorize a new passphrase.  The default is 1 repetition.
1914
1915  * Using a PIN pad does now also work for the signing key.
1916
1917  * A warning is displayed by gpg-agent if a new passphrase is too
1918    short.  New option --min-passphrase-len defaults to 8.
1919
1920  * The status code BEGIN_SIGNING now shows the used hash algorithms.
1921
1922  See-also: gnupg-announce/2007q1/000249.html
1923
1924
1925 Noteworthy changes in version 2.0.1 (2006-11-28)
1926 ------------------------------------------------
1927
1928  * Experimental support for the PIN pads of the SPR 532 and the Kaan
1929    Advanced card readers.  Add "disable-keypad" scdaemon.conf if you
1930    don't want it.  Does currently only work for the OpenPGP card and
1931    its authentication and decrypt keys.
1932
1933  * Fixed build problems on some some platforms and crashes on amd64.
1934
1935  * Fixed a buffer overflow in gpg2. [bug#728,CVE-2006-6169]
1936
1937  See-also: gnupg-announce/2006q4/000242.html
1938
1939
1940 Noteworthy changes in version 2.0.0 (2006-11-11)
1941 ------------------------------------------------
1942
1943  * First stable version of a GnuPG integrating OpenPGP and S/MIME.
1944
1945  See-also: gnupg-announce/2006q4/000239.html
1946
1947
1948 Noteworthy changes in version 1.9.95 (2006-11-06)
1949 -------------------------------------------------
1950
1951  * Minor bug fixes.
1952
1953
1954 Noteworthy changes in version 1.9.94 (2006-10-24)
1955 -------------------------------------------------
1956
1957  * Keys for gpgsm may now be specified using a keygrip.  A keygrip is
1958    indicated by a prefixing it with an ampersand.
1959
1960  * gpgconf now supports switching the CMS cipher algo (e.g. to AES).
1961
1962  * New command --gpgconf-test for all major tools. This may be used to
1963    check whether the configuration file is sane.
1964
1965
1966 Noteworthy changes in version 1.9.93 (2006-10-18)
1967 -------------------------------------------------
1968
1969  * In --with-validation mode gpgsm will now also ask whether a root
1970    certificate should be trusted.
1971
1972  * Link to Pth only if really necessary.
1973
1974  * Fixed a pubring corruption bug in gpg2 occurring when importing
1975    signatures or keys with insane lengths.
1976
1977  * Fixed v3 keyID calculation bug in gpg2.
1978
1979  * More tweaks for certificates without extensions.
1980
1981
1982 Noteworthy changes in version 1.9.92 (2006-10-11)
1983 -------------------------------------------------
1984
1985  * Bug fixes.
1986
1987  See-also: gnupg-announce/2006q4/000236.html
1988
1989
1990 Noteworthy changes in version 1.9.91 (2006-10-04)
1991 -------------------------------------------------
1992
1993  * New "relax" flag for trustlist.txt to allow root CA certificates
1994    without BasicContraints.
1995
1996  * [gpg2] Removed the -k PGP 2 compatibility hack.  -k is now an
1997    alias for --list-keys.
1998
1999  * [gpg2] Print a warning if "-sat" is used instead of "--clearsign".
2000
2001
2002 Noteworthy changes in version 1.9.90 (2006-09-25)
2003 -------------------------------------------------
2004
2005  * Made readline work for gpg.
2006
2007  * Cleanups und minor bug fixes.
2008
2009  * Included translations from gnupg 1.4.5.
2010
2011
2012 Noteworthy changes in version 1.9.23 (2006-09-18)
2013 -------------------------------------------------
2014
2015  * Regular man pages for most tools are now build directly from the
2016    Texinfo source.
2017
2018  * The gpg code from 1.4.5 has been fully merged into this release.
2019    The configure option --enable-gpg is still required to build this
2020    gpg part.  For production use of OpenPGP the gpg version 1.4.5 is
2021    still recommended.  Note, that gpg will be installed under the name
2022    gpg2 to allow coexisting with an 1.4.x gpg.
2023
2024  * API change in gpg-agent's pkdecrypt command.  Thus an older gpgsm
2025    may not be used with the current gpg-agent.
2026
2027  * The scdaemon will now call a script on reader status changes.
2028
2029  * gpgsm now allows file descriptor passing for "INPUT", "OUTPUT" and
2030    "MESSAGE".
2031
2032  * The gpgsm server may now output a key listing to the output file
2033    handle. This needs to be enabled using "OPTION list-to-output=1".
2034
2035  * The --output option of gpgsm has now an effect on list-keys.
2036
2037  * New gpgsm commands --dump-chain and list-chain.
2038
2039  * gpg-connect-agent has new options to utilize descriptor passing.
2040
2041  * A global trustlist may now be used.  See doc/examples/trustlist.txt.
2042
2043  * When creating a new pubring.kbx keybox common certificates are
2044    imported.
2045
2046
2047 Noteworthy changes in version 1.9.22 (2006-07-27)
2048 -------------------------------------------------
2049
2050  * Enhanced pkcs#12 support to allow import from simple keyBags.
2051
2052  * Exporting to pkcs#12 now create bag attributes so that Mozilla is
2053    able to import the files.
2054
2055  * Fixed uploading of certain keys to the smart card.
2056
2057
2058 Noteworthy changes in version 1.9.21 (2006-06-20)
2059 -------------------------------------------------
2060
2061  * New command APDU for scdaemon to allow using it for general card
2062    access.  Might be used through gpg-connect-agent by using the SCD
2063    prefix command.
2064
2065  * Support for the CardMan 4040 PCMCIA reader (Linux 2.6.15 required).
2066
2067  * Scdaemon does not anymore reset cards at the end of a connection.
2068
2069  * Kludge to allow use of Bundesnetzagentur issued X.509 certificates.
2070
2071  * Added --hash=xxx option to scdaemon's PKSIGN command.
2072
2073  * Pkcs#12 files are now created with a MAC.  This is for better
2074    interoperability.
2075
2076  * Collected bug fixes and minor other changes.
2077
2078
2079 Noteworthy changes in version 1.9.20 (2005-12-20)
2080 -------------------------------------------------
2081
2082  * Importing pkcs#12 files created be recent versions of Mozilla works
2083    again.
2084
2085  * Basic support for qualified signatures.
2086
2087  * New debug tool gpgparsemail.
2088
2089
2090 Noteworthy changes in version 1.9.19 (2005-09-12)
2091 -------------------------------------------------
2092
2093  * The Belgian eID card is now supported for signatures and ssh.
2094    Other pkcs#15 cards should work as well.
2095
2096  * Fixed bug in --export-secret-key-p12 so that certificates are again
2097    included.
2098
2099
2100 Noteworthy changes in version 1.9.18 (2005-08-01)
2101 -------------------------------------------------
2102
2103  * [gpgsm] Now allows for more than one email address as well as URIs
2104    and dnsNames in certificate request generation.  A keygrip may be
2105    given to create a request from an existing key.
2106
2107  * A couple of minor bug fixes.
2108
2109
2110 Noteworthy changes in version 1.9.17 (2005-06-20)
2111 -------------------------------------------------
2112
2113  * gpg-connect-agent has now features to handle Assuan INQUIRE
2114    commands.
2115
2116  * Internal changes for OpenPGP cards. New Assuan command WRITEKEY.
2117
2118  * GNU Pth is now a hard requirement.
2119
2120  * [scdaemon] Support for OpenSC has been removed.  Instead a new and
2121    straightforward pkcs#15 modules has been written.  As of now it
2122    does allows only signing using TCOS cards but we are going to
2123    enhance it to match all the old capabilities.
2124
2125  * [gpg-agent] New option --write-env-file and Assuan command
2126    UPDATESTARTUPTTY.
2127
2128  * [gpg-agent] New option --default-cache-ttl-ssh to set the TTL for
2129    SSH passphrase caching independent from the other passphrases.
2130
2131
2132 Noteworthy changes in version 1.9.16 (2005-04-21)
2133 -------------------------------------------------
2134
2135  * gpg-agent does now support the ssh-agent protocol and thus allows
2136    to use the pinentry as well as the OpenPGP smartcard with ssh.
2137
2138  * New tool gpg-connect-agent as a general client for the gpg-agent.
2139
2140  * New tool symcryptrun as a wrapper for certain encryption tools.
2141
2142  * The gpg tool is not anymore build by default because those gpg
2143    versions available in the gnupg 1.4 series are far more matured.
2144
2145
2146 Noteworthy changes in version 1.9.15 (2005-01-13)
2147 -------------------------------------------------
2148
2149  * Fixed passphrase caching bug.
2150
2151  * Better support for CCID readers; the reader from Cherry RS 6700 USB
2152    does now work.
2153
2154
2155 Noteworthy changes in version 1.9.14 (2004-12-22)
2156 -------------------------------------------------
2157
2158  * [gpg-agent] New option --use-standard-socket to allow the use of a
2159    fixed socket.  gpgsm falls back to this socket if GPG_AGENT_INFO
2160    has not been set.
2161
2162  * Ported to MS Windows with some functional limitations.
2163
2164  * New tool gpg-preset-passphrase.
2165
2166
2167 Noteworthy changes in version 1.9.13 (2004-12-03)
2168 -------------------------------------------------
2169
2170  * [gpgsm] New option --prefer-system-dirmngr.
2171
2172  * Minor cleanups and debugging aids.
2173
2174
2175 Noteworthy changes in version 1.9.12 (2004-10-22)
2176 -------------------------------------------------
2177
2178  * [scdaemon] Partly rewrote the PC/SC code.
2179
2180  * Removed the sc-investigate tool.  It is now in a separate package
2181    available at ftp://ftp.g10code.com/g10code/gscutils/ .
2182
2183  * [gpg-agent] Fixed logging problem.
2184
2185
2186 Noteworthy changes in version 1.9.11 (2004-10-01)
2187 -------------------------------------------------
2188
2189  * When using --import along with --with-validation, the imported
2190    certificates are validated and only imported if they are fully
2191    valid.
2192
2193  * [gpg-agent] New option --max-cache-ttl.
2194
2195  * [gpg-agent] When used without --daemon or --server, gpg-agent now
2196    check whether a agent is already running and usable.
2197
2198  * Fixed some i18n problems.
2199
2200
2201 Noteworthy changes in version 1.9.10 (2004-07-22)
2202 -------------------------------------------------
2203
2204  * Fixed a serious bug in the checking of trusted root certificates.
2205
2206  * New configure option --enable-agent-pnly allows to build and
2207    install just the agent.
2208
2209  * Fixed a problem with the log file handling.
2210
2211
2212 Noteworthy changes in version 1.9.9 (2004-06-08)
2213 ------------------------------------------------
2214
2215  * [gpg-agent] The new option --allow-mark-trusted is now required to
2216    allow gpg-agent to add a key to the trustlist.txt after user
2217    confirmation.
2218
2219  * Creating PKCS#10 requests does now honor the key usage.
2220
2221
2222 Noteworthy changes in version 1.9.8 (2004-04-29)
2223 ------------------------------------------------
2224
2225  * [scdaemon] Overhauled the internal CCID driver.
2226
2227  * [scdaemon] Status files named ~/.gnupg/reader_<n>.status are now
2228    written when using the internal CCID driver.
2229
2230  * [gpgsm] New commands --dump-{,secret,external}-keys to show a very
2231    detailed view of the certificates.
2232
2233  * The keybox gets now compressed after 3 hours and ephemeral
2234    stored certificates are deleted after about a day.
2235
2236  * [gpg] Usability fixes for --card-edit.  Note, that this has already
2237    been ported back to gnupg-1.3
2238
2239
2240 Noteworthy changes in version 1.9.7 (2004-04-06)
2241 ------------------------------------------------
2242
2243  * Instrumented the modules for gpgconf.
2244
2245  * Added support for DINSIG card applications.
2246
2247  * Include the smimeCapabilities attribute with signed messages.
2248
2249  * Now uses the gettext domain "gnupg2" to avoid conflicts with gnupg
2250    versions < 1.9.
2251
2252
2253 Noteworthy changes in version 1.9.6 (2004-03-06)
2254 ------------------------------------------------
2255
2256  * Code cleanups and bug fixes.
2257
2258
2259 Noteworthy changes in version 1.9.5 (2004-02-21)
2260 ------------------------------------------------
2261
2262  * gpg-protect-tool gets now installed into libexec as it ought to be.
2263    Cleaned up the build system to better comply with the coding
2264    standards.
2265
2266  * [gpgsm] The --import command is now able to autodetect pkcs#12
2267    files and import secret and private keys from this file format.
2268    A new command --export-secret-key-p12 is provided to allow
2269    exporting of secret keys in PKCS\#12 format.
2270
2271  * [gpgsm] The pinentry will now present a description of the key for
2272    whom the passphrase is requested.
2273
2274  * [gpgsm] New option --with-validation to check the validity of key
2275    while listing it.
2276
2277  * New option --debug-level={none,basic,advanced,expert,guru} to map
2278    the debug flags to sensitive levels on a per program base.
2279
2280
2281 Noteworthy changes in version 1.9.4 (2004-01-30)
2282 ------------------------------------------------
2283
2284  * Added support for the Telesec NKS 2.0 card application.
2285
2286  * Added simple tool addgnupghome to create .gnupg directories from
2287    /etc/skel/.gnupg.
2288
2289  * Various minor bug fixes and cleanups; mainly gpgsm and gpg-agent
2290    related.
2291
2292
2293 Noteworthy changes in version 1.9.3 (2003-12-23)
2294 ------------------------------------------------
2295
2296  * New gpgsm options --{enable,disable}-ocsp to validate keys using
2297    OCSP. This option requires a not yet released DirMngr version.
2298    Default is disabled.
2299
2300  * The --log-file option may now be used to print logs to a socket.
2301    Prefix the socket name with "socket://" to enable this.  This does
2302    not work on all systems and falls back to stderr if there is a
2303    problem with the socket.
2304
2305  * The options --encrypt-to and --no-encrypt-to now work the same in
2306    gpgsm as in gpg.  Note, they are also used in server mode.
2307
2308  * Duplicated recipients are now silently removed in gpgsm.
2309
2310
2311 Noteworthy changes in version 1.9.2 (2003-11-17)
2312 ------------------------------------------------
2313
2314  * On card key generation is no longer done using the --gen-key
2315    command but from the menu provided by the new --card-edit command.
2316
2317  * PINs are now properly cached and there are only 2 PINs visible.
2318    The 3rd PIN (CHV2) is internally syncronized with the regular PIN.
2319
2320  * All kind of other internal stuff.
2321
2322
2323 Noteworthy changes in version 1.9.1 (2003-09-06)
2324 ------------------------------------------------
2325
2326  * Support for OpenSC is back. scdaemon supports a --disable-opensc to
2327    disable OpenSC use at runtime, so that PC/SC or ct-API can still be
2328    used directly.
2329
2330  * Rudimentary support for the SCR335 smartcard reader using an
2331    internal driver.  Requires current libusb from CVS.
2332
2333  * Bug fixes.
2334
2335
2336 Noteworthy changes in version 1.9.0 (2003-08-05)
2337 ------------------------------------------------
2338
2339       ====== PLEASE SEE README-alpha =======
2340
2341  * gpg has been renamed to gpg2 and gpgv to gpgv2.  This is a
2342    temporary change to allow co-existing with stable gpg versions.
2343
2344  * ~/.gnupg/gpg.conf-1.9.0 is fist tried as config file before the
2345    usual gpg.conf.
2346
2347  * Removed the -k, -kv and -kvv commands.  -k is now an alias to
2348    --list-keys.  New command -K as alias for --list-secret-keys.
2349
2350  * Removed --run-as-shm-coprocess feature.
2351
2352  * gpg does now also use libgcrypt, libgpg-error is required.
2353
2354  * New gpgsm commands --call-dirmngr and --call-protect-tool.
2355
2356  * Changing a passphrase is now possible using "gpgsm --passwd"
2357
2358  * The content-type attribute is now recognized and created.
2359
2360  * The agent does now reread certain options on receiving a HUP.
2361
2362  * The pinentry is now forked for each request so that clients with
2363    different environments are supported.  When running in daemon mode
2364    and --keep-display is not used the DISPLAY variable is ignored.
2365
2366  * Merged stuff from the newpg branch and started this new
2367    development branch.
2368
2369
2370 Version 1.4.19 (2015-02-27)
2371 Version 1.4.18 (2014-06-30)
2372 Version 1.4.17 (2014-06-23)
2373 Version 1.4.16 (2013-12-18)
2374 Version 1.4.15 (2013-10-04)
2375 Version 1.4.14 (2013-07-25)
2376 Version 1.4.13 (2012-12-20)
2377 Version 1.4.12 (2012-01-30)
2378 Version 1.4.11 (2010-10-18)
2379 Version 1.4.10 (2009-09-02)
2380 Version 1.4.9 (2008-03-26)
2381 Version 1.4.8 (2007-12-20)
2382 Version 1.4.7 (2007-03-05)
2383 Version 1.4.6 (2006-12-06)
2384 Version 1.4.5 (2006-08-01)
2385 Version 1.4.4 (2006-06-25)
2386 Version 1.4.3 (2006-04-03)
2387 Version 1.4.2 (2005-07-26)
2388 Version 1.4.1 (2005-03-15)
2389 Version 1.4.0 (2004-12-16)
2390
2391
2392 Noteworthy changes in version 1.3.2 (2003-05-27)
2393 ------------------------------------------------
2394
2395     * New "--gnupg" option (set by default) that disables --openpgp,
2396       and the various --pgpX emulation options.  This replaces
2397       --no-openpgp, and --no-pgpX, and also means that GnuPG has
2398       finally grown a --gnupg option to make GnuPG act like GnuPG.
2399
2400     * A bug in key validation has been fixed.  This bug only affects
2401       keys with more than one user ID (photo IDs do not count here),
2402       and results in all user IDs on a given key being treated with
2403       the validity of the most-valid user ID on that key.
2404
2405     * Notation names that do not contain a '@' are no longer allowed
2406       unless --expert is set.  This is to help prevent pollution of
2407       the (as yet unused) IETF notation namespace.
2408
2409     * Multiple trust models are now supported via the --trust-model
2410       option.  The options are "pgp" (web-of-trust plus trust
2411       signatures), "classic" (web-of-trust only), and "always"
2412       (identical to the --always-trust option).
2413
2414     * The --personal-{cipher|digest|compression}-preferences are now
2415       consulted to get default algorithms before resorting to the
2416       last-ditch defaults of --s2k-cipher-algo, SHA1, and ZIP
2417       respectively.  This allows a user to set algorithms to use in a
2418       safe manner so they are used when legal to do so, without
2419       forcing them on for all messages.
2420
2421     * New --primary-keyring option to designate the keyring that the
2422       user wants new keys imported into.
2423
2424     * --s2k-digest-algo is now used for all password mangling.
2425       Earlier versions used both --s2k-digest-algo and --digest-algo
2426       for passphrase mangling.
2427
2428     * Handling of --hidden-recipient or --throw-keyid messages is now
2429       easier - the user only needs to give their passphrase once, and
2430       GnuPG will try it against all of the available secret keys.
2431
2432     * Care is taken to prevent compiler optimization from removing
2433       memory wiping code.
2434
2435     * New option --no-mangle-dos-filenames so that filenames are not
2436       truncated in the W32 version.
2437
2438     * A "convert-from-106" script has been added.  This is a simple
2439       script that automates the conversion from a 1.0.6 or earlier
2440       version of GnuPG to a 1.0.7 or later version.
2441
2442     * Disabled keys are now skipped when selecting keys for
2443       encryption.  If you are using the --with-colons key listings to
2444       detect disabled keys, please see doc/DETAILS for a minor format
2445       change in this release.
2446
2447     * Minor trustdb changes to make the trust calculations match
2448       common usage.
2449
2450     * New command "revuid" in the --edit-key menu to revoke a user ID.
2451       This is a simpler interface to the old method (which still
2452       works) of revoking the user ID self-signature.
2453
2454     * Status VALIDSIG does now also print the primary key's
2455       fingerprint, as well as the signature version, pubkey algorithm,
2456       hash algorithm, and signature class.
2457
2458     * Add read-only support for the SHA-256 hash, and optional
2459       read-only support for the SHA-384 and SHA-512 hashes.
2460
2461     * New option --enable-progress-filter for use with frontends.
2462
2463     * DNS SRV records are used in HKP keyserver lookups to allow
2464       administrators to load balance and select keyserver ports
2465       automatically.  This is as specified in
2466       draft-shaw-openpgp-hkp-00.txt.
2467
2468     * When using the "keyid!" syntax during a key export, only that
2469       specified key is exported.  If the key in question is a subkey,
2470       the primary key plus only that subkey is exported.
2471
2472     * configure --disable-xxx options to disable individual algorithms
2473       at build time.  This can be used to build a smaller gpg binary
2474       for embedded uses where space is tight.  See the README file for
2475       the algorithms that can be used with this option, or use
2476       --enable-minimal to build the smallest gpg possible (disables
2477       all optional algorithms, disables keyserver access, and disables
2478       photo IDs).
2479
2480     * The keyserver no-modify flag on a key can now be displayed and
2481       modified.
2482
2483     * Note that the TIGER/192 digest algorithm is in the process of
2484       being dropped from the OpenPGP standard.  While this release of
2485       GnuPG still contains it, it is disabled by default.  To ensure
2486       you will still be able to use your messages with future versions
2487       of GnuPG and other OpenPGP programs, please do not use this
2488       algorithm.
2489
2490     See-also: gnupg-announce/2003q2/000153.html
2491
2492
2493 Noteworthy changes in version 1.3.1 (2002-11-12)
2494 ------------------------------------------------
2495
2496     * Trust signature support.  This is based on the Maurer trust
2497       model where a user can specify the trust level along with the
2498       signature with multiple levels so users can delegate
2499       certification ability to other users, possibly restricted by a
2500       regular expression on the user ID.  Note that full trust
2501       signature support requires a regular expression parsing library.
2502       The regexp code from glibc 2.3.1 is included for those platforms
2503       that don't have working regexp functions available.  The
2504       configure option --disable-regex may be used to disable any
2505       regular expression code, which will make GnuPG ignore any trust
2506       signature with a regular expression included.
2507
2508     * Two new commands --hidden-recipient (-R) and --hidden-encrypt-to
2509       encrypt to a user, but hide the identity of that user.  This is
2510       the same functionality as --throw-keyid, but can be used on a
2511       per-user basis.
2512
2513     * Full algorithm names (e.g. "3DES", "SHA1", "ZIP") can now be
2514       used interchangeably with the short algorithm names (e.g. "S2",
2515       "H2", "Z1") anywhere algorithm names are used in GnuPG.
2516
2517
2518 Noteworthy changes in version 1.3.0 (2002-10-18)
2519 ------------------------------------------------
2520
2521     * The last piece of internal keyserver support has been removed,
2522       and now all keyserver access is done via the keyserver plugins.
2523       There is also a newer keyserver protocol used between GnuPG and
2524       the plugins, so plugins from earlier versions of GnuPG may not
2525       work properly.
2526
2527     * The HKP keyserver plugin supports the new machine-readable key
2528       listing format for those keyservers that provide it.
2529
2530     * When using a HKP keyserver with multiple DNS records (such as
2531       wwwkeys.pgp.net which has the addresses of multiple servers
2532       around the world), try all records until one succeeds.  Note
2533       that it depends on the LDAP library used whether the LDAP
2534       keyserver plugin does this as well.
2535
2536     * The library dependencies for OpenLDAP seem to change fairly
2537       frequently, and GnuPG's configure script cannot guess all the
2538       combinations.  Use ./configure LDAPLIBS="-L libdir -l libs" to
2539       override the script and use the libraries selected.
2540
2541     * Secret keys generated with --export-secret-subkeys are now
2542       indicated in key listings with a '#' after the "sec", and in
2543       --with-colons listings by showing no capabilities (no lowercase
2544       characters).
2545
2546     * --trusted-key has been un-obsoleted, as it is useful for adding
2547       ultimately trusted keys from the config file.  It is identical
2548       to using --edit and "trust" to change a key to ultimately
2549       trusted.
2550
2551     * Translations other than de are no longer distributed with the
2552       development branch.  This is due to the frequent text changes
2553       during development, which cause the translations to rapidly go
2554       out of date.
2555
2556
2557 Version 1.2.8 (2006-12-07)
2558 Version 1.2.7 (2004-12-27)
2559 Version 1.2.6 (2004-08-25)
2560 Version 1.2.5 (2004-07-26)
2561 Version 1.2.4 (2003-12-23)
2562 Version 1.2.3 (2003-08-21)
2563 Version 1.2.2 (2003-05-01)
2564 Version 1.2.1 (2002-10-25)
2565 Version 1.2.0 (2002-09-21)
2566
2567
2568 Noteworthy changes in version 1.1.92 (2002-09-11)
2569 -------------------------------------------------
2570
2571     * [IMPORTANT] The default configuration file is now
2572       ~/.gnupg/gpg.conf.  If an old ~/.gnupg/options is found it will
2573       still be used.  This change is required to have a more
2574       consistent naming scheme with forthcoming tools.
2575
2576     * The use of MDCs have increased.  A MDC will be used if the
2577       recipients directly request it, if the recipients have AES,
2578       AES192, AES256, or TWOFISH in their cipher preferences, or if
2579       the chosen cipher has a blocksize not equal to 64 bits
2580       (currently this is also AES, AES192, AES256, and TWOFISH).
2581
2582     * GnuPG will no longer automatically disable compression when
2583       processing an already-compressed file unless a MDC is being
2584       used.  This is to give the message a certain amount of
2585       resistance to the chosen-ciphertext attack while communicating
2586       with other programs (most commonly PGP earlier than version 7.x)
2587       that do not support MDCs.
2588
2589     * The option --interactive now has the desired effect when
2590       importing keys.
2591
2592     * The file permission and ownership checks on files have been
2593       clarified.  Specifically, the homedir (usually ~/.gnupg) is
2594       checked to protect everything within it.  If the user specifies
2595       keyrings outside this homedir, they are presumed to be shared
2596       keyrings and therefore *not* checked.  Configuration files
2597       specified with the --options option and the IDEA cipher
2598       extension specified with --load-extension are checked, along
2599       with their enclosing directories.
2600
2601     * The configure option --with-static-rnd=auto allows to build gpg
2602       with all available entropy gathering modules included.  At
2603       runtime the best usable one will be selected from the list
2604       linux, egd, unix.  This is also the default for systems lacking
2605       a /dev/random device.
2606
2607     * The default character set is now taken from the current locale;
2608       it can still be overridden by the --charset option.  Using the
2609       option -vvv shows the used character set.
2610
2611     * [REMOVED] --emulate-checksum-bug and --emulate-3des-s2k-bug have
2612       been removed.
2613
2614
2615 Noteworthy changes in version 1.1.91 (2002-08-04)
2616 -------------------------------------------------
2617
2618     * All modules are now linked statically; the --load-extension
2619       option is in general not useful anymore.  The only exception is
2620       to specify the deprecated idea cipher.
2621
2622     * The IDEA plugin has changed.  Previous versions of the IDEA
2623       plugin will no longer work with GnuPG.  However, the current
2624       version of the plugin will work with earlier GnuPG versions.
2625
2626     * When using --batch with one of the --delete-key commands, the
2627       key must be specified by fingerprint.  See the man page for
2628       details.
2629
2630     * There are now various ways to restrict the ability GnuPG has to
2631       exec external programs (for the keyserver helpers or photo ID
2632       viewers).  Read the README file for the complete list.
2633
2634     * New export option to leave off attribute packets (photo IDs)
2635       during export.  This is useful when exporting to HKP keyservers
2636       which do not understand attribute packets.
2637
2638     * New import option to repair during import the HKP keyserver
2639       mangling multiple subkeys bug.  Note that this cannot completely
2640       repair the damaged key as some crucial data is removed by the
2641       keyserver, but it does at least give you back one subkey.  This
2642       is on by default for keyserver --recv-keys, and off by default
2643       for regular --import.
2644
2645     * The keyserver helper programs now live in
2646       /usr/[local/]libexec/gnupg by default.  If you are upgrading
2647       from 1.0.7, you might want to delete your old copies in
2648       /usr/[local/]bin.  If you use an OS that does not use libexec
2649       for whatever reason, use configure --libexecdir=/usr/local/lib
2650       to place the keyserver helpers there.
2651
2652     * The LDAP keyserver handler now works properly with very old
2653       (version 1) LDAP keyservers.
2654
2655
2656 Noteworthy changes in version 1.1.90 (2002-07-01)
2657 -------------------------------------------------
2658
2659     * New commands: --personal-cipher-preferences,
2660       --personal-digest-preferences, and
2661       --personal-compress-preferences allow the user to specify which
2662       algorithms are to be preferred.  Note that this does not permit
2663       using an algorithm that is not present in the recipient's
2664       preferences (which would violate the OpenPGP standard).  This
2665       just allows sorting the preferences differently.
2666
2667     * New "group" command to refer to several keys with one name.
2668
2669     * A warning is issued if the user forces the use of an algorithm
2670       that is not listed in the recipient's preferences.
2671
2672     * Full revocation key (aka "designated revoker") support.
2673
2674     * The preferred hash algorithms on a key are consulted when
2675       encrypting a signed message to that key.  Note that this is
2676       disabled by default by a SHA1 preference in
2677       --personal-digest-preferences.
2678
2679     * --cert-digest-algo allows the user to specify the hash algorithm
2680       to use when signing a key rather than the default SHA1 (or MD5
2681       for PGP2 keys).  Do not use this feature unless you fully
2682       understand the implications of this.
2683
2684     * --pgp7 mode automatically sets all necessary options to ensure
2685       that the resulting message will be usable by a user of PGP 7.x.
2686
2687     * New --attribute-fd command for frontends and scripts to get the
2688       contents of attribute packets (i.e. photos)
2689
2690     * In expert mode, the user can now re-sign a v3 key with a v4
2691       self-signature.  This does not change the v3 key into a v4 key,
2692       but it does allow the user to use preferences, primary ID flags,
2693       etc.
2694
2695     * Significantly improved photo ID support on non-unixlike
2696       platforms.
2697
2698     * The version number has jumped ahead to 1.1.90 to skip over the
2699       old version 1.1 and to get ready for the upcoming 1.2.
2700
2701     * ElGamal sign and encrypt is not anymore allowed in the key
2702       generation dialog unless in expert mode.  RSA sign and encrypt
2703       has been added with the same restrictions.
2704
2705     * [W32] Keyserver access does work with Windows NT.
2706
2707
2708 Noteworthy changes in version 1.0.7 (2002-04-29)
2709 ------------------------------------------------
2710
2711     * Secret keys are now stored and exported in a new format which
2712       uses SHA-1 for integrity checks.  This format renders the
2713       Rosa/Klima attack useless.  Other OpenPGP implementations might
2714       not yet support this, so the option --simple-sk-checksum creates
2715       the old vulnerable format.
2716
2717     * The default cipher algorithm for encryption is now CAST5,
2718       default hash algorithm is SHA-1.  This will give us better
2719       interoperability with other OpenPGP implementations.
2720
2721     * Symmetric encrypted messages now use a fixed file size if
2722       possible.  This is a tradeoff: it breaks PGP 5, but fixes PGP 2,
2723       6, and 7.  Note this was only an issue with RFC-1991 style
2724       symmetric messages.
2725
2726     * Photographic user ID support.  This uses an external program to
2727       view the images.
2728
2729     * Enhanced keyserver support via keyserver "plugins".  GnuPG comes
2730       with plugins for the NAI LDAP keyserver as well as the HKP email
2731       keyserver.  It retains internal support for the HKP HTTP
2732       keyserver.
2733
2734     * Nonrevocable signatures are now supported.  If a user signs a
2735       key nonrevocably, this signature cannot be taken back so be
2736       careful!
2737
2738     * Multiple signature classes are usable when signing a key to
2739       specify how carefully the key information (fingerprint, photo
2740       ID, etc) was checked.
2741
2742     * --pgp2 mode automatically sets all necessary options to ensure
2743       that the resulting message will be usable by a user of PGP 2.x.
2744
2745     * --pgp6 mode automatically sets all necessary options to ensure
2746       that the resulting message will be usable by a user of PGP 6.x.
2747
2748     * Signatures may now be given an expiration date.  When signing a
2749       key with an expiration date, the user is prompted whether they
2750       want their signature to expire at the same time.
2751
2752     * Revocation keys (designated revokers) are now supported if
2753       present.  There is currently no way to designate new keys as
2754       designated revokers.
2755
2756     * Permissions on the .gnupg directory and its files are checked
2757       for safety.
2758
2759     * --expert mode enables certain silly things such as signing a
2760       revoked user id, expired key, or revoked key.
2761
2762     * Some fixes to build cleanly under Cygwin32.
2763
2764     * New tool gpgsplit to split OpenPGP data formats into packets.
2765
2766     * New option --preserve-permissions.
2767
2768     * Subkeys created in the future are not used for encryption or
2769       signing unless the new option --ignore-valid-from is used.
2770
2771     * Revoked user-IDs are not listed unless signatures are listed too
2772       or we are in verbose mode.
2773
2774     * There is no default comment string with ascii armors anymore
2775       except for revocation certificates and --enarmor mode.
2776
2777     * The command "primary" in the edit menu can be used to change the
2778       primary UID, "setpref" and "updpref" can be used to change the
2779       preferences.
2780
2781     * Fixed the preference handling; since 1.0.5 they were erroneously
2782       matched against against the latest user ID and not the given one.
2783
2784     * RSA key generation.
2785
2786     * Merged Stefan's patches for RISC OS in.  See comments in
2787       scripts/build-riscos.
2788
2789     * It is now possible to sign and conventional encrypt a message (-cs).
2790
2791     * The MDC feature flag is supported and can be set by using
2792       the "updpref" edit command.
2793
2794     * The status messages GOODSIG and BADSIG are now returning the primary
2795       UID, encoded using %XX escaping (but with spaces left as spaces,
2796       so that it should not break too much)
2797
2798     * Support for GDBM based keyrings has been removed.
2799
2800     * The entire keyring management has been revamped.
2801
2802     * The way signature stati are store has changed so that v3
2803       signatures can be supported. To increase the speed of many
2804       operations for existing keyrings you can use the new
2805       --rebuild-keydb-caches command.
2806
2807     * The entire key validation process (trustdb) has been revamped.
2808       See the man page entries for --update-trustdb, --check-trustdb
2809       and --no-auto-check-trustdb.
2810
2811     * --trusted-keys is again obsolete, --edit can be used to set the
2812       ownertrust of any key to ultimately trusted.
2813
2814     * A subkey is never used to sign keys.
2815
2816     * Read only keyrings are now handled as expected.
2817
2818     See-also: gnupg-announce/2002q2/000135.html
2819
2820
2821 Noteworthy changes in version 1.0.6 (2001-05-29)
2822 ------------------------------------------------
2823
2824     * Security fix for a format string bug in the tty code.
2825
2826     * Fixed format string bugs in all PO files.
2827
2828     * Removed Russian translation due to too many bugs.  The FTP
2829       server has an unofficial but better translation in the contrib
2830       directory.
2831
2832     * Fixed expire time calculation and keyserver access.
2833
2834     * The usual set of minor bug fixes and enhancements.
2835
2836     * non-writable keyrings are now correctly handled.
2837
2838     See-also: gnupg-announce/2001q2/000123.html
2839
2840
2841 Noteworthy changes in version 1.0.5 (2001-04-29)
2842 ------------------------------------------------
2843
2844     * WARNING: The semantics of --verify have changed to address a
2845       problem with detached signature detection. --verify now ignores
2846       signed material given on stdin unless this is requested by using
2847       a "-" as the name for the file with the signed material.  Please
2848       check all your detached signature handling applications and make
2849       sure that they don't pipe the signed material to stdin without
2850       using a filename together with "-" on the the command line.
2851
2852     * WARNING: Corrected hash calculation for input data larger than
2853       512M - it was just wrong, so you might notice bad signature in
2854       some very big files.  It may be wise to keep an old copy of
2855       GnuPG around.
2856
2857     * Secret keys are no longer imported unless you use the new option
2858       --allow-secret-key-import.  This is a kludge and future versions will
2859       handle it in another way.
2860
2861     * New command "showpref" in the --edit-key menu to show an easier
2862       to understand preference listing.
2863
2864     * There is now the notation of a primary user ID.  For example, it
2865       is printed with a signature verification as the first user ID;
2866       revoked user IDs are not printed there anymore.  In general the
2867       primary user ID is the one with the latest self-signature.
2868
2869     * New --charset=utf-8 to bypass all internal conversions.
2870
2871     * Large File Support (LFS) is now working.
2872
2873     * New options: --ignore-crc-error, --no-sig-create-check,
2874       --no-sig-cache, --fixed-list-mode, --no-expensive-trust-checks,
2875       --enable-special-filenames and --use-agent.  See man page.
2876
2877     * New command --pipemode, which can be used to run gpg as a
2878       co-process.  Currently only the verification of detached
2879       signatures are working.  See doc/DETAILS.
2880
2881     * Keyserver support for the W32 version.
2882
2883     * Rewritten key selection code so that GnuPG can better cope with
2884       multiple subkeys, expire dates and so.  The drawback is that it
2885       is slower.
2886
2887     * A whole lot of bug fixes.
2888
2889     * The verification status of self-signatures are now cached. To
2890       increase the speed of key list operations for existing keys you
2891       can do the following in your GnuPG homedir (~/.gnupg):
2892          cp pubring.gpg pubring.gpg.save && gpg --export-all >x && \
2893          rm pubring.gpg && gpg --import x
2894       Only v4 keys (i.e not the old RSA keys) benefit from this caching.
2895
2896     * New translations: Estonian, Turkish.
2897
2898     See-also: gnupg-announce/2001q2/000122.html
2899
2900
2901 Noteworthy changes in version 1.0.4 (2000-10-17)
2902 ------------------------------------------------
2903
2904     * Fixed a serious bug which could lead to false signature verification
2905       results when more than one signature is fed to gpg.  This is the
2906       primary reason for releasing this version.
2907
2908     * New utility gpgv which is a stripped down version of gpg to
2909       be used to verify signatures against a list of trusted keys.
2910
2911     * Rijndael (AES) is now supported and listed with top preference.
2912
2913     * --with-colons now works with --print-md[s].
2914
2915     See-also: gnupg-announce/2000q4/000082.html
2916
2917
2918 Noteworthy changes in version 1.0.3 (2000-09-18)
2919 ------------------------------------------------
2920
2921     * Fixed problems with piping to/from other MS-Windows software
2922
2923     * Expiration time of the primary key can be changed again.
2924
2925     * Revoked user IDs are now marked in the output of --list-key
2926
2927     * New options --show-session-key and --override-session-key
2928       to help the British folks to somewhat minimize the danger
2929       of this Orwellian RIP bill.
2930
2931     * New options --merge-only and --try-all-secrets.
2932
2933     * New configuration option --with-egd-socket.
2934
2935     * The --trusted-key option is back after it left us with 0.9.5
2936
2937     * RSA is supported. Key generation does not yet work but will come
2938       soon.
2939
2940     * CAST5 and SHA-1 are now the default algorithms to protect the key
2941       and for symmetric-only encryption. This should solve a couple
2942       of compatibility problems because the old algorithms are optional
2943       according to RFC2440
2944
2945     * Twofish and MDC enhanced encryption is now used.  PGP 7 supports
2946       this.  Older versions of GnuPG don't support it, so they should be
2947       upgraded to at least 1.0.2
2948
2949     See-also: gnupg-announce/2000q3/000075.html
2950
2951
2952 Noteworthy changes in version 1.0.2 (2000-07-12)
2953 ----------------------------------------------
2954
2955     * Fixed expiration handling of encryption keys.
2956
2957     * Add an experimental feature to do unattended key generation.
2958
2959     * The user is now asked for the reason of revocation as required
2960       by the new OpenPGP draft.
2961
2962     * There is a ~/.gnupg/random_seed file now which saves the
2963       state of the internal RNG and increases system performance
2964       somewhat.  This way the full entropy source is only used in
2965       cases were it is really required.
2966       Use the option --no-random-seed-file to disable this feature.
2967
2968     * New options --ignore-time-conflict and --lock-never.
2969
2970     * Some fixes for the W32 version.
2971
2972     * The entropy.dll is not anymore used by the W32 version but replaced
2973       by code derived from Cryptlib.
2974
2975     * Encryption is now much faster: About 2 times for 1k bit keys
2976       and 8 times for 4k keys.
2977
2978     * New encryption keys are generated in a way which allows a much
2979       faster decryption.
2980
2981     * New command --export-secret-subkeys which outputs the
2982       the _primary_ key with it's secret parts deleted.  This is
2983       useful for automated decryption/signature creation as it
2984       allows to keep the real secret primary key offline and
2985       thereby protecting the key certificates and allowing to
2986       create revocations for the subkeys.  See the FAQ for a
2987       procedure to install such secret keys.
2988
2989     * Keygeneration now writes to the first writeable keyring or
2990       as default to the one in the homedirectory.  Prior versions
2991       ignored all --keyring options.
2992
2993     * New option --command-fd to take user input from a file descriptor;
2994       to be used with --status-fd by software which uses GnuPG as a backend.
2995
2996     * There is a new status PROGRESS which is used to show progress during
2997       key generation.
2998
2999     * Support for the new MDC encryption packets.  To create them either
3000       --force-mdc must be use or cipher algorithm with a blocksize other
3001       than 64 bits is to be used.  --openpgp currently disables MDC packets
3002       entirely.  This option should not yet be used.
3003
3004     * New option --no-auto-key-retrieve to disable retrieving of
3005       a missing public key from a keyserver, when a keyserver has been set.
3006
3007     * Danish translation
3008
3009     See-also: gnupg-announce/2000q3/000069.html
3010
3011
3012 Noteworthy changes in version 1.0.1 (1999-12-16)
3013 -----------------------------------
3014
3015     * New command --verify-files.  New option --fast-list-mode.
3016
3017     * $http_proxy is now used when --honor-http-proxy is set.
3018
3019     * Fixed some minor bugs and the problem with conventional encrypted
3020       packets which did use the gpg v3 partial length headers.
3021
3022     * Add Indonesian and Portugese translations.
3023
3024     * Fixed a bug with symmetric-only encryption using the non-default 3DES.
3025       The option --emulate-3des-s2k-bug may be used to decrypt documents
3026       which have been encrypted this way; this should be done immediately
3027       as this workaround will be remove in 1.1
3028
3029     * Can now handle (but not display) PGP's photo IDs. I don't know the
3030       format of that packet but after stripping a few bytes from the start
3031       it looks like a JPEG (at least my test data).  Handling of this
3032       package is required because otherwise it would mix up the
3033       self signatures and you can't import those keys.
3034
3035     * Passing non-ascii user IDs on the commandline should now work in all
3036       cases.
3037
3038     * New keys are now generated with an additional preference to Blowfish.
3039
3040     * Removed the GNU Privacy Handbook from the distribution as it will go
3041       into a separate one.
3042
3043     See-also: gnupg-announce/1999q4/000050.html
3044
3045
3046 Noteworthy changes in version 1.0.0 (1999-09-07)
3047 -----------------------------------
3048
3049     * Add a very preliminary version of the GNU Privacy Handbook to
3050       the distribution (lynx doc/gph/index.html).
3051
3052     * Changed the version number to GnuPG 2001 ;-)
3053
3054     See-also: gnupg-announce/1999q3/000037.html
3055
3056
3057 Noteworthy changes in version 0.9.11 (1999-09-03)
3058 ------------------------------------
3059
3060     * UTF-8 strings are now correctly printed (if --charset is set correctly).
3061       Output of --with-colons remains C-style escaped UTF-8.
3062
3063     * Workaround for a problem with PGP 5 detached signature in textmode.
3064
3065     * Fixed a problem when importing new subkeys (duplicated signatures).
3066
3067     See-also: gnupg-announce/1999q3/000036.html
3068
3069
3070 Noteworthy changes in version 0.9.10 (1999-07-23)
3071 ------------------------------------
3072
3073     * Some strange new options to help pgpgpg
3074
3075     * Cleaned up the dox a bit.
3076
3077     See-also: gnupg-announce/1999q3/000034.html
3078
3079
3080 Noteworthy changes in version 0.9.9
3081 -----------------------------------
3082
3083     * New options --[no-]utf8-strings.
3084
3085     * New edit-menu commands "enable" and "disable" for entire keys.
3086
3087     * You will be asked for a filename if gpg cannot deduce one.
3088
3089     * Changes to support libtool which is needed for the development
3090       of libgcrypt.
3091
3092     * New script tools/lspgpot to help transferring assigned
3093       trustvalues from PGP to GnuPG.
3094
3095     * New commands --lsign-key and made --sign-key a shortcut for --edit
3096       and sign.
3097
3098     * New options (#122--126 ;-) --[no-]default-recipient[-self],
3099       --disable-{cipher,pubkey}-algo. See the man page.
3100
3101     * Enhanced info output in case of multiple recipients and fixed exit code.
3102
3103     * New option --allow-non-selfsigned-uid to work around a problem with
3104       the German IN way of separating signing and encryption keys.
3105
3106     See-also: gnupg-announce/1999q3/000028.html
3107
3108
3109 Noteworthy changes in version 0.9.8 (1999-06-26)
3110 -----------------------------------
3111
3112     * New subcommand "delsig" in the edit menu.
3113
3114     * The name of the output file is not anymore the one which is
3115       embedded in the processed message, but the used filename with
3116       the extension stripped.  To revert to the old behaviour you can
3117       use the option --use-embedded-filename.
3118
3119     * Another hack to cope with pgp2 generated detached signatures.
3120
3121     * latin-2 character set works (--charset=iso-8859-2).
3122
3123     * New option --with-key-data to list the public key parameters.
3124       New option -N to insert notations and a --set-policy-url.
3125       A couple of other options to allow reseting of options.
3126
3127     * Better support for HPUX.
3128
3129     See-also: gnupg-announce/1999q2/000016.html
3130
3131
3132 Noteworthy changes in version 0.9.7 (1999-05-23)
3133 -----------------------------------
3134
3135     * Add some work arounds for a bugs in pgp 2 which led to bad signatures
3136       when used with canonical texts in some cases.
3137
3138     * Enhanced some status outputs.
3139
3140     See-also: gnupg-announce/1999q2/000000.html
3141
3142
3143 Noteworthy changes in version 0.9.6 (1999-05-06)
3144 -----------------------------------
3145
3146     * Twofish is now statically linked by default. The experimental 128 bit
3147       version is now disabled.  Full support will be available as soon as
3148       the OpenPGP WG has decided on an interpretation of rfc2440.
3149
3150     * Dropped support for the ancient Blowfish160 which is not OpenPGP.
3151
3152     * Merged gpgm and gpg into one binary.
3153
3154     * Add "revsig" and "revkey" commands to the edit menu.  It is now
3155       possible to revoke signature and subkeys.
3156
3157
3158 Noteworthy changes in version 0.9.5 (1999-03-20)
3159 -----------------------------------
3160
3161     * New command "lsign" in the keyedit menu to create non-exportable
3162       signatures.  Removed --trusted-keys option.
3163
3164     * A bunch of changes to the key validation code.
3165
3166     * --list-trust-path now has an optional --with-colons format.
3167
3168     * New command --recv-keys to import keys from an keyserver.
3169
3170
3171 Noteworthy changes in version 0.9.4 (1999-03-08)
3172 -----------------------------------
3173
3174     * New configure option --enable-static-rnd=[egd|linux|unix|none]
3175       to select a random gathering module for static linking.
3176
3177     * The original text is now verbatim copied to a cleartext signed message.
3178
3179     * Bugfixes but there are still a couple of bugs.
3180
3181
3182 Noteworthy changes in version 0.9.3 (1999-02-19)
3183 -----------------------------------
3184
3185     * Changed the internal design of getkey which now allows a
3186       efficient lookup of multiple keys and add a word match mode.
3187
3188     * New options --[no-]encrypt-to.
3189
3190     * Some changes to the configure stuff.  Switched to automake 1.4.
3191       Removed intl/ from CVS, autogen.sh now uses gettextize.
3192
3193     * Preferences now include Twofish. Removed preference to Blowfish with
3194       a special hack to suppress the "not listed in preferences" warning;
3195       this is to allow us to switch completely to Twofish in the near future.
3196
3197     * Changed the locking stuff.
3198
3199     * Print all user ids of a good signature.
3200
3201
3202 Noteworthy changes in version 0.9.2 (1999-01-01)
3203 -----------------------------------
3204
3205     * add some additional time warp checks.
3206
3207     * Option --keyserver and command --send-keys to utilize HKP servers.
3208
3209     * Upgraded to zlib 1.1.3 and fixed an inflate bug
3210
3211     * More cleanup on the cleartext signatures.
3212
3213
3214 Noteworthy changes in version 0.9.1 (1999-01-01)
3215 -----------------------------------
3216
3217     * Polish language support.
3218
3219     * When querying the passphrase, the key ID of the primary key is
3220       displayed along with the one of the used secondary key.
3221
3222     * Fixed a bug occurring when decrypting pgp 5 encrypted messages,
3223       fixed an infinite loop bug in the 3DES code and in the code
3224       which looks for trusted signatures.
3225
3226     * Fixed a bug in the mpi library which caused signatures not to
3227       compare okay.
3228
3229     * Rewrote the handling of cleartext signatures; the code is now
3230       better maintainable (I hope so).
3231
3232     * New status output VALIDSIG only for valid signatures together
3233       with the fingerprint of the signer's key.
3234
3235
3236 Noteworthy changes in version 0.9.0 (1998-12-23)
3237 -----------------------------------
3238
3239     * --export does now only exports rfc2440 compatible keys; the
3240       old behaviour is available with --export-all.
3241       Generation of v3 ElGamal (sign and encrypt) keys is not longer
3242       supported.
3243
3244     * Fixed the uncompress bug.
3245
3246     * Rewrote the rndunix module. There are two environment variables
3247       used for debugging now: GNUPG_RNDUNIX_DBG give the file to write
3248       debugging information (use "-" for stdout) and if GNUPG_RNDUNIX_DBGALL
3249       is set, all programs which are only tried are also printed.
3250
3251     * New option --escape-from-lines to "dash-escape" "From " lines to
3252       prevent mailers to change them to ">From ".  This is not enabled by
3253       default because it is not in compliance with rfc2440 - however, you
3254       should turn it on.
3255
3256
3257 Noteworthy changes in version 0.4.5 (1998-12-08)
3258 -----------------------------------
3259
3260     * The keyrings and the trustdb is now locked, so that
3261       other GnuPG processes won't damage these files.  You
3262       may want to put the option --lock-once into your options file.
3263
3264     * The latest self-signatures are now used; this enables --import
3265       to see updated preferences etc.
3266
3267     * Import of subkeys should now work.
3268
3269     * Random gathering modules may now be loaded as extensions. Add
3270       such a module for most Unices but it is very experimental!
3271
3272     * Brazilian language support.
3273
3274
3275 Noteworthy changes in version 0.4.4 (1998-11-20)
3276 -----------------------------------
3277
3278     * Fixed the way the key expiration time is stored. If you have
3279       an expiration time on your key you should fix it with --edit-key
3280       and the command "expire".  I apologize for this inconvenience.
3281
3282     * Add option --charset to support "koi8-r" encoding of user ids.
3283       (Not yet tested).
3284
3285     * Preferences should now work again. You should run
3286       "gpgm --check-trustdb \*" to rebuild all preferences.
3287
3288     * Checking of certificates should now work but this needs a lot
3289       of testing.  Key validation values are now cached in the
3290       trustdb; they should be recalculated as needed, but you may
3291       use --check-trustdb or --update-trustdb to do this.
3292
3293     * Spanish translation by Urko Lusa.
3294
3295     * Patch files are from now on signed.  See the man page
3296       for the new option --not-dash-escaped.
3297
3298     * New syntax: --edit-key <userID> [<commands>]
3299       If you run it without --batch the commands are executed and then
3300       you are put into normal mode unless you use "quit" or "save" as
3301       one of the commands.  When in batch mode, the program quits after
3302       the last command, so you have to use "save" if you did some changes.
3303       It does not yet work completely, but may be used to list so the
3304       keys etc.
3305
3306
3307 Noteworthy changes in version 0.4.3 (1998-11-08)
3308 -----------------------------------
3309
3310     * Fixed the gettext configure bug.
3311
3312     * Kludge for RSA keys: keyid and length of a RSA key are
3313       correctly reported, but you get an error if you try to use
3314       this key (If you do not have the non-US version).
3315
3316     * Experimental support for keyrings stored in a GDBM database.
3317       This is *much* faster than a standard keyring.  You will notice
3318       that the import gets slower with time; the reason is that all
3319       new keys are used to verify signatures of previous inserted
3320       keys.  Use "--keyring gnupg-gdbm:<name-of-gdbm-file>".  This is
3321       not (yet) supported for secret keys.
3322
3323     * A Russian language file in the distribution (alternatives are in
3324       the contrib directory of the FTP servers)
3325
3326     * commandline option processing now works as expected for GNU programs
3327       with the exception that you can't mix options and normal arguments.
3328
3329     * Now --list-key lists all matching keys.  This is needed in some
3330       other places too.
3331
3332
3333 Noteworthy changes in version 0.4.2 (1998-10-18)
3334 -----------------------------------
3335
3336     * This is only a snapshot: There are still a few bugs.
3337
3338     * Fixed this huge memory leak.
3339
3340     * Redesigned the trust database:  You should run "gpgm --check-trustdb".
3341       New command --update-trustdb, which adds new key from the public
3342       keyring into your trustdb
3343
3344     * Fixed a bug in the armor code, leading to invalid packet errors.
3345       (a workaround for this was to use --no-armor).  The shorten line
3346       length (64 instead of 72) fixes a problem with pgp5 and keyservers.
3347
3348     * comment packets are not anymore generated. "--export" filters
3349       them out.  One Exception:  The comment packets in a secret keyring
3350       are still used because they carry the factorization of the public
3351       prime product.
3352
3353     * --import now only looks for KEYBLOCK headers, so you can now simply
3354       remove the "- " in front of such a header if someone accidentally signed
3355       such a message or the keyblock is part of a cleartext signed message.
3356
3357     * --with-colons now lists the key expiration time and not anymore
3358       the valid period.
3359
3360     * Some keyblocks created with old releases have a wrong sequence
3361       of packets, so that the keyservers don't accept these keys.
3362       Simply using "--edit-key" fixes the problem.
3363
3364     * New option --force-v3-sigs to generate signed messages which are
3365       compatible to PGP 5.
3366
3367     * Add some code to support DLD (for non ELF systems) - but this is
3368       not tested because my BSD box is currently broken.
3369
3370     * New command "expire" in the edit-key menu.
3371
3372
3373
3374 Noteworthy changes in version 0.4.1 (1998-10-07)
3375 -----------------------------------
3376
3377     * A secondary key is used when the primary key is specified but cannot
3378       be used for the operation (if it is a sign-only key).
3379
3380     * GNUPG can now handle concatenated armored messages:  There is still a
3381       bug if different kinds of messages are mixed.
3382
3383     * Iterated+Salted passphrases now work.  If want to be sure that PGP5
3384       is able to handle them you may want to use the options
3385         "--s2k-mode 3 --s2k-cipher-algo cast5 --s2k-digest-algo sha1"
3386       when changing a passphrase.
3387
3388     * doc/OpenPGP talks about OpenPGP compliance, doc/HACKING gives
3389       a few hints about the internal structure.
3390
3391     * Checked gnupg against the August 1998 draft (07) and I believe
3392       it is in compliance with this document (except for one point).
3393
3394     * Fixed some bugs in the import merging code and rewrote some
3395       code for the trustdb.
3396
3397
3398 Noteworthy changes in version 0.4.0 (1998-09-18)
3399 -----------------------------------
3400
3401     * Triple DES is now supported.  Michael Roth did this piece of
3402       needed work.  We have now all the coded needed to be OpenPGP
3403       compliant.
3404
3405     * Added a simple rpm spec file (see INSTALL).
3406
3407     * detached and armored signatures are now using "PGP SIGNATURE",
3408       except when --rfc1991 is used.
3409
3410     * All times which are not in the yyyy-mm-dd format are now printed
3411       in local time.
3412
3413
3414 Noteworthy changes in version 0.3.5 (1998-09-14)
3415 -----------------------------------
3416
3417     * New option --throw-keyid to create anonymous enciphered messages.
3418       If gpg detects such a message it tires all available secret keys
3419       in turn so decode it.  This is a gnupg extension and not in OpenPGP
3420       but it has been discussed there and afaik some products use this
3421       scheme too (Suggested by Nimrod Zimmerman).
3422
3423     * Fixed a bug with 5 byte length headers.
3424
3425     * --delete-[secret-]key is now also available in gpgm.
3426
3427     * cleartext signatures are not anymore converted to LF only.
3428
3429     * Fixed a trustdb problem.  Run "gpgm --check-trustdb" to fix old
3430       trust dbs.
3431
3432     * Building in another directory should now work.
3433
3434     * Weak key detection mechanism (Niklas Hernaeus).
3435
3436
3437 Noteworthy changes in version 0.3.4 (1998-08-11)
3438 -----------------------------------
3439
3440     * New options --comment and --set-filename; see g10/OPTIONS
3441
3442     * yes/no, y/n localized.
3443
3444     * Fixed some bugs.
3445
3446
3447 Noteworthy changes in version 0.3.3 (1998-08-08)
3448 -----------------------------------
3449
3450     * IMPORTANT: I found yet another bug in the way the secret keys
3451       are encrypted - I did it the way pgp 2.x did it, but OpenPGP
3452       and pgp 5.x specify another (in some aspects simpler) method.
3453       To convert your secret keys you have to do this:
3454         1. Build the new release but don't install it and keep
3455            a copy of the old program.
3456         2. Disable the network, make sure that you are the only
3457            user, be sure that there are no Trojan horses etc ....
3458         3. Use your old gpg (version 0.3.1 or 0.3.2) and set the
3459            passphrases of ALL your secret keys to empty!
3460            (gpg --change-passphrase your-user-id).
3461         4. Save your ownertrusts (see the next point)
3462         5. rm ~/.gnupg/trustdb.gpg
3463         6. install the new version of gpg (0.3.3)
3464         7. For every secret key call "gpg --edit-key your-user-id",
3465            enter "passwd" at the prompt, follow the instructions and
3466            change your password back, enter "save" to store it.
3467         8. Restore the ownertrust (see next point).
3468
3469     * The format of the trust database has changed; you must delete
3470       the old one, so gnupg can create a new one.
3471       IMPORTANT: Use version 0.3.1 or .2 to save your assigned ownertrusts
3472       ("gpgm --list-ownertrust >saved-trust"); then build this new version
3473       and restore the ownertrust with this new version
3474       ("gpgm --import-ownertrust saved-trust").  Please note that
3475       --list-ownertrust has been renamed to --export-ownertrust in this
3476       release and it does now only export defined ownertrusts.
3477
3478     * The command --edit-key now provides a commandline driven menu
3479       which can be used for various tasks.  --sign-key is only an
3480       an alias to --edit-key and maybe removed in future: use the
3481       command "sign" of this new menu - you can select which user ids
3482       you want to sign.
3483
3484     * Alternate user ids can now be created an signed.
3485
3486     * Owner trust values can now be changed with --edit-key (trust)
3487
3488     * GNUPG can now run as a coprocess; this enables sophisticated
3489       frontends.  tools/shmtest.c is a simple sample implementation.
3490       This needs some more work: all tty_xxx() are to be replaced
3491       by cpr_xxx() and some changes in the display logics is needed.
3492
3493     * Removed options --gen-prime and --gen-random.
3494
3495     * Removed option --add-key; use --edit-key instead.
3496
3497     * Removed option --change-passphrase; use --edit-key instead.
3498
3499     * Signatures are now checked even if the output file could not
3500       be created. Command "--verify" tries to find the detached data.
3501
3502     * gpg now disables core dumps.
3503
3504     * compress and symmetric cipher preferences are now used.
3505       Because there is no 3DES yet, this is replaced by Blowfish.
3506
3507     * We have added the Twofish as an experimental cipher algorithm.
3508       Many thanks to Matthew Skala for doing this work.
3509       Twofish is the AES submission from Schneier et al.; see
3510       "www.counterpane.com/twofish.html" for more information.
3511
3512     * Started with a help system: If you enter a question mark at some
3513       prompt; you should get a specific help for this prompt.
3514
3515     * There is no more backup copy of the secret keyring.
3516
3517     * A lot of new bugs. I think this release is not as stable as
3518       the previous one.
3519
3520
3521 Noteworthy changes in version 0.3.2 (1998-07-09)
3522 -----------------------------------
3523
3524     * Fixed some bugs when using --textmode (-seat)
3525
3526     * Now displays the trust status of a positive verified message.
3527
3528     * Keyrings are now scanned in the sequence they are added with
3529       --[secret-]keyring.  Note that the default keyring is implicitly
3530       added as the very first one unless --no-default-keyring is used.
3531
3532     * Fixed setuid and dlopen bug.
3533
3534
3535 Noteworthy changes in version 0.3.1 (1998-07-06)
3536 -----------------------------------
3537
3538     * Partial headers are now written in the OpenPGP format if
3539       a key in a v4 packet is used.
3540
3541     * Removed some unused options, removed the gnupg.sig stuff.
3542
3543     * Key lookup by name now returns a key which can be used for
3544       the desired action.
3545
3546     * New options --list-ownertrust (gpgm) to make a backup copy
3547       of the ownertrust values you assigned.
3548
3549     * clear signature headers are now in compliance with OpenPGP.
3550
3551
3552 Noteworthy changes in version 0.3.0 (1998-06-25)
3553 -----------------------------------
3554
3555     * New option --emulate-checksum-bug.  If your passphrase does not
3556       work anymore, use this option and --change-passphrase to rewrite
3557       your passphrase.
3558
3559     * More complete v4 key support: Preferences and expiration time
3560       is set into the self signature.
3561
3562     * Key generation defaults to DSA/ElGamal keys, so that new keys are
3563       interoperable with pgp5
3564
3565     * DSA key generation is faster and key generation does not anymore
3566       remove entropy from the random generator (the primes are public
3567       parameters, so there is really no need for a cryptographic secure
3568       prime number generator which we had used).
3569
3570     * A complete new structure for representing the key parameters.
3571
3572     * Removed most public key knowledge into the cipher library.
3573
3574     * Support for dynamic loading of new algorithms.
3575
3576     * Moved tiger to an extension module.
3577
3578
3579 Noteworthy changes in version 0.2.19 (1998-05-29)
3580 ------------------------------------
3581
3582     * Replaced /dev/urandom in checks with new tool mk-tdata.
3583
3584     * Some assembler file cleanups; some more functions for the Alpha.
3585
3586     * Tiger has now the OpenPGP assigned number 6.  Because the OID has
3587       changed, old signatures using this algorithm can't be verified.
3588
3589     * gnupg now encrypts the compressed packed and not any longer in the
3590       reverse order; anyway it can decrypt both versions. Thanks to Tom
3591       for telling me this (not security related) bug.
3592
3593     * --add-key works and you are now able to generate subkeys.
3594
3595     * It is now possible to generate ElGamal keys in v4 packets to create
3596       valid OpenPGP keys.
3597
3598     * Some new features for better integration into MUAs.
3599
3600
3601 Noteworthy changes in version 0.2.18 (1998-05-15)
3602 ------------------------------------
3603
3604     * Splitted cipher/random.c, add new option "--disable-dev-random"
3605       to configure to support the development of a random source for
3606       other systems. Prepared sourcefiles rand-unix.c, rand-w32.c
3607       and rand-dummy.c (which is used to allow compilation on systems
3608       without a random source).
3609
3610     * Fixed a small bug in the key generation (it was possible that 48 bits
3611       of a key were not taken from the random pool)
3612
3613     * Add key generation for DSA and v4 signatures.
3614
3615     * Add a function trap_unaligned(), so that a SIGBUS is issued on
3616       Alphas and not the slow emulation code is used. And success: rmd160
3617       raised a SIGBUS.
3618
3619     * Enhanced the formatting facility of argparse and changed the use of
3620       \r,\v to @ because gettext does not like it.
3621
3622     * New option "--compress-algo 1" to allow the creation of compressed
3623       messages which are readable by PGP and "--print-md" (gpgm) to make
3624       speed measurement easier.
3625
3626
3627 Noteworthy changes in version 0.2.17 (1998-05-04)
3628 ------------------------------------
3629
3630     * Comment packets are now of private type 61.
3631
3632     * Passphrase code still used a 160 bit blowfish key, added a
3633       silly workaround. Please change your passphrase again - sorry.
3634
3635     * Conventional encryption now uses a type 3 packet to describe the
3636       used algorithms.
3637
3638     * The new algorithm number for Blowfish is 20, 16 is still used for
3639       encryption only; for signing it is only used when it is in a v3 packet,
3640       so that GNUPG keys are still valid.
3641
3642
3643 Noteworthy changes in version 0.2.16 (1998-04-28)
3644 ------------------------------------
3645
3646     * Add experimental support for the TIGER/192 message digest algorithm.
3647       (But there is only a dummy ASN OID).
3648
3649     * Standard cipher is now Blowfish with 128 bit key in OpenPGP's CFB
3650       mode. I renamed the old cipher to Blowfish160. Because the OpenPGP
3651       group refused to assign me a number for Blowfish160, I have to
3652       drop support for this in the future. You should use
3653       "--change-passphrase" to recode your current passphrase with 128
3654       bit Blowfish.
3655
3656
3657 Noteworthy changes in version 0.2.15 (1998-04-09)
3658 ------------------------------------
3659
3660     * Fixed a bug with the old checksum calculation for secret keys.
3661       If you run the program without --batch, a warning does inform
3662       you if your secret key needs to be converted; simply use
3663       --change-passphrase to recalculate the checksum. Please do this
3664       soon, as the compatible mode will be removed sometime in the future.
3665
3666     * CAST5 works (using the PGP's special CFB mode).
3667
3668     * Again somewhat more PGP 5 compatible.
3669
3670     * Some new test cases
3671
3672 Noteworthy changes in version 0.2.14 (1998-04-02)
3673 ------------------------------------
3674
3675     * Changed the internal handling of keyrings.
3676
3677     * Add support to list PGP 5 keyrings with subkeys
3678
3679     * Timestamps of signatures are now verified.
3680
3681     * A expiration time can now be specified during key generation.
3682
3683     * Some speedups for Blowfish and SHA-1, rewrote SHA-1 transform.
3684       Reduced the amount of random bytes needed for key generation in
3685       some cases.
3686
3687
3688 Noteworthy changes in version 0.2.13 (1998-03-10)
3689 ------------------------------------
3690
3691     * Verify of DSA signatures works.
3692
3693     * Re-implemented the slower random number generator.
3694
3695
3696 Noteworthy changes in version 0.2.12 (1998-03-07)
3697 ------------------------------------
3698
3699     * --delete-key checks that there is no secret key. The new
3700       option --delete-secret-key maybe used to delete a secret key.
3701
3702     * "-kv" now works as expected. Options "--list-{keys,sigs]"
3703       and "--check-sigs" are now working.
3704
3705     * New options "--verify" and "--decrypt" to better support integration
3706       into MUAs (partly done for Mutt).
3707
3708     * New option "--with-colons" to make parsing of key lists easier.
3709
3710 Noteworthy changes in version 0.2.11 (1998-03-02)
3711 ------------------------------------
3712
3713     * GPG now asks for a recipient's name if option "-r" is not used.
3714
3715     * If there is no good trust path, the program asks whether to use
3716       the public keys anyway.
3717
3718     * "--delete-key" works for public keys. What semantics shall I use
3719       when there is a secret key too? Delete the secret key or leave him
3720       and auto-regenerate the public key, next time the secret key is used?
3721
3722 Noteworthy changes in version 0.2.10 (1998-02-27)
3723 ------------------------------------
3724
3725     * Code for the alpha is much faster (about 20 times); the data
3726       was misaligned and the kernel traps this, so nearly all time
3727       was used by system to trap the misalignments and to write
3728       syslog messages. Shame on me and thanks to Ralph for
3729       pointing me at this while drinking some beer yesterday.
3730
3731     * Changed some configure options and add an option
3732       --disable-m-guard to remove the memory checking code
3733       and to compile everything with optimization on.
3734
3735     * New environment variable GNUPGHOME, which can be used to set
3736       another homedir than ~/.gnupg.  Changed default homedir for
3737       Windoze version to c:/gnupg.
3738
3739     * Fixed detached signatures; detached PGP signatures caused a SEGV.
3740
3741     * The Windoze version works (as usual w/o a strong RNG).
3742
3743
3744 Noteworthy changes in version 0.2.9 (1998-02-26)
3745 -----------------------------------
3746
3747     * Fixed FreeBSD bug.
3748
3749     * Added a simple man page.
3750
3751     * Switched to automake1.2f and a newer gettext.
3752
3753 Noteworthy changes in version 0.2.8 (1998-02-24)
3754 -----------------------------------
3755
3756     * Changed the name to GNUPG, the binaries are called gpg and gpgm.
3757       You must rename rename the directory "~/.g10" to ~/.gnupg/, rename
3758       {pub,sec}ring.g10 to {pub,sec}ring.gpg, trustdb.g10 to trustdb.gpg
3759       and g10.sig to gnupg.sig.
3760
3761     * New or changed passphrases are now salted.
3762
3763
3764 Noteworthy changes in version 0.2.7 (1998-02-18)
3765 -----------------------------------
3766
3767     * New command "gen-revoke" to create a key revocation certificate.
3768
3769     * New option "homedir" to set the homedir (which defaults to "~/.g10").
3770       This directory is created if it does not exists (only the last
3771       part of the name and not the complete hierarchy)
3772
3773     * Command "import" works. (Try: "finger gcrypt@ftp.guug.de|g10 --import")
3774
3775     * New commands "dearmor/enarmor" for g10maint.  These are mainly
3776       used for internal test purposes.
3777
3778     * Option --version now conforming to the GNU standards and lists
3779       the available ciphers, message digests and public key algorithms.
3780
3781     * Assembler code for m68k (not tested).
3782
3783     * "make check" works.
3784
3785 Noteworthy changes in version 0.2.6 (1998-02-13)
3786 -----------------------------------
3787
3788     * Option "--export" works.
3789
3790
3791 Noteworthy changes in version 0.2.5 (1998-02-12)
3792 -----------------------------------
3793
3794     * Added zlib for systems which don't have it.
3795       Use "./configure --with-zlib" to link with the static version.
3796
3797     * Generalized some more functions and rewrote the encoding of
3798       message digests into MPIs.
3799
3800     * Enhanced the checkit script
3801
3802
3803 Noteworthy changes in version 0.2.4 (1998-02-11)
3804 -----------------------------------
3805
3806     * nearly doubled the speed of the ElGamal signature verification.
3807
3808     * backup copies of keyrings are created.
3809
3810     * assembler stuff for Pentium; gives about 15% better performance.
3811
3812     * fixed a lot of bugs.
3813
3814
3815 Noteworthy changes in version 0.2.3 (1998-02-09)
3816 -----------------------------------
3817
3818     * Found a bug in the calculation of ELG fingerprints. This is now
3819       fixed, but all existing fingerprints and keyids for ELG keys
3820       are not any more valid.
3821
3822     * armor should now work; including clear signed text.
3823
3824     * moved some options to the new program g10maint
3825
3826     * It's now 64 bit clean and runs fine on an alpha--linux.
3827
3828     * Key generation is much faster now.  I fixed this by using not
3829       so strong random number for the primes (this was a bug because the
3830       ElGamal primes are public parameters and it does not make sense
3831       to generate them from strong random).  The real secret is the x value
3832       which is still generated from strong (okay: /dev/random) random bits.
3833
3834     * added option "--status-fd": see g10/OPTIONS
3835
3836     * We have secure memory on systems which support mlock().
3837       It is not complete yet, because we do not have signal handler
3838       which does a cleanup in very case.
3839       We should also check the ulimit for the user in the case
3840       that the admin does not have set a limit on locked pages.
3841
3842     * started with internationalization support.
3843
3844     * The logic to handle the web of trust is now implemented. It is
3845       has some bugs; but I'm going to change the algorithm anyway.
3846       It works by calculating the trustlevel on the fly.  It may ask
3847       you to provide trust parameters if the calculated trust probability
3848       is too low.  I will write a paper which discusses this new approach.
3849
3850     * a couple of changes to the configure script.
3851
3852     * New option "--quick-random" which uses a much quicker random
3853       number generator.  Keys generated while this option is in effect
3854       are flags with "INSECURE!" in the user-id.  This is a development
3855       only option.
3856
3857     * Read support for new version packets (OpenPGP).
3858
3859     * Comment packets are now of correct OpenPGP type 16. Old comment
3860       packets written by G10 are detected because they always start with
3861       a hash which is an invalid version byte.
3862
3863     * The string "(INSECURE!)" is appended to a new user-id if this
3864       is generated on a system without a good random number generator.
3865
3866
3867 Version 0.2.2 (1998-02-09)
3868 Version 0.2.1 (1998-01-28)
3869 Version 0.2.0 (1998-01-25)
3870 Version 0.1.3 (1998-01-12)
3871 Version 0.1.2 (1998-01-07)
3872 Version 0.1.1 (1998-01-07)
3873 Version 0.1.0 (1998-01-05)
3874 Version 0.0.0 (1997-12-20)
3875
3876
3877  Copyright (C) 1998-2017 Free Software Foundation, Inc.
3878  Copyright (C) 1997-2017 Werner Koch
3879
3880  This file is free software; as a special exception the author gives
3881  unlimited permission to copy and/or distribute it, with or without
3882  modifications, as long as this notice is preserved.
3883
3884  This file is distributed in the hope that it will be useful, but
3885  WITHOUT ANY WARRANTY, to the extent permitted by law; without even the
3886  implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.