/* 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);
}