summaryrefslogtreecommitdiff
path: root/credential.c
diff options
context:
space:
mode:
authorMatthew John Cheetham <mjcheetham@outlook.com>2023-02-27 17:20:19 (GMT)
committerJunio C Hamano <gitster@pobox.com>2023-02-27 18:40:40 (GMT)
commit6b8dda9a4fdec1638b047506a121df8e15872492 (patch)
tree9ca464e2156957f53bab72b19caf244e243e3baa /credential.c
parent988aad99b44f3fb3f04f4a75cadf0dbb7ac89ffe (diff)
downloadgit-6b8dda9a4fdec1638b047506a121df8e15872492.zip
git-6b8dda9a4fdec1638b047506a121df8e15872492.tar.gz
git-6b8dda9a4fdec1638b047506a121df8e15872492.tar.bz2
http: read HTTP WWW-Authenticate response headers
Read and store the HTTP WWW-Authenticate response headers made for a particular request. This will allow us to pass important authentication challenge information to credential helpers or others that would otherwise have been lost. libcurl only provides us with the ability to read all headers recieved for a particular request, including any intermediate redirect requests or proxies. The lines returned by libcurl include HTTP status lines delinating any intermediate requests such as "HTTP/1.1 200". We use these lines to reset the strvec of WWW-Authenticate header values as we encounter them in order to only capture the final response headers. The collection of all header values matching the WWW-Authenticate header is complicated by the fact that it is legal for header fields to be continued over multiple lines, but libcurl only gives us each physical line a time, not each logical header. This line folding feature is deprecated in RFC 7230 [1] but older servers may still emit them, so we need to handle them. In the future [2] we may be able to leverage functions to read headers from libcurl itself, but as of today we must do this ourselves. [1] https://www.rfc-editor.org/rfc/rfc7230#section-3.2 [2] https://daniel.haxx.se/blog/2022/03/22/a-headers-api-for-libcurl/ Signed-off-by: Matthew John Cheetham <mjcheetham@outlook.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'credential.c')
-rw-r--r--credential.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/credential.c b/credential.c
index f6389a5..897b467 100644
--- a/credential.c
+++ b/credential.c
@@ -22,6 +22,7 @@ void credential_clear(struct credential *c)
free(c->username);
free(c->password);
string_list_clear(&c->helpers, 0);
+ strvec_clear(&c->wwwauth_headers);
credential_init(c);
}