Make --allow-admin the default.
[gnupg.git] / scd / ChangeLog
1 2009-01-28  Werner Koch  <wk@g10code.com>
2
3         * scdaemon.c (main): Make --allow-admin the default and make the
4         option a dummy.
5
6 2009-01-27  Werner Koch  <wk@g10code.com>
7
8         * app-geldkarte.c: Changed to use an AID.
9
10         * app.c (app_munge_serialno): Add case for no serialno.
11         (app_get_serial_and_stamp): Ditto.
12
13 2009-01-26  Werner Koch  <wk@g10code.com>
14
15         * app-geldkarte.c: New.
16         * Makefile.am (card_apps): Add new file.
17         * app.c (select_application): Test for geldkarte.
18
19 2009-01-12  Werner Koch  <wk@g10code.com>
20
21         * command.c (send_client_notifications) [HAVE_W32_SYSTEM]: Fix
22         brackets.
23
24 2009-01-08  Werner Koch  <wk@g10code.com>
25
26         * iso7816.c (iso7816_read_record, iso7816_read_binary): Pass 0 for
27         L_e because the problem with the CCID driver has gone.
28         (iso7816_apdu_direct): New.
29
30         * app-nks.c (filelist): Add NKS_VER field.  Add NKS 3 specific
31         entries.
32         (app_local_s, do_deinit): New.
33         (get_nks_version): New.
34         (app_select_nks): Setup local data.
35         (keygripstr_from_pk_file): Replace SLOT by APP and take care of
36         NKS version > 2.
37         (do_learn_status): Take care of NKS version.
38
39 2009-01-05  Werner Koch  <wk@g10code.com>
40
41         * apdu.c (apdu_get_status): Save the last status.
42
43 2008-12-18  Werner Koch  <wk@g10code.com>
44
45         * ccid-driver.c (abort_cmd): New. 
46         (bulk_in): Call abort_cmd after severe errors.
47
48         * apdu.c (reader_table_s): Add field ANY_STATUS.
49         (new_reader_slot): Clear it.
50         (apdu_get_status): Use ANY_STATUS to update the change counter.
51         Remove the use of the flag bit from LAST_STATUS everywhere.
52         * command.c (update_reader_status_file): Factor code out to ...
53         (send_client_notifications): New.  Track signals already sent.
54         (update_reader_status_file): Shutdown the reader  after a failed
55         apdu_get_status.
56
57 2008-12-09  Werner Koch  <wk@g10code.com>
58
59         * scdaemon.c (main): Call i18n_init before init_common_subsystems.
60
61 2008-12-08  Werner Koch  <wk@g10code.com>
62
63         * scdaemon.c (handle_connections): Sync ticker to the next full
64         interval.
65         (TIMERTICK_INTERVAL_USEC): Change to 500ms.
66
67 2008-12-05  Werner Koch  <wk@g10code.com>
68
69         * app-openpgp.c (app_local_s): Add field ALGO_ATTR_CHANGE.
70         (app_select_openpgp): Parse new capability.
71         (show_caps): Show new capability.
72
73 2008-12-03  Werner Koch  <wk@g10code.com>
74
75         * scdaemon.c (opts): Use ARGPARSE_ macros.  Add option
76         --card-timeout.
77         * command.c (update_reader_status_file): Implement it.
78
79 2008-11-18  Werner Koch  <wk@g10code.com>
80
81         * scdaemon.c (make_libversion): New.
82         (my_strusage): Print libgcrypt and libksba version.
83
84 2008-11-03  Werner Koch  <wk@g10code.com>
85
86         * command.c (server_local_s): Add field DISCONNECT_ALLOWED.
87         (cmd_disconnect): Implement command.
88         (open_card): Reset disconnect flag.
89         (update_reader_status_file): Disconnect if allowed.
90
91         * app-common.h (app_ctx_s): Remove INITIALIZED.  Make REF_COUNT
92         unsigned. 
93         * app.c (select_application): Remove INITIALIZED.
94         (app_write_learn_status, app_readcert, app_readkey, app_getattr)
95         (app_setattr, app_sign, app_decipher, app_writecert)
96         (app_writekey, app_get_challenge, app_change_pin, app_check_pin):
97         Replace INITIALIZED by REF_COUNT check.
98         (application_notify_card_removed): Rename to ..
99         (application_notify_card_reset): .. this.  Change all callers.
100         * command.c (do_reset): Call application_notify_card_reset after
101         sending a reset.
102         (update_reader_status_file): Add arg SET_CARD_REMOVED.
103         (scd_update_reader_status_file): Pass true for new flag.
104         (do_reset): Pass false for new flag.
105
106         * app.c (app_get_serial_and_stamp): Use bin2hex.
107         * app-help.c (app_help_get_keygrip_string): Ditto.
108         * app-p15.c (send_certinfo, send_keypairinfo, do_getattr): Ditto.
109         * app-openpgp.c (send_fpr_if_not_null, send_key_data) 
110         (retrieve_fpr_from_card, send_keypair_info): Ditto.
111         * app-nks.c (keygripstr_from_pk_file): Ditto.
112         * command.c (cmd_apdu): Ditto.
113
114 2008-10-21  Marcus Brinkmann  <marcus@g10code.com>
115
116         * command.c (open_card): If connect error is SW_HOST_NO_CARD,
117         return a more descriptive error.
118
119 2008-10-20  Werner Koch  <wk@g10code.com>
120
121         * pcsc-wrapper.c (read_32): Use provided arg and not stdin.  Is
122         called with stdin, though.
123         (handle_close): Mark unused arg.
124         (handle_status, handle_reset): Ditto.
125
126         * ccid-driver.c (ccid_check_card_presence): Mark not yet used arg.
127
128         * scdaemon.c (scd_deinit_default_ctrl): Mark unused arg.
129         * command.c (cmd_unlock, cmd_restart, cmd_disconnect): Ditto.
130         * apdu.c (ct_get_status): Ditto.
131         (ct_send_apdu, pcsc_send_apdu_wrapped)
132         (apdu_open_remote_reader): Ditto.
133         * app.c (select_application): Ditto.
134         * app-openpgp.c (do_writecert, do_change_pin, do_writekey): Ditto.
135         * app-nks.c (do_change_pin, do_check_pin): Ditto.
136
137 2008-10-16  Werner Koch  <wk@g10code.com>
138
139         * command.c (cmd_disconnect): New dummy command.
140         (register_commands): Register command.
141
142 2008-10-15  Werner Koch  <wk@g10code.com>
143
144         * command.c (scd_command_handler): Return true if there is no more
145         active session.
146         * scdaemon.c (start_connection_thread): Set shutdown flag if
147         requested by command handler.
148         (main): Make PIPE_SERVER module global.
149         (handle_connections): Disable listen_fd if a shutdown is pending.
150
151 2008-10-14  Werner Koch  <wk@g10code.com>
152
153
154         * apdu.c (reader_table_s): Add fields connect_card and
155         disconnect_card.
156         (new_reader_slot): Set them to NULL.
157         (apdu_connect, apdu_disconnect): New.
158         (apdu_close_reader, apdu_shutdown_reader): Call apdu_disconnect.
159         (connect_pcsc_card, disconnect_pcsc_card): new.
160         (reset_pcsc_reader_direct): Implement in terms of
161         disconnect_pcsc_card and connect_pcsc_card.
162         (apdu_get_atr): Return NULL if there is no ATR.
163         * sc-copykeys.c (main): Add call to apdu_connect.
164         * command.c (open_card): Ditto.
165
166         * apdu.h (SW_HOST_ALREADY_CONNECTED): New.
167         (APDU_CARD_USABLE, APDU_CARD_PRESENT, APDU_CARD_ACTIVE): New.
168         * apdu.c: Replace constants by the new macros.
169         (open_pcsc_reader): Factor  code out to ...
170         (open_pcsc_reader_direct, open_pcsc_reader_wrapped): New.
171         (reset_pcsc_reader): Factor code out to ...
172         (reset_pcsc_reader_direct, reset_pcsc_reader_wrapped): New.
173         (pcsc_get_status): Factor code out to ...
174         (pcsc_get_status_direct, pcsc_get_status_wrapped): New.
175         (pcsc_send_apdu): Factor code out to ...
176         (pcsc_send_apdu_direct, pcsc_send_apdu_wrapped): New.
177         (close_pcsc_reader): Factor code out to ...
178         (close_pcsc_reader_direct, close_pcsc_reader_wrapped): New.
179
180         * command.c (update_reader_status_file): Open the reader if not
181         yet done.
182
183         * scdaemon.c (TIMERTICK_INTERVAL_SEC, TIMERTICK_INTERVAL_USEC):
184         New to replace TIMERTICK_INTERVAL.  Chnage from 2s (4 under W32)
185         to 250ms.
186
187 2008-10-13  Werner Koch  <wk@g10code.com>
188
189         * command.c (option_handler) [W32]: Use strtoul with base 16.
190         (update_reader_status_file) [W32]: Set Event.
191         (scd_command_handler): Use INT2FD to silent warning.
192
193 2008-09-29  Werner Koch  <wk@g10code.com>
194
195         * scdaemon.h (GCRY_MD_USER): Rename to GCRY_MODULE_ID_USER.
196         (GCRY_MD_USER_TLS_MD5SHA1): Rename to MD_USER_TLS_MD5SHA1 and
197         change all users.
198
199 2008-09-28  Marcus Brinkmann  <marcus@g10code.com>
200
201         * apdu.c (pcsc_get_status): Fix last change.
202
203 2008-09-25  Werner Koch  <wk@g10code.com>
204
205         * app-openpgp.c (do_setattr): Do not allow setting of the reset
206         code.
207         (do_change_pin): Allow setting of the reset code.
208
209 2008-09-24  Werner Koch  <wk@g10code.com>
210
211         * app-openpgp.c (verify_chv3): Set the did_chv3 flag which was
212         accidently removed on 2008-03-26.
213         (verify_chv2): Revert last change.
214         (do_change_pin): Do not change CHV2. Add reset code logic for v2
215         cards.
216         * iso7816.c (iso7816_reset_retry_counter_with_rc): New.
217         
218         * app-openpgp.c (add_tlv, build_privkey_template): New.
219         (do_writekey): Support v2 keys and other key lengths than 1024.
220         * iso7816.c (iso7816_put_data_odd): New.
221
222 2008-09-23  Werner Koch  <wk@g10code.com>
223
224         * app-openpgp.c (do_sign): Support SHA-2 digests.
225         (verify_chv2): No CHV auto-sync for v2 cards.
226         (do_auth): Allow 2048 bit keys.
227         (parse_algorithm_attribute): New.
228         (rsa_key_format_t): New.
229         (struct app_local_s): Add struct KEYATTR.
230
231 2008-09-23  Marcus Brinkmann  <marcus@g10code.com>
232
233         * apdu.c (pcsc_get_status): Be more relaxed with the usable flag
234         under Windows.
235
236 2008-09-23  Werner Koch  <wk@g10code.com>
237
238         * app-openpgp.c (do_setattr): Use command chaining for long
239         values.
240         * iso7816.c (iso7816_put_data): Add arg EXTENDED_MODE. Change all
241         callers.
242         * apdu.c (apdu_send_simple): Add arg EXTENDED_MODE. Change all
243         callers.
244         (send_le): Implement command chaining.
245         * ccid-driver.c (ccid_transceive_apdu_level): Increase allowed
246         APDU size.
247         (ccid_transceive): Alow for APDUS of up to 259 bytes.
248         * apdu.h: Add new SW_ codes.
249
250 2008-09-16  Werner Koch  <wk@g10code.com>
251
252         * command.c (cmd_writecert): New.
253         (register_commands): Register it.
254         * app-common.h (app_ctx_s): Add member WRITECERT.
255         * app.c (app_writecert): New.
256         * app-openpgp.c (do_writecert): New.
257         (parse_historical): New.
258         (show_extcap): New.
259         (dump_all_do): Print only the length of longs DOs.
260         * command.c (cmd_writekey, cmd_apdu, cmd_pksign)
261         (cmd_passwd): Replace open coding by skip_options.
262
263 2008-08-30  Moritz  <moritz@gnu.org>
264
265         * scdaemon.c (main): Use estream_asprintf instead of asprintf.
266         * command.c (update_reader_status_file): Likewise.
267         (cmd_serialno): Use estream_asprintf instead of asprintf
268         and xfree instead of free to release memory allocated
269         through (estream_)asprintf.
270         (cmd_learn): Likewise.
271         (pin_cb): Likewise.
272         * app-openpgp.c (get_public_key): Likewise.
273
274 2008-08-18  Werner Koch  <wk@g10code.com>
275
276         * app-openpgp.c (do_setattr): Fix test for v2 cards.
277
278 2008-08-11  Werner Koch  <wk@g10code.com>
279
280         * apdu.c (reset_pcsc_reader, open_pcsc_reader)
281         (reset_rapdu_reader, open_rapdu_reader): Allow ATRs of up to 33
282         bytes.  Provide maximum size of ATR buffer using DIM.  Such long
283         ATR are never seen in reality but the PC/SC library of MAC OS X is
284         just too buggy.  Reported by Ludovic Rousseau.  Fixes bug #948.
285
286 2008-07-30  Werner Koch  <wk@g10code.com>
287
288         * app-openpgp.c (verify_a_chv): Use xtrymalloc and make the prompt
289         for CHV2 more user friendly.
290
291 2008-07-03  Werner Koch  <wk@g10code.com>
292
293         * app-openpgp.c (do_readcert): New.
294         (app_local_s): Add fields IS_V2 and MAX_CERTLEN_3.
295         (app_select_openpgp): Set them and register do_readcert.
296         (do_setattr): Allow storing of the certificate.
297
298 2008-06-25  Werner Koch  <wk@g10code.com>
299
300         * app-dinsig.c (do_sign): Allow for SHA256.
301
302 2008-06-24  Werner Koch  <wk@g10code.com>
303
304         * app-common.h (app_ctx_s): Renamed reset_mode parameter of
305         change_pin to mode_Flags and make it an unsigned int.
306         (APP_CHANGE_FLAG_RESET, APP_CHANGE_FLAG_NULLPIN): New.
307         * app-openpgp.c (do_change_pin): Adjust for that.
308
309         * command.c (cmd_passwd): Add option --nullpin.
310         * app-nks.c (do_check_pin, do_change_pin): New.
311         (app_select_nks): Register new functions.
312
313 2008-04-21  Moritz Schulte  <mo@g10code.com>  (wk)
314
315         * app-openpgp.c (verify_a_chv): Make use of the default CHV flag.
316
317 2008-03-26  Werner Koch  <wk@g10code.com>
318
319         * app-openpgp.c (verify_chv3): Support the keypad.
320
321 2008-02-09  Marcus Brinkmann  <marcus@g10code.de>
322
323         * scdaemon.c (main): Use CONFIG_FILENAME as filename if it is set
324         in gpgconf-list output.
325
326 2007-12-10  Werner Koch  <wk@g10code.com>
327
328         * app-openpgp.c (do_decipher): Take care of cryptograms shorter
329         that 128 bytes.  Fixes bug#851.
330
331 2007-11-14  Werner Koch  <wk@g10code.com>
332
333         * scdaemon.c (main): Pass STANDARD_SOCKET flag to
334         create_server_socket.
335         
336 2007-11-13  Werner Koch  <wk@g10code.com>
337
338         * scdaemon.c (start_connection_thread): Do not call
339         assuan_sock_check_nonce if we are running in --server mode.
340
341 2007-11-07  Werner Koch  <wk@g10code.com>
342
343         * scdaemon.h: Remove errors.h.
344
345 2007-10-02  Werner Koch  <wk@g10code.com>
346
347         * command.c (cmd_getinfo): Add "pid" subcommand.
348
349 2007-10-01  Werner Koch  <wk@g10code.com>
350
351         * scdaemon.c (create_server_socket): Use Assuan socket wrappers
352         and remove Windows specific code.
353         (socket_nonce): New.
354         (start_connection_thread): Check nonce.
355
356 2007-09-14  Marcus Brinkmann  <marcus@g10code.de>
357
358         * scdaemon.c (main): New variable STANDARD_SOCKET, which is 1 for
359         W32 targets.  Use it for create_socket_name.
360
361 2007-08-07  Werner Koch  <wk@g10code.com>
362
363         * tlv.c, tlv.h:  Move to ../common/.
364
365 2007-08-02  Werner Koch  <wk@g10code.com>
366
367         * scdaemon.c: Include gc-opt-flags.h and remove their definition
368         here.
369
370 2007-08-01  Werner Koch  <wk@g10code.com>
371
372         * apdu.c (send_le): Implement exact length hack.  Suggested by
373         Sten Lindgren.
374
375 2007-07-05  Werner Koch  <wk@g10code.com>
376
377         * command.c (has_option_name, skip_options): New.
378         (cmd_genkey): Add option --timestamp.
379         (cmd_writekey): Enter confidential mode while inquiring the key data.
380
381         * app.c (app_genkey): Add arg CREATETIME.
382         * app-common.h (app_ctx_s): Likewise
383         * app-openpgp.c (do_genkey): Ditto.  Use it.
384
385
386 2007-07-04  Werner Koch  <wk@g10code.com>
387
388         * command.c (cmd_getinfo): New subcommand "version".
389
390         * scdaemon.c (TIMERTICK_INTERVAL): New.
391         (handle_connections) [W32]: Enable a dummy sigs event.
392         (handle_connections): Use a proper count for select and not
393         FD_SETSIZE.
394         (fixed_gcry_pth_init, main): Kludge to fix pth initialization.
395
396 2007-06-21  Werner Koch  <wk@g10code.com>
397
398         * scdaemon.h (ctrl_t): Remove.  It is now declared in ../common/util.h.
399
400 2007-06-18  Marcus Brinkmann  <marcus@g10code.de>
401
402         * scdaemon.c (main): Percent escape output of --gpgconf-list.
403
404 2007-06-12  Werner Koch  <wk@g10code.com>
405
406         * scdaemon.c (main): Replace some calls by init_common_subsystems.
407
408 2007-06-11  Werner Koch  <wk@g10code.com>
409
410         * Makefile.am (scdaemon_LDADD): Use libcommonpth macro.
411
412         * command.c (initialize_module_command): New.
413         * scdaemon.c (main) [W32]: Do not use sigpipe code.
414         (main): Call initialize_module_command.
415
416 2007-06-06  Werner Koch  <wk@g10code.com>
417
418         * app-openpgp.c (do_sign): Fix arithmetic on void*.
419
420         * app.c (dump_mutex_state) [W32]: Handle the W32Pth case.
421
422         * apdu.c: Remove dynload.h.
423
424         * scdaemon.c (i18n_init): Remove.
425
426 2007-04-20  Werner Koch  <wk@g10code.com>
427
428         * sc-copykeys.c (my_gcry_logger): Removed.
429         (main): Call setup_libgcrypt_logging helper.
430         * scdaemon.c (my_gcry_logger): Removed.
431         (main): Call setup_libgcrypt_logging helper.
432
433 2007-04-03  Werner Koch  <wk@g10code.com>
434
435         * command.c (cmd_getinfo): New subcommand "reader_list".
436         * ccid-driver.c (scan_or_find_devices): Ignore EBUSY in scan mode
437         for special transports.
438
439 2007-03-07  Werner Koch  <wk@g10code.com>
440
441         * app-dinsig.c: Include i18n.h.
442         (verify_pin): Support PIN pads.
443         * app-nks.c (verify_pin): Ditto.
444
445         * ccid-driver.c (bulk_in): Handle time extension before checking
446         the message type.
447         (ccid_transceive_secure): Support the Cherry XX44 keyboard.
448         Kudos to the nice folks at Cherry for helping with that.
449
450 2007-02-18  Werner Koch  <wk@g10code.com>
451
452         * scdaemon.c (DEFAULT_PCSC_DRIVER): Add a default for OS X.
453
454 2007-01-25  Werner Koch  <wk@g10code.com>
455
456         * Makefile.am (scdaemon_LDADD): Added LIBICONV.  Noted by Billy
457         Halsey.
458
459 2006-12-21  Werner Koch  <wk@g10code.com>
460
461         * app-openpgp.c (verify_chv2): Factored most code out into...
462         (verify_a_chv): ... new.
463         (do_sign): Factored verification code out to new function and
464         take care of a keypad entered PIN.
465         (compare_fingerprint): Print an additional diagnostic.
466
467 2006-11-28  Werner Koch  <wk@g10code.com>
468
469         * apdu.c (send_le, apdu_send_direct): Increase RESULTLEN to 258 to
470         allow for full 256 byte and the status word.  This might break
471         some old PC/SC drivers or cards, but we will see.  Suggested by
472         Kenneth Wang.
473
474 2006-11-23  Werner Koch  <wk@g10code.com>
475
476         * command.c (scd_command_handler): Fixed use of CTRL.
477
478 2006-11-21  Werner Koch  <wk@g10code.com>
479
480         * Makefile.am (libexec_PROGRAMS): Put pscs-wrapper into libexec.
481         Renamed to gnupg-pcsc-wrapper.
482         * apdu.c (open_pcsc_reader): Use GNUPG_LIBEXECDIR to accces the
483         wrapper.  Suggested by Eric Dorland.
484
485 2006-11-20  Werner Koch  <wk@g10code.com>
486
487         * app-openpgp.c (verify_chv2): Support for keypads (only CHV2).
488
489         * ccid-driver.c (ccid_transceive_secure): Made it work for Kaan
490         and SCM.
491
492 2006-11-17  Werner Koch  <wk@g10code.com>
493
494         * ccid-driver.c (scan_or_find_devices): Use DEBUGOUT_2 instead of
495         log_debug.  Removed few other log_debug.
496
497         * iso7816.c (iso7816_check_keypad): Allow for a SW of 0.
498
499         * command.c (pin_cb): New mode to prompt for a keypad entry.
500
501         * scdaemon.c (main) <gpgconf-list>: Add disable-keypad.
502
503 2006-11-15  Werner Koch  <wk@g10code.com>
504
505         * app-p15.c (read_ef_odf): Cast one printf arg.
506
507         * scdaemon.h (struct server_control_s): Add field THREAD_STARTUP.
508         * command.c (scd_command_handler): Add new arg CTRL.
509         * scdaemon.c (scd_init_default_ctrl): Made static.
510         (scd_deinit_default_ctrl): New.
511         (start_connection_thread): Call init/deinit of ctrl.
512         (handle_connections): Allocate CTRL.
513
514         * apdu.c (PCSC_ERR_MASK): New.
515         (reset_pcsc_reader, pcsc_get_status, pcsc_send_apdu)
516         (close_pcsc_reader, open_pcsc_reader): Use it after shifting error
517         values.  Reported by Henrik Nordstrom.  Fixes bug #724.
518
519 2006-10-24  Werner Koch  <wk@g10code.com>
520
521         * scdaemon.h (GCRY_MD_USER_TLS_MD5SHA1): New.
522         (MAX_DIGEST_LEN): Increased to 36.
523         * app-p15.c (do_sign): Support for TLS_MD5SHA1.
524         (do_auth): Detect TLS_MD5SHA1.
525         (do_sign): Tweaks for that digest.
526
527 2006-10-23  Werner Koch  <wk@g10code.com>
528
529         * scdaemon.c (main): New command --gpgconf-test.
530
531 2006-10-17  Werner Koch  <wk@g10code.com>
532
533         * Makefile.am (scdaemon_LDADD): Link against libcommonpth.
534
535 2006-10-12  Werner Koch  <wk@g10code.com>
536
537         * apdu.c: Include pth.h after unistd.h for the sake of newer Pth
538         versions.
539
540 2006-10-11  Werner Koch  <wk@g10code.com>
541
542         * app-openpgp.c (do_sign): Redirect to do_auth for OpenPGP.3.
543
544 2006-10-06  Werner Koch  <wk@g10code.com>
545
546         * Makefile.am (AM_CFLAGS): Use PTH version of libassuan.
547         (scdaemon_LDADD): Ditto.
548
549         * scdaemon.h (send_status_info): Mark with sentinel attribute.
550
551 2006-10-02  Marcus Brinkmann  <marcus@g10code.de>
552
553         * command.c (update_reader_status_file): Increase buffer of
554         NUMBUF2 (fixing typo).
555
556 2006-09-24  Marcus Brinkmann  <marcus@g10code.de>
557
558         * app-openpgp.c (do_sign): Advance INDATA by the SHA1 resp. RMD160
559         prefix length.
560
561 2006-09-14  Werner Koch  <wk@g10code.com>
562
563         Replaced all call gpg_error_from_errno(errno) by
564         gpg_error_from_syserror().
565
566         * command.c (scd_command_handler): Replaced
567         init_connected_socket_server by init_socket_server_ext.
568
569 2006-09-07  Werner Koch  <wk@g10code.com>
570
571         * command.c (update_reader_status_file): Execute an event handler
572         if available.
573
574 2006-09-06  Werner Koch  <wk@g10code.com>
575
576         * apdu.c (pcsc_end_transaction): 
577         * pcsc-wrapper.c (pcsc_end_transaction: Fixed dclaration.
578         Reported by Bob Dunlop.
579
580         * scdaemon.h (CTRL,APP): Removed and changed everywhere to
581         ctrl_t/app_t.
582
583         Replaced all Assuan error codes by libgpg-error codes.  Removed
584         all map_to_assuan_status and map_assuan_err.
585         
586         * scdaemon.c (main): Call assuan_set_assuan_err_source to have Assuan
587         switch to gpg-error codes.
588         * command.c (set_error): Adjusted.
589
590 2006-09-02  Marcus Brinkmann  <marcus@g10code.de>
591
592         * command.c (get_reader_slot): Return the slot_table index, not
593         the APDU slot number.
594         (update_reader_status_file): Use the slot_table index in the
595         update_card_removed invocation.
596
597 2006-09-01  Marcus Brinkmann  <marcus@g10code.de>
598
599         * command.c (cmd_getinfo): Handle status command.
600
601 2006-08-30  Marcus Brinkmann  <marcus@g10code.de>
602
603         * command.c (do_reset): Delay resetting CTRL->reader_slot until
604         after update_card_removed invocation.
605
606 2006-08-28  Marcus Brinkmann  <marcus@g10code.de>
607
608         * app-openpgp.c (do_decipher, do_sign): Allow "OPENPGP.2"
609         resp. "OPENPGP.1" for KEYIDSTR.
610
611 2006-08-21  Werner Koch  <wk@g10code.com>
612
613         * pcsc-wrapper.c (handle_open, handle_close): Reset card and
614         protocol on error/close.
615         (handle_status): Don't set the state if the state is unknown.
616         (handle_reset): Ignore an error if already disconnected.  May
617         happen due to system wake-up after hibernation.  Suggested by Bob
618         Dunlop.
619
620 2006-06-28  Werner Koch  <wk@g10code.com>
621
622         * app-openpgp.c (do_writekey): Fixed computation of memmove
623         length.  This led to garbled keys if E was larger than one byte.
624         Thanks to Achim Pietig for hinting at the garbled E.
625
626 2006-06-09  Marcus Brinkmann  <marcus@g10code.de>
627
628         * Makefile.am (scdaemon_LDADD): Add $(NETLIBS).
629
630 2006-04-14  Marcus Brinkmann  <marcus@g10code.de>
631
632         * app.c (select_application): Cover up a slot mismatch error in
633         case it happens (it shouldn't happen).
634         (release_application): Use APP->slot.  Lock the reader.
635         (application_notify_card_removed): Lock the reader.
636
637 2006-04-11  Werner Koch  <wk@g10code.com>
638
639         * command.c (hex_to_buffer): New.
640         (cmd_apdu): New.
641
642 2006-04-03  Werner Koch  <wk@g10code.com>
643
644         * scdaemon.c [__GLIBC__]: Default to libpcsclite.so.1.
645
646 2006-03-21  Werner Koch  <wk@g10code.com>
647
648         * command.c (cmd_pksign): Add --hash option.
649
650 2006-03-01  Werner Koch  <wk@g10code.com>
651
652         * command.c (status_file_update_lock): New.
653         (scd_update_reader_status_file): Use lock and factor existing code
654         out to ..
655         (update_reader_status_file): .. this.
656         (do_reset): Use the lock and call update_reader_status_file.
657
658 2006-02-20  Werner Koch  <wk@g10code.com>
659
660         * apdu.c (open_pcsc_reader): Fixed double free.  Thanks to Moritz.
661
662 2006-02-09  Werner Koch  <wk@g10code.com>
663
664         * command.c (get_reader_slot, do_reset) 
665         (scd_update_reader_status_file): Rewrote.
666
667         * app.c (release_application): Factored code out to ..
668         (deallocate_app): new function.
669         (select_application): Introduce new saved application stuff.
670         (application_notify_card_removed): New.
671         * command.c (update_card_removed): Call it here.
672         (do_reset): And here.
673
674         * app.c (check_application_conflict): New.
675         * command.c (open_card): Use it here.
676         (cmd_restart): New command.
677
678         * command.c (cmd_lock): Fixed --wait option to actually terminate.
679
680 2006-02-08  Werner Koch  <wk@g10code.com>
681
682         * ccid-driver.c (ccid_get_atr): Read Parameter and select T=1
683         using these parameters.
684         (scan_or_find_devices): Check for NULL r_fd.
685
686 2006-02-02  Werner Koch  <wk@g10code.com>
687
688         * ccid-driver.c (special_transport): New
689         (ccid_open_reader, do_close_reader, ccid_shutdown_reader)
690         (bulk_out, bulk_in): Add support for CardMan 4040 reader.
691
692         * ccid-driver.c (scan_or_find_devices): Factored most code out to
693         (scan_or_find_usb_device): .. new.
694         (make_reader_id): Fixed vendor mask.
695
696 2006-01-01  Werner Koch  <wk@g10code.com>
697
698         * app-openpgp.c (do_sign): Give user error if hash algorithm is
699         not supported by the card.
700
701 2005-12-06  Werner Koch  <wk@g10code.com>
702
703         * apdu.c (open_pcsc_reader): Check that pcsc-wrapper is actually
704         installed.
705
706 2005-11-23  Werner Koch  <wk@g10code.com>
707
708         * app-nks.c (verify_pin): Give a special error message for a Nullpin.
709
710 2005-10-29  Werner Koch  <wk@g10code.com>
711
712         * ccid-driver.c (send_escape_cmd): New args RESULT, RESULTLEN and
713         RESULTMAX.  Changed all callers.
714         (ccid_transceive_escape): New.
715
716 2005-10-27  Werner Koch  <wk@g10code.com>
717
718         * apdu.c [__CYGWIN__]: Make cygwin environment similar to _WIN32.
719         Suggested by John P. Clizbe.
720         * scdaemon.c [__CYGWIN__]: Set default PC/SC driver to winscard.dll.
721
722 2005-10-19  Werner Koch  <wk@g10code.com>
723
724         * ccid-driver.h (CCID_DRIVER_ERR_NO_KEYPAD): New.
725         * apdu.h (SW_HOST_NO_KEYPAD): New.
726         * iso7816.h (struct iso7816_pininfo_s): New.
727         * iso7816.c (map_sw): Support new code.
728         (iso7816_check_keypad): New.
729         (iso7816_verify_kp, iso7816_change_reference_data_kp) 
730         (iso7816_reset_retry_counter_kp): New.  Extended versions of the
731         original functions.
732         * apdu.c (host_sw_string): Support new code. 
733         (reader_table_s): New field CHECK_KEYPAD.
734         (new_reader_slot, open_ct_reader, open_pcsc_reader) 
735         (open_ccid_reader, open_rapdu_reader): Initialize it.
736         (check_ccid_keypad): New.
737         (apdu_check_keypad): New.
738         (apdu_send_le): Factored all code out to ...
739         (send_le): .. new.  Takes an additional arg; changed all callers
740         of the orginal function to use this one with a NULL for the new
741         arg.
742         (apdu_send_simple_kp): New.
743         (ct_send_apdu, pcsc_send_apdu, my_rapdu_send_apdu) 
744         (send_apdu_ccid): New arg PININFO.
745         (send_apdu_ccid): Use the new arg.
746
747         * scdaemon.c: New option --disable-keypad.
748
749 2005-10-08  Marcus Brinkmann  <marcus@g10code.de>
750
751         * Makefile.am (scdaemon_LDADD): Add ../gl/libgnu.a after
752         ../common/libcommon.a.
753
754 2005-09-20  Werner Koch  <wk@g10code.com>
755
756         * app-dinsig.c (verify_pin): Try ISO 9564 BCD encoding.
757
758         * iso7816.c (iso7816_select_application): Add arg FLAGS.  Changed
759         all callers to pass 0.
760         * app-openpgp.c (app_select_openpgp): But this one requires a
761         special flag.
762
763         * app-p15.c (app_select_p15): Don't use select application for the
764         BELPIC.
765
766 2005-09-09  Werner Koch  <wk@g10code.com>
767
768         * pcsc-wrapper.c (main): Removed bogus free.
769
770         * app-p15.c (do_auth): New.
771         (do_getattr): New attribs $AUTHKEYID and $DISPSERIALNO.
772         * app-openpgp.c (do_getattr): Ditto.
773
774 2005-09-08  Werner Koch  <wk@g10code.com>
775
776         * app-openpgp.c (do_getattr): New key $AUTHKEYID.
777
778 2005-09-06  Werner Koch  <wk@g10code.com>
779
780         * app-p15.c (do_sign): Tweaked for BELPIC cards.
781         (read_home_df): New arg R_BELPIC.
782         (app_select_p15): Set card type for BELPIC.
783
784 2005-09-05  Werner Koch  <wk@g10code.com>
785
786         * iso7816.c (iso7816_select_path): New.
787         * app-p15.c (select_ef_by_path): Allow for direct path selection.
788         (app_select_p15): Try using the Belgian variant of pkcs#15.
789         (read_home_df): New.
790         (read_ef_odf): Generalized.
791         (read_ef_tokeninfo): New.
792         (read_p15_info): Set serialnumber from TokenInfo.
793         (app_select_p15): Don't munge serialNumber - that must be done
794         only once.
795
796         * iso7816.c (iso7816_read_binary): Use Le=0 when reading all
797         data.  Handle 6C00 error and take 6B00 as indication for EOF.
798         * apdu.h (SW_EXACT_LENGTH_P): New.
799         * apdu.c (new_reader_slot, reset_pcsc_reader, pcsc_get_status) 
800         (open_pcsc_reader): Set new reader state IS_T0.
801         (apdu_send_le): When doing T=0 make sure not to send Lc and Le.
802         Problem reported by Carl Meijer.
803         (apdu_send_direct): Initialize RESULTLEN.
804         * pcsc-wrapper.c (handle_status): Return the current protocol as
805         a new third word.
806
807 2005-08-05  Werner Koch  <wk@g10code.com>
808
809         * apdu.c (open_rapdu_reader): Set the reader number.
810
811 2005-07-05  Werner Koch  <wk@g10code.com>
812
813         * app-openpgp.c (do_readkey): Return a mallcoed copy of the key as
814         required by the description.  Thanks to Moritz for tracking this
815         problem down.
816
817 2005-06-21  Werner Koch  <wk@g10code.com>
818
819         * scdaemon.c (main): ifdef call to ccid_set_debug_level.
820
821         * apdu.c (reset_pcsc_reader, open_pcsc_reader): Cast size_t to
822         ulong for printf.
823
824 2005-06-06  Werner Koch  <wk@g10code.com>
825
826         * scdaemon.c (main): New option --debug-allow-core-dump. 
827
828 2005-06-03  Werner Koch  <wk@g10code.com>
829
830         * scdaemon.c (handle_connections): Make sure that the signals we
831         are handling are not blocked.Block signals while creating new
832         threads.
833         (handle_connections): Include the file descriptor into the name of
834         the thread.
835
836 2005-06-02  Werner Koch  <wk@g10code.com>
837
838         * app.c (app_dump_state, dump_mutex_state): New.
839         * scdaemon.c (handle_signal): Print it on SIGUSR1.
840
841         * app-openpgp.c (do_writekey): Typo fix.
842
843         * command.c (open_card): Check for locked state even if an
844         application context is available.
845
846         * app-common.h: Add REF_COUNT field.
847         * app.c (release_application, select_application): Implement
848         reference counting to share the context beween connections.
849
850         * app.c (lock_reader, unlock_reader): Take SLOT instead of APP as
851         argument.  Changed all callers.
852         (select_application): Unlock the reader on error.  This should fix
853         the hangs I noticed last week.
854
855         * scdaemon.h: Removed card_ctx_t cruft.
856
857 2005-06-01  Werner Koch  <wk@g10code.com>
858
859         * scdaemon.c: Include mkdtemp.h.
860
861 2005-05-31  Werner Koch  <wk@g10code.com>
862
863         * tlv.c [GNUPG_MAJOR_VERSION==1]: Define constants instead of
864         including a gnupg 1.4 header.
865
866 2005-05-30  Werner Koch  <wk@g10code.com>
867
868         * tlv.c: Add hack to compile without gpg-error.h when used with
869         GnuPG 1.4.
870
871 2005-05-23  Werner Koch  <wk@g10code.com>
872
873         * Makefile.am: Do not build sc-copykeys anymore.
874
875         * app-openpgp.c (app_openpgp_storekey, app_openpgp_readkey)
876         (app_openpgp_cardinfo): Removed.
877
878         * ccid-driver.c (parse_ccid_descriptor): SCR335 FW version 5.14 is
879         good.
880         (do_close_reader): Never do a reset. The caller should instead
881         make sure that the reader has been closed properly.  The new retry
882         code in ccid_slot_status will make sure that the readersatrts up
883         fine even if the last process didn't closed the USB connection
884         properly.
885         (ccid_get_atr): For certain readers try switching to ISO mode.
886         Thanks to Ludovic Rousseau for this hint and the magic numbers.
887         (print_command_failed): New.
888         (bulk_in): Use it here. Add new arg NO_DEBUG.
889         (ccid_slot_status): Disabled debugging.
890
891 2005-05-21  Werner Koch  <wk@g10code.com>
892
893         * scdaemon.c (handle_signal): Print thread info on SIGUSR1.
894
895 2005-05-20  Werner Koch  <wk@g10code.com>
896
897         * ccid-driver.c: Replaced macro DEBUG_T1 by a new debug level.
898         (parse_ccid_descriptor): Mark SCR335 firmware version 5.18 good.
899         (ccid_transceive): Arghhh.  The seqno is another bit in the
900         R-block than in the I block, this was wrong at one place.
901
902         * scdaemon.c: New options --debug-ccid-driver and
903         --debug-disable-ticker.
904
905         * app-openpgp.c (do_genkey, do_writekey): Factored code to check
906         for existing key out into ..
907         (does_key_exist): .. New function.
908
909 2005-05-19  Werner Koch  <wk@g10code.com>
910
911         * tlv.c (parse_sexp): New.
912
913         * command.c (cmd_writekey): New.
914         * app.c (app_writekey): New.
915         * app-common.c (app_t): Add function ptr WRITEKEY.
916         * app-openpgp.c (do_writekey): New.
917
918         * app-openpgp.c (do_readkey) [GNUPG_MAJOR_VERSION==1]: Return error.
919         * app-common.h (app_t) [GNUPG_MAJOR_VERSION==1]: Add a field to
920         store the Assuan context.
921
922 2005-05-17  Werner Koch  <wk@g10code.com>
923
924         * scdaemon.c: Removed non-pth code paths.
925         (create_socket_name, create_server_socket): New.  Taken from
926         ../agent/gpg-agent.
927         (cleanup): Changed to adjust for SOCKET_NAME now being malloced.
928         (ticker_thread): Always use pth_event_occurred; it is again
929         defined for all decent PTH versions.
930         (handle_connections): New. Based on the gpg-agent code.
931         (start_connection_thread): Ditto.
932         (ticker_thread): Removed.
933         (cleanup_sh): Removed.
934         (main): Run the handler for the pipe server in a separate
935         thread.  This replaces the old ticker thread.
936         (scd_get_socket_name): New.
937         * command.c (cmd_getinfo): New command GETINFO.
938         (scd_command_handler): Renamed argument and changed code to use an
939         already connected FD.
940
941 2005-05-15  Werner Koch  <wk@g10code.com>
942
943         * app.c, app-common.h, app-nks.c, app-p15.c, app-dinsig.c
944         * app-openpgp.c: Change most function return types from int to
945         gpg_error_t.
946         * command.c (pin_cb): Ditto.
947         * sc-copykeys.c (pincb): Ditto.
948
949         * app.c (lock_reader, unlock_reader): New.  Changed call handler
950         wrappers to make use of these functions.
951
952 2005-05-07  Werner Koch  <wk@g10code.com>
953
954         * ccid-driver.c (do_close_reader): Don't do a reset before close.
955         Some folks reported that it makes the SCR335 hang less often.
956         Look at the source on how to re-enable it.
957
958 2005-04-27  Werner Koch  <wk@g10code.com>
959
960         * app-p15.c (micardo_mse): New.
961         (do_sign): Call it.
962         * iso7816.c (iso7816_manage_security_env): Allow passing DATA as
963         NULL to indicate an empty Lc.
964         * tlv.c (find_tlv): Check that a found object fits into the
965         buffer.
966         (find_tlv_unchecked): New as replacement for the old non-checking
967         variant.
968         * app.c (select_application): Keep on using the non-checking
969         variant.
970         * app-openpgp.c (get_one_do, dump_all_do): Ditto.
971
972         
973         Removal of the old OpenSC based code.
974         
975         * app-p15.c: New.  Basic support for pkcs15 cards without OpenSC.
976         There are quite a couple of things missing but at least I can use
977         my old TCOS cards from the Aegypten-1 development for signing.
978         * app.c (select_application): Detect pkcs15 applications.
979         * Makefile.am (scdaemon_SOURCES): Removed card.c, card-common.h
980         and card-p15.c because they are now obsolete. Added app-p15.c.
981         Removed all OpenSC stuff.
982         * command.c (do_reset, open_card, cmd_serialno, cmd_learn) 
983         (cmd_readcert, cmd_readkey, cmd_pksign, cmd_pkdecrypt): Removed
984         all special cases for the old card.c based mechanisms.
985         * scdaemon.c, apdu.c: Removed all special cases for OpenSC.
986
987 2005-04-20  Werner Koch  <wk@g10code.com>
988
989         * command.c: Use GPG_ERR_LOCKED instead of EBUSY.
990
991 2005-04-14  Werner Koch  <wk@g10code.com>
992
993         * app-openpgp.c (retrieve_key_material): Rewritten.  Return a
994         proper error code.
995         (retrieve_next_token): Removed.
996         (retrieve_fpr_from_card): Rewritten to make use of DO caching and
997         to take the KEYNO as arg.
998         (get_public_key): Renamed variable for clarity.
999
1000 2005-04-12  Werner Koch  <wk@g10code.com>
1001
1002         Basic support for several sessions.
1003         
1004         * command.c (scd_command_handler): Replace the primary_connection
1005         stuff by a real connection list.  Release the local context on
1006         exit.
1007         (scd_update_reader_status_file): Update accordingly.  Send signal
1008         to all connections who registered an event signal.
1009         (cmd_lock, cmd_unlock, register_commands): New commands LOCK and
1010         UNLOCK.
1011         (cmd_setdata, cmd_pksign, cmd_pkauth, cmd_pkdecrypt, cmd_setattr) 
1012         (cmd_genkey, cmd_passwd, cmd_checkpin): Return an error if reader
1013         is locked.
1014         (do_reset): Handle locking.
1015         (open_card): Ditto.  Share the reader slot with other sessions.
1016         (get_reader_slot): New.
1017         (update_card_removed): New.  Use it in the TEST_CARD_REMOVAL macro.
1018
1019 2005-04-07  Werner Koch  <wk@g10code.com>
1020
1021         * app-openpgp.c (do_check_pin): Add hack to allow verification of
1022         CHV3.
1023         (get_public_key): Don't use gcry functions to create S-expressions.
1024         (do_deinit, do_readkey, do_genkey, send_keypair_info): Adjust for
1025         above change.
1026
1027 2005-03-29  Moritz Schulte  <moritz@g10code.com>
1028
1029         * app-openpgp.c (retrieve_fpr_from_card): New function.
1030         (retrieve_next_token): New function.
1031         (retrieve_key_material): New function.
1032         (get_public_key): Implement retrival of key through expernal
1033         helper (gpg) in case the openpgp card is not cooperative enough.
1034
1035 2005-03-16  Werner Koch  <wk@g10code.com>
1036
1037         * ccid-driver.c (parse_ccid_descriptor): Make SCM workaround
1038         reader type specific.
1039         (scan_or_find_devices): Do not check the interface subclass in the
1040         SPR532 kludge, as this depends on the firmware version.
1041         (ccid_get_atr): Get the Slot status first.  This solves the
1042         problem with readers hanging on recent Linux 2.6.x.
1043         (bulk_in): Add argument TIMEOUT and changed all callers to pass an
1044         appropriate one.  Change the standard timeout from 10 to 5 seconds.
1045         (ccid_slot_status): Add a retry code with an initial short timeout.
1046         (do_close_reader): Do an usb_reset before closing the reader.
1047
1048 2005-02-25  Werner Koch  <wk@g10code.com>
1049
1050         * app-openpgp.c (get_public_key): Make sure not to return negative
1051         numbers.
1052         (do_sign): Allow passing of indata with algorithm prefix.
1053         (do_auth): Allow OPENPGP.3 as an alternative ID.
1054
1055         * app.c (app_getattr): Return just the S/N but not the timestamp.
1056
1057 2005-02-24  Werner Koch  <wk@g10code.com>
1058
1059         * app.c (app_getattr): Return APPTYPE or SERIALNO type even if the
1060         application does dot support the getattr call.
1061
1062         * app-openpgp.c (get_one_do): Never try to get a non cacheable
1063         object from the cache.
1064         (get_one_do): Add new arg to return an error code.  Changed all
1065         callers.
1066         (do_getattr): Let it return a proper error code.
1067
1068         * app.c (select_application): Return an error code and the
1069         application context in an new arg.
1070         * command.c (open_card): Adjusted for that.  Don't use the
1071         fallback if no card is present.  Return an error if the card has
1072         been removed without a reset.
1073         (do_reset, cmd_serialno): Clear that error flag.
1074         (TEST_CARD_REMOVAL): New. Use it with all command handlers.
1075         (scd_update_reader_status_file): Set the error flag on all changes.
1076
1077         * scdaemon.c (ticker_thread): Termintate if a shutdown is pending.
1078
1079         * apdu.c: Added some PCSC error codes.
1080         (pcsc_error_to_sw): New.
1081         (reset_pcsc_reader, pcsc_get_status, pcsc_send_apdu) 
1082         (open_pcsc_reader): Do proper error code mapping.
1083
1084 2005-03-16  Werner Koch  <wk@g10code.com>
1085
1086         * ccid-driver.c (parse_ccid_descriptor): Make SCM workaround
1087         reader type specific.
1088         (scan_or_find_devices): Do not check the interface subclass in the
1089         SPR532 kludge, as this depends on the firmware version.
1090         (ccid_get_atr): Get the Slot status first.  This solves the
1091         problem with readers hanging on recent Linux 2.6.x.
1092
1093 2005-02-22  Werner Koch  <wk@g10code.com>
1094
1095         * app-openpgp.c (app_local_s): New field PK.
1096         (do_deinit, do_genkey, app_openpgp_storekey): Clear it.
1097         (get_public_key, send_keypair_info): New.
1098         (do_learn_status): Send KEYPAIR info
1099
1100         * app-common.h (app_ctx_t): Add function pointer READKEY.
1101         * app.c (app_readkey): New.
1102         * command.c (cmd_readkey): Use READKEY function if possible.
1103
1104 2005-01-26  Werner Koch  <wk@g10code.com>
1105
1106         * ccid-driver.c (parse_ccid_descriptor): Need the CSM workaround
1107         also for newer firmware versions.  Need to get a list of fixed
1108         firmware versions and use that.
1109
1110 2005-01-25  Werner Koch  <wk@g10code.com>
1111
1112         * apdu.c (apdu_send_le, apdu_send_direct): Fix some compiler
1113         warnings.
1114
1115         * app-openpgp.c (get_cached_data): New arg GET_IMMEDIATE to bypass
1116         the cache.  Changed all callers.
1117         (get_one_do): Bypass the cache if the value would have been read
1118         directly for v1.1 cards.It makes things a bit slower but obnly for
1119         1.0 cards and there are not that many cards out in the wild.  This
1120         is required to fix a caching bug when generating new keys; as a
1121         side effect of the retrieval of the the C4 DO from the 6E DO the
1122         cached fingerprint will get updated to the old value and later
1123         when signing the generated key the checking of the fingerprint
1124         fails because it won't match the new one.  Thanks to Moritz for
1125         analyzing this problem.
1126         (verify_chv3): Removed the CHV status reread logic because we
1127         won't cache the C4 DO anymore.
1128
1129 2004-12-28  Werner Koch  <wk@g10code.com>
1130
1131         * ccid-driver.c (find_endpoint): New.
1132         (scan_or_find_devices): Add new args to return endpoint info and
1133         interface number.
1134         (ccid_open_reader, ccid_shutdown_reader): Take care of these new
1135         args.
1136         (bulk_in, bulk_out): Use the correct endpoints.
1137         (ccid_transceive_apdu_level): New.
1138         (ccid_transceive): Divert to above.
1139         (parse_ccid_descriptor): Allow APDU level exchange mode.
1140         (do_close_reader): Pass the interface number to usb_release_interface.
1141
1142 2004-12-21  Werner Koch  <wk@g10code.com>
1143
1144         * scdaemon.c (main): Use default_homedir().
1145
1146 2004-12-18  Werner Koch  <wk@g10code.com>
1147
1148         * scdaemon.c (main) [W32]: Remove special Pth initialize..
1149
1150         * scdaemon.h (map_assuan_err): Define in terms of
1151         map_assuan_err_with_source.
1152
1153 2004-12-15  Werner Koch  <wk@g10code.com>
1154
1155         * scdaemon.c [W32]: Various hacks to make it run under W32.
1156
1157         * command.c (scd_update_reader_status_file) [W32]: Don't use kill.
1158
1159         * apdu.c [W32]: Disable use of pcsc_wrapper.
1160
1161         * Makefile.am (scdaemon_LDADD): Reorder libs.
1162         (sc_copykeys_LDADD): Add libassuan because it is needed for W32. 
1163
1164 2004-12-06  Werner Koch  <wk@g10code.com>
1165
1166         * Makefile.am (pkglib_PROGRAMS): Build only for W32.
1167
1168 2004-10-22  Werner Koch  <wk@g10code.com>
1169
1170         * app-openpgp.c (verify_chv3): The minium length for CHV3 is
1171         8. Changed string to match the other ones.
1172
1173 2004-10-21  Werner Koch  <wk@g10code.com>
1174
1175         * app-openpgp.c (do_sign): Replace asprintf by direct allocation.
1176         This avoids problems with missing vasprintf implementations in
1177         gnupg 1.4.
1178
1179         * app-common.h (app_openpgp_storekey: Add prototype. 
1180
1181 2004-10-20  Werner Koch  <wk@g10code.com>
1182
1183         * sc-investigate: Removed.
1184         * Makefile.am (sc_investigate): Removed.
1185         
1186         * pcsc-wrapper.c (load_pcsc_driver): Load get_status_change func.
1187         (handle_open): Succeed even without a present card.
1188         (handle_status, handle_reset): New.
1189         
1190         * apdu.c (apdu_open_reader): Load pcsc_get_status_change fucntion.
1191         (pcsc_get_status): Implemented.
1192         (reset_pcsc_reader): Implemented.
1193         (open_pcsc_reader): Succeed even with no card inserted.
1194         (open_ccid_reader): Set LAST_STATUS.
1195
1196         * iso7816.c (iso7816_select_application): Always use 0 for P1.
1197
1198 2004-10-18  Werner Koch  <wk@g10code.com>
1199
1200         * ccid-driver.c (ccid_get_atr): Reset T=1 state info.
1201
1202 2004-10-14  Werner Koch  <wk@g10code.com>
1203
1204         * app-openpgp.c (parse_login_data): New. 
1205         (app_select_openpgp): Call it.
1206         (do_setattr): Reparse it after change.
1207
1208 2004-10-06  Werner Koch  <wk@g10code.de>
1209
1210         * ccid-driver.c (ccid_open_reader): Store the vendor ID.
1211         (ccid_transceive_secure): New.
1212         (parse_ccid_descriptor): Workaround for an SCM reader problem.
1213
1214 2004-10-04  Werner Koch  <wk@g10code.de>
1215
1216         * ccid-driver.c (send_escape_cmd): New.
1217
1218 2004-09-30  Werner Koch  <wk@g10code.com>
1219
1220         * Makefile.am: Adjusted for gettext 0.14.
1221
1222         * app-openpgp.c (do_sign): Add the error string to the verify
1223         failed messages.
1224
1225 2004-09-27  Werner Koch  <wk@g10code.com>
1226
1227         From gnupg 1.3
1228
1229         * app-openpgp.c: Made all strings translatable.
1230         (verify_chv3) [GNUPG_MAJOR_VERSION]: Make opt.allow_admin
1231         available for use in gnupg 2. 
1232         (verify_chv3): Reimplemented countdown showing to use only
1233         functions from this module.  Flush the CVH status cache on a
1234         successful read.
1235         (get_one_do): Hack to bypass the cache for cards versions > 1.0.
1236         (store_fpr): Store the creation date for card version > 1.0.
1237
1238         * app-openpgp.c (app_openpgp_storekey): Call flush_cache.
1239         (get_cached_data): Move local data initialization to ..
1240         (app_select_openpgp): .. here. Read some flags for later use.
1241         (do_getattr): New read-only attribute EXTCAP.
1242         
1243         * apdu.c (open_pcsc_reader): Do not print empty reader string.
1244
1245         * ccid-driver.c (do_close_reader): Factored some code out from ...
1246         (ccid_close_reader): ..here.
1247         (ccid_shutdown_reader): New.
1248
1249         * apdu.c (apdu_shutdown_reader): New.
1250         (shutdown_ccid_reader): New.
1251
1252         * apdu.c (open_ccid_reader): New arg PORTSTR.  Pass it to
1253         ccid_open_reader.
1254         (apdu_open_reader): Pass portstr to open_ccid_reader.
1255         (apdu_open_reader): No fallback if a full CCID reader id has been
1256         given.
1257
1258         * ccid-driver.c (ccid_get_reader_list): New.
1259         (ccid_open_reader): Changed API to take a string for the reader.
1260         Removed al the cruft for the libusb development vesion which seems
1261         not to be maintained anymore and there are no packages anyway.
1262         The stable library works just fine.
1263         (struct ccid_reader_id_s): Deleted and replaced everywhere by a
1264         simple string.
1265         (usb_get_string_simple): Removed.
1266         (bulk_in): Do valgrind hack here and not just everywhere.
1267
1268         * ccid-driver.c (read_device_info): Removed.
1269         (make_reader_id, scan_or_find_devices): New.
1270         (ccid_open_reader): Simplified by make use of the new functions.
1271         (ccid_set_debug_level): New.  Changed the macros to make use of
1272         it.  It has turned out that it is often useful to enable debugging
1273         at runtime so I added this option.
1274
1275         From gnupg 1.3 - David Shaw  <dshaw@jabberwocky.com>
1276
1277         * app-openpgp.c (verify_chv3): Show a countdown of how many wrong
1278         admin PINs can be entered before the card is locked.
1279
1280         * app-openpgp.c (get_cached_data): Avoid mallocing zero since it
1281         breaks us when using --enable-m-guard.
1282
1283         * ccid-driver.c (usb_get_string_simple): Replacement function to
1284         work with older libusb.
1285
1286         * ccid-driver.c (read_device_info): Fix segfault when usb device
1287         is not accessible.
1288         (ccid_open_reader): Allow working with an even older version of
1289         libusb (usb_busses global instead of usb_get_busses()).
1290
1291 2004-09-11  Werner Koch  <wk@g10code.com>
1292
1293         * app-openpgp.c (app_select_openpgp): Its app_munge_serialno and
1294         not app_number_serialno.
1295
1296 2004-08-20  Werner Koch  <wk@g10code.de>
1297
1298         * app.c (select_application): Fixed serial number extraction and
1299         added the BMI card workaround.
1300         (app_munge_serialno): New.
1301         * app-openpgp.c (app_select_openpgp): Try munging serialno.
1302
1303 2004-08-05  Werner Koch  <wk@g10code.de>
1304
1305         * scdaemon.c (main): New option --disable-application.
1306         * app.c (is_app_allowed): New.
1307         (select_application): Use it to check for disabled applications.
1308
1309         * ccid-driver.h (CCID_DRIVER_ERR_ABORTED): New.
1310         * ccid-driver.c (ccid_open_reader): Support the stable 0.1 version
1311         of libusb.
1312         (ccid_get_atr): Handle short messages.
1313
1314         * apdu.c (my_rapdu_get_status): Implemented.
1315
1316 2004-07-27  Moritz Schulte  <moritz@g10code.com>
1317
1318         * apdu.c: Include <signal.h>.
1319
1320         * Makefile.am: Use @DL_LIBS@ instead of -ldl.
1321
1322 2004-07-22  Werner Koch  <wk@g10code.de>
1323
1324         * Makefile.am: Make OpenSC lib link after libgcrypt. Do not link
1325         to pth.
1326         * apdu.c: Don't use Pth if we use OpenSC.
1327         * sc-investigate.c, scdaemon.c: Disable use of pth if OpenSC is used. 
1328
1329         * scdaemon.c (main): Bumbed thread stack size up to 512k.
1330
1331 2004-07-16  Werner Koch  <wk@gnupg.org>
1332
1333         * apdu.c (reader_table_s):  Add function pointers for the backends.
1334         (apdu_close_reader, apdu_get_status, apdu_activate) 
1335         (send_apdu): Make use of them.
1336         (new_reader_slot): Intialize them to NULL.
1337         (dump_ccid_reader_status, ct_dump_reader_status): New.
1338         (dump_pcsc_reader_status): New.
1339         (open_ct_reader, open_pcsc_reader, open_ccid_reader) 
1340         (open_osc_reader, open_rapdu_reader): Intialize function pointers.
1341         (ct_activate_card, ct_send_apdu, pcsc_send_apdu, osc_send_apdu) 
1342         (error_string): Removed.  Replaced by apdu_strerror.
1343         (get_ccid_error_string): Removed.
1344         (ct_activate_card): Remove the unused loop.
1345         (reset_ct_reader): Implemented.
1346         (ct_send_apdu): Activate the card if not yet done.
1347         (pcsc_send_apdu): Ditto.
1348
1349 2004-07-15  Werner Koch  <wk@gnupg.org>
1350
1351         * ccid-driver.h: Add error codes.
1352         * ccid-driver.c: Implement more or less proper error codes all
1353         over the place.
1354
1355         * apdu.c (apdu_send_direct): New.
1356         (get_ccid_error_string): Add some error code mappings.
1357         (send_apdu): Pass error codes along for drivers already supporting
1358         them.
1359         (host_sw_string): New.
1360         (get_ccid_error_string): Use above.
1361         (send_apdu_ccid): Reset the reader if it has not yet been done.
1362         (open_ccid_reader): Don't care if the ATR can't be read.
1363         (apdu_activate_card): New.
1364         (apdu_strerror): New.
1365         (dump_reader_status): Only enable it with opt.VERBOSE.
1366         * iso7816.c (map_sw): Add mappings for the new error codes.
1367
1368 2004-07-02  Werner Koch  <wk@gnupg.org>
1369
1370         * apdu.c (open_ct_reader, open_pcsc_reader, open_ccid_reader)
1371         (reset_ccid_reader, open_osc_reader): Call dump_reader_status only
1372         in verbose mode.
1373
1374 2004-07-01  Werner Koch  <wk@gnupg.org>
1375
1376         * sc-investigate.c: Initialize Pth which is now required.
1377         (interactive_shell): New command "readpk".
1378
1379         * app-openpgp.c (do_getattr): Fix for sending CA-FPR.
1380
1381 2004-06-30  Werner Koch  <wk@gnupg.org>
1382
1383         * app-openpgp.c (app_openpgp_readkey): Fixed check for valid
1384         exponent.
1385
1386 2004-06-18  Werner Koch  <wk@g10code.com>
1387
1388         * sc-investigate.c (my_read_line): Renamed from read_line.
1389
1390 2004-06-16  Werner Koch  <wk@gnupg.org>
1391
1392         * apdu.c (osc_get_status): Fixed type in function name. Noted by
1393         Axel Thimm.  Yes, I didn't tested it with OpenSC :-(.
1394
1395 2004-04-28  Werner Koch  <wk@gnupg.org>
1396
1397         * app-openpgp.c (do_setattr): Sync FORCE_CHV1.
1398
1399 2004-04-27  Werner Koch  <wk@gnupg.org>
1400
1401         * app-common.h: Do not include ksba.h for gnupg 1.
1402
1403 2004-04-26  Werner Koch  <wk@gnupg.org>
1404
1405         * app-common.h: New members FNC.DEINIT and APP_LOCAL.
1406         * app.c (release_application): Call new deconstructor.
1407         * app-openpgp.c (do_deinit): New.
1408         (get_cached_data, flush_cache_item, flush_cache_after_error)
1409         (flush_cache): New.
1410         (get_one_do): Replaced arg SLOT by APP.  Make used of cached data.
1411         (verify_chv2, verify_chv3): Flush some cache item after error.
1412         (do_change_pin): Ditto.
1413         (do_sign): Ditto.
1414         (do_setattr): Flush cache item.
1415         (do_genkey): Flush the entire cache.
1416         (compare_fingerprint): Use cached data.
1417
1418         * scdaemon.c (main): Do the last change the usual way. This is so
1419         that we can easily test for versioned config files above.
1420
1421 2004-04-26  Marcus Brinkmann  <marcus@g10code.de>
1422
1423         * scdaemon.c (main): For now, always print default filename for
1424         --gpgconf-list, and never /dev/null.
1425
1426 2004-04-21  Werner Koch  <wk@gnupg.org>
1427
1428         * command.c (scd_update_reader_status_file): Send a signal back to
1429         the client.
1430         (option_handler): Parse the new event-signal option.
1431
1432         * scdaemon.c (handle_signal): Do not use SIGUSR{1,2} anymore for
1433         changing the verbosity.
1434
1435 2004-04-20  Werner Koch  <wk@gnupg.org>
1436
1437         * command.c (scd_update_reader_status_file): Write status files.
1438
1439         * app-help.c (app_help_read_length_of_cert): Fixed calculation of
1440         R_CERTOFF.
1441
1442         * pcsc-wrapper.c: New.
1443         * Makefile.am (pkglib_PROGRAMS): Install it here.
1444         * apdu.c (writen, readn): New.
1445         (open_pcsc_reader, pcsc_send_apdu, close_pcsc_reader): Use the
1446         pcsc-wrapper if we are using Pth.
1447         (apdu_send_le): Reinitialize RESULTLEN.  Handle SW_EOF_REACHED
1448         like SW_SUCCESS.
1449
1450 2004-04-19  Werner Koch  <wk@gnupg.org>
1451
1452         * ccid-driver.c (parse_ccid_descriptor): Store some of the reader
1453         features away.  New arg HANDLE
1454         (read_device_info): New arg HANDLE. Changed caller.
1455         (bulk_in): Handle time extension requests.
1456         (ccid_get_atr): Setup parameters and the IFSD.
1457         (compute_edc): New. Factored out code.
1458         (ccid_transceive): Use default NADs when required.
1459
1460 2004-04-14  Werner Koch  <wk@gnupg.org>
1461
1462         * scdaemon.h (server_control_s): Add member READER_SLOT.
1463         * scdaemon.c (scd_init_default_ctrl): Initialize READER_SLOT to -1.
1464         * command.c (open_card): Reuse an open slot.
1465         (reset_notify): Just reset the slot if supported by the reader.
1466         (do_reset): Factored code from above out.
1467         (scd_command_handler): Use it for cleanup.
1468
1469         * apdu.h: New pseudo stati SW_HOST_NOT_SUPPORTED,
1470         SW_HOST_LOCKING_FAILED and SW_HOST_BUSY.
1471         * iso7816.c (map_sw): Map it.
1472         
1473         * ccid-driver.c (ccid_slot_status): Add arg STATUSBITS.
1474         * apdu.c (apdu_get_status): New.
1475         (ct_get_status, pcsc_get_status, ocsc_get_status): New stubs.
1476         (get_status_ccid): New.
1477         (apdu_reset): New.
1478         (reset_ct_reader, reset_pcsc_reader, reset_osc_reader): New stubs.
1479         (reset_ccid_reader): New.
1480         (apdu_enum_reader): New.
1481         
1482         * apdu.c (lock_slot, trylock_slot, unlock_slot): New helpers.
1483         (new_reader_slot) [USE_GNU_PTH]: Init mutex.
1484         (apdu_reset, apdu_get_status, apdu_send_le): Run functions
1485         in locked mode.
1486
1487         * command.c (scd_update_reader_status_file): New.
1488         * scdaemon.c (handle_tick): Call it.
1489
1490 2004-04-13  Werner Koch  <wk@gnupg.org>
1491
1492         * scdaemon.c: Convert to a Pth application.
1493         (handle_signal, ticker_thread, handle_tick): New.
1494         (main): Fire up the ticker thread in server mode.
1495
1496 2004-03-23  Werner Koch  <wk@gnupg.org>
1497
1498         * scdaemon.c (main) <gpgconf_list>: Fixed output for pcsc_driver.
1499
1500 2004-03-17  Werner Koch  <wk@gnupg.org>
1501
1502         * tlv.c (parse_ber_header): Do not check for tag overflow - it
1503         does not make sense.  Simplified the check for length overflow.
1504
1505         * scdaemon.c (main) <gpgconf>: Fixed default value quoting.
1506
1507 2004-03-16  Werner Koch  <wk@gnupg.org>
1508
1509         * app-dinsig.c: Implemented. Based on app-nks.c and card-dinsig.c
1510         * app-nks.c (get_length_of_cert): Removed.
1511         * app-help.c: New.
1512         (app_help_read_length_of_cert): New.  Code taken from above.  New
1513         optional arg R_CERTOFF.
1514
1515         * card-dinsig.c: Removed.
1516         * card.c (card_get_serial_and_stamp): Do not bind to the old and
1517         never finsiged card-dinsig.c.
1518
1519         * iso7816.c (iso7816_read_binary): Allow for an NMAX > 254.
1520
1521 2004-03-11  Werner Koch  <wk@gnupg.org>
1522
1523         * scdaemon.h (out_of_core): Removed.  Replaced callers by standard
1524         gpg_error function.
1525
1526         * apdu.c, iso7816.c, ccid-driver.c [GNUPG_SCD_MAIN_HEADER]: Allow
1527         to include a header defined by the compiler.  This helps us to
1528         reuse the source in other software.
1529
1530 2004-03-10  Werner Koch  <wk@gnupg.org>
1531
1532         * iso7816.c (iso7816_read_record): New arg SHORT_EF.  Changed all
1533         callers.
1534
1535 2004-02-18  Werner Koch  <wk@gnupg.org>
1536
1537         * sc-investigate.c (main): Setup the used character set.
1538         * scdaemon.c (main): Ditto.
1539
1540         * scdaemon.c (set_debug): New.  Add option --debug-level.
1541         (main): Add option --gpgconf-list.
1542
1543 2004-02-12  Werner Koch  <wk@gnupg.org>
1544
1545         * Makefile.am: Include cmacros.am for common flags.
1546
1547 2004-01-29  Werner Koch  <wk@gnupg.org>
1548
1549         * command.c (reset_notify): Release the application context and
1550         close the reader.
1551
1552 2004-01-28  Werner Koch  <wk@gnupg.org>
1553
1554         * iso7816.c (iso7816_manage_security_env): New.
1555         (iso7816_decipher): Add PADIND argument.
1556
1557 2004-01-27  Werner Koch  <wk@gnupg.org>
1558
1559         * command.c (cmd_readcert, cmd_readkey): Work on a copy of LINE.
1560
1561         * app-common.h (app_ctx_s): Added readcert field.
1562         * app.c (app_readcert): New.
1563         * tlv.c (parse_ber_header): Added; taken from libksba.
1564
1565 2004-01-26  Werner Koch  <wk@gnupg.org>
1566
1567         * card.c (map_sc_err): Use SCD as the error source.
1568
1569         * command.c (open_card): ADD arg NAME to allow requesting a
1570         specific application.  Changed all callers.
1571         (cmd_serialno): Allow optional argument to select the desired
1572         application.
1573
1574         * app-nks.c: New. 
1575
1576         * scdaemon.h (opt): Add READER_PORT.
1577         * scdaemon.c (main): Set it here.
1578         * app.c (app_set_default_reader_port): Removed.
1579         (select_application): Add NAME arg and figure out a
1580         default serial number from the GDO. Add SLOT arg and remove all
1581         reader management.
1582         (release_application): New.
1583         (app_write_learn_status): Output an APPTYPE status line.
1584         * command.c (open_card): Adapt for select_application change.
1585         * app-openpgp.c (app_select_openpgp): Removed SN and SNLEN args
1586         and set it directly.  Changed all callers.
1587
1588 2004-01-25  Werner Koch  <wk@gnupg.org>
1589
1590         * iso7816.c (iso7816_select_application): P1 kludge for OpenPGP
1591         card.
1592         * app-openpgp.c (find_tlv): Factor out this function to ..
1593         * tlv.c, tlv.h: .. new.
1594
1595         * scdaemon.h: Introduced app_t and ctrl_t as the new types for APP
1596         and CTRL.
1597
1598 2004-01-21  Werner Koch  <wk@gnupg.org>
1599
1600         * apdu.c (apdu_send_le): Treat SW_EOF_REACHED as a warning.
1601
1602 2004-01-20  Werner Koch  <wk@gnupg.org>
1603
1604         * iso7816.c (iso7816_read_binary): New.
1605         (iso7816_select_file): New.
1606         (iso7816_list_directory): New.
1607
1608         * sc-investigate.c: Add option -i.
1609         (select_app, read_line, interactive_shell): New.
1610
1611 2004-01-16  Werner Koch  <wk@gnupg.org>
1612
1613         * apdu.h: Add SW_FILE_NOT_FOUND.
1614         * iso7816.c (map_sw): Map it to GPG_ERR_ENOENT.
1615         * iso7816.c (iso7816_select_file): New.
1616
1617         * app-dinsig.c: New file w/o any real code yet.
1618         * Makefile.am (scdaemon_SOURCES,sc_investigate_SOURCES): Add file.
1619
1620         * sc-investigate.c: Add option --disable-ccid.
1621
1622 2003-12-19  Werner Koch  <wk@gnupg.org>
1623
1624         * apdu.c (apdu_send_le): Send a get_response with the indicated
1625         length and not the 64 bytes we used for testing.
1626
1627         * app-openpgp.c (verify_chv2, verify_chv3, do_sign): Check the
1628         minimum length of the passphrase, so that we don't need to
1629         decrement the retry counter.
1630
1631 2003-12-17  Werner Koch  <wk@gnupg.org>
1632
1633         * card-p15.c (p15_enum_keypairs): Replaced KRC by RC.
1634         * card-dinsig.c (dinsig_enum_keypairs): Ditto.
1635
1636 2003-12-16  Werner Koch  <wk@gnupg.org>
1637
1638         * scdaemon.c (main): Set the prefixes for assuan logging.
1639
1640 2003-11-17  Werner Koch  <wk@gnupg.org>
1641
1642         * scdaemon.c, scdaemon.h: New options --allow-admin and --deny-admin.
1643         * app-openpgp.c (verify_chv3): Check it here.
1644
1645 2003-11-12  Werner Koch  <wk@gnupg.org>
1646
1647         Adjusted for API changes in Libksba.
1648
1649 2003-10-30  Werner Koch  <wk@gnupg.org>
1650
1651         * apdu.c (close_ct_reader, close_pcsc_reader): Implemented.
1652         (get_ccid_error_string): New.  Not very useful messages, though.
1653
1654 2003-10-25  Werner Koch  <wk@gnupg.org>
1655
1656         * ccid-driver.c (ccid_open_reader): Return an error if no USB
1657         devices are found.
1658
1659         * command.c (cmd_genkey, cmd_passwd): Fixed faulty use of
1660         !spacep().
1661
1662         * apdu.c (apdu_open_reader): Hacks for PC/SC under Windows.
1663
1664 2003-10-20  Werner Koch  <wk@gnupg.org>
1665
1666         * command.c (cmd_checkpin): New.
1667         (register_commands): Add command CHECKPIN.
1668         * app.c (app_check_pin): New.
1669         * app-openpgp.c (check_against_given_fingerprint): New. Factored
1670         out that code elsewhere.
1671         (do_check_pin): New.
1672
1673 2003-10-10  Werner Koch  <wk@gnupg.org>
1674
1675         * ccid-driver.c (ccid_close_reader): New.
1676
1677         * apdu.c (close_ccid_reader, close_ct_reader, close_csc_reader)
1678         (close_osc_reader, apdu_close_reader): New.  Not all are properly
1679         implemented yet.
1680
1681 2003-10-09  Werner Koch  <wk@gnupg.org>
1682
1683         * ccid-driver.c (ccid_transceive): Add T=1 chaining for sending.
1684
1685 2003-10-08  Werner Koch  <wk@gnupg.org>
1686
1687         * app-openpgp.c (do_getattr): Support SERIALNO and AID.
1688
1689 2003-10-01  Werner Koch  <wk@gnupg.org>
1690
1691         * ccid-driver.c: Detect GnuPG 1.3 and include appropriate files.
1692         * apdu.c: Ditto.
1693         * app-openpgp.c: Ditto.
1694         * iso7816.c: Ditto.
1695         (generate_keypair): Renamed to ..
1696         (do_generate_keypair): .. this.
1697         * app-common.h [GNUPG_MAJOR_VERSION]: New.
1698         * iso7816.h [GNUPG_MAJOR_VERSION]: Include cardglue.h
1699
1700 2003-09-30  Werner Koch  <wk@gnupg.org>
1701
1702         * command.c (cmd_getattr): New command GETATTR.
1703         * app.c (app_setattr): New.
1704         (do_getattr): New.
1705         (do_learn_status): Reimplemented in terms of do_getattr.
1706
1707         * app-openpgp.c (do_change_pin): Make sure CVH1 and CHV2 are
1708         always synced.
1709         (verify_chv2, verify_chv3): New. Factored out common code.
1710         (do_setattr, do_sign, do_auth, do_decipher): Change the names of
1711         the prompts to match that we have only 2 different PINs.
1712         (app_select_openpgp): Check whether the card enforced CHV1.
1713         (convert_sig_counter_value): New. Factor out code from
1714         get_sig_counter.
1715
1716 2003-09-28  Werner Koch  <wk@gnupg.org>
1717
1718         * app-openpgp.c (dump_all_do): Use gpg_err_code and not gpg_error.
1719
1720 2003-09-19  Werner Koch  <wk@gnupg.org>
1721
1722         * ccid-driver.c (parse_ccid_descriptor): New.
1723         (read_device_info): New.
1724         (ccid_open_reader): Check that the device has all required features.
1725
1726 2003-09-06  Werner Koch  <wk@gnupg.org>
1727
1728         * scdaemon.c (main): --pcsc-driver again defaults to pcsclite.
1729         David Corcoran was so kind to remove the GPL incompatible
1730         advertisng clause from pcsclite.
1731         * apdu.c (apdu_open_reader): Actually make pcsc-driver option work.
1732
1733 2003-09-05  Werner Koch  <wk@gnupg.org>
1734
1735         * ccid-driver.c: More work, data can now actually be retrieved.
1736         * ccid-driver.c, ccid-driver.h: Alternativley allow use under BSD
1737         conditions.
1738
1739 2003-09-02  Werner Koch  <wk@gnupg.org>
1740
1741         * scdaemon.c, scdaemon.h: New option --pcsc-ccid.
1742         * ccid-driver.c, ccid-driver.h: New but far from being useful.
1743         * Makefile.am: Add above.
1744         * apdu.c: Add support for that ccid driver.
1745         
1746 2003-08-26  Timo Schulz  <twoaday@freakmail.de>
1747
1748         * apdu.c (new_reader_slot): Only set 'is_osc' when OpenSC
1749         is used.
1750         
1751 2003-08-25  Werner Koch  <wk@gnupg.org>
1752
1753         * command.c (cmd_setattr): Use a copy of LINE.
1754         (cmd_genkey): Use a copy of KEYNO.
1755         (cmd_passwd): Use a copy of CHVNOSTR.
1756         (cmd_pksign, cmd_pkauth, cmd_pkdecrypt): s/strdup/xtrystrdup/.
1757
1758 2003-08-19  Werner Koch  <wk@gnupg.org>
1759
1760         * scdaemon.c, scdaemon.h: New option --pcsc-driver.
1761         * apdu.c (apdu_open_reader): Use that option here instead of a
1762         hardcoded one.
1763
1764 2003-08-18  Werner Koch  <wk@gnupg.org>
1765
1766         * Makefile.am: Add OPENSC_LIBS to all programs. 
1767
1768         * scdaemon.c, scdaemon.h: New option --disable-opensc.
1769         * card.c (card_open): Implement it.
1770         * apdu.c (open_osc_reader, osc_send_apdu): New.
1771         (apdu_open_reader) [HAVE_OPENSC]: Use the opensc driver if not
1772         disabled.
1773         (error_string) [HAVE_OPENSC]: Use sc_strerror.
1774         (send_apdu) [HAVE_OPENSC]: Call osc_apdu_send.
1775
1776         * card-p15.c (p15_enum_keypairs, p15_prepare_key): Adjusted for
1777         libgpg-error.
1778
1779 2003-08-14  Timo Schulz  <twoaday@freakmail.de>
1780
1781         * apdu.c (ct_activate_card): Change the code a little to avoid
1782         problems with other readers.
1783         * Always use 'dynload.h' instead of 'dlfcn.h'.
1784
1785 2003-08-05  Werner Koch  <wk@gnupg.org>
1786
1787         * app-openpgp.c (dump_all_do): Don't analyze constructed DOs after
1788         an error.
1789
1790 2003-08-04  Werner Koch  <wk@gnupg.org>
1791
1792         * app.c (app_set_default_reader_port): New.
1793         (select_application): Use it here.
1794         * scdaemon.c (main): and here.
1795         * sc-copykeys.c: --reader-port does now take a string.
1796         * sc-investigate.c, scdaemon.c: Ditto.
1797         * apdu.c (apdu_open_reader): Ditto.  Load pcsclite if no ctapi
1798         driver is configured.  Always include code for ctapi.
1799         (new_reader_slot): Don't test for already used ports and remove
1800         port arg.
1801         (open_pcsc_reader, pcsc_send_apdu, pcsc_error_string): New.
1802         (apdu_send_le): Changed RC to long to cope with PC/SC.
1803
1804         * scdaemon.c, scdaemon.h: New option --ctapi-driver.
1805         * sc-investigate.c, sc-copykeys.c: Ditto.
1806         
1807 2003-07-31  Werner Koch  <wk@gnupg.org>
1808
1809         * Makefile.am (scdaemon_LDADD): Added INTLLIBS.
1810
1811 2003-07-28  Werner Koch  <wk@gnupg.org>
1812
1813         * app-openpgp.c (do_setattr): Change implementation.  Allow all
1814         useful DOs.
1815
1816 2003-07-27  Werner Koch  <wk@gnupg.org>
1817
1818         Adjusted for gcry_mpi_print and gcry_mpi_scan API change.
1819
1820 2003-07-24  Werner Koch  <wk@gnupg.org>
1821
1822         * app-openpgp.c (do_learn_status): Print more status information.
1823         (app_select_openpgp): Store the card version.
1824         (store_fpr): Add argument card_version and fix DOs for old cards.
1825         (app_openpgp_storekey): Likewise.
1826
1827 2003-07-23  Werner Koch  <wk@gnupg.org>
1828
1829         * command.c (cmd_pkauth): New.
1830         (cmd_setdata): Check whether data was given at all to avoid
1831         passing 0 to malloc.
1832
1833         * app.c (app_auth): New.
1834         * app-openpgp.c (do_auth): New.
1835
1836 2003-07-22  Werner Koch  <wk@gnupg.org>
1837
1838         * command.c (cmd_passwd): New.
1839         * app.c (app_change_pin): New.
1840         * app-openpgp.c (do_change_pin): New.
1841         * iso7816.c (iso7816_reset_retry_counter): Implemented.
1842
1843         * sc-investigate.c (main): New option --gen-random.
1844         * iso7816.c (iso7816_get_challenge): Don't create APDUs with a
1845         length larger than 255.
1846
1847 2003-07-17  Werner Koch  <wk@gnupg.org>
1848
1849         * command.c (cmd_random): New command RANDOM.
1850
1851         * iso7816.c (map_sw): New. Use it in this file to return
1852         meaningful error messages.  Changed all public fucntions to return
1853         a gpg_error_t.
1854         (iso7816_change_reference_data): New.
1855         * apdu.c (apdu_open_reader): Use faked status words for soem
1856         system errors.
1857
1858 2003-07-16  Werner Koch  <wk@gnupg.org>
1859
1860         * apdu.c (apdu_send_simple): Use apdu_send_le so that we can
1861         specify not to send Le as it should be.
1862
1863 2003-07-15  Werner Koch  <wk@gnupg.org>
1864
1865         * Makefile.am: Add sc-copykeys program.
1866         * sc-copykeys.c: New.
1867         * app-openpgp.c (app_openpgp_storekey): New.
1868         (app_openpgp_cardinfo): New.
1869         (count_bits): New.
1870         (store_fpr): And use it here to get the actual length in bit.
1871
1872 2003-07-03  Werner Koch  <wk@gnupg.org>
1873
1874         * app-openpgp.c (do_setattr): Add setting of the URL.
1875         (app_select_openpgp): Dump card data only in very verbose mode.
1876         (do_decipher): New.
1877
1878 2003-07-02  Werner Koch  <wk@gnupg.org>
1879
1880         * app-openpgp.c (get_sig_counter): New.
1881         (do_sign): Print the signature counter and enable the PIN callback.
1882         (do_genkey): Implement the PIN callback. 
1883
1884 2003-07-01  Werner Koch  <wk@gnupg.org>
1885
1886         * app-openpgp.c (store_fpr): Fixed fingerprint calculation.
1887
1888 2003-06-26  Werner Koch  <wk@gnupg.org>
1889
1890         * app-openpgp.c (find_tlv): Fixed length header parsing.
1891
1892         * app.c (app_genkey): New.
1893         * command.c (cmd_genkey): New.
1894
1895 2003-06-25  Werner Koch  <wk@gnupg.org>
1896
1897         * command.c (percent_plus_unescape): New.
1898         (cmd_setattr): New.
1899
1900 2003-06-24  Werner Koch  <wk@gnupg.org>
1901
1902         * command.c (send_status_info): New.
1903
1904         * app-openpgp.c (app_select_openpgp): Replace SLOT arg by APP arg
1905         and setup the function pointers in APP on success. Changed callers.
1906         * app.c: New.
1907         * app-common.h: New.
1908         * scdaemon.h (APP): New type to handle applications.
1909         (server_control_s): Add an APP context field.
1910
1911         * command.c (cmd_serialno): Handle applications.
1912         (cmd_pksign): Ditto.
1913         (cmd_pkdecrypt): Ditto.
1914         (reset_notify): Ditto.
1915         (cmd_learn): For now return error for application contexts.
1916         (cmd_readcert): Ditto.
1917         (cmd_readkey): Ditto.
1918
1919 2003-06-04  Werner Koch  <wk@gnupg.org>
1920
1921         * card.c (map_sc_err): Renamed gpg_make_err to gpg_err_make.
1922
1923         Renamed error codes from INVALID to INV and removed _ERROR suffixes.
1924
1925 2003-06-03  Werner Koch  <wk@gnupg.org>
1926
1927         Changed all error codes in all files to the new libgpg-error scheme.
1928
1929         * scdaemon.h: Include gpg-error.h and errno.h
1930         * card.c (map_sc_err): Use unknown for the error source.
1931         * Makefile.am: Link with libgpg-error
1932
1933 2003-05-14  Werner Koch  <wk@gnupg.org>
1934
1935         * atr.c, atr.h: New.
1936         * sc-investigate.c: Dump the ATR in a human readable format.
1937
1938 2003-05-08  Werner Koch  <wk@gnupg.org>
1939
1940         * scdaemon.h (DBG_CARD_IO_VALUE): New.
1941
1942         * sc-investigate.c: New.
1943         * scdaemon.c (main): Removed --print-atr option.
1944
1945         * iso7816.c, iso7816.h, app-openpgp.c: New.
1946
1947 2003-04-29  Werner Koch  <wk@gnupg.org>
1948
1949         * scdaemon.c: New options --print-atr and --reader-port
1950         * apdu.c, apdu.h: New
1951
1952         * card.c, card-p15.c, card-dinsig.c: Allow build without OpenSC.
1953         
1954         * Makefile.am (LDFLAGS): Removed.
1955
1956         * command.c (register_commands): Adjusted for new Assuan semantics.
1957
1958 2002-08-21  Werner Koch  <wk@gnupg.org>
1959
1960         * scdaemon.c (main): New option --daemon so that the program is
1961         not accidently started in the background.
1962
1963 2002-08-16  Werner Koch  <wk@gnupg.org>
1964
1965         * scdaemon.c: Include i18n.h.
1966
1967         * card-common.h (struct p15_private_s): Forward declaration.  Add
1968         it to card_ctx_s.
1969         * card.c (card_close): Make sure private data is released.
1970         (card_enum_certs): New.
1971         * card-p15.c (p15_release_private_data): New.
1972         (init_private_data): New to work around an OpenSC weirdness.
1973         (p15_enum_keypairs): Do an OpenSC get_objects only once.
1974         (p15_enum_certs): New.
1975         (card_p15_bind): Bind new function.
1976         * command.c (cmd_learn): Return information about the certificates.
1977
1978 2002-08-09  Werner Koch  <wk@gnupg.org>
1979
1980         * card.c (card_get_serial_and_stamp): Use the tokeinfo serial
1981         number as a fallback. Add a special prefix for serial numbers.
1982
1983 2002-07-30  Werner Koch  <wk@gnupg.org>
1984
1985         Changes to cope with OpenSC 0.7.0:
1986         
1987         * card.c: Removed the check for the packed opensc version.
1988         Changed include file names of opensc.
1989         (map_sc_err): Adjusted error codes for new opensc version.
1990         * card-p15.c: Changed include filename of opensc.
1991         * card-dinsig.c: Ditto.
1992
1993         * card-p15.c (p15_decipher): Add flags argument to OpenSC call.
1994         
1995 2002-07-24  Werner Koch  <wk@gnupg.org>
1996
1997         * card.c (find_simple_tlv, find_iccsn): New.
1998         (card_get_serial_and_stamp): Improved serial number parser.
1999
2000 2002-06-27  Werner Koch  <wk@gnupg.org>
2001
2002         * scdaemon.c (main): Use GNUPG_DEFAULT_HOMEDIR constant.
2003
2004 2002-06-15  Werner Koch  <wk@gnupg.org>
2005
2006         * card-dinsig.c: Documented some stuff from the DIN norm.
2007
2008 2002-04-15  Werner Koch  <wk@gnupg.org>
2009
2010         * command.c (cmd_pksign, cmd_pkdecrypt): Use a copy of the key ID.
2011
2012 2002-04-12  Werner Koch  <wk@gnupg.org>
2013
2014         * scdaemon.c: New option --debug-sc N.
2015         * card.c (card_open): set it here.
2016
2017         * card-p15.c (p15_prepare_key): Factored out common code from ...
2018         (p15_sign, p15_decipher): here and made the decryption work the
2019         regular way.
2020
2021 2002-04-10  Werner Koch  <wk@gnupg.org>
2022
2023         * card.c (card_open): Return immediately when no reader is available.
2024
2025 2002-03-27  Werner Koch  <wk@gnupg.org>
2026
2027         * card.c (card_open, card_close): Adjusted for changes in OpenSC.
2028
2029 2002-03-10  Werner Koch  <wk@gnupg.org>
2030
2031         * card-p15.c, card-dinsig.c, card-common.h: New.
2032         * card.c: Factored most code out to the new modules, so that we
2033         can better support different types of card applications.
2034
2035 2002-01-26  Werner Koch  <wk@gnupg.org>
2036
2037         * scdaemon.c scdaemon.h, command.c: New. Based on the code from
2038         the gpg-agent.
2039
2040         
2041  Copyright 2002, 2003, 2004, 2005, 2007, 2008 Free Software Foundation, Inc.
2042
2043  This file is free software; as a special exception the author gives
2044  unlimited permission to copy and/or distribute it, with or without
2045  modifications, as long as this notice is preserved.
2046
2047  This file is distributed in the hope that it will be useful, but
2048  WITHOUT ANY WARRANTY, to the extent permitted by law; without even the
2049  implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.