diff options
author | Loïc Hoguin <[email protected]> | 2012-01-31 10:52:44 +0100 |
---|---|---|
committer | Loïc Hoguin <[email protected]> | 2012-01-31 12:17:29 +0100 |
commit | 9823450cc31ecdcbf5d3ef3609695815f3d84782 (patch) | |
tree | 84a54e1d3400799b2dffe9a5214bde0883a04ffe /test/websocket_echo_handler.erl | |
parent | 21802d2767e48924186d173eb36b61994e990b87 (diff) | |
parent | 88088251732e36f72e3edf806a5561b569e62c19 (diff) | |
download | cowboy-9823450cc31ecdcbf5d3ef3609695815f3d84782.tar.gz cowboy-9823450cc31ecdcbf5d3ef3609695815f3d84782.tar.bz2 cowboy-9823450cc31ecdcbf5d3ef3609695815f3d84782.zip |
Merge branch 'autobahn-suite' of https://github.com/klaar/cowboy
This needs python2 to be the default python in /usr/bin/python.
Diffstat (limited to 'test/websocket_echo_handler.erl')
-rw-r--r-- | test/websocket_echo_handler.erl | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/test/websocket_echo_handler.erl b/test/websocket_echo_handler.erl new file mode 100644 index 0000000..b06c1e7 --- /dev/null +++ b/test/websocket_echo_handler.erl @@ -0,0 +1,34 @@ +%% Feel free to use, reuse and abuse the code in this file. + +-module(websocket_echo_handler). +-behaviour(cowboy_http_handler). +-behaviour(cowboy_http_websocket_handler). +-export([init/3, handle/2, terminate/2]). +-export([websocket_init/3, websocket_handle/3, + websocket_info/3, websocket_terminate/3]). + +init(_Any, _Req, _Opts) -> + {upgrade, protocol, cowboy_http_websocket}. + +handle(_Req, _State) -> + exit(badarg). + +terminate(_Req, _State) -> + exit(badarg). + +websocket_init(_TransportName, Req, _Opts) -> + Req2 = cowboy_http_req:compact(Req), + {ok, Req2, undefined}. + +websocket_handle({text, Data}, Req, State) -> + {reply, {text, Data}, Req, State}; +websocket_handle({binary, Data}, Req, State) -> + {reply, {binary, Data}, Req, State}; +websocket_handle(_Frame, Req, State) -> + {ok, Req, State}. + +websocket_info(_Info, Req, State) -> + {ok, Req, State}. + +websocket_terminate(_Reason, _Req, _State) -> + ok. |