Fix a gpg2 problem with removed cards.
[gnupg.git] / NEWS
1 Noteworthy changes in version 2.0.11 (unreleased)
2 -------------------------------------------------
3
4  * Fixed a problem in SCDAEMON which caused unexpected card resets.
5
6  * SCDAEMON is now aware of the Geldkarte.
7
8  * The SCDAEMON option --allow-admin is now used by default.
9
10  * The default cipher algorithm in GPGSM is now again 3DES.  This is
11    due to interoperability problems with Outlook 2003 which still
12    can't cope with AES.
13
14
15 Noteworthy changes in version 2.0.10 (2009-01-12)
16 -------------------------------------------------
17
18  * [gpg] New keyserver helper gpg2keys_kdns as generic DNS CERT
19    lookup.  Run with --help for a short description.  Requires the
20    ADNS library.
21
22  * [gpg] New mechanisms "local" and "nodefault" for --auto-key-locate.
23    Fixed a few problems with this option.
24
25  * [gpg] New command --locate-keys.
26
27  * [gpg] New options --with-sig-list and --with-sig-check.
28
29  * [gpg] The option "-sat" is no longer an alias for --clearsign.
30
31  * [gpg] The option --fixed-list-mode is now implicitly used and obsolete.
32
33  * [gpg] New control statement %ask-passphrase for the unattended key
34    generation.
35
36  * [gpg] The algorithm to compute the SIG_ID status has been changed.
37
38  * [gpgsm] Now uses AES by default.
39
40  * [gpgsm] Made --output option work with --export-secret-key-p12.
41
42  * [gpg-agent] Terminate process if the own listening socket is not
43    anymore served by ourself.
44
45  * [scdaemon] Made it more robust on W32.
46
47  * [gpg-connect-agent] Accept commands given as command line arguments.
48
49  * [w32] Initialized the socket subsystem for all keyserver helpers.
50
51  * [w32] The sysconf directory has been moved from a subdirectory of
52    the installation directory to %CSIDL_COMMON_APPDATA%/GNU/etc/gnupg.
53
54  * [w32] The gnupg2.nls directory is not anymore used.  The standard
55    locale directory is now used.  
56
57  * [w32] Fixed a race condition between gpg and gpgsm in the use of
58    temporary file names.
59
60  * The gpg-preset-passphrase mechanism works again.  An arbitrary
61    string may now be used for a custom cache ID.
62
63  * Admin PINs are cached again (bug in 2.0.9).
64
65  * Support for version 2 OpenPGP cards.
66
67  * Libgcrypt 1.4 is now required.
68
69
70 Noteworthy changes in version 2.0.9 (2008-03-26)
71 ------------------------------------------------
72
73  * Gpgsm always tries to locate missing certificates from a running
74    Dirmngr's cache.
75
76  * Tweaks for Windows.
77
78  * The Admin PIN for OpenPGP cards may now be entered with the pinpad.
79
80  * Improved certificate chain construction.
81
82  * Extended the PKITS framework.
83
84  * Fixed a bug in the ambigious name detection.
85
86  * Fixed possible memory corruption while importing OpenPGP keys (bug
87    introduced with 2.0.8). [CVE-2008-1530]
88
89  * Minor bug fixes.
90
91
92 Noteworthy changes in version 2.0.8 (2007-12-20)
93 ------------------------------------------------
94
95  * Enhanced gpg-connect-agent with a small scripting language.
96
97  * New option --list-config for gpgconf.
98
99  * Fixed a crash in gpgconf.
100
101  * Gpg-agent now supports the passphrase quality bar of the latest
102    Pinentry.
103
104  * The envvars XAUTHORITY and PINENTRY_USER_DATA are now passed to the
105    Pinentry.
106
107  * Fixed the auto creation of the key stub for smartcards.  
108
109  * Fixed a rare bug in decryption using the OpenPGP card.
110
111  * Creating DSA2 keys is now possible.
112
113  * New option --extra-digest-algo for gpgsm to allow verification of
114    broken signatures.
115
116  * Allow encryption with legacy Elgamal sign+encrypt keys with option
117    --rfc2440.
118
119  * Windows is now a supported platform.
120
121  * Made sure that under Windows the file permissions of the socket are
122    taken into account.  This required a change of our socket emulation
123    code and changed the IPC protocol under Windows.
124
125
126 Noteworthy changes in version 2.0.7 (2007-09-10)
127 ------------------------------------------------
128
129  * Fixed encryption problem if duplicate certificates are in the
130    keybox.
131
132  * Made it work on Windows Vista.  Note that the entire Windows port
133    is still considered Beta.
134
135  * Add new options min-passphrase-nonalpha, check-passphrase-pattern,
136    enforce-passphrase-constraints and max-passphrase-days to
137    gpg-agent.
138
139  * Add command --check-components to gpgconf.  Gpgconf now uses the
140    installed versions of the programs and does not anymore search via
141    PATH for them.
142
143
144 Noteworthy changes in version 2.0.6 (2007-08-16)
145 ------------------------------------------------
146
147  * GPGSM does now grok --default-key.
148
149  * GPGCONF is now aware of --default-key and --encrypt-to. 
150
151  * GPGSM does again correctly print the serial number as well the the
152    various keyids.  This was broken since 2.0.4.
153
154  * New option --validation-model and support for the chain-model.
155
156  * Improved Windows support.
157
158  
159 Noteworthy changes in version 2.0.5 (2007-07-05)
160 ------------------------------------------------
161
162  * Switched license to GPLv3.
163
164  * Basic support for Windows.  Run "./autogen.sh --build-w32" to build
165    it.  As usual the mingw cross compiling toolchain is required.
166
167  * Fixed bug when using the --p12-charset without --armor.
168
169  * The command --gen-key may now be used instead of the
170    gpgsm-gencert.sh script.
171
172  * Changed key generation to reveal less information about the
173    machine.  Bug fixes for gpg2's card key generation.
174
175
176 Noteworthy changes in version 2.0.4 (2007-05-09)
177 ------------------------------------------------
178
179  * The server mode key listing commands are now also working for
180    systems without the funopen/fopencookie API.
181
182  * PKCS#12 import now tries several encodings in case the passphrase
183    was not utf-8 encoded.  New option --p12-charset for gpgsm.
184
185  * Improved the libgcrypt logging support in all modules.
186
187
188 Noteworthy changes in version 2.0.3 (2007-03-08)
189 ------------------------------------------------
190
191  * By default, do not allow processing multiple plaintexts in a single
192    stream.  Many programs that called GnuPG were assuming that GnuPG
193    did not permit this, and were thus not using the plaintext boundary
194    status tags that GnuPG provides.  This change makes GnuPG reject
195    such messages by default which makes those programs safe again.
196    --allow-multiple-messages returns to the old behavior. [CVE-2007-1263].
197
198  * New --verify-option show-primary-uid-only. 
199
200  * gpgconf may now reads a global configuration file to select which
201    options are changeable by a frontend.  The new applygnupgdefaults
202    tool may be used by an admin to set default options for all users.
203
204  * The PIN pad of the Cherry XX44 keyboard is now supported.  The
205    DINSIG and the NKS applications are now also aware of PIN pads.
206
207
208 Noteworthy changes in version 2.0.2 (2007-01-31)
209 ------------------------------------------------
210
211  * Fixed a serious and exploitable bug in processing encrypted
212    packages. [CVE-2006-6235].
213
214  * Added --passphrase-repeat to set the number of times GPG will
215    prompt for a new passphrase to be repeated.  This is useful to help
216    memorize a new passphrase.  The default is 1 repetition.
217
218  * Using a PIN pad does now also work for the signing key.
219
220  * A warning is displayed by gpg-agent if a new passphrase is too
221    short.  New option --min-passphrase-len defaults to 8.
222
223  * The status code BEGIN_SIGNING now shows the used hash algorithms.
224
225
226 Noteworthy changes in version 2.0.1 (2006-11-28)
227 ------------------------------------------------
228
229  * Experimental support for the PIN pads of the SPR 532 and the Kaan
230    Advanced card readers.  Add "disable-keypad" scdaemon.conf if you
231    don't want it.  Does currently only work for the OpenPGP card and
232    its authentication and decrypt keys.
233
234  * Fixed build problems on some some platforms and crashes on amd64.
235
236  * Fixed a buffer overflow in gpg2. [bug#728,CVE-2006-6169]
237
238
239 Noteworthy changes in version 2.0.0 (2006-11-11)
240 ------------------------------------------------
241
242  * First stable version of a GnuPG integrating OpenPGP and S/MIME.
243
244
245 Noteworthy changes in version 1.9.95 (2006-11-06)
246 -------------------------------------------------
247
248  * Minor bug fixes.
249
250
251 Noteworthy changes in version 1.9.94 (2006-10-24)
252 -------------------------------------------------
253
254  * Keys for gpgsm may now be specified using a keygrip.  A keygrip is
255    indicated by a prefixing it with an ampersand.
256
257  * gpgconf now supports switching the CMS cipher algo (e.g. to AES).
258
259  * New command --gpgconf-test for all major tools. This may be used to
260    check whether the configuration file is sane.
261
262
263 Noteworthy changes in version 1.9.93 (2006-10-18)
264 -------------------------------------------------
265
266  * In --with-validation mode gpgsm will now also ask whether a root
267    certificate should be trusted.
268
269  * Link to Pth only if really necessary.
270
271  * Fixed a pubring corruption bug in gpg2 occurring when importing
272    signatures or keys with insane lengths.
273
274  * Fixed v3 keyID calculation bug in gpg2.
275
276  * More tweaks for certificates without extensions.
277
278
279 Noteworthy changes in version 1.9.92 (2006-10-11)
280 -------------------------------------------------
281
282  * Bug fixes.
283
284
285 Noteworthy changes in version 1.9.91 (2006-10-04)
286 -------------------------------------------------
287
288  * New "relax" flag for trustlist.txt to allow root CA certificates
289    without BasicContraints.
290
291  * [gpg2] Removed the -k PGP 2 compatibility hack.  -k is now an
292    alias for --list-keys.
293
294  * [gpg2] Print a warning if "-sat" is used instead of "--clearsign".
295
296
297 Noteworthy changes in version 1.9.90 (2006-09-25)
298 -------------------------------------------------
299
300  * Made readline work for gpg.
301
302  * Cleanups und minor bug fixes.
303
304  * Included translations from gnupg 1.4.5.
305
306
307 Noteworthy changes in version 1.9.23 (2006-09-18)
308 -------------------------------------------------
309
310  * Regular man pages for most tools are now build directly from the
311    Texinfo source.
312
313  * The gpg code from 1.4.5 has been fully merged into this release.
314    The configure option --enable-gpg is still required to build this
315    gpg part.  For production use of OpenPGP the gpg version 1.4.5 is
316    still recommended.  Note, that gpg will be installed under the name
317    gpg2 to allow coexisting with an 1.4.x gpg.
318
319  * API change in gpg-agent's pkdecrypt command.  Thus an older gpgsm
320    may not be used with the current gpg-agent.
321
322  * The scdaemon will now call a script on reader status changes.
323
324  * gpgsm now allows file descriptor passing for "INPUT", "OUTPUT" and
325    "MESSAGE".
326
327  * The gpgsm server may now output a key listing to the output file
328    handle. This needs to be enabled using "OPTION list-to-output=1".
329
330  * The --output option of gpgsm has now an effect on list-keys.
331
332  * New gpgsm commands --dump-chain and list-chain.
333
334  * gpg-connect-agent has new options to utilize descriptor passing.
335
336  * A global trustlist may now be used.  See doc/examples/trustlist.txt.
337
338  * When creating a new pubring.kbx keybox common certificates are
339    imported.
340
341
342 Noteworthy changes in version 1.9.22 (2006-07-27)
343 -------------------------------------------------
344
345  * Enhanced pkcs#12 support to allow import from simple keyBags.
346
347  * Exporting to pkcs#12 now create bag attributes so that Mozilla is
348    able to import the files.
349
350  * Fixed uploading of certain keys to the smart card.
351
352
353 Noteworthy changes in version 1.9.21 (2006-06-20)
354 -------------------------------------------------
355
356  * New command APDU for scdaemon to allow using it for general card
357    access.  Might be used through gpg-connect-agent by using the SCD
358    prefix command.
359
360  * Support for the CardMan 4040 PCMCIA reader (Linux 2.6.15 required).
361
362  * Scdaemon does not anymore reset cards at the end of a connection. 
363
364  * Kludge to allow use of Bundesnetzagentur issued X.509 certificates.
365
366  * Added --hash=xxx option to scdaemon's PKSIGN command.
367
368  * Pkcs#12 files are now created with a MAC.  This is for better
369    interoperability.
370
371  * Collected bug fixes and minor other changes.
372
373
374 Noteworthy changes in version 1.9.20 (2005-12-20)
375 -------------------------------------------------
376
377  * Importing pkcs#12 files created be recent versions of Mozilla works
378    again.
379
380  * Basic support for qualified signatures.
381
382  * New debug tool gpgparsemail. 
383
384
385 Noteworthy changes in version 1.9.19 (2005-09-12)
386 -------------------------------------------------
387
388  * The Belgian eID card is now supported for signatures and ssh.
389    Other pkcs#15 cards should work as well.
390
391  * Fixed bug in --export-secret-key-p12 so that certificates are again
392    included.
393
394
395 Noteworthy changes in version 1.9.18 (2005-08-01)
396 -------------------------------------------------
397
398  * [gpgsm] Now allows for more than one email address as well as URIs
399    and dnsNames in certificate request generation.  A keygrip may be
400    given to create a request from an existing key.
401
402  * A couple of minor bug fixes.
403
404
405 Noteworthy changes in version 1.9.17 (2005-06-20)
406 -------------------------------------------------
407
408  * gpg-connect-agent has now features to handle Assuan INQUIRE
409    commands.
410
411  * Internal changes for OpenPGP cards. New Assuan command WRITEKEY.
412
413  * GNU Pth is now a hard requirement.
414
415  * [scdaemon] Support for OpenSC has been removed.  Instead a new and
416    straightforward pkcs#15 modules has been written.  As of now it
417    does allows only signing using TCOS cards but we are going to
418    enhance it to match all the old capabilities.
419
420  * [gpg-agent] New option --write-env-file and Assuan command
421    UPDATESTARTUPTTY.
422
423  * [gpg-agent] New option --default-cache-ttl-ssh to set the TTL for
424    SSH passphrase caching independent from the other passphrases.
425
426
427 Noteworthy changes in version 1.9.16 (2005-04-21)
428 -------------------------------------------------
429
430  * gpg-agent does now support the ssh-agent protocol and thus allows
431    to use the pinentry as well as the OpenPGP smartcard with ssh.
432
433  * New tool gpg-connect-agent as a general client for the gpg-agent.
434
435  * New tool symcryptrun as a wrapper for certain encryption tools.
436
437  * The gpg tool is not anymore build by default because those gpg
438    versions available in the gnupg 1.4 series are far more matured.
439
440
441 Noteworthy changes in version 1.9.15 (2005-01-13)
442 -------------------------------------------------
443
444  * Fixed passphrase caching bug.
445
446  * Better support for CCID readers; the reader from Cherry RS 6700 USB
447    does now work.
448
449
450 Noteworthy changes in version 1.9.14 (2004-12-22)
451 -------------------------------------------------
452
453  * [gpg-agent] New option --use-standard-socket to allow the use of a
454    fixed socket.  gpgsm falls back to this socket if GPG_AGENT_INFO
455    has not been set.
456
457  * Ported to MS Windows with some functional limitations.
458
459  * New tool gpg-preset-passphrase.
460
461
462 Noteworthy changes in version 1.9.13 (2004-12-03)
463 -------------------------------------------------
464
465  * [gpgsm] New option --prefer-system-dirmngr.
466
467  * Minor cleanups and debugging aids.
468
469
470 Noteworthy changes in version 1.9.12 (2004-10-22)
471 -------------------------------------------------
472
473  * [scdaemon] Partly rewrote the PC/SC code.
474
475  * Removed the sc-investigate tool.  It is now in a separate package
476    available at ftp://ftp.g10code.com/g10code/gscutils/ .
477
478  * [gpg-agent] Fixed logging problem.
479
480
481 Noteworthy changes in version 1.9.11 (2004-10-01)
482 -------------------------------------------------
483
484  * When using --import along with --with-validation, the imported
485    certificates are validated and only imported if they are fully
486    valid.
487
488  * [gpg-agent] New option --max-cache-ttl.
489
490  * [gpg-agent] When used without --daemon or --server, gpg-agent now
491    check whether a agent is already running and usable.
492
493  * Fixed some i18n problems.
494
495
496 Noteworthy changes in version 1.9.10 (2004-07-22)
497 -------------------------------------------------
498
499  * Fixed a serious bug in the checking of trusted root certificates.
500
501  * New configure option --enable-agent-pnly allows to build and
502    install just the agent.
503
504  * Fixed a problem with the log file handling.
505
506
507 Noteworthy changes in version 1.9.9 (2004-06-08)
508 ------------------------------------------------
509
510  * [gpg-agent] The new option --allow-mark-trusted is now required to
511    allow gpg-agent to add a key to the trustlist.txt after user
512    confirmation.
513
514  * Creating PKCS#10 requests does now honor the key usage.
515
516
517 Noteworthy changes in version 1.9.8 (2004-04-29)
518 ------------------------------------------------
519
520  * [scdaemon] Overhauled the internal CCID driver.
521
522  * [scdaemon] Status files named ~/.gnupg/reader_<n>.status are now
523    written when using the internal CCID driver.
524
525  * [gpgsm] New commands --dump-{,secret,external}-keys to show a very
526    detailed view of the certificates.
527
528  * The keybox gets now compressed after 3 hours and ephemeral
529    stored certificates are deleted after about a day.
530
531  * [gpg] Usability fixes for --card-edit.  Note, that this has already
532    been ported back to gnupg-1.3
533
534
535 Noteworthy changes in version 1.9.7 (2004-04-06)
536 ------------------------------------------------
537
538  * Instrumented the modules for gpgconf.
539
540  * Added support for DINSIG card applications.
541
542  * Include the smimeCapabilities attribute with signed messages.
543
544  * Now uses the gettext domain "gnupg2" to avoid conflicts with gnupg
545    versions < 1.9.
546
547
548 Noteworthy changes in version 1.9.6 (2004-03-06)
549 ------------------------------------------------
550
551  * Code cleanups and bug fixes.
552
553
554 Noteworthy changes in version 1.9.5 (2004-02-21)
555 ------------------------------------------------
556
557  * gpg-protect-tool gets now installed into libexec as it ought to be.
558    Cleaned up the build system to better comply with the coding
559    standards.
560
561  * [gpgsm] The --import command is now able to autodetect pkcs#12
562    files and import secret and private keys from this file format.
563    A new command --export-secret-key-p12 is provided to allow
564    exporting of secret keys in PKCS\#12 format.
565
566  * [gpgsm] The pinentry will now present a description of the key for
567    whom the passphrase is requested.
568
569  * [gpgsm] New option --with-validation to check the validity of key
570    while listing it.
571
572  * New option --debug-level={none,basic,advanced,expert,guru} to map
573    the debug flags to sensitive levels on a per program base.
574
575
576 Noteworthy changes in version 1.9.4 (2004-01-30)
577 ------------------------------------------------
578
579  * Added support for the Telesec NKS 2.0 card application.
580
581  * Added simple tool addgnupghome to create .gnupg directories from
582    /etc/skel/.gnupg.
583
584  * Various minor bug fixes and cleanups; mainly gpgsm and gpg-agent
585    related.
586
587
588 Noteworthy changes in version 1.9.3 (2003-12-23)
589 ------------------------------------------------
590
591  * New gpgsm options --{enable,disable}-ocsp to validate keys using
592    OCSP. This option requires a not yet released DirMngr version.
593    Default is disabled.
594
595  * The --log-file option may now be used to print logs to a socket.
596    Prefix the socket name with "socket://" to enable this.  This does
597    not work on all systems and falls back to stderr if there is a
598    problem with the socket.
599
600  * The options --encrypt-to and --no-encrypt-to now work the same in
601    gpgsm as in gpg.  Note, they are also used in server mode.
602
603  * Duplicated recipients are now silently removed in gpgsm.
604
605
606 Noteworthy changes in version 1.9.2 (2003-11-17)
607 ------------------------------------------------
608
609  * On card key generation is no longer done using the --gen-key
610    command but from the menu provided by the new --card-edit command.
611
612  * PINs are now properly cached and there are only 2 PINs visible.
613    The 3rd PIN (CHV2) is internally syncronized with the regular PIN.
614
615  * All kind of other internal stuff.
616
617
618 Noteworthy changes in version 1.9.1 (2003-09-06)
619 ------------------------------------------------
620
621  * Support for OpenSC is back. scdaemon supports a --disable-opensc to
622    disable OpenSC use at runtime, so that PC/SC or ct-API can still be
623    used directly.
624
625  * Rudimentary support for the SCR335 smartcard reader using an
626    internal driver.  Requires current libusb from CVS.
627
628  * Bug fixes.
629
630
631 Noteworthy changes in version 1.9.0 (2003-08-05)
632 ------------------------------------------------
633
634       ====== PLEASE SEE README-alpha =======
635
636  * gpg has been renamed to gpg2 and gpgv to gpgv2.  This is a
637    temporary change to allow co-existing with stable gpg versions.
638
639  * ~/.gnupg/gpg.conf-1.9.0 is fist tried as config file before the
640    usual gpg.conf.
641
642  * Removed the -k, -kv and -kvv commands.  -k is now an alias to
643    --list-keys.  New command -K as alias for --list-secret-keys.
644
645  * Removed --run-as-shm-coprocess feature.
646
647  * gpg does now also use libgcrypt, libgpg-error is required.
648
649  * New gpgsm commands --call-dirmngr and --call-protect-tool.
650
651  * Changing a passphrase is now possible using "gpgsm --passwd"
652
653  * The content-type attribute is now recognized and created.
654
655  * The agent does now reread certain options on receiving a HUP.
656
657  * The pinentry is now forked for each request so that clients with
658    different environments are supported.  When running in daemon mode
659    and --keep-display is not used the DISPLAY variable is ignored.
660
661  * Merged stuff from the newpg branch and started this new
662    development branch.
663
664
665  Copyright 2002, 2003, 2004, 2005, 2006, 2007,
666            2008, 2009  Free Software Foundation, Inc.
667
668  This file is free software; as a special exception the author gives
669  unlimited permission to copy and/or distribute it, with or without
670  modifications, as long as this notice is preserved.
671
672  This file is distributed in the hope that it will be useful, but
673  WITHOUT ANY WARRANTY, to the extent permitted by law; without even the
674  implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.