From 9fce2c55d4b0273ac99b59bd8cb982a6d96b88cf Mon Sep 17 00:00:00 2001 From: Daniel Stenberg Date: Tue, 17 Dec 2024 23:56:42 +0100 Subject: [PATCH] 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 Conflict:context adapt Reference:https://github.com/curl/curl/commit/9fce2c55d4b0273ac99b59bd8cb982a6d96b88cf --- lib/netrc.c | 7 +++++- tests/data/Makefile.inc | 2 +- tests/data/test2005 | 55 ++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 62 insertions(+), 2 deletions(-) create mode 100644 tests/data/test2005 diff --git a/lib/netrc.c b/lib/netrc.c index cbc86484f..b517c1dfa 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.inc b/tests/data/Makefile.inc index bd9a0bbaa..105108309 100644 --- a/tests/data/Makefile.inc +++ b/tests/data/Makefile.inc @@ -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 \ \ -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 000000000..91e256298 --- /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: */* + + + + -- 2.33.0