* Makefile.in: Revert $(S)=>/ change, for Windows support
[krb5.git] / src / lib / krb5 / krb / ChangeLog
1 2002-08-29  Ken Raeburn  <raeburn@mit.edu>
2
3         * Makefile.in: Revert $(S)=>/ change, for Windows support.
4
5 2002-08-23  Ken Raeburn  <raeburn@mit.edu>
6
7         * Makefile.in: Change $(S)=>/ and $(U)=>.. globally.
8
9 2002-08-22  Ken Raeburn  <raeburn@mit.edu>
10
11         * init_ctx.c (init_common): Initialize udp_pref_limit field.
12
13 2002-08-15  Tom Yu  <tlyu@mit.edu>
14
15         * t_ser.c (ser_ccache_test): Remove references to STDIO ccaches.
16
17 2002-08-01  Tom Yu  <tlyu@mit.edu>
18
19         * unparse.c (krb5_unparse_name_ext): Error out if passed a NULL
20         pointer.  Patch from Mark Levinson; fixes [krb5-admin/1140].
21
22 2002-06-26  Ezra Peisach  <epeisach@bu.edu>
23
24         * appdefault.c (conf_boolean): Change variable from char ** to
25         const char ** to prevent warning of const to non-const.
26         
27         * get_in_tkt.c (_krb5_conf_boolean): Same
28
29 2002-06-25  Alexandra Ellwood <lxs@mit.edu>
30
31         * appdefault.c, get_in_tkt.c: made conf_yes and conf_no const to 
32         improve load time on Mach-O
33
34         * init_ctx: fixed Mac OS macros
35
36         [pullups from 1-2-2-branch]
37
38 2001-06-25  Miro Jurisic  <meeroh@mit.edu>
39
40         * rd_safe.c, rd_priv.c, rd_cred.c, preauth.c, mk_safe.c,
41         mk_cred.c, appdefault.c: use "" includes for krb5.h, k5-int.h and
42         syslog.h
43         [pullup from 1-2-2-branch]
44
45 2002-06-18  Ken Raeburn  <raeburn@mit.edu>
46
47         * sendauth.c (ECONNABORTED): Don't define here now that it's
48         defined in port-sockets.h.
49
50 2002-06-18  Danilo Almeida  <dalmeida@mit.edu>
51
52         * princ_comp.c (krb5_realm_compare), auth_con.c
53         (krb5_auth_con_setports, krb5_auth_con_getaddrs,
54         krb5_auth_con_initivector), addr_order.c (krb5_address_order),
55         addr_comp.c (krb5_address_compare): Make KRB5_CALLCONV.
56         [pullup from 1-2-2-branch]
57
58 2002-06-18  Danilo Almeida  <dalmeida@mit.edu>
59
60         * bld_princ.c (krb5_build_principal_va): Make
61         krb5_build_principal_va() KRB5_CALLCONV.
62         [pullup from 1-2-2-branch]
63
64 2002-06-12  Ken Raeburn  <raeburn@mit.edu>
65
66         * preauth.c: Don't include syslog.h.
67
68 2002-06-10  Ken Raeburn  <raeburn@mit.edu>
69
70         * get_in_tkt.c (send_as_request): Update arg list for
71         sendto_kdc.  If a RESPONSE_TOO_BIG error is returned from the KDC,
72         use a TCP connection.
73         * send_tgs.c (krb5_send_tgs): Update arg list for sendto_kdc.  If
74         a RESPONSE_TOO_BIG error is returned from the KDC, use a TCP
75         connection.
76
77 2002-04-12  Ezra Peisach  <epeisach@bu.edu>
78
79         * Makefile.in (clean): Remove t_expand and t_expand.o
80
81 2002-04-12  Ken Raeburn  <raeburn@mit.edu>
82
83         * conv_princ.c (struct krb_convert): Add new field 'len'.
84         (RC, R, NR): New macros.
85         (sconv_list): Use them.
86         (krb5_524_conv_principal): Compare lengths and then use memcmp.
87
88         * recvauth.c (sendauth_version): Now a const array.
89         * sendauth.c (sendauth_version): Now a const array.
90         (krb5_sendauth): Cast address when assigning to outbuf data
91         field.
92
93 2002-04-05  Ken Raeburn  <raeburn@mit.edu>
94
95         * decrypt_tk.c (krb5_decrypt_tkt_part): Call krb5_c_valid_enctype
96         instead of valid_enctype.
97         * encode_kdc.c (krb5_encode_kdc_rep): Likewise.
98         * gc_frm_kdc.c (krb5_get_cred_from_kdc_opt): Likewise.
99         * gic_keytab.c (krb5_get_as_key_keytab): Likewise.
100         * in_tkt_ktb.c (keytab_keyproc): Likewise.
101         * in_tkt_sky.c (skey_keyproc): Likewise.
102         * init_ctx.c (krb5_set_default_in_tkt_ktypes,
103         krb5_set_default_tgs_enctypes): Likewise.
104         * send_tgs.c (krb5_send_tgs): Likewise.
105
106         * mk_safe.c (krb5_mk_safe_basic): Call krb5_c_valid_cksumtype,
107         krb5_c_is_coll_proof_cksum, krb5_c_is_keyed_cksum instead of
108         non-prefixed forms.
109         * rd_safe.c (krb5_rd_safe_basic): Likewise.
110
111 2002-03-28  Sam Hartman  <hartmans@mit.edu>
112
113         * Makefile.in :  New file init_keyblock.c
114
115         * init_keyblock.c (krb5_init_keyblock): New function
116
117 2002-03-16  Sam Hartman  <hartmans@mit.edu>
118
119         * fwd_tgt.c (krb5_fwd_tgt_creds): Fix merge of patch from 1.2.2
120         back to mainline. 
121
122 2002-03-14  Sam Hartman  <hartmans@mit.edu>
123
124         * walk_rtree.c (krb5_walk_realm_tree):  Fix handling of null client or server realm
125
126 2002-03-06  Ken Raeburn  <raeburn@mit.edu>
127
128         * ser_actx.c (krb5_auth_context_externalize): Do bounds checking
129         on converted size value.
130
131         * fwd_tgt.c (krb5_fwd_tgt_creds): If no session key has been set,
132         try getting credentials and use the session key type as a hint
133         for the enctype to use for the forwarded credentials.
134
135 2002-02-27  Sam Hartman  <hartmans@mit.edu>
136
137         * rd_cred.c (krb5_rd_cred_basic): Don't check IP addresses; if
138         someone knows the key and wants to give us credentials, that's OK.
139         No reflection attack is possible in most protocols since  krb_cred
140         is almost always client->server.  Address checking created
141         significant problems for NATs.    We also ran into problems
142         getting our code to work with Heimdal  and removing checking was
143         easier than a staged upgrade to fix the problems.
144         (krb5_rd_cred): Don't pass in addresses
145
146 2002-02-22  Ken Raeburn  <raeburn@mit.edu>
147
148         * addr_comp.c, addr_order.c, addr_srch.c, bld_pr_ext.c,
149         bld_princ.c, enc_helper.c, encrypt_tk.c, gen_seqnum.c,
150         gen_subkey.c, preauth.c: Use const instead of krb5_const.
151         * bld_pr_ext.c, bld_princ.c: Always use stdarg macros and not
152         varargs.
153
154 2002-01-08  Sam Hartman  <hartmans@mit.edu>
155
156         * gen_subkey.c (krb5_generate_subkey): Label entropy sources
157
158         * init_ctx.c (init_common): Use /dev/urandom if present for random data
159
160 2001-12-05  Ezra Peisach  <epeisach@mit.edu>
161
162         * t_ser.c (main): Free context on failure exit route.
163
164  2001-11-24  Sam Hartman  <hartmans@mit.edu>
165  
166         * fwd_tgt.c (krb5_fwd_tgt_creds): Get a session key for the
167         forwarded tgt that is the same as the  session key for  the
168         auth_context.  This  is an enctype we know the remote side
169         supports.  
170  
171 2001-11-26  Sam Hartman  <hartmans@mit.edu>
172
173         * gen_seqnum.c (krb5_generate_seq_number):  add entropy source id
174
175         * sendauth.c (krb5_sendauth): Add entropy source ID
176
177         * mk_req_ext.c (krb5_mk_req_extended):  Add entropy source ID to random seed call
178
179         * init_ctx.c (init_common): Specify entropy source for random seed
180
181 2001-11-16  Sam Hartman  <hartmans@mit.edu>
182
183         * init_ctx.c (krb5_set_default_tgs_enctypes):  rename from
184         set_default_ktypes; old function provided as APIA 
185
186 2001-11-16  Ezra Peisach  <epeisach@mit.edu>
187
188         * init_ctx.c (DEFAULT_ETYPE_LIST): Ensure space present after
189         arcfour-hmac-md5 entry for when ANSI strings concatenated the
190         des-cbc-crc entry was dropped.
191
192 2001-11-07  Sam Hartman  <hartmans@mit.edu>
193
194         * init_ctx.c (DEFAULT_ETYPE_LIST): Add arcfour-hmac-md5; it really
195         is probably at least as good as DES 
196
197 2001-10-10  Danilo Almeida  <dalmeida@mit.edu>
198
199         * gic_pwd.c (krb5_get_as_key_password),
200         gic_keytab.c (krb5_get_as_key_keytab): Use ANSI-style
201         declaration in definition.
202
203 2001-10-09  Ken Raeburn  <raeburn@mit.edu>
204
205         * init_ctx.c (init_common): After fetching kdc_default_options
206         value from krb5.conf, actually use that value.  Pointed out by
207         Emily Ratliff, <ratliff@austin.ibm.com>.
208
209         * get_in_tkt.c, in_tkt_ktb.c, in_tkt_pwd.c, in_tkt_sky.c,
210         int-proto.h, mk_req_ext.c, pr_to_salt.c, rd_req_dec.c, ser_actx.c,
211         ser_adata.c, ser_addr.c, ser_auth.c, ser_cksum.c, ser_ctx.c,
212         ser_eblk.c, ser_key.c, ser_princ.c, t_kerb.c: Make prototypes
213         unconditional.
214
215 2001-10-05  Ken Raeburn  <raeburn@mit.edu>
216
217         * init_ctx.c, preauth.c: Drop _MSDOS support.
218
219 2001-10-03  Ken Raeburn  <raeburn@mit.edu>
220
221         * appdefault.c, auth_con.c, bld_pr_ext.c, bld_princ.c, chpw.c,
222         conv_princ.c, copy_addrs.c, copy_athctr.c, copy_auth.c,
223         copy_cksum.c, copy_creds.c, copy_data.c, copy_key.c, copy_princ.c,
224         copy_tick.c, cp_key_cnt.c, decrypt_tk.c, fwd_tgt.c, get_creds.c,
225         get_in_tkt.c, gic_keytab.c, gic_opt.c, gic_pwd.c, in_tkt_ktb.c,
226         in_tkt_pwd.c, in_tkt_sky.c, init_ctx.c, kfree.c, mk_cred.c,
227         mk_error.c, mk_priv.c, mk_rep.c, mk_req.c, mk_req_ext.c,
228         mk_safe.c, parse.c, princ_comp.c, rd_cred.c, rd_error.c,
229         rd_priv.c, rd_rep.c, rd_req.c, rd_safe.c, recvauth.c, sendauth.c,
230         ser_actx.c, ser_ctx.c, serialize.c, set_realm.c, srv_rcache.c,
231         str_conv.c, unparse.c, vfy_increds.c, vic_opt.c, x-deltat.y: Don't
232         use KRB5_DLLIMP.  Don't explicitly declare pointers FAR any more.
233
234 2001-09-07  Ken Raeburn  <raeburn@mit.edu>
235
236         * t_expand.c: New file.
237         * Makefile.in (SRCS): Add test-case source files; rebuilt
238         dependencies.
239         (t_expand.o): Build from t_expand.c now, no special build rule.
240
241 2001-09-07  Ken Raeburn  <raeburn@mit.edu>
242
243         * rd_req_dec.c (krb5_rd_req_decoded_opt): Pass server realm to
244         transited-list check, not local realm, in case they're different.
245
246 2001-08-21  Ken Raeburn  <raeburn@mit.edu>
247
248         * walk_rtree.c (krb5_walk_realm_tree): Initialize slen to silence
249         compiler warning.
250
251 2001-08-08    <epeisach@mit.edu>
252
253         * walk_rtree.c (krb5_walk_realm_tree): Do not try to free const char *.
254
255         * mk_safe.c (krb5_mk_safe_basic): Do not declare local_addr and
256         remote_addr const and then cast the attribute away.
257
258         * mk_req_ext.c (krb5_generate_authenticator): Static function -
259         remove const attribute from cksum pointer.
260
261         * gc_via_tkt.c (krb5_get_cred_via_tkt): Cast unsigned integer
262         krb5_error error_value to signed before adding
263         ERROR_TABLE_BASE_krb5.
264
265 2001-07-31  Ken Raeburn  <raeburn@mit.edu>
266
267         * chk_trans.c (krb5_check_transited_list): Pointer args now point
268         to const.
269
270 2001-07-31  Ezra Peisach  <epeisach@mit.edu>
271
272         * get_in_tkt.c: Cast to unsigned krb5_error error value to 
273         krb5_error_code before trying to add to ERROR_TABLE_BASE_krb5. 
274
275 2001-07-30  Ezra Peisach  <epeisach@mit.edu>
276
277         * sendauth.c (krb5_sendauth): Instead of casting second argument
278         to getpeername() and getsockname() to "struct sockaddr *", cast to
279         system specific type as determined by autoconf. 
280
281 2001-07-24  Ezra Peisach  <epeisach@mit.edu>
282
283         * in_tkt_sky.c (krb5_get_in_tkt_with_skey): Change cast from
284         krb5_pointer to krb5_const_pointer to ensure const integrity of
285         parameter.
286
287         * in_tkt_ktb.c (keytab_keyproc): Add const argument to cast of
288         keyseed to struct keytab_keyproc_arg to maintain const status.
289
290         * conv_princ.c (krb5_524_conv_principal): Cast argument to memcpy
291         to size_t.
292
293 2001-07-06  Ezra Peisach  <epeisach@mit.edu>
294
295         * conv_princ.c (krb5_425_conv_principal): Cast argument to tolower
296         to int.
297
298         * get_in_tkt.c: Include os-proto.h for _krb5_conf_boolean prototype.
299
300         * Makefile.in (LOCALINCLUDES): Add -I$(srcdir)/../os so os-proto.h
301         can be included.
302
303 2001-06-29  Tom Yu  <tlyu@mit.edu>
304
305         * init_ctx.c (get_profile_etype_list): Fix etype-counting loop so
306         that trailing separator characters (as in the DEFAULT_ETYPE_LIST)
307         don't cause another iteration, which was causing the following
308         loop to fall off the end of the string due to count being one too
309         great.
310
311 2001-06-28  Ezra Peisach  <epeisach@mit.edu>
312
313         * chk_trans.c (foreach_realm): Cleanup loal variable set but never
314         used.
315
316 2001-06-21  Ezra Peisach  <epeisach@mit.edu>
317
318         * chk_trans.c: Cast length arguments of %.*s in formats to int.
319
320 2001-06-20  Ezra Peisach  <epeisach@mit.edu>
321
322         * Makefile.in (check-unix): Add $(RUN_SETUP) before invocation of
323         transit-tests for shared library environment variables.
324
325 2001-06-19  Ken Raeburn  <raeburn@mit.edu>
326
327         * chk_trans.c: Reimplemented from scratch.
328         * transit-tests: New file.
329         * Makefile.in (t_expand, t_expand.o): New targets.  Build test
330         program from chk_trans.c.
331         (T_EXPAND_OBJS): New variable.
332         (TEST_PROGS): Add t_expand.
333         (check-unix): Run transit-tests.
334         * t_krb5.conf: Added capaths section.
335
336 2001-06-16  Ken Raeburn  <raeburn@mit.edu>
337
338         * fwd_tgt.c (krb5_fwd_tgt_creds): Copy enctype for new creds from
339         tgt.
340
341 2001-06-12  Ezra Peisach  <epeisach@mit.edu>
342
343         * Makefile.in (t_walk_rtree, t_kerb): Do not link against kdb libraries
344         for these test executables. 
345
346         * srv_rcache.c (krb5_get_server_rcache): Cast argument to
347         isgraph() to int.
348
349         * init_ctx.c: Cast arguments to isspace() to int. If unix is defined, 
350         include ../krb5_libinit.h. There has to be a better was for windows.
351
352         * conv_princ.c (krb5_425_conv_principal): Cast argument to isupper().
353         to int.
354
355 2001-06-11  Ezra Peisach  <epeisach@mit.edu>
356
357         * str_conv.c: If strptime() is present on system without a
358         prototype, provide one.
359
360 2001-06-07  Ezra Peisach  <epeisach@mit.edu>
361
362         * vfy_increds.c (krb5_verify_init_creds): Get rid of a variable
363         that was set in a conditional and never used afterwards.
364
365 2001-06-01  Ken Raeburn  <raeburn@mit.edu>
366
367         * init_ctx.c (get_profile_etype_list): Zero out multiple separator
368         characters between tokens, so the second can be recognized
369         properly.
370
371 2001-04-04  Tom Yu  <tlyu@mit.edu>
372
373         * mk_safe.c (krb5_mk_safe): Only use safe_cksumtype from the
374         auth_context (derived from the config file or hardcoded default)
375         if it's suitable for the enctype of the key we're going to
376         use. [pullup from krb5-1-2-2-branch]
377
378 2001-03-28  Ken Raeburn  <raeburn@mit.edu>
379
380         * init_ctx.c (DEFAULT_ETYPE_LIST): New macro.  Old etype list,
381         plus des-md4, with des-crc before des-mdX for now.
382         (get_profile_etype_list): Use DEFAULT_ETYPE_LIST.
383
384 2001-03-10  Ezra Peisach  <epeisach@mit.edu>
385
386         * init_ctx.c: Provide a full prototype for init_common().
387
388         * recvauth.c (recvauth_common): Declare recvauth_common as static. 
389
390         * parse.c, sendauth.c: Changes to prevent shadowing of local
391         variables.
392
393         * get_in_tkt.c, tgtname.c: Include int-proto.h for prototypes.
394
395 2001-03-03  Ken Raeburn  <raeburn@mit.edu>
396
397         * preauth2.c (pa_sam): Return an error if no prompter was
398         provided.
399
400 2001-02-15  Ezra Peisach  <epeisach@mit.edu>
401
402         * t_deltat.c (main): Test of overflow and underflow of krb5_int32. 
403
404         * x-deltat.y: Test for over/underflow of krb5_int32 for a
405         krb5_deltat. Return EINVAL. [krb5-libs/922]
406
407         * deltat.c: Regenerated from x-deltat.y
408
409         * str_conv.c (krb5_string_to_timestamp): Do not accept a time
410         format that only partially matches the input string. [krb5-lib/922]
411
412 2001-01-30  Tom Yu  <tlyu@mit.edu>
413
414         * preauth.c (krb5_obtain_padata): Don't dereference a NULL pointer
415         if we receive an empty ETYPE_INFO preauth. [krb5-libs/903 from
416         craziboy77@hotmail.com]
417
418         * preauth2.c (krb5_do_preauth): Don't dereference a NULL pointer
419         if we receive an empty ETYPE_INFO preauth. [krb5-libs/903 from
420         craziboy77@hotmail.com]
421
422 2001-01-30  Ezra Peisach  <epeisach@mit.edu>
423
424         * rd_req_dec.c (krb5_rd_req_decrypt_tkt_part): Free
425         krb5_keytab_entry if call to krb5_decrypt_tkt_part()
426         fails. [krb5-libs/855 reported by guy@packeteer.com]
427
428 2001-01-19  Ken Raeburn  <raeburn@mit.edu>
429
430         * preauth.c: Don't use PROTOTYPE macro, just always use the
431         prototypes.
432
433 2001-01-19  Tom Yu  <tlyu@mit.edu>
434
435         * preauth.c: Remove uses of KRB5_NPROTOTYPE() macro.
436
437 2000-10-26  Ezra Peisach  <epeisach@mit.edu>
438
439         * t_ser.c: Cast getpid() calls to int as arguments to sprintf.
440
441         * ser_actx.c: Move prototypes (listed below) to int-proto.h
442
443         * int-proto.h: Add prototypes for krb5_ser_authdata_init,
444         krb5_ser_address_init, krb5_ser_authenticator_init,
445         krb5_ser_checksum_init, krb5_ser_keyblock_init,
446         krb5_ser_principal_init.
447         
448         * ser_adata.c, ser_addr.c, ser_auth.c, ser_cksum.c, ser_key.c,
449         ser_princ.c: Include int-proto.h for prototypes.
450
451 2000-10-17  Ezra Peisach  <epeisach@mit.edu>
452
453         * bld_pr_ext.c, bld_princ.c (krb5_build_principal_ext,
454         krb5_build_principal_va, krb5_build_principal): Take an unsigned
455         int realm length.
456
457         * get_in_tkt.c (krb5_get_init_creds): Use SALT_TYPE_AFS_LENGTH
458         instead of -1.
459
460         * gic_pwd.c (krb5_get_as_key_password): Use SALT_TYPE_AFS_LENGTH
461         instead of -1.
462
463         * in_tkt_pwd.c (pwd_keyproc): Argument to krb5_read_password is
464         unsigned int.
465
466         * pr_to_salt.c (krb5_principal2salt_internal): Declare as
467         static. Unsigned int fix.
468
469         * preauth.c (krb5_obtain_padata): Use SALT_TYPE_AFS_LENGTH instead
470         of -1.
471
472         * preauth2.c (pa_salt): Use SALT_TYPE_AFS_LENGTH instead of -1. 
473
474         * conv_princ.c, copy_auth.c, copy_princ.c, gc_frm_kdc.c, parse.c,
475         send_tgs.c, srv_rcache.c: Unsigned/signed int cleanup.
476
477         * unparse.c (krb5_unparse_name_ext): size parameter changed to
478         unsigned int *.
479
480 2000-10-04  Ezra Peisach  <epeisach@mit.edu>
481
482         * rd_req_dec.c (krb5_rd_req_decrypt_tkt_part): Fix memory leak if
483         krb5_decrypt_tkt_part() fails. [krb5-libs/855]
484
485 2000-10-03  Ezra Peisach  <epeisach@mit.edu>
486
487         * srv_rcache.c (krb5_get_server_rcache): Signed vs unsigned int
488         warning fix.
489
490         * pr_to_salt.c (krb5_principal2salt_internal): Add prototype for
491         internal function, and declare static.
492
493         * copy_addrs.c (krb5_copy_addresses): Cleanup unsigned vs signed
494         warnings as arguments to malloc().
495
496 Tue Sep 26 13:00:54 2000  Ezra Peisach  <epeisach@mit.edu>
497
498         * conv_princ.c (krb5_425_conv_principal): Call profile_free_list
499         on v4realms during the iteration loop. Do not call
500         profile_release_string with a NULL pointer.
501
502 2000-09-25  Ezra Peisach  <epeisach@mit.edu>
503
504         * t_kerb.c: Add prototypes for test functions.
505
506 2000-08-29  Ken Raeburn  <raeburn@mit.edu>
507
508         * get_creds.c (krb5_get_credentials_core): If the supplied enctype
509         is not supported, return an error; can't satisfy both
510         TC_SUPPORTED_KTYPES and TC_MATCH_KTYPE that way.  Delete unused
511         arguments CCACHE and OUT_CREDS; fix callers.
512
513 2000-07-18  Ezra Peisach  <epeisach@mit.edu>
514
515         * vfy_increds.c: include int-proto.h for krb5_libdefault_boolean
516         prototype.
517
518         * t_ser.c (ser_eblock_test): ifdef out old eblock serialization
519         test which is no longer called. (see 1999-09-01 ChangeLog)
520
521         * t_kerb.c: Cast argument to fprintf to long to agree with format
522         string.
523
524         * t_deltat.c: If MIN is defined, undef before redefined as 60.
525
526         * str_conv.c: Provide strptime prototype if the system header
527         files fail to provide a prototype.
528
529         * int-proto.h:  Add prototype for krb5_libdefault_boolean()
530
531 2000-06-30  Tom Yu  <tlyu@mit.edu>
532
533         * conv_princ.c (krb5_425_conv_principal): NULL, not nil.
534
535 2000-06-30  Miro Jurisic  <meeroh@mit.edu>
536
537         * conv_princ.c (krb5_425_conv_principal): Fixed a memory leak
538
539 2000-06-29  Ezra Peisach  <epeisach@engrailed.mit.edu>
540
541         * t_walk_rtree.c (main): Declare as returning int.
542
543         * get_in_tkt.c (_krb5_conf_boolean): Declare as taking a const char *
544
545         * str_conv.c (krb5_timestamp_to_string): Work around gcc's warning
546         that %c format in strftime might return only two digits for the
547         year.
548
549         * mk_safe.c, rd_rep.c, send_tgs.c: Remove unused goto label.
550
551         * kdc_rep_dc.c (krb5_kdc_rep_decrypt_proc): Remove code with no
552         effect.
553
554         * init_ctx.c: Make krb5_brand[] look used.
555
556         * chpw.c, decode_kdc.c, decrypt_tk.c, enc_helper.c, get_creds.c,
557         get_in_tkt.c, gic_keytab.c, gic_pwd.c, preauth2.c, vfy_increds.c:
558         Add parentheses around assignment used as truth value
559
560 2000-06-28  Ezra Peisach  <epeisach@mit.edu>
561
562         * conv_princ.c, get_creds.c, get_in_tkt.c, mk_rep.c, parse.c,
563         send_tgs.c: Remove unused variable.
564
565 2000-06-23  Miro Jurisic  <meeroh@mit.edu>
566
567         * conv_princ.c (krb5_425_conv_principal): Fixed v4->v5 realm
568         name conversion
569
570         * conv_princ.c (krb5_425_conv_principal): Honor v4/v5 realm name
571         differences when convertion from v4 principals to v5.
572
573 2000-06-23  Tom Yu  <tlyu@mit.edu>
574
575         * get_creds.c (krb5_get_credentials): Translate KRB5_CC_NOTFOUND
576         returned from krb5_get_cred_from_kdc() if a prior call to
577         krb5_cc_retrieve_cred() returned KRB5_CC_NOT_KTYPE.
578
579         * rd_priv.c (krb5_rd_priv_basic): Delete code that was incorrectly
580         doing explicit ivec chaining; c_decrypt() does it now.
581
582         * mk_priv.c (krb5_mk_priv_basic): Delete code that was incorrectly
583         doing explicit ivec chaining; c_encrypt() does it now.
584
585         * conv_princ.c (krb5_524_conv_principal): Make a copy of the krb5
586         realm that is nul-terminated to avoid falling off the end of the
587         krb5 realm, which is not necessarily nul-terminated.
588
589 2000-06-23  Danilo Almeida  <dalmeida@mit.edu>
590
591         * init_ctx.c (krb5_get_tgs_ktypes, krb5_free_ktypes): Fix linkage to
592         be KRB5_CALLCONV.
593
594 2000-06-23  Ken Raeburn  <raeburn@mit.edu>
595
596         * get_in_tkt.c (krb5_get_in_tkt): If enctypes are specified, send
597         the server the intersection of that list and the supported types,
598         in the order requested.
599
600         * recvauth.c (krb5_recvauth_version): New routine, takes a
601         krb5_data in which to store the client's application version
602         string.
603         (recvauth_common): Renamed from krb5_recvauth, added above
604         functionality depending on extra argument values.
605         (krb5_recvauth): New stub, calls above routine with extra dummy
606         values.
607
608         * kfree.c: Remove unneeded "return" statements at the end of many
609         functions.
610         (krb5_free_*_content, krb5_free_*_contents,
611         krb5_free_cred_enc_part, krb5_free_pwd_sequences): Set freed
612         pointer members to null when containing structure isn't being
613         freed.
614
615         * t_kerb.c (test_524_conv_principal): New test code, to exercise
616         bbense's code addition.
617         (main, usage): Updated.
618         * t_krb5.conf: Added stanford.edu->IR.STANFORD.EDU mapping, and a
619         test case for improperly long v4 realm names.
620         * Makefile.in (check-unix): Run 524 conversion test for some test
621         Athena and Stanford names.
622         * t_ref_kerb.out: Updated.
623
624         * init_ctx.c (init_common): Feed current-microsecond time and
625         process-id into PRNG, instead of just current-second time.
626         * mk_req_ext.c (krb5_mk_req_extended): Feed current time into
627         PRNG if a subkey will be generated.
628         * sendauth.c (krb5_sendauth): Feed local and remote addresses of
629         socket, if they can be determined, into the PRNG if a subkey will
630         be used.
631
632         * init_ctx.c (krb5_free_ktypes): New routine, to free values
633         returned by krb5_get_tgs_ktypes, krb5_get_permitted_enctypes, and
634         krb5_get_default_in_tkt_ktypes.
635         (krb5_set_default_tgs_ktypes, krb5_is_permitted_enctype): Use it.
636         (get_profile_etype_list): Use passed-in enctype list if the
637         passed-in count is non-zero, instead of checking the
638         in_tkt_ktype_count value in the context.
639
640 2000-06-23  Ken Raeburn  <raeburn@mit.edu>
641             Nalin Dahyabhai  <nalin@redhat.com>
642
643         * conv_princ.c (krb5_524_conv_principal): Return an error if name
644         is too long.  Use memcpy for character data since we already know
645         the length.
646
647 2000-06-23  Nalin Dahyabhai  <nalin@redhat.com>
648
649         * kfree.c (krb5_free_keyblock_contents): Set contents pointer to
650         null after freeing.
651
652         * chk_trans.c (krb5_check_transited_list): Don't overflow buffers
653         "prev" and "next".
654         * conv_princ.c (krb5_425_conv_principal): Don't overflow buffer
655         "buf".
656
657 2000-06-23  Ken Raeburn  <raeburn@mit.edu>
658             Booker C. Bense  <bbense@networking.stanford.edu>
659
660         * conv_princ.c (krb5_524_conv_principal): Look up v4_realm in
661         config file, in case site's krb4 realm name isn't the same as the
662         krb5 realm name.
663
664 2000-05-31  Wilfredo Sanchez  <tritan@mit.edu>
665
666         * fwd_tgt.c: Check for existance of <memory.h>.
667         [from Nathan Neulinger <nneul@umr.edu>]
668
669 2000-5-19       Alexandra Ellwood <lxs@mit.edu>
670
671         * sendauth.c, fwd_tgt.c: Changed to use krb5int_cc_default.  This function 
672         supports the Kerberos Login Library and pops up a dialog if the cache does 
673         not contain valid tickets.  This is used to automatically get a tgt before
674         obtaining service tickets.  Note that this should be an internal function
675         because callers don't expect krb5_cc_default to pop up a dialog!
676         (We found this out the hard way :-)
677
678 2000-05-15      Jeffrey Altman          <jaltman@columbia.edu>
679
680         * Added new source file appdefault.c
681           Implements new public functions
682
683                krb5_appdefault_string
684                krb5_appdefault_boolean
685
686 2000-04-28      Alexandra Ellwood       <lxs@mit.edu>
687
688         * gic_pwd.c (krb5_init_creds_password) added code to return to
689         login library if the password is expired (login library handles
690         this error appropriately).
691
692 2000-04-08  Tom Yu  <tlyu@mit.edu>
693
694         * vfy_increds.c (krb5_verify_init_creds): appdefault_boolean ->
695         libdefault_boolean; it somehow got missed earlier.
696
697 2000-04-07  Jeffrey Altman  <jaltman@columbia.edu>
698
699         * gic_pwd.c (krb5_get_init_creds_keytab), gic_pwd.c
700         (krb5_get_init_creds_password) when determining whether or not to
701         retry with a "master kdc" do not retry if the return value from
702         the first attempt was KRB5_REALM_CANT_RESOLV.  Also, do not
703         overwrite the return code if the return value from the access to
704         the "master kdc" was KRB5_REALM_CANT_RESOLV.
705
706 2000-03-15  Danilo Almeida  <dalmeida@mit.edu>
707
708         * init_ctx.c (init_common), gic_pwd.c (krb5_get_as_key_password,
709         krb5_get_init_creds_password), preauth2.c (pa_sam): Add support
710         for krb5_get_prompt_types().
711
712 2000-03-13  Ken Raeburn  <raeburn@mit.edu>
713
714         * preauth2.c (pa_function): Called function now takes new
715         krb5_enctype pointer argument.
716         (pa_salt, pa_sam): Accept new arg, ignore it.
717         (pa_enc_timestamp): Accept new arg.  If value pointed to is
718         nonzero, pass it to get-AS-key fn instead of first requested
719         enctype.  Added some debugging fprintf calls, conditionally
720         compiled.
721         (krb5_do_preauth): Accept new arg, and pass it through to the
722         specific preauth functions.  Added some debugging fprintf calls,
723         conditionally compiled.
724
725         * get_in_tkt.c (krb5_get_init_creds): Pass etype pointer to
726         krb5_do_preauth.
727
728 2000-03-12  Ezra Peisach  <epeisach@mit.edu>
729
730         * addr_comp.c, addr_order.c, addr_srch.c, bld_pr_ext.c,
731         bld_princ.c, encrypt_tk.c, gen_seqnum.c, gen_subkey.c: Change
732         prototypes to use krb5_const instead of const to match the entries
733         in krb5.hin
734
735 2000-03-10  Miro Jurisic  <meeroh@mit.edu>
736
737         * get_in_tkt.c (krb5_get_init_creds): Always initialize local_as_reply
738         to avoid returning garbage on error returns.
739
740 2000-02-25  Ken Raeburn  <raeburn@mit.edu>
741
742         * preauth2.c (krb5_do_preauth): Check paorder[h] not h for
743         PA_REAL.  Fix from Matt Crawford.
744
745 2000-02-16  Ken Raeburn  <raeburn@mit.edu>
746
747         * preauth2.c (pa_sam): In send-encrypted-sad mode, check for magic
748         salt length and generate a salt from the principal name if found;
749         use the password and salt to generate a key.  Provide timestamp if
750         nonce is zero, regardless of preauth mode.  (Patch from Chas
751         Williams.)
752
753 2000-02-07  Ken Raeburn  <raeburn@mit.edu>
754
755         * gic_pwd.c (krb5_get_as_key_password): If the as_key enctype is
756         already set to the correct type, do continue and ask for the
757         password anyways.  (Patch from Chas Williams, PR krb5-libs/730.)
758
759         * preauth2.c (pa_sam): If no sam_flags were set, return
760         KRB5_PREAUTH_BAD_TYPE, because we don't currently handle that
761         case.
762
763 2000-02-06  Ken Raeburn  <raeburn@mit.edu>
764
765         * preauth2.c (pa_sam): Remove unused variable use_sam_key.
766         (SAMDATA): Cast first result to int, which is what sprintf needs.
767         (pa_salt): Delete unused variable ret.
768
769         Patches from Frank Cusack:
770         * kfree.c (krb5_free_predicted_sam_response_contents): Fix typo.
771         Free new data fields if needed.
772         (krb5_free_enc_sam_response_enc_contents): Update for field name
773         change.
774         * preauth.c (obtain_sam_padata): Update for field name change.
775         * preauth2.c (pa_sam): Likewise.
776
777 2000-01-27  Ken Raeburn  <raeburn@mit.edu>
778
779         * init_ctx.c (get_profile_etype_list): Discard DESONLY changes
780         from 1999-09-01, and revert call sites.
781
782 1999-12-02  Ken Raeburn  <raeburn@mit.edu>
783
784         * init_ctx.c (get_profile_etype_list): Report an error if no
785         recognized enctypes are found in the config file.
786
787 1999-11-23  Ken Raeburn  <raeburn@mit.edu>
788
789         * init_ctx.c (init_common): Renamed from krb5_init_context, now
790         static.  New argument SECURE provides initialization of
791         profile_secure field.
792         (krb5_init_context): Call it.
793         (krb5_init_secure_context): New function.
794
795         * in_tkt_ktb.c (keytab_keyproc): Now static.
796         * in_tkt_pwd.c (pwd_keyproc): Now static.
797         * in_tkt_sky.c (skey_keyproc): Now static.
798
799         * preauth2.c (krb5_do_preauth): Fix syntax in switch statement.
800         Cast padata contents pointer to avoid warning.
801         (pa_types): Now static.
802
803         * str_conv.c (krb5_deltat_to_string): Always write to a local
804         temporary buffer that's guaranteed to be large enough, then see if
805         the supplied output buffer is big enough.
806         (krb5_string_to_deltat): Deleted.
807         * x-deltat.y, deltat.c: New files.
808         * Makefile.in (deltat.c): Add rule for building from x-deltat.y,
809         but comment out dependencies for easier maintenance.
810         (BISON, BISONFLAGS): New variables.
811
812         * str_conv.c: Removed most static char arrays, substituting the
813         values in place.
814         (krb5_string_to_timestamp): Move atime_format_table inside here.
815         (krb5_timestamp_to_sfstring): Move sftime_format_table inside
816         here.
817
818         * str_conv.c: If strftime or strptime are not available, include
819         the renamed NetBSD versions, and define the function names as
820         macros to map them to the replacement names.
821         (__P, _CurrentTimeLocale, dummy_locale_info, TM_YEAR_BASE,
822         DAYSPERLYEAR, DAYSPERNYEAR, DAYSPERWEEK, isleap, tzname, tzset):
823         Define some dummies for strftime/strptime to use.
824         (strptime): Deleted old stub version.
825         (krb5_timestamp_to_string, krb5_timestamp_to_sfstring): Always
826         assume strftime is available.
827         (krb5_string_to_timestamp): Assume strptime is always available.
828         * strftime.c, strptime.c: New files, based on NetBSD versions.
829         Modified to rename the functions and not export any symbols.
830
831         * Makefile.in (T_DELTAT_OBJS): New variable.
832         (TEST_PROGS): Add t_deltat.
833         (t_deltat): Add rule.
834         (clean): Added t_deltat stuff.  Run rm only once.
835         * t_deltat.c: New file.
836
837 1999-11-02  Ken Raeburn  <raeburn@mit.edu>
838
839         * t_ref_kerb.out: Fix expected zephyr/zephyr output.
840
841 1999-10-26  Wilfredo Sanchez  <tritan@mit.edu>
842
843         * Makefile.in: Clean up usage of CFLAGS, CPPFLAGS, DEFS, DEFINES,
844         LOCAL_INCLUDES such that one can override CFLAGS from the command
845         line without losing CPP search patchs and defines. Some associated
846         Makefile cleanup.
847
848 1999-10-12  Ken Raeburn  <raeburn@mit.edu>
849
850         * conv_princ.c (sconv_list): Don't do conversion for "zephyr"
851         principal.  (Noticed by Derrick Brashear.)  Delete about a dozen
852         duplicate entries.
853
854 1999-09-01  Ken Raeburn  <raeburn@mit.edu>
855
856         * init_ctx.c (get_profile_etype_list): Update name of the des3
857         entry in the default etype list.
858
859         * init_ctx.c (get_profile_etype_list): New argument DESONLY; if
860         set, ignore any ktype values other than NULL, DES_CBC_CRC, and
861         DES_CBC_MD5.
862         (krb5_get_default_in_tkt_ktypes, krb5_get_tgs_ktypes): Set it.
863         (krb5_get_permitted_enctypes): Don't set it.
864
865         * fwd_tgt.c (krb5_fwd_tgt_creds): Use KRB5_TC_SUPPORTED_KTYPES
866         when calling krb5_cc_retrieve_cred.
867         * gc_frm_kdc.c (krb5_get_cred_from_kdc_opt): Ditto.
868         * get_creds.c (krb5_get_credentials_core): Set that flag.
869         (krb5_get_credentials): Check for KRB5_CC_NOT_KTYPE error return.
870
871         * t_ser.c (main): Disable eblock serialization test, since the
872         code it tests was disabled nearly a year ago.
873
874         * str_conv.c (krb5_timestamp_to_sfstring): Don't pass extra
875         argument to sprintf.
876
877 1999-08-10      Alexandra Ellwood       <lxs@mit.edu>
878
879         * chpw.c (krb5_mk_chpw_req):
880                 Added call to free cipherpw.data.  cipherpw.data is allocated 
881                 by krb5_mk_priv and passed back.  Since cipherpw is never
882                 passed back, krb5_mk_chpw_req should free it.
883
884 1999-08-05  Danilo Almeida  <dalmeida@mit.edu>
885
886         * init_ctx.c (krb5_init_context): Document why krb5_win_ccdll_load
887         is called way early in code.  (It is because we need to have the
888         ccapi stuff loaded before trying to get the OS-specific context
889         initialization where we figure out default cache names and such.)
890
891 1999-08-05  Danilo Almeida  <dalmeida@mit.edu>
892
893         * init_ctx.c (get_profile_etype_list): Use profile_release_string
894         to free string allocated by profile_get_string.
895         (krb5_init_context): Use a real context for krb5_win_ccdll_load.
896
897         * get_in_tkt.c (krb5_appdefault_string):
898         * conv_princ.c (krb5_425_conv_principal): Use profile_free_list
899         to free values allocated by profile_get_values.
900
901 1999-08-04  Danilo Almeida  <dalmeida@mit.edu>
902
903         * get_in_tkt.c (_krb5_conf_boolean, krb5_appdefault_boolean): 
904         Rename krb5_conf_boolean to _krb5_conf_boolean to denote that
905         it is not public so that folks outside the libraries won't
906         be tempted to use it.
907
908 1999-08-03  Danilo Almeida  <dalmeida@mit.edu>
909
910         * get_creds.c (krb5_validate_or_renew_creds): Intialize out_creds
911         pointer to 0 and then check whether it is 0 before trying to 
912         dereference it, in case lower-level routine failed to assign
913         a value to it.
914
915 1999-07-22  Jeffrey Altman <jaltman@columbia.edu>
916
917         get_in_tkt.c:  rename conf_boolean to krb5_conf_boolean so that
918         it may be used in additional modules.
919
920 1999-06-28  Tom Yu  <tlyu@mit.edu>
921
922         * enc_helper.c (krb5_encrypt_helper): NULL out the pointer to the
923         ciphertext if there is an error; this prevents stuff farther up
924         from freeing freed memory.
925
926 1999-06-18  Ken Raeburn  <raeburn@mit.edu>
927
928         * init_ctx.c (krb5_free_context): Set field pointers to NULL after
929         freeing targets, in case higher-level code retains pointers into
930         the context structure.  (From Jeffrey Altman.)
931
932 Thu May 13 17:31:34 1999  Theodore Y. Ts'o  <tytso@mit.edu>
933
934         * init_ctx.c (krb5_init_context): Pass the context to
935                 kkrb5_win_ccdll_load so that it can register the FILE
936                 ccache type if using ccapi (so that the FILE ccache type
937                 will always work).
938
939 Mon May 10 15:26:00 1999  Danilo Almeida  <dalmeida@mit.edu>
940
941         * Makefile.in: Do win32 build in subdir.
942
943 1999-04-09  Theodore Ts'o  <tytso@rsts-11.mit.edu>
944
945         * kfree.c (krb5_free_sam_challenge, krb5_free_sam_challenge_contents,
946                 krb5_free_sam_response, krb5_free_sam_response_contents,
947                 krb5_free_predicted_sam_response, 
948                 krb5_free_predicted_sam_response_contents,
949                 krb5_free_enc_sam_response_enc, 
950                 krb5_free_enc_sam_response_enc_contents,
951                 krb5_free_pa_enc_ts): Added new functions.  Part of
952                 patches from [krb5-kdc/662]
953
954         * gic_pwd.c (krb5_get_init_creds_password): Add new argument to
955                 calls to the prompter function.  Part of patches from
956                 [krb5-kdc/662].
957
958         * preauth2.c (pa_enc_timestamp, pa_sam): Update calls to new
959                 prompter function.   [krb5-kdc/662].
960
961 1999-03-31  Theodore Ts'o  <tytso@rsts-11.mit.edu>
962
963         * init_ctx.c (krb5_init_context): Call krb5_win_ccdll_load() to
964                 load the krbcc32.dll under windows.
965
966 Mon Mar  8 22:39:01 1999  Tom Yu  <tlyu@mit.edu>
967
968         * sendauth.c (krb5_sendauth): Set credspout to NULL if it's
969         destined to be returned to avoid freeing it.  Also,
970         unconditionally free credspout if it's non-NULL so that if someone
971         doesn't pass in a ticket and doesn't give us a non-NULL out_creds,
972         we don't leak it. [krb5-libs/699]
973
974 1998-11-13  Theodore Ts'o  <tytso@rsts-11.mit.edu>
975
976         * Makefile.in: Set the myfulldir and mydir variables (which are
977                 relative to buildtop and thisconfigdir, respectively.)
978
979 Mon Nov  2 19:00:23 1998  Tom Yu  <tlyu@mit.edu>
980
981         * str_conv.c: Remove krb5_cksumtype_to_string after merge.
982
983 1998-10-27  Marc Horowitz  <marc@mit.edu>
984
985         * vfy_increds.c: rearrange the code a bit to make it more clear
986         that the logic is correct.
987
988         * str_conv.c: remove enctype and cksumtype string converstions.
989         They're in the crypto library now, since the information drops
990         right into the enctype table.
991
992         * ser_eblk.c: ifdef the whole file out, since it's not used
993         anywhere.  it should probably be deleted, but I'm not sure about
994         backward-compatibility issues yet.
995
996         * rd_req_dec.c: check the auth_context permit-all flag and
997         permitted_enctypes list, and reject the request if the policy
998         check fails.
999
1000         * init_ctx.c: add code to initialize the prng.  It's not great,
1001         but can be improved, and the prng is reseeded when new keys are
1002         processed. Read permitted_enctypes from the krb5.conf file, and
1003         provide accessor functions for it.  Make the various etype list
1004         parsers share code as a side effect.
1005
1006         * get_creds.c: add krb5_get_{validat,renew}ed_creds functions,
1007         which are part of the new init_creds api.  The prototypes were
1008         already in, krb5.hin but there was no implementing code.
1009
1010         * auth_con.c, auth_con.h: add a list of permitted enctypes to the
1011         auth_context for rd_req to check, and create accessor functions
1012         for this list.
1013
1014         * Makefile.in, enc_helper.c: add enc_helper.c.  This provides a
1015         wrapper around the conventional way the library encrypts and wraps
1016         encoded asn.1 structures, so the code isn't repeated in a dozen
1017         places.
1018
1019 Wed Aug 19 17:27:51 1998  Tom Yu  <tlyu@mit.edu>
1020
1021         * conv_princ.c: Add some additional entries to sconv_list that
1022         were forgotten.
1023
1024 Wed Jul 15 11:46:05 1998  Ezra Peisach  <epeisach@mit.edu>
1025
1026         * gic_pwd.c (krb5_get_init_creds_password): Remove unused argument
1027                 to sprintf().
1028
1029         * t_ref_kerb.out: Fix test case for zephyr principal to reflect
1030                 addition to conv_princ.c
1031
1032 Tue Jul  7 17:06:13 1998  Theodore Y. Ts'o  <tytso@mit.edu>
1033
1034         * conv_princ.c: Add additional commonly seen Kerberos V4 services
1035                 to the hard-coded list.
1036
1037 Tue Jul  7 16:59:03 1998  Tom Yu  <tlyu@mit.edu>
1038
1039         * chk_trans.c: Fix up previous fix; short-circuit out when
1040         trans->length == 0.
1041
1042 Wed Jul  1 17:59:26 1998  Theodore Y. Ts'o  <tytso@mit.edu>
1043
1044         * chk_trans.c (krb5_check_transited_list): Fix use of an
1045                 uninitialized variable; apparently the code was depending
1046                 on the stack garbage being non-zero(!)
1047
1048 1998-05-26  Theodore Ts'o  <tytso@rsts-11.mit.edu>
1049
1050         * srv_rcache.c (krb5_get_server_rcache): 
1051         * auth_con.c (krb5_auth_con_setrcache): Export this function in
1052                 Windows DLL.
1053
1054 1998-05-12  Theodore Ts'o  <tytso@rsts-11.mit.edu>
1055
1056         * str_conv.c (krb5_timestamp_to_sfstring): Make sure the date
1057                 string printed uses 4 digit years.
1058
1059 1998-05-08  Theodore Ts'o  <tytso@rsts-11.mit.edu>
1060
1061         * str_conv.c (krb5_string_to_timestamp, strptime): Fix routines to
1062                 be able to properly parse Y2K dates.  
1063
1064         * t_kerb.c: Add ability to test krb5_string_to_timestamp
1065
1066 1998-05-06  Theodore Ts'o  <tytso@rsts-11.mit.edu>
1067
1068         * t_ser.c (main): POSIX states that getopt returns -1
1069                 when it is done parsing options, not EOF.
1070
1071 1998-05-05  Theodore Ts'o  <tytso@rsts-11.mit.edu>
1072
1073         * get_in_tkt.c (krb5_get_init_creds): If
1074                 libdefaults/{REALM}/noaddresses is true, then don't put
1075                 any addresses in the ticket request.
1076
1077 Mon May  4 15:54:07 1998  Tom Yu  <tlyu@mit.edu>
1078
1079         * get_in_tkt.c: Add prototype for make_preauth_list.
1080
1081 Sat May  2 21:46:02 1998  Tom Yu  <tlyu@mit.edu>
1082
1083         * get_in_tkt.c (krb5_get_in_tkt): Add missing argument to call to
1084         make_preauth_list to avoid stack smashing.  Pointed out by lxs.
1085
1086 Mon Mar 16 19:50:55 1998  Tom Yu  <tlyu@mit.edu>
1087
1088         * chk_trans.c (krb5_check_transited_list): Check lengths when
1089         appending to next and prev.
1090
1091 Fri Feb 27 18:03:33 1998  Theodore Ts'o  <tytso@rsts-11.mit.edu>
1092
1093         * Makefile.in: Changed thisconfigdir to point at the lib/krb5
1094                 directory, since we've moved the configure.in tests in
1095                 this directory to the toplevel lib/krb5 configure.in
1096
1097 Thu Feb 19 19:03:20 1998  Tom Yu  <tlyu@mit.edu>
1098
1099         * recvauth.c (krb5_recvauth): Add some bookkeeping flags so we
1100         know how much stuff to free upon cleanup.  Fix the up cleanup
1101         code.
1102
1103 Wed Feb 18 16:24:02 1998  Tom Yu  <tlyu@mit.edu>
1104
1105         * Makefile.in: Remove trailing slash from thisconfigdir.  Fix up
1106         BUILDTOP for new conventions.
1107
1108 Fri Feb 13 15:27:35 1998  Theodore Ts'o  <tytso@rsts-11.mit.edu>
1109
1110         * Makefile.in: Added new file kfree.c, which contained all of the
1111                 functions previously in the lib/krb5/free directory.
1112
1113 Mon Feb  2 17:02:29 1998  Theodore Ts'o  <tytso@rsts-11.mit.edu>
1114
1115         * Makefile.in: Define BUILDTOP and thisconfigdir in the Makefile
1116
1117 Thu Feb  5 23:48:34 1998  Theodore Y. Ts'o  <tytso@mit.edu>
1118
1119         * rd_cred.c (krb5_rd_cred): 
1120         * rd_safe.c (krb5_rd_safe): 
1121         * rd_priv.c (krb5_rd_priv): Use the remote_subkey first, since the
1122                 mk_* routines try to use their local_subkey first.
1123                 Otherwise, the wrong keys will get used if subkeys are
1124                 used in both directions.
1125
1126 Fri Jan  2 21:21:29 1998  Tom Yu  <tlyu@mit.edu>
1127
1128         * preauth.c (handle_sam_labels):
1129         (obtain_sam_padata): Check return of malloc. [krb5-libs/518]
1130
1131         * chpw.c (krb5_mk_chpw_req): Check return of malloc.
1132         (krb5_rd_chpw_rep): Check return of malloc. [krb5-libs/518]
1133
1134 Tue Dec 16 00:08:33 1997  Tom Yu  <tlyu@mit.edu>
1135
1136         * mk_req_ext.c (krb5_mk_req_extended): Check enctype of session
1137         key, not that of the ticket, which we really shouldn't care about.
1138
1139 Sun Dec  7 07:24:23 1997  Ezra Peisach  <epeisach@dumpster.rose.brandeis.edu>
1140
1141         * gic_pwd.c (krb5_get_init_creds_password): Change fourth argument
1142         in call to prompter (which is an int) from NULL to 0.
1143
1144 Sat Dec  6 02:28:17 1997  Tom Yu  <tlyu@mit.edu>
1145
1146         * Makefile.in: Add files chpw.c, gic_*, preauth2.c, vfy_increds.c,
1147         vic_opt.c.
1148
1149         * chpw.c: New file; implement Cygnus chpw.
1150
1151         * get_in_tkt.c: Implement support for Cygnus initial credentials
1152         API.
1153
1154         * gic_keytab.c: New file; Cygnus initial creds.
1155
1156         * gic_opt.c: New file; Cygnus initial creds.
1157
1158         * gic_pwd.c: New file; Cygnus initial creds.
1159
1160         * preauth.c: Add more SAM support (from Cygnus).
1161
1162         * preauth2.c: New file; additional SAM support from Cygnus.
1163
1164         * send_tgs.c: Account for additional parameter to sendto_kdc.
1165
1166         * vfy_increds.c: New file; Cygnus initial creds.
1167
1168         * vic_opt.c: New file; Cygnus initial creds.
1169
1170 Wed Oct 22 00:29:33 1997  Theodore Y. Ts'o  <tytso@mit.edu>
1171
1172         * send_tgs.c (krb5_send_tgs): Don't send a zero endtime; if the
1173                 requested endtime is zero, set it equal to the TGT endtime.
1174
1175 Mon Oct  6 12:07:19 1997  Ezra Peisach  <epeisach@kangaroo.mit.edu>
1176
1177         * set_realm.c (krb5_set_principal_realm): Allocate extra byte for
1178                 \0 after realm.
1179
1180 Mon Sep  1 21:38:16 1997  Tom Yu  <tlyu@mit.edu>
1181
1182         * rd_cred.c (krb5_rd_cred_basic): Fix swapped args to memset.
1183
1184 Fri Aug 29 16:41:25 1997  Tom Yu  <tlyu@mit.edu>
1185
1186         * get_in_tkt.c (krb5_get_in_tkt): Move nulling out of
1187         request.padata before the os_localaddr call in order to avoid
1188         freeing a null pointer in the cleanup code.
1189
1190 Tue Aug 12 09:13:22 1997  Ezra Peisach  <epeisach@mit.edu>
1191
1192         * init_ctx.c (krb5_init_context): Initialize local variable ctx
1193                 before calling krb5_init_ets.
1194
1195 Fri Aug  8 17:04:54 1997  Tom Yu  <tlyu@mit.edu>
1196
1197         * rd_cred.c (krb5_rd_cred_basic): Check remote_addr and
1198         encpart.s_address before calling krb5_address_compare.  Fixes
1199         krb5-libs/456.
1200
1201 Fri Jul 25 15:25:32 1997  Tom Yu  <tlyu@mit.edu>
1202
1203         * t_ser.c: Add support for changed kdb API.
1204
1205 Tue Jul 15 22:15:09 1997  Theodore Y. Ts'o  <tytso@mit.edu>
1206
1207         * serialize.c (krb5_register_serializer): Only copy over the old
1208                 table when there's an old table to copy over.  Otherwise,
1209                 BoundsChecker complains about memcpy(foo, NULL, 0).
1210
1211 Tue Mar 25 00:32:55 1997  Theodore Y. Ts'o  <tytso@mit.edu>
1212
1213         * preauth.c (obtain_sam_padata): Fix handling of the sam-timestamp
1214                 and sam-usec fields, which should always be set if the
1215                 nonce is not available, not just SAM_USE_SAD_AS_KEY is
1216                 being used.  [krb5-libs/325]
1217
1218 Mon Mar 24 12:21:38 1997  Theodore Ts'o  <tytso@rsts-11.mit.edu>
1219
1220         * t_ser.c: Clean up error reporting for krb5_init_context().  Also
1221                 report errors for each subtest, so we know which subtest
1222                 failed.
1223
1224 Sat Feb 22 22:39:49 1997  Richard Basch  <basch@lehman.com>
1225
1226         * Makefile.in: Use some of the new library list build rules in
1227                 win-post.in
1228
1229 Fri Feb 21 18:38:06 1997  Sam Hartman  <hartmans@tertius.mit.edu>
1230
1231         * crypto_glue.c: Move into libcrypto as krb5_glue.c; I need to
1232         avoid libcrypto depending on libkrb5
1233
1234 Wed Feb 19 14:21:12 1997  Theodore Y. Ts'o  <tytso@mit.edu>
1235
1236         * t_kerb.c (test_set_realm): New function used to test
1237         krb5_set_principal_realm().  Called by using the new "set_realm"
1238         command to t_kerb.
1239
1240         * set_realm.c (krb5_set_principal_realm): New function which sets
1241                 the realm of a principal.
1242
1243 Thu Feb 13 14:17:00 1997  Richard Basch  <basch@lehman.com>
1244
1245         * get_in_tkt.c (krb5_get_in_tkt): Initialize as_reply; if
1246                 krb5_os_localaddr() returns an error, the cleanup
1247                 routine may try to free a garbage pointer (as_reply).
1248
1249 Wed Feb 12 20:47:30 1997  Tom Yu  <tlyu@mit.edu>
1250
1251         * fwd_tgt.c (krb5_fwd_tgt_creds): Use the client's realm rather
1252                 than the server's realm for constructing the tgs principal.
1253                 Remove TC_MATCH_SRV_NAMEONLY from call to retrieve_cred()
1254                 because we want to get an exact match.
1255
1256 Mon Feb 10 10:41:36 1997  Ezra Peisach  <epeisach@mit.edu>
1257
1258         * crypto_glue.c (krb5_calculate_checksum): Add krb5_const to
1259                 krb5_pointer of in data to match prototype.
1260
1261 Sat Feb  8 15:02:39 1997  Richard Basch  <basch@lehman.com>
1262
1263         * get_creds.c:
1264                 Export krb5_get_credentials_{renew,validate} (win32)
1265                 Removed unused variable.
1266
1267 Fri Feb  7 09:41:33 1997  Richard Basch  <basch@lehman.com>
1268
1269         * mk_cred.c (krb5_mk_ncred): Declare ncred as krb5_int32 so that
1270                 the right value is pushed onto the stack when calling
1271                 krb5_mk_ncred_basic()
1272
1273         * copy_addrs.c fwd_tgt.c mk_cred.c:
1274                 Use FAR keyword in pointer declarations.
1275
1276         * sendauth.c (krb5_sendauth): Do not free the credentials if they
1277                 are being returned to the caller [krb5-libs/357]
1278
1279 Sun Feb  2 20:57:15 1997  Richard Basch  <basch@lehman.com>
1280
1281         * serialize.c: Added FAR declarations to pointer arguments for
1282                 all functions declared as KRB5_DLLIMP.
1283
1284 Thu Jan 30 21:44:37 1997  Richard Basch  <basch@lehman.com>
1285
1286         * crypto_glue.c:
1287                 Export more crypto-layer functions:
1288                 krb5_encrypt, krb5_decrypt, krb5_eblock_enctype,
1289                 krb5_process_key, krb5_finish_key, krb5_string_to_key,
1290                 krb5_init_random_key, krb5_finish_random_key, krb5_random_key
1291
1292 Sat Feb  8 18:41:42 1997  Tom Yu  <tlyu@mit.edu>
1293
1294         * Makefile.in:
1295         * configure.in: Update to new program build procedure.
1296
1297 Thu Jan  2 17:16:18 1997  Tom Yu  <tlyu@mit.edu>
1298
1299         * Makefile.in:
1300         * configure.in: Update to new library build procedure.
1301
1302 Mon Dec 23 17:20:03 1996  Theodore Y. Ts'o  <tytso@mit.edu>
1303
1304         * Makefile.in (SRCS): Add brand.c to the SRCS line so that the
1305                 kerbsrc.mac.tar includes brand.c
1306
1307 Sat Dec 21 01:26:11 1996  Theodore Y. Ts'o  <tytso@mit.edu>
1308
1309         * brand.c: New file, which allows a release engineer to "brand"
1310                 the krb5 library or a binary application program
1311                 statically linked against the krb5 library.  This file is
1312                 statically included by init_ctx.c, to force it be in a
1313                 binary library or application program.
1314         
1315         * init_ctx.c (krb5_init_context): Use new call krb5_vercheck() for
1316                 Windows timebomb checking; this call returns an error
1317                 code, which is returned to the user if the timebomb should
1318                 be activated.
1319
1320 Thu Nov 21 14:55:16 EST 1996    Richard Basch   <basch@lehman.com>
1321
1322         * Makefile.in: win32 build
1323
1324         * auth_con.c bld_pr_ext.c conv_princ.c copy_addrs.c copy_athctr.c
1325         copy_auth.c copy_cksum.c copy_creds.c copy_data.c copy_key.c
1326         copy_princ.c copy_tick.c cp_key_cnt.c decrypt_tk.c fwd_tgt.c
1327         gc_via_tkt.c get_creds.c get_in_tkt.c in_tkt_ktb.c in_tkt_pwd.c
1328         in_tkt_sky.c init_ctx.c mk_cred.c mk_error.c mk_priv.c mk_rep.c
1329         mk_req.c mk_req_ext.c mk_safe.c parse.c princ_comp.c rd_cred.c
1330         rd_error.c rd_priv.c rd_rep.c rd_req.c rd_safe.c recvauth.c
1331         sendauth.c str_conv.c unparse.c valid_times.c
1332                 DLL export various functions (see lib/krb5.def for full list)
1333
1334 Thu Nov 21 13:54:01 1996  Ezra Peisach  <epeisach@mit.edu>
1335
1336         * recvauth.c (krb5_recvauth): If there is an error, and the server
1337                 argument to krb5_recvauth is NULL, create a dummy server
1338                 entry for the krb5_error structure so that krb5_mk_error
1339                 will not die with missing required fields. [krb5-libs/209]
1340
1341 Wed Nov 13 14:30:47 1996  Tom Yu  <tlyu@mit.edu>
1342
1343         * init_ctx.c: Revert previous kt_default_name changes.
1344
1345 Tue Nov 12 22:07:33 1996  Tom Yu  <tlyu@mit.edu>
1346
1347         * init_ctx.c (krb5_init_context): Oops. Initialize kt_default_name
1348         to NULL.
1349         
1350         * init_ctx.c (krb5_free_context): Free kt_default_name if it's
1351         non-NULL.
1352
1353 Sat Nov  9 14:19:28 1996  Ezra Peisach  <epeisach@mit.edu>
1354
1355         * Makefile.in (check-unix): Invoking t_ser requires that
1356                 KRB5_CONFIG points to a valid krb5.conf 
1357
1358         * t_ser.c (main): If verbose flag is set and there is an error,
1359                 display error message.
1360
1361 Wed Nov  6 14:02:21 1996  Theodore Y. Ts'o  <tytso@mit.edu>
1362
1363         * init_ctx.c (krb5_init_context): Initialize the error tables, so
1364                 applications don't need to call krb5_init_ets().
1365
1366 Tue Nov  5 08:09:23 1996  Ezra Peisach  <epeisach@mit.edu>
1367
1368         * serialize.c (krb5_register_serializer): Do not free a NULL pointer. 
1369
1370 Thu Oct 31 13:48:14 1996  Theodore Y. Ts'o  <tytso@mit.edu>
1371
1372         * init_ctx.c (krb5_init_context): Make it more obvious that
1373                 default ticket lifetimes is not yet supported.
1374
1375 Tue Sep 24 20:59:14 1996  Theodore Y. Ts'o  <tytso@mit.edu>
1376
1377         * get_in_tkt.c (make_preauth_list): Correctly null-terminate the
1378                 preauth list generated by make_preauth_list.
1379
1380 Thu Sep 19 12:29:59 1996  Theodore Y. Ts'o  <tytso@mit.edu>
1381
1382         * unparse.c (krb5_unparse_name_ext): Make unparse correctly handle
1383                 a all cases where a principal contains a nulls, backspace,
1384                 newlines, or tabs.
1385
1386         * t_kerb.c (test_parse_principal): Add test for checking
1387                 krb5_parse_principal()
1388
1389         * parse.c (krb5_parse_name): Set all of the magic field values.
1390
1391 Wed Jul 24 17:09:39 1996  Theodore Y. Ts'o  <tytso@mit.edu>
1392
1393         * preauth.c (find_pa_system): Change type of first argument to be
1394                 krb5_preauthtype, to eliminate compiler warnings under
1395                 Windows.
1396         
1397 Wed Jul 10 20:22:41 1996  Theodore Y. Ts'o  <tytso@mit.edu>
1398
1399         * init_ctx.c (krb5_init_context): Add a call to krb5_win_do_init()
1400                 on Win16 and Win32 machines.  This is where we do timebomb
1401                 and version server checking.
1402
1403 Sun Jul  7 15:14:43 1996  Ezra Peisach  <epeisach@kangaroo.mit.edu>
1404
1405         * get_creds.c: (krb5_get_credentials_val_renew_core) Combine
1406                 common internals needed from krb5_get_credentials_validate()
1407                 and used by new function krb5_get_credentials_renew()
1408
1409         * gc_frm_kdc.c (krb5_get_cred_from_kdc_renew): A wrapper that
1410                 passes KDC_OPT_RENEW to the static
1411                 krb5_get_cred_from_kdc_opt so that kinit can use it.
1412
1413
1414 Mon Jun 24 09:45:04 1996  Theodore Ts'o  <tytso@rsts-11.mit.edu>
1415
1416         * bld_princ.c (krb5_build_principal_va): Change const to
1417                 krb5_const, so that it works on compilers that don't
1418                 support const.
1419
1420 Mon Jun 17 20:23:48 1996  Ezra Peisach  <epeisach@kangaroo.mit.edu>
1421
1422         * str_conv.c (krb5_string_to_timestamp): Ensure that all fields of
1423                 the timestamp are filled in if strptime does not fill in
1424                 unspecified fields.
1425
1426 Wed Jun 12 01:10:09 1996  Theodore Ts'o  <tytso@rsts-11.mit.edu>
1427
1428         * sendauth.c (krb5_sendauth): If ECCONABORTED is not defined, try
1429                 using the Winsock equivalent (WSAECONNABORTED).
1430
1431 Mon Jun 10 21:47:21 1996  Theodore Ts'o  <tytso@rsts-11.mit.edu>
1432
1433         * parse.c (krb5_parse_name): Change use of _WINDOWS to _MSDOS, and
1434                 add check for _WIN32.
1435
1436 Thu Jun  6 00:06:18 1996  Theodore Y. Ts'o  <tytso@mit.edu>
1437
1438         * get_creds.c (krb5_get_credentials_core): A static function must
1439                 not use the INTERFACE keyword.
1440
1441 Tue May 14 18:39:22 1996  Richard Basch  <basch@lehman.com>
1442
1443         * mk_req_ext.c mk_safe.c send_tgs.c:
1444                 set the length field of the krb5_checksum structure before
1445                 calling krb5_calculate_checksum.
1446
1447         * str_conv.c: replaced sha-des3 cksum with hmac-sha.
1448
1449 Tue May 14 02:53:42 1996  Theodore Y. Ts'o  <tytso@mit.edu>
1450
1451         * ser_ctx.c (krb5_context_size, krb5_context_externalize,
1452                 krb5_context_internalize): Add missing fields from the
1453                 serialized context: clockskew, default_kdc_req_sumtype,
1454                 default_ap_req_sumtype, default_safe_sumtype,
1455                 kdc_default_options, library_options, profile_secure,
1456                 fcc_default_format, scc_default_format.
1457
1458         * ser_actx.c (krb5_auth_context_size, krb5_auth_context_externalize,
1459                 krb5_auth_context_internalize): Serialize the two fields
1460                 req_cksumtype and safe_cksumtype, instead of the one
1461                 cksumtype field.
1462
1463         * mk_safe.c (krb_mk_safe): Use safe_cksumtype instead of cksumtype
1464                 in the auth context.
1465
1466         * mk_req_ext.c (krb5_mk_req_extended): Use req_cksumtype instead
1467                 of cksumtype in the auth context.
1468
1469         * init_ctx.c (krb5_init_context): Add support for new profile
1470                 relations libdefaults/tkt_lifetime,
1471                 libdefaults/kdc_req_checksum_type,
1472                 libdefaults/ap_req_cksumtype,
1473                 libdefaults/safe_checksumtype, and
1474                 libdefaults/kdc_default_options.
1475
1476         * auth_con.h: Remove old cksumtype element, and replace it with
1477                 req_cksumtype and safe_cksumtype.
1478
1479         * auth_con.c (krb5_auth_con_init): Initialize the req_cksumtype
1480                 and safe_cksumtype from the context's default
1481                 req_cksumtype and safe_cksumtype.
1482                 (krb5_auth_con_set_req_cksumtype,
1483                 krb5_auth_con_set_safe_cksumtype): New functions, to
1484                 replace old krb5_auth_con_setcksumtype
1485         
1486 Fri May 10 18:48:38 EDT 1996  Richard Basch  <basch@lehman.com>
1487
1488         * init_ctx.c: Removed des3-cbc-md5 default support
1489
1490 Fri May 10 02:51:17 1996  Richard Basch  <basch@lehman.com>
1491
1492         * str_conv.c: changes des3-md5 to des3-sha & added sha cksum types
1493
1494 Sun May  5 09:46:18 1996  Ezra Peisach  (epeisach@kangaroo.mit.edu)
1495
1496         * preauth.c: Add casts and const keywords as needed.
1497
1498 Fri May  3 00:15:18 1996  Mark Eichin  <eichin@cygnus.com>
1499
1500         * get_creds.c (krb5_get_credentials_core): new function. Common
1501         part of krb5_get_credentials and krb5_get_credentials_validate.
1502         Some formerly local variables are now arguments.
1503         (krb5_get_credentials): same as before, but calls _core to do some
1504         of the work.
1505         (krb5_get_credentials_validate): uses
1506         krb5_get_cred_from_kdc_validate and only stores the returned
1507         credential in the cache, instead of storing all of them.
1508
1509 Thu May  2 22:48:56 1996  Mark Eichin  <eichin@cygnus.com>
1510
1511         * gc_frm_kdc.c (krb5_get_cred_from_kdc_opt): new function. Same
1512         body as krb5_get_cred_from_kdc, but takes one new argument,
1513         kdcopts, and combines it with the other kdc options when calling
1514         krb5_get_cred_via_tkt. This is static and only called by
1515         (krb5_get_cred_from_kdc): a wrapper that provides the same
1516         function it did before, and
1517         (krb5_get_cred_from_kdc_validate): a wrapper that passes
1518         KDC_OPT_VALIDATE, so that kinit can use it.
1519         We'll probably need another one for renewing tickets as well.
1520
1521         * rd_req_dec.c (krb5_rd_req_decoded_opt): new function. Same body
1522         as krb5_rd_req_decoded, but takes one new argument,
1523         check_valid_flag, to determine whether or not to check if the
1524         "invalid flag" is set in the ticket. Also made static, so that it
1525         is only called via:
1526         (krb5_rd_req_decoded): wrapper for krb5_rd_req_decoded_opt that
1527         specifies the "invalid flag" gets checked, and
1528         (krb5_rd_req_decoded_anyflag): wrapper for krb5_rd_req_decoded_opt
1529         that specifies that the "invalid flag" doesn't get checked. (This
1530         version is only called from kdc_util.c:kdc_process_tgs_req.)
1531
1532 Wed May  1 14:30:29 1996  Richard Basch  <basch@lehman.com>
1533
1534         * srv_rcache.c (krb5_get_server_rcache): include the uid in the
1535                 default server replay cachename, for systems with geteuid.
1536
1537         * configure.in: test if the system has geteuid()
1538
1539 Wed May  1 02:26:53 1996  Mark Eichin  <eichin@cygnus.com>
1540
1541         * str_conv.c (krb5_string_to_timestamp): double check that
1542         strptime at least parsed *some* of the string, avoid degenerate
1543         cases from GNU libc strptime.
1544
1545 Tue Apr 30 18:19:01 1996  Ken Raeburn  <raeburn@cygnus.com>
1546
1547         * t_ser.c (stuff): New variable.
1548         (ser_acontext_test, ser_eblock_test, ser_cksum_test): Use it,
1549         instead of assuming it's valid to treat &FUNCTION as a data
1550         pointer.
1551
1552         * conv_princ.c (sconv_list): Now const.
1553         (krb5_*_conv_principal): Use pointer to const for it.
1554
1555         Tue Apr 23 19:39:59 1996  Mark Eichin  <eichin@cygnus.com>
1556
1557         * get_creds.c (krb5_get_credentials): this isn't the kernel, so
1558         don't return negative errno values.
1559
1560 Sat Apr 27 19:14:21 1996  Richard Basch  <basch@lehman.com>
1561
1562         * fwd_tgt.c (krb5_fwd_tgt_creds): fixed a possible null dereference.
1563
1564 Wed Apr 17 14:22:10 1996  Theodore Y. Ts'o  <tytso@mit.edu>
1565
1566         * conv_princ.c: Added ftp and ecat to the list of services which
1567                 should be converted.  This really ought to be something
1568                 that's configurable in the profile...
1569
1570 Thu Apr 11 21:30:23 1996  Theodore Y. Ts'o  <tytso@dcl>
1571
1572         * init_ctx.c (krb5_init_context): On a Macintosh, turn on
1573                 kdc_timesync and use the v4 credentials cache by default.
1574
1575         * get_in_tkt.c (stash_as_reply, verify_as_reply): Move time offset
1576                 code from stash_as_reply to verify_as_reply, and fix it so
1577                 that it actually works.
1578
1579 Wed Apr  3 16:04:36 1996  Theodore Y. Ts'o  <tytso@dcl>
1580
1581         * rd_req_dec.c (krb5_rd_req_decoded): Move code which
1582                 validated the ticket times to krb5_validate_times.
1583
1584         * valid_times.c (krb5_validate_times): New function which
1585                 determines whether or not the ticket times are valid.
1586
1587         * mk_req_ext.c (krb5_mk_req_extended): Call krb5_validate_time()
1588                 to determine whether or not the ticket in passed-in
1589                 credentials is valid.  If it isn't, return an error right
1590                 away. 
1591
1592 Wed Mar 27 17:05:47 1996  Richard Basch  <basch@lehman.com>
1593
1594         * in_tkt_ktb.c (keytab_keyproc): Do not check to see that the
1595         enctype of the key is identical; there are several equivalent
1596         DES enctypes.
1597
1598         * in_tkt_ktb.c (krb5_get_in_tkt_with_keytab): Removed the fancy
1599         logic to only request the keytypes that correspond to those in
1600         the keytab.  There were too many fencepost conditions that could
1601         get you into trouble.  Either it should be there and *fully*
1602         functional, or not in there at all.  Besides, there are too many
1603         other components in Kerberos that expect the end-service to know
1604         all its keys that this sanity check is overkill.
1605
1606 Tue Mar 26 14:45:03 1996  Richard Basch  <basch@lehman.com>
1607
1608         * conv_princ.c: added "imap" service to the conversion list as
1609         requiring domain conversion for the instance.  (imap/<host> is used
1610         by some of the new imap mail implementations)
1611
1612 Sun Mar 24 01:34:14 1996  Sam Hartman  <hartmans@tertius.mit.edu>
1613
1614         * send_tgs.c (krb5_send_tgs_basic): You want to setup the eblock
1615         used for the authenticator using the in_cred->keyblock, *not*
1616         request.ticket.enc_part.enctype.  Under a multi-enctype system,
1617         the session key may be different from the ticket key.
1618
1619 Wed Mar 20 23:00:59 1996  Theodore Y. Ts'o  <tytso@dcl>
1620
1621         * walk_rtree.c (krb5_walk_realm_tree): Fix 16bit vs. 32bit error.
1622                 (cap_code should been a krb5_error_code, not an int!)
1623
1624         * mk_cred.c (krb5_mk_ncred_basic): Fix windows lint flame.
1625
1626         * get_in_tkt.c (krb5_get_in_tkt): Fix 16bit vs. 32bit error.
1627                 (do_more should not have been an int!)
1628
1629 Tue Mar 19 13:03:26 1996  Richard Basch  <basch@lehman.com>
1630
1631         * in_tkt_ktb.c (krb5_get_in_tkt_with_keytab):
1632         Only request keytypes that correspond to those in the keytab.
1633
1634 Mon Mar 18 21:49:39 1996  Ezra Peisach  <epeisach@kangaroo.mit.edu>
1635
1636         * configure.in: Add KRB5_RUN_FLAGS
1637
1638         * Makefile.in: Use runtime flags.
1639
1640 Sun Mar 17 20:32:08 1996  Ezra Peisach  <epeisach@dumpster.rose.brandeis.edu>
1641
1642         * configure.in: Add USE_ANAME, USE_KRB5_LIBRARY, KRB5_LIBRARIES so
1643                 that Makefile does not have to know build tree layout.
1644
1645         * Makefile.in: Rework to be consistant with configure defines so
1646                 that configure can specify other needed libraries.
1647
1648 Sun Mar 17 02:10:19 1996  Mark W. Eichin  <eichin@cygnus.com>
1649
1650         * copy_addrs.c (krb5_copy_addr): make non-static so we can use it
1651         in mk_cred.
1652         * mk_cred.c (krb5_mk_ncred_basic): copy local_addr and remote_addr
1653         instead of just aliasing them, so we can safely free them ourselves.
1654
1655 Fri Mar 15 14:29:00 1996  Richard Basch  <basch@lehman.com>
1656
1657         * in_tkt_ktb.c: Close the keytab if we opened it, not if the
1658         caller opened it.
1659
1660 Wed Mar 13 17:31:30 1996  Ken Raeburn  <raeburn@cygnus.com>
1661
1662         * configure.in: Use AC_HEADER_STDARG.
1663
1664 Mon Mar 11 11:15:26 1996  Ezra Peisach  <epeisach@kangaroo.mit.edu>
1665
1666         * str_conv.c (krb5_timestamp_to_string): Handle statement not
1667                 reached warning.
1668
1669         * ser_addr.c (krb5_address_internalize): Add magic numbers
1670
1671 Thu Feb 29 11:49:38 1996  Theodore Y. Ts'o  <tytso@dcl>
1672
1673         * fwd_tgt.c (NEED_SOCKETS): Use NEED_SOCKETS instead of #including
1674                 <netdb.h>
1675
1676 Sat Feb 24 16:27:54 1996  Theodore Y. Ts'o  <tytso@dcl>
1677
1678         * gc_via_tkt.c (krb5_get_cred_via_tkt): Fix memory leak; free
1679                 enctypes after use.
1680
1681 Thu Jan 25 01:35:52 1996  Sam Hartman  <hartmans@tertius.mit.edu>
1682
1683         * rd_req_dec.c (krb5_rd_req_decrypt_tkt_part): Remove outdated
1684         comment about mapping etype to ktype.
1685
1686         * gc_via_tkt.c (krb5_get_cred_via_tkt): If the keyblock.enctype is
1687         non-null in in_cred, then request that particular key.
1688
1689 Wed Jan 24 21:48:53 1996  Sam Hartman  <hartmans@tertius.mit.edu>
1690
1691         * get_creds.c (krb5_get_credentials): Only match against enctype
1692         if it is non-null in increds.
1693
1694 Sun Jan 21 23:32:53 1996  Tom Yu  <tlyu@dragons-lair.MIT.EDU>
1695
1696         * gc_via_tkt.c (krb5_kdcrep2creds): Set is_skey so get_creds won't
1697                 break trying to match is_skey in the ccache.  This way we
1698                 won't end up with many copies of user-to-user tickets.
1699
1700 Fri Jan 19 23:16:17 1996  Ezra Peisach  <epeisach@kangaroo.mit.edu>
1701
1702         * mk_req.c (krb5_mk_req): krb5_get_credentials does not take
1703                 default_kdc_options. 
1704
1705         * sendauth.c (krb5_sendauth): krb5_get_credentials does not take
1706                 default_kdc_options. 
1707
1708 Wed Jan 10 21:01:36 1996  Theodore Y. Ts'o  <tytso@dcl>
1709
1710         * init_ctx.c (krb5_init_context): Added checking of profile for
1711                 DCE compatability options (ccache type, and checksum type).
1712
1713         * fwd_tgt.c (krb5_fwd_tgt_creds): Initialize addrs to 0 so that we
1714                 don't try to free stack garbage on an error.
1715
1716         * krbconfig.c, Makefile.in: Removed krbconfig.c; it contained
1717                 global variables which are no longer used.
1718
1719         * recvauth.c: Removed the global extern of
1720                 krb5_kdc_default_options, which wasn't being used anyway.
1721
1722         * mk_req.c (krb5_mk_req): Replace use of krb5_kdc_default_options
1723                 with context->kdc_default_options.
1724
1725         * gc_frm_kdc.c: Remove the global extern of krb5_kdc_req_sumtype,
1726                 which wasn't being used anymore anyway.
1727
1728         * send_tgs.c (krb5_send_tgs_basic): Remove use of the global
1729                 variable krb5_kdc_req_sumtype, and use the kdc_req_sumtype
1730                 in the context structure instead.
1731
1732         * walk_rtree.c (krb5_walk_realm_tree): Applied patch submitted by
1733                 Doug Engbert, so that the configurable authentication
1734                 patch takes into account the null entry at the end of the
1735                 list.
1736
1737 Tue Jan  9 22:04:09 1996  Theodore Y. Ts'o  <tytso@dcl>
1738
1739         * fwd_tgt.c (krb5_fwd_tgt_creds): New function which handles all
1740                 of the dirty work of forwarding TGT's.
1741
1742         * rd_cred.c (krb5_rd_cred_basic): Clean up memory allocation
1743                 discpline to remove memory leaks.
1744
1745         * mk_cred.c (krb5_mk_ncred_basic, krb5_mk_ncred, krb5_mk_1cred):
1746                 Clean up memory allocation discpline to remove memory
1747                 leaks.
1748
1749         * init_ctx.c (krb5_get_tgs_ktypes): Clean up parsing of the etype
1750                 list.  Don't overrun the string containing the etype list.
1751
1752 Wed Jan  3 21:32:59 1996  Theodore Y. Ts'o  <tytso@dcl>
1753
1754         * rd_cred.c (krb5_rd_cred_basic): When the keyblock is NULL,
1755                 assume we're being called from the gssapi code, which
1756                 doesn't have access to the sender or receive address
1757                 information, don't check the sender address, since it
1758                 won't be available.
1759
1760         * rd_cred.c (decrypt_credencdata): When calling krb5_rd_credd(),
1761                 if the keyblock is null, just copy the encoded structure
1762                 from the "ciphertext" part of the structure and decode it.
1763
1764         * mk_cred.c (encrypt_credencpart):  When calling krb5_mk_cred(), if
1765                 the keyblock is NULL, don't encrypt it; just encode it and
1766                 leave it in the ciphertext area of the structure.
1767
1768 Thu Dec 21 18:47:54 1995  Theodore Y. Ts'o  <tytso@dcl>
1769
1770         * rd_rep.c (krb5_rd_rep): Change use of
1771                 KRB5_SENDAUTH_MUTUAL_FAILED to KRB5_MUTUAL_FAILED.
1772
1773 Tue Dec 19 17:15:40 1995  Theodore Y. Ts'o  <tytso@dcl>
1774
1775         * rd_cred.c (krb5_rd_cred_basic): Missing parenthesis meant that
1776                 wrong number of bytes was being allocated.
1777
1778 Sun Dec  3 11:49:09 1995  Ezra Peisach  <epeisach@kangaroo.mit.edu>
1779
1780         * Makefile.in (SRCS/OBJS): Move compat_recv.c to krb5util library.
1781
1782 Fri Dec  1 17:04:43 1995  Theodore Y. Ts'o  <tytso@dcl>
1783
1784         * recvauth.c (krb5_recvauth): Initialize rcache to zero, so that
1785                 on cleanup we don't try to free stack garbage.
1786
1787 Sun Nov 26 19:31:18 1995  Tom Yu  <tlyu@dragons-lair.MIT.EDU>
1788
1789         * preauth.c: Ultrix is broken.  Prototype obtain_enc_ts_padata()
1790                 and process_pw_salt() explicitly rather than using the
1791                 typedef in k5-int.h becaus that typedef is to a function
1792                 pointer now.
1793
1794 Fri Nov 17 22:35:52 1995  Theodore Y. Ts'o  <tytso@dcl>
1795
1796         * get_in_tkt.c (decrypt_as_reply): 
1797         * preauth.c (process_pw_salt): When fetching the key to decrypting
1798                 the encrypted kdc reply, use the etype associated with the
1799                 etype reply, not the etype associated with the included
1800                 ticket. 
1801
1802         * encode_kdc.c: Remove eblock argument from krb5_encode_kdc_rep;
1803                 set the eblock type from the client_key's enctype.
1804
1805 Thu Nov 16 20:29:17 1995  Ezra Peisach  <epeisach@kangaroo.mit.edu>
1806
1807         * srv_rcache.c (krb5_get_server_rcache): Use krb5_rc_default_type
1808                 instead of assuming default rcache type is "dfl".
1809
1810 Mon Nov 13 14:40:05 1995    <tytso@rsts-11.mit.edu>
1811
1812         * walk_rtree.c (krb5_walk_realm_tree): Added ANL changes to
1813                 support configuration authentication paths.
1814
1815 Mon Nov 13 12:57:12 1995  Theodore Y. Ts'o  <tytso@dcl>
1816
1817         * preauth.c (krb5_process_padata): Added generalized processing
1818                 for preauth information which is returned by the KDC.
1819                 This should be general enough to support the AFS3_SALT
1820                 preauth type, the SNK4 preauth type, and the public-key
1821                 mods to Kerberos.
1822         (process_pw_salt): New function for processing the KRB5_PW_SALT
1823                 preauthentication type.
1824
1825         * get_in_tkt.c (decrypt_as_reply): Removed temporary kludge for
1826                 processing the PW_SALT preauth type; that's now done in
1827                 preauth.c
1828         (krb5_get_in_tkt): Call krb5_process_padata with new arguments so
1829                 that the preauth code can set the decryption_key if
1830                 necessary. 
1831                 
1832 Thu Nov 09 17:05:57 1995  Chris Provenzano (proven@mit.edu)
1833
1834         * in_tkt_pwd.c : Remove krb5_enctype from krb5_string_to_key() args.
1835
1836 Thu Nov  9 00:02:43 1995  Theodore Y. Ts'o  <tytso@dcl>
1837
1838         * get_in_tkt.c (krb5_get_in_tkt): Remove the etype_info argument
1839                 from the call to krb5_obtain_padata.
1840
1841         * preauth.c (krb5_obtain_padata): Use the PADATA_ETYPE_INFO
1842                 preauth, if it exists, to determine which salt type to use
1843                 when encrypting the preauthentication data.  Remove the
1844                 etype_info argument.
1845
1846 Wed Nov  8 02:50:59 1995  Theodore Y. Ts'o  <tytso@dcl>
1847
1848         * krbconfig.c: Removed the krb5_clockskew variable.
1849
1850         * srv_rcache.c (krb5_get_server_rcache): 
1851         * rd_safe.c (krb5_rd_safe): 
1852         * rd_req_dec.c (krb5_rd_req_decoded): 
1853         * rd_priv.c (krb5_rd_priv): 
1854         * rd_cred.c (krb5_rd_cred): 
1855         * gc_via_tkt.c (krb5_get_cred_via_tkt): 
1856         * get_in_tkt.c (verify_as_reply): Replace use of krb5_clockskew
1857                 with context->clockskew.
1858
1859         * encrypt_tk.c (cleanup_scratch): Changed interface to no longer
1860                 require an eblock; we can use our own and figure out the
1861                 enctype from the passed-in key.
1862
1863         * get_in_tkt.c (krb5_get_in_tkt): Added calls to
1864                 krb5_obtain_padata(). 
1865
1866         * preauth.c: Completely restructured file to support
1867                 preauthentication. 
1868                 
1869
1870 Fri Oct 27 22:15:33 1995  Theodore Y. Ts'o  <tytso@dcl>
1871
1872         * get_in_tkt.c (krb5_get_in_tkt): Extensive reworking of the
1873                 structure of this file to make it possible to support
1874                 preauthentication.
1875
1876 Mon Oct 23 17:08:59 1995  Theodore Y. Ts'o  <tytso@dcl>
1877
1878         * in_tkt_pwd.c (krb5_get_in_tkt_with_password): Fix to properly
1879                 malloc password buffer.
1880
1881 Mon Oct 23 11:09:56 1995  Ezra Peisach  <epeisach@kangaroo.mit.edu>
1882
1883         * rd_req_dec.c (krb5_rd_req_decoded): For heirarchal cross-realm,
1884                 set the length after initializing string.
1885
1886         * rd_req.c (krb5_rd_req): If a new auth_context is created
1887                 and then there is an error, make sure return pointer is not
1888                 looking at freed memory.
1889
1890 Fri Oct  6 22:04:42 1995  Theodore Y. Ts'o  <tytso@dcl>
1891
1892         * Makefile.in: Remove ##DOS!include of config/windows.in.
1893                 config/windows.in is now included by wconfig.
1894
1895 Fri Sep 29 00:08:53 1995  Theodore Y. Ts'o  <tytso@dcl>
1896
1897         * gc_via_tkt.c (krb5_get_cred_via_tkt): Only check the returned
1898                 starttime to make sure it matches the requested starttime
1899                 if we requested a postdated ticket.
1900
1901 Thu Sep 28 22:58:53 1995  Theodore Y. Ts'o  <tytso@dcl>
1902
1903         * conv_princ.c (krb5_425_conv_principal): Only convert instances
1904                 which don't have a '.' in them.  If they have a '.',
1905                 assume that they are fully qualified already.
1906
1907 Thu Sep 28 12:00:00 1995  John Rivlin <jrivlin@fusion.com)
1908
1909         * gc_via_tkt.c: Cleaned up corrupt ticket error testing to 
1910                 make it more debugable and I think work around a compiler
1911                 bug.
1912
1913 Mon Sep 25 16:57:59 1995  Theodore Y. Ts'o  <tytso@dcl>
1914
1915         * Makefile.in: Removed "foo:: foo-$(WHAT)" lines from the
1916                 Makefile. 
1917
1918 Wed Sep 13 10:58:20 1995 Keith Vetter (keithv@fusion.com)
1919
1920         * get_in_t.c: removed unused variable.
1921         * rd_cred.c: removed INTERFACE keyword.
1922         * ser_auth.c: passing int32 where a size_t is wanted.
1923         * ser_ctx.c: 16/32 bit int size mismatch.
1924
1925 Sun Sep 17 23:41:19 1995  Ezra Peisach  <epeisach@kangaroo.mit.edu>
1926
1927         * rd_safe.c: Fix typo error.
1928
1929 Sat Sep 16 01:23:14 1995  Theodore Y. Ts'o  <tytso@dcl>
1930
1931         * sendauth.c (krb5_sendauth): Make sure the scratch credentials
1932                 structure may have possible been used be freed..
1933
1934         * rd_safe.c (krb5_rd_safe_basic): Fall through to the cleanup code
1935                 at the end, to make sure the decoded message in message is
1936                 freed.
1937
1938         * rd_req_dec.c (krb5_rd_req_decoded): Use krb5_copy_keyblock to
1939                 copy authent->subkey to auth_context->remote_subkey.
1940                 Keeping them separate avoids aliasing problems.
1941
1942         * mk_req_ext.c (krb5_generate_authenticator): Fix memory leak.
1943                 Don't bash authent->subkey with key after carefully
1944                 copying it using krb5_copy_keyblock!
1945
1946         * recvauth.c (krb5_recvauth): krb5_get_server_rcache() already
1947                 opens the rcache; doing it again merely causes a memory leak.
1948
1949 Fri Sep 15 17:20:08 1995  Theodore Y. Ts'o  <tytso@dcl>
1950
1951         * gen_subkey.c (krb5_generate_subkey): Eliminate memory leak.
1952                 krb5_init_random_key() does its own allocation of the
1953                 keyblock.
1954
1955         * gc_via_tkt.c (krb5_kdcrep2creds): Fix memory leak.
1956
1957         * srv_rcache.c (krb5_get_server_rcache): Fix memory leak.
1958
1959         * rd_safe.c (krb5_rd_safe_basic): Fix memory leak.
1960
1961 Tue Sep 12 12:40:30 1995  Ezra Peisach  <epeisach@kangaroo.mit.edu>
1962
1963         * t_ser.c (ser_cksum_test): Work around an optimizer bug unser
1964                 OSF/1 and gcc.
1965
1966 Sun Sep 10 12:00:00 1995        James Mattly    (mattly@fusion.com)
1967
1968         * gen_seqnum.c:  change usage of krb5_crypto_us_timeofday to krb5_timeofday
1969         * get_in_tkt.c:  change usage of  krb5_crypto_us_timeofday to krb5_timeofday
1970         * mk_priv.c: change usage of krb5_crypto_us_timeofday to krb5_timeofday
1971         * mk_req_ext.c: change usage of krb5_crypto_us_timeofday to krb5_timeofday
1972         * send_tgs.c: change usage of krb5_timeofday over to krb5_crypto_us_timeofday
1973
1974 Wed Sep 06 14:20:57 1995   Chris Provenzano (proven@mit.edu)
1975
1976         * auth_con.c, decrypt_tk.c, encode_kdc.c, encrypt_tk.c,
1977         * gc_frm_kdc.c, gen_seqnum.c, get_creds.c, get_in_tkt.c,
1978         * in_tkt_ktb.c, in_tkt_pwd.c, in_tkt_sky.c, init_ctx.c,
1979         * kdc_rep_dc.c, mk_cred.c, mk_priv.c, mk_rep.c, mk_req._ext.c,
1980         * preauth.c, rd_cred.c, rd_priv.c, rd_rep.c, rd_req_dec.c,
1981         * send_tgs.c, sendauth.c, ser_actx.c, ser_ctx.c, ser_eblk.c,
1982         * ser_key.c, t_ser.c : s/keytype/enctype/g, s/KEYTYPE/ENCTYPE/g
1983
1984 Wed Sept 6 12:00:00 EDT 1995    James Mattly    (mattly@fusion.com)
1985
1986         * get_in_tkt.c:  change usage of krb5_timeofday to krb5_crypto_us_timeofday
1987         * mk_req_ext.c: change usage of timeofday
1988         * parse.c:  disabled a usage of exit for macintosh
1989         * send_tgs.c: change usage of krb5_timeofday over to
1990                 krb5_crypto_us_timeofday
1991         * unparse.c: include <stdio.h>
1992
1993
1994 Tue Sep 05 22:10:34 1995   Chris Provenzano (proven@mit.edu)
1995
1996         * decode_kdc.c, decrypt_tk.c, encode_kdc.c, encrypt_tk.c, gc_frm_kdc.c
1997         * gc_via_tkt.c, get_in_tkt.c, in_tkt_ktb.c, in_tkt_pwd.c, in_tkt_sky.c
1998         * init_ctx.c, kdc_rep_dc.c, mk_cred.c, mk_priv.c, mk_rep.c
1999         * mk_req_ext.c, rd_cred.c, rd_priv.c, rd_rep.c, rd_req_dec.c,
2000         * send_tgs.c, ser_ctx.c, ser_eblk.c, ser_key.c, t_ser.c: 
2001                 Remove krb5_enctype references, and replace with
2002                 krb5_keytype where appropriate
2003
2004 Fri Sep  1 20:03:41 1995  Theodore Y. Ts'o  <tytso@dcl>
2005
2006         * get_in_tkt.c (krb5_get_in_tkt): If kdc_settime is enabled, then
2007                 set the time_offset fields from the returned ticket's
2008                 authtime value.
2009
2010         * init_ctx.c (krb5_init_context): Initialize new fields in
2011                 krb5_context (clockskew, kdc_req_sumtype, and
2012                 kdc_default_options).
2013
2014         * gc_via_tkt.c (krb5_get_cred_via_tkt): Perform the necessary
2015                 sanity checking on the KDC response to make sure we detect
2016                 tampering.
2017   
2018         * send_tgs.c (krb5_send_tgs): Set the expected nonce in the
2019                 response structure.
2020
2021         * krbconfig.c: Set the default checksum to use MD5
2022
2023 Fri Sep 1 11:16:43 EDT 1995     Paul Park       (pjpark@mit.edu)
2024         * ser_ctx.c - Add handling of new time offset fields in the os_context.
2025
2026
2027 Tue Aug 29 14:14:26 EDT 1995    Paul Park       (pjpark@mit.edu)
2028         * Makefile.in, .Sanitize, ser_{actx,adata,addr,auth,cksum,ctx,eblk,key,
2029                 princ}.c, serialize.c, t_ser.c - Add serialization operations
2030                 for data structures required to serialize krb5_context, krb5_
2031                 auth_context, krb5_encrypt_block and krb5_principal.
2032         * auth_con.h - Add magic number.
2033         * auth_con.c - Add static routine to copy an address and use this
2034                 instead of the other code.  Set the magic number when initing
2035                 an auth_context.  Use krb5_free_address to release an address.
2036         * init_ctx.c - Free the allocated serializers when releasing context.
2037         * rd_rep.c - Copy the keyblock from the message instead of setting
2038                 a pointer into it.
2039
2040 Thu Aug 24 18:55:50 1995  Theodore Y. Ts'o  <tytso@dcl>
2041
2042         * .Sanitize: Update file list.
2043
2044 Mon Aug  7 18:54:35 1995  Theodore Y. Ts'o  <tytso@dcl>
2045
2046         * in_tkt_ktb.c (keytab_keyproc): If there is an error looking up
2047                 the key, make sure the keytab is closed as part of the
2048                 cleanup. 
2049
2050 Fri Aug  4 22:04:08 1995  Tom Yu  <tlyu@dragons-lair.MIT.EDU>
2051
2052         * conv_princ.c: Add braces to initializer to shut up gcc -Wall
2053
2054 Fri Jul 7 16:31:06 EDT 1995     Paul Park       (pjpark@mit.edu)
2055         * Makefile.in - Find com_err in TOPLIBD.
2056         * rd_safe.c - Use checksum verifier instead of doing it manually.
2057
2058 Thu Jul  6 17:31:40 1995  Tom Yu  <tlyu@lothlorien.MIT.EDU>
2059
2060         * rd_safe.c (krb5_rd_safe_basic): Pass context to os_localaddr.
2061
2062         * rd_priv.c (krb5_rd_priv_basic): Pass context to os_localaddr.
2063
2064         * rd_cred.c (krb5_rd_cred_basic): Pass context to os_localaddr.
2065
2066         * get_in_tkt.c (krb5_get_in_tkt): Pass context to os_localaddr.
2067
2068 Wed July  5 15:52:31 1995  James Mattly  <mattly@fusion.com>
2069         * added condition for _MACINTOSH
2070
2071 Sun Jul  2 18:59:53 1995  Sam Hartman  <hartmans@tertius.mit.edu>
2072
2073         * recvauth.c (krb5_recvauth): recvauth should send an error reply
2074         if problem is not zero. Removed if that caused it to only send a
2075         reply on success.
2076
2077 Fri Jun 16 22:11:21 1995  Theodore Y. Ts'o  (tytso@dcl)
2078
2079         * get_in_tkt.c (krb5_get_in_tkt): Allow the credentials cache
2080                 argument to be optional; allow it to be NULL, meaning that
2081                 the credentials shouldn't be stored in a credentials cache.
2082
2083 Mon Jun 12 16:49:42 1995  Chris Provenzano (proven@mit.edu)
2084
2085         A couple bug reports/patches from Ed Phillips (flaregun@udel.edu)
2086         * in_tkt_ktb.c (keytab_keyproc()): Fix memory leak. 
2087         * recvauth.c (krb5_recvauth()): Don't open a new rcache if
2088                 the auth_context already has one.
2089         * auth_con.c (krb5_auth_con_free()): Close rcache is the
2090                 auth_context has one set.
2091         * auth_con.c (krb5_auth_con_getrcache()): Return pointer
2092                 to the rcache set in the auth_context.
2093
2094 Sun Jun 11 12:31:39 1995  Ezra Peisach  (epeisach@kangaroo.mit.edu)
2095
2096         * auth_con.c (krb5_auth_con_init): Zero newly allocated
2097                 krb5_auth_context. (Fixed error in redefinitions).
2098
2099 Sat Jun 10 23:05:51 1995  Tom Yu  (tlyu@dragons-lair)
2100
2101         * auth_con.c, compat_recv.c, mk_cred.c, mk_priv.c, mk_rep.c,
2102           mk_req.c, mk_req_ext.c, mk_safe.c, rd_cred.c, rd_priv.c,
2103           rd_rep.c, rd_req.c rd_req_dec.c, rd_safe.c, recvauth.c,
2104           sendauth.c: krb5_auth_context redefinitions
2105
2106 Fri Jun  9 18:48:43 1995    <tytso@rsx-11.mit.edu>
2107
2108         * rd_req_dec.c (krb5_rd_req_decoded): Fix -Wall nits
2109
2110         * configure.in: Remove standardized set of autoconf macros, which
2111                 are now handled by CONFIG_RULES.
2112
2113         * Makefile.in, faddr_ordr.c: Remove faddr_ordr.c; its function,
2114                 krb5_fulladdr_order, isn't used anywhere.
2115
2116 Fri Jun  9 02:42:54 1995  Tom Yu  (tlyu@dragons-lair)
2117
2118         * rd_cred.c (krb5_rd_cred_basic): fix typo (extra "context"
2119                 argument passed to krb5_xfree)
2120
2121 Thu Jun  8 22:48:27 1995  Theodore Y. Ts'o  <tytso@dcl>
2122
2123         * rd_cred.c (krb5_rd_cred_basic): Fix problem where the ticket
2124                 field was assigned with a krb5_data, which was then
2125                 immediately freed.
2126
2127 Thu Jun  8 16:06:44 1995    <tytso@rsx-11.mit.edu>
2128
2129         * compat_recv.c, auth_con.c, chk_trans.c, encrypt_tk.c,
2130                 gc_frm_kdc.c, gc_via_tkt.c, gen_seqnum.c, gen_subkey.c,
2131                 get_creds.c, get_in_tkt.c, in_tkt_ktb.c, in_tkt_pwd.c,
2132                 in_tkt_skey.c, init_ctx.c, kdc_rep_dc.c, mk_cred.c,
2133                 mk_error.c, mk_priv.c, mk_rep.c, mk_req.c, mk_req_ext.c,
2134                 mk_cred.c, mk_safe.c, parse.c, preauth.c, rd_cred.c,
2135                 rd_rep.c, rd_req.c, rd_req_dec.c, rd_safe.c, recvauth.c,
2136                 sendauth.c, send_tgs.c, srv_rcache.c, walk_rtree.c: Clean
2137                 up GCC -Wall flames.
2138
2139 Wed Jun  7 15:23:21 1995    <tytso@rsx-11.mit.edu>
2140
2141         * conv_princ.c (krb5_425_conv_principal): Remove old CONFIG_FILES
2142                 code. 
2143
2144 Fri May 26 10:18:28 1995 Keith Vetter (keithv@fusion.com)
2145
2146         * makefile.in: removed for the PC creating shared directory.
2147           (still bug with the '@SHARED_RULE@' line but I'm waiting
2148           on tytso for that since I don't want to break Unix).
2149
2150 Thu May 25 09:58:42 1995  Ezra Peisach  <epeisach@kangaroo.mit.edu>
2151
2152         * gc_via_tkt.c (krb5_kdcrep2creds): Fix syntax error in the
2153                 freeing of the keyblock.
2154
2155 Wed May 24 18:19:17 1995  Theodore Y. Ts'o  (tytso@dcl)
2156
2157         * Makefile.in, configure.in: Add rules for building shared library.
2158
2159         * gc_via_tkt.c (krb5_kdcrep2creds): On an error, free the keyblock.
2160
2161 Tue May 23 16:28:42 1995  Theodore Y. Ts'o  (tytso@dcl)
2162
2163         * gc_frm_kdc.c, preauth.c, t_kerb.c, t_walk_rtree.c, unparse.c:
2164                 Rearrange #include files so that krb5.h gets included
2165                 first, so that the debugging information can be more
2166                 efficiently collapsed since the type numbers will be the
2167                 same.
2168
2169 Sat May 20 14:01:16 1995  Ezra Peisach  <epeisach@kangaroo.mit.edu>
2170
2171         * rd_safe.c (krb5_rd_safe): Increment remote_seq_number if
2172                 KRB5_AUTH_CONTEXT_DO_SEQUENCE is set.
2173
2174 Thu May 11 22:42:30 1995  Ezra Peisach  <epeisach@kangaroo.mit.edu>
2175
2176         * rd_cred.c (krb5_rd_cred_basic): If address don't match, return
2177                 KRB5KRB_AP_ERR_BADADDR (add missing retval).
2178
2179 Thu May 11 18:30:21 1995  Chris Provenzano (proven@mit.edu)
2180
2181         * mk_cred.c (krb5_mk_cred()), mk_priv.c (krb5_mk_priv()),
2182         * mk_safe.c (krb5_mk_safe()), rd_cred.c (krb5_rd_cred()),
2183         * rd_priv.c (krb5_rd_prev()), rd_safe.c (krb5_rd_safe()):
2184                 Pass the contents pointer returned from krb5_make_fulladdr()
2185                 to free() not the address of the pointer.
2186
2187 Tue May  9 08:34:21 1995  Ezra Peisach  <epeisach@kangaroo.mit.edu>
2188
2189         * Makefile.in (clean): Remove t_kerb and t_kerb.o
2190
2191 Fri May  5 00:06:24 1995  Theodore Y. Ts'o  (tytso@dcl)
2192
2193         * conv_princ.c (krb5_425_conv_principal): Use new calling
2194                 convention of krb5_get_realm_domain, which is that it
2195                 returns the realm *without* the leading dot.
2196
2197                 Also use the profile code to look up individual instance
2198                 conversions using [realms]/<realm>/v4_instance_convert/<inst>
2199                 This allows special case handling of mit.edu and
2200                 lithium.lcs.mit.edu.
2201
2202         * t_kerb.c: New file for testing krb library functions.  Currently
2203                 only tests krb5_425_conv_principal.
2204
2205 Wed May 03 03:30:51 1995  Chris Provenzano (proven@mit.edu)
2206
2207         * recvauth.c, compat_recv.c (krb5_recvauth()): 
2208         * compat_recv.c (krb5_compat_recvauth()):
2209                 No longer needs the rc_type arg.
2210
2211 Tue May 02 19:29:18 1995  Chris Provenzano (proven@mit.edu)
2212
2213         * mk_cred.c (mk_cred()), mk_priv.c (mk_priv()), mk_safe.c (mk_safe()),
2214         * rd_cred.c (rd_cred()), rd_priv.c (rd_priv()), rd_safe.c (rd_safe()):
2215                 Don't call krb5_make_fulladdrs() if a port isn't specified.
2216
2217 Mon May 01 15:56:32 1995  Chris Provenzano (proven@mit.edu)
2218
2219         * auth_con.c (krb5_auth_con_free()) :
2220                 Free all the data associated with the auth_context.
2221
2222         * auth_con.c (krb5_auth_con_setkey()) : Removed.
2223         * mk_rep.c (mk_rep()),
2224                 The krb5_mk_rep() routine must always encode the data in
2225                 the keyblock of the ticket, not the subkey.
2226
2227         * cleanup.h, auth_con.c (krb5_auth_con_setports()) : Added.
2228         * auth_con.h, mk_cred.c (mk_cred()), mk_priv.c (mk_priv()),
2229         * mk_safe.c (mk_safe()), rd_cred.c (rd_cred()), 
2230         * rd_priv.c (rd_priv()), rd_safe.c (rd_safe()) :
2231                 Changes to auth_context to better support full addresses.
2232
2233 Sat Apr 29 00:09:40 1995  Theodore Y. Ts'o  <tytso@dcl>
2234
2235         * srv_rcache.c (krb5_get_server_rcache): Fix fencepost error which
2236                 caused an access beyond the allocated memory of piece->data.
2237
2238         * rd_priv.c (krb5_rd_priv_basic): Call krb5_free_priv_enc_part to free 
2239                 the entire privenc_msg structure.
2240
2241 Fri Apr 28 09:54:51 EDT 1995    Paul Park       (pjpark@mit.edu)
2242
2243         Move adm_rw.c from libkrb5 to libkadm.
2244
2245 Fri Apr 28 08:36:03 1995  Theodore Y. Ts'o  <tytso@lurch.mit.edu>
2246
2247         * init_ctx.c (krb5_free_context): Extra semicolon meant the etypes
2248                 field in the context was never being freed.
2249
2250 Fri Apr 28 01:44:51 1995  Chris Provenzano  (proven@mit.edu)
2251
2252         * send_tgs.c (krb5_send_tgs()), gc_via_tkt.c (krb5_get_cred_via_tkt()):
2253                 Removed krb5_cksumtype argument.
2254
2255 Thu Apr 27 21:36:01 1995  Chris Provenzano  (proven@mit.edu)
2256
2257         * auth_con.c (krb5_auth_con_getaddrs() and krb5_auth_con_getflags()):
2258                 Added for completeness.
2259         * mk_req_ext.c (krb5_mk_req_extended()) : Don't send the 
2260                 AP_OPTS_USE_SUBKEY option over the wire.
2261
2262 Thu Apr 27 17:40:20 1995 Keith Vetter (keithv@fusion.com)
2263
2264         * adm_rw.c, mk_cred.c, rd_cred.c:
2265            malloc on the PC must be size SIZE_T not int32.
2266         * adm_rw.c: krb5_free_adm_data second argument now a krb5_int32.
2267
2268 Thu Apr 27 16:33:17 EDT 1995    Paul Park       (pjpark@mit.edu)
2269
2270         * mk_priv.c     - Back out previous change which always put in
2271                           timestamp, regardless of DO_TIME setting and
2272                           instead, clear out the replaydata before calling
2273                           mk_priv_basic from mk_priv.
2274         * mk_safe.c     - Same replaydata fix.
2275
2276 Thu Apr 26 15:59:51 EDT 1995    Paul Park       (pjpark@mit.edu)
2277
2278         * Add adm_rw.c - routines to read and write commands from/to the
2279           administrative (kpasswd/kadmin) server.
2280
2281 Wed Apr 27 11:30:00 1995 Keith Vetter (keithv@fusion.com)
2282
2283         * init_ctx.c: krb5_init_context wasn't checking return values.
2284         * mk_req.c: deleted unused local variable.
2285
2286 Wed Apr 26 22:49:18 1995  Chris Provenzano  (proven@mit.edu)
2287
2288         * gc_via_tgt.c, and gc_2tgt.c : Removed.
2289         * Makefile.in, gc_via_tkt.c, gc_frm_kdc.c, and, int-proto.h : 
2290                 Replaced get_cred_via_tgt() and get_cred_via_2tgt()
2291                 with more general function get_cred_via_tkt().
2292
2293 Tue Apr 25 21:58:23 1995  Chris Provenzano  (proven@mit.edu)
2294
2295         * Makefile.in : Added gc_via_tkt.c and removed get_fcreds.c
2296         * auth_con.c (krb5_auth_con_setaddrs()) : Fixed so it allocates 
2297                 space and copies addresses, not just pointer.
2298         * mk_cred.c: Completely rewritten from sources donated by asriniva.
2299         * rd_cred.c: Completely rewritten from sources donated by asriniva.
2300         * mk_priv.c (krb5_mk_priv()), mk_safe.c (krb5_mk_safe()), 
2301           rd_priv.c (krb5_rd_priv()), and rd_safe (krb5_rd_safe()) : 
2302                 Try using a subkey before using the session key for encryption.
2303         * recvauth.c (krb5_recvauth()): Don't close the rcache on success.
2304
2305 Mon Apr 24 23:12:21 1995  Theodore Y. Ts'o  <tytso@dcl>
2306
2307         * Makefile.in, configure.in (t_walk_rtree): Add WITH_NETLIBS and
2308                 $(LIBS), so that t_walk_rtree can compile under solaris.
2309
2310 Mon Apr 24 17:09:36 1995  Ezra Peisach  <epeisach@kangaroo.mit.edu>
2311
2312         * parse.c (krb5_parse_name): Add magic number to new structure
2313
2314         * get_creds.c: Fix comments describing operation
2315
2316         * gc_frm_kdc.c: Fix comments describing operation
2317
2318         * copy_cksum.c (krb5_copy_checksum): Fix comment in file
2319
2320         * copy_addrs.c (krb5_append_addresses): ifdef out unused
2321                 krb5_append_addresses function. (no API or prototype
2322                 existed). 
2323
2324         * copy_data.c (krb5_copy_data): Initialize magic number
2325
2326         * init_ctx.c (krb5_init_context): If an error is returned from
2327                 krb5_set_default_in_tkt_etypes or krb5_os_init_context,
2328                 pass to caller instead of stack garbage.
2329
2330 Sat Apr 22 11:06:45 1995  Ezra Peisach  (epeisach@kangaroo.mit.edu)
2331
2332         * Makefile.in: t_walk_rtree needs libcrypto
2333
2334         * t_walk_rtree.c: error in checking for argument count
2335
2336 Thu Apr 20 16:23:23 1995  Theodore Y. Ts'o  (tytso@dcl)
2337
2338         * copy_addrs.c, copy_athctr.c, copy_auth.c, copy_cksum.c,
2339         copy_creds.c, copy_key.c, copy_princ.c, copy_tick.c,
2340         gc_2tgt.c, gc_frm_kdc.c, gc_via_tgt.c, get_creds.c,
2341         mk_req_ext.c: Unless HAVE_C_STRUCTURE_ASSIGNMENT is defined, use
2342                 memcpy to copy structures around, instead of using
2343                 structure assignments.  (Which aren't guaranteed to work
2344                 on some broken compilers.)
2345
2346         * mk_req.c (krb5_mk_req): Use krb5_sname_to_principal() in order
2347                 to create the service principal from the service and
2348                 hostname pair.  This allows for the host cannoncialization
2349                 to work correctly.
2350
2351         * mk_req_ext.c (krb5_mk_req_extended): Revamp checksum handling
2352                 code so that no checksum is performed in in_data is NULL,
2353                 and the special case handing of cksumtype == 0x8003 for
2354                 the GSSAPI library is handled correctly.
2355
2356 Wed Apr 19 13:39:34 1995  Ezra Peisach  <epeisach@kangaroo.mit.edu>
2357
2358         * init_ctx.c: (krb5_init_context) initialize context default
2359                 realm. (krb5_free_context) free default realm.
2360
2361 Fri Apr 14 15:05:51 1995    <tytso@rsx-11.mit.edu>
2362
2363         * sendauth.c (krb5_sendauth): initialize error return parameter
2364
2365         * copy_princ.c (krb5_copy_principal): Fix bug where
2366                 krb5_copy_principal can fail if it is asked to copy a
2367                 principal with a zero-length component on a system where
2368                 malloc(0) returns null. 
2369
2370 Thu Apr 13 15:49:16 1995 Keith Vetter (keithv@fusion.com)
2371
2372         * *.[ch]: removed unneeded INTERFACE from non-api functions.
2373
2374 Fri Mar 31 16:45:47 1995 Keith Vetter (keithv@fusion.com)
2375
2376         * krb5_get_in_tkt: changed error return value for when clocks
2377            are out of skew to be KRB5_KDCREP_SKEW.
2378
2379 Fri Mar 31 00:44:26 1995  Theodore Y. Ts'o  (tytso@dcl)
2380
2381         * rd_req.c (krb5_rd_req): Fix typo which caused new_keytab to not
2382                 get freed, causing a memory leak.
2383
2384 Thu Mar 30 15:49:27 1995 Keith Vetter (keithv@fusion.com)
2385
2386         * rd_req.c: removed unused local variable.
2387
2388 Tue Mar 28 18:34:20 1995  John Gilmore  (gnu at toad.com)
2389
2390         * rd_req_sim.c:  Really remove the file.
2391
2392 Mon Mar 27 08:34:49 1995 Chris Provenzano (proven@mit.edu)
2393
2394         * Makefile.in: Removed rd_req_sim.c
2395
2396         * auth_con.c: Default cksumtype is now CKSUMTYPE_RSA_MD4_DES.
2397
2398         * auth_con.c: Added krb5_auth_con_setuseruserkey(), 
2399                 krb5_auth_con_getkey(), 
2400                 krb5_auth_con_getremotesubkey(),
2401                 krb5_auth_con_getauthenticator(), 
2402                 krb5_auth_con_getremoteseqnumber(),
2403                 krb5_auth_con_initivector().
2404
2405         * auth_con.c: Fixed krb5_auth_con_getlocalsubkey() to check for
2406                 a valid local_subkey before calling krb5_copy_keyblock().
2407
2408         * auth_con.h: Fixed some comments.
2409
2410         * mk_req_ext.c (krb5_mk_req_extended()): Always pass in a seed
2411                 (the keyblock contents) to krb5_calculate_checksum()
2412
2413         * rd_rep.c (krb5_rd_rep()): Use appropriate key to decode reply.
2414
2415         * rd_safe.c (krb5_rd_safe()): Don't pass checksum to 
2416                 krb5_rd_safe_basic(), it's unnecessary.
2417
2418         * compat_recv.c (krb5_compat_recvauth()):
2419         * mk_rep.c (krb5_mk_rep()):
2420         * rd_req.c (krb5_rd_req()):
2421         * rd_req_dec.c (krb5_rd_req_decode()):
2422         * recvauth.c (krb5_recvauth()):
2423                 Added a krb5_auth_context argument and eliminated many of 
2424                 the other arguments because they are included in the
2425                 krb5_auth_context structure.
2426
2427
2428 Tue Mar 21 19:22:51 1995 Keith Vetter (keithv@fusion.com)
2429
2430         * mk_safe.c: fixed signed/unsigned mismatch.
2431         * rd_safe.c: removed unused local variable currentime.
2432         * mk_req_e.c: fixed signed/unsigned mismatch.
2433
2434 Sat Mar 18 18:58:02 1995  John Gilmore  (gnu at toad.com)
2435
2436         * bld_pr_ext.c, bld_princ.c:  Replace STDARG_PROTOTYPES with
2437         HAVE_STDARG_H for consistency.
2438
2439 Fri Mar 17 19:48:07 1995  John Gilmore  (gnu at toad.com)
2440
2441         * Makefile.in (check-mac):  Add.
2442         * compat_recv.c, get_fcreds.c, recvauth.c:  Eliminate Unix socket
2443         #includes, which are now handled by k5-int.h (via k5-config.h).
2444         * conv_princ.c:  Rename variable "comp" to another name; "comp"
2445         apparently bothers the MPW compiler...
2446         * rd_cred.c:  Avoid (void) casts of void functions, for MPW.
2447         * t_walk_rtree.c:  Put com_err.h after k5_int for <sys/types> stuff.
2448         (main):  Declare and initialize the krb5_context that's being
2449         passed to everything.
2450
2451 Fri Mar 10 10:58:59 1995  Chris Provenzano (proven@mit.edu)
2452
2453         * auth_con.h auth_con.c Added for krb5_auth_con definition and
2454                 support routines.
2455
2456         * mk_req.c (krb5_mk_req())
2457         * mk_req_ext.c (krb5_mk_req_extended())
2458         * rd_rep.c (krb5_rd_rep())
2459         * sendauth.c (krb5_sendauth())
2460         * mk_priv.c (krb5_mk_priv())
2461         * mk_safe.c (krb5_mk_safe())
2462         * rd_priv.c (krb5_rd_priv())
2463         * rd_safe.c (krb5_rd_safe())
2464                 Added a krb5_auth_context argument and eliminated many of 
2465                 the other arguments because they are included in the
2466                 krb5_auth_context structure.
2467
2468         * send_tgs.c (krb5_send_tgs()) Eliminate call to krb5_mk_req_extended(),
2469                 which does far more than krb5_send_tgs() needs.
2470
2471 Tue Mar  7 19:57:34 1995  Mark Eichin  <eichin@cygnus.com>
2472
2473         * configure.in: take out ISODE_INCLUDE.
2474
2475 Tue Mar 7 13:20:06 1995 Keith Vetter (keithv@fusion.com)
2476
2477         * Makefile.in: changed library name on the pc.
2478         * parse.c: disabled for the PC error messages to stderr.
2479         * chk_trans.c: fixed signed/unsigned assignment.
2480
2481 Thu Mar 2 11:45:00 1995 Keith Vetter (keithv@fusion.com)
2482         
2483         * compat_recv.c, get_fcre.c, recvauth.c, sendauth.c: changed
2484            NEED_WINSOCK_H to NEED_SOCKETS.
2485
2486 Wed Mar 1 20:15:00 1995 Keith Vetter (keithv@fusion.com)
2487
2488         * compat_r.c, copy_pri.c, get_fcre.c, get_in_t.c, init_ctx.c, in_tkt_p.c
2489            in_tkt_s.c, preauth.c, princ_co.c, pr_to_sa.c, rd_req_d.c, recvauth.c
2490            sendauth.c, send_tgs.c, unparse.c: 16 vs 32 bit casts, removed some
2491            unused local variables, and pulled in winsock.h for network byte
2492            ordering.
2493
2494 Tue Feb 28 01:14:57 1995  John Gilmore  (gnu at toad.com)
2495
2496         * *.c:  Avoid <krb5/...> includes.
2497         * parse.c:  Exdent #ifndef to left margin for old compilers.
2498
2499 Wed Feb 22 17:14:31 1995 Keith Vetter (keithv@fusion.com)
2500
2501         * walk_rtr.c (krb5_walk_realm_tree): formal parameter wasn't declared.
2502         * send_tgs.c: const in wrong place in the prototype.
2503         * get_in_tkt.c, preauth.c, rd_cred.c, rd_priv.c, rd_req_dec.c, 
2504            rd_safe.c: needed a 32 bit abs() function.
2505         * parse.c: removed call to fprintf on error the windows version
2506         * send_auth.c: defined for windows the ECONNABORTED errno (will
2507            be removed when the socket layer is fully implemented).
2508
2509 Tue Feb 21 23:38:34 1995  Theodore Y. Ts'o  (tytso@dcl)
2510
2511         * mk_cred.c (krb5_mk_cred): Fix argument type to
2512                 krb5_free_cred_enc_part().
2513
2514 Mon Feb 13 20:25:20 1995  Theodore Y. Ts'o  (tytso@dcl)
2515
2516         * get_in_tkt.c (krb5_get_in_tkt): Fix memory leak --- the default
2517                 encryption types was not being freed.
2518
2519 Fri Feb 10 15:45:59 1995  Theodore Y. Ts'o  <tytso@dcl>
2520
2521         * rd_req.c (krb5_rd_req): Remove ISODE cruft.
2522
2523 Thu Feb  9 17:43:04 1995  Theodore Y. Ts'o  <tytso@dcl>
2524
2525         * gc_via_tgt.c (krb5_get_cred_via_tgt): Set up the keyblock's
2526                 etype field correctly (after copying the keyblock, so it
2527                 doesn't get overwritten!)
2528
2529 Mon Feb 06 17:19:04 1995 Chris Provenzano  (proven@mit.edu)
2530
2531         * get_in_tkt.c (krb5_get_in_tkt())
2532         * in_tkt_sky.c (krb5_get_in_tkt_with_skey())
2533         * in_tkt_pwd.c (krb5_get_in_tkt_with_password())
2534                 Removed krb5_keytype, changed krb5_enctype to krb5_enctype *,
2535                 changed krb5_preauthtype to krb5_preauthtype *.
2536
2537                 Changed the args to the key_proc arg of krb5_get_in_tkt()
2538                 to be the following (krb5_context, const krb5_keytype, 
2539                 krb5_data *, krb5_const_pointer, krb5_keyblock **)
2540
2541         * in_tkt_ktb.c (krb5_get_in_tkt_with_keytab()) Added this routine
2542                 to replace krb5_get_in_tkt_with_skey() in kinit.
2543
2544         * Makefile.in Added new source file in_tkt_ktb.c.
2545                 
2546 Fri Feb  3 16:41:19 1995  Mark Eichin  (eichin@cygnus.com)
2547
2548         * get_in_tkt.c (krb5_get_in_tkt): also check for the version
2549         number of the reply being whatever we had in the first byte of the
2550         request.
2551
2552 Fri Feb  3 08:07:55 1995  Theodore Y. Ts'o  (tytso@dcl)
2553
2554         * compat_recv.c (krb_v4_recvauth): Use explicit 32 bit types so
2555                 this will work on an Alpha.
2556
2557 Fri Feb  3 00:43:48 1995  Tom Yu  (tlyu@dragons-lair)
2558
2559         * get_in_tkt.c (krb5_get_in_tkt): fix typo
2560
2561 Thu Feb  2 20:51:55 1995  Mark Eichin  (eichin@cygnus.com)
2562
2563         * get_in_tkt.c (krb5_get_in_tkt): if krb5_is_as_rep fails, check
2564         if the packet might be a V4 error packet. Use modified V4 check so
2565         that it compiles under SCO.
2566
2567 Mon Jan 30 15:46:14 1995 Chris Provenzano (proven@mit.edu)
2568
2569         * int-proto.h Update prototypes for krb5_get_cred_via_tgt(), and
2570                 krb5_get_cred_via_2tgt().
2571
2572         * get_fcreds.c (krb5_get_for_creds()) 
2573         * gc_via_tgt.c (krb5_get_cred_via_tgt())
2574         * gc_2tgt.c (krb5_get_cred_via_2tgt())
2575                 Removed krb5_enctype argument. Pass NULL list of encryption
2576                 types to krb5_send_tgs to get default encryption types.
2577
2578         * gc_frm_kdc.c Removed krb5_enctype argument passed to 
2579                 krb5_get_cred_via_tgt()
2580
2581         * send_tgs.c (krb5_send_tgs()) Changed krb5_enctype arg to
2582                 krb5_enctype *, a NULL terminated array of encryption 
2583                 types. If argument is NULL then krb5_send_tgs() will 
2584                 use defaul list of encryption types.
2585
2586         * send_tgs.c (krb5_send_tgs()) To encrypt request ticket use
2587                 usecred->keyblock.etype instead of (and now defunct) 
2588                 krb5_enctype arg.
2589
2590         * init_ctx.c Added krb5_set_default_in_tkt_etypes() and
2591                 krb5_get_default_in_tkt_etypes().
2592         
2593         * rd_req.c, rd_req_decode.c Removed typedef for rdreq_key_proc
2594                 and use krb5_rd_req_decoded in its place.
2595
2596 Mon Jan 30 11:26:05 1995 Chris Provenzano (proven@mit.edu)
2597
2598         * get_fcreds.c Really needs #include<krb5/asn1.h> for definition
2599                 of krb5_is_krb_error()
2600
2601 Sat Jan 28 14:45:55 1995 Chris Provenzano (proven@mit.edu)
2602
2603         * in_tkt_sky.c (skey_keyproc()), rd_req_dec.c (krb5_rd_req_decoded())
2604                 use new API for krb5_kt_get_entry.
2605
2606 Fri Jan 27 15:45:45 1995 Chris Provenzano (proven@mit.edu)
2607
2608         * get_fcreds.c Removed #include<krb5/crc-32.h> and #include<krb5/asn1.h>
2609
2610 Wed Jan 25 16:54:40 1995  Chris Provenzano (proven@mit.edu)
2611
2612         * Removed all narrow types and references to wide.h and narrow.h
2613
2614 Fri Jan 13 15:23:47 1995  Chris Provenzano (proven@mit.edu)
2615
2616         * Added krb5_context to all krb5_routines
2617
2618 Mon Dec 19 21:55:44 1994  Theodore Y. Ts'o  (tytso@dcl)
2619
2620         * init_ctx.c: New file.  Initializes and frees the krb5_context
2621           structure.
2622
2623 Wed Dec  7 17:52:08 1994    <tytso@localhost>
2624
2625         * rd_req_dec.c (decrypt_authenticator): If the subkey doesn't
2626                 exist, don't try to set the subkey's etype.
2627
2628 Wed Nov 30 17:10:39 1994  Theodore Y. Ts'o  (tytso@dcl)
2629
2630         * bld_princ.c (krb5_build_principal_va): Set the principal's type
2631                 and magic number.
2632
2633         * Makefile.in: Build new test driver (t_walk_rtree) for
2634                 krb5_walk_realm_tree.
2635
2636         * walk_realm_tree.c (krb5_walk_realm_tree): Fix bug which occured
2637                 when the client or the server is a subdomain of the other;
2638                 walk_realm_tree would return the wrong answer, and suffer
2639                 from memory access errors.
2640
2641         * unparse.c (krb5_unparse_name_ext): Quote the '/' and '@'
2642                 characters properly.
2643
2644         * configure.in: Add appropriate help text for the --with-krb4
2645                 option.  Remove ISODE_DEFS call, since ISODE_INCLUDES now
2646                 defines ISODE automatically.
2647
2648 Mon Nov 21 15:30:07 1994  Theodore Y. Ts'o  (tytso@dcl)
2649
2650         * mk_req_ext.c (krb5_mk_req_extended): Sanitize how memory is
2651                 freed in both error and normal cases, to remove memory
2652                 leaks. 
2653
2654         * mk_req_ext.c (krb5_mk_req_extended): Use the encryption type
2655                 specified by the ticket to generate the authenticator.
2656
2657         * encode_kdc.c (krb5_encode_kdc_rep): Now requires that the
2658                 caller pass in the encryption block to be used for
2659                 encrpyting the ticket.  That way, this routine doesn't
2660                 need to create its own encryption block.
2661
2662         * encrypt_tk.c (krb5_encrypt_tkt_part): Now requires that the
2663                 caller pass in the encryption block to be used for
2664                 encrpyting the ticket.  That way, this routine doesn't
2665                 need to create its own encryption block.
2666
2667 Fri Nov 18 17:30:44 1994  Theodore Y. Ts'o  (tytso@dcl)
2668
2669         * mk_req_ext.c (krb5_mk_req_extended): Encrypt the authenticator
2670                 using the same encryption system used to encrypt the ticket.
2671
2672 Thu Nov 17 01:56:05 1994  Theodore Y. Ts'o  (tytso@dcl)
2673
2674         * gc_via_tgt.c (krb5_get_cred_via_tgt): 
2675         * gc_2tgt.c (krb5_get_cred_via_2tgt): Set the encryption type of
2676                 the session keyblock to be the type used to encrypt the
2677                 ticket. 
2678
2679 Fri Nov 11 01:20:22 1994  Theodore Y. Ts'o  (tytso@dcl)
2680
2681         * get_in_tkt.c (krb5_get_in_tkt): Set the encryption type of the
2682                 session keyblock to be the type used to encrypt the
2683                 ticket. 
2684
2685 Thu Nov 10 23:56:43 1994  Theodore Y. Ts'o  (tytso@dcl)
2686
2687         * rd_rep.c (krb5_rd_rep): Set the encryption type in
2688                 the subkey keyblock to be the encryption type used to
2689                 encrypt the rd_rep message.
2690
2691         * decrypt_tk.c (krb5_decrypt_tkt_part): Set the encryption type in
2692                 the session keyblock to be the encryption type used to
2693                 encrypt the ticket.
2694
2695         * rd_req_dec.c (decrypt_authenticator): Set the encryption type in
2696                 the subkey keyblock to be the encryption type used to
2697                 encrypt the authenticator. 
2698
2699 Tue Nov  8 17:09:48 1994  Theodore Y. Ts'o  (tytso@dcl)
2700
2701         * in_tkt_pwd.c (pwd_keyproc): Use the documented interface for
2702                 calling krb5_string_to_key().
2703
2704 Tue Oct 25 23:34:57 1994  Theodore Y. Ts'o  (tytso@dcl)
2705
2706         * srv_rcache.c (krb5_get_server_rcache): Added missing continue so
2707                 that we don't copy both the unprintable character as well
2708                 as the quoted version of it.
2709
2710 Mon Oct 24 15:50:19 1994  Theodore Y. Ts'o  (tytso@dcl)
2711
2712         * configure.in: If KRB4 is defined, define KRB5_KRB4_COMPAT for
2713                 compat_recv.c.
2714
2715 Thu Oct 13 17:26:28 1994  Theodore Y. Ts'o  (tytso@maytag)
2716
2717         * configure.in: Add ISODE_DEFS
2718
2719 Tue Oct  4 16:29:19 1994  Theodore Y. Ts'o  (tytso@dcl)
2720
2721         * in_tkt_sky.c (skey_keyproc):
2722         * in_tkt_pwd.c (pwd_keyproc): Add widen.h and narrow.h includes
2723                 around pwd_keyproc, so that the keyproc input arguments
2724                 are appropriately widened.
2725
2726 Fri Sep 30 21:58:15 1994  Theodore Y. Ts'o  (tytso@dcl)
2727
2728         * preauth.c (preauth_systems): Add placeholder for magic number
2729
2730 Thu Sep 29 15:31:10 1994  Theodore Y. Ts'o  (tytso@dcl)
2731
2732         * srv_rcache.c (krb5_get_server_rcache): cachename was not being
2733                 properly null-terminated.
2734
2735         * get_in_tkt.c (krb5_get_in_tkt): Return KRB5_IN_TKT_REALM_MISATCH
2736                 if the client and server realms don't match.  Return
2737                 KRB5_KDCREP_SKEW if the KDC reply has an unacceptible
2738                 clock skew (instead of KDCREP_MODIFIED.)
2739
2740         * gc_via_tgt.c (krb5_get_cred_via_tgt): Use a distinct error code
2741                 for KDC skew separate from the standard KDCREP_MODIFIED
2742
2743         * princ_comp.c (krb5_realm_compare): Added new function from
2744                 OpenVision.
2745
2746 Wed Sep 21 17:57:35 1994  Theodore Y. Ts'o  (tytso@dcl)
2747
2748         * rd_req_dec.c (krb5_rd_req_decoded): Added Changes from Cybersafe
2749                 to do transited realm path checking.
2750
2751         * chk_trans.c: Added donated module from CyberSafe.  It checks to
2752                 see if a transited path is a legal one between two realms.
2753
2754 Thu Sep 15 11:08:39 1994  Theodore Y. Ts'o  (tytso@dcl)
2755
2756         * rd_req_sim.c (krb5_rd_req_simple): Use krb5_rd_req instead of
2757                 krb5_rd_req_decoded, to eliminate some code duplication.
2758
2759 Sat Aug 20 01:43:43 1994  Theodore Y. Ts'o  (tytso at tsx-11)
2760
2761         * mk_req_ext.c (krb5_generate_authenticator): Fix pointer aliasing
2762         problem between newkey and authent->subkey.
2763
2764 Wed Aug 17 17:58:22 1994  Theodore Y. Ts'o  (tytso at tsx-11)
2765
2766         * encode_kdc.c (krb5_encode_kdc_rep): Pass in to
2767         encode_krb5_enc_kdc_rep_part the msg_type which should be used.
2768         Old versions of Kerberos always assume TGS_REP; this merely allows
2769         the right msg_type to be passed down to the encoding routines.
2770         For now, the encoding routines will ignore this value and do
2771         things the old way, for compatibility's sake.
2772
2773 Mon Aug  8 22:38:16 1994  Theodore Y. Ts'o  (tytso at tsx-11)
2774
2775         * preauth.c: Renamed preauthentication mechanism names to match
2776         what bcn and I agreed upon.
2777
2778 Tue Jun 28 19:35:07 1994  Tom Yu  (tlyu at dragons-lair)
2779
2780         * decode_kdc.c: folding in Harry's changes
2781         * rd_req.c: ditto
2782         * rd_req_sim.c: ditto
2783         * configure.in: adding ISODE_DEFS
2784