package org.java_websocket;
import java.net.InetSocketAddress;
import java.nio.ByteBuffer;
import org.java_websocket.drafts.Draft;
import org.java_websocket.exceptions.InvalidDataException;
import org.java_websocket.framing.Framedata;
import org.java_websocket.handshake.ClientHandshake;
import org.java_websocket.handshake.Handshakedata;
import org.java_websocket.handshake.ServerHandshake;
import org.java_websocket.handshake.ServerHandshakeBuilder;
/**
* Implemented by <tt>WebSocketClient</tt> and <tt>WebSocketServer</tt>. The
* methods within are called by <tt>WebSocket</tt>. Almost every method takes a
* first parameter conn which represents the source of the respective event.
*/
public interface WebSocketListener {
/**
* Gets the XML string that should be returned if a client requests a Flash
* security policy.
*
* @throws InvalidDataException
* thrown when some data that is required to generate the
* flash-policy like the websocket local port could not be
* obtained.
*/
public String getFlashPolicy(WebSocket conn) throws InvalidDataException;
public InetSocketAddress getLocalSocketAddress(WebSocket conn);
public InetSocketAddress getRemoteSocketAddress(WebSocket conn);
/**
* Called after <tt>WebSocket#close</tt> is explicity called, or when the
* other end of the WebSocket connection is closed.
*
* @param conn
* The <tt>WebSocket</tt> instance this event is occuring on.
*/
public void onWebsocketClose(WebSocket ws, int code, String reason,
boolean remote);
/** send when this peer sends a close handshake */
public void onWebsocketCloseInitiated(WebSocket ws, int code, String reason);
/** called as soon as no further frames are accepted */
public void onWebsocketClosing(WebSocket ws, int code, String reason,
boolean remote);
/**
* Called if an exception worth noting occurred. If an error causes the
* connection to fail onClose will be called additionally afterwards.
*
* @param ex
* The exception that occurred. <br>
* Might be null if the exception is not related to any specific
* connection. For example if the server port could not be bound.
*/
public void onWebsocketError(WebSocket conn, Exception ex);
/**
* Called on the client side when the socket connection is first
* established, and the WebSocketImpl handshake response has been received.
*
* @param conn
* The WebSocket related to this event
* @param request
* The handshake initially send out to the server by this
* websocket.
* @param response
* The handshake the server sent in response to the request.
* @throws InvalidDataException
* Allows the client to reject the connection with the server in
* respect of its handshake response.
*/
public void onWebsocketHandshakeReceivedAsClient(WebSocket conn,
ClientHandshake request, ServerHandshake response)
throws InvalidDataException;
/**
* Called on the server side when the socket connection is first
* established, and the WebSocket handshake has been received. This method
* allows to deny connections based on the received handshake.<br>
* By default this method only requires protocol compliance.
*
* @param conn
* The WebSocket related to this event
* @param draft
* The protocol draft the client uses to connect
* @param request
* The opening http message send by the client. Can be used to
* access additional fields like cookies.
* @return Returns an incomplete handshake containing all optional fields
* @throws InvalidDataException
* Throwing this exception will cause this handshake to be
* rejected
*/
public ServerHandshakeBuilder onWebsocketHandshakeReceivedAsServer(
WebSocket conn, Draft draft, ClientHandshake request)
throws InvalidDataException;
/**
* Called on the client side when the socket connection is first
* established, and the WebSocketImpl handshake has just been sent.
*
* @param conn
* The WebSocket related to this event
* @param request
* The handshake sent to the server by this websocket
* @throws InvalidDataException
* Allows the client to stop the connection from progressing
*/
public void onWebsocketHandshakeSentAsClient(WebSocket conn,
ClientHandshake request) throws InvalidDataException;
/**
* Called when an entire binary frame has been received. Do whatever you
* want here...
*
* @param conn
* The <tt>WebSocket</tt> instance this event is occurring on.
* @param blob
* The binary message that was received.
*/
public void onWebsocketMessage(WebSocket conn, ByteBuffer blob);
/**
* Called when an entire text frame has been received. Do whatever you want
* here...
*
* @param conn
* The <tt>WebSocket</tt> instance this event is occurring on.
* @param message
* The UTF-8 decoded message that was received.
*/
public void onWebsocketMessage(WebSocket conn, String message);
public void onWebsocketMessageFragment(WebSocket conn, Framedata frame);
/**
* Called after <var>onHandshakeReceived</var> returns <var>true</var>.
* Indicates that a complete WebSocket connection has been established, and
* we are ready to send/receive data.
*
* @param conn
* The <tt>WebSocket</tt> instance this event is occuring on.
*/
public void onWebsocketOpen(WebSocket conn, Handshakedata d);
/**
* Called a ping frame has been received. This method must send a
* corresponding pong by itself.
*
* @param f
* The ping frame. Control frames may contain payload.
*/
public void onWebsocketPing(WebSocket conn, Framedata f);
/**
* Called when a pong frame is received.
**/
public void onWebsocketPong(WebSocket conn, Framedata f);
/**
* This method is used to inform the selector thread that there is data
* queued to be written to the socket.
*/
public void onWriteDemand(WebSocket conn);
}