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