public.javadoc.org.spincast.core.websocket.WebsocketController.html Maven / Gradle / Ivy
Show all versions of spincast-website Show documentation
WebsocketController (org.spincast:spincast-framework 1.0.0 API)
org.spincast.core.websocket
Interface WebsocketController<R extends RequestContext<?>,W extends WebsocketContext<?>>
-
public interface WebsocketController<R extends RequestContext<?>,W extends WebsocketContext<?>>
A controller for a WebSocket connection.
-
-
Method Summary
All Methods Instance Methods Abstract Methods
Modifier and Type
Method and Description
void
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.
WebsocketConnectionConfig
onPeerPreConnect(R context)
Called before the HTTP request is converted to a
WebSocket connection.
-
-
Method Detail
-
onPeerPreConnect
WebsocketConnectionConfig onPeerPreConnect(R context)
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
void onEndpointReady(WebsocketEndpointManager endpointManager)
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
void onPeerConnected(W context)
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
void onPeerMessage(W context,
byte[] message)
A peer sent a bytes[] message.
-
onPeerClosed
void onPeerClosed(W context)
A peer closed the WebSocket connection.
-
onEndpointClosed
void onEndpointClosed(String endpointId)
The endpoint is now closed.
Copyright © 2019. All rights reserved.