convM2T.c 579 B

12345678910111213141516171819202122232425262728
  1. #include <u.h>
  2. #include <libc.h>
  3. #include <authsrv.h>
  4. #define CHAR(x) f->x = *p++
  5. #define SHORT(x) f->x = (p[0] | (p[1]<<8)); p += 2
  6. #define VLONG(q) q = (p[0] | (p[1]<<8) | (p[2]<<16) | (p[3]<<24)); p += 4
  7. #define LONG(x) VLONG(f->x)
  8. #define STRING(x,n) memmove(f->x, p, n); p += n
  9. void
  10. convM2T(char *ap, Ticket *f, char *key)
  11. {
  12. uchar *p;
  13. if(key)
  14. decrypt(key, ap, TICKETLEN);
  15. p = (uchar*)ap;
  16. CHAR(num);
  17. STRING(chal, CHALLEN);
  18. STRING(cuid, ANAMELEN);
  19. f->cuid[ANAMELEN-1] = 0;
  20. STRING(suid, ANAMELEN);
  21. f->suid[ANAMELEN-1] = 0;
  22. STRING(key, DESKEYLEN);
  23. USED(p);
  24. }