Commit bc61920d authored by Tyler's avatar Tyler Committed by Luca Barbato

http: header field names are case insensitive

Amazon S3 sends header field names all lowercase.
This is actually acceptable according to the HTTP standard.

http://tools.ietf.org/html/rfc2616#section-4.2Signed-off-by: 's avatarLuca Barbato <lu_zero@gentoo.org>
parent 991f3de1
...@@ -246,12 +246,12 @@ static int process_line(URLContext *h, char *line, int line_count, ...@@ -246,12 +246,12 @@ static int process_line(URLContext *h, char *line, int line_count,
p++; p++;
while (isspace(*p)) while (isspace(*p))
p++; p++;
if (!strcmp(tag, "Location")) { if (!strcasecmp(tag, "Location")) {
strcpy(s->location, p); strcpy(s->location, p);
*new_location = 1; *new_location = 1;
} else if (!strcmp (tag, "Content-Length") && s->filesize == -1) { } else if (!strcasecmp (tag, "Content-Length") && s->filesize == -1) {
s->filesize = atoll(p); s->filesize = atoll(p);
} else if (!strcmp (tag, "Content-Range")) { } else if (!strcasecmp (tag, "Content-Range")) {
/* "bytes $from-$to/$document_size" */ /* "bytes $from-$to/$document_size" */
const char *slash; const char *slash;
if (!strncmp (p, "bytes ", 6)) { if (!strncmp (p, "bytes ", 6)) {
...@@ -261,14 +261,14 @@ static int process_line(URLContext *h, char *line, int line_count, ...@@ -261,14 +261,14 @@ static int process_line(URLContext *h, char *line, int line_count,
s->filesize = atoll(slash+1); s->filesize = atoll(slash+1);
} }
h->is_streamed = 0; /* we _can_ in fact seek */ h->is_streamed = 0; /* we _can_ in fact seek */
} else if (!strcmp (tag, "Transfer-Encoding") && !strncasecmp(p, "chunked", 7)) { } else if (!strcasecmp (tag, "Transfer-Encoding") && !strncasecmp(p, "chunked", 7)) {
s->filesize = -1; s->filesize = -1;
s->chunksize = 0; s->chunksize = 0;
} else if (!strcmp (tag, "WWW-Authenticate")) { } else if (!strcasecmp (tag, "WWW-Authenticate")) {
ff_http_auth_handle_header(&s->auth_state, tag, p); ff_http_auth_handle_header(&s->auth_state, tag, p);
} else if (!strcmp (tag, "Authentication-Info")) { } else if (!strcasecmp (tag, "Authentication-Info")) {
ff_http_auth_handle_header(&s->auth_state, tag, p); ff_http_auth_handle_header(&s->auth_state, tag, p);
} else if (!strcmp (tag, "Connection")) { } else if (!strcasecmp (tag, "Connection")) {
if (!strcmp(p, "close")) if (!strcmp(p, "close"))
s->willclose = 1; s->willclose = 1;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment