diff options
author | Loïc Hoguin <[email protected]> | 2025-02-11 12:00:03 +0100 |
---|---|---|
committer | Loïc Hoguin <[email protected]> | 2025-02-11 13:28:45 +0100 |
commit | e8a1868033a75fa1f684a8b91ff7aa25e6c67676 (patch) | |
tree | 06abf00b254033dd36a43730e3fa37f50b4c9eaa /src | |
parent | f316a65906d97609c7a3f317c0b1dea95fc37e6c (diff) | |
download | cowboy-e8a1868033a75fa1f684a8b91ff7aa25e6c67676.tar.gz cowboy-e8a1868033a75fa1f684a8b91ff7aa25e6c67676.tar.bz2 cowboy-e8a1868033a75fa1f684a8b91ff7aa25e6c67676.zip |
Add support for lists in cowboy_req:set_resp_headers
This is meant to be used with clients such as Gun to simplify
proxying and similar operations. The set-cookie header must
not be set this way so there is still some extra processing
to be done to fully translate a Gun response into a Cowboy
response.
Diffstat (limited to 'src')
-rw-r--r-- | src/cowboy_req.erl | 17 |
1 files changed, 16 insertions, 1 deletions
diff --git a/src/cowboy_req.erl b/src/cowboy_req.erl index 8d8cf82..adee364 100644 --- a/src/cowboy_req.erl +++ b/src/cowboy_req.erl @@ -726,8 +726,10 @@ set_resp_header(Name, Value, Req=#{resp_headers := RespHeaders}) -> set_resp_header(Name,Value, Req) -> Req#{resp_headers => #{Name => Value}}. --spec set_resp_headers(cowboy:http_headers(), Req) +-spec set_resp_headers(cowboy:http_headers() | [{binary(), iodata()}], Req) -> Req when Req::req(). +set_resp_headers(Headers, Req) when is_list(Headers) -> + set_resp_headers_list(Headers, Req, #{}); set_resp_headers(#{<<"set-cookie">> := _}, _) -> exit({response_error, invalid_header, 'Response cookies must be set using cowboy_req:set_resp_cookie/3,4.'}); @@ -736,6 +738,19 @@ set_resp_headers(Headers, Req=#{resp_headers := RespHeaders}) -> set_resp_headers(Headers, Req) -> Req#{resp_headers => Headers}. +set_resp_headers_list([], Req, Acc) -> + set_resp_headers(Acc, Req); +set_resp_headers_list([{<<"set-cookie">>, _}|_], _, _) -> + exit({response_error, invalid_header, + 'Response cookies must be set using cowboy_req:set_resp_cookie/3,4.'}); +set_resp_headers_list([{Name, Value}|Tail], Req, Acc) -> + case Acc of + #{Name := ValueAcc} -> + set_resp_headers_list(Tail, Req, Acc#{Name => [ValueAcc, <<", ">>, Value]}); + _ -> + set_resp_headers_list(Tail, Req, Acc#{Name => Value}) + end. + -spec resp_header(binary(), req()) -> binary() | undefined. resp_header(Name, Req) -> resp_header(Name, Req, undefined). |