* Extend sulogin to support additional encryption algorithms

This commit is contained in:
Werner Fink 2010-03-30 15:22:00 +00:00
parent b2fec03199
commit 0c8868b54f
2 changed files with 44 additions and 14 deletions

View File

@ -75,6 +75,7 @@ sysvinit (2.88dsf) UNRELEASED; urgency=low
getting a controlling tty isn't that reported by spawn() getting a controlling tty isn't that reported by spawn()
* Re-enable writting utmp/wtmp for boot scripts * Re-enable writting utmp/wtmp for boot scripts
* Provide a simply /etc/pam.d/init as without it will not work (sigh!) * Provide a simply /etc/pam.d/init as without it will not work (sigh!)
* Extend sulogin to support additional encryption algorithms
-- Petter Reinholdtsen <pere@hungry.com> Sun, 12 Jul 2009 19:58:10 +0200 -- Petter Reinholdtsen <pere@hungry.com> Sun, 12 Jul 2009 19:58:10 +0200

View File

@ -160,28 +160,57 @@ void alrm_handler(int sig)
* FreeBSD-style MD5 encryption. * FreeBSD-style MD5 encryption.
*/ */
static static
int valid(char *pass) int valid(const char *pass)
{ {
char *s; const char *s;
int len; char id[5];
size_t len;
off_t off;
if (pass[0] == 0) return 1; if (pass[0] == 0) return 1;
#if CHECK_MD5 #if CHECK_MD5
if (pass[0] != '$') goto check_des;
/* /*
* 3 bytes for the signature $1$ * up to 4 bytes for the signature e.g. $1$
* up to 8 bytes for the salt
* $
* the MD5 hash (128 bits or 16 bytes) encoded in base64 = 22 bytes
*/ */
if (strncmp(pass, "$1$", 3) == 0) { for(s = pass+1; *s && *s != '$'; s++)
for(s = pass + 3; *s && *s != '$'; s++)
; ;
if (*s++ != '$') return 0; if (*s++ != '$') return 0;
len = strlen(s); if ((off = (off_t)(s-pass)) > 4 || off < 3) return 0;
if (len < 22 || len > 24) return 0;
memset(id, '\0', sizeof(id));
strncpy(id, pass, off);
/*
* up to 16 bytes for the salt
*/
for(; *s && *s != '$'; s++)
;
if (*s++ != '$') return 0;
if ((off_t)(s-pass) > 16) return 0;
len = strlen(s);
/*
* the MD5 hash (128 bits or 16 bytes) encoded in base64 = 22 bytes
*/
if ((strcmp(id, "$1$") == 0) && (len < 22 || len > 24)) return 0;
/*
* the SHA-256 hash 43 bytes
*/
if ((strcmp(id, "$5$") == 0) && (len < 42 || len > 44)) return 0;
/*
* the SHA-512 hash 86 bytes
*/
if ((strcmp(id, "$6$") == 0) && (len < 85 || len > 87)) return 0;
/*
* e.g. Blowfish hash
*/
return 1; return 1;
} check_des:
#endif #endif
#if CHECK_DES #if CHECK_DES
if (strlen(pass) != 13) return 0; if (strlen(pass) != 13) return 0;