X-Git-Url: http://git.ozlabs.org/?p=ppp.git;a=blobdiff_plain;f=pppd%2Fchap_ms.c;h=0a5c126159b71c304daea125b46558992909104c;hp=c46ca13f7022eb0f4d3871284286eaa9fd2a7de5;hb=61ebd9732d40eade1a74d55302bdb02c2865cb6c;hpb=2b18ef2f6444c3d18a511de6248f0dbe76cd5356 diff --git a/pppd/chap_ms.c b/pppd/chap_ms.c index c46ca13..0a5c126 100644 --- a/pppd/chap_ms.c +++ b/pppd/chap_ms.c @@ -32,18 +32,22 @@ */ #ifndef lint -static char rcsid[] = "$Id: chap_ms.c,v 1.5 1997/11/27 06:08:10 paulus Exp $"; +static char rcsid[] = "$Id: chap_ms.c,v 1.12 1998/11/24 19:38:05 christos Exp $"; #endif #ifdef CHAPMS #include +#include #include #include #include #include #include #include +#ifdef HAVE_CRYPT_H +#include +#endif #include "pppd.h" #include "chap.h" @@ -77,6 +81,11 @@ static void Expand __P((u_char *, u_char *)); static void Collapse __P((u_char *, u_char *)); #endif +#ifdef MSLANMAN +bool ms_lanman = 0; /* Use LanMan password instead of NT */ + /* Has meaning only with MS-CHAP challenges */ +#endif + static void ChallengeResponse(challenge, pwHash, response) u_char *challenge; /* IN 8 octets */ @@ -252,10 +261,15 @@ ChapMS_NT(rchallenge, rchallenge_len, secret, secret_len, response) MS_ChapResponse *response; { int i; +#ifdef __NetBSD__ + /* NetBSD uses the libc md4 routines which take bytes instead of bits */ + int mdlen = secret_len * 2; +#else + int mdlen = secret_len * 2 * 8; +#endif MD4_CTX md4Context; - u_short hash[MD4_SIGNATURE_SIZE/sizeof(u_short)]; + u_char hash[MD4_SIGNATURE_SIZE]; u_char unicodePassword[MAX_NT_PASSWORD * 2]; - static int low_byte_first = -1; /* Initialize the Unicode version of the secret (== password). */ /* This implicitly supports 8-bit ISO8859/1 characters. */ @@ -264,18 +278,11 @@ ChapMS_NT(rchallenge, rchallenge_len, secret, secret_len, response) unicodePassword[i * 2] = (u_char)secret[i]; MD4Init(&md4Context); - MD4Update(&md4Context, unicodePassword, secret_len * 2 * 8); /* Unicode is 2 bytes/char, *8 for bit count */ - - MD4Final((u_char *) hash, &md4Context); /* Tell MD4 we're done */ + MD4Update(&md4Context, unicodePassword, mdlen); - if (low_byte_first == -1) - low_byte_first = (htons((unsigned short int)1) != 1); - if (low_byte_first == 0) { - for (i = 0; i < MD4_SIGNATURE_SIZE; i += sizeof(u_short)) - hash[i] = htons(hash[i]); - } + MD4Final(hash, &md4Context); /* Tell MD4 we're done */ - ChallengeResponse(rchallenge, (u_char *)hash, response->NTResp); + ChallengeResponse(rchallenge, hash, response->NTResp); } #ifdef MSLANMAN @@ -312,9 +319,6 @@ ChapMS(cstate, rchallenge, rchallenge_len, secret, secret_len) int secret_len; { MS_ChapResponse response; -#ifdef MSLANMAN - extern int ms_lanman; -#endif #if 0 CHAPDEBUG((LOG_INFO, "ChapMS: secret is '%.*s'", secret_len, secret));