xref: /plan9/sys/src/libauthsrv/convA2M.c (revision 9a747e4fd48b9f4522c70c07e8f882a15030f964)
1*9a747e4fSDavid du Colombier #include <u.h>
2*9a747e4fSDavid du Colombier #include <libc.h>
3*9a747e4fSDavid du Colombier #include <authsrv.h>
4*9a747e4fSDavid du Colombier 
5*9a747e4fSDavid du Colombier #define	CHAR(x)		*p++ = f->x
6*9a747e4fSDavid du Colombier #define	SHORT(x)	p[0] = f->x; p[1] = f->x>>8; p += 2
7*9a747e4fSDavid du Colombier #define	VLONG(q)	p[0] = (q); p[1] = (q)>>8; p[2] = (q)>>16; p[3] = (q)>>24; p += 4
8*9a747e4fSDavid du Colombier #define	LONG(x)		VLONG(f->x)
9*9a747e4fSDavid du Colombier #define	STRING(x,n)	memmove(p, f->x, n); p += n
10*9a747e4fSDavid du Colombier 
11*9a747e4fSDavid du Colombier int
convA2M(Authenticator * f,char * ap,char * key)12*9a747e4fSDavid du Colombier convA2M(Authenticator *f, char *ap, char *key)
13*9a747e4fSDavid du Colombier {
14*9a747e4fSDavid du Colombier 	int n;
15*9a747e4fSDavid du Colombier 	uchar *p;
16*9a747e4fSDavid du Colombier 
17*9a747e4fSDavid du Colombier 	p = (uchar*)ap;
18*9a747e4fSDavid du Colombier 	CHAR(num);
19*9a747e4fSDavid du Colombier 	STRING(chal, CHALLEN);
20*9a747e4fSDavid du Colombier 	LONG(id);
21*9a747e4fSDavid du Colombier 	n = p - (uchar*)ap;
22*9a747e4fSDavid du Colombier 	if(key)
23*9a747e4fSDavid du Colombier 		encrypt(key, ap, n);
24*9a747e4fSDavid du Colombier 	return n;
25*9a747e4fSDavid du Colombier }
26