From: Daniel Stenberg Date: Tue, 17 Dec 2024 22:56:42 +0000 (+0100) Subject: netrc: fix password-only entries X-Git-Tag: curl-8_12_0~320 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=9fce2c55d4b0273ac99b59bd8cb982a6d96b88cf;p=thirdparty%2Fcurl.git netrc: fix password-only entries When a specific hostname matched, and only a password is set before another machine is specified in the netrc file, the parser would not be happy and stop there and return the password-only state. It instead continued and did not return a match. Add test 2005 to verify this case Regression from e9b9bba, shipped in 8.11.1. Reported-by: Ben Zanin Fixes #15767 Closes #15768 --- diff --git a/lib/netrc.c b/lib/netrc.c index cbc86484f6..b517c1dfab 100644 --- a/lib/netrc.c +++ b/lib/netrc.c @@ -267,7 +267,8 @@ static int parsenetrc(struct store_netrc *store, retcode = NETRC_FAILED; /* allocation failed */ goto out; } - found |= FOUND_PASSWORD; + if(!specific_login || our_login) + found |= FOUND_PASSWORD; keyword = NONE; } else if(strcasecompare("login", tok)) @@ -276,6 +277,10 @@ static int parsenetrc(struct store_netrc *store, keyword = PASSWORD; else if(strcasecompare("machine", tok)) { /* a new machine here */ + if(found & FOUND_PASSWORD) { + done = TRUE; + break; + } state = HOSTFOUND; keyword = NONE; found = 0; diff --git a/tests/data/Makefile.am b/tests/data/Makefile.am index bd9a0bbaaf..105108309d 100644 --- a/tests/data/Makefile.am +++ b/tests/data/Makefile.am @@ -238,7 +238,7 @@ test1941 test1942 test1943 test1944 test1945 test1946 test1947 test1948 \ test1955 test1956 test1957 test1958 test1959 test1960 test1964 \ test1970 test1971 test1972 test1973 test1974 test1975 test1976 \ \ -test2000 test2001 test2002 test2003 test2004 \ +test2000 test2001 test2002 test2003 test2004 test2005 \ \ test2023 \ test2024 test2025 test2026 test2027 test2028 test2029 test2030 test2031 \ diff --git a/tests/data/test2005 b/tests/data/test2005 new file mode 100644 index 0000000000..91e256298a --- /dev/null +++ b/tests/data/test2005 @@ -0,0 +1,55 @@ + + + +HTTP +netrc + + +# +# Server-side + + +HTTP/1.1 200 OK +Date: Fri, 05 Aug 2022 10:09:00 GMT +Server: test-server/fake +Content-Type: text/plain +Content-Length: 6 +Connection: close + +-foo- + + + +# +# Client-side + + +http + + +netrc match with password only in file, no username. machine follows + + +--netrc-optional --netrc-file %LOGDIR/netrc%TESTNUMBER http://%HOSTIP:%HTTPPORT/ + + +machine %HOSTIP +password 5up3r53cr37 + +machine example.com + + + +# +# Verify data after the test has been "shot" + + +GET / HTTP/1.1 +Host: %HOSTIP:%HTTPPORT +Authorization: Basic %b64[:5up3r53cr37]b64% +User-Agent: curl/%VERSION +Accept: */* + + + +