Package jakarta.websocket
Interface WebSocketContainer
- 
- All Known Subinterfaces:
- ServerContainer
 
 public interface WebSocketContainerA 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. - Author:
- dannycoward
 
- 
- 
Method SummaryAll Methods Instance Methods Abstract Methods Modifier and Type Method Description SessionconnectToServer(Endpoint endpointInstance, ClientEndpointConfig cec, URI path)Connect the supplied programmatic client endpoint instance to its server with the given configuration.SessionconnectToServer(Class<?> annotatedEndpointClass, URI path)Connect the supplied annotated endpoint to its server.SessionconnectToServer(Class<? extends Endpoint> endpointClass, ClientEndpointConfig cec, URI path)Connect the supplied programmatic endpoint to its server with the given configuration.SessionconnectToServer(Object annotatedEndpointInstance, URI path)Connect the supplied annotated endpoint instance to its server.longgetDefaultAsyncSendTimeout()Return the number of milliseconds the implementation will timeout attempting to send a websocket message for all RemoteEndpoints associated with this container.intgetDefaultMaxBinaryMessageBufferSize()Returns the default maximum size of incoming binary message that this container will buffer.longgetDefaultMaxSessionIdleTimeout()Return the default time in milliseconds after which any web socket sessions in this container will be closed if it has been inactive.intgetDefaultMaxTextMessageBufferSize()Returns the default maximum size of incoming text message that this container will buffer.Set<Extension>getInstalledExtensions()Return the set of Extensions installed in the container.voidsetAsyncSendTimeout(long timeoutmillis)Sets the number of milliseconds the implementation will timeout attempting to send a websocket message for all RemoteEndpoints associated with this container.voidsetDefaultMaxBinaryMessageBufferSize(int max)Sets the default maximum size of incoming binary message that this container will buffer.voidsetDefaultMaxSessionIdleTimeout(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.voidsetDefaultMaxTextMessageBufferSize(int max)Sets the maximum size of incoming text message that this container will buffer.
 
- 
- 
- 
Method Detail- 
getDefaultAsyncSendTimeoutlong 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.
 
 - 
setAsyncSendTimeoutvoid 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
 
 - 
connectToServerSession 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 levelClientEndpointannotation. 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.
 
 - 
connectToServerSession 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 levelClientEndpointannotation. 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.
 
 - 
connectToServerSession 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 instance- Endpoint.
- path- the complete path to the server endpoint.
- cec- the configuration used to configure the programmatic endpoint.
- Returns:
- the Session created if the connection is successful.
- Throws:
- DeploymentException- if the configuration 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.
 
 - 
connectToServerSession 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 class- Endpoint.
- path- the complete path to the server endpoint.
- cec- the configuration used to configure the programmatic endpoint.
- Returns:
- the Session created if the connection is successful.
- Throws:
- DeploymentException- if the configuration 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.
 
 - 
getDefaultMaxSessionIdleTimeoutlong 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
 
 - 
setDefaultMaxSessionIdleTimeoutvoid 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
 
 - 
getDefaultMaxBinaryMessageBufferSizeint 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.
 
 - 
setDefaultMaxBinaryMessageBufferSizevoid 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.
 
 - 
getDefaultMaxTextMessageBufferSizeint 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.
 
 - 
setDefaultMaxTextMessageBufferSizevoid 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.
 
 
- 
 
-