1
0
mirror of https://github.com/moparisthebest/wget synced 2024-07-03 16:38:41 -04:00

[svn] Don't complain about "unknown authentication scheme" if the scheme

is Basic.  Allow empty user-agent meaning "don't send User-Agent".
This commit is contained in:
hniksic 2005-05-06 10:16:15 -07:00
parent 24eea8436b
commit 302c744e9a
3 changed files with 34 additions and 31 deletions

View File

@ -1,3 +1,12 @@
2005-05-06 Hrvoje Niksic <hniksic@xemacs.org>
* init.c (cmd_spec_useragent): Allow empty User-Agent.
* http.c (gethttp): Don't print "unknown authentication scheme"
for failed Basic authentication.
(SET_USER_AGENT): Don't set user-agent if opt.useragent is empty.
(gethttp): Use alloca for allocation of www_authenticate.
2005-05-06 Hrvoje Niksic <hniksic@xemacs.org> 2005-05-06 Hrvoje Niksic <hniksic@xemacs.org>
* main.c (print_help): Fix wording of --secure-protocol help text. * main.c (print_help): Fix wording of --secure-protocol help text.

View File

@ -1113,13 +1113,13 @@ time_t http_atotm PARAMS ((const char *));
&& (ISSPACE (line[sizeof (string_constant) - 1]) \ && (ISSPACE (line[sizeof (string_constant) - 1]) \
|| !line[sizeof (string_constant) - 1])) || !line[sizeof (string_constant) - 1]))
#define SET_USER_AGENT(req) \ #define SET_USER_AGENT(req) do { \
if (opt.useragent) \ if (!opt.useragent) \
request_set_header (req, "User-Agent", opt.useragent, rel_none); \
else \
request_set_header (req, "User-Agent", \ request_set_header (req, "User-Agent", \
aprintf ("Wget/%s", version_string), rel_value); aprintf ("Wget/%s", version_string), rel_value); \
else if (*opt.useragent) \
request_set_header (req, "User-Agent", opt.useragent, rel_none); \
} while (0)
/* Retrieve a document through HTTP protocol. It recognizes status /* Retrieve a document through HTTP protocol. It recognizes status
code, and correctly handles redirections. It closes the network code, and correctly handles redirections. It closes the network
@ -1622,18 +1622,11 @@ gethttp (struct url *u, struct http_stat *hs, int *dt, struct url *proxy)
CLOSE_INVALIDATE (sock); CLOSE_INVALIDATE (sock);
} }
pconn.authorized = 0; pconn.authorized = 0;
if (auth_finished || !(user && passwd)) if (!auth_finished && (user && passwd))
{ {
/* If we have tried it already, then there is not point /* IIS sends multiple copies of WWW-Authenticate, one with
retrying it. */ the value "negotiate", and other(s) with data. Loop over
logputs (LOG_NOTQUIET, _("Authorization failed.\n")); all the occurrences and pick the one we recognize. */
}
else
{
/* IIS sometimes sends two instances of WWW-Authenticate
header, one with the keyword "negotiate", and other with
useful data. Loop over all occurrences of this header
and use the one we recognize. */
int wapos; int wapos;
const char *wabeg, *waend; const char *wabeg, *waend;
char *www_authenticate = NULL; char *www_authenticate = NULL;
@ -1643,18 +1636,20 @@ gethttp (struct url *u, struct http_stat *hs, int *dt, struct url *proxy)
++wapos) ++wapos)
if (known_authentication_scheme_p (wabeg, waend)) if (known_authentication_scheme_p (wabeg, waend))
{ {
www_authenticate = strdupdelim (wabeg, waend); BOUNDED_TO_ALLOCA (wabeg, waend, www_authenticate);
break; break;
} }
/* If the authentication header is missing or recognized, or
if the authentication scheme is "Basic" (which we send by if (!www_authenticate)
default), there's no sense in retrying. */ /* If the authentication header is missing or
if (!www_authenticate unrecognized, there's no sense in retrying. */
|| BEGINS_WITH (www_authenticate, "Basic"))
{
xfree_null (www_authenticate);
logputs (LOG_NOTQUIET, _("Unknown authentication scheme.\n")); logputs (LOG_NOTQUIET, _("Unknown authentication scheme.\n"));
} else if (BEGINS_WITH (www_authenticate, "Basic"))
/* If the authentication scheme is "Basic", which we send
by default, there's no sense in retrying either. (This
should be changed when we stop sending "Basic" data by
default.) */
;
else else
{ {
char *pth; char *pth;
@ -1669,10 +1664,10 @@ gethttp (struct url *u, struct http_stat *hs, int *dt, struct url *proxy)
if (BEGINS_WITH (www_authenticate, "NTLM")) if (BEGINS_WITH (www_authenticate, "NTLM"))
ntlm_seen = 1; ntlm_seen = 1;
xfree (pth); xfree (pth);
xfree (www_authenticate);
goto retry_with_auth; goto retry_with_auth;
} }
} }
logputs (LOG_NOTQUIET, _("Authorization failed.\n"));
request_free (req); request_free (req);
return AUTHFAILED; return AUTHFAILED;
} }

View File

@ -1292,9 +1292,8 @@ cmd_spec_timeout (const char *com, const char *val, void *place_ignored)
static int static int
cmd_spec_useragent (const char *com, const char *val, void *place_ignored) cmd_spec_useragent (const char *com, const char *val, void *place_ignored)
{ {
/* Just check for empty string and newline, so we don't throw total /* Disallow embedded newlines. */
junk to the server. */ if (strchr (val, '\n'))
if (!*val || strchr (val, '\n'))
{ {
fprintf (stderr, _("%s: %s: Invalid value `%s'.\n"), fprintf (stderr, _("%s: %s: Invalid value `%s'.\n"),
exec_name, com, val); exec_name, com, val);