- All Known Subinterfaces:
ServerContainer
public interface WebSocketContainer
A WebSocketContainer is an implementation provided object that provides applications a view on the container running
it. The WebSocketContainer container various configuration parameters that control default session and buffer
properties of the endpoints it contains. It also allows the developer to deploy websocket client endpoints by
initiating a web socket handshake from the provided endpoint to a supplied URI where the peer endpoint is presumed to
reside.
A WebSocketContainer may be accessed by concurrent threads, so implementations must ensure the integrity of its mutable attributes in such circumstances.
-
Method Summary
Modifier and TypeMethodDescriptionconnectToServer
(Endpoint endpointInstance, ClientEndpointConfig cec, URI path) Connect the supplied programmatic client endpoint instance to its server with the given configuration.connectToServer
(Class<?> annotatedEndpointClass, URI path) Connect the supplied annotated endpoint to its server.connectToServer
(Class<? extends Endpoint> endpointClass, ClientEndpointConfig cec, URI path) Connect the supplied programmatic endpoint to its server with the given configuration.connectToServer
(Object annotatedEndpointInstance, URI path) Connect the supplied annotated endpoint instance to its server.long
Return the number of milliseconds the implementation will timeout attempting to send a websocket message for all RemoteEndpoints associated with this container.int
Returns the default maximum size of incoming binary message that this container will buffer.long
Return the default time in milliseconds after which any web socket sessions in this container will be closed if it has been inactive.int
Returns the default maximum size of incoming text message that this container will buffer.Return the set of Extensions installed in the container.void
setAsyncSendTimeout
(long timeoutmillis) Sets the number of milliseconds the implementation will timeout attempting to send a websocket message for all RemoteEndpoints associated with this container.void
setDefaultMaxBinaryMessageBufferSize
(int max) Sets the default maximum size of incoming binary message that this container will buffer.void
setDefaultMaxSessionIdleTimeout
(long timeout) Sets the default time in milliseconds after which any web socket sessions in this container will be closed if it has been inactive.void
setDefaultMaxTextMessageBufferSize
(int max) Sets the maximum size of incoming text message that this container will buffer.
-
Method Details
-
getDefaultAsyncSendTimeout
long getDefaultAsyncSendTimeout()Return the number of milliseconds the implementation will timeout attempting to send a websocket message for all RemoteEndpoints associated with this container. A zero or negative value indicates the implementation will not timeout attempting to send a websocket message asynchronously. Note this default may be overridden in each RemoteEndpoint.- Returns:
- the timeout time in milliseconds.
-
setAsyncSendTimeout
void setAsyncSendTimeout(long timeoutmillis) Sets the number of milliseconds the implementation will timeout attempting to send a websocket message for all RemoteEndpoints associated with this container. A zero or negative value indicates the implementation will not timeout attempting to send a websocket message asynchronously. Note this default may be overridden in each RemoteEndpoint.- Parameters:
timeoutmillis
- the timeout in milliseconds; use zero or negative value for no timeout
-
connectToServer
Session connectToServer(Object annotatedEndpointInstance, URI path) throws DeploymentException, IOException Connect the supplied annotated endpoint instance to its server. The supplied object must be a class decorated with the class levelClientEndpoint
annotation. This method blocks until the connection is established, or throws an error if either the connection could not be made or there was a problem with the supplied endpoint class. If the developer uses this method to deploy the client endpoint, services like dependency injection that are supported, for example, when the implementation is part of the Java EE platform may not be available. If the client endpoint uses dependency injection, useconnectToServer(java.lang.Class, java.net.URI)
instead.- Parameters:
annotatedEndpointInstance
- the annotated websocket client endpoint instance.path
- the complete path to the server endpoint.- Returns:
- the Session created if the connection is successful.
- Throws:
DeploymentException
- if the annotated endpoint instance is not valid.IOException
- if there was a network or protocol problem that prevented the client endpoint being connected to its server.IllegalStateException
- if called during the deployment phase of the containing application.
-
connectToServer
Session connectToServer(Class<?> annotatedEndpointClass, URI path) throws DeploymentException, IOException Connect the supplied annotated endpoint to its server. The supplied object must be a class decorated with the class levelClientEndpoint
annotation. This method blocks until the connection is established, or throws an error if either the connection could not be made or there was a problem with the supplied endpoint class.- Parameters:
annotatedEndpointClass
- the annotated websocket client endpoint.path
- the complete path to the server endpoint.- Returns:
- the Session created if the connection is successful.
- Throws:
DeploymentException
- if the class is not a valid annotated endpoint class.IOException
- if there was a network or protocol problem that prevented the client endpoint being connected to its server.IllegalStateException
- if called during the deployment phase of the containing application.
-
connectToServer
Session connectToServer(Endpoint endpointInstance, ClientEndpointConfig cec, URI path) throws DeploymentException, IOException Connect the supplied programmatic client endpoint instance to its server with the given configuration. This method blocks until the connection is established, or throws an error if the connection could not be made. If the developer uses this method to deploy the client endpoint, services like dependency injection that are supported, for example, when the implementation is part of the Java EE platform may not be available. If the client endpoint uses dependency injection, useconnectToServer(java.lang.Class, jakarta.websocket.ClientEndpointConfig, java.net.URI)
instead.- Parameters:
endpointInstance
- the programmatic client endpoint instanceEndpoint
.cec
- the configuration used to configure the programmatic endpoint.path
- the complete path to the server endpoint.- Returns:
- the Session created if the connection is successful.
- Throws:
DeploymentException
- if the configuration is not validIOException
- if there was a network or protocol problem that prevented the client endpoint being connected to its serverIllegalStateException
- if called during the deployment phase of the containing application.
-
connectToServer
Session connectToServer(Class<? extends Endpoint> endpointClass, ClientEndpointConfig cec, URI path) throws DeploymentException, IOException Connect the supplied programmatic endpoint to its server with the given configuration. This method blocks until the connection is established, or throws an error if the connection could not be made.- Parameters:
endpointClass
- the programmatic client endpoint classEndpoint
.cec
- the configuration used to configure the programmatic endpoint.path
- the complete path to the server endpoint.- Returns:
- the Session created if the connection is successful.
- Throws:
DeploymentException
- if the configuration is not validIOException
- if there was a network or protocol problem that prevented the client endpoint being connected to its serverIllegalStateException
- if called during the deployment phase of the containing application.
-
getDefaultMaxSessionIdleTimeout
long getDefaultMaxSessionIdleTimeout()Return the default time in milliseconds after which any web socket sessions in this container will be closed if it has been inactive. A value that is zero or negative indicates the sessions will never timeout due to inactivity. The value may be overridden on a per session basis usingSession.setMaxIdleTimeout(long)
- Returns:
- the default number of milliseconds after which an idle session in this container will be closed
-
setDefaultMaxSessionIdleTimeout
void setDefaultMaxSessionIdleTimeout(long timeout) Sets the default time in milliseconds after which any web socket sessions in this container will be closed if it has been inactive. A value that is zero or negative indicates the sessions will never timeout due to inactivity. The value may be overridden on a per session basis usingSession.setMaxIdleTimeout(long)
- Parameters:
timeout
- the maximum time in milliseconds; use zero or negative value for no timeout
-
getDefaultMaxBinaryMessageBufferSize
int getDefaultMaxBinaryMessageBufferSize()Returns the default maximum size of incoming binary message that this container will buffer. This default may be overridden on a per session basis usingSession.setMaxBinaryMessageBufferSize(int)
- Returns:
- the maximum size of incoming binary message in number of bytes.
-
setDefaultMaxBinaryMessageBufferSize
void setDefaultMaxBinaryMessageBufferSize(int max) Sets the default maximum size of incoming binary message that this container will buffer.- Parameters:
max
- the maximum size of binary message in number of bytes.
-
getDefaultMaxTextMessageBufferSize
int getDefaultMaxTextMessageBufferSize()Returns the default maximum size of incoming text message that this container will buffer. This default may be overridden on a per session basis usingSession.setMaxTextMessageBufferSize(int)
- Returns:
- the maximum size of incoming text message in number of bytes.
-
setDefaultMaxTextMessageBufferSize
void setDefaultMaxTextMessageBufferSize(int max) Sets the maximum size of incoming text message that this container will buffer.- Parameters:
max
- the maximum size of text message in number of bytes.
-
getInstalledExtensions
-