Class MessageHandler
- All Implemented Interfaces:
FrameHandler
,IncomingFrames
A utility implementation of FrameHandler that aggregates TEXT frames
into a String message before calling onText(String, Callback)
.
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionstatic MessageHandler
from
(Consumer<String> onText, Consumer<ByteBuffer> onBinary) protected void
onBinary
(ByteBuffer message, Callback callback) Method called when a complete binary message is received.protected void
onBinaryFrame
(Frame frame, Callback callback) void
onClosed
(CloseStatus closeStatus, Callback callback) Invoked when a WebSocket close event happened.protected void
onCloseFrame
(Frame frame, Callback callback) protected void
onContinuationFrame
(Frame frame, Callback callback) void
Invoked when an error has occurred or has been detected.void
Invoked when a WebSocket frame is received.void
onOpen
(CoreSession coreSession, Callback callback) Invoked when the WebSocket connection is opened.protected void
onPingFrame
(Frame frame, Callback callback) protected void
onPongFrame
(Frame frame, Callback callback) protected void
Method called when a complete text message is received.protected void
onTextFrame
(Frame frame, Callback callback) void
sendBinary
(ByteBuffer message, Callback callback, boolean batch) Send a ByteBuffer as a single binary frame.void
sendBinary
(Callback callback, boolean batch, ByteBuffer... parts) Send a sequence of ByteBuffers as a sequences for fragmented text frame.void
Send a String as a single text frame.void
Send a sequence of Strings as a sequences for fragmented text frame.
-
Constructor Details
-
MessageHandler
public MessageHandler()
-
-
Method Details
-
from
-
getCoreSession
-
onOpen
Description copied from interface:FrameHandler
Invoked when the WebSocket connection is opened.
It is allowed to send WebSocket frames via
OutgoingFrames.sendFrame(Frame, Callback, boolean)
.WebSocket frames cannot be received until a call to
CoreSession.demand()
is made.If the callback argument is failed, the implementation sends a CLOSE frame with
CloseStatus.SERVER_ERROR
, and the connection will be closed.- Specified by:
onOpen
in interfaceFrameHandler
- Parameters:
coreSession
- the session associated with this connection.callback
- the callback to indicate success or failure of the processing of this event.
-
onFrame
Description copied from interface:FrameHandler
Invoked when a WebSocket frame is received.
This method will never be called concurrently for the same session; will be called sequentially to satisfy the outstanding demand signaled by calls to
CoreSession.demand()
.Both control and data frames are passed to this method.
CLOSE frames may be responded from this method, but if they are not responded, then the implementation will respond when the callback is completed.
The callback argument must be completed to indicate that the buffers associated with the frame can be recycled.
Additional WebSocket frames (of any type, including CLOSE frames) cannot be received until a call to
CoreSession.demand()
is made.- Specified by:
onFrame
in interfaceFrameHandler
- Specified by:
onFrame
in interfaceIncomingFrames
- Parameters:
frame
- the WebSocket frame.callback
- the callback to indicate success or failure of the processing of this event.
-
onError
Description copied from interface:FrameHandler
Invoked when an error has occurred or has been detected.
A call to this method will be followed by a call to
FrameHandler.onClosed(CloseStatus, Callback)
with the close status derived from the error.This method will not be called more than once,
FrameHandler.onClosed(CloseStatus, Callback)
will be called on the callback completion.- Specified by:
onError
in interfaceFrameHandler
- Parameters:
cause
- the error causecallback
- the callback to indicate success or failure of the processing of this event.
-
onClosed
Description copied from interface:FrameHandler
Invoked when a WebSocket close event happened.
The WebSocket connection is closed, no reading or writing is possible anymore.
Implementations of this method may cleanup resources that have been allocated.
This method will not be called more than once.
- Specified by:
onClosed
in interfaceFrameHandler
- Parameters:
closeStatus
- the close status received from the remote peer, or generated locally in the case of abnormal closures.callback
- the callback to indicate success or failure of the processing of this event.
-
onTextFrame
-
onBinaryFrame
-
onContinuationFrame
-
onPingFrame
-
onPongFrame
-
onCloseFrame
-
onText
Method called when a complete text message is received.- Parameters:
message
- the received text payloadcallback
- The callback to signal completion of handling.
-
onBinary
Method called when a complete binary message is received.- Parameters:
message
- The binary payloadcallback
- The callback to signal completion of handling.
-
sendText
Send a String as a single text frame.- Parameters:
message
- The message to sendcallback
- The callback to call when the send is completebatch
- The batch mode to send the frames in.
-
sendText
Send a sequence of Strings as a sequences for fragmented text frame. Sending a large message in fragments can reduce memory overheads as only a single fragment need be converted to bytes- Parameters:
callback
- The callback to call when the send is completebatch
- The batch mode to send the frames in.parts
- The parts of the message.
-
sendBinary
Send a ByteBuffer as a single binary frame.- Parameters:
message
- The message to sendcallback
- The callback to call when the send is completebatch
- The batch mode to send the frames in.
-
sendBinary
Send a sequence of ByteBuffers as a sequences for fragmented text frame.- Parameters:
callback
- The callback to call when the send is completebatch
- The batch mode to send the frames in.parts
- The parts of the message.
-