xref: /plan9/sys/src/cmd/unix/drawterm/libauthsrv/convM2PR.c (revision 8ccd4a6360d974db7bd7bbd4f37e7018419ea908)
1*8ccd4a63SDavid du Colombier #include <u.h>
2*8ccd4a63SDavid du Colombier #include <libc.h>
3*8ccd4a63SDavid du Colombier #include <authsrv.h>
4*8ccd4a63SDavid du Colombier 
5*8ccd4a63SDavid du Colombier #define	CHAR(x)		f->x = *p++
6*8ccd4a63SDavid du Colombier #define	SHORT(x)	f->x = (p[0] | (p[1]<<8)); p += 2
7*8ccd4a63SDavid du Colombier #define	VLONG(q)	q = (p[0] | (p[1]<<8) | (p[2]<<16) | (p[3]<<24)); p += 4
8*8ccd4a63SDavid du Colombier #define	LONG(x)		VLONG(f->x)
9*8ccd4a63SDavid du Colombier #define	STRING(x,n)	memmove(f->x, p, n); p += n
10*8ccd4a63SDavid du Colombier 
11*8ccd4a63SDavid du Colombier void
convM2PR(char * ap,Passwordreq * f,char * key)12*8ccd4a63SDavid du Colombier convM2PR(char *ap, Passwordreq *f, char *key)
13*8ccd4a63SDavid du Colombier {
14*8ccd4a63SDavid du Colombier 	uchar *p;
15*8ccd4a63SDavid du Colombier 
16*8ccd4a63SDavid du Colombier 	p = (uchar*)ap;
17*8ccd4a63SDavid du Colombier 	if(key)
18*8ccd4a63SDavid du Colombier 		decrypt(key, ap, PASSREQLEN);
19*8ccd4a63SDavid du Colombier 	CHAR(num);
20*8ccd4a63SDavid du Colombier 	STRING(old, ANAMELEN);
21*8ccd4a63SDavid du Colombier 	f->old[ANAMELEN-1] = 0;
22*8ccd4a63SDavid du Colombier 	STRING(new, ANAMELEN);
23*8ccd4a63SDavid du Colombier 	f->new[ANAMELEN-1] = 0;
24*8ccd4a63SDavid du Colombier 	CHAR(changesecret);
25*8ccd4a63SDavid du Colombier 	STRING(secret, SECRETLEN);
26*8ccd4a63SDavid du Colombier 	f->secret[SECRETLEN-1] = 0;
27*8ccd4a63SDavid du Colombier 	USED(p);
28*8ccd4a63SDavid du Colombier }
29