From c5eb2fd61869d33e48d55007e6d262c2b80e01e8 Mon Sep 17 00:00:00 2001 From: Steve Holme Date: Sun, 14 Apr 2019 03:17:23 +0100 Subject: md4: Move the WinCrypt implementation out of the NTLM code --- lib/curl_md4.h | 8 +++++--- lib/curl_ntlm_core.c | 14 ++------------ lib/md4.c | 54 +++++++++++++++++++++++++++++++++++++++++++++++++--- 3 files changed, 58 insertions(+), 18 deletions(-) diff --git a/lib/curl_md4.h b/lib/curl_md4.h index 59935480d..828b21af4 100644 --- a/lib/curl_md4.h +++ b/lib/curl_md4.h @@ -25,7 +25,8 @@ #include "curl_setup.h" #if defined(USE_GNUTLS_NETTLE) || defined(USE_GNUTLS) || \ - defined(USE_OPENSSL) || defined(USE_SECTRANSP) || defined(USE_NSS) || \ + defined(USE_OPENSSL) || defined(USE_SECTRANSP) || \ + defined(USE_WIN32_CRYPTO) || defined(USE_NSS) || \ defined(USE_OS400CRYPTO) || \ (defined(USE_MBEDTLS) && !defined(MBEDTLS_MD4_C)) @@ -34,8 +35,9 @@ void Curl_md4it(unsigned char *output, const unsigned char *input, size_t len); #endif /* defined(USE_GNUTLS_NETTLE) || defined(USE_GNUTLS) || - defined(USE_OPENSSL) || defined(USE_SECTRANSP) || defined(USE_NSS) || - defined(USE_OS400CRYPTO) || + defined(USE_OPENSSL) || defined(USE_SECTRANSP) || \ + defined(USE_WIN32_CRYPTO) || defined(USE_NSS) || \ + defined(USE_OS400CRYPTO) || \ (defined(USE_MBEDTLS) && !defined(MBEDTLS_MD4_C)) */ #endif /* HEADER_CURL_MD4_H */ diff --git a/lib/curl_ntlm_core.c b/lib/curl_ntlm_core.c index 332d9409a..abf4ac0b5 100644 --- a/lib/curl_ntlm_core.c +++ b/lib/curl_ntlm_core.c @@ -110,6 +110,7 @@ # include "curl_md4.h" #elif defined(USE_WIN32_CRYPTO) # include +# include "curl_md4.h" #else # error "Can't compile NTLM support without a crypto library." #endif @@ -584,18 +585,7 @@ CURLcode Curl_ntlm_core_mk_nt_hash(struct Curl_easy *data, #elif defined(USE_OS400CRYPTO) Curl_md4it(ntbuffer, pw, 2 * len); #elif defined(USE_WIN32_CRYPTO) - HCRYPTPROV hprov; - if(CryptAcquireContext(&hprov, NULL, NULL, PROV_RSA_FULL, - CRYPT_VERIFYCONTEXT)) { - HCRYPTHASH hhash; - if(CryptCreateHash(hprov, CALG_MD4, 0, 0, &hhash)) { - DWORD length = 16; - CryptHashData(hhash, pw, (unsigned int)len * 2, 0); - CryptGetHashParam(hhash, HP_HASHVAL, ntbuffer, &length, 0); - CryptDestroyHash(hhash); - } - CryptReleaseContext(hprov, 0); - } + Curl_md4it(ntbuffer, pw, 2 * len); #endif memset(ntbuffer + 16, 0, 21 - 16); diff --git a/lib/md4.c b/lib/md4.c index eaf513774..45a17b8b0 100644 --- a/lib/md4.c +++ b/lib/md4.c @@ -134,6 +134,52 @@ static void MD4_Final(unsigned char *result, MD4_CTX *ctx) } } +#elif defined(USE_WIN32_CRYPTO) + +#include + +#include "curl_md4.h" +#include "warnless.h" +#include "curl_memory.h" + /* The last #include file should be: */ +#include "memdebug.h" + +typedef struct { + HCRYPTPROV hCryptProv; + HCRYPTHASH hHash; +} MD4_CTX; + +static void MD4_Init(MD4_CTX *ctx) +{ + ctx->hCryptProv = 0; + ctx->hHash = 0; + + if(CryptAcquireContext(&ctx->hCryptProv, NULL, NULL, PROV_RSA_FULL, + CRYPT_VERIFYCONTEXT)) { + CryptCreateHash(ctx->hCryptProv, CALG_MD4, 0, 0, &ctx->hHash); + } +} + +static void MD4_Update(MD4_CTX *ctx, const void *data, unsigned long size) +{ + CryptHashData(ctx->hHash, data, (unsigned int) size, 0); +} + +static void MD4_Final(unsigned char *result, MD4_CTX *ctx) +{ + unsigned long length = 0; + + CryptGetHashParam(ctx->hHash, HP_HASHVAL, NULL, &length, 0); + if(length == MD4_DIGEST_LENGTH) + CryptGetHashParam(ctx->hHash, HP_HASHVAL, result, &length, 0); + + if(ctx->hHash) + CryptDestroyHash(ctx->hHash); + + if(ctx->hCryptProv) + CryptReleaseContext(ctx->hCryptProv, 0); +} + #elif defined(USE_NSS) || defined(USE_OS400CRYPTO) || \ (defined(USE_OPENSSL) && defined(OPENSSL_NO_MD4)) || \ (defined(USE_MBEDTLS) && !defined(MBEDTLS_MD4_C)) @@ -431,7 +477,8 @@ static void MD4_Final(unsigned char *result, MD4_CTX *ctx) #endif /* CRYPTO LIBS */ #if defined(USE_GNUTLS_NETTLE) || defined(USE_GNUTLS) || \ - defined(USE_OPENSSL) || defined(USE_SECTRANSP) || defined(USE_NSS) || \ + defined(USE_OPENSSL) || defined(USE_SECTRANSP) || \ + defined(USE_WIN32_CRYPTO) || defined(USE_NSS) || \ defined(USE_OS400CRYPTO) || \ (defined(USE_OPENSSL) && defined(OPENSSL_NO_MD4)) || \ (defined(USE_MBEDTLS) && !defined(MBEDTLS_MD4_C)) @@ -445,6 +492,7 @@ void Curl_md4it(unsigned char *output, const unsigned char *input, size_t len) } #endif /* defined(USE_GNUTLS_NETTLE) || defined(USE_GNUTLS) || - defined(USE_OPENSSL) || defined(USE_SECTRANSP) || defined(USE_NSS) || - defined(USE_OS400CRYPTO) || + defined(USE_OPENSSL) || defined(USE_SECTRANSP) || \ + defined(USE_WIN32_CRYPTO) || defined(USE_NSS) || \ + defined(USE_OS400CRYPTO) || \ (defined(USE_MBEDTLS) && !defined(MBEDTLS_MD4_C)) */ -- cgit v1.2.1