block/curl: HTTP header fields allow whitespace around values

RFC 7230 section 3.2 indicates that whitespace is permitted between
the field name and field value and after the field value.

Signed-off-by: David Edmondson <david.edmondson@oracle.com>
Message-Id: <20200224101310.101169-2-david.edmondson@oracle.com>
Reviewed-by: Max Reitz <mreitz@redhat.com>
Signed-off-by: Max Reitz <mreitz@redhat.com>
This commit is contained in:
David Edmondson 2020-02-24 10:13:09 +00:00 committed by Max Reitz
parent c13de3b32f
commit 7788a31939

View File

@ -214,12 +214,35 @@ static size_t curl_header_cb(void *ptr, size_t size, size_t nmemb, void *opaque)
{ {
BDRVCURLState *s = opaque; BDRVCURLState *s = opaque;
size_t realsize = size * nmemb; size_t realsize = size * nmemb;
const char *accept_line = "Accept-Ranges: bytes"; const char *header = (char *)ptr;
const char *end = header + realsize;
const char *accept_ranges = "Accept-Ranges:";
const char *bytes = "bytes";
if (realsize >= strlen(accept_line) if (realsize >= strlen(accept_ranges)
&& strncmp((char *)ptr, accept_line, strlen(accept_line)) == 0) { && strncmp(header, accept_ranges, strlen(accept_ranges)) == 0) {
char *p = strchr(header, ':') + 1;
/* Skip whitespace between the header name and value. */
while (p < end && *p && g_ascii_isspace(*p)) {
p++;
}
if (end - p >= strlen(bytes)
&& strncmp(p, bytes, strlen(bytes)) == 0) {
/* Check that there is nothing but whitespace after the value. */
p += strlen(bytes);
while (p < end && *p && g_ascii_isspace(*p)) {
p++;
}
if (p == end || !*p) {
s->accept_range = true; s->accept_range = true;
} }
}
}
return realsize; return realsize;
} }