4.4BSD/usr/src/kerberosIV/krb/util.c
/*
* $Source: /usr/src/kerberosIV/krb/RCS/util.c,v $
* $Author: bostic $
*
* Copyright 1988 by the Massachusetts Institute of Technology.
*
* For copying and distribution information, please see the file
* <mit-copyright.h>.
*
* Miscellaneous debug printing utilities
*/
#ifndef lint
static char rcsid_util_c[] =
"$Header: /usr/src/kerberosIV/krb/RCS/util.c,v 4.10 91/02/25 15:31:14 bostic Exp $";
#endif lint
#include <mit-copyright.h>
#include <des.h>
#include <krb.h>
#include <sys/types.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <stdio.h>
/*
* Print some of the contents of the given authenticator structure
* (AUTH_DAT defined in "krb.h"). Fields printed are:
*
* pname, pinst, prealm, netaddr, flags, cksum, timestamp, session
*/
ad_print(x)
AUTH_DAT *x;
{
struct in_addr add;
/*
* Print the contents of an auth_dat struct. We can't cast a char
* array (x->address) to a struct in_addr, so we must turn off
* lint checking here.
*
* The above was the original comment -- I don't really understand
* the problem, but gcc won't compile it the way it was. Hope this
* works -- TK.
*/
add.s_addr = x->address;
printf("\n%s %s %s %s flags %u cksum 0x%X\n\ttkt_tm 0x%X sess_key",
x->pname, x->pinst, x->prealm, inet_ntoa(add), x->k_flags,
x->checksum, x->time_sec);
printf("[8] =");
#ifdef NOENCRYPTION
placebo_cblock_print(x->session);
#else /* Do Encryption */
des_cblock_print_file(x->session,stdout);
#endif /* NOENCRYPTION */
/* skip reply for now */
}
#ifdef NOENCRYPTION
/*
* Print in hex the 8 bytes of the given session key.
*
* Printed format is: " 0x { x, x, x, x, x, x, x, x }"
*/
placebo_cblock_print(x)
des_cblock x;
{
unsigned char *y = (unsigned char *) x;
register int i = 0;
printf(" 0x { ");
while (i++ <8) {
printf("%x",*y++);
if (i<8) printf(", ");
}
printf(" }");
}
#endif /* NOENCRYPTION */