diff options
author | Loïc Hoguin <[email protected]> | 2013-01-29 19:16:45 +0100 |
---|---|---|
committer | Loïc Hoguin <[email protected]> | 2013-01-29 19:16:45 +0100 |
commit | a59c5d6e913e62c0102b4213b0a19a4a403fcf98 (patch) | |
tree | 2de623a1bf0d0ee52f65fc8e724463eb5ebeb800 /test/rest_patch_resource.erl | |
parent | 85d05fff340198bb9af332b7fd503f7c8883e634 (diff) | |
parent | c4d1ee554778cc7c90e0a964bfbdddb8823de0c9 (diff) | |
download | cowboy-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.erl | 34 |
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. |