mirror of
git://uclibc.org/uClibc.git
synced 2026-01-12 00:19:53 +08:00
BZ #7808 asks us not to fallback to DES if the optional SHA are disabled but requested by the user. Signed-off-by: Bernhard Reutner-Fischer <rep.dot.nop@gmail.com>
35 lines
919 B
C
35 lines
919 B
C
/* vi: set sw=4 ts=4: */
|
|
/*
|
|
* crypt() for uClibc
|
|
* Copyright (C) 2000-2006 by Erik Andersen <andersen@uclibc.org>
|
|
* Licensed under the LGPL v2.1, see the file COPYING.LIB in this tarball.
|
|
*/
|
|
|
|
#include <unistd.h>
|
|
#include <crypt.h>
|
|
#include "libcrypt.h"
|
|
|
|
char *crypt(const char *key, const char *salt)
|
|
{
|
|
const unsigned char *ukey = (const unsigned char *)key;
|
|
const unsigned char *usalt = (const unsigned char *)salt;
|
|
|
|
if (salt[0] == '$') {
|
|
if (salt[1] && salt[2] == '$') { /* no blowfish '2X' here ATM */
|
|
if (*++salt == '1')
|
|
return __md5_crypt(ukey, usalt);
|
|
#ifdef __UCLIBC_HAS_SHA256_CRYPT_IMPL__
|
|
else if (*salt == '5')
|
|
return __sha256_crypt(ukey, usalt);
|
|
#endif
|
|
#ifdef __UCLIBC_HAS_SHA512_CRYPT_IMPL__
|
|
else if (*salt == '6')
|
|
return __sha512_crypt(ukey, usalt);
|
|
#endif
|
|
}
|
|
/* __set_errno(EINVAL);*/ /* ENOSYS might be misleading */
|
|
return NULL;
|
|
}
|
|
return __des_crypt(ukey, usalt);
|
|
}
|