Better Digest stuff
authorDaniel Stenberg <daniel@haxx.se>
Thu, 22 May 2003 22:39:38 +0000 (22:39 +0000)
committerDaniel Stenberg <daniel@haxx.se>
Thu, 22 May 2003 22:39:38 +0000 (22:39 +0000)
lib/http.c
lib/http_digest.c
lib/http_digest.h
lib/transfer.c
lib/urldata.h

index a7ad947e18ea9f766c8bb6d46223c6dbe326e2a4..44ef29e8fc1d2207e5015cc1694bf784eb0a5426 100644 (file)
@@ -670,7 +670,9 @@ CURLcode Curl_http(struct connectdata *conn)
     if(result)
       return result;
   }
-  else if((conn->bits.user_passwd) && !checkheaders(data, "Authorization:")) {
+  else if(!data->set.httpdigest && /* not if Digest is enabled */
+          conn->bits.user_passwd &&
+          !checkheaders(data, "Authorization:")) {
     char *authorization;
 
     /* To prevent the user+password to get sent to other than the original
index 2aeb3b8e9a35aa432c24f85f448955e1cccdbbb5..7f62c26b4b12e751c4e40123f279d7a0aa2f8405 100644 (file)
@@ -65,7 +65,8 @@ CURLdigest Curl_input_digest(struct connectdata *conn,
   if(checkprefix("Digest", header)) {
     header += strlen("Digest");
 
-    data->state.digest.algo = CURLDIGESTALGO_MD5; /* default algorithm */
+    /* clear off any former leftovers and init to defaults */
+    Curl_digest_cleanup(data);
 
     while(more) {
       char value[32];
@@ -207,4 +208,21 @@ CURLcode Curl_output_digest(struct connectdata *conn,
   return CURLE_OK;
 }
 
+void Curl_digest_cleanup(struct SessionHandle *data)
+{
+  if(data->state.digest.nonce)
+    free(data->state.digest.nonce);
+  data->state.digest.nonce = NULL;
+
+  if(data->state.digest.cnonce)
+    free(data->state.digest.cnonce);
+  data->state.digest.cnonce = NULL;
+
+  if(data->state.digest.realm)
+    free(data->state.digest.realm);
+  data->state.digest.realm = NULL;
+
+  data->state.digest.algo = CURLDIGESTALGO_MD5; /* default algorithm */
+}
+
 #endif
index 622567361705bdbe1f5aa3cc7cbef542783e62af..1e7feac212f02368ba98d18285876ed0faca5eef 100644 (file)
@@ -43,4 +43,6 @@ CURLdigest Curl_input_digest(struct connectdata *conn, char *header);
 CURLcode Curl_output_digest(struct connectdata *conn,
                             unsigned char *request,
                             unsigned char *uripath);
+void Curl_digest_cleanup(struct SessionHandle *data);
+
 #endif
index c8c1273481418418cc97e5826551aec2f4059397..9bc9f102077e222e01a6aae5665575e0ae3f628d 100644 (file)
@@ -704,15 +704,20 @@ CURLcode Curl_readwrite(struct connectdata *conn,
             }
             else if(checkprefix("WWW-Authenticate:", k->p) &&
                     (401 == k->httpcode) &&
-                    1 /* TODO: replace with a check for Digest authentication
-                         activated */) {
-              CURLdigest dig = Curl_input_digest(conn, k->p+
-                                                 strlen("WWW-Authenticate:"));
-              if(CURLDIGEST_FINE == dig) {
+                    data->set.httpdigest /* Digest authentication is 
+                                            activated */) {
+              CURLdigest dig = CURLDIGEST_BAD;
+
+              if(data->state.digest.nonce)
+                infof(data, "Authentication problem. Ignoring this.");
+              else
+                dig = Curl_input_digest(conn,
+                                        k->p+strlen("WWW-Authenticate:"));
+
+              if(CURLDIGEST_FINE == dig)
                 /* We act on it. Store our new url, which happens to be
                    the same one we already use! */
                 conn->newurl = strdup(data->change.url); /* clone string */
-              }
             }
             else if ((k->httpcode >= 300 && k->httpcode < 400) &&
                      checkprefix("Location:", k->p)) {
@@ -797,7 +802,7 @@ CURLcode Curl_readwrite(struct connectdata *conn,
               /* HTTP-only checks */
               if (conn->newurl) {
                 /* abort after the headers if "follow Location" is set */
-                infof (data, "Follow to new URL: %s\n", conn->newurl);
+                infof (data, "Send request to this URL: %s\n", conn->newurl);
                 k->keepon &= ~KEEP_READ;
                 FD_ZERO(&k->rkeepfd);
                 *done = TRUE;
@@ -1568,7 +1573,7 @@ CURLcode Curl_follow(struct SessionHandle *data,
   data->change.url = newurl;
   newurl = NULL; /* don't free! */
 
-  infof(data, "Follows Location: to new URL: '%s'\n", data->change.url);
+  infof(data, "Issue another request to this URL: '%s'\n", data->change.url);
 
   /*
    * We get here when the HTTP code is 300-399. We need to perform
index 31a7553554ed43cd7100a0be7c104c1f217b9cd5..58f70067738cc67ea6ac19dad9e52982c4eb0699 100644 (file)
@@ -671,6 +671,7 @@ struct UserDefined {
   char *set_proxy;   /* proxy to use */
   long use_port;     /* which port to use (when not using default) */
   char *userpwd;     /* <user:password>, if used */
+  bool httpdigest;   /* if HTTP Digest is enabled */
   char *set_range;   /* range, if used. See README for detailed specification
                         on this syntax. */
   long followlocation; /* as in HTTP Location: */