mirror of
https://github.com/ninenines/cowboy.git
synced 2025-07-14 12:20:24 +00:00
Don't raise an error for malformed accept-encoding headers in compressed
This commit is contained in:
parent
63b17e4edf
commit
8ffbe073c2
2 changed files with 23 additions and 2 deletions
|
@ -72,8 +72,7 @@ early_error(StreamID, Reason, PartialReq, Resp, Opts) ->
|
|||
|
||||
%% Check if the client supports decoding of gzip responses.
|
||||
check_req(Req) ->
|
||||
%% @todo Probably shouldn't unconditionally crash on failure.
|
||||
case cowboy_req:parse_header(<<"accept-encoding">>, Req) of
|
||||
try cowboy_req:parse_header(<<"accept-encoding">>, Req) of
|
||||
%% Client doesn't support any compression algorithm.
|
||||
undefined ->
|
||||
#state{compress=undefined};
|
||||
|
@ -87,6 +86,10 @@ check_req(Req) ->
|
|||
_ ->
|
||||
#state{compress=gzip}
|
||||
end
|
||||
catch
|
||||
%% Don't raise an error because of malformed or unsupported accept-encoding headers.
|
||||
exit:{request_error, {header, <<"accept-encoding">>}, _Reason} ->
|
||||
#state{compress=undefined}
|
||||
end.
|
||||
|
||||
%% Do not compress responses that contain the content-encoding header.
|
||||
|
|
|
@ -80,6 +80,24 @@ gzip_accept_encoding_no_gzip(Config) ->
|
|||
{_, <<"100000">>} = lists:keyfind(<<"content-length">>, 1, Headers),
|
||||
ok.
|
||||
|
||||
gzip_accept_encoding_not_supported(Config) ->
|
||||
doc("Send not supported accept-encoding; get an uncompressed response."),
|
||||
{200, Headers, _} = do_get("/reply/large",
|
||||
[{<<"accept-encoding">>, <<"application/gzip">>}], Config),
|
||||
false = lists:keyfind(<<"content-encoding">>, 1, Headers),
|
||||
false = lists:keyfind(<<"vary">>, 1, Headers),
|
||||
{_, <<"100000">>} = lists:keyfind(<<"content-length">>, 1, Headers),
|
||||
ok.
|
||||
|
||||
gzip_accept_encoding_malformed(Config) ->
|
||||
doc("Send malformed accept-encoding; get an uncompressed response."),
|
||||
{200, Headers, _} = do_get("/reply/large",
|
||||
[{<<"accept-encoding">>, <<";">>}], Config),
|
||||
false = lists:keyfind(<<"content-encoding">>, 1, Headers),
|
||||
false = lists:keyfind(<<"vary">>, 1, Headers),
|
||||
{_, <<"100000">>} = lists:keyfind(<<"content-length">>, 1, Headers),
|
||||
ok.
|
||||
|
||||
gzip_reply_content_encoding(Config) ->
|
||||
doc("Reply with content-encoding header; get an uncompressed response."),
|
||||
{200, Headers, _} = do_get("/reply/content-encoding",
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue