From: Steve Holme Date: Mon, 4 Jun 2012 19:22:06 +0000 (+0100) Subject: sasl: Added service parameter to Curl_sasl_create_digest_md5_message() X-Git-Tag: curl-7_27_0~281 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=bf51b8c07af9f6eb16c82673c66ce7402c067172;p=thirdparty%2Fcurl.git sasl: Added service parameter to Curl_sasl_create_digest_md5_message() Added a service type parameter to Curl_sasl_create_digest_md5_message() to allow the function to be used by different services rather than being hard coded to "smtp". --- diff --git a/lib/curl_sasl.c b/lib/curl_sasl.c index 18c2782bcf..9f5fe95fb9 100644 --- a/lib/curl_sasl.c +++ b/lib/curl_sasl.c @@ -240,6 +240,7 @@ CURLcode Curl_sasl_create_cram_md5_message(struct SessionHandle *data, * chlg64 [in] - Pointer to the input buffer. * userp [in] - The user name. * passdwp [in] - The user's password. + * service [in] - The service type such as www, smtp or pop * outptr [in/out] - The address where a pointer to newly allocated memory * holding the result will be stored upon completion. * outlen [out] - The length of the output message. @@ -250,6 +251,7 @@ CURLcode Curl_sasl_create_digest_md5_message(struct SessionHandle *data, const char* chlg64, const char* userp, const char* passwdp, + const char* service, char **outptr, size_t *outlen) { static const char table16[] = "0123456789abcdef"; @@ -271,7 +273,7 @@ CURLcode Curl_sasl_create_digest_md5_message(struct SessionHandle *data, char cnonce[] = "12345678"; /* will be changed */ char method[] = "AUTHENTICATE"; char qop[] = "auth"; - char uri[128] = "smtp/"; + char uri[128]; char response[512]; result = Curl_base64_decode(chlg64, &chlg, &chlglen); @@ -341,7 +343,9 @@ CURLcode Curl_sasl_create_digest_md5_message(struct SessionHandle *data, for(i = 0; i < MD5_DIGEST_LEN; i++) snprintf(&HA1_hex[2 * i], 3, "%02x", digest[i]); - /* Orepare URL string, append realm to the protocol */ + /* Prepare the URL string */ + strcpy(uri, service); + strcat(uri, "/"); strcat(uri, realm); /* Calculate H(A2) */ diff --git a/lib/curl_sasl.h b/lib/curl_sasl.h index 892da81ec7..97e9bcd755 100644 --- a/lib/curl_sasl.h +++ b/lib/curl_sasl.h @@ -58,6 +58,7 @@ CURLcode Curl_sasl_create_digest_md5_message(struct SessionHandle *data, const char* chlg64, const char* user, const char* passwdp, + const char* service, char **outptr, size_t *outlen); #endif diff --git a/lib/smtp.c b/lib/smtp.c index fc952481ba..c251e50f55 100644 --- a/lib/smtp.c +++ b/lib/smtp.c @@ -752,7 +752,8 @@ static CURLcode smtp_state_authdigest_resp(struct connectdata *conn, ; result = Curl_sasl_create_digest_md5_message(data, chlg64, conn->user, - conn->passwd, &rplyb64, &len); + conn->passwd, "smtp", + &rplyb64, &len); if(!result) { if(rplyb64) {