From: Stefan Bühler Date: Thu, 12 Nov 2015 10:09:21 +0000 (+0100) Subject: sasl_sspi: fixed unicode build for digest authentication X-Git-Tag: curl-7_46_0~77 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=b6baa108fac4d5c251fd4951867444d7cb92fe96;p=curl sasl_sspi: fixed unicode build for digest authentication Closes #525 --- diff --git a/lib/curl_sasl_sspi.c b/lib/curl_sasl_sspi.c index 3e2e49571..84fce9f24 100644 --- a/lib/curl_sasl_sspi.c +++ b/lib/curl_sasl_sspi.c @@ -418,6 +418,7 @@ CURLcode Curl_sasl_create_digest_http_message(struct SessionHandle *data, SECURITY_STATUS status; unsigned long attrs; TimeStamp expiry; /* For Windows 9x compatibility of SSPI calls */ + TCHAR *spn; (void) data; @@ -489,12 +490,20 @@ CURLcode Curl_sasl_create_digest_http_message(struct SessionHandle *data, resp_buf.pvBuffer = output_token; resp_buf.cbBuffer = curlx_uztoul(token_max); + spn = Curl_convert_UTF8_to_tchar((char *) uripath); + if(!spn) { + free(output_token); + + return CURLE_OUT_OF_MEMORY; + } + /* Generate our reponse message */ status = s_pSecFn->InitializeSecurityContext(&credentials, NULL, - (TCHAR *) uripath, + spn, ISC_REQ_USE_HTTP_STYLE, 0, 0, &chlg_desc, 0, &context, &resp_desc, &attrs, &expiry); + Curl_unicodefree(spn); if(status == SEC_I_COMPLETE_NEEDED || status == SEC_I_COMPLETE_AND_CONTINUE)