diff options
| author | tedu <> | 2014-11-17 16:47:28 +0000 |
|---|---|---|
| committer | tedu <> | 2014-11-17 16:47:28 +0000 |
| commit | 1d73abd6ebdd0b8188330f94e644727d86b1d336 (patch) | |
| tree | f8c67ffae926873c4b6b8eb4d6a4dc43ef63d29c /src/lib/libc/crypt/cryptutil.c | |
| parent | d6b346577efe94c30d6ba08ca7f8feae71688a3c (diff) | |
| download | openbsd-1d73abd6ebdd0b8188330f94e644727d86b1d336.tar.gz openbsd-1d73abd6ebdd0b8188330f94e644727d86b1d336.tar.bz2 openbsd-1d73abd6ebdd0b8188330f94e644727d86b1d336.zip | |
add new function crypt_newhash to simplify creating new hashes.
does most of the work pwd_gensalt did, but also creates the hash.
(unused yet)
Diffstat (limited to 'src/lib/libc/crypt/cryptutil.c')
| -rw-r--r-- | src/lib/libc/crypt/cryptutil.c | 30 |
1 files changed, 29 insertions, 1 deletions
diff --git a/src/lib/libc/crypt/cryptutil.c b/src/lib/libc/crypt/cryptutil.c index 36deda778e..4a8c46be49 100644 --- a/src/lib/libc/crypt/cryptutil.c +++ b/src/lib/libc/crypt/cryptutil.c | |||
| @@ -1,4 +1,4 @@ | |||
| 1 | /* $OpenBSD: cryptutil.c,v 1.1 2014/05/12 19:13:14 tedu Exp $ */ | 1 | /* $OpenBSD: cryptutil.c,v 1.2 2014/11/17 16:47:28 tedu Exp $ */ |
| 2 | /* | 2 | /* |
| 3 | * Copyright (c) 2014 Ted Unangst <tedu@openbsd.org> | 3 | * Copyright (c) 2014 Ted Unangst <tedu@openbsd.org> |
| 4 | * | 4 | * |
| @@ -18,6 +18,7 @@ | |||
| 18 | #include <unistd.h> | 18 | #include <unistd.h> |
| 19 | #include <string.h> | 19 | #include <string.h> |
| 20 | #include <pwd.h> | 20 | #include <pwd.h> |
| 21 | #include <login_cap.h> | ||
| 21 | #include <errno.h> | 22 | #include <errno.h> |
| 22 | 23 | ||
| 23 | int | 24 | int |
| @@ -52,3 +53,30 @@ fail: | |||
| 52 | errno = EACCES; | 53 | errno = EACCES; |
| 53 | return -1; | 54 | return -1; |
| 54 | } | 55 | } |
| 56 | |||
| 57 | int | ||
| 58 | crypt_newhash(const char *pass, login_cap_t *lc, char *hash, size_t hashlen) | ||
| 59 | { | ||
| 60 | int rv = -1; | ||
| 61 | char *pref; | ||
| 62 | char *defaultpref = "blowfish,8"; | ||
| 63 | const char *errstr; | ||
| 64 | int rounds; | ||
| 65 | |||
| 66 | if (lc == NULL || | ||
| 67 | (pref = login_getcapstr(lc, "localcipher", NULL, NULL)) == NULL) | ||
| 68 | pref = defaultpref; | ||
| 69 | if (strncmp(pref, "blowfish,", 9) != 0) { | ||
| 70 | errno = EINVAL; | ||
| 71 | goto err; | ||
| 72 | } | ||
| 73 | rounds = strtonum(pref + 9, 4, 31, &errstr); | ||
| 74 | if (errstr) | ||
| 75 | goto err; | ||
| 76 | rv = bcrypt_newhash(pass, rounds, hash, hashlen); | ||
| 77 | |||
| 78 | err: | ||
| 79 | if (pref != defaultpref) | ||
| 80 | free(pref); | ||
| 81 | return rv; | ||
| 82 | } | ||
