Browse Source

http: use newer curl options for setting credentials

We give the username and password to curl by sticking them
in a buffer of the form "user:pass" and handing the result
to CURLOPT_USERPWD. Since curl 7.19.1, there is a split
mechanism, where you can specify each element individually.

This has the advantage that a username can contain a ":"
character. It also is less code for us, since we can hand
our strings over to curl directly. And since curl 7.17.0 and
higher promise to copy the strings for us, we we don't even
have to worry about memory ownership issues.

Unfortunately, we have to keep the ugly code for old curl
around, but as it is now nicely #if'd out, we can easily get
rid of it when we decide that 7.19.1 is "old enough".

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
maint
Jeff King 13 years ago committed by Junio C Hamano
parent
commit
6f4c347ca1
  1. 13
      http.c

13
http.c

@ -210,14 +210,23 @@ static int http_options(const char *var, const char *value, void *cb)


static void init_curl_http_auth(CURL *result) static void init_curl_http_auth(CURL *result)
{ {
if (http_auth.username) { if (!http_auth.username)
return;

credential_fill(&http_auth);

#if LIBCURL_VERSION_NUM >= 0x071301
curl_easy_setopt(result, CURLOPT_USERNAME, http_auth.username);
curl_easy_setopt(result, CURLOPT_PASSWORD, http_auth.password);
#else
{
static struct strbuf up = STRBUF_INIT; static struct strbuf up = STRBUF_INIT;
credential_fill(&http_auth);
strbuf_reset(&up); strbuf_reset(&up);
strbuf_addf(&up, "%s:%s", strbuf_addf(&up, "%s:%s",
http_auth.username, http_auth.password); http_auth.username, http_auth.password);
curl_easy_setopt(result, CURLOPT_USERPWD, up.buf); curl_easy_setopt(result, CURLOPT_USERPWD, up.buf);
} }
#endif
} }


static int has_cert_password(void) static int has_cert_password(void)

Loading…
Cancel
Save