aboutsummaryrefslogtreecommitdiffstats
path: root/test/rest_patch_resource.erl
diff options
context:
space:
mode:
authorLoïc Hoguin <[email protected]>2013-01-29 19:16:45 +0100
committerLoïc Hoguin <[email protected]>2013-01-29 19:16:45 +0100
commita59c5d6e913e62c0102b4213b0a19a4a403fcf98 (patch)
tree2de623a1bf0d0ee52f65fc8e724463eb5ebeb800 /test/rest_patch_resource.erl
parent85d05fff340198bb9af332b7fd503f7c8883e634 (diff)
parentc4d1ee554778cc7c90e0a964bfbdddb8823de0c9 (diff)
downloadcowboy-a59c5d6e913e62c0102b4213b0a19a4a403fcf98.tar.gz
cowboy-a59c5d6e913e62c0102b4213b0a19a4a403fcf98.tar.bz2
cowboy-a59c5d6e913e62c0102b4213b0a19a4a403fcf98.zip
Merge branch 'rest_patch' of https://github.com/treetopllc/cowboy
Diffstat (limited to 'test/rest_patch_resource.erl')
-rw-r--r--test/rest_patch_resource.erl34
1 files changed, 34 insertions, 0 deletions
diff --git a/test/rest_patch_resource.erl b/test/rest_patch_resource.erl
new file mode 100644
index 0000000..e265f6f
--- /dev/null
+++ b/test/rest_patch_resource.erl
@@ -0,0 +1,34 @@
+-module(rest_patch_resource).
+-export([init/3, allowed_methods/2, content_types_provided/2, get_text_plain/2,
+ content_types_accepted/2, patch_text_plain/2]).
+
+init(_Transport, _Req, _Opts) ->
+ {upgrade, protocol, cowboy_rest}.
+
+allowed_methods(Req, State) ->
+ {[<<"HEAD">>, <<"GET">>, <<"PATCH">>], Req, State}.
+
+content_types_provided(Req, State) ->
+ {[{{<<"text">>, <<"plain">>, []}, get_text_plain}], Req, State}.
+
+get_text_plain(Req, State) ->
+ {<<"This is REST!">>, Req, State}.
+
+content_types_accepted(Req, State) ->
+ case cowboy_req:method(Req) of
+ {<<"PATCH">>, Req0} ->
+ {[{{<<"text">>, <<"plain">>, []}, patch_text_plain}], Req0, State};
+ {_, Req0} ->
+ {[], Req0, State}
+ end.
+
+patch_text_plain(Req, State) ->
+ case cowboy_req:body(Req) of
+ {ok, <<"halt">>, Req0} ->
+ {ok, Req1} = cowboy_req:reply(400, Req0),
+ {halt, Req1, State};
+ {ok, <<"false">>, Req0} ->
+ {false, Req0, State};
+ {ok, _Body, Req0} ->
+ {true, Req0, State}
+ end.