Interface WebsocketController<R extends RequestContext<?>,W extends WebsocketContext<?>>
- All Known Implementing Classes:
WebsocketsDemoEchoAllController
-
Method Summary
Modifier and TypeMethodDescriptionvoid
onEndpointClosed
(String endpointId) The endpoint is now closed.void
onEndpointReady
(WebsocketEndpointManager endpointManager) This method is called when a new endpoint is created and its manager is ready.void
onPeerClosed
(W context) A peer closed the WebSocket connection.void
onPeerConnected
(W context) A peer is connected on the WebSocket endpoint.void
onPeerMessage
(W context, byte[] message) A peer sent a bytes[] message.void
onPeerMessage
(W context, String message) A Peer sent a String message.onPeerPreConnect
(R context) Called before the HTTP request is converted to a WebSocket connection.
-
Method Details
-
onPeerPreConnect
Called before the HTTP request is converted to a WebSocket connection.Allows you to decide which endpoint and which peer id to use for the WebSocket connection. You still have access to the request parameters, the cookies, so you can make a decision based on those.
- Returns:
- the WebSocket configuration to used for this peer
or, if
null
is returned, the WebSocket connection won't be established.
-
onEndpointReady
This method is called when a new endpoint is created and its manager is ready. This occures when the controller returns a endpoint id to be used for the first time. Save this manager and use it to send messages, to echo received messages from a peer to multiple peers, to close peers, or to close the endpoint itself.IMPORTANT: To make sure you receive this manager before the connection with the very first peer is established, to prevent any concurrency issues, this method is actually called synchronously in the same thread handling the connection with that first peer. This means this method should not block! If you use this method to start a loop and send messages, for example, then the WebSocket connection with the first peer will fail...
To use this method as a starting point to send events to the peers, start a new Thread in it and return immediately.
-
onPeerConnected
A peer is connected on the WebSocket endpoint. You may want to wait for the first call to this method before strating to send messages. -
onPeerMessage
A Peer sent a String message. -
onPeerMessage
A peer sent a bytes[] message. -
onPeerClosed
A peer closed the WebSocket connection. -
onEndpointClosed
The endpoint is now closed.
-