diff options
author | Loïc Hoguin <[email protected]> | 2013-03-03 19:15:54 +0100 |
---|---|---|
committer | Loïc Hoguin <[email protected]> | 2013-03-03 19:15:54 +0100 |
commit | 7d13391d398bffbfe9460d094f28caf42638a454 (patch) | |
tree | a36e4f404242b0408078a3e6eb59391dea3fcb24 /test/rest_param_all.erl | |
parent | dbc1bc6d91548b199fc86a477bdc1873faa890ac (diff) | |
parent | bb1362c744ec24a72fbb2fa3e1cc8e44ef51ab2d (diff) | |
download | cowboy-7d13391d398bffbfe9460d094f28caf42638a454.tar.gz cowboy-7d13391d398bffbfe9460d094f28caf42638a454.tar.bz2 cowboy-7d13391d398bffbfe9460d094f28caf42638a454.zip |
Merge branch 'param_all' of git://github.com/nevar/cowboy
Diffstat (limited to 'test/rest_param_all.erl')
-rw-r--r-- | test/rest_param_all.erl | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/test/rest_param_all.erl b/test/rest_param_all.erl new file mode 100644 index 0000000..09b8cd3 --- /dev/null +++ b/test/rest_param_all.erl @@ -0,0 +1,36 @@ +-module(rest_param_all). + +-export([init/3]). +-export([allowed_methods/2]). +-export([content_types_provided/2]). +-export([get_text_plain/2]). +-export([content_types_accepted/2]). +-export([put_text_plain/2]). + +init(_Transport, _Req, _Opts) -> + {upgrade, protocol, cowboy_rest}. + +allowed_methods(Req, State) -> + {[<<"GET">>, <<"PUT">>], Req, State}. + +content_types_provided(Req, State) -> + {[{{<<"text">>, <<"plain">>, '*'}, get_text_plain}], Req, State}. + +get_text_plain(Req, State) -> + {{_, _, Param}, Req2} = + cowboy_req:meta(media_type, Req, {{<<"text">>, <<"plain">>}, []}), + Body = if + Param == '*' -> + <<"'*'">>; + Param == [] -> + <<"[]">>; + Param /= [] -> + iolist_to_binary([[Key, $=, Value] || {Key, Value} <- Param]) + end, + {Body, Req2, State}. + +content_types_accepted(Req, State) -> + {[{{<<"text">>, <<"plain">>, '*'}, put_text_plain}], Req, State}. + +put_text_plain(Req, State) -> + {true, Req, State}. |