org.eclipse.jetty.server.handler.IdleTimeoutHandler Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of aem-sdk-api Show documentation
Show all versions of aem-sdk-api Show documentation
The Adobe Experience Manager SDK
//
// ========================================================================
// Copyright (c) 1995-2022 Mort Bay Consulting Pty Ltd and others.
// ------------------------------------------------------------------------
// All rights reserved. This program and the accompanying materials
// are made available under the terms of the Eclipse Public License v1.0
// and Apache License v2.0 which accompanies this distribution.
//
// The Eclipse Public License is available at
// http://www.eclipse.org/legal/epl-v10.html
//
// The Apache License v2.0 is available at
// http://www.opensource.org/licenses/apache2.0.php
//
// You may elect to redistribute this code under either of these licenses.
// ========================================================================
//
package org.eclipse.jetty.server.handler;
import java.io.IOException;
import javax.servlet.AsyncEvent;
import javax.servlet.AsyncListener;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.eclipse.jetty.server.HttpChannel;
import org.eclipse.jetty.server.Request;
/**
* Handler to adjust the idle timeout of requests while dispatched.
* Can be applied in jetty.xml with
*
* <Get id='handler' name='Handler'/>
* <Set name='Handler'>
* <New id='idleTimeoutHandler' class='org.eclipse.jetty.server.handler.IdleTimeoutHandler'>
* <Set name='Handler'><Ref id='handler'/></Set>
* <Set name='IdleTimeoutMs'>5000</Set>
* </New>
* </Set>
*
*
* @deprecated The Eclipse Jetty and Apache Felix Http Jetty packages are no longer supported.
*/
@Deprecated(since = "2021-05-27")
public class IdleTimeoutHandler extends HandlerWrapper {
private long _idleTimeoutMs = 1000;
private boolean _applyToAsync = false;
public boolean isApplyToAsync() {
return _applyToAsync;
}
/**
* Should the adjusted idle time be maintained for asynchronous requests
*
* @param applyToAsync true if alternate idle timeout is applied to asynchronous requests
*/
public void setApplyToAsync(boolean applyToAsync) {
_applyToAsync = applyToAsync;
}
public long getIdleTimeoutMs() {
return _idleTimeoutMs;
}
/**
* @param idleTimeoutMs The idle timeout in MS to apply while dispatched or async
*/
public void setIdleTimeoutMs(long idleTimeoutMs) {
this._idleTimeoutMs = idleTimeoutMs;
}
@Override
public void handle(String target, Request baseRequest, HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException {
final HttpChannel channel = baseRequest.getHttpChannel();
final long idle_timeout = baseRequest.getHttpChannel().getIdleTimeout();
channel.setIdleTimeout(_idleTimeoutMs);
try {
super.handle(target, baseRequest, request, response);
} finally {
if (_applyToAsync && request.isAsyncStarted()) {
request.getAsyncContext().addListener(new AsyncListener() {
@Override
public void onTimeout(AsyncEvent event) throws IOException {
}
@Override
public void onStartAsync(AsyncEvent event) throws IOException {
}
@Override
public void onError(AsyncEvent event) throws IOException {
channel.setIdleTimeout(idle_timeout);
}
@Override
public void onComplete(AsyncEvent event) throws IOException {
channel.setIdleTimeout(idle_timeout);
}
});
} else
channel.setIdleTimeout(idle_timeout);
}
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy