xref: /plan9/sys/src/libauthsrv/convM2A.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)		f->x = *p++
6*9a747e4fSDavid du Colombier #define	SHORT(x)	f->x = (p[0] | (p[1]<<8)); p += 2
7*9a747e4fSDavid du Colombier #define	VLONG(q)	q = (p[0] | (p[1]<<8) | (p[2]<<16) | (p[3]<<24)); p += 4
8*9a747e4fSDavid du Colombier #define	LONG(x)		VLONG(f->x)
9*9a747e4fSDavid du Colombier #define	STRING(x,n)	memmove(f->x, p, n); p += n
10*9a747e4fSDavid du Colombier 
11*9a747e4fSDavid du Colombier void
convM2A(char * ap,Authenticator * f,char * key)12*9a747e4fSDavid du Colombier convM2A(char *ap, Authenticator *f, char *key)
13*9a747e4fSDavid du Colombier {
14*9a747e4fSDavid du Colombier 	uchar *p;
15*9a747e4fSDavid du Colombier 
16*9a747e4fSDavid du Colombier 	if(key)
17*9a747e4fSDavid du Colombier 		decrypt(key, ap, AUTHENTLEN);
18*9a747e4fSDavid du Colombier 	p = (uchar*)ap;
19*9a747e4fSDavid du Colombier 	CHAR(num);
20*9a747e4fSDavid du Colombier 	STRING(chal, CHALLEN);
21*9a747e4fSDavid du Colombier 	LONG(id);
22*9a747e4fSDavid du Colombier 	USED(p);
23*9a747e4fSDavid du Colombier }
24