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