aboutsummaryrefslogtreecommitdiffstats
path: root/test/rest_param_all.erl
diff options
context:
space:
mode:
authorLoïc Hoguin <[email protected]>2013-03-03 19:15:54 +0100
committerLoïc Hoguin <[email protected]>2013-03-03 19:15:54 +0100
commit7d13391d398bffbfe9460d094f28caf42638a454 (patch)
treea36e4f404242b0408078a3e6eb59391dea3fcb24 /test/rest_param_all.erl
parentdbc1bc6d91548b199fc86a477bdc1873faa890ac (diff)
parentbb1362c744ec24a72fbb2fa3e1cc8e44ef51ab2d (diff)
downloadcowboy-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.erl36
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}.