From 605aa03ac198e049e6779df5ccc433b0934e40aa Mon Sep 17 00:00:00 2001 From: Daniel Stenberg Date: Mon, 5 Apr 2021 12:11:30 +0200 Subject: [PATCH] http_proxy: only loop on 407 + close if we have credentials MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit ... to fix the retry-loop. Add test 718 to verify. Reported-by: Daniel Kurečka Fixes #6828 Closes #6850 --- lib/http_proxy.c | 3 ++- tests/data/Makefile.inc | 1 + tests/data/test718 | 59 +++++++++++++++++++++++++++++++++++++++++ 3 files changed, 62 insertions(+), 1 deletion(-) create mode 100644 tests/data/test718 diff --git a/lib/http_proxy.c b/lib/http_proxy.c index 732fea7e3..f403ffc0e 100644 --- a/lib/http_proxy.c +++ b/lib/http_proxy.c @@ -358,7 +358,8 @@ static CURLcode CONNECT(struct Curl_easy *data, break; } else if(gotbytes <= 0) { - if(data->set.proxyauth && data->state.authproxy.avail) { + if(data->set.proxyauth && data->state.authproxy.avail && + data->state.aptr.proxyuserpwd) { /* proxy auth was requested and there was proxy auth available, then deem this as "mere" proxy disconnect */ conn->bits.proxy_connect_closed = TRUE; diff --git a/tests/data/Makefile.inc b/tests/data/Makefile.inc index 6ae2a249b..d083baffa 100644 --- a/tests/data/Makefile.inc +++ b/tests/data/Makefile.inc @@ -94,6 +94,7 @@ test670 test671 test672 test673 test674 test675 \ \ test700 test701 test702 test703 test704 test705 test706 test707 test708 \ test709 test710 test711 test712 test713 test714 test715 test716 test717 \ +test718 \ \ test800 test801 test802 test803 test804 test805 test806 test807 test808 \ test809 test810 test811 test812 test813 test814 test815 test816 test817 \ diff --git a/tests/data/test718 b/tests/data/test718 new file mode 100644 index 000000000..6ab6c5a31 --- /dev/null +++ b/tests/data/test718 @@ -0,0 +1,59 @@ + + + +HTTP +HTTP GET +HTTP CONNECT +HTTP proxy +proxytunnel +HTTP proxy Digest auth + + + +# Server-side + + +# this is returned first since we get no proxy-auth + +HTTP/1.1 407 Authorization Required to proxy me swsclose +Proxy-Authenticate: Digest realm="weirdorealm", nonce="12345" + + + +HTTP/1.1 407 Authorization Required to proxy me swsclose +Proxy-Authenticate: Digest realm="weirdorealm", nonce="12345" + + + +# Client-side + + +http + + +!SSPI +crypto +proxy + + +HTTP proxy CONNECT (no auth) with proxy returning 407 and closing + + +http://test.remote.haxx.se.%TESTNUMBER:8990/path/%TESTNUMBER0002 --proxy http://%HOSTIP:%HTTPPORT --proxytunnel + + + +# Verify data after the test has been "shot" + + +CONNECT test.remote.haxx.se.%TESTNUMBER:8990 HTTP/1.1 +Host: test.remote.haxx.se.%TESTNUMBER:8990 +User-Agent: curl/%VERSION +Proxy-Connection: Keep-Alive + + + +56 + + +