summaryrefslogtreecommitdiff
path: root/lib/ZFmtAuth.c
blob: cd131fa53eb2283f5c934be3509e7621a9651c2b (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
/* This file is part of the Project Athena Zephyr Notification System.
 * It contains source for the ZFormatAuthenticNotice function.
 *
 *	Created by:	Robert French
 *
 *	$Source$
 *	$Author$
 *
 *	Copyright (c) 1987 by the Massachusetts Institute of Technology.
 *	For copying and distribution information, see the file
 *	"mit-copyright.h". 
 */
/* $Header$ */

#include <zephyr/mit-copyright.h>

#include <zephyr/zephyr_internal.h>

Code_t ZFormatAuthenticNotice(notice,buffer,buffer_len,len,session)
	ZNotice_t	*notice;
	ZPacket_t	buffer;
	int		buffer_len;
	int		*len;
	C_Block		session;
{
	char *ptr;
	int result,retval,hdrlen;
	AUTH_DAT dat;
	KTEXT_ST authent;
	ZChecksum_t our_checksum;
	CREDENTIALS cred;

	notice->z_auth = 1;
	notice->z_authent_len = 0;
	notice->z_ascii_authent = (KTEXT)"";
	
	if ((retval = Z_FormatRawHeader(notice,buffer,buffer_len,&hdrlen))
	    != ZERR_NONE)
		return (retval);

	for (hdrlen--;buffer[hdrlen];hdrlen--)
		;
	
	if (result = get_credentials(SERVER_SERVICE,SERVER_INSTANCE,
			    __Zephyr_realm,&cred))
		return (result+krb_err_base);

	notice->z_checksum = (ZChecksum_t)quad_cksum(buffer,NULL,hdrlen,0,
						     cred.session);

	if ((retval = Z_FormatRawHeader(notice,buffer,buffer_len,&hdrlen))
	    != ZERR_NONE)
		return (retval);

	ptr = buffer+hdrlen;

	if (notice->z_message_len+hdrlen > buffer_len)
		return (ZERR_PKTLEN);

	bcopy(notice->z_message,ptr,notice->z_message_len);

	*len = hdrlen+notice->z_message_len;

	if (*len > Z_MAXPKTLEN)
		return (ZERR_PKTLEN);

	return (ZERR_NONE);
}