diff options
author | Marco d'Itri <md@linux.it> | 2017-12-10 16:54:03 +0100 |
---|---|---|
committer | Marco d'Itri <md@linux.it> | 2017-12-10 17:13:03 +0100 |
commit | 182fdaaaaa52a1976b5ff00fc8d1520971ff79ab (patch) | |
tree | fb8ddccb4c6fb27e1835210045954aa9601e4d84 /mkpasswd.c | |
parent | 41387e5837b2da27c9d55e6d4e416bf27db47f0c (diff) | |
download | whois-182fdaaaaa52a1976b5ff00fc8d1520971ff79ab.tar.gz |
mkpasswd: refactoring
Diffstat (limited to 'mkpasswd.c')
-rw-r--r-- | mkpasswd.c | 15 |
1 files changed, 6 insertions, 9 deletions
@@ -360,7 +360,8 @@ int main(int argc, char *argv[]) exit(0); } -#ifdef RANDOM_DEVICE +#if defined RANDOM_DEVICE || defined HAVE_ARC4RANDOM_BUF + void* get_random_bytes(const unsigned int count) { char *buf; @@ -368,6 +369,9 @@ void* get_random_bytes(const unsigned int count) ssize_t bytes_read; buf = NOFAIL(malloc(count)); +#if defined HAVE_ARC4RANDOM_BUF + arc4random_buf(buf, count); +#else fd = open(RANDOM_DEVICE, O_RDONLY); if (fd < 0) { perror("open(" RANDOM_DEVICE ")"); @@ -383,24 +387,17 @@ void* get_random_bytes(const unsigned int count) exit(2); } close(fd); +#endif return buf; } -#endif - -#if defined RANDOM_DEVICE || defined HAVE_ARC4RANDOM_BUF void generate_salt(char *const buf, const unsigned int len) { unsigned int i; unsigned char *entropy; -#if defined HAVE_ARC4RANDOM_BUF - entropy = NOFAIL(malloc(len)); - arc4random_buf(entropy, len); -#else entropy = get_random_bytes(len); -#endif for (i = 0; i < len; i++) buf[i] = valid_salts[entropy[i] % (sizeof valid_salts - 1)]; |