]> git.lizzy.rs Git - plan9front.git/blob - sys/src/libauthsrv/passtokey.c
libsec: generalize pbkdf2_hmac_sha1() to pbkdf2_x() passing the hmac as an argument
[plan9front.git] / sys / src / libauthsrv / passtokey.c
1 #include <u.h>
2 #include <libc.h>
3 #include <authsrv.h>
4 #include <libsec.h>
5
6 static void
7 passtodeskey(char *key, char *p)
8 {
9         uchar buf[ANAMELEN], *t;
10         int i, n;
11
12         n = strlen(p);
13         if(n >= ANAMELEN)
14                 n = ANAMELEN-1;
15         memset(buf, ' ', 8);
16         t = buf;
17         strncpy((char*)t, p, n);
18         t[n] = 0;
19         memset(key, 0, DESKEYLEN);
20         for(;;){
21                 for(i = 0; i < DESKEYLEN; i++)
22                         key[i] = (t[i] >> i) + (t[i+1] << (8 - (i+1)));
23                 if(n <= 8)
24                         return;
25                 n -= 8;
26                 t += 8;
27                 if(n < 8){
28                         t -= 8 - n;
29                         n = 8;
30                 }
31                 encrypt(key, t, 8);
32         }
33 }
34
35 static void
36 passtoaeskey(uchar *key, char *p)
37 {
38         static char salt[] = "Plan 9 key derivation";
39         pbkdf2_x((uchar*)p, strlen(p), (uchar*)salt, sizeof(salt)-1, 9001, key, AESKEYLEN, hmac_sha1, SHA1dlen);
40 }
41
42 void
43 passtokey(Authkey *key, char *p)
44 {
45         memset(key, 0, sizeof(Authkey));
46         passtodeskey(key->des, p);
47         passtoaeskey(key->aes, p);
48 }