Annotation of embedaddon/curl/lib/http_digest.c, revision 1.1.1.1

1.1       misho       1: /***************************************************************************
                      2:  *                                  _   _ ____  _
                      3:  *  Project                     ___| | | |  _ \| |
                      4:  *                             / __| | | | |_) | |
                      5:  *                            | (__| |_| |  _ <| |___
                      6:  *                             \___|\___/|_| \_\_____|
                      7:  *
                      8:  * Copyright (C) 1998 - 2019, Daniel Stenberg, <daniel@haxx.se>, et al.
                      9:  *
                     10:  * This software is licensed as described in the file COPYING, which
                     11:  * you should have received as part of this distribution. The terms
                     12:  * are also available at https://curl.haxx.se/docs/copyright.html.
                     13:  *
                     14:  * You may opt to use, copy, modify, merge, publish, distribute and/or sell
                     15:  * copies of the Software, and permit persons to whom the Software is
                     16:  * furnished to do so, under the terms of the COPYING file.
                     17:  *
                     18:  * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
                     19:  * KIND, either express or implied.
                     20:  *
                     21:  ***************************************************************************/
                     22: 
                     23: #include "curl_setup.h"
                     24: 
                     25: #if !defined(CURL_DISABLE_HTTP) && !defined(CURL_DISABLE_CRYPTO_AUTH)
                     26: 
                     27: #include "urldata.h"
                     28: #include "strcase.h"
                     29: #include "vauth/vauth.h"
                     30: #include "http_digest.h"
                     31: 
                     32: /* The last 3 #include files should be in this order */
                     33: #include "curl_printf.h"
                     34: #include "curl_memory.h"
                     35: #include "memdebug.h"
                     36: 
                     37: /* Test example headers:
                     38: 
                     39: WWW-Authenticate: Digest realm="testrealm", nonce="1053604598"
                     40: Proxy-Authenticate: Digest realm="testrealm", nonce="1053604598"
                     41: 
                     42: */
                     43: 
                     44: CURLcode Curl_input_digest(struct connectdata *conn,
                     45:                            bool proxy,
                     46:                            const char *header) /* rest of the *-authenticate:
                     47:                                                   header */
                     48: {
                     49:   struct Curl_easy *data = conn->data;
                     50: 
                     51:   /* Point to the correct struct with this */
                     52:   struct digestdata *digest;
                     53: 
                     54:   if(proxy) {
                     55:     digest = &data->state.proxydigest;
                     56:   }
                     57:   else {
                     58:     digest = &data->state.digest;
                     59:   }
                     60: 
                     61:   if(!checkprefix("Digest", header))
                     62:     return CURLE_BAD_CONTENT_ENCODING;
                     63: 
                     64:   header += strlen("Digest");
                     65:   while(*header && ISSPACE(*header))
                     66:     header++;
                     67: 
                     68:   return Curl_auth_decode_digest_http_message(header, digest);
                     69: }
                     70: 
                     71: CURLcode Curl_output_digest(struct connectdata *conn,
                     72:                             bool proxy,
                     73:                             const unsigned char *request,
                     74:                             const unsigned char *uripath)
                     75: {
                     76:   CURLcode result;
                     77:   struct Curl_easy *data = conn->data;
                     78:   unsigned char *path = NULL;
                     79:   char *tmp = NULL;
                     80:   char *response;
                     81:   size_t len;
                     82:   bool have_chlg;
                     83: 
                     84:   /* Point to the address of the pointer that holds the string to send to the
                     85:      server, which is for a plain host or for a HTTP proxy */
                     86:   char **allocuserpwd;
                     87: 
                     88:   /* Point to the name and password for this */
                     89:   const char *userp;
                     90:   const char *passwdp;
                     91: 
                     92:   /* Point to the correct struct with this */
                     93:   struct digestdata *digest;
                     94:   struct auth *authp;
                     95: 
                     96:   if(proxy) {
                     97:     digest = &data->state.proxydigest;
                     98:     allocuserpwd = &conn->allocptr.proxyuserpwd;
                     99:     userp = conn->http_proxy.user;
                    100:     passwdp = conn->http_proxy.passwd;
                    101:     authp = &data->state.authproxy;
                    102:   }
                    103:   else {
                    104:     digest = &data->state.digest;
                    105:     allocuserpwd = &conn->allocptr.userpwd;
                    106:     userp = conn->user;
                    107:     passwdp = conn->passwd;
                    108:     authp = &data->state.authhost;
                    109:   }
                    110: 
                    111:   Curl_safefree(*allocuserpwd);
                    112: 
                    113:   /* not set means empty */
                    114:   if(!userp)
                    115:     userp = "";
                    116: 
                    117:   if(!passwdp)
                    118:     passwdp = "";
                    119: 
                    120: #if defined(USE_WINDOWS_SSPI)
                    121:   have_chlg = digest->input_token ? TRUE : FALSE;
                    122: #else
                    123:   have_chlg = digest->nonce ? TRUE : FALSE;
                    124: #endif
                    125: 
                    126:   if(!have_chlg) {
                    127:     authp->done = FALSE;
                    128:     return CURLE_OK;
                    129:   }
                    130: 
                    131:   /* So IE browsers < v7 cut off the URI part at the query part when they
                    132:      evaluate the MD5 and some (IIS?) servers work with them so we may need to
                    133:      do the Digest IE-style. Note that the different ways cause different MD5
                    134:      sums to get sent.
                    135: 
                    136:      Apache servers can be set to do the Digest IE-style automatically using
                    137:      the BrowserMatch feature:
                    138:      https://httpd.apache.org/docs/2.2/mod/mod_auth_digest.html#msie
                    139: 
                    140:      Further details on Digest implementation differences:
                    141:      http://www.fngtps.com/2006/09/http-authentication
                    142:   */
                    143: 
                    144:   if(authp->iestyle) {
                    145:     tmp = strchr((char *)uripath, '?');
                    146:     if(tmp) {
                    147:       size_t urilen = tmp - (char *)uripath;
                    148:       path = (unsigned char *) aprintf("%.*s", urilen, uripath);
                    149:     }
                    150:   }
                    151:   if(!tmp)
                    152:     path = (unsigned char *) strdup((char *) uripath);
                    153: 
                    154:   if(!path)
                    155:     return CURLE_OUT_OF_MEMORY;
                    156: 
                    157:   result = Curl_auth_create_digest_http_message(data, userp, passwdp, request,
                    158:                                                 path, digest, &response, &len);
                    159:   free(path);
                    160:   if(result)
                    161:     return result;
                    162: 
                    163:   *allocuserpwd = aprintf("%sAuthorization: Digest %s\r\n",
                    164:                           proxy ? "Proxy-" : "",
                    165:                           response);
                    166:   free(response);
                    167:   if(!*allocuserpwd)
                    168:     return CURLE_OUT_OF_MEMORY;
                    169: 
                    170:   authp->done = TRUE;
                    171: 
                    172:   return CURLE_OK;
                    173: }
                    174: 
                    175: void Curl_http_auth_cleanup_digest(struct Curl_easy *data)
                    176: {
                    177:   Curl_auth_digest_cleanup(&data->state.digest);
                    178:   Curl_auth_digest_cleanup(&data->state.proxydigest);
                    179: }
                    180: 
                    181: #endif

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>