Annotation of 43BSDReno/kerberosIV/krb/mk_safe.c, revision 1.1.1.1

1.1       root        1: /*
                      2:  * $Source: /mit/kerberos/src/lib/krb/RCS/mk_safe.c,v $
                      3:  * $Author: jtkohl $
                      4:  *
                      5:  * Copyright 1986, 1987, 1988 by the Massachusetts Institute
                      6:  * of Technology.
                      7:  *
                      8:  * For copying and distribution information, please see the file
                      9:  * <mit-copyright.h>.
                     10:  *
                     11:  * This routine constructs a Kerberos 'safe msg', i.e. authenticated
                     12:  * using a private session key to seed a checksum. Msg is NOT
                     13:  * encrypted.
                     14:  *
                     15:  *      Note-- bcopy is used to avoid alignment problems on IBM RT
                     16:  *
                     17:  *      Returns either <0 ===> error, or resulting size of message
                     18:  *
                     19:  * Steve Miller    Project Athena  MIT/DEC
                     20:  */
                     21: 
                     22: #ifndef lint
                     23: static char *rcsid_mk_safe_c=
                     24: "$Header: mk_safe.c,v 4.12 89/03/22 14:50:49 jtkohl Exp $";
                     25: #endif /* lint */
                     26: 
                     27: #include <mit-copyright.h>
                     28: 
                     29: /* system include files */
                     30: #include <stdio.h>
                     31: #include <errno.h>
                     32: #include <sys/types.h>
                     33: #include <netinet/in.h>
                     34: #include <sys/time.h>
                     35: 
                     36: /* application include files */
                     37: #include <des.h>
                     38: #include <krb.h>
                     39: #include <prot.h>
                     40: #include "lsb_addr_comp.h"
                     41: 
                     42: extern char *errmsg();
                     43: extern int errno;
                     44: extern int krb_debug;
                     45: 
                     46: /* static storage */
                     47: 
                     48: static u_long cksum;
                     49: static C_Block big_cksum[2];
                     50: static struct timeval msg_time;
                     51: static u_char msg_time_5ms;
                     52: static long msg_time_sec;
                     53: 
                     54: /*
                     55:  * krb_mk_safe() constructs an AUTH_MSG_SAFE message.  It takes some
                     56:  * user data "in" of "length" bytes and creates a packet in "out"
                     57:  * consisting of the user data, a timestamp, and the sender's network
                     58:  * address, followed by a checksum computed on the above, using the
                     59:  * given "key".  The length of the resulting packet is returned.
                     60:  *
                     61:  * The "out" packet consists of:
                     62:  *
                     63:  * Size                        Variable                Field
                     64:  * ----                        --------                -----
                     65:  *
                     66:  * 1 byte              KRB_PROT_VERSION        protocol version number
                     67:  * 1 byte              AUTH_MSG_SAFE |         message type plus local
                     68:  *                     HOST_BYTE_ORDER         byte order in low bit
                     69:  *
                     70:  * ===================== begin checksum ================================
                     71:  * 
                     72:  * 4 bytes             length                  length of user data
                     73:  * length              in                      user data
                     74:  * 1 byte              msg_time_5ms            timestamp milliseconds
                     75:  * 4 bytes             sender->sin.addr.s_addr sender's IP address
                     76:  *
                     77:  * 4 bytes             msg_time_sec or         timestamp seconds with
                     78:  *                     -msg_time_sec           direction in sign bit
                     79:  *
                     80:  * ======================= end checksum ================================
                     81:  *
                     82:  * 16 bytes            big_cksum               quadratic checksum of
                     83:  *                                             above using "key"
                     84:  */
                     85: 
                     86: long krb_mk_safe(in,out,length,key,sender,receiver)
                     87:     u_char *in;                        /* application data */
                     88:     u_char *out;               /*
                     89:                                 * put msg here, leave room for header!
                     90:                                 * breaks if in and out (header stuff)
                     91:                                 * overlap
                     92:                                 */
                     93:     u_long length;             /* of in data */
                     94:     C_Block *key;              /* encryption key for seed and ivec */
                     95:     struct sockaddr_in *sender;        /* sender address */
                     96:     struct sockaddr_in *receiver; /* receiver address */
                     97: {
                     98:     register u_char     *p,*q;
                     99: 
                    100:     /*
                    101:      * get the current time to use instead of a sequence #, since
                    102:      * process lifetime may be shorter than the lifetime of a session
                    103:      * key.
                    104:      */
                    105:     if (gettimeofday(&msg_time,(struct timezone *)0)) {
                    106:         return  -1;
                    107:     }
                    108:     msg_time_sec = (long) msg_time.tv_sec;
                    109:     msg_time_5ms = msg_time.tv_usec/5000; /* 5ms quanta */
                    110: 
                    111:     p = out;
                    112: 
                    113:     *p++ = KRB_PROT_VERSION;
                    114:     *p++ = AUTH_MSG_SAFE | HOST_BYTE_ORDER;
                    115: 
                    116:     q = p;                     /* start for checksum stuff */
                    117:     /* stuff input length */
                    118:     bcopy((char *)&length,(char *)p,sizeof(length));
                    119:     p += sizeof(length);
                    120: 
                    121:     /* make all the stuff contiguous for checksum */
                    122:     bcopy((char *)in,(char *)p,(int) length);
                    123:     p += length;
                    124: 
                    125:     /* stuff time 5ms */
                    126:     bcopy((char *)&msg_time_5ms,(char *)p,sizeof(msg_time_5ms));
                    127:     p += sizeof(msg_time_5ms);
                    128: 
                    129:     /* stuff source address */
                    130:     bcopy((char *) &sender->sin_addr.s_addr,(char *)p,
                    131:           sizeof(sender->sin_addr.s_addr));
                    132:     p += sizeof(sender->sin_addr.s_addr);
                    133: 
                    134:     /*
                    135:      * direction bit is the sign bit of the timestamp.  Ok until
                    136:      * 2038??
                    137:      */
                    138:     /* For compatibility with broken old code, compares are done in VAX 
                    139:        byte order (LSBFIRST) */ 
                    140:     if (lsb_net_ulong_less(sender->sin_addr.s_addr, /* src < recv */ 
                    141:                          receiver->sin_addr.s_addr)==-1) 
                    142:         msg_time_sec =  -msg_time_sec; 
                    143:     else if (lsb_net_ulong_less(sender->sin_addr.s_addr, 
                    144:                                receiver->sin_addr.s_addr)==0) 
                    145:         if (lsb_net_ushort_less(sender->sin_port,receiver->sin_port) == -1) 
                    146:             msg_time_sec = -msg_time_sec; 
                    147:     /*
                    148:      * all that for one tiny bit!  Heaven help those that talk to
                    149:      * themselves.
                    150:      */
                    151: 
                    152:     /* stuff time sec */
                    153:     bcopy((char *)&msg_time_sec,(char *)p,sizeof(msg_time_sec));
                    154:     p += sizeof(msg_time_sec);
                    155: 
                    156: #ifdef NOENCRYPTION
                    157:     cksum = 0;
                    158:     bzero(big_cksum, sizeof(big_cksum));
                    159: #else /* Do encryption */
                    160:     /* calculate the checksum of length, timestamps, and input data */
                    161:     cksum = quad_cksum(q,big_cksum,p-q,2,key);
                    162: #endif /* NOENCRYPTION */
                    163:     if (krb_debug)
                    164:         printf("\ncksum = %u",cksum);
                    165: 
                    166:     /* stuff checksum */
                    167:     bcopy((char *)big_cksum,(char *)p,sizeof(big_cksum));
                    168:     p += sizeof(big_cksum);
                    169: 
                    170:     return ((long)(p - out));  /* resulting size */
                    171: 
                    172: }

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.