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:
parent
24eea8436b
commit
302c744e9a
@ -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.
|
||||||
|
49
src/http.c
49
src/http.c
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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);
|
||||||
|
Loading…
Reference in New Issue
Block a user