2005-03-29 Moritz Schulte <moritz@g10code.com>
[gnupg.git] / scd / ChangeLog
1 2005-03-29  Moritz Schulte  <moritz@g10code.com>
2
3         * app-openpgp.c (retrieve_fpr_from_card): New function.
4         (retrieve_next_token): New function.
5         (retrieve_key_material): New function.
6         (get_public_key): Implement retrival of key through expernal
7         helper (gpg) in case the openpgp card is not cooperative enough.
8
9 2005-02-25  Werner Koch  <wk@g10code.com>
10
11         * app-openpgp.c (get_public_key): Make sure not to return negative
12         numbers.
13         (do_sign): Allow passing of indata with algorithm prefix.
14         (do_auth): Allow OPENPGP.3 as an alternative ID.
15
16         * app.c (app_getattr): Return just the S/N but not the timestamp.
17
18 2005-02-24  Werner Koch  <wk@g10code.com>
19
20         * app.c (app_getattr): Return APPTYPE or SERIALNO type even if the
21         application does dot support the getattr call.
22
23         * app-openpgp.c (get_one_do): Never try to get a non cacheable
24         object from the cache.
25         (get_one_do): Add new arg to return an error code.  Changed all
26         callers.
27         (do_getattr): Let it return a proper error code.
28
29         * app.c (select_application): Return an error code and the
30         application context in an new arg.
31         * command.c (open_card): Adjusted for that.  Don't use the
32         fallback if no card is present.  Return an error if the card has
33         been removed without a reset.
34         (do_reset, cmd_serialno): Clear that error flag.
35         (TEST_CARD_REMOVAL): New. Use it with all command handlers.
36         (scd_update_reader_status_file): Set the error flag on all changes.
37
38         * scdaemon.c (ticker_thread): Termintate if a shutdown is pending.
39
40         * apdu.c: Added some PCSC error codes.
41         (pcsc_error_to_sw): New.
42         (reset_pcsc_reader, pcsc_get_status, pcsc_send_apdu) 
43         (open_pcsc_reader): Do proper error code mapping.
44
45 2005-02-22  Werner Koch  <wk@g10code.com>
46
47         * app-openpgp.c (app_local_s): New field PK.
48         (do_deinit, do_genkey, app_openpgp_storekey): Clear it.
49         (get_public_key, send_keypair_info): New.
50         (do_learn_status): Send KEYPAIR info
51
52         * app-common.h (app_ctx_t): Add function pointer READKEY.
53         * app.c (app_readkey): New.
54         * command.c (cmd_readkey): Use READKEY function if possible.
55
56 2005-01-26  Werner Koch  <wk@g10code.com>
57
58         * ccid-driver.c (parse_ccid_descriptor): Need the CSM workaround
59         also for newer firmware versions.  Need to get a list of fixed
60         firmware versions and use that.
61
62 2005-01-25  Werner Koch  <wk@g10code.com>
63
64         * apdu.c (apdu_send_le, apdu_send_direct): Fix some compiler
65         warnings.
66
67         * app-openpgp.c (get_cached_data): New arg GET_IMMEDIATE to bypass
68         the cache.  Changed all callers.
69         (get_one_do): Bypass the cache if the value would have been read
70         directly for v1.1 cards.It makes things a bit slower but obnly for
71         1.0 cards and there are not that many cards out in the wild.  This
72         is required to fix a caching bug when generating new keys; as a
73         side effect of the retrieval of the the C4 DO from the 6E DO the
74         cached fingerprint will get updated to the old value and later
75         when signing the generated key the checking of the fingerprint
76         fails because it won't match the new one.  Thanks to Moritz for
77         analyzing this problem.
78         (verify_chv3): Removed the CHV status reread logic because we
79         won't cache the C4 DO anymore.
80
81 2004-12-28  Werner Koch  <wk@g10code.com>
82
83         * ccid-driver.c (find_endpoint): New.
84         (scan_or_find_devices): Add new args to return endpoint info and
85         interface number.
86         (ccid_open_reader, ccid_shutdown_reader): Take care of these new
87         args.
88         (bulk_in, bulk_out): Use the correct endpoints.
89         (ccid_transceive_apdu_level): New.
90         (ccid_transceive): Divert to above.
91         (parse_ccid_descriptor): Allow APDU level exchange mode.
92         (do_close_reader): Pass the interface number to usb_release_interface.
93
94 2004-12-21  Werner Koch  <wk@g10code.com>
95
96         * scdaemon.c (main): Use default_homedir().
97
98 2004-12-18  Werner Koch  <wk@g10code.com>
99
100         * scdaemon.c (main) [W32]: Remove special Pth initialize..
101
102         * scdaemon.h (map_assuan_err): Define in terms of
103         map_assuan_err_with_source.
104
105 2004-12-15  Werner Koch  <wk@g10code.com>
106
107         * scdaemon.c [W32]: Various hacks to make it run under W32.
108
109         * command.c (scd_update_reader_status_file) [W32]: Don't use kill.
110
111         * apdu.c [W32]: Disable use of pcsc_wrapper.
112
113         * Makefile.am (scdaemon_LDADD): Reorder libs.
114         (sc_copykeys_LDADD): Add libassuan because it is needed for W32. 
115
116 2004-12-06  Werner Koch  <wk@g10code.com>
117
118         * Makefile.am (pkglib_PROGRAMS): Build only for W32.
119
120 2004-10-22  Werner Koch  <wk@g10code.com>
121
122         * app-openpgp.c (verify_chv3): The minium length for CHV3 is
123         8. Changed string to match the other ones.
124
125 2004-10-21  Werner Koch  <wk@g10code.com>
126
127         * app-openpgp.c (do_sign): Replace asprintf by direct allocation.
128         This avoids problems with missing vasprintf implementations in
129         gnupg 1.4.
130
131         * app-common.h (app_openpgp_storekey: Add prototype. 
132
133 2004-10-20  Werner Koch  <wk@g10code.com>
134
135         * sc-investigate: Removed.
136         * Makefile.am (sc_investigate): Removed.
137         
138         * pcsc-wrapper.c (load_pcsc_driver): Load get_status_change func.
139         (handle_open): Succeed even without a present card.
140         (handle_status, handle_reset): New.
141         
142         * apdu.c (apdu_open_reader): Load pcsc_get_status_change fucntion.
143         (pcsc_get_status): Implemented.
144         (reset_pcsc_reader): Implemented.
145         (open_pcsc_reader): Succeed even with no card inserted.
146         (open_ccid_reader): Set LAST_STATUS.
147
148         * iso7816.c (iso7816_select_application): Always use 0 for P1.
149
150 2004-10-18  Werner Koch  <wk@g10code.com>
151
152         * ccid-driver.c (ccid_get_atr): Reset T=1 state info.
153
154 2004-10-14  Werner Koch  <wk@g10code.com>
155
156         * app-openpgp.c (parse_login_data): New. 
157         (app_select_openpgp): Call it.
158         (do_setattr): Reparse it after change.
159
160 2004-10-06  Werner Koch  <wk@g10code.de>
161
162         * ccid-driver.c (ccid_open_reader): Store the vendor ID.
163         (ccid_transceive_secure): New.
164         (parse_ccid_descriptor): Workaround for an SCM reader problem.
165
166 2004-10-04  Werner Koch  <wk@g10code.de>
167
168         * ccid-driver.c (send_escape_cmd): New.
169
170 2004-09-30  Werner Koch  <wk@g10code.com>
171
172         * Makefile.am: Adjusted for gettext 0.14.
173
174         * app-openpgp.c (do_sign): Add the error string to the verify
175         failed messages.
176
177 2004-09-27  Werner Koch  <wk@g10code.com>
178
179         From gnupg 1.3
180
181         * app-openpgp.c: Made all strings translatable.
182         (verify_chv3) [GNUPG_MAJOR_VERSION]: Make opt.allow_admin
183         available for use in gnupg 2. 
184         (verify_chv3): Reimplemented countdown showing to use only
185         functions from this module.  Flush the CVH status cache on a
186         successful read.
187         (get_one_do): Hack to bypass the cache for cards versions > 1.0.
188         (store_fpr): Store the creation date for card version > 1.0.
189
190         * app-openpgp.c (app_openpgp_storekey): Call flush_cache.
191         (get_cached_data): Move local data initialization to ..
192         (app_select_openpgp): .. here. Read some flags for later use.
193         (do_getattr): New read-only attribute EXTCAP.
194         
195         * apdu.c (open_pcsc_reader): Do not print empty reader string.
196
197         * ccid-driver.c (do_close_reader): Factored some code out from ...
198         (ccid_close_reader): ..here.
199         (ccid_shutdown_reader): New.
200
201         * apdu.c (apdu_shutdown_reader): New.
202         (shutdown_ccid_reader): New.
203
204         * apdu.c (open_ccid_reader): New arg PORTSTR.  Pass it to
205         ccid_open_reader.
206         (apdu_open_reader): Pass portstr to open_ccid_reader.
207         (apdu_open_reader): No fallback if a full CCID reader id has been
208         given.
209
210         * ccid-driver.c (ccid_get_reader_list): New.
211         (ccid_open_reader): Changed API to take a string for the reader.
212         Removed al the cruft for the libusb development vesion which seems
213         not to be maintained anymore and there are no packages anyway.
214         The stable library works just fine.
215         (struct ccid_reader_id_s): Deleted and replaced everywhere by a
216         simple string.
217         (usb_get_string_simple): Removed.
218         (bulk_in): Do valgrind hack here and not just everywhere.
219
220         * ccid-driver.c (read_device_info): Removed.
221         (make_reader_id, scan_or_find_devices): New.
222         (ccid_open_reader): Simplified by make use of the new functions.
223         (ccid_set_debug_level): New.  Changed the macros to make use of
224         it.  It has turned out that it is often useful to enable debugging
225         at runtime so I added this option.
226
227         From gnupg 1.3 - David Shaw  <dshaw@jabberwocky.com>
228
229         * app-openpgp.c (verify_chv3): Show a countdown of how many wrong
230         admin PINs can be entered before the card is locked.
231
232         * app-openpgp.c (get_cached_data): Avoid mallocing zero since it
233         breaks us when using --enable-m-guard.
234
235         * ccid-driver.c (usb_get_string_simple): Replacement function to
236         work with older libusb.
237
238         * ccid-driver.c (read_device_info): Fix segfault when usb device
239         is not accessible.
240         (ccid_open_reader): Allow working with an even older version of
241         libusb (usb_busses global instead of usb_get_busses()).
242
243 2004-09-11  Werner Koch  <wk@g10code.com>
244
245         * app-openpgp.c (app_select_openpgp): Its app_munge_serialno and
246         not app_number_serialno.
247
248 2004-08-20  Werner Koch  <wk@g10code.de>
249
250         * app.c (select_application): Fixed serial number extraction and
251         added the BMI card workaround.
252         (app_munge_serialno): New.
253         * app-openpgp.c (app_select_openpgp): Try munging serialno.
254
255 2004-08-05  Werner Koch  <wk@g10code.de>
256
257         * scdaemon.c (main): New option --disable-application.
258         * app.c (is_app_allowed): New.
259         (select_application): Use it to check for disabled applications.
260
261         * ccid-driver.h (CCID_DRIVER_ERR_ABORTED): New.
262         * ccid-driver.c (ccid_open_reader): Support the stable 0.1 version
263         of libusb.
264         (ccid_get_atr): Handle short messages.
265
266         * apdu.c (my_rapdu_get_status): Implemented.
267
268 2004-07-27  Moritz Schulte  <moritz@g10code.com>
269
270         * apdu.c: Include <signal.h>.
271
272         * Makefile.am: Use @DL_LIBS@ instead of -ldl.
273
274 2004-07-22  Werner Koch  <wk@g10code.de>
275
276         * Makefile.am: Make OpenSC lib link after libgcrypt. Do not link
277         to pth.
278         * apdu.c: Don't use Pth if we use OpenSC.
279         * sc-investigate.c, scdaemon.c: Disable use of pth if OpenSC is used. 
280
281         * scdaemon.c (main): Bumbed thread stack size up to 512k.
282
283 2004-07-16  Werner Koch  <wk@gnupg.org>
284
285         * apdu.c (reader_table_s):  Add function pointers for the backends.
286         (apdu_close_reader, apdu_get_status, apdu_activate) 
287         (send_apdu): Make use of them.
288         (new_reader_slot): Intialize them to NULL.
289         (dump_ccid_reader_status, ct_dump_reader_status): New.
290         (dump_pcsc_reader_status): New.
291         (open_ct_reader, open_pcsc_reader, open_ccid_reader) 
292         (open_osc_reader, open_rapdu_reader): Intialize function pointers.
293         (ct_activate_card, ct_send_apdu, pcsc_send_apdu, osc_send_apdu) 
294         (error_string): Removed.  Replaced by apdu_strerror.
295         (get_ccid_error_string): Removed.
296         (ct_activate_card): Remove the unused loop.
297         (reset_ct_reader): Implemented.
298         (ct_send_apdu): Activate the card if not yet done.
299         (pcsc_send_apdu): Ditto.
300
301 2004-07-15  Werner Koch  <wk@gnupg.org>
302
303         * ccid-driver.h: Add error codes.
304         * ccid-driver.c: Implement more or less proper error codes all
305         over the place.
306
307         * apdu.c (apdu_send_direct): New.
308         (get_ccid_error_string): Add some error code mappings.
309         (send_apdu): Pass error codes along for drivers already supporting
310         them.
311         (host_sw_string): New.
312         (get_ccid_error_string): Use above.
313         (send_apdu_ccid): Reset the reader if it has not yet been done.
314         (open_ccid_reader): Don't care if the ATR can't be read.
315         (apdu_activate_card): New.
316         (apdu_strerror): New.
317         (dump_reader_status): Only enable it with opt.VERBOSE.
318         * iso7816.c (map_sw): Add mappings for the new error codes.
319
320 2004-07-02  Werner Koch  <wk@gnupg.org>
321
322         * apdu.c (open_ct_reader, open_pcsc_reader, open_ccid_reader)
323         (reset_ccid_reader, open_osc_reader): Call dump_reader_status only
324         in verbose mode.
325
326 2004-07-01  Werner Koch  <wk@gnupg.org>
327
328         * sc-investigate.c: Initialize Pth which is now required.
329         (interactive_shell): New command "readpk".
330
331         * app-openpgp.c (do_getattr): Fix for sending CA-FPR.
332
333 2004-06-30  Werner Koch  <wk@gnupg.org>
334
335         * app-openpgp.c (app_openpgp_readkey): Fixed check for valid
336         exponent.
337
338 2004-06-18  Werner Koch  <wk@g10code.com>
339
340         * sc-investigate.c (my_read_line): Renamed from read_line.
341
342 2004-06-16  Werner Koch  <wk@gnupg.org>
343
344         * apdu.c (osc_get_status): Fixed type in function name. Noted by
345         Axel Thimm.  Yes, I didn't tested it with OpenSC :-(.
346
347 2004-04-28  Werner Koch  <wk@gnupg.org>
348
349         * app-openpgp.c (do_setattr): Sync FORCE_CHV1.
350
351 2004-04-27  Werner Koch  <wk@gnupg.org>
352
353         * app-common.h: Do not include ksba.h for gnupg 1.
354
355 2004-04-26  Werner Koch  <wk@gnupg.org>
356
357         * app-common.h: New members FNC.DEINIT and APP_LOCAL.
358         * app.c (release_application): Call new deconstructor.
359         * app-openpgp.c (do_deinit): New.
360         (get_cached_data, flush_cache_item, flush_cache_after_error)
361         (flush_cache): New.
362         (get_one_do): Replaced arg SLOT by APP.  Make used of cached data.
363         (verify_chv2, verify_chv3): Flush some cache item after error.
364         (do_change_pin): Ditto.
365         (do_sign): Ditto.
366         (do_setattr): Flush cache item.
367         (do_genkey): Flush the entire cache.
368         (compare_fingerprint): Use cached data.
369
370         * scdaemon.c (main): Do the last change the usual way. This is so
371         that we can easily test for versioned config files above.
372
373 2004-04-26  Marcus Brinkmann  <marcus@g10code.de>
374
375         * scdaemon.c (main): For now, always print default filename for
376         --gpgconf-list, and never /dev/null.
377
378 2004-04-21  Werner Koch  <wk@gnupg.org>
379
380         * command.c (scd_update_reader_status_file): Send a signal back to
381         the client.
382         (option_handler): Parse the new event-signal option.
383
384         * scdaemon.c (handle_signal): Do not use SIGUSR{1,2} anymore for
385         changing the verbosity.
386
387 2004-04-20  Werner Koch  <wk@gnupg.org>
388
389         * command.c (scd_update_reader_status_file): Write status files.
390
391         * app-help.c (app_help_read_length_of_cert): Fixed calculation of
392         R_CERTOFF.
393
394         * pcsc-wrapper.c: New.
395         * Makefile.am (pkglib_PROGRAMS): Install it here.
396         * apdu.c (writen, readn): New.
397         (open_pcsc_reader, pcsc_send_apdu, close_pcsc_reader): Use the
398         pcsc-wrapper if we are using Pth.
399         (apdu_send_le): Reinitialize RESULTLEN.  Handle SW_EOF_REACHED
400         like SW_SUCCESS.
401
402 2004-04-19  Werner Koch  <wk@gnupg.org>
403
404         * ccid-driver.c (parse_ccid_descriptor): Store some of the reader
405         features away.  New arg HANDLE
406         (read_device_info): New arg HANDLE. Changed caller.
407         (bulk_in): Handle time extension requests.
408         (ccid_get_atr): Setup parameters and the IFSD.
409         (compute_edc): New. Factored out code.
410         (ccid_transceive): Use default NADs when required.
411
412 2004-04-14  Werner Koch  <wk@gnupg.org>
413
414         * scdaemon.h (server_control_s): Add member READER_SLOT.
415         * scdaemon.c (scd_init_default_ctrl): Initialize READER_SLOT to -1.
416         * command.c (open_card): Reuse an open slot.
417         (reset_notify): Just reset the slot if supported by the reader.
418         (do_reset): Factored code from above out.
419         (scd_command_handler): Use it for cleanup.
420
421         * apdu.h: New pseudo stati SW_HOST_NOT_SUPPORTED,
422         SW_HOST_LOCKING_FAILED and SW_HOST_BUSY.
423         * iso7816.c (map_sw): Map it.
424         
425         * ccid-driver.c (ccid_slot_status): Add arg STATUSBITS.
426         * apdu.c (apdu_get_status): New.
427         (ct_get_status, pcsc_get_status, ocsc_get_status): New stubs.
428         (get_status_ccid): New.
429         (apdu_reset): New.
430         (reset_ct_reader, reset_pcsc_reader, reset_osc_reader): New stubs.
431         (reset_ccid_reader): New.
432         (apdu_enum_reader): New.
433         
434         * apdu.c (lock_slot, trylock_slot, unlock_slot): New helpers.
435         (new_reader_slot) [USE_GNU_PTH]: Init mutex.
436         (apdu_reset, apdu_get_status, apdu_send_le): Run functions
437         in locked mode.
438
439         * command.c (scd_update_reader_status_file): New.
440         * scdaemon.c (handle_tick): Call it.
441
442 2004-04-13  Werner Koch  <wk@gnupg.org>
443
444         * scdaemon.c: Convert to a Pth application.
445         (handle_signal, ticker_thread, handle_tick): New.
446         (main): Fire up the ticker thread in server mode.
447
448 2004-03-23  Werner Koch  <wk@gnupg.org>
449
450         * scdaemon.c (main) <gpgconf_list>: Fixed output for pcsc_driver.
451
452 2004-03-17  Werner Koch  <wk@gnupg.org>
453
454         * tlv.c (parse_ber_header): Do not check for tag overflow - it
455         does not make sense.  Simplified the check for length overflow.
456
457         * scdaemon.c (main) <gpgconf>: Fixed default value quoting.
458
459 2004-03-16  Werner Koch  <wk@gnupg.org>
460
461         * app-dinsig.c: Implemented. Based on app-nks.c and card-dinsig.c
462         * app-nks.c (get_length_of_cert): Removed.
463         * app-help.c: New.
464         (app_help_read_length_of_cert): New.  Code taken from above.  New
465         optional arg R_CERTOFF.
466
467         * card-dinsig.c: Removed.
468         * card.c (card_get_serial_and_stamp): Do not bind to the old and
469         never finsiged card-dinsig.c.
470
471         * iso7816.c (iso7816_read_binary): Allow for an NMAX > 254.
472
473 2004-03-11  Werner Koch  <wk@gnupg.org>
474
475         * scdaemon.h (out_of_core): Removed.  Replaced callers by standard
476         gpg_error function.
477
478         * apdu.c, iso7816.c, ccid-driver.c [GNUPG_SCD_MAIN_HEADER]: Allow
479         to include a header defined by the compiler.  This helps us to
480         reuse the source in other software.
481
482 2004-03-10  Werner Koch  <wk@gnupg.org>
483
484         * iso7816.c (iso7816_read_record): New arg SHORT_EF.  Changed all
485         callers.
486
487 2004-02-18  Werner Koch  <wk@gnupg.org>
488
489         * sc-investigate.c (main): Setup the used character set.
490         * scdaemon.c (main): Ditto.
491
492         * scdaemon.c (set_debug): New.  Add option --debug-level.
493         (main): Add option --gpgconf-list.
494
495 2004-02-12  Werner Koch  <wk@gnupg.org>
496
497         * Makefile.am: Include cmacros.am for common flags.
498
499 2004-01-29  Werner Koch  <wk@gnupg.org>
500
501         * command.c (reset_notify): Release the application context and
502         close the reader.
503
504 2004-01-28  Werner Koch  <wk@gnupg.org>
505
506         * iso7816.c (iso7816_manage_security_env): New.
507         (iso7816_decipher): Add PADIND argument.
508
509 2004-01-27  Werner Koch  <wk@gnupg.org>
510
511         * command.c (cmd_readcert, cmd_readkey): Work on a copy of LINE.
512
513         * app-common.h (app_ctx_s): Added readcert field.
514         * app.c (app_readcert): New.
515         * tlv.c (parse_ber_header): Added; taken from libksba.
516
517 2004-01-26  Werner Koch  <wk@gnupg.org>
518
519         * card.c (map_sc_err): Use SCD as the error source.
520
521         * command.c (open_card): ADD arg NAME to allow requesting a
522         specific application.  Changed all callers.
523         (cmd_serialno): Allow optional argument to select the desired
524         application.
525
526         * app-nks.c: New. 
527
528         * scdaemon.h (opt): Add READER_PORT.
529         * scdaemon.c (main): Set it here.
530         * app.c (app_set_default_reader_port): Removed.
531         (select_application): Add NAME arg and figure out a
532         default serial number from the GDO. Add SLOT arg and remove all
533         reader management.
534         (release_application): New.
535         (app_write_learn_status): Output an APPTYPE status line.
536         * command.c (open_card): Adapt for select_application change.
537         * app-openpgp.c (app_select_openpgp): Removed SN and SNLEN args
538         and set it directly.  Changed all callers.
539
540 2004-01-25  Werner Koch  <wk@gnupg.org>
541
542         * iso7816.c (iso7816_select_application): P1 kludge for OpenPGP
543         card.
544         * app-openpgp.c (find_tlv): Factor out this function to ..
545         * tlv.c, tlv.h: .. new.
546
547         * scdaemon.h: Introduced app_t and ctrl_t as the new types for APP
548         and CTRL.
549
550 2004-01-21  Werner Koch  <wk@gnupg.org>
551
552         * apdu.c (apdu_send_le): Treat SW_EOF_REACHED as a warning.
553
554 2004-01-20  Werner Koch  <wk@gnupg.org>
555
556         * iso7816.c (iso7816_read_binary): New.
557         (iso7816_select_file): New.
558         (iso7816_list_directory): New.
559
560         * sc-investigate.c: Add option -i.
561         (select_app, read_line, interactive_shell): New.
562
563 2004-01-16  Werner Koch  <wk@gnupg.org>
564
565         * apdu.h: Add SW_FILE_NOT_FOUND.
566         * iso7816.c (map_sw): Map it to GPG_ERR_ENOENT.
567         * iso7816.c (iso7816_select_file): New.
568
569         * app-dinsig.c: New file w/o any real code yet.
570         * Makefile.am (scdaemon_SOURCES,sc_investigate_SOURCES): Add file.
571
572         * sc-investigate.c: Add option --disable-ccid.
573
574 2003-12-19  Werner Koch  <wk@gnupg.org>
575
576         * apdu.c (apdu_send_le): Send a get_response with the indicated
577         length and not the 64 bytes we used for testing.
578
579         * app-openpgp.c (verify_chv2, verify_chv3, do_sign): Check the
580         minimum length of the passphrase, so that we don't need to
581         decrement the retry counter.
582
583 2003-12-17  Werner Koch  <wk@gnupg.org>
584
585         * card-p15.c (p15_enum_keypairs): Replaced KRC by RC.
586         * card-dinsig.c (dinsig_enum_keypairs): Ditto.
587
588 2003-12-16  Werner Koch  <wk@gnupg.org>
589
590         * scdaemon.c (main): Set the prefixes for assuan logging.
591
592 2003-11-17  Werner Koch  <wk@gnupg.org>
593
594         * scdaemon.c, scdaemon.h: New options --allow-admin and --deny-admin.
595         * app-openpgp.c (verify_chv3): Check it here.
596
597 2003-11-12  Werner Koch  <wk@gnupg.org>
598
599         Adjusted for API changes in Libksba.
600
601 2003-10-30  Werner Koch  <wk@gnupg.org>
602
603         * apdu.c (close_ct_reader, close_pcsc_reader): Implemented.
604         (get_ccid_error_string): New.  Not very useful messages, though.
605
606 2003-10-25  Werner Koch  <wk@gnupg.org>
607
608         * ccid-driver.c (ccid_open_reader): Return an error if no USB
609         devices are found.
610
611         * command.c (cmd_genkey, cmd_passwd): Fixed faulty use of
612         !spacep().
613
614         * apdu.c (apdu_open_reader): Hacks for PC/SC under Windows.
615
616 2003-10-20  Werner Koch  <wk@gnupg.org>
617
618         * command.c (cmd_checkpin): New.
619         (register_commands): Add command CHECKPIN.
620         * app.c (app_check_pin): New.
621         * app-openpgp.c (check_against_given_fingerprint): New. Factored
622         out that code elsewhere.
623         (do_check_pin): New.
624
625 2003-10-10  Werner Koch  <wk@gnupg.org>
626
627         * ccid-driver.c (ccid_close_reader): New.
628
629         * apdu.c (close_ccid_reader, close_ct_reader, close_csc_reader)
630         (close_osc_reader, apdu_close_reader): New.  Not all are properly
631         implemented yet.
632
633 2003-10-09  Werner Koch  <wk@gnupg.org>
634
635         * ccid-driver.c (ccid_transceive): Add T=1 chaining for sending.
636
637 2003-10-08  Werner Koch  <wk@gnupg.org>
638
639         * app-openpgp.c (do_getattr): Support SERIALNO and AID.
640
641 2003-10-01  Werner Koch  <wk@gnupg.org>
642
643         * ccid-driver.c: Detect GnuPG 1.3 and include appropriate files.
644         * apdu.c: Ditto.
645         * app-openpgp.c: Ditto.
646         * iso7816.c: Ditto.
647         (generate_keypair): Renamed to ..
648         (do_generate_keypair): .. this.
649         * app-common.h [GNUPG_MAJOR_VERSION]: New.
650         * iso7816.h [GNUPG_MAJOR_VERSION]: Include cardglue.h
651
652 2003-09-30  Werner Koch  <wk@gnupg.org>
653
654         * command.c (cmd_getattr): New command GETATTR.
655         * app.c (app_setattr): New.
656         (do_getattr): New.
657         (do_learn_status): Reimplemented in terms of do_getattr.
658
659         * app-openpgp.c (do_change_pin): Make sure CVH1 and CHV2 are
660         always synced.
661         (verify_chv2, verify_chv3): New. Factored out common code.
662         (do_setattr, do_sign, do_auth, do_decipher): Change the names of
663         the prompts to match that we have only 2 different PINs.
664         (app_select_openpgp): Check whether the card enforced CHV1.
665         (convert_sig_counter_value): New. Factor out code from
666         get_sig_counter.
667
668 2003-09-28  Werner Koch  <wk@gnupg.org>
669
670         * app-openpgp.c (dump_all_do): Use gpg_err_code and not gpg_error.
671
672 2003-09-19  Werner Koch  <wk@gnupg.org>
673
674         * ccid-driver.c (parse_ccid_descriptor): New.
675         (read_device_info): New.
676         (ccid_open_reader): Check that the device has all required features.
677
678 2003-09-06  Werner Koch  <wk@gnupg.org>
679
680         * scdaemon.c (main): --pcsc-driver again defaults to pcsclite.
681         David Corcoran was so kind to remove the GPL incompatible
682         advertisng clause from pcsclite.
683         * apdu.c (apdu_open_reader): Actually make pcsc-driver option work.
684
685 2003-09-05  Werner Koch  <wk@gnupg.org>
686
687         * ccid-driver.c: More work, data can now actually be retrieved.
688         * ccid-driver.c, ccid-driver.h: Alternativley allow use under BSD
689         conditions.
690
691 2003-09-02  Werner Koch  <wk@gnupg.org>
692
693         * scdaemon.c, scdaemon.h: New option --pcsc-ccid.
694         * ccid-driver.c, ccid-driver.h: New but far from being useful.
695         * Makefile.am: Add above.
696         * apdu.c: Add support for that ccid driver.
697         
698 2003-08-26  Timo Schulz  <twoaday@freakmail.de>
699
700         * apdu.c (new_reader_slot): Only set 'is_osc' when OpenSC
701         is used.
702         
703 2003-08-25  Werner Koch  <wk@gnupg.org>
704
705         * command.c (cmd_setattr): Use a copy of LINE.
706         (cmd_genkey): Use a copy of KEYNO.
707         (cmd_passwd): Use a copy of CHVNOSTR.
708         (cmd_pksign, cmd_pkauth, cmd_pkdecrypt): s/strdup/xtrystrdup/.
709
710 2003-08-19  Werner Koch  <wk@gnupg.org>
711
712         * scdaemon.c, scdaemon.h: New option --pcsc-driver.
713         * apdu.c (apdu_open_reader): Use that option here instead of a
714         hardcoded one.
715
716 2003-08-18  Werner Koch  <wk@gnupg.org>
717
718         * Makefile.am: Add OPENSC_LIBS to all programs. 
719
720         * scdaemon.c, scdaemon.h: New option --disable-opensc.
721         * card.c (card_open): Implement it.
722         * apdu.c (open_osc_reader, osc_send_apdu): New.
723         (apdu_open_reader) [HAVE_OPENSC]: Use the opensc driver if not
724         disabled.
725         (error_string) [HAVE_OPENSC]: Use sc_strerror.
726         (send_apdu) [HAVE_OPENSC]: Call osc_apdu_send.
727
728         * card-p15.c (p15_enum_keypairs, p15_prepare_key): Adjusted for
729         libgpg-error.
730
731 2003-08-14  Timo Schulz  <twoaday@freakmail.de>
732
733         * apdu.c (ct_activate_card): Change the code a little to avoid
734         problems with other readers.
735         * Always use 'dynload.h' instead of 'dlfcn.h'.
736
737 2003-08-05  Werner Koch  <wk@gnupg.org>
738
739         * app-openpgp.c (dump_all_do): Don't analyze constructed DOs after
740         an error.
741
742 2003-08-04  Werner Koch  <wk@gnupg.org>
743
744         * app.c (app_set_default_reader_port): New.
745         (select_application): Use it here.
746         * scdaemon.c (main): and here.
747         * sc-copykeys.c: --reader-port does now take a string.
748         * sc-investigate.c, scdaemon.c: Ditto.
749         * apdu.c (apdu_open_reader): Ditto.  Load pcsclite if no ctapi
750         driver is configured.  Always include code for ctapi.
751         (new_reader_slot): Don't test for already used ports and remove
752         port arg.
753         (open_pcsc_reader, pcsc_send_apdu, pcsc_error_string): New.
754         (apdu_send_le): Changed RC to long to cope with PC/SC.
755
756         * scdaemon.c, scdaemon.h: New option --ctapi-driver.
757         * sc-investigate.c, sc-copykeys.c: Ditto.
758         
759 2003-07-31  Werner Koch  <wk@gnupg.org>
760
761         * Makefile.am (scdaemon_LDADD): Added INTLLIBS.
762
763 2003-07-28  Werner Koch  <wk@gnupg.org>
764
765         * app-openpgp.c (do_setattr): Change implementation.  Allow all
766         useful DOs.
767
768 2003-07-27  Werner Koch  <wk@gnupg.org>
769
770         Adjusted for gcry_mpi_print and gcry_mpi_scan API change.
771
772 2003-07-24  Werner Koch  <wk@gnupg.org>
773
774         * app-openpgp.c (do_learn_status): Print more status information.
775         (app_select_openpgp): Store the card version.
776         (store_fpr): Add argument card_version and fix DOs for old cards.
777         (app_openpgp_storekey): Likewise.
778
779 2003-07-23  Werner Koch  <wk@gnupg.org>
780
781         * command.c (cmd_pkauth): New.
782         (cmd_setdata): Check whether data was given at all to avoid
783         passing 0 to malloc.
784
785         * app.c (app_auth): New.
786         * app-openpgp.c (do_auth): New.
787
788 2003-07-22  Werner Koch  <wk@gnupg.org>
789
790         * command.c (cmd_passwd): New.
791         * app.c (app_change_pin): New.
792         * app-openpgp.c (do_change_pin): New.
793         * iso7816.c (iso7816_reset_retry_counter): Implemented.
794
795         * sc-investigate.c (main): New option --gen-random.
796         * iso7816.c (iso7816_get_challenge): Don't create APDUs with a
797         length larger than 255.
798
799 2003-07-17  Werner Koch  <wk@gnupg.org>
800
801         * command.c (cmd_random): New command RANDOM.
802
803         * iso7816.c (map_sw): New. Use it in this file to return
804         meaningful error messages.  Changed all public fucntions to return
805         a gpg_error_t.
806         (iso7816_change_reference_data): New.
807         * apdu.c (apdu_open_reader): Use faked status words for soem
808         system errors.
809
810 2003-07-16  Werner Koch  <wk@gnupg.org>
811
812         * apdu.c (apdu_send_simple): Use apdu_send_le so that we can
813         specify not to send Le as it should be.
814
815 2003-07-15  Werner Koch  <wk@gnupg.org>
816
817         * Makefile.am: Add sc-copykeys program.
818         * sc-copykeys.c: New.
819         * app-openpgp.c (app_openpgp_storekey): New.
820         (app_openpgp_cardinfo): New.
821         (count_bits): New.
822         (store_fpr): And use it here to get the actual length in bit.
823
824 2003-07-03  Werner Koch  <wk@gnupg.org>
825
826         * app-openpgp.c (do_setattr): Add setting of the URL.
827         (app_select_openpgp): Dump card data only in very verbose mode.
828         (do_decipher): New.
829
830 2003-07-02  Werner Koch  <wk@gnupg.org>
831
832         * app-openpgp.c (get_sig_counter): New.
833         (do_sign): Print the signature counter and enable the PIN callback.
834         (do_genkey): Implement the PIN callback. 
835
836 2003-07-01  Werner Koch  <wk@gnupg.org>
837
838         * app-openpgp.c (store_fpr): Fixed fingerprint calculation.
839
840 2003-06-26  Werner Koch  <wk@gnupg.org>
841
842         * app-openpgp.c (find_tlv): Fixed length header parsing.
843
844         * app.c (app_genkey): New.
845         * command.c (cmd_genkey): New.
846
847 2003-06-25  Werner Koch  <wk@gnupg.org>
848
849         * command.c (percent_plus_unescape): New.
850         (cmd_setattr): New.
851
852 2003-06-24  Werner Koch  <wk@gnupg.org>
853
854         * command.c (send_status_info): New.
855
856         * app-openpgp.c (app_select_openpgp): Replace SLOT arg by APP arg
857         and setup the function pointers in APP on success. Changed callers.
858         * app.c: New.
859         * app-common.h: New.
860         * scdaemon.h (APP): New type to handle applications.
861         (server_control_s): Add an APP context field.
862
863         * command.c (cmd_serialno): Handle applications.
864         (cmd_pksign): Ditto.
865         (cmd_pkdecrypt): Ditto.
866         (reset_notify): Ditto.
867         (cmd_learn): For now return error for application contexts.
868         (cmd_readcert): Ditto.
869         (cmd_readkey): Ditto.
870
871 2003-06-04  Werner Koch  <wk@gnupg.org>
872
873         * card.c (map_sc_err): Renamed gpg_make_err to gpg_err_make.
874
875         Renamed error codes from INVALID to INV and removed _ERROR suffixes.
876
877 2003-06-03  Werner Koch  <wk@gnupg.org>
878
879         Changed all error codes in all files to the new libgpg-error scheme.
880
881         * scdaemon.h: Include gpg-error.h and errno.h
882         * card.c (map_sc_err): Use unknown for the error source.
883         * Makefile.am: Link with libgpg-error
884
885 2003-05-14  Werner Koch  <wk@gnupg.org>
886
887         * atr.c, atr.h: New.
888         * sc-investigate.c: Dump the ATR in a human readable format.
889
890 2003-05-08  Werner Koch  <wk@gnupg.org>
891
892         * scdaemon.h (DBG_CARD_IO_VALUE): New.
893
894         * sc-investigate.c: New.
895         * scdaemon.c (main): Removed --print-atr option.
896
897         * iso7816.c, iso7816.h, app-openpgp.c: New.
898
899 2003-04-29  Werner Koch  <wk@gnupg.org>
900
901         * scdaemon.c: New options --print-atr and --reader-port
902         * apdu.c, apdu.h: New
903
904         * card.c, card-p15.c, card-dinsig.c: Allow build without OpenSC.
905         
906         * Makefile.am (LDFLAGS): Removed.
907
908         * command.c (register_commands): Adjusted for new Assuan semantics.
909
910 2002-08-21  Werner Koch  <wk@gnupg.org>
911
912         * scdaemon.c (main): New option --daemon so that the program is
913         not accidently started in the background.
914
915 2002-08-16  Werner Koch  <wk@gnupg.org>
916
917         * scdaemon.c: Include i18n.h.
918
919         * card-common.h (struct p15_private_s): Forward declaration.  Add
920         it to card_ctx_s.
921         * card.c (card_close): Make sure private data is released.
922         (card_enum_certs): New.
923         * card-p15.c (p15_release_private_data): New.
924         (init_private_data): New to work around an OpenSC weirdness.
925         (p15_enum_keypairs): Do an OpenSC get_objects only once.
926         (p15_enum_certs): New.
927         (card_p15_bind): Bind new function.
928         * command.c (cmd_learn): Return information about the certificates.
929
930 2002-08-09  Werner Koch  <wk@gnupg.org>
931
932         * card.c (card_get_serial_and_stamp): Use the tokeinfo serial
933         number as a fallback. Add a special prefix for serial numbers.
934
935 2002-07-30  Werner Koch  <wk@gnupg.org>
936
937         Changes to cope with OpenSC 0.7.0:
938         
939         * card.c: Removed the check for the packed opensc version.
940         Changed include file names of opensc.
941         (map_sc_err): Adjusted error codes for new opensc version.
942         * card-p15.c: Changed include filename of opensc.
943         * card-dinsig.c: Ditto.
944
945         * card-p15.c (p15_decipher): Add flags argument to OpenSC call.
946         
947 2002-07-24  Werner Koch  <wk@gnupg.org>
948
949         * card.c (find_simple_tlv, find_iccsn): New.
950         (card_get_serial_and_stamp): Improved serial number parser.
951
952 2002-06-27  Werner Koch  <wk@gnupg.org>
953
954         * scdaemon.c (main): Use GNUPG_DEFAULT_HOMEDIR constant.
955
956 2002-06-15  Werner Koch  <wk@gnupg.org>
957
958         * card-dinsig.c: Documented some stuff from the DIN norm.
959
960 2002-04-15  Werner Koch  <wk@gnupg.org>
961
962         * command.c (cmd_pksign, cmd_pkdecrypt): Use a copy of the key ID.
963
964 2002-04-12  Werner Koch  <wk@gnupg.org>
965
966         * scdaemon.c: New option --debug-sc N.
967         * card.c (card_open): set it here.
968
969         * card-p15.c (p15_prepare_key): Factored out common code from ...
970         (p15_sign, p15_decipher): here and made the decryption work the
971         regular way.
972
973 2002-04-10  Werner Koch  <wk@gnupg.org>
974
975         * card.c (card_open): Return immediately when no reader is available.
976
977 2002-03-27  Werner Koch  <wk@gnupg.org>
978
979         * card.c (card_open, card_close): Adjusted for changes in OpenSC.
980
981 2002-03-10  Werner Koch  <wk@gnupg.org>
982
983         * card-p15.c, card-dinsig.c, card-common.h: New.
984         * card.c: Factored most code out to the new modules, so that we
985         can better support different types of card applications.
986
987 2002-01-26  Werner Koch  <wk@gnupg.org>
988
989         * scdaemon.c scdaemon.h, command.c: New. Based on the code from
990         the gpg-agent.
991
992         
993  Copyright 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
994
995  This file is free software; as a special exception the author gives
996  unlimited permission to copy and/or distribute it, with or without
997  modifications, as long as this notice is preserved.
998
999  This file is distributed in the hope that it will be useful, but
1000  WITHOUT ANY WARRANTY, to the extent permitted by law; without even the
1001  implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.