xref: /illumos-gate/usr/src/cmd/krb5/krb5kdc/dispatch.c (revision 55fea89d)
17c478bd9Sstevel@tonic-gate /*
2159d09a2SMark Phalan  * Copyright 2008 Sun Microsystems, Inc.  All rights reserved.
37c478bd9Sstevel@tonic-gate  * Use is subject to license terms.
47c478bd9Sstevel@tonic-gate  */
57c478bd9Sstevel@tonic-gate 
67c478bd9Sstevel@tonic-gate /*
77c478bd9Sstevel@tonic-gate  * kdc/dispatch.c
87c478bd9Sstevel@tonic-gate  *
97c478bd9Sstevel@tonic-gate  * Copyright 1990 by the Massachusetts Institute of Technology.
107c478bd9Sstevel@tonic-gate  *
117c478bd9Sstevel@tonic-gate  * Export of this software from the United States of America may
127c478bd9Sstevel@tonic-gate  *   require a specific license from the United States Government.
137c478bd9Sstevel@tonic-gate  *   It is the responsibility of any person or organization contemplating
147c478bd9Sstevel@tonic-gate  *   export to obtain such a license before exporting.
15*55fea89dSDan Cross  *
167c478bd9Sstevel@tonic-gate  * WITHIN THAT CONSTRAINT, permission to use, copy, modify, and
177c478bd9Sstevel@tonic-gate  * distribute this software and its documentation for any purpose and
187c478bd9Sstevel@tonic-gate  * without fee is hereby granted, provided that the above copyright
197c478bd9Sstevel@tonic-gate  * notice appear in all copies and that both that copyright notice and
207c478bd9Sstevel@tonic-gate  * this permission notice appear in supporting documentation, and that
217c478bd9Sstevel@tonic-gate  * the name of M.I.T. not be used in advertising or publicity pertaining
227c478bd9Sstevel@tonic-gate  * to distribution of the software without specific, written prior
237c478bd9Sstevel@tonic-gate  * permission.  Furthermore if you modify this software you must label
247c478bd9Sstevel@tonic-gate  * your software as modified software and not distribute it in such a
257c478bd9Sstevel@tonic-gate  * fashion that it might be confused with the original M.I.T. software.
267c478bd9Sstevel@tonic-gate  * M.I.T. makes no representations about the suitability of
277c478bd9Sstevel@tonic-gate  * this software for any purpose.  It is provided "as is" without express
287c478bd9Sstevel@tonic-gate  * or implied warranty.
29*55fea89dSDan Cross  *
307c478bd9Sstevel@tonic-gate  *
317c478bd9Sstevel@tonic-gate  * Dispatch an incoming packet.
327c478bd9Sstevel@tonic-gate  */
337c478bd9Sstevel@tonic-gate 
347c478bd9Sstevel@tonic-gate 
357c478bd9Sstevel@tonic-gate #include "k5-int.h"
367c478bd9Sstevel@tonic-gate #include <syslog.h>
377c478bd9Sstevel@tonic-gate #include "kdc_util.h"
387c478bd9Sstevel@tonic-gate #include "extern.h"
397c478bd9Sstevel@tonic-gate #include "adm_proto.h"
407c478bd9Sstevel@tonic-gate #include <netinet/in.h>
417c478bd9Sstevel@tonic-gate #include <arpa/inet.h>
427c478bd9Sstevel@tonic-gate #include <string.h>
437c478bd9Sstevel@tonic-gate 
4456a424ccSmp static krb5_int32 last_usec = 0, last_os_random = 0;
457c478bd9Sstevel@tonic-gate 
467c478bd9Sstevel@tonic-gate krb5_error_code
dispatch(krb5_data * pkt,const krb5_fulladdr * from,krb5_data ** response)4756a424ccSmp dispatch(krb5_data *pkt, const krb5_fulladdr *from, krb5_data **response)
487c478bd9Sstevel@tonic-gate {
497c478bd9Sstevel@tonic-gate 
507c478bd9Sstevel@tonic-gate     krb5_error_code retval;
517c478bd9Sstevel@tonic-gate     krb5_kdc_req *as_req;
5256a424ccSmp     krb5_int32 now, now_usec;
53*55fea89dSDan Cross 
547c478bd9Sstevel@tonic-gate     /* decode incoming packet, and dispatch */
557c478bd9Sstevel@tonic-gate 
567c478bd9Sstevel@tonic-gate #ifndef NOCACHE
577c478bd9Sstevel@tonic-gate     /* try the replay lookaside buffer */
58159d09a2SMark Phalan     if (kdc_check_lookaside(pkt, response)) {
597c478bd9Sstevel@tonic-gate 	/* a hit! */
607c478bd9Sstevel@tonic-gate 	const char *name = 0;
617c478bd9Sstevel@tonic-gate 	char buf[46];
627c478bd9Sstevel@tonic-gate 
637c478bd9Sstevel@tonic-gate 	name = (char *) inet_ntop (ADDRTYPE2FAMILY (from->address->addrtype),
647c478bd9Sstevel@tonic-gate 			  from->address->contents, buf, sizeof (buf));
657c478bd9Sstevel@tonic-gate 	if (name == 0)
667c478bd9Sstevel@tonic-gate 	    name = "[unknown address type]";
677c478bd9Sstevel@tonic-gate 	krb5_klog_syslog(LOG_INFO,
6856a424ccSmp 			 "DISPATCH: repeated (retransmitted?) request from %s, resending previous response",
6956a424ccSmp 			 name);
707c478bd9Sstevel@tonic-gate 	return 0;
717c478bd9Sstevel@tonic-gate     }
7256a424ccSmp #endif
7356a424ccSmp /* SUNW14resync XXX */
7456a424ccSmp #if 0
7556a424ccSmp     retval = krb5_crypto_us_timeofday(&now, &now_usec);
7656a424ccSmp     if (retval == 0) {
7756a424ccSmp       krb5_int32 usec_difference = now_usec-last_usec;
7856a424ccSmp       krb5_data data;
7956a424ccSmp       if(last_os_random == 0)
8056a424ccSmp 	last_os_random = now;
8156a424ccSmp       /* Grab random data from OS every hour*/
8256a424ccSmp       if(now-last_os_random >= 60*60) {
8356a424ccSmp 	krb5_c_random_os_entropy(kdc_context, 0, NULL);
8456a424ccSmp 	last_os_random = now;
8556a424ccSmp       }
86*55fea89dSDan Cross 
8756a424ccSmp       data.length = sizeof(krb5_int32);
8856a424ccSmp       data.data = (void *) &usec_difference;
89*55fea89dSDan Cross 
9056a424ccSmp       krb5_c_random_add_entropy(kdc_context,
9156a424ccSmp 				KRB5_C_RANDSOURCE_TIMING, &data);
9256a424ccSmp       last_usec = now_usec;
9356a424ccSmp     }
947c478bd9Sstevel@tonic-gate #endif
957c478bd9Sstevel@tonic-gate     /* try TGS_REQ first; they are more common! */
967c478bd9Sstevel@tonic-gate 
977c478bd9Sstevel@tonic-gate     if (krb5_is_tgs_req(pkt)) {
9856a424ccSmp 	retval = process_tgs_req(pkt, from, response);
997c478bd9Sstevel@tonic-gate     } else if (krb5_is_as_req(pkt)) {
1007c478bd9Sstevel@tonic-gate 	if (!(retval = decode_krb5_as_req(pkt, &as_req))) {
1017c478bd9Sstevel@tonic-gate 	    /*
1027c478bd9Sstevel@tonic-gate 	     * setup_server_realm() sets up the global realm-specific data
1037c478bd9Sstevel@tonic-gate 	     * pointer.
1047c478bd9Sstevel@tonic-gate 	     */
1057c478bd9Sstevel@tonic-gate 	    if (!(retval = setup_server_realm(as_req->server))) {
106159d09a2SMark Phalan 		retval = process_as_req(as_req, pkt, from, response);
1077c478bd9Sstevel@tonic-gate 	    }
1087c478bd9Sstevel@tonic-gate 	    krb5_free_kdc_req(kdc_context, as_req);
1097c478bd9Sstevel@tonic-gate 	}
1107c478bd9Sstevel@tonic-gate     }
11156a424ccSmp #ifdef KRB5_KRB4_COMPAT
11256a424ccSmp     else if (pkt->data[0] == 4)		/* old version */
11356a424ccSmp 	retval = process_v4(pkt, from, response);
11456a424ccSmp #endif
1157c478bd9Sstevel@tonic-gate     else
1167c478bd9Sstevel@tonic-gate 	retval = KRB5KRB_AP_ERR_MSG_TYPE;
1177c478bd9Sstevel@tonic-gate #ifndef NOCACHE
1187c478bd9Sstevel@tonic-gate     /* put the response into the lookaside buffer */
1197c478bd9Sstevel@tonic-gate     if (!retval)
120159d09a2SMark Phalan 	kdc_insert_lookaside(pkt, *response);
1217c478bd9Sstevel@tonic-gate #endif
1227c478bd9Sstevel@tonic-gate 
1237c478bd9Sstevel@tonic-gate     return retval;
1247c478bd9Sstevel@tonic-gate }
125