Skip to content

Commit

Permalink
builtin.vcl: Delete Content-Range header where it has no meaning
Browse files Browse the repository at this point in the history
Since 4ab1100 (see also varnishcache#3246), we fail backend
responses with an unexpected Content-Range.

Yet RFC9110 states:

	The Content-Range header field has no meaning for status codes that do
	not explicitly describe its semantic.

	https://www.rfc-editor.org/rfc/rfc9110.html#section-14.4

The semantic is described for status codes 206 and 416, so the obvious
implementation change would be for core code to only consider Content-Range for
these status codes.

But there might be scenarios where a stricter-than-RFC check is intended, so we
keep that in core code and change builtin.vcl to remove the header where it has
no semantic.
  • Loading branch information
nigoroll committed Jul 23, 2024
1 parent 7292f92 commit 82aa447
Show file tree
Hide file tree
Showing 2 changed files with 60 additions and 0 deletions.
7 changes: 7 additions & 0 deletions bin/varnishd/builtin.vcl
Original file line number Diff line number Diff line change
Expand Up @@ -210,6 +210,7 @@ sub vcl_backend_response {
}

sub vcl_builtin_backend_response {
call vcl_beresp_range;
if (bereq.uncacheable) {
return (deliver);
}
Expand Down Expand Up @@ -245,6 +246,12 @@ sub vcl_beresp_vary {
}
}

sub vcl_beresp_range {
if (beresp.status != 206 && beresp.status != 416) {
unset beresp.http.Content-Range;
}
}

sub vcl_beresp_hitmiss {
set beresp.ttl = 120s;
set beresp.uncacheable = true;
Expand Down
53 changes: 53 additions & 0 deletions bin/varnishtest/tests/c00034.vtc
Original file line number Diff line number Diff line change
Expand Up @@ -273,6 +273,18 @@ varnish v1 -vcl+backend {
return (pass);
}
}

# skip built-in vcl_beresp_range
sub vcl_backend_response {
if (bereq.uncacheable) {
return (deliver);
}
call vcl_beresp_stale;
call vcl_beresp_cookie;
call vcl_beresp_control;
call vcl_beresp_vary;
return (deliver);
}
}

client c8 {
Expand Down Expand Up @@ -326,3 +338,44 @@ client c9 {
expect resp.status == 200
expect resp.bodylen == 256
} -run

# built-in vcl has vcl_beresp_range to ignore content-range for responses but
# 206, 416
#
server s1 {
rxreq
expect req.url == "/?unexpected=content-range"
expect req.http.range == <undef>
txresp -hdr "content-range: bytes 0-49/100" -bodylen 40

rxreq
expect req.url == "/?unexpected=unsatisfied-range"
expect req.http.range == <undef>
txresp -hdr "content-range: bytes */100" -bodylen 100

rxreq
expect req.url == "/?invalid=content-range"
expect req.http.range == <undef>
txresp -hdr "content-range: bytes=0-99/100" -bodylen 100

} -start

varnish v1 -vcl+backend {
sub vcl_recv {
return (pass);
}
}

client c10 {
txreq -url "/?unexpected=content-range"
rxresp
expect resp.status == 200

txreq -url "/?unexpected=unsatisfied-range"
rxresp
expect resp.status == 200

txreq -url "/?invalid=content-range"
rxresp
expect resp.status == 200
} -run

0 comments on commit 82aa447

Please sign in to comment.