X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=util%2Fpasswddb.c;h=a0f4ddc8d896da44d04bde784237d25f0d8985f1;hb=27a6d4f7f7425896345ab5a2bfdf35a96c97416e;hp=114da0666e8f0ab8973295f3eee9eae38451fc03;hpb=4478d785b7769691261005c98063b98a5a5971b3;p=idzebra-moved-to-github.git diff --git a/util/passwddb.c b/util/passwddb.c index 114da06..a0f4ddc 100644 --- a/util/passwddb.c +++ b/util/passwddb.c @@ -1,5 +1,5 @@ -/* $Id: passwddb.c,v 1.14 2006-08-14 10:40:34 adam Exp $ - Copyright (C) 1995-2006 +/* $Id: passwddb.c,v 1.16 2007-01-15 15:10:26 adam Exp $ + Copyright (C) 1995-2007 Index Data ApS This file is part of the Zebra server. @@ -135,15 +135,19 @@ int passwd_db_auth(Passwd_db db, const char *user, const char *pass) if (pe->encrypt_flag) { #if HAVE_CRYPT_H - char salt[3]; const char *des_try; if (strlen (pe->des) < 3) return -3; if (!pass) return -2; - memcpy (salt, pe->des, 2); - salt[2] = '\0'; - des_try = crypt (pass, salt); + + if (pe->des[0] != '$') /* Not MD5? (assume DES) */ + { + if (strlen(pass) > 8) /* maximum key length is 8 */ + return -2; + } + des_try = crypt (pass, pe->des); + if (strcmp (des_try, pe->des)) return -2; #else