summaryrefslogtreecommitdiffstats
path: root/src/lib/krb4/ad_print.c
blob: c6779047afafff563b9d40f8ef1fcd95be0fb549 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
/*
 * ad_print.c
 *
 * Copyright 1988 by the Massachusetts Institute of Technology.
 *
 * For copying and distribution information, please see the file
 * <mit-copyright.h>.
 *
 * Miscellaneous debug printing utilities
 */

#include "mit-copyright.h"
#define	DEFINE_SOCKADDR		/* Request definitions for sockets */
#include "krb.h"
#include "des.h"
#include "krb4int.h"
#include <stdio.h>

#ifndef _WINDOWS

/*
 * 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
 */

void
ad_print(x)
    AUTH_DAT *x;
{
    struct in_addr ina;
    ina.s_addr = x->address;
  
    printf("\n%s %s %s ", x->pname, x->pinst, x->prealm);
    far_fputs (inet_ntoa(ina), stdout);
    printf(" flags %u cksum 0x%lX\n\ttkt_tm 0x%lX sess_key",
            x->k_flags, (long) x->checksum, (long) 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 */

#endif