last local commit
[gnupg.git] / g10 / ChangeLog
1 Fri Oct 16 10:24:47 1998  Werner Koch  (wk@isil.d.shuttle.de)
2
3         * trustdb.c: Rewrote most.
4         * tdbio.c: Add cache and generalized hash tables.
5
6         * options.h (ENABLE_COMMENT_PACKETS): New but undef'ed.
7         * encode.c, sign.c, keygen.c: Disabled comment packets.
8         * export.c (do_export): Comment packets are never exported,
9         except for those in the secret keyring.
10
11         * g10.c (main): Removed option do-no-export-rsa; should be
12         be replaced by a secpial tool.
13         * export.c (do_export): Removed the code for the above option.
14
15         * armor.c (find_header): Support for new only_keyblocks.
16         * import.c (import_keys): Only looks for keyblock armors.
17
18         * packet.h: replaced valid_days by expiredate and changed all users.
19         * build-packet.c (do_public_key): calculates valid-days
20         (do_secret_key): Ditto.
21         * parse-packet.c (parse_key): expiredate is calucated from the
22         valid_period in v3 packets.
23         * keyid.c (do_fingerprint_md): calculates valid_dates.
24
25         * keygen.c (add_key_expire): fixed key expiration time for v4 packets.
26
27         * armor.c (find_header): A LF in the first 28 bytes
28         was skipped for non-armored data.
29
30 Thu Oct  8 11:35:51 1998  Werner Koch  (wk@isil.d.shuttle.de)
31
32         * armor.c (is_armored): Add test on old comment packets.
33
34         * tdbio.c (tdbio_search_dir_bypk): fixed memory leak.
35
36         * getkey.c: Changed the caching algorithms.
37
38 Wed Oct  7 19:33:28 1998  Werner Koch  (wk@isil.d.shuttle.de)
39
40         * kbnodes.c (unused_nodes): New.
41
42 Wed Oct  7 11:15:36 1998  Werner Koch  (wk@isil.d.shuttle.de)
43
44         * keyedit.c (sign_uids): Fixed a problem with SK which could caused
45         a save of an unprotected key.
46         (menu_adduid): Ditto.
47
48         * keyedit.c (keyedit_menu): Prefs are now correctly listed for
49         new user ids.
50
51         * trustdb.c (update_trust_record): New.
52         (insert_trust_record): Now makes use of update_trust_record.
53
54 Tue Oct  6 16:18:03 1998  Werner Koch  (wk@isil.d.shuttle.de)
55
56         * trustdb.c (read_record): replaces most of the tdbio_read_records.
57         (write_record): Ditto.
58
59 Sat Oct  3 11:01:21 1998  Werner Koch  (wk@isil.d.shuttle.de)
60
61         * keygen.c (ask_alogo): enable ElGamal enc-only only for addmode.
62
63 Wed Sep 30 10:15:33 1998  Werner Koch  (wk@isil.d.shuttle.de)
64
65         * import.c (import_one): Fixed update of wrong keyblock.
66
67 Tue Sep 29 08:32:08 1998  me,,,  (wk@tobold)
68
69         * mainproc.c (proc_plaintext): Display note for special filename.
70         * plaintext.c (handle_plaintext): Suppress output of special file.
71
72 Mon Sep 28 12:57:12 1998  Werner Koch  (wk@isil.d.shuttle.de)
73
74         * g10.c (verify_own_keys): Add warning if a key is not protected.
75
76         * passphrase (hash_passphrase): Fixed iterated+salted mode and
77         setup for keysizes > hashsize.
78
79         * g10.c (main): New options: --s2k-{cipher,digest,mode}.
80
81 Fri Sep 25 09:34:23 1998  Werner Koch  (wk@isil.d.shuttle.de)
82
83         * g10.c: Chnaged some help texts.
84
85 Tue Sep 22 19:34:39 1998  Werner Koch  (wk@isil.d.shuttle.de)
86
87         * passphrase.c (read_passphrase_from_fd): fixed bug for long
88         passphrases.
89
90 Mon Sep 21 11:28:05 1998  Werner Koch  (wk@(none))
91
92         * getkey.c (lookup): Add code to use the sub key if the primary one
93         does not match the usage.
94
95         * armor.c (armor_filter): New error message: no valid data found.
96         (radix64_read): Changes to support multiple messages.
97         (i18n.h): New.
98         * mainproc.c (add_onepass_sig): bug fix.
99
100 Mon Sep 21 08:03:16 1998  Werner Koch  (wk@isil.d.shuttle.de)
101
102         * pkclist.c (do_we_trust): Add keyid to most messages.
103
104         * passphrase.c (read_passphrase_from_fd): New.
105         (have_static_passphrase): New
106         (get_passphrase_fd): Removed.
107         (set_passphrase_fd): Removed.
108         * g10.c (main): passphrase is now read here.
109
110         * keyedit.c (keyedit_menu): "help" texts should now translate fine.
111
112 Mon Sep 21 06:40:02 1998  Werner Koch  (wk@isil.d.shuttle.de)
113
114         * encode.c (encode_simple): Now disables compression
115         when --rfc1991 is used.
116         (encode_crypt): Ditto.
117
118 Fri Sep 18 16:50:32 1998  Werner Koch  (wk@isil.d.shuttle.de)
119
120         * getkey.c (merge_key_and_selfsig): New.
121
122 Fri Sep 18 10:20:11 1998  Werner Koch  (wk@isil.d.shuttle.de)
123
124         * pkclist.c (select_algo_from_prefs): Removed 3DES kludge.
125
126         * seskey.c (make_session_key): Fixed SERIOUS bug introduced
127         by adding the weak key detection code.
128
129         * sign.c (sign_file): Changed aremor header in certain cases.
130
131 Tue Sep 15 17:52:55 1998  Werner Koch  (wk@isil.d.shuttle.de)
132
133         * mainproc.c (check_sig_and_print): Replaced ascime by asctimestamp.
134
135 Mon Sep 14 11:40:52 1998  Werner Koch  (wk@isil.d.shuttle.de)
136
137         * seskey.c (make_session_key): Now detects weak keys.
138
139         * trustdb (clear_trust_checked_flag): New.
140
141         * plaintext.c (handle_plaintext): Does no anymore suppress CR from
142         cleartext signed messages.
143
144 Sun Sep 13 12:54:29 1998  Werner Koch  (wk@isil.d.shuttle.de)
145
146         * trustdb.c (insert_trust_record): Fixed a stupid bug in the free
147         liunked list loops.
148
149 Sat Sep 12 15:49:16 1998  Werner Koch  (wk@isil.d.shuttle.de)
150
151         * status.c (remove_shmid): New.
152         (init_shm_comprocess): Now sets permission to the real uid.
153
154 Wed Sep  9 11:15:03 1998  Werner Koch  (wk@isil.d.shuttle.de)
155
156         * packet.h (PKT_pubkey_enc): New flah throw_keyid, and add logic to
157         implement it.
158         * g10.c (main): New Option --throw-keyid
159
160         * getkey.c (enum_secret_keys): Add new ar and changed all callers.
161
162 Tue Sep  8 20:04:09 1998  Werner Koch  (wk@isil.d.shuttle.de)
163
164         * delkey.c (delete_key): Moved from keyedit.c.
165
166 Mon Sep  7 16:37:52 1998  Werner Koch  (wk@isil.d.shuttle.de)
167
168         * build-packet.c (calc_length_header): New arg new_ctb to correctly
169         calculate the length of new style packets.
170
171         * armor.c (is_armored): Checks for symkey_enc packets.
172
173         * pkclist.c (select_algo_from_prefs): 3DEs substitute is now CAST5.
174
175 Tue Aug 11 17:54:50 1998  Werner Koch  (wk@isil.d.shuttle.de)
176
177         * build-packet.c (do_secret_key): Fixed handling of old keys.
178
179         * getkey.c (compare_name): Fixed exact and email matching
180
181         * openfile.c (open_outfile): Changed arguments and all callers.
182
183 Tue Aug 11 09:14:35 1998  Werner Koch  (wk@isil.d.shuttle.de)
184
185         * encode.c (encode_simple): Applied option set-filename and comment.
186         (encode_crypt): Ditto.
187         * sign.c (sign_file): Ditto.
188         * armor.c (armor_filter): Applied option comment.
189
190         * encode.c (encode_crypt): Moved init_packet to the begin.
191         (encode_simple): add an init_packet().
192
193         * comment (write_comment): Now enforces a hash sign as the 1st byte.
194
195         * import.c (import_one): Add explanation for "no user ids".
196
197         * compress.c (do_uncompress): Applied Brian Warner's patch to support
198         zlib 1.1.3 etc.
199
200         * trustdb.c (check_trust): Fixed a problem after inserting new keys.
201
202         * getkey (lookup): do not return the primary key if usage is given
203         (lookup_sk): Ditto and take usage into account.
204
205         * status.c (cpr_get_answer_is_yes): add display_help.
206
207 Mon Aug 10 10:11:28 1998  Werner Koch  (wk@isil.d.shuttle.de)
208
209         * getkey.c (lookup_sk): Now always returns the primary if arg
210         primary is true.
211         (lookup): Likewise.
212         (get_pubkey_byname): Now returns the primary key
213         (get_seckey_byname): Ditto.
214
215
216 Mon Aug 10 08:34:03 1998  Werner Koch  (wk@isil.d.shuttle.de)
217
218         * keyid.c (pubkey_letter): ELG_E is now a small g.
219
220 Sat Aug  8 17:26:12 1998  Werner Koch  (wk@isil.d.shuttle.de)
221
222         * openfile (overwrite_filep): Changed semantics and all callers.
223
224 Sat Aug  8 12:17:07 1998  Werner Koch  (wk@isil.d.shuttle.de)
225
226         * status.c (display_help): New.
227
228 Thu Aug  6 16:30:41 1998  Werner Koch,mobil,,,  (wk@tobold)
229
230         * seskey.c (encode_session_key): Now uses get_random_bits().
231
232 Thu Aug  6 07:34:56 1998  Werner Koch,mobil,,,  (wk@tobold)
233
234         * ringedit.c (keyring_copy): No more backupfiles for
235         secret keyrings and add additional warning in case of
236         a failed secret keyring operation.
237
238 Wed Aug  5 11:54:37 1998  Werner Koch  (wk@isil.d.shuttle.de)
239
240         * g10.c (check_opts): Moved to main.  Changed def_cipher_algo
241         semantics and chnaged all users.
242
243         * pubkey-enc.c (get_sssion_key): New informational output
244         about preferences.
245
246         * parse-packet.c (parse_symkeyenc): Fixed salted+iterated S2K
247         (parse_key): Ditto.
248         * build-packet.c (do_secret_key): Ditto.
249         (do_symkey_enc): Ditto.
250
251 Tue Aug  4 08:59:10 1998  Werner Koch  (wk@isil.d.shuttle.de)
252
253         * getkey.c (enum_secret_keys): Now returns only primary keys.
254
255         * getkey (lookup): Now sets the new namehash field.
256
257         * parse-packet.c (parse_sig_subpkt2): New.
258
259         * sign.c (sign_file): one-pass sigs are now emiited reverse.
260         Preference data is considered when selecting the compress algo.
261
262 Wed Jul 29 12:53:03 1998  Werner Koch  (wk@isil.d.shuttle.de)
263
264         * free-packet.c (copy_signature): New.
265
266         * keygen.c (generate_subkeypair): rewritten
267         * g10.c (aKeyadd): Removed option --add-key
268
269 Mon Jul 27 10:37:28 1998  Werner Koch  (wk@isil.d.shuttle.de)
270
271         * seckey-cert.c (do_check): Additional check on cipher blocksize.
272         (protect_secret_key): Ditto.
273         * encr-data.c: Support for other blocksizes.
274         * cipher.c (write_header): Ditto.
275
276 Fri Jul 24 16:47:59 1998  Werner Koch  (wk@isil.d.shuttle.de)
277
278         * kbnode.c (insert_kbnode): Changed semantics and all callers.
279         * keyedit.c : More or less a complete rewrite
280
281 Wed Jul 22 17:10:04 1998  Werner Koch  (wk@isil.d.shuttle.de)
282
283         * build-packet.c (write_sign_packet_header): New.
284
285 Tue Jul 21 14:37:09 1998  Werner Koch  (wk@isil.d.shuttle.de)
286
287         * import.c (import_one): Now creates a trustdb record.
288
289         * g10.c (main): New command --check-trustdb
290
291 Mon Jul 20 11:15:07 1998  Werner Koch  (wk@isil.d.shuttle.de)
292
293         * genkey.c (generate_keypair): Default key is now DSA with
294         encryption only ElGamal subkey.
295
296 Thu Jul 16 10:58:33 1998  Werner Koch  (wk@isil.d.shuttle.de)
297
298         * keyid.c (keyid_from_fingerprint): New.
299         * getkey.c (get_pubkey_byfprint): New.
300
301 Tue Jul 14 18:09:51 1998  Werner Koch  (wk@isil.d.shuttle.de)
302
303         * keyid.c (fingerprint_from_pk): Add argument and changed all callers.
304         (fingerprint_from_sk): Ditto.
305
306 Tue Jul 14 10:10:03 1998  Werner Koch  (wk@isil.d.shuttle.de)
307
308         * plaintext.c (handle_plaintext): Now returns create error if
309         the file could not be created or the user responded not to overwrite
310         the file.
311         * mainproc.c (proc_plaintext): Tries again if the file could not
312         be created to check the signature without output.
313
314         * misc.c (disable_core_dumps): New.
315         * g10.c (main): disable coredumps for gpg
316
317         * g10.c (MAINTAINER_OPTIONS): New to disable some options
318
319 Mon Jul 13 16:47:54 1998  Werner Koch  (wk@isil.d.shuttle.de)
320
321         * plaintext.c (hash_datafiles): New arg for better support of
322         detached sigs. Changed all callers.
323         * mainproc.c (proc_signature_packets): Ditto.
324
325         * g10.c (main): New option "compress-sigs"
326         * sig.c (sign_file): detached signatures are not anymore compressed
327         unless the option --compress-sigs is used.
328
329 Thu Jul  9 19:54:54 1998  Werner Koch  (wk@isil.d.shuttle.de)
330
331         * armor.c: Fixes to allow zero length cleartext signatures
332
333 Thu Jul  9 14:52:47 1998  Werner Koch  (wk@isil.d.shuttle.de)
334
335         * g10.c (build_list): Now drops setuid.
336         (main): Changed the way keyrings  and algorithms are registered .
337
338 Wed Jul  8 14:17:30 1998  Werner Koch  (wk@isil.d.shuttle.de)
339
340         * packet.h (PKT_public_key): Add field keyid.
341         * parse-packet.c (parse_key): Reset the above field.
342         * keyid.c (keyid_from_pk): Use above field as cache.
343
344         * tdbio.c, tdbio.h: New
345         * trustdb.c: Moved some functions to tdbio.c.
346         (print_keyid): New.
347
348         * pkclist.c (check_signatures_trust): New.
349
350 Wed Jul  8 10:45:28 1998  Werner Koch  (wk@isil.d.shuttle.de)
351
352         * plaintext.c (special_md_putc): New.
353         (handle_plaintext): add clearsig argument
354         * mainproc.c (proc_plaintext): detection of clearsig
355         * sign.c (write_dased_escaped): Changed clearsig format
356
357 Tue Jul  7 18:56:19 1998  Werner Koch  (wk@isil.d.shuttle.de)
358
359         * armor.c (find_header): Now makes sure that there is only one
360         empty line for clearsigs, as this is what OP now says.
361
362 Mon Jul  6 13:09:07 1998  Werner Koch  (wk@isil.d.shuttle.de)
363
364         * g10.c (main): New option default-secret-key
365         * getkey.c (get_seckey_byname): support for this option.
366
367 Mon Jul  6 09:03:49 1998  Werner Koch  (wk@isil.d.shuttle.de)
368
369         * getkey.c (add_keyring): Keyrings are now added to end of the
370         list of keyrings.  The first added keyringwill be created.
371         (add_secret_keyring): Likewise.
372
373         * ringedit.c (add_keyblock_resource): Files are created here.
374
375         * g10.c (aNOP): Removed
376
377         * getkey.c (lookup): Add checking of usage for name lookups
378         * packet.h (pubkey_usage): Add a field which may be used to store
379         usage capabilities.
380         * pkclist.c (build_pk_list): getkey now called with usage arg.
381         * skclist.c (build_sk_list): Ditto.
382
383         * sign.c (clearsign_file): Fixed "Hash:" headers
384
385 Sat Jul  4 13:33:31 1998  Werner Koch  (wk@isil.d.shuttle.de)
386
387         * trustdb.c (list_ownertrust): New.
388         * g10.c (aListOwnerTrust): New.
389
390         * g10.c (def_pubkey_algo): Removed.
391
392         * trustdb.c (verify_private_data): Removed and also the call to it.
393         (sign_private_data): Removed.
394
395 Fri Jul  3 13:26:10 1998  Werner Koch  (wk@isil.d.shuttle.de)
396
397         * g10.c (aEditKey): was aEditSig. Changed usage msg.
398
399         * keyedit.c: Done some i18n stuff.
400
401         * g10.c (do_not_use_RSA): New.
402         * sign.c (do_sign): Add call to above function.
403         * encode.c (write_pubkey_enc_from_list): Ditto.
404
405 Thu Jul  2 21:01:25 1998  Werner Koch  (wk@isil.d.shuttle.de)
406
407         * parse-packet.c: Now is able sto store data of unknown
408         algorithms.
409         * free-packet.c: Support for this.
410         * build-packet.c: Can write data of packet with unknown algos.
411
412 Thu Jul  2 11:46:36 1998  Werner Koch  (wk@isil.d.shuttle.de)
413
414         * parse-packet.c (parse): fixed 4 byte length header
415
416 Wed Jul  1 12:36:55 1998  Werner Koch  (wk@isil.d.shuttle.de)
417
418         * packet.h (new_ctb): New field for some packets
419         * build-packet.c (build_packet): Support for new_ctb
420         * parse-packet.c (parse): Ditto.
421
422 Mon Jun 29 12:54:45 1998  Werner Koch  (wk@isil.d.shuttle.de)
423
424         * packet.h: changed all "_cert" to "_key", "subcert" to "subkey".
425
426         * free-packet.c (free_packet): Removed memory leak for subkeys.
427
428 Sun Jun 28 18:32:27 1998  Werner Koch  (wk@isil.d.shuttle.de)
429
430         * import.c (import_keys): Renamed from import_pubkeys.
431         (import_secret_one): New.
432
433         * g10.c (aExportSecret): New.
434
435         * export.c (export_seckeys): New.
436
437         * parse-packet.c (parse_certificate): Cleaned up.
438         (parse_packet): Trust packets are now considered as unknown.
439         (parse_pubkey_warning): New.
440
441 Fri Jun 26 10:37:35 1998  Werner Koch  (wk@isil.d.shuttle.de)
442
443         * keygen.c (has_invalid_email_chars): New.
444
445 Wed Jun 24 16:40:22 1998  Werner Koch  (wk@isil.d.shuttle.de)
446
447         * armor.c (armor_filter): Now creates valid onepass_sig packets
448         with all detected hash algorithms.
449         * mainproc.c (proc_plaintext): Now uses the hash algos as specified
450         in the onepass_sig packets (if there are any)
451
452 Mon Jun 22 11:54:08 1998  Werner Koch  (wk@isil.d.shuttle.de)
453
454         * plaintext.c (handle_plaintext): add arg to disable outout
455         * mainproc.c (proc_plaintext): disable output when in sigs_only mode.
456
457 Thu Jun 18 13:17:27 1998  Werner Koch  (wk@isil.d.shuttle.de)
458
459         * keygen.c: Removed all rsa packet stuff, chnaged defaults
460         for key generation.
461
462 Sun Jun 14 21:28:31 1998  Werner Koch  (wk@isil.d.shuttle.de)
463
464         * misc.c (checksum_u16): Fixed a stupid bug which caused a
465         wrong checksum calculation for the secret key protection and
466         add a backward compatibility option.
467         * g10.c (main): Add option --emulate-checksum-bug.
468
469 Thu Jun 11 13:26:44 1998  Werner Koch  (wk@isil.d.shuttle.de)
470
471         * packet.h: Major changes to the structure of public key material
472         which is now stored in an array and not anaymore in a union of
473         algorithm specific structures.  These is needed to make the system
474         more extendable and makes a lot of stuff much simpler. Changed
475         all over the system.
476
477         * dsa.c, rsa.c, elg.c: Removed.
478
479 Wed Jun 10 07:22:02 1998  Werner Koch,mobil,,,  (wk@tobold)
480
481         * g10.c ("load-extension"): New option.
482
483 Mon Jun  8 22:23:37 1998  Werner Koch  (wk@isil.d.shuttle.de)
484
485         * seckey-cert.c (do_check): Removed cipher constants
486         (protect_secret_key): Ditto.
487
488 Fri May 29 10:00:28 1998  Werner Koch  (wk@isil.d.shuttle.de)
489
490         * trustdb.c (query_trust_info): New.
491         * keylist.c (list_one): Add output of trust info
492         * mainproc (list_node): ditto.
493         * g10.c (main): full trustdb init if -with-colons and any of the
494         key list modes.
495
496 Thu May 28 10:34:42 1998  Werner Koch  (wk@isil.d.shuttle.de)
497
498         * status.c (STATUS_RSA_OR_IDEA): New.
499         * sig-check.c (check_signature): Output special status message.
500         * pubkey-enc.c (get_session_key): Ditto.
501
502         * mainproc.c (check_sig_and_print): Changed format of output.
503         * passpharse.c (passphrase_to_dek): Likewise.
504
505 Wed May 27 13:46:48 1998  Werner Koch  (wk@isil.d.shuttle.de)
506
507         * g10.c (aListSecretKeys): New option --list-secret-keys
508         * keylist.c (std_key_list): Renamed to public_key_list.
509         (secret_key_list): New
510         (list_one, list_all): Add support for secret keys.
511         * getkey.c (get_secret_keyring): New.
512         * mainproc.c (list_node): Add option --with-colons for secret keys
513
514         * sig-check.c (check_key_signature): detection of selfsigs
515         * mainproc.c (list_node): fixed listing.
516
517         * g10.c (aListSecretKeys): New option --always-trust
518         * pkclist.c (do_we_trust): Override per option added
519
520         * status.c (write_status_text): Add a prefix to every output line.
521
522 Wed May 27 07:49:21 1998  Werner Koch  (wk@isil.d.shuttle.de)
523
524         * g10 (--compress-keys): New.
525         * options.h (compress_keys): New.
526         * export.c (export_pubkeys): Only compresses with the new option.
527
528 Tue May 26 11:24:33 1998  Werner Koch  (wk@isil.d.shuttle.de)
529
530         * passphrase.c (get_last_passphrase): New
531         (set_next_passphrase): New.
532         (passphrase_to_dek): add support for the above functions.
533         * keyedit.c (make_keysig_packet): Add sigclass 0x18,
534         changed all callers due to a new argument.
535         * keygen.c (write_keybinding): New
536         (generate_subkeypair): Add functionality
537         (ask_algo, ask_keysize, ask_valid_days): Broke out of generate_keypair
538         (ask_user_id, ask_passphrase): Ditto.
539
540 Thu May 21 11:26:13 1998  Werner Koch  (wk@isil.d.shuttle.de)
541
542         * g10.c,gpgd.c (main): Does now return an int, so that egcs does
543         not complain.
544
545         * armor.c (fake_packet): Removed erro message and add a noticed
546         that this part should be fixed.
547
548         * sign.c (sign_file): Compression now comes in front of encryption.
549         * encode.c (encode_simple): Ditto.
550         (encode_crypt): Ditto.
551
552 Tue May 19 16:18:19 1998  Werner Koch  (wk@isil.d.shuttle.de)
553
554         * armor.c (fake_packet): Changed assertion to log_error
555
556 Sat May 16 16:02:06 1998  Werner Koch  (wk@isil.d.shuttle.de)
557
558         * build-packet.c (build_packet): Add SUBKEY packets.
559
560 Fri May 15 17:57:23 1998  Werner Koch  (wk@isil.d.shuttle.de)
561
562         * sign.c (hash_for): New and used in all places here.
563         * main.h (DEFAULT_): new macros.
564         * g10.c  (opt.def_digest_algo): Now set to 0
565
566         * compress.c (init_compress): Add support for algo 1
567         * options.h (def_compress_algo): New
568         * g10.c (main): New option --compress-algo
569
570 Fri May 15 13:23:59 1998  Werner Koch  (wk@isil.d.shuttle.de)
571
572         * g10.c (print_mds): New feature to print only one hash,
573         chnaged formatting.
574
575 Thu May 14 15:36:24 1998  Werner Koch  (wk@isil.d.shuttle.de)
576
577         * misc.c (trap_unaligned) [__alpha__]: New
578         * g10.c (trap_unaligned): Add call to this to track down SIGBUS
579         on Alphas (to avoid the slow emulation code).
580
581 Wed May 13 11:48:27 1998  Werner Koch  (wk@isil.d.shuttle.de)
582
583         * build-packet.c (do_signature): Support for v4 pakets.
584         * keyedit.c (make_keysig_packet): Ditto.
585         * build-packet.c (build_sig_subpkt_from_sig): New.
586         (build_sig_subpkt): New.
587
588         * elg.c (g10_elg_sign): removed keyid_from_skc.
589         * dsa.c (g10_dsa_sign): Ditto.
590         * rsa.c (g10_rsa_sign): Ditto.
591         * keyedit.c (make_keysig_packet): Add call to keyid_from_skc
592
593         * sign.c (clearsign_file): Support for v4 signatures.
594         (sign_file): Ditto.
595
596 Wed May  6 09:31:24 1998  Werner Koch  (wk@isil.d.shuttle.de)
597
598         * parse-packet.c (do_parse): add support for 5 byte length leader.
599         (parse_subpkt): Ditto.
600         * build-packet.c (write_new_header): Ditto.
601
602         * packet.h (SIGSUBPKT_): New constants.
603         * parse-packet.c (parse_sig_subpkt): Changed name, made global,
604         and arg to return packet length, chnaged all callers
605
606
607 Tue May  5 22:11:59 1998  Werner Koch  (wk@isil.d.shuttle.de)
608
609         * keygen.c (gen_dsa): New.
610         * build_packet.c (do_secret_cert): Support for DSA
611
612 Mon May  4 19:01:25 1998  Werner Koch  (wk@isil.d.shuttle.de)
613
614         * compress.c: doubled buffer sizes
615         * parse-packet.c (do_plaintext): now uses iobuf_read/write.
616
617 Mon May  4 09:35:53 1998  Werner Koch  (wk@isil.d.shuttle.de)
618
619         * seskey.c (encode_md_value): Add optional argument hash_algo,
620         changed all callers.
621
622         * passphrase.c (make_dek_from_passphrase): Removed
623         * (get_passhrase_hash): Changed name to passphrase_to_dek, add arg,
624         changed all callers.
625
626         * all: Introduced the new ELG identifier and added support for the
627         encryption only one (which is okay to use by GNUPG for signatures).
628
629 Sun May  3 17:50:26 1998  Werner Koch  (wk@isil.d.shuttle.de)
630
631         * packet.h (PKT_OLD_COMMENT): New name for type 16.
632         * parse-packet.c (parse_comment): Now uses type 61
633
634 Fri May  1 12:44:39 1998  Werner Koch,mobil,,,  (wk@tobold)
635
636         * packet.h (count): Chnaged s2k count from byte to u32.
637         * seckey-cert.c (do_check): Changed s2k algo 3 to 4, changed
638         reading of count.
639         * build-packet.c (do_secret_cert): ditto.
640         * parse-packet.c (parse_certificate): ditto.
641
642         * parse-packet.c (parse_symkeyenc): New.
643         * build-packet.c (do_symkey_enc): New.
644
645 Thu Apr 30 16:33:34 1998  Werner Koch  (wk@isil.d.shuttle.de)
646
647         * sign.c (clearsign_file): Fixed "Hash: " armor line.
648
649 Tue Apr 28 14:27:42 1998  Werner Koch  (wk@isil.d.shuttle.de)
650
651         * parse-packet.c (parse_subpkt): Some new types.
652
653 Mon Apr 27 12:53:59 1998  Werner Koch  (wk@isil.d.shuttle.de)
654
655         * g10.c (main): Add option --skip-verify.
656         * mainproc.c (check_sig_and_print): Ditto.
657
658         * g10.c (print_mds): Add output for Tiger.
659
660         * sign.c (sign_file): Now uses partial length headers if used
661         in canonical textmode (kludge to fix a bug).
662
663         * parse-packet.c (parse_certificate): Changed BLOWFISH id.
664         * pubkey-enc.c (get_session_key): Ditto.
665         * seskey.c (make_session_key): Ditto.
666         * seckey-cert.c (protect_secret_key,do_check): Add BLOWFISH160.
667
668 Fri Apr 24 17:38:48 1998  Werner Koch,mobil,,,  (wk@tobold)
669
670         * sig-check.c (check_key_signature): Add sig-class 0x14..0x17
671         * keyedit.c (sign-key): Some changes to start with support of
672         the above new sig-classes.
673
674 Wed Apr 22 09:01:57 1998  Werner Koch,mobil,,,  (wk@tobold)
675
676         * getkey.c (compare_name): add email matching
677
678 Tue Apr 21 16:17:12 1998  Werner Koch,mobil,,,  (wk@tobold)
679
680         * armor.c (armor_filter): fixed missing last LF before CSUM.
681
682 Thu Apr  9 11:35:22 1998  Werner Koch  (wk@isil.d.shuttle.de)
683
684         * seckey-cert.c (do_check): New; combines all the check functions
685         into one.
686
687         * sign.c: removed all key management functions
688         * keyedit.c: New.
689
690 Thu Apr  9 09:49:36 1998  Werner Koch  (wk@isil.d.shuttle.de)
691
692         * import.c (chk_self_sigs): Changed an error message.
693
694 Wed Apr  8 16:19:39 1998  Werner Koch  (wk@isil.d.shuttle.de)
695
696         * packet.h: packet structs now uses structs from the pubkey,
697         removed all copy operations from packet to pubkey structs.
698
699 Wed Apr  8 13:40:33 1998  Werner Koch  (wk@isil.d.shuttle.de)
700
701         * trustdb.c (verify_own_certs): Fixed "public key not found".
702
703         * getkey.c (key_byname): New, combines public and secret key search.
704
705         * pkclist.c (build_pkc_list): Add new arg usage, changed all callers.
706         * skclist.c (build_skc_list): Likewise.
707
708         * ringedit.c (find_keyblock, keyring_search2): Removed.
709
710 Wed Apr  8 09:47:21 1998  Werner Koch  (wk@isil.d.shuttle.de)
711
712         * sig-check.c (do_check): Applied small fix from Ulf Möller.
713
714 Tue Apr  7 19:28:07 1998  Werner Koch  (wk@isil.d.shuttle.de)
715
716         * cipher.c, encr-data.c, seckey-cert.c: Now uses cipher_xxxx
717         functions instead of blowfish_xxx or cast_xxx
718
719 Tue Apr  7 11:04:02 1998  Werner Koch  (wk@isil.d.shuttle.de)
720
721         * Makefile.am (g10maint.o): Changed the way it is created.
722
723 Mon Apr  6 11:17:08 1998  Werner Koch  (wk@isil.d.shuttle.de)
724
725         * misc.c: New.
726         * keygen.c (checksum,checksum_u16,checksum_mpi): Moved to misc.c
727         * seckey-cert.c: Kludge for wrong ELG checksum implementation.
728
729 Sat Apr  4 20:07:01 1998  Werner Koch  (wk@isil.d.shuttle.de)
730
731         * cipher.c (cipher_filter): Support for CAST5
732         * encr-data.c (decode_filter): Ditto.
733         (decrypt_data): Ditto.
734         * seskey.c (make_session_key): Ditto.
735         * seckey-cert.c (check_elg, check_dsa): Ditto,
736         (protect_secret_key): Ditto.
737         * pubkey-enc.c (get_session_key): Ditto.
738         * passphrase.c (hash_passphrase): Ditto.
739
740 Thu Apr  2 20:22:35 1998  Werner Koch  (wk@isil.d.shuttle.de)
741
742         * gpgd.c: New
743
744 Thu Apr  2 10:38:16 1998  Werner Koch  (wk@isil.d.shuttle.de)
745
746         * keygen.c (generate_keypair): Add valid_days stuff.
747         * trustdb.c (check_trust): Add check for valid_days.
748
749 Wed Apr  1 16:15:58 1998  Werner Koch  (wk@isil.d.shuttle.de)
750
751         * keygen.c (generate_keypair): Addional question whether the
752         selected large keysize is really needed.
753
754 Wed Apr  1 15:56:33 1998  Werner Koch  (wk@isil.d.shuttle.de)
755
756         * seckey-cert.c (protect_secret_key): merged protect_xxx to here.
757
758 Wed Apr  1 10:34:46 1998  Werner Koch  (wk@isil.d.shuttle.de)
759
760         * Makefile.am (g10maint.c): Changed creation rule, so that it works
761         on FreeBSD (missing CFLAGS).
762
763         * parse-packet.c (parse_subkey): Removed.
764
765 Thu Mar 19 15:22:36 1998  Werner Koch  (wk@isil.d.shuttle.de)
766
767         * ringedit.c (keyring_enum): Fixed problem with reading too
768         many packets. Add support to read secret keyrings.
769
770         * getkey.c (scan_keyring): Removed
771         (lookup): New to replace scan_keyring.
772         (scan_secret_keyring): Removed.
773         (lookup_skc): New.
774
775 Wed Mar 18 11:47:34 1998  Werner Koch  (wk@isil.d.shuttle.de)
776
777         * ringedit.c (enum_keyblocks): New read mode 11.
778
779         * keyid.c (elg_fingerprint_md): New and changed all other functions
780         to call this if the packet version is 4 or above.
781
782 Tue Mar 17 20:46:16 1998  Werner Koch  (wk@isil.d.shuttle.de)
783
784         * parse-packet.c (parse_certificate): Add listing support for subkeys.
785
786 Tue Mar 17 20:32:22 1998  Werner Koch  (wk@isil.d.shuttle.de)
787
788         * armor.c (is_armored): Allow marker packet.
789
790 Thu Mar 12 13:36:49 1998  Werner Koch  (wk@isil.d.shuttle.de)
791
792         * trustdb.c (check_trust): Checks timestamp of pubkey.
793         * sig-check. (do_check): Compares timestamps.
794
795 Tue Mar 10 17:01:56 1998  Werner Koch  (wk@isil.d.shuttle.de)
796
797         * g10.c (main): Add call to init_signals.
798         * signal.c: New.
799
800 Mon Mar  9 12:43:42 1998  Werner Koch  (wk@isil.d.shuttle.de)
801
802         * dsa.c: New
803         * packet.h, free-packet.c, parse-packet.c : Add support for DSA
804         * sig-check.c, getkey.c, keyid.c, ringedit.c: Ditto.
805         * seckey-cert.c: Ditto.
806
807         * packet.h : Moved .digest_algo of signature packets to outer
808         structure. Changed all references
809
810 Sun Mar  8 13:06:42 1998  Werner Koch  (wk@isil.d.shuttle.de)
811
812         * openfile.c : Support for stdout filename "-".
813
814         * mainproc.c (check_sig_and_print): Enhanced status output:
815         * status.c (write_status_text): New.
816
817 Fri Mar  6 16:10:54 1998  Werner Koch  (wk@isil.d.shuttle.de)
818
819         * kbnode.c (clone_kbnode): Fixed private_flag.
820
821         * mainproc.c (list_node): Output of string "Revoked" as user-id.
822
823 Fri Mar  6 14:26:39 1998  Werner Koch  (wk@isil.d.shuttle.de)
824
825         * g10.c (main): Add userids to "-kv" and cleaned up this stuff.
826
827 Fri Mar  6 12:45:58 1998  Werner Koch  (wk@isil.d.shuttle.de)
828
829         * g10.c (main): Changed semantics of the list-... commands
830         and added a new one. Removed option "-d"
831
832         * decrypt.c: New.
833
834         * trustdb.c (init_trustdb): Autocreate directory only if it ends
835         in "/.gnupg".
836
837 Thu Mar  5 12:12:11 1998  Werner Koch  (wk@isil.d.shuttle.de)
838
839         * mainproc.c (do_proc_packets): New. Common part of proc_packet.
840         (proc_signature_packets): special version to handle signature data.
841         * verify.c: New.
842         * g10.c (aVerify): New.
843         * plaintext.c (hash_datafiles): New.
844         * compress.c (handle_compressed): Add callback arg, changed caller.
845
846 Thu Mar  5 10:20:06 1998  Werner Koch  (wk@isil.d.shuttle.de)
847
848         * g10.c: Is nom the common source for gpg and gpgm
849         * g10maint.c: Removed
850         * Makefile.am: Add rule to build g10maint.c
851
852 Thu Mar  5 08:43:59 1998  Werner Koch  (wk@isil.d.shuttle.de)
853
854         * g10.c (main): Changed the way clear text sigs are faked.
855
856 Wed Mar  4 19:47:37 1998  Werner Koch  (wk@isil.d.shuttle.de)
857
858         * g10maint.c (aMuttKeyList): New
859         * keylist.c: New.
860
861 Wed Mar  4 17:20:33 1998  Werner Koch  (wk@isil.d.shuttle.de)
862
863         * getkey.c (get_pubkey_byname): Kludge to allow 0x prefix.
864
865 Tue Mar  3 13:46:55 1998  Werner Koch  (wk@isil.d.shuttle.de)
866
867         * g10maint.c (main): New option --gen-random.
868
869 Tue Mar  3 09:50:08 1998  Werner Koch  (wk@isil.d.shuttle.de)
870
871         * g10.c (aDeleteSecretKey): New.
872         (aEditSig): Add option "--edit-key" as synonym for "--edit-sig".
873         (aDeleteSecretKey): New.
874         * getkey.c (seckey_available): New.
875         * sign.c (delete_key): Enhanced to delete secret keys, changed all
876         callers.
877
878 Mon Mar  2 21:23:48 1998  Werner Koch  (wk@isil.d.shuttle.de)
879
880         * pkc_list.c (build_pkc_list): Add interactive input of user ID.
881
882 Mon Mar  2 20:54:05 1998  Werner Koch  (wk@isil.d.shuttle.de)
883
884         * pkclist.c (do_we_trust_pre): New.
885         (add_ownertrust): Add message.
886         * trustdb.c (enum_trust_web): Quick fix.
887
888 Mon Mar  2 13:50:53 1998  Werner Koch  (wk@isil.d.shuttle.de)
889
890         * g10.c (main): New action aDeleteKey
891         * sign.c (delete_key): New.
892
893 Sun Mar  1 16:38:58 1998  Werner Koch  (wk@isil.d.shuttle.de)
894
895         * trustdb.c (do_check): No returns TRUST_UNDEFINED instead of
896         eof error.
897
898 Fri Feb 27 18:14:03 1998  Werner Koch  (wk@isil.d.shuttle.de)
899
900         * armor.c (find_header): Removed trailing CR on headers.
901
902 Fri Feb 27 18:02:48 1998  Werner Koch  (wk@isil.d.shuttle.de)
903
904         * ringedit.c (keyring_search) [MINGW32]: Open and close file here
905         because rename does not work on open files. Chnaged callers.
906
907 Fri Feb 27 16:43:11 1998  Werner Koch  (wk@isil.d.shuttle.de)
908
909         * sig-check.c (do_check): Add an md_enable.
910         * mainproc.c (do_check_sig): Use md_open in case of detached sig
911         (proc_tree): Take detached sigs into account.
912
913 Fri Feb 27 15:22:46 1998  Werner Koch  (wk@isil.d.shuttle.de)
914
915         * g10.c (main): Make use of GNUPGHOME envvar.
916         * g10main.c (main): Ditto.
917
918 Wed Feb 25 11:40:04 1998  Werner Koch  (wk@isil.d.shuttle.de)
919
920         * plaintext.c (ask_for_detached_datafile): add opt.verbose to
921         info output.
922
923         * openfile.c (open_sigfile): Try also name ending in ".asc"
924
925 Wed Feb 25 08:41:00 1998  Werner Koch  (wk@isil.d.shuttle.de)
926
927         * keygen.c (generate_keypair): Fixed memory overflow.
928
929 Tue Feb 24 15:51:55 1998  Werner Koch  (wk@isil.d.shuttle.de)
930
931         * parse-packet.c (parse_certificate): Support for S2K.
932         * build-packet.c (do_secret_cert): Ditto.
933         * keygen.c (gen_elg): Ditto.
934         * seckey-cert.c (check_elg): Ditto
935         (protect_elg): Ditto.
936         * sign.c (chnage_passphrase): Ditto.
937         * passphrase.c (get_passphrase_hash): Support for a salt and
938         changed all callers.
939         (make_dek_from_passphrase): Ditto.
940
941 Tue Feb 24 12:30:56 1998  Werner Koch  (wk@isil.d.shuttle.de)
942
943         * build-packet.c (hash_public_cert): Disabled debug output.
944
945 Fri Feb 20 17:22:28 1998  Werner Koch  (wk@isil.d.shuttle.de)
946
947         * trustdb.c (init_trustdb) [MINGW32]: Removed 2nd mkdir arg.
948         (keyring_copy) [MINGW32]: Add a remove prior to the renames.
949
950 Wed Feb 18 18:39:02 1998  Werner Koch  (wk@isil.d.shuttle.de)
951
952         * Makefile.am (OMIT_DEPENDENCIES): New.
953
954         * rsa.c: Replaced log_bug by BUG.
955
956 Wed Feb 18 13:35:58 1998  Werner Koch  (wk@isil.d.shuttle.de)
957
958         * mainproc.c (do_check_sig): Now uses hash_public_cert.
959         * parse-packet.c (parse_certificate): Removed hashing.
960         * packet.h (public_cert): Removed hash variable.
961         * free-packet.c (copy_public_cert, free_public_cert): Likewise.
962
963         * sig-check.c (check_key_signatures): Changed semantics.
964
965 Wed Feb 18 12:11:28 1998  Werner Koch  (wk@isil.d.shuttle.de)
966
967         * trustdb.c (do_check): Add handling for revocation certificates.
968         (build_sigrecs): Ditto.
969         (check_sigs): Ditto.
970
971 Wed Feb 18 09:31:04 1998  Werner Koch  (wk@isil.d.shuttle.de)
972
973         * armor.c (armor_filter): Add afx->hdrlines.
974         * revoke.c (gen_revoke): Add comment line.
975         * dearmor.c (enarmor_file): Ditto.
976
977         * sig-check.c (check_key_signature): Add handling for class 0x20.
978         * mainproc.c : Ditto.
979
980 Tue Feb 17 21:24:17 1998  Werner Koch  (wk@isil.d.shuttle.de)
981
982         * armor.c : Add header lines "...ARMORED FILE .."
983         * dearmor.c (enarmor_file): New.
984         * g10maint.c (main): New option "--enarmor"
985
986 Tue Feb 17 19:03:33 1998  Werner Koch  (wk@isil.d.shuttle.de)
987
988         * mainproc.c : Changed a lot, because the packets are now stored
989         a simple linlked list and not anymore in a complicatd tree structure.
990
991 Tue Feb 17 10:14:48 1998  Werner Koch  (wk@isil.d.shuttle.de)
992
993         * free_packet.c (cmp_public_certs): New.
994         (cmp_user_ids): New.
995
996         * kbnode.c (clone_kbnode): New.
997         (release_kbnode): Add clone support.
998
999         * ringedit.c (find_keyblock_bypkc): New.
1000
1001         * sign.c (remove_keysigs): Self signatures are now skipped,
1002         changed arguments and all callers.
1003
1004         * import.c : Add functionality.
1005
1006 Tue Feb 17 09:31:40 1998  Werner Koch  (wk@isil.d.shuttle.de)
1007
1008         * options.h (homedir): New option.
1009         * g10.c, g10maint.c, getkey.c, keygen.c, trustdb.c (opt.homedir): New.
1010
1011         * trustdb.c (init_trustdb): mkdir for hoem directory
1012         (sign_private_data): Renamed "sig" to "g10.sig"
1013
1014 Mon Feb 16 20:02:03 1998  Werner Koch  (wk@isil.d.shuttle.de)
1015
1016         * kbnode.c (commit_kbnode): New.
1017         (delete_kbnode): removed unused first arg. Changed all Callers.
1018
1019         * ringedit.c (keyblock_resource_name): New.
1020         (get_keyblock_handle): NULL for filename returns default resource.
1021
1022 Mon Feb 16 19:38:48 1998  Werner Koch  (wk@isil.d.shuttle.de)
1023
1024         * sig-check.s (check_key_signature): Now uses the supplied
1025         public key to check the signature and not any more the one
1026         from the getkey.c
1027         (do_check): New.
1028         (check_signature): Most work moved to do_check.
1029
1030 Mon Feb 16 14:48:57 1998  Werner Koch  (wk@isil.d.shuttle.de)
1031
1032         * armor.c (find_header): Fixed another bug.
1033
1034 Mon Feb 16 12:18:34 1998  Werner Koch  (wk@isil.d.shuttle.de)
1035
1036         * getkey.c (scan_keyring): Add handling of compressed keyrings.
1037
1038 Mon Feb 16 10:44:51 1998  Werner Koch  (wk@isil.d.shuttle.de)
1039
1040         * g10.c, g10maint.c (strusage): Rewrote.
1041         (build_list): New
1042
1043 Mon Feb 16 08:58:41 1998  Werner Koch  (wk@isil.d.shuttle.de)
1044
1045         * armor.c (use_armor): New.
1046
1047 Sat Feb 14 14:30:57 1998  Werner Koch  (wk@isil.d.shuttle.de)
1048
1049         * mainproc.c (proc_tree): Sigclass fix.
1050
1051 Sat Feb 14 14:16:33 1998  Werner Koch  (wk@isil.d.shuttle.de)
1052
1053         * armor.c (armor_filter): Changed version and comment string.
1054         * encode.c, sign.c, keygen.c: Changed all comment packet strings.
1055
1056 Sat Feb 14 12:39:24 1998  Werner Koch  (wk@isil.d.shuttle.de)
1057
1058         * g10.c (aGenRevoke): New command.
1059         * revoke.c: New.
1060         * sign.c (make_keysig_packet): Add support for sigclass 0x20.
1061
1062 Fri Feb 13 20:18:14 1998  Werner Koch  (wk@isil.d.shuttle.de)
1063
1064         * ringedit.c (enum_keyblocks, keyring_enum): New.
1065
1066 Fri Feb 13 19:33:40 1998  Werner Koch  (wk@isil.d.shuttle.de)
1067
1068         * export.c: Add functionality.
1069
1070         * keygen.c (generate_keypair): Moved the leading comment behind the
1071         key packet.
1072         * kbnode.c (walk_kbnode): Fixed.
1073
1074         * g10.c (main): listing armored keys now work.
1075
1076 Fri Feb 13 16:17:43 1998  Werner Koch  (wk@isil.d.shuttle.de)
1077
1078         * parse-packet.c (parse_publickey, parse_signature): Fixed calls
1079         to mpi_read used for ELG b.
1080
1081 Fri Feb 13 15:13:23 1998  Werner Koch  (wk@isil.d.shuttle.de)
1082
1083         * g10.c (main): changed formatting of help output.
1084
1085 Thu Feb 12 22:24:42 1998  Werner Koch  (wk@frodo)
1086
1087         * pubkey-enc.c (get_session_key): rewritten
1088