Release 0.0j
[heimdal.git] / ChangeLog
blob869ed94bdc7c4f2ec36af3c8e6a2c79c9590bdfe
1 Mon Oct 13 17:18:57 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
3         * Release 0.0j
5         * lib/krb5/get_cred.c: Get the subkey from mk_req so it can be
6         used to decrypt the reply from DCE secds.
8         * lib/krb5/auth_context.c: Add {get,set}enctype.
10         * lib/krb5/get_cred.c: Fix for DCE secd.
12         * lib/krb5/store.c: Store keytype twice, as MIT does.
14         * lib/krb5/get_in_tkt.c: Use etype from reply.
16 Fri Oct 10 00:39:48 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
18         * kdc/connect.c: check for leading '/' in http request
20 Tue Sep 30 21:50:18 1997  Assar Westerlund  <assar@assaris.pdc.kth.se>
22         * Release 0.0i
24 Mon Sep 29 15:58:43 1997  Assar Westerlund  <assar@sics.se>
26         * lib/krb5/rd_req.c (krb5_rd_req): redone because we don't know
27         the kvno or keytype before receiving the AP-REQ
29         * lib/krb5/mk_safe.c (krb5_mk_safe): figure out what cksumtype to
30         use from the keytype.
32         * lib/krb5/mk_req_ext.c (krb5_mk_req_extended): figure out what
33         cksumtype to use from the keytype.
35         * lib/krb5/mk_priv.c (krb5_mk_priv): figure out what etype to use
36         from the keytype.
38         * lib/krb5/keytab.c (krb5_kt_get_entry): check the keytype
40         * lib/krb5/get_for_creds.c (krb5_get_forwarded_creds): figure out
41         what etype to use from the keytype.
43         * lib/krb5/generate_seq_number.c (krb5_generate_seq_number):
44         handle other key types than DES
46         * lib/krb5/encrypt.c (key_type): add `best_cksumtype'
47         (krb5_keytype_to_cksumtype): new function
49         * lib/krb5/build_auth.c (krb5_build_authenticator): figure out
50         what etype to use from the keytype.
52         * lib/krb5/auth_context.c (krb5_auth_con_init): set `cksumtype'
53         and `enctype' to 0
55         * admin/extkeytab.c (ext_keytab): extract all keys
57         * appl/telnet/telnet/commands.c: INET6_ADDRSTRLEN kludge
59         * configure.in: check for <netinet6/in6.h>. check for -linet6
60         
61 Tue Sep 23 03:00:53 1997  Assar Westerlund  <assar@sics.se>
63         * lib/krb5/encrypt.c: fix checksumtype for des3-cbc-sha1
65         * lib/krb5/rd_safe.c: fix check for keyed and collision-proof
66         checksum
68         * lib/krb5/context.c (valid_etype): remove hard-coded constants
69         (default_etypes): include DES3
71         * kdc/kerberos5.c: fix check for keyed and collision-proof
72         checksum
74         * admin/util.c (init_des_key, set_password): DES3 keys also
76         * lib/krb/send_to_kdc.c (krb5_sendto_kdc): no data returned means
77         no contact?
79         * lib/krb5/addr_families.c: fix typo in `ipv6_anyaddr'
81 Mon Sep 22 11:44:27 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
83         * kdc/kerberos5.c: Somewhat fix the etype usage. The list sent by
84         the client is used to select wich key to encrypt the kdc rep with
85         (in case of as-req), and with the server info to select the
86         session key type. The server key the ticket is encrypted is based
87         purely on the keys in the database.
89         * kdc/string2key.c: Add keytype support. Default to version 5
90         keys.
92         * lib/krb5/get_in_tkt.c: Fix a lot of etype/keytype misuse.
94         * lib/krb5/encrypt.c: Add des3-cbc-md5, and des3-cbc-sha1. Add
95         many *_to_* functions.
97         * lib/krb5/str2key.c: Add des3 string-to-key. Add ktype argument
98         to krb5_string_to_key().
100         * lib/krb5/checksum.c: Some cleanup, and added: 
101           - rsa-md5-des3 
102           - hmac-sha1-des3 
103           - keyed and collision proof flags to each checksum method
104           - checksum<->string functions.
106         * lib/krb5/generate_subkey.c: Use krb5_generate_random_keyblock.
108 Sun Sep 21 15:19:23 1997  Assar Westerlund  <assar@sics.se>
110         * kdc/connect.c: use new addr_families functions
112         * kpasswd/kpasswdd.c: use new addr_families functions.  Now works
113         over IPv6
115         * kuser/klist.c: use correct symbols for address families
117         * lib/krb5/sock_principal.c: use new addr_families functions
119         * lib/krb5/send_to_kdc.c: use new addr_families functions
121         * lib/krb5/krb5.h: add KRB5_ADDRESS_INET6
123         * lib/krb5/get_addrs.c: use new addr_families functions
125         * lib/krb5/changepw.c: use new addr_families functions.  Now works
126         over IPv6
128         * lib/krb5/auth_context.c: use new addr_families functions
130         * lib/krb5/addr_families.c: new file
132         * acconfig.h: AC_SOCKADDR_IN6 -> AC_STRUCT_SOCKADDR_IN6.  Updated
133         uses.
135         * acinclude.m4: new macro `AC_KRB_IPV6'.  Use it.
137 Sat Sep 13 23:04:23 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
139         * kdc/hprop.c: Don't encrypt twice. Complain on non-convertable
140         principals.
142 Sat Sep 13 00:59:36 1997  Assar Westerlund  <assar@sics.se>
144         * Release 0.0h
145         
146         * appl/telnet/telnet/commands.c: AF_INET6 support
148         * admin/misc.c: new file
150         * lib/krb5/context.c: new configuration variable `max_retries'
152         * lib/krb5/get_addrs.c: fixes and better #ifdef's
154         * lib/krb5/config_file.c: implement krb5_config_get_int
156         * lib/krb5/auth_context.c, send_to_kdc.c, sock_principal.c:
157         AF_INET6 support
159         * kuser/klist.c: support for printing IPv6-addresses
161         * kdc/connect.c: support AF_INET6
163         * configure.in: test for gethostbyname2 and struct sockaddr_in6
165 Thu Sep 11 07:25:28 1997  Assar Westerlund  <assar@sics.se>
167         * lib/asn1/k5.asn1: Use `METHOD-DATA' instead of `SEQUENCE OF
168         PA-DATA'
170 Wed Sep 10 21:20:17 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
172         * kdc/kerberos5.c: Fixes for cross-realm, including (but not
173         limited to):
174           - allow client to be non-existant (should probably check for
175             "local realm")
176           - if server isn't found and it is a request for a krbtgt, try to
177             find a realm on the way to the requested realm
178           - update the transited encoding iff 
179             client-realm != server-realm != tgt-realm
181         * lib/krb5/get_cred.c: Several fixes for cross-realm.
183 Tue Sep  9 15:59:20 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
185         * kdc/string2key.c: Fix password handling.
187         * lib/krb5/encrypt.c: krb5_key_to_string
189 Tue Sep  9 07:46:05 1997  Assar Westerlund  <assar@sics.se>
191         * lib/krb5/get_addrs.c: rewrote.  Now should be able to handle
192         aliases and IPv6 addresses
194         * kuser/klist.c: try printing IPv6 addresses
196         * kdc/kerberos5.c: increase the arbitrary limit from 1024 to 8192
198         * configure.in: check for <netinet/in6_var.h>
200 Mon Sep  8 02:57:14 1997  Assar Westerlund  <assar@sics.se>
202         * doc: fixes
204         * admin/util.c (init_des_key): increase kvno
205         (set_password): return -1 if `des_read_pw_string' failed
207         * admin/mod.c (doit2): check the return value from `set_password'
209         * admin/ank.c (doit): don't add a new entry if `set_password'
210         failed
212 Mon Sep  8 02:20:16 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
214         * lib/krb5/verify_init.c: fix ap_req_nofail semantics
216         * lib/krb5/transited.c: something that might resemble
217         domain-x500-compress
219 Mon Sep  8 01:24:42 1997  Assar Westerlund  <assar@sics.se>
221         * kdc/hpropd.c (main): check number of arguments
223         * appl/popper/pop_init.c (pop_init): check number of arguments
225         * kpasswd/kpasswd.c (main): check number of arguments
227         * kdc/string2key.c (main): check number of arguments
229         * kuser/kdestroy.c (main): check number of arguments
231         * kuser/kinit.c (main): check number of arguments
233         * kpasswd/kpasswdd.c (main): use sigaction without SA_RESTART to
234         break out of select when a signal arrives
236         * kdc/main.c (main): use sigaction without SA_RESTART to break out
237         of select when a signal arrives
239         * kdc/kstash.c: default to HDB_DB_DIR "/m-key"
241         * kdc/config.c (configure): add `--version'.  Check the number of
242         arguments. Handle the case of there being no specification of port
243         numbers.
245         * admin/util.c: seal and unseal key at appropriate places
247         * admin/kdb_edit.c (main): parse arguments, config file and read
248         master key iff there's one.
250         * admin/extkeytab.c (ext_keytab): unseal key while extracting
252 Sun Sep  7 20:41:01 1997  Assar Westerlund  <assar@sics.se>
254         * lib/roken/roken.h: include <fcntl.h>
256         * kdc/kerberos5.c (set_salt_padata): new function
258         * appl/telnet/telnetd/telnetd.c: Rename some variables that
259         conflict with cpp symbols on HP-UX 10.20
261         * change all calls of `gethostbyaddr' to cast argument 1 to `const
262         char *'
264         * acconfig.h: only use SGTTY on nextstep
266 Sun Sep  7 14:33:50 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
268         * kdc/kerberos5.c: Check invalid flag.
270 Fri Sep  5 14:19:38 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
272         * lib/krb5/verify_user.c: Use get_init_creds/verify_init_creds.
274         * lib/kafs: Move functions common to krb/krb5 modules to new file,
275         and make things more modular.
277         * lib/krb5/krb5.h: rename STRING -> krb5_config_string, and LIST
278         -> krb5_config_list
280 Thu Sep  4 23:39:43 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
282         * lib/krb5/get_addrs.c: Fix loopback test.
284 Thu Sep  4 04:45:49 1997  Assar Westerlund  <assar@sics.se>
286         * lib/roken/roken.h: fallback definition of `O_ACCMODE'
288         * lib/krb5/get_in_tkt.c (krb5_get_in_cred): be more careful when
289         checking for a v4 reply
291 Wed Sep  3 18:20:14 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
293         * kdc/hprop.c: Add `--decrypt' and `--encrypt' flags.
295         * lib/hdb/hdb.c: new {seal,unseal}_keys functions
297         * kdc/{hprop,hpropd}.c: Add support to dump database to stdout.
299         * kdc/hprop.c: Don't use same master key as version 4.
301         * admin/util.c: Don't dump core if no `default' is found.
303 Wed Sep  3 16:01:07 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
305         * kdc/connect.c: Allow run time port specification.
307         * kdc/config.c: Add flags for http support, and port
308         specifications.
310 Tue Sep  2 02:00:03 1997  Assar Westerlund  <assar@sics.se>
312         * include/bits.c: Don't generate ifndef's in bits.h.  Instead, use
313         them when building the program.  This makes it possible to include
314         bits.h without having defined all HAVE_INT17_T symbols.
315         
316         * configure.in: test for sigaction
318         * doc: updated documentation.
319         
320 Tue Sep  2 00:20:31 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
322         * Release 0.0g
324 Mon Sep  1 17:42:14 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
326         * lib/krb5/data.c: don't return ENOMEM if len == 0
328 Sun Aug 31 17:15:49 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
330         * lib/hdb/hdb.asn1: Include salt type in salt.
332         * kdc/hprop.h: Change port to 754.
334         * kdc/hpropd.c: Verify who tries to transmit a database.
336         * appl/popper: Use getarg and krb5_log.
338         * lib/krb5/get_port.c: Add context parameter. Now takes port in
339         host byte order.
341 Sat Aug 30 18:48:19 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
343         * kdc/connect.c: Add timeout to select, and log about expired tcp
344         connections.
346         * kdc/config.c: Add `database' option.
348         * kdc/hpropd.c: Log about duplicate entries.
350         * lib/hdb/{db,ndbm}.c: Use common routines.
352         * lib/hdb/common.c: Implement more generic fetch/store/delete
353         functions.
355         * lib/hdb/hdb.h: Add `replace' parameter to store.
356         
357         * kdc/connect.c: Set filedecriptor to -1 on allocated decriptor
358         entries.
360 Fri Aug 29 03:13:23 1997  Assar Westerlund  <assar@sics.se>
362         * lib/krb5/get_in_tkt.c: extract_ticket -> _krb5_extract_ticket
364         * aux/make-proto.pl: fix __P for stone age mode
366 Fri Aug 29 02:45:46 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
368         * lib/45/mk_req.c: implementation of krb_mk_req that uses 524
369         protocol
371         * lib/krb5/init_creds_pw.c: make change_password and
372         get_init_creds_common static
374         * lib/krb5/krb5.h: Merge stuff from removed headerfiles.
376         * lib/krb5/fcache.c: fcc_ops -> krb5_fcc_ops
378         * lib/krb5/mcache.c: mcc_ops -> krb5_mcc_ops
380 Fri Aug 29 01:45:25 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
382         * lib/krb5/krb5.h: Remove all prototypes.
384         * lib/krb5/convert_creds.c: Use `struct credentials' instead of
385         `CREDENTIALS'.
387 Fri Aug 29 00:08:18 1997  Assar Westerlund  <assar@sics.se>
389         * lib/asn1/gen_glue.c: new file. generates 2int and int2 functions
390         and units for bit strings.
392         * admin/util.c: flags2int, int2flags, and flag_units are now
393         generated by asn1_compile
395         * lib/roken/parse_units.c: generalised `parse_units' and
396         `unparse_units' and added new functions `parse_flags' and
397         `unparse_flags' that use these
399         * lib/krb5/krb5_locl.h: moved krb5_data* functions to krb5.h
401         * admin/util.c: Use {un,}parse_flags for printing and parsing
402         hdbflags.
404 Thu Aug 28 03:26:12 1997  Assar Westerlund  <assar@sics.se>
406         * lib/krb5/get_addrs.c: restructured
408         * lib/krb5/warn.c (_warnerr): leak less memory
410         * lib/hdb/hdb.c (hdb_free_entry): zero keys
411         (hdb_check_db_format): leak less memory
413         * lib/hdb/ndbm.c (NDBM_seq): check for valid hdb_entries implement
414         NDBM__get, NDBM__put
416         * lib/hdb/db.c (DB_seq): check for valid hdb_entries
418 Thu Aug 28 02:06:58 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
420         * lib/krb5/send_to_kdc.c: Don't use sendto on connected sockets.
422 Thu Aug 28 01:13:17 1997  Assar Westerlund  <assar@sics.se>
424         * kuser/kinit.1, klist.1, kdestroy.1: new man pages
426         * kpasswd/kpasswd.1, kpasswdd.8: new man pages
428         * kdc/kstash.8, hprop.8, hpropd.8: new man pages
430         * admin/ktutil.8, admin/kdb_edit.8: new man pages
432         * admin/mod.c: new file
434         * admin/life.c: renamed gettime and puttime to getlife and putlife
435         and moved them to life.c
437         * admin/util.c: add print_flags, parse_flags, init_entry,
438         set_created_by, set_modified_by, edit_entry, set_password.  Use
439         them.
441         * admin/get.c: use print_flags
443         * admin: removed unused stuff.  use krb5_{warn,err}*
445         * admin/ank.c: re-organized and abstracted.
447         * admin/gettime.c: removed
449 Thu Aug 28 00:37:39 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
451         * lib/krb5/{get_cred,get_in_tkt}.c: Check for v4 reply.
453         * lib/roken/base64.c: Add base64 functions.
455         * kdc/connect.c lib/krb5/send_to_kdc.c: Add http support.
457 Wed Aug 27 00:29:20 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
459         * include/Makefile.am: Don't make links to built files.
461         * admin/kdb_edit.c: Add command to set the database path.
463         * lib/hdb: Include version number in database.
465 Tue Aug 26 20:14:54 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
467         * admin/ktutil: Merged v4 srvtab conversion.
469 Mon Aug 25 23:02:18 1997  Assar Westerlund  <assar@sics.se>
471         * lib/roken/roken.h: add F_OK
473         * lib/gssapi/acquire_creds.c: fix typo
475         * configure.in: call AC_TYPE_MODE_T
477         * acinclude.m4: Add AC_TYPE_MODE_T
479 Sun Aug 24 16:46:53 1997  Assar Westerlund  <assar@sics.se>
481         * Release 0.0f
483 Sun Aug 24 08:06:54 1997  Assar Westerlund  <assar@sics.se>
485         * appl/rsh/rshd.c: syslog remote shells
487         * appl/popper/pop_pass.c: log poppers
489         * kdc/kaserver.c: some more checks
491         * kpasswd/kpasswd.c: removed `-p'
493         * kuser/kinit.c: removed `-p'
495         * lib/krb5/init_creds_pw.c (krb5_get_init_creds_password): If
496         KDC_ERR_PREUATH_REQUIRED, add preauthentication and try again.
498         * lib/krb5/get_in_tkt.c (krb5_get_in_cred): don't print out
499         krb-error text
501         * lib/gssapi/import_name.c (input_name): more names types.
503         * admin/load.c (parse_keys): handle the case of an empty salt
505         * kdc/kaserver.c: fix up memory deallocation
507         * kdc/kaserver.c: quick hack at talking kaserver protocol
509         * kdc/kerberos4.c: Make `db-fetch4' global
511         * configure.in: add --enable-kaserver
513         * kdc/rx.h, kdc/kerberos4.h: new header files
515         * lib/krb5/principal.c: fix krb5_build_principal_ext & c:o
517 Sun Aug 24 03:52:44 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
519         * lib/krb5/{get_in_tkt,mk_safe,mk_priv}.c: Fix some Cray specific
520         type conflicts.
522         * lib/krb5/{get_cred,get_in_tkt}.c: Mask nonce to 32 bits.
524         * lib/des/{md4,md5,sha}.c: Now works on Crays.
526 Sat Aug 23 18:15:01 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
528         * appl/afsutil/afslog.c: If no cells or files specified, get
529         tokens for all local cells. Better test for files.
531 Thu Aug 21 23:33:38 1997  Assar Westerlund  <assar@sics.se>
533         * lib/gssapi/v1.c: new file with v1 compatibility functions.
535 Thu Aug 21 20:36:13 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
537         * lib/kafs/afskrb5.c: Don't check ticket file for afs ticket.
539         * kdc/kerberos4.c: Check database when converting v4 principals.
541         * kdc/kerberos5.c: Include kvno in Ticket.
543         * lib/krb5/encrypt.c: Add kvno parameter to encrypt_EncryptedData.
545         * kuser/klist.c: Print version number of ticket, include more
546         flags.
548 Wed Aug 20 21:26:58 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
550         * lib/kafs/afskrb5.c (get_cred): Check cached afs tickets for
551         expiration.
553 Wed Aug 20 17:40:31 1997  Assar Westerlund  <assar@sics.se>
555         * lib/krb5/recvauth.c (krb5_recvauth): Send a KRB-ERROR iff
556         there's an error.
558         * lib/krb5/sendauth.c (krb5_sendauth): correct the protocol
559         documentation and process KRB-ERROR's
561 Tue Aug 19 20:41:30 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
563         * kdc/kerberos4.c: Fix memory leak in v4 protocol handler.
565 Mon Aug 18 05:15:09 1997  Assar Westerlund  <assar@sics.se>
567         * lib/gssapi/accept_sec_context.c: Added
568         `gsskrb5_register_acceptor_identity'
570 Sun Aug 17 01:40:20 1997  Assar Westerlund  <assar@sics.se>
572         * lib/gssapi/accept_sec_context.c (gss_accept_sec_context): don't
573         always pass server == NULL to krb5_rd_req.
575         * lib/gssapi: new files: canonicalize_name.c export_name.c
576         context_time.c compare_name.c release_cred.c acquire_cred.c
577         inquire_cred.c, from Luke Howard <lukeh@xedoc.com.au>
579         * lib/krb5/config_file.c: Add netinfo support from Luke Howard
580         <lukeh@xedoc.com.au>
582         * lib/editline/sysunix.c: sgtty-support from Luke Howard
583         <lukeh@xedoc.com.au>
585         * lib/krb5/principal.c: krb5_sname_to_principal fix from Luke
586         Howard <lukeh@xedoc.com.au>
588 Sat Aug 16 00:44:47 1997  Assar Westerlund  <assar@koi.pdc.kth.se>
590         * Release 0.0e
592 Sat Aug 16 00:23:46 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
594         * appl/afsutil/afslog.c: Use new libkafs.
596         * lib/kafs/afskrb5.c: Get AFS tokens via 524 protocol.
598         * lib/krb5/warn.c: Fix format string for *x type.
600 Fri Aug 15 22:15:01 1997  Assar Westerlund  <assar@sics.se>
602         * admin/get.c (get_entry): print more information about the entry
604         * lib/des/Makefile.am: build destest, mdtest, des, rpw, speed
606         * lib/krb5/config_file.c: new functions `krb5_config_get_time' and
607         `krb5_config_vget_time'.  Use them.
609 Fri Aug 15 00:09:37 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
611         * admin/ktutil.c: Keytab manipulation program.
613         * lib/krb5/keytab.c: Return sane values from resolve and
614         start_seq_get.
616         * kdc/kerberos5.c: Fix for old clients passing 0 for `no endtime'.
618         * lib/45/get_ad_tkt.c: Kerberos 4 get_ad_tkt using
619         krb524_convert_creds_kdc.
621         * lib/krb5/convert_creds.c: Implementation of
622         krb524_convert_creds_kdc.
624         * lib/asn1/k5.asn1: Make kdc-req-body.till OPTIONAL
626         * kdc/524.c: A somewhat working 524-protocol module.
628         * kdc/kerberos4.c: Add version 4 ticket encoding and encryption
629         functions.
631         * lib/krb5/context.c: Fix kdc_timeout.
633         * lib/hdb/{ndbm,db}.c: Free name in close.
635         * kdc/kerberos5.c (tgs_check_autenticator): Return error code
637 Thu Aug 14 21:29:03 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
639         * kdc/kerberos5.c (tgs_make_reply): Fix endtime in reply.
641         * lib/krb5/store_emem.c: Fix reallocation bug.
643 Tue Aug 12 01:29:46 1997  Assar Westerlund  <assar@sics.se>
645         * appl/telnet/libtelnet/kerberos5.c, appl/popper/pop_init.c,
646         appl/rshd/rshd.c: Use `krb5_sock_to_principal'.  Send server
647         parameter to krb5_rd_req/krb5_recvauth.  Set addresses in
648         auth_context.
650         * lib/krb5/recvauth.c: Set addresses in auth_context if there
651         aren't any
653         * lib/krb5/auth_context.c: New function
654         `krb5_auth_con_setaddrs_from_fd'
656         * lib/krb5/sock_principal.c: new function
657         `krb5_sock_to_principal'
658         
659         * lib/krb5/time.c: new file with `krb5_timeofday' and
660         `krb5_us_timeofday'.  Use these functions.
662         * kuser/klist.c: print KDC offset iff verbose
664         * lib/krb5/get_in_tkt.c: implement KDC time offset and use it if
665         [libdefaults]kdc_timesync is set.
666         
667         * lib/krb5/fcache.c: Implement version 4 of the ccache format.
669 Mon Aug 11 05:34:43 1997  Assar Westerlund  <assar@sics.se>
671         * lib/krb5/rd_rep.c (krb5_free_ap_rep_enc_part): free all memory
673         * lib/krb5/principal.c (krb5_unparse_name): allocate memory
674         properly
676         * kpasswd/kpasswd.c: Use `krb5_change_password'
678         * lib/krb5/init_creds_pw.c (init_cred): set realm of server
679         correctly.
681         * lib/krb5/init_creds_pw.c: support changing of password when it
682         has expired
684         * lib/krb5/changepw.c: new file
686         * kuser/klist.c: use getarg
688         * admin/init.c (init): add `kadmin/changepw'
690 Mon Aug 11 04:30:47 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
692         * lib/krb5/get_cred.c: Make get_credentials handle cross-realm.
694 Mon Aug 11 00:03:24 1997  Assar Westerlund  <assar@sics.se>
696         * lib/krb5/config_file.c: implement support for #-comments
698 Sat Aug  9 02:21:46 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
700         * kdc/hprop*.c: Add database propagation programs.
702         * kdc/connect.c: Max request size.
704 Sat Aug  9 00:47:28 1997  Assar Westerlund  <assar@sics.se>
706         * lib/otp: resurrected from krb4
708         * appl/push: new program for fetching mail with POP.
710         * appl/popper/popper.h: new include files.  new fields in `POP'
712         * appl/popper/pop_pass.c: Implement both v4 and v5.
714         * appl/popper/pop_init.c: Implement both v4 and v5.
716         * appl/popper/pop_debug.c: use getarg.  Talk both v4 and v5
718         * appl/popper: Popper from krb4.
720         * configure.in: check for inline and <netinet/tcp.h> generate
721         files in appl/popper, appl/push, and lib/otp
723 Fri Aug  8 05:51:02 1997  Assar Westerlund  <assar@sics.se>
725         * lib/krb5/get_cred.c: clean-up and try to free memory even when
726         there're errors
728         * lib/krb5/get_cred.c: adapt to new `extract_ticket'
730         * lib/krb5/get_in_tkt.c: reorganize.  check everything and try to
731         return memory even if there are errors.
733         * kuser/kverify.c: new file
735         * lib/krb5/free_host_realm.c: new file
737         * lib/krb5/principal.c (krb5_sname_to_principal): implement
738         different nametypes.  Also free memory.
740         * lib/krb5/verify_init.c: more functionality
742         * lib/krb5/mk_req_ext.c (krb5_mk_req_extended): free the checksum
744         * lib/krb5/get_in_tkt.c (extract_ticket): don't copy over the
745         principals in creds.  Should also compare them with that received
746         from the KDC
748         * lib/krb5/cache.c (krb5_cc_gen_new): copy the newly allocated
749         krb5_ccache
750         (krb5_cc_destroy): call krb5_cc_close
751         (krb5_cc_retrieve_cred): delete the unused creds
753 Fri Aug  8 02:30:40 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
755         * lib/krb5/log.c: Allow better control of destinations of logging
756         (like passing explicit destinations, and log-functions).
758 Fri Aug  8 01:20:39 1997  Assar Westerlund  <assar@sics.se>
760         * lib/krb5/get_default_principal.c: new file
762         * kpasswd/kpasswdd.c: use krb5_log*
764 Fri Aug  8 00:37:47 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
766         * lib/krb5/init_creds_pw.c: Implement krb5_get_init_creds_keytab.
768 Fri Aug  8 00:37:17 1997  Assar Westerlund  <assar@sics.se>
770         * lib/krb5/init_creds_pw.c: Use `krb5_get_default_principal'.
771         Print password expire information.
773         * kdc/config.c: new variable `kdc_warn_pwexpire'
775         * kpasswd/kpasswd.c: converted to getarg and get_init_creds
777 Thu Aug  7 22:17:09 1997  Assar Westerlund  <assar@sics.se>
779         * lib/krb5/mcache.c: new file
781         * admin/gettime.c: new function puttime.  Use it.
783         * lib/krb5/keyblock.c: Added krb5_free_keyblock and
784         krb5_copy_keyblock
786         * lib/krb5/init_creds_pw.c: more functionality
788         * lib/krb5/creds.c: Added krb5_free_creds_contents and
789         krb5_copy_creds.  Changed callers.
791         * lib/krb5/config_file.c: new functions krb5_config_get and
792         krb5_config_vget
794         * lib/krb5/cache.c: cleanup added mcache
795         
796         * kdc/kerberos5.c: include last-req's of type 6 and 7, if
797         applicable
799 Wed Aug  6 20:38:23 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
801         * lib/krb5/log.c: New parameter `log-level'. Default to `SYSLOG'.
803 Tue Aug  5 22:53:54 1997  Assar Westerlund  <assar@sics.se>
805         * lib/krb5/verify_init.c, init_creds_pw.c, init_creds.c,
806         prompter_posix.c: the beginning of an implementation of the cygnus
807         initial-ticket API.
809         * lib/krb5/get_in_tkt_pw.c: make `krb5_password_key_proc' global
811         * lib/krb5/get_in_tkt.c (krb5_get_in_cred): new function that is
812         almost krb5_get_in_tkt but doesn't write the creds to the ccache.
813         Small fixes in krb5_get_in_tkt
815         * lib/krb5/get_addrs.c (krb5_get_all_client_addrs): don't include
816         loopback.
818 Mon Aug  4 20:20:48 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
820         * kdc: Make context global.
822 Fri Aug  1 17:23:56 1997  Assar Westerlund  <assar@sics.se>
824         * Release 0.0d
826         * lib/roken/flock.c: new file
828         * kuser/kinit.c: check for and print expiry information in the
829         `kdc_rep'
831         * lib/krb5/get_in_tkt.c: Set `ret_as_reply' if != NULL
833         * kdc/kerberos5.c: Check the valid times on client and server.
834         Check the password expiration.
835         Check the require_preauth flag.
836         Send an lr_type == 6 with pw_end.
837         Set key.expiration to min(valid_end, pw_end)
838         
839         * lib/hdb/hdb.asn1: new flags `require_preauth' and `change_pw'
841         * admin/util.c, admin/load.c: handle the new flags.
843 Fri Aug  1 16:56:12 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
845         * lib/hdb: Add some simple locking.
847 Sun Jul 27 04:44:31 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
849         * lib/krb5/log.c: Add some general logging functions.
851         * kdc/kerberos4.c: Add version 4 protocol handler. The requrement
852         for this to work is that all involved principals has a des key in
853         the database, and that the client has a version 4 (un-)salted
854         key. Furthermore krb5_425_conv_principal has to do it's job, as
855         present it's not very clever.
857         * lib/krb5/principal.c: Quick patch to make 425_conv work
858         somewhat.
860         * lib/hdb/hdb.c: Add keytype->key and next key functions.
862 Fri Jul 25 17:32:12 1997  Assar Westerlund  <assar@sics.se>
864         * lib/krb5/build_auth.c (krb5_build_authenticator): don't free
865         `cksum'.  It's allocated and freed by the caller
867         * lib/krb5/get_cred.c (krb5_get_kdc_cred): Don't free `addresses'.
869         * kdc/kerberos5.c (tgs_rep2): make sure we also have an defined
870         `client' to return as part of the KRB-ERROR
872         * appl/rsh/rshd.c: implement forwarding
874         * appl/rsh/rsh.c: Use getarg.  Implement forwarding.
876 Thu Jul 24 08:13:59 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
878         * kdc/kerberos5.c: Unseal keys from database before use.
880         * kdc/misc.c: New functions set_master_key, unseal_key and
881         free_key.
883         * lib/roken/getarg.c: Handle `-f arg' correctly.
885 Thu Jul 24 01:54:43 1997  Assar Westerlund  <assar@sics.se>
887         * kuser/kinit.c: implement `-l' aka `--lifetime'
889         * lib/roken/parse_units.c, parse_time.c: new files
891         * admin/gettime.c (gettime): use `parse_time'
893         * kdc/kerberos5.c (as_rep): Use `METHOD-DATA' when sending
894         KRB5KDC_ERR_PREAUTH_REQUIRED, not PA-DATA.
896         * kpasswd/kpasswdd.c: fix freeing bug use sequence numbers set
897         addresses in auth_context bind one socket per interface.
898         
899         * kpasswd/kpasswd.c: use sequence numbers
901         * lib/krb5/rd_req.c (krb5_verify_ap_req): do abs when verifying
902         the timestamps
904         * lib/krb5/rd_priv.c (krb5_rd_priv): Fetch the correct session key
905         from auth_context
907         * lib/krb5/mk_priv.c (krb5_mk_priv): Fetch the correct session key
908         from auth_context
910         * lib/krb5/mk_error.c (krb5_mk_error): return an error number and
911         not a comerr'd number.
913         * lib/krb5/get_in_tkt.c (krb5_get_in_tkt): interpret the error
914         number in KRB-ERROR correctly.
916         * lib/krb5/get_cred.c (krb5_get_kdc_cred): interpret the error
917         number in KRB-ERROR correctly.
919         * lib/asn1/k5.asn1: Add `METHOD-DATA'
921         * removed some memory leaks.
923 Wed Jul 23 07:53:18 1997  Assar Westerlund  <assar@sics.se>
925         * Release 0.0c
927         * lib/krb5/rd_cred.c, get_for_creds.c: new files
929         * lib/krb5/get_host_realm.c: try default realm as last chance
931         * kpasswd/kpasswdd.c: updated to hdb changes
933         * appl/telnet/libtelnet/kerberos5.c: Implement forwarding
935         * appl/telnet/libtelnet: removed totally unused files
937         * admin/ank.c: fix prompts and generation of random keys
939 Wed Jul 23 04:02:32 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
941         * admin/dump.c: Include salt in dump.
943         * admin: Mostly updated for new db-format.
945         * kdc/kerberos5.c: Update to use new db format. Better checking of
946         flags and such. More logging.
948         * lib/hdb/hdb.c: Use generated encode and decode functions.
950         * lib/hdb/hdb.h: Get hdb_entry from ASN.1 generated code.
952         * lib/krb5/get_cred.c: Get addresses from krbtgt if there are none
953         in the reply.
955 Sun Jul 20 16:22:30 1997  Assar Westerlund  <assar@sics.se>
957         * kuser/kinit.c: break if des_read_pw_string() != 0
959         * kpasswd/kpasswdd.c: send a reply
961         * kpasswd/kpasswd.c: restructured code.  better report on
962         krb-error break if des_read_pw_string() != 0
964         * kdc/kerberos5.c: Check `require_enc_timestamp' malloc space for
965         starttime and renew_till
967         * appl/telnet/libtelnet/kerberos5.c (kerberos5_is): Send a
968         keyblock to krb5_verify_chekcsum
970 Sun Jul 20 06:35:46 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
972         * Release 0.0b
974         * kpasswd/kpasswd.c: Avoid using non-standard struct names.
976 Sat Jul 19 19:26:23 1997  Assar Westerlund  <assar@sics.se>
978         * lib/krb5/keytab.c (krb5_kt_get_entry): check return from
979         `krb5_kt_start_seq_get'.  From <map@stacken.kth.se>
981 Sat Jul 19 04:07:39 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
983         * lib/asn1/k5.asn1: Update with more pa-data types from
984         draft-ietf-cat-kerberos-revisions-00.txt
986         * admin/load.c: Update to match current db-format.
988         * kdc/kerberos5.c (as_rep): Try all valid pa-datas before giving
989         up. Send back an empty pa-data if the client has the v4 flag set.
991         * lib/krb5/get_in_tkt.c: Pass both version5 and version4 salted
992         pa-data. DTRT if there is any pa-data in the reply.
994         * lib/krb5/str2key.c: XOR with some sane value.
996         * lib/hdb/hdb.h: Add `version 4 salted key' flag.
998         * kuser/kinit.c: Ask for password before calling get_in_tkt. This
999         makes it possible to call key_proc more than once.
1001         * kdc/string2key.c: Add flags to output version 5 (DES only),
1002         version 4, and AFS string-to-key of a password.
1004         * lib/asn1/gen_copy.c: copy_* functions now returns an int (0 or
1005         ENOMEM).
1007 Fri Jul 18 02:54:58 1997  Assar Westerlund  <assar@sics.se>
1009         * lib/krb5/get_host_realm.c (krb5_get_host_realm): do the
1010         name2name thing
1012         * kdc/misc.c: check result of hdb_open
1014         * admin/kdb_edit: updated to new sl
1016         * lib/sl: sl_func now returns an int. != 0 means to exit.
1018         * kpasswd/kpasswdd: A crude (but somewhat working) implementation
1019         of `draft-ietf-cat-kerb-chg-password-00.txt'
1021 Fri Jul 18 00:55:39 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1023         * kuser/krenew.c: Crude ticket renewing program.
1025         * kdc/kerberos5.c: Rewritten flags parsing, it now might work to
1026         get forwarded and renewed tickets.
1028         * kuser/kinit.c: Add `-r' flag.
1030         * lib/krb5/get_cred.c: Move most of contents of get_creds to new
1031         function get_kdc_cred, that always contacts the kdc and doesn't
1032         save in the cache. This is a hack.
1034         * lib/krb5/get_in_tkt.c: Pass starttime and renew_till in request
1035         (a bit kludgy).
1037         * lib/krb5/mk_req_ext.c: Make an auth_context if none passed in.
1039         * lib/krb5/send_to_kdc.c: Get timeout from context.
1041         * lib/krb5/context.c: Add kdc_timeout to context struct.
1043 Thu Jul 17 20:35:45 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1045         * kuser/klist.c: Print start time of ticket if available.
1047         * lib/krb5/get_host_realm.c: Return error if no realm was found.
1049 Thu Jul 17 20:28:21 1997  Assar Westerlund  <assar@sics.se>
1051         * kpasswd: non-working kpasswd added
1053 Thu Jul 17 00:21:22 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1055         * Release 0.0a
1057         * kdc/main.c: Add -p flag to disable pa-enc-timestamp requirement.
1059 Wed Jul 16 03:37:41 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
1061         * kdc/kerberos5.c (tgs_rep2): Free ticket and ap_req.
1063         * lib/krb5/auth_context.c (krb5_auth_con_free): Free remote
1064         subkey.
1066         * lib/krb5/principal.c (krb5_free_principal): Check for NULL.
1068         * lib/krb5/send_to_kdc.c: Check for NULL return from
1069         gethostbyname.
1071         * lib/krb5/set_default_realm.c: Try to get realm of local host if
1072         no default realm is available.
1074         * Remove non ASN.1 principal code.
1076 Wed Jul 16 03:17:30 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1078         * kdc/kerberos5.c: Split tgs_rep in smaller functions. Add better
1079         error handing. Do some logging.
1081         * kdc/log.c: Some simple logging facilities.
1083         * kdc/misc.c (db_fetch): Take a krb5_principal.
1085         * kdc/connect.c: Pass address of request to as_rep and
1086         tgs_rep. Send KRB-ERROR.
1088         * lib/krb5/mk_error.c: Add more fields.
1090         * lib/krb5/get_cred.c: Print normal error code if no e_text is
1091         available.
1093 Wed Jul 16 03:07:50 1997  Assar Westerlund  <assar@sics.se>
1095         * lib/krb5/get_in_tkt.c: implement `krb5_init_etype'.
1096         Change encryption type of pa_enc_timestamp to DES-CBC-MD5
1098         * lib/krb5/context.c: recognize all encryption types actually
1099         implemented
1101         * lib/krb5/auth_context.c (krb5_auth_con_init): Change default
1102         encryption type to `DES_CBC_MD5'
1104         *  lib/krb5/read_message.c, write_message.c: new files
1106 Tue Jul 15 17:14:21 1997  Assar Westerlund  <assar@sics.se>
1108         * lib/asn1: replaced asn1_locl.h by `der_locl.h' and `gen_locl.h'.
1110         * lib/error/compile_et.awk: generate a prototype for the
1111         `destroy_foo_error_table' function.
1113 Mon Jul 14 12:24:40 1997  Assar Westerlund  <assar@sics.se>
1115         * lib/krb5/krbhst.c (krb5_get_krbhst): Get all kdc's and try also
1116         with `kerberos.REALM'
1118         * kdc/kerberos5.c, lib/krb5/rd_priv.c, lib/krb5/rd_safe.c: use
1119         `max_skew'
1121         * lib/krb5/rd_req.c (krb5_verify_ap_req): record authenticator
1122         subkey
1124         * lib/krb5/build_auth.c (krb5_build_authenticator): always
1125         generate a subkey.
1127         * lib/krb5/address.c: implement `krb5_address_order'
1129         * lib/gssapi/import_name.c: Implement `gss_import_name'
1131         * lib/gssapi/external.c: Use new OID
1133         * lib/gssapi/encapsulate.c: New functions
1134         `gssapi_krb5_encap_length' and `gssapi_krb5_make_header'.  Changed
1135         callers.
1137         * lib/gssapi/decapsulate.c: New function
1138         `gssaspi_krb5_verify_header'.  Changed callers.
1140         * lib/asn1/gen*.c: Give tags to generated structs.
1141         Use `err' and `asprintf'
1143         * appl/test/gss_common.c: new file
1145         * appl/test/gssapi_server.c: removed all krb5 calls
1147         * appl/telnet/libtelnet/kerberos5.c: Add support for genering and
1148         verifying checksums.  Also start using session subkeys.
1150 Mon Jul 14 12:08:25 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1152         * lib/krb5/rd_req.c (krb5_rd_req_with_keyblock): Split up.
1154 Sun Jul 13 03:07:44 1997  Assar Westerlund  <assar@sics.se>
1156         * lib/krb5/rd_safe.c, mk_safe.c: made bug-compatible with MIT
1158         * lib/krb5/encrypt.c: new functions `DES_encrypt_null_ivec' and
1159         `DES_encrypt_key_ivec'
1161         * lib/krb5/checksum.c: implement rsa-md4-des and rsa-md5-des
1163         * kdc/kerberos5.c (tgs_rep): support keyed checksums
1165         * lib/krb5/creds.c: new file
1167         * lib/krb5/get_in_tkt.c: better freeing
1169         * lib/krb5/context.c (krb5_free_context): more freeing
1171         * lib/krb5/config_file.c: New function `krb5_config_file_free'
1173         * lib/error/compile_et.awk: Generate a `destroy_' function.
1175         * kuser/kinit.c, klist.c: Don't leak memory.
1177 Sun Jul 13 02:46:27 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
1179         * kdc/connect.c: Check filedescriptor in select.
1181         * kdc/kerberos5.c: Remove most of the most common memory leaks.
1183         * lib/krb5/rd_req.c: Free allocated data.
1185         * lib/krb5/auth_context.c (krb5_auth_con_free): Free a lot of
1186         fields.
1188 Sun Jul 13 00:32:16 1997  Assar Westerlund  <assar@sics.se>
1190         * appl/telnet, appl/rsh: Conditionalize the krb4-support.
1192         * configure.in: Test for krb4
1194 Sat Jul 12 17:14:12 1997  Assar Westerlund  <assar@sics.se>
1196         * kdc/kerberos5.c: check if the pre-auth was decrypted properly.
1197         set the `pre_authent' flag
1199         * lib/krb5/get_cred.c, lib/krb5/get_in_tkt.c: generate a random nonce.
1201         * lib/krb5/encrypt.c: Made `generate_random_block' global.
1203         * appl/test: Added gssapi_client and gssapi_server.
1205         * lib/krb5/data.c: Add `krb5_data_zero'
1207         * appl/test/tcp_client.c: try `mk_safe' and `mk_priv'
1209         * appl/test/tcp_server.c: try `rd_safe' and `rd_priv'
1211 Sat Jul 12 16:45:58 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
1213         * lib/krb5/get_addrs.c: Fix for systems that has sa_len, but
1214         returns zero length from SIOCGIFCONF.
1216 Sat Jul 12 16:38:34 1997  Assar Westerlund  <assar@sics.se>
1218         * appl/test: new programs
1219         
1220         * lib/krb5/rd_req.c: add address compare
1222         * lib/krb5/mk_req_ext.c: allow no checksum
1224         * lib/krb5/keytab.c (krb5_kt_ret_string): 0-terminate string
1226         * lib/krb5/address.c: fix `krb5_address_compare'
1228 Sat Jul 12 15:03:16 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1230         * lib/krb5/get_addrs.c: Fix ip4 address extraction.
1232         * kuser/klist.c: Add verbose flag, and split main into smaller
1233         pieces.
1235         * lib/krb5/fcache.c: Save ticket flags.
1237         * lib/krb5/get_in_tkt.c (extract_ticket): Extract addresses and
1238         flags.
1240         * lib/krb5/krb5.h: Add ticket_flags to krb5_creds.
1242 Sat Jul 12 13:12:48 1997  Assar Westerlund  <assar@sics.se>
1244         * configure.in: Call `AC_KRB_PROG_LN_S'
1246         * acinclude.m4: Add `AC_KRB_PROG_LN_S' from krb4
1248 Sat Jul 12 00:57:01 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1250         * lib/krb5/get_in_tkt.c: Use union of krb5_flags and KDCOptions to
1251         pass options.
1253 Fri Jul 11 15:04:22 1997  Assar Westerlund  <assar@sics.se>
1255         * appl/telnet: telnet & telnetd seems to be working.
1256         
1257         * lib/krb5/config_file.c: Added krb5_config_v?get_list Fixed
1258         krb5_config_vget_next
1260         * appl/telnet/libtelnet/kerberos5.c: update to current API
1262 Thu Jul 10 14:54:39 1997  Assar Westerlund  <assar@sics.se>
1264         * appl/telnet/libtelnet/kerberos5.c (kerberos5_status): call
1265         `krb5_kuserok'
1267         * appl/telnet: Added.
1269 Thu Jul 10 05:09:25 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
1271         * lib/error/compile_et.awk: Remove usage of sub, gsub, and
1272         functions for compatibility with awk.
1274         * include/bits.c: Must use signed char.
1276         * lib/krb5/context.c: Move krb5_get_err_text, and krb5_init_ets
1277         here.
1279         * lib/error/error.c: Replace krb5_get_err_text with new function
1280         com_right.
1282         * lib/error/compile_et.awk: Avoid using static variables.
1284         * lib/error/error.c: Don't use krb5_locl.h
1286         * lib/error/error.h: Move definitions of error_table and
1287         error_list from krb5.h.
1289         * lib/error: Moved from lib/krb5.
1291 Wed Jul  9 07:42:04 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1293         * lib/krb5/encrypt.c: Temporary hack to avoid des_rand_data.
1295 Wed Jul  9 06:58:00 1997  Assar Westerlund  <assar@sics.se>
1297         * appl/rsh/rsh.c: use the correct user for the checksum
1299         * lib/krb5/{rd,mk}_{*}.c: more checking for addresses and stuff
1300         according to pseudocode from 1510
1302 Wed Jul  9 06:06:06 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1304         * lib/hdb/hdb.c: Add hdb_etype2key.
1306         * kdc/kerberos5.c: Check authenticator. Use more general etype
1307         functions.
1308         
1309 Wed Jul  9 03:51:12 1997  Assar Westerlund  <assar@sics.se>
1311         * lib/asn1/k5.asn1: Made all `s_address' OPTIONAL according to
1312         draft-ietf-cat-kerberos-r-00.txt
1314         * lib/krb5/principal.c (krb5_parse_name): default to local realm
1315         if none given
1316         
1317         * kuser/kinit.c: New option `-p' and prompt
1319 Wed Jul  9 02:30:06 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1321         * lib/krb5/keyblock.c: Keyblock generation functions.
1323         * lib/krb5/encrypt.c: Use functions from checksum.c.
1325         * lib/krb5/checksum.c: Move checksum functions here. Add
1326         krb5_cksumsize function.
1328 Wed Jul  9 01:15:38 1997  Assar Westerlund  <assar@sics.se>
1330         * lib/krb5/get_host_realm.c: implemented
1332         * lib/krb5/config_file.c: Redid part.  New functions:
1333         krb5_config_v?get_next
1335         * kuser/kdestroy.c: new program
1337         * kuser/kinit.c: new flag `-f'
1339         * lib/asn1/k5.asn1: Made HostAddresses = SEQUENCE OF HostAddress
1341         * acinclude.m4: Added AC_KRB_STRUCT_SOCKADDR_SA_LEN
1343         * lib/krb5/krb5.h: krb5_addresses == HostAddresses.  Changed all
1344         users.
1346         * lib/krb5/get_addrs.c: figure out all local addresses, possibly
1347         even IPv6!
1349         * lib/krb5/checksum.c: table-driven checksum
1351 Mon Jul  7 21:13:28 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1353         * lib/krb5/encrypt.c: Make krb5_decrypt use the same struct as
1354         krb5_encrypt.
1356 Mon Jul  7 11:15:51 1997  Assar Westerlund  <assar@sics.se>
1358         * lib/roken/vsyslog.c: new file
1360         * lib/krb5/encrypt.c: add des-cbc-md4.
1361         adjust krb5_encrypt and krb5_decrypt to reality
1363         * appl/rsh/rshd.c: Now works.  Also implementd encryption and
1364         `-p'.
1365         
1366         * appl/rsh/common.c: new file
1368 Mon Jul  7 02:46:31 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1370         * lib/krb5/encrypt.c: Implement as a vector of function pointers.
1372         * lib/krb5/{decrypt,encrypt}.c: Implement des-cbc-crc, and
1373         des-cbc-md5 in separate functions.
1375         * lib/krb5/krb5.h: Add more checksum and encryption types.
1377         * lib/krb5/krb5_locl.h: Add etype to krb5_decrypt.
1379 Sun Jul  6 23:02:59 1997  Assar Westerlund  <assar@sics.se>
1381         * lib/krb5/[gs]et_default_realm.c, kuserok.c: new files
1383         * lib/krb5/config_file.[ch]: new c-based configuration reading
1384         stuff
1386 Wed Jul  2 23:12:56 1997  Assar Westerlund  <assar@sics.se>
1388         * configure.in: Set WFLAGS if using gcc
1390 Wed Jul  2 17:47:03 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1392         * lib/asn1/der_put.c (der_put_int): Return size correctly.
1394         * admin/ank.c: Be compatible with the asn1 principal format.
1396 Wed Jul  1 23:52:20 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1398         * lib/asn1: Now all decode_* and encode_* functions now take a
1399         final size_t* argument, that they return the size in. Return
1400         values are zero for success, and anything else (such as some
1401         ASN1_* constant) for error.
1403 Mon Jun 30 06:08:14 1997  Assar Westerlund  <assar@sics.se>
1405         * appl/rsh: New program.
1407         * lib/krb5/keytab.c (krb5_kt_add_entry): change open mode to
1408         O_WRONLY | O_APPEND
1410         * lib/krb5/get_cred.c: removed stale prototype for
1411         `extract_ticket' and corrected call.
1413         * lib/asn1/gen_length.c (length_type): Make the length functions
1414         for SequenceOf non-destructive
1416         * admin/ank.c (doit): Fix reading of `y/n'.
1418 Mon Jun 16 05:41:43 1997  Assar Westerlund  <assar@sics.se>
1420         * lib/gssapi/wrap.c, unwrap.c: do encrypt and add sequence number
1422         * lib/gssapi/get_mic.c, verify_mic.c: Add sequence number.
1424         * lib/gssapi/accept_sec_context.c (gss_accept_sec_context): Set
1425         KRB5_AUTH_CONTEXT_DO_SEQUENCE.  Verify 8003 checksum.
1427         * lib/gssapi/8003.c: New file.
1429         * lib/krb/krb5.h: Define a `krb_authenticator' as an ASN.1
1430         Authenticator.
1432         * lib/krb5/auth_context.c: New functions
1433         `krb5_auth_setlocalseqnumber' and `krb5_auth_setremoteseqnumber'
1435 Tue Jun 10 00:35:54 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1437         * lib/krb5: Preapre for use of some asn1-types.
1439         * lib/asn1/*.c (copy_*): Constness.
1441         * lib/krb5/krb5.h: Include asn1.h; krb5_data is now an
1442         octet_string.
1444         * lib/asn1/der*,gen.c: krb5_data -> octet_string, char * ->
1445         general_string
1447         * lib/asn1/libasn1.h: Moved stuff from asn1_locl.h that doesn't
1448         have anything to do with asn1_compile.
1450         * lib/asn1/asn1_locl.h: Remove der.h. Add some prototypes.
1452 Sun Jun  8 03:51:55 1997  Assar Westerlund  <assar@sics.se>
1454         * kdc/kerberos5.c: Fix PA-ENC-TS-ENC
1456         * kdc/connect.c(process_request): Set `new'
1457         
1458         * lib/krb5/get_in_tkt.c: Do PA-ENC-TS-ENC the correct way.
1460         * lib: Added editline,sl,roken.
1462 Mon Jun  2 00:37:48 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1464         * lib/krb5/fcache.c: Move file cache from cache.c.
1466         * lib/krb5/cache.c: Allow more than one cache type.
1468 Sun Jun  1 23:45:33 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1470         * admin/extkeytab.c: Merged with kdb_edit.
1472 Sun Jun  1 23:23:08 1997  Assar Westerlund  <assar@sics.se>
1474         * kdc/kdc.c: more support for ENC-TS-ENC
1476         * lib/krb5/get_in_tkt.c: redone to enable pre-authentication
1478 Sun Jun  1 22:45:11 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1480         * lib/hdb/db.c: Merge fetch and store.
1482         * admin: Merge to one program.
1484         * lib/krb5/str2key.c: Fill in keytype and length.
1486 Sun Jun  1 16:31:23 1997  Assar Westerlund  <assar@sics.se>
1488         * lib/krb5/rd_safe.c, lib/krb5/rd_priv.c, lib/krb5/mk_rep.c,
1489         lib/krb5/mk_priv.c, lib/krb5/build_auth.c: Some support for
1490         KRB5_AUTH_CONTEXT_DO_SEQUENCE
1492         * lib/krb5/get_in_tkt.c (get_in_tkt): be prepared to parse an
1493         KRB_ERROR.  Some support for PA_ENC_TS_ENC.
1495         * lib/krb5/auth_context.c: implemented seq_number functions
1497         * lib/krb5/generate_subkey.c, generate_seq_number.c: new files
1499         * lib/gssapi/gssapi.h: avoid including <krb5.h>
1501         * lib/asn1/Makefile.am: SUFFIXES as a variable to make automake
1502         happy
1504         * kdc/kdc.c: preliminary PREAUTH_ENC_TIMESTAMP
1506         * configure.in: adapted to automake 1.1p
1508 Mon May 26 22:26:21 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1510         * lib/krb5/principal.c: Add contexts to many functions.
1512 Thu May 15 20:25:37 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
1514         * lib/krb5/verify_user.c: First stab at a verify user.
1516         * lib/auth/sia/sia5.c: SIA module for Kerberos 5.
1518 Mon Apr 14 00:09:03 1997  Assar Westerlund  <assar@sics.se>
1520         * lib/gssapi: Enough of a gssapi-over-krb5 implementation to be
1521         able to (mostly) run gss-client and gss-server.
1522         
1523         * lib/krb5/keytab.c: implemented krb5_kt_add_entry,
1524         krb5_kt_store_principal, krb5_kt_store_keyblock
1526         * lib/des/md5.[ch], sha.[ch]: new files
1528         * lib/asn1/der_get.c (generalizedtime2time): use `timegm'
1530         * lib/asn1/timegm.c: new file
1532         * admin/extkeytab.c: new program
1534         * admin/admin_locl.h: new file
1536         * admin/Makefile.am: Added extkeytab
1538         * configure.in: moved config to include
1539         removed timezone garbage
1540         added lib/gssapi and admin
1542         * Makefile.am: Added admin
1544 Mon Mar 17 11:34:05 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1546         * kdc/kdc.c: Use new copying functions, and free some data.
1548         * lib/asn1/Makefile.am: Try to not always rebuild generated files.
1550         * lib/asn1/der_put.c: Add fix_dce().
1552         * lib/asn1/der_{get,length,put}.c: Fix include files.
1554         * lib/asn1/der_free.c: Remove unused functions.
1555         
1556         * lib/asn1/gen.c: Split into gen_encode, gen_decode, gen_free,
1557         gen_length, and gen_copy.
1559 Sun Mar 16 18:13:52 1997  Assar Westerlund  <assar@sics.se>
1561         * lib/krb5/sendauth.c: implemented functionality
1563         * lib/krb5/rd_rep.c: Use `krb5_decrypt'
1565         * lib/krb5/cache.c (krb5_cc_get_name): return default if `id' ==
1566         NULL
1568         * lib/krb5/principal.c (krb5_free_principal): added `context'
1569         argument.  Changed all callers.
1570         
1571         (krb5_sname_to_principal): new function
1573         * lib/krb5/auth_context.c (krb5_free_authenticator): add `context'
1574         argument.  Changed all callers
1576         * lib/krb5/{net_write.c,net_read.c,recvauth.c}: new files
1578         * lib/asn1/gen.c: Fix encoding and decoding of BitStrings
1580 Fri Mar 14 11:29:00 1997  Assar Westerlund  <assar@sics.se>
1582         * configure.in: look for *dbm?
1584         * lib/asn1/gen.c: Fix filename in generated files. Check fopens.
1585         Put trailing newline in asn1_files.
1587 Fri Mar 14 05:06:44 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
1589         * lib/krb5/get_in_tkt.c: Fix some memory leaks.
1591         * lib/krb5/krbhst.c: Properly free hostlist.
1593         * lib/krb5/decrypt.c: CRCs are 32 bits.
1595 Fri Mar 14 04:39:15 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1597         * lib/asn1/gen.c: Generate one file for each type.
1599 Fri Mar 14 04:13:47 1997  Assar Westerlund  <assar@sics.se>
1601         * lib/asn1/gen.c: Generate `length_FOO' functions
1603         * lib/asn1/der_length.c: new file
1605         * kuser/klist.c: renamed stime -> printable_time to avoid conflict
1606         on HP/UX
1608 Fri Mar 14 03:37:23 1997  Johan Danielsson  <joda@emma.pdc.kth.se>
1610         * lib/hdb/ndbm.c: Return NOENTRY if fetch fails. Don't free
1611         datums. Don't add .db to filename.
1613 Fri Mar 14 02:49:51 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1615         * kdc/dump.c: Database dump program.
1617         * kdc/ank.c: Trivial database editing program.
1619         * kdc/{kdc.c, load.c}: Use libhdb.
1621         * lib/hdb: New database routine library.
1623         * lib/krb5/error/Makefile.am: Add hdb_err.
1625 Wed Mar 12 17:41:14 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1627         * kdc/kdc.c: Rewritten AS, and somewhat more working TGS support.
1629         * lib/asn1/gen.c: Generate free functions.
1631         * Some specific free functions.
1633 Wed Mar 12 12:30:13 1997  Assar Westerlund  <assar@sics.se>
1635         * lib/krb5/krb5_mk_req_ext.c: new file
1637         * lib/asn1/gen.c: optimize the case with a simple type
1639         * lib/krb5/get_cred.c (krb5_get_credentials): Use
1640         `mk_req_extended' and remove old code.
1642         * lib/krb5/get_in_tkt.c (decrypt_tkt): First try with an
1643         EncASRepPart, then with an EncTGSRepPart.
1645 Wed Mar 12 08:26:04 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1647         * lib/krb5/store_emem.c: New resizable memory storage.
1649         * lib/krb5/{store.c, store_fd.c, store_mem.c}: Split of store.c
1651         * lib/krb5/krb5.h: Add free entry to krb5_storage.
1653         * lib/krb5/decrypt.c: Make keyblock const.
1655 Tue Mar 11 20:22:17 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1657         * lib/krb5/krb5.h: Add EncTicketPart to krb5_ticket.
1659         * lib/krb5/rd_req.c: Return whole asn.1 ticket in
1660         krb5_ticket->tkt.
1662         * lib/krb5/get_in_tkt.c: TGS -> AS
1664         * kuser/kfoo.c: Print error string rather than number.
1666         * kdc/kdc.c: Some kind of non-working TGS support.
1668 Mon Mar 10 01:43:22 1997  Assar Westerlund  <assar@sics.se>
1670         * lib/asn1/gen.c: reduced generated code by 1/5
1672         * lib/asn1/der_put.c: (der_put_length_and_tag): new function
1674         * lib/asn1/der_get.c (der_match_tag_and_length): new function
1676         * lib/asn1/der.h: added prototypes
1678 Mon Mar 10 01:15:43 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1680         * lib/krb5/krb5.h: Include <asn1_err.h>. Add prototype for
1681         krb5_rd_req_with_keyblock.
1683         * lib/krb5/rd_req.c: Add function krb5_rd_req_with_keyblock that
1684         takes a precomputed keyblock.
1686         * lib/krb5/get_cred.c: Use krb5_mk_req rather than inlined code.
1688         * lib/krb5/mk_req.c: Calculate checksum of in_data.
1690 Sun Mar  9 21:17:58 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1692         * lib/krb5/error/compile_et.awk: Add a declaration of struct
1693         error_list, and multiple inclusion block to header files.
1695 Sun Mar  9 21:01:12 1997  Assar Westerlund  <assar@sics.se>
1697         * lib/krb5/rd_req.c: do some checks on times
1699         * lib/krb/{mk_priv.c, rd_priv.c, sendauth.c, decrypt.c,
1700         address.c}: new files
1702         * lib/krb5/auth_context.c: more code
1704         * configure.in: try to figure out timezone
1706 Sat Mar  8 11:41:07 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1708         * lib/krb5/error/error.c: Try strerror if error code wasn't found.
1710         * lib/krb5/get_in_tkt.c: Remove realm parameter from
1711         krb5_get_salt.
1713         * lib/krb5/context.c: Initialize error table.
1715         * kdc: The beginnings of a kdc.
1717 Sat Mar  8 08:16:28 1997  Assar Westerlund  <assar@sics.se>
1719         * lib/krb5/rd_safe.c: new file
1721         * lib/krb5/checksum.c (krb5_verify_checksum): New function
1723         * lib/krb5/get_cred.c: use krb5_create_checksum
1725         * lib/krb5/checksum.c: new file
1727         * lib/krb5/store.c: no more arithmetic with void*
1729         * lib/krb5/cache.c: now seems to work again
1731 Sat Mar  8 06:58:09 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1733         * lib/krb5/Makefile.am: Add asn1_glue.c and error/*.c to libkrb5.
1735         * lib/krb5/get_in_tkt.c: Moved some functions to asn1_glue.c.
1737         * lib/krb5/asn1_glue.c: Moved some asn1-stuff here.
1738         
1739         * lib/krb5/{cache,keytab}.c: Use new storage functions.
1741         * lib/krb5/krb5.h: Protypes for new storage functions.
1743         * lib/krb5/krb5.h: Make krb5_{ret,store}_* functions able to write
1744         data to more than file descriptors.
1746 Sat Mar  8 01:01:17 1997  Assar Westerlund  <assar@sics.se>
1748         * lib/krb5/encrypt.c: New file.
1750         * lib/krb5/Makefile.am: More -I
1752         * configure.in: Test for big endian, random, rand, setitimer
1754         * lib/asn1/gen.c: perhaps even decodes bitstrings
1756 Thu Mar  6 19:05:29 1997  Johan Danielsson  <joda@blubb.pdc.kth.se>
1758         * lib/krb5/config_file.y: Better return values on error.
1760 Sat Feb  8 15:59:56 1997  Assar Westerlund  <assar@pdc.kth.se>
1762         * lib/asn1/parse.y: ifdef HAVE_STRDUP
1764         * lib/asn1/lex.l: ifdef strdup
1765         brange-dead version of list of special characters to make stupid
1766         lex accept it.
1768         * lib/asn1/gen.c: A DER integer should really be a `unsigned'
1770         * lib/asn1/der_put.c: A DER integer should really be a `unsigned'
1772         * lib/asn1/der_get.c: A DER integer should really be a `unsigned'
1774         * lib/krb5/error/Makefile.am: It seems "$(SHELL) ./compile_et" is
1775         needed.
1777         * lib/krb/mk_rep.c, lib/krb/rd_req.c, lib/krb/store.c,
1778         lib/krb/store.h: new files.
1780         * lib/krb5/keytab.c: now even with some functionality.
1782         * lib/asn1/gen.c: changed paramater from void * to Foo *
1784         * lib/asn1/der_get.c (der_get_octet_string): Fixed bug with empty
1785         string.
1787 Sun Jan 19 06:17:39 1997  Assar Westerlund  <assar@pdc.kth.se>
1789         * lib/krb5/get_cred.c (krb5_get_credentials): Check for creds in
1790         cc before getting new ones.
1792         * lib/krb5/krb5.h (krb5_free_keyblock): Fix prototype.
1794         * lib/krb5/build_auth.c (krb5_build_authenticator): It seems the
1795         CRC should be stored LSW first. (?)
1797         * lib/krb5/auth_context.c: Implement `krb5_auth_con_getkey' and
1798         `krb5_free_keyblock'
1800         * lib/**/Makefile.am: Rename foo libfoo.a
1802         * include/Makefile.in: Use test instead of [
1803         -e does not work with /bin/sh on psoriasis
1805         * configure.in: Search for awk
1806         create lib/krb/error/compile_et
1807         
1808 Tue Jan 14 03:46:26 1997  Assar Westerlund  <assar@pdc.kth.se>
1810         * lib/krb5/Makefile.am: replaced mit-crc.c by crc.c
1812 Wed Dec 18 00:53:55 1996  Johan Danielsson  <joda@emma.pdc.kth.se>
1814         * kuser/kinit.c: Guess principal.
1816         * lib/krb5/error/compile_et.awk: Don't include krb5.h. Fix some
1817         warnings.
1819         * lib/krb5/error/asn1_err.et: Add ASN.1 error messages.
1821         * lib/krb5/mk_req.c: Get client from cache.
1823         * lib/krb5/cache.c: Add better error checking some useful return
1824         values.
1826         * lib/krb5/krb5.h: Fix krb5_auth_context.
1828         * lib/asn1/der.h: Make krb5_data compatible with krb5.h
1830 Tue Dec 17 01:32:36 1996  Johan Danielsson  <joda@emma.pdc.kth.se>
1832         * lib/krb5/error: Add primitive error library.
1834 Mon Dec 16 16:30:20 1996  Johan Danielsson  <joda@emma.pdc.kth.se>
1836         * lib/krb5/cache.c: Get correct address type from cache.
1838         * lib/krb5/krb5.h: Change int16 to int to be compatible with asn1.