aboutsummaryrefslogtreecommitdiffstats
path: root/src/cowboy_websocket.erl
diff options
context:
space:
mode:
authorLoïc Hoguin <[email protected]>2016-08-15 19:21:38 +0200
committerLoïc Hoguin <[email protected]>2016-08-15 19:21:38 +0200
commit1d01d0fc06bae095e488f17a172246907eceea3f (patch)
treeaa4d6e5bdf5d59735cb2f7d70a054985f4f83f6d /src/cowboy_websocket.erl
parentaf88442610f9f0cc3ec620bbae9ad90f940a8176 (diff)
downloadcowboy-1d01d0fc06bae095e488f17a172246907eceea3f.tar.gz
cowboy-1d01d0fc06bae095e488f17a172246907eceea3f.tar.bz2
cowboy-1d01d0fc06bae095e488f17a172246907eceea3f.zip
Allow websocket_init/1 to reply/close/hibernate
Diffstat (limited to 'src/cowboy_websocket.erl')
-rw-r--r--src/cowboy_websocket.erl25
1 files changed, 12 insertions, 13 deletions
diff --git a/src/cowboy_websocket.erl b/src/cowboy_websocket.erl
index e7736fa..690ee60 100644
--- a/src/cowboy_websocket.erl
+++ b/src/cowboy_websocket.erl
@@ -40,8 +40,7 @@
when Req::cowboy_req:req().
-callback websocket_init(State)
- %% @todo Make that call_result/1.
- -> {ok, State} when State::any().
+ -> call_result(State) when State::any().
-optional_callbacks([websocket_init/1]).
-callback websocket_handle({text | binary | ping | pong, binary()}, State)
@@ -170,17 +169,14 @@ websocket_handshake(State=#state{key=Key},
-spec takeover(pid(), ranch:ref(), inet:socket(), module(), any(), binary(),
{#state{}, any()}) -> ok.
takeover(_Parent, Ref, Socket, Transport, _Opts, Buffer,
- {State=#state{handler=Handler}, HandlerState0}) ->
+ {State0=#state{handler=Handler}, HandlerState}) ->
ranch:remove_connection(Ref),
- %% @todo Allow sending a reply from websocket_init.
- %% @todo Try/catch.
- {ok, HandlerState} = case erlang:function_exported(Handler, websocket_init, 1) of
- true -> Handler:websocket_init(HandlerState0);
- false -> {ok, HandlerState0}
- end,
- State2 = handler_loop_timeout(State#state{socket=Socket, transport=Transport}),
- handler_before_loop(State2#state{key=undefined,
- messages=Transport:messages()}, HandlerState, Buffer).
+ State1 = handler_loop_timeout(State0#state{socket=Socket, transport=Transport}),
+ State = State1#state{key=undefined, messages=Transport:messages()},
+ case erlang:function_exported(Handler, websocket_init, 1) of
+ true -> handler_call(State, HandlerState, Buffer, websocket_init, undefined, fun handler_before_loop/3);
+ false -> handler_before_loop(State, HandlerState, Buffer)
+ end.
-spec handler_before_loop(#state{}, any(), binary())
%% @todo Yeah not env.
@@ -317,7 +313,10 @@ websocket_dispatch(State=#state{socket=Socket, transport=Transport, frag_state=F
-> {ok, cowboy_middleware:env()}.
handler_call(State=#state{handler=Handler}, HandlerState,
RemainingData, Callback, Message, NextState) ->
- try Handler:Callback(Message, HandlerState) of
+ try case Callback of
+ websocket_init -> Handler:websocket_init(HandlerState);
+ _ -> Handler:Callback(Message, HandlerState)
+ end of
{ok, HandlerState2} ->
NextState(State, HandlerState2, RemainingData);
{ok, HandlerState2, hibernate} ->