Issue #3712 - rename maxIdleTime usage to idleTimeout for WebSockets
Signed-off-by: Lachlan Roberts <lachlan@webtide.com>
This commit is contained in:
parent
90e849af76
commit
85aa3424b6
|
@ -18,15 +18,15 @@
|
||||||
|
|
||||||
package org.eclipse.jetty.websocket.api.annotations;
|
package org.eclipse.jetty.websocket.api.annotations;
|
||||||
|
|
||||||
import org.eclipse.jetty.websocket.api.BatchMode;
|
|
||||||
import org.eclipse.jetty.websocket.api.StatusCode;
|
|
||||||
|
|
||||||
import java.lang.annotation.Documented;
|
import java.lang.annotation.Documented;
|
||||||
import java.lang.annotation.ElementType;
|
import java.lang.annotation.ElementType;
|
||||||
import java.lang.annotation.Retention;
|
import java.lang.annotation.Retention;
|
||||||
import java.lang.annotation.RetentionPolicy;
|
import java.lang.annotation.RetentionPolicy;
|
||||||
import java.lang.annotation.Target;
|
import java.lang.annotation.Target;
|
||||||
|
|
||||||
|
import org.eclipse.jetty.websocket.api.BatchMode;
|
||||||
|
import org.eclipse.jetty.websocket.api.StatusCode;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tags a POJO as being a WebSocket class.
|
* Tags a POJO as being a WebSocket class.
|
||||||
*/
|
*/
|
||||||
|
@ -39,26 +39,33 @@ public @interface WebSocket
|
||||||
/**
|
/**
|
||||||
* The size of the buffer (in bytes) used to read from the network layer.
|
* The size of the buffer (in bytes) used to read from the network layer.
|
||||||
*/
|
*/
|
||||||
int inputBufferSize() default -2;
|
int inputBufferSize() default -1;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The maximum size of a binary message (in bytes) during parsing/generating.
|
* The maximum size of a binary message (in bytes) during parsing/generating.
|
||||||
* <p>
|
* <p>
|
||||||
* Binary messages over this maximum will result in a close code 1009 {@link StatusCode#MESSAGE_TOO_LARGE}
|
* Binary messages over this maximum will result in a close code 1009 {@link StatusCode#MESSAGE_TOO_LARGE}
|
||||||
*/
|
*/
|
||||||
int maxBinaryMessageSize() default -2;
|
int maxBinaryMessageSize() default -1;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The time in ms (milliseconds) that a websocket may be idle before closing.
|
||||||
|
* @deprecated use {@link #idleTimeout()} instead
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
|
int maxIdleTime() default -1;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The time in ms (milliseconds) that a websocket may be idle before closing.
|
* The time in ms (milliseconds) that a websocket may be idle before closing.
|
||||||
*/
|
*/
|
||||||
int maxIdleTime() default -2;
|
int idleTimeout() default -1;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The maximum size of a text message during parsing/generating.
|
* The maximum size of a text message during parsing/generating.
|
||||||
* <p>
|
* <p>
|
||||||
* Text messages over this maximum will result in a close code 1009 {@link StatusCode#MESSAGE_TOO_LARGE}
|
* Text messages over this maximum will result in a close code 1009 {@link StatusCode#MESSAGE_TOO_LARGE}
|
||||||
*/
|
*/
|
||||||
int maxTextMessageSize() default -2;
|
int maxTextMessageSize() default -1;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The output frame buffering mode.
|
* The output frame buffering mode.
|
||||||
|
|
|
@ -296,14 +296,20 @@ public class JettyWebSocketFrameHandlerFactory extends ContainerLifeCycle
|
||||||
{
|
{
|
||||||
JettyWebSocketFrameHandlerMetadata metadata = new JettyWebSocketFrameHandlerMetadata();
|
JettyWebSocketFrameHandlerMetadata metadata = new JettyWebSocketFrameHandlerMetadata();
|
||||||
|
|
||||||
if (anno.inputBufferSize()>=0)
|
int max = anno.inputBufferSize();
|
||||||
metadata.setInputBufferSize(anno.inputBufferSize());
|
if (max>=0)
|
||||||
if (anno.maxBinaryMessageSize()>=0)
|
metadata.setInputBufferSize(max);
|
||||||
metadata.setMaxBinaryMessageSize(anno.maxBinaryMessageSize());
|
max = anno.maxBinaryMessageSize();
|
||||||
if (anno.maxTextMessageSize()>=0)
|
if (max>=0)
|
||||||
metadata.setMaxTextMessageSize(anno.maxTextMessageSize());
|
metadata.setMaxBinaryMessageSize(max);
|
||||||
if (anno.maxIdleTime()>=0)
|
max = anno.maxTextMessageSize();
|
||||||
metadata.setIdleTimeout(Duration.ofMillis(anno.maxIdleTime()));
|
if (max>=0)
|
||||||
|
metadata.setMaxTextMessageSize(max);
|
||||||
|
max = anno.idleTimeout();
|
||||||
|
if (max<0)
|
||||||
|
max = anno.maxIdleTime();
|
||||||
|
if (max>=0)
|
||||||
|
metadata.setIdleTimeout(Duration.ofMillis(max));
|
||||||
metadata.setBatchMode(anno.batchMode());
|
metadata.setBatchMode(anno.batchMode());
|
||||||
|
|
||||||
Method onmethod;
|
Method onmethod;
|
||||||
|
|
|
@ -36,8 +36,8 @@ import org.eclipse.jetty.websocket.api.WebSocketTimeoutException;
|
||||||
import org.eclipse.jetty.websocket.api.annotations.WebSocket;
|
import org.eclipse.jetty.websocket.api.annotations.WebSocket;
|
||||||
import org.eclipse.jetty.websocket.client.WebSocketClient;
|
import org.eclipse.jetty.websocket.client.WebSocketClient;
|
||||||
import org.eclipse.jetty.websocket.common.WebSocketSession;
|
import org.eclipse.jetty.websocket.common.WebSocketSession;
|
||||||
import org.eclipse.jetty.websocket.core.internal.WebSocketCoreSession;
|
|
||||||
import org.eclipse.jetty.websocket.core.internal.WebSocketConnection;
|
import org.eclipse.jetty.websocket.core.internal.WebSocketConnection;
|
||||||
|
import org.eclipse.jetty.websocket.core.internal.WebSocketCoreSession;
|
||||||
import org.eclipse.jetty.websocket.server.JettyWebSocketServerContainer;
|
import org.eclipse.jetty.websocket.server.JettyWebSocketServerContainer;
|
||||||
import org.eclipse.jetty.websocket.server.JettyWebSocketServletContainerInitializer;
|
import org.eclipse.jetty.websocket.server.JettyWebSocketServletContainerInitializer;
|
||||||
import org.eclipse.jetty.websocket.tests.EchoSocket;
|
import org.eclipse.jetty.websocket.tests.EchoSocket;
|
||||||
|
@ -98,7 +98,7 @@ public class ClientConfigTest
|
||||||
server.stop();
|
server.stop();
|
||||||
}
|
}
|
||||||
|
|
||||||
@WebSocket(maxIdleTime=idleTimeout, maxTextMessageSize=maxMessageSize, maxBinaryMessageSize=maxMessageSize, inputBufferSize=inputBufferSize, batchMode=BatchMode.ON)
|
@WebSocket(idleTimeout=idleTimeout, maxTextMessageSize=maxMessageSize, maxBinaryMessageSize=maxMessageSize, inputBufferSize=inputBufferSize, batchMode=BatchMode.ON)
|
||||||
public class AnnotatedConfigEndpoint extends EventSocket
|
public class AnnotatedConfigEndpoint extends EventSocket
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
@ -182,7 +182,7 @@ public class ClientConfigTest
|
||||||
|
|
||||||
@ParameterizedTest
|
@ParameterizedTest
|
||||||
@MethodSource("data")
|
@MethodSource("data")
|
||||||
public void testMaxIdleTime(String param) throws Exception
|
public void testIdleTimeout(String param) throws Exception
|
||||||
{
|
{
|
||||||
URI uri = URI.create("ws://localhost:" + connector.getLocalPort() + "/");
|
URI uri = URI.create("ws://localhost:" + connector.getLocalPort() + "/");
|
||||||
EventSocket clientEndpoint = getClientSocket(param);
|
EventSocket clientEndpoint = getClientSocket(param);
|
||||||
|
|
|
@ -40,8 +40,8 @@ import org.eclipse.jetty.websocket.api.WebSocketTimeoutException;
|
||||||
import org.eclipse.jetty.websocket.api.annotations.WebSocket;
|
import org.eclipse.jetty.websocket.api.annotations.WebSocket;
|
||||||
import org.eclipse.jetty.websocket.client.WebSocketClient;
|
import org.eclipse.jetty.websocket.client.WebSocketClient;
|
||||||
import org.eclipse.jetty.websocket.common.WebSocketSession;
|
import org.eclipse.jetty.websocket.common.WebSocketSession;
|
||||||
import org.eclipse.jetty.websocket.core.internal.WebSocketCoreSession;
|
|
||||||
import org.eclipse.jetty.websocket.core.internal.WebSocketConnection;
|
import org.eclipse.jetty.websocket.core.internal.WebSocketConnection;
|
||||||
|
import org.eclipse.jetty.websocket.core.internal.WebSocketCoreSession;
|
||||||
import org.eclipse.jetty.websocket.server.JettyWebSocketServerContainer;
|
import org.eclipse.jetty.websocket.server.JettyWebSocketServerContainer;
|
||||||
import org.eclipse.jetty.websocket.server.JettyWebSocketServlet;
|
import org.eclipse.jetty.websocket.server.JettyWebSocketServlet;
|
||||||
import org.eclipse.jetty.websocket.server.JettyWebSocketServletContainerInitializer;
|
import org.eclipse.jetty.websocket.server.JettyWebSocketServletContainerInitializer;
|
||||||
|
@ -96,7 +96,7 @@ public class ServerConfigTest
|
||||||
return Stream.of("servletConfig", "annotatedConfig", "containerConfig", "sessionConfig").map(Arguments::of);
|
return Stream.of("servletConfig", "annotatedConfig", "containerConfig", "sessionConfig").map(Arguments::of);
|
||||||
}
|
}
|
||||||
|
|
||||||
@WebSocket(maxIdleTime=idleTimeout, maxTextMessageSize=maxMessageSize, maxBinaryMessageSize=maxMessageSize, inputBufferSize=inputBufferSize, batchMode=BatchMode.ON)
|
@WebSocket(idleTimeout=idleTimeout, maxTextMessageSize=maxMessageSize, maxBinaryMessageSize=maxMessageSize, inputBufferSize=inputBufferSize, batchMode=BatchMode.ON)
|
||||||
public static class AnnotatedConfigEndpoint extends EventSocket
|
public static class AnnotatedConfigEndpoint extends EventSocket
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
@ -257,7 +257,7 @@ public class ServerConfigTest
|
||||||
|
|
||||||
@ParameterizedTest
|
@ParameterizedTest
|
||||||
@MethodSource("data")
|
@MethodSource("data")
|
||||||
public void testMaxIdleTime(String path) throws Exception
|
public void testIdleTimeout(String path) throws Exception
|
||||||
{
|
{
|
||||||
URI uri = URI.create("ws://localhost:" + connector.getLocalPort() + "/" + path);
|
URI uri = URI.create("ws://localhost:" + connector.getLocalPort() + "/" + path);
|
||||||
EventSocket clientEndpoint = new EventSocket();
|
EventSocket clientEndpoint = new EventSocket();
|
||||||
|
|
|
@ -71,7 +71,7 @@ import org.eclipse.jetty.websocket.core.WebSocketExtensionRegistry;
|
||||||
* <b>Configuration / Init-Parameters:</b>
|
* <b>Configuration / Init-Parameters:</b>
|
||||||
* </p>
|
* </p>
|
||||||
* <dl>
|
* <dl>
|
||||||
* <dt>maxIdleTime</dt>
|
* <dt>idleTimeout</dt>
|
||||||
* <dd>set the time in ms that a websocket may be idle before closing<br>
|
* <dd>set the time in ms that a websocket may be idle before closing<br>
|
||||||
* <dt>maxTextMessageSize</dt>
|
* <dt>maxTextMessageSize</dt>
|
||||||
* <dd>set the size in UTF-8 bytes that a websocket may be accept as a Text Message before closing<br>
|
* <dd>set the size in UTF-8 bytes that a websocket may be accept as a Text Message before closing<br>
|
||||||
|
@ -119,7 +119,13 @@ public abstract class WebSocketServlet extends HttpServlet
|
||||||
components = WebSocketComponents.ensureWebSocketComponents(servletContext);
|
components = WebSocketComponents.ensureWebSocketComponents(servletContext);
|
||||||
mapping = new WebSocketMapping(components);
|
mapping = new WebSocketMapping(components);
|
||||||
|
|
||||||
String max = getInitParameter("maxIdleTime");
|
String max = getInitParameter("idleTimeout");
|
||||||
|
if (max == null)
|
||||||
|
{
|
||||||
|
max = getInitParameter("maxIdleTime");
|
||||||
|
if (max != null)
|
||||||
|
LOG.warn("'maxIdleTime' init param is deprecated, use 'idleTimeout' instead");
|
||||||
|
}
|
||||||
if (max != null)
|
if (max != null)
|
||||||
customizer.setIdleTimeout(Duration.ofMillis(Long.parseLong(max)));
|
customizer.setIdleTimeout(Duration.ofMillis(Long.parseLong(max)));
|
||||||
|
|
||||||
|
|
|
@ -55,7 +55,7 @@ import org.eclipse.jetty.websocket.core.WebSocketComponents;
|
||||||
* <b>Configuration / Init-Parameters:</b>
|
* <b>Configuration / Init-Parameters:</b>
|
||||||
* </p>
|
* </p>
|
||||||
* <dl>
|
* <dl>
|
||||||
* <dt>maxIdleTime</dt>
|
* <dt>idleTimeout</dt>
|
||||||
* <dd>set the time in ms that a websocket may be idle before closing<br>
|
* <dd>set the time in ms that a websocket may be idle before closing<br>
|
||||||
* <dt>maxTextMessageSize</dt>
|
* <dt>maxTextMessageSize</dt>
|
||||||
* <dd>set the size in UTF-8 bytes that a websocket may be accept as a Text Message before closing<br>
|
* <dd>set the size in UTF-8 bytes that a websocket may be accept as a Text Message before closing<br>
|
||||||
|
@ -164,7 +164,13 @@ public class WebSocketUpgradeFilter implements Filter, Dumpable
|
||||||
else
|
else
|
||||||
mapping = new WebSocketMapping(WebSocketComponents.ensureWebSocketComponents(context));
|
mapping = new WebSocketMapping(WebSocketComponents.ensureWebSocketComponents(context));
|
||||||
|
|
||||||
String max = config.getInitParameter("maxIdleTime");
|
String max = config.getInitParameter("idleTimeout");
|
||||||
|
if (max == null)
|
||||||
|
{
|
||||||
|
max = config.getInitParameter("maxIdleTime");
|
||||||
|
if (max != null)
|
||||||
|
LOG.warn("'maxIdleTime' init param is deprecated, use 'idleTimeout' instead");
|
||||||
|
}
|
||||||
if (max != null)
|
if (max != null)
|
||||||
defaultCustomizer.setIdleTimeout(Duration.ofMillis(Long.parseLong(max)));
|
defaultCustomizer.setIdleTimeout(Duration.ofMillis(Long.parseLong(max)));
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue