All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.frameworkset.web.request.async.DeferredResultProcessingInterceptor Maven / Gradle / Ivy

Go to download

bboss is a j2ee framework include aop/ioc,mvc,persistent,taglib,rpc,event ,bean-xml serializable and so on.http://www.bbossgroups.com

There is a newer version: 6.2.7
Show newest version
package org.frameworkset.web.request.async;

import org.frameworkset.web.servlet.mvc.NativeWebRequest;

/**
 * Intercepts concurrent request handling, where the concurrent result is
 * obtained by waiting for a {@link DeferredResult} to be set from a thread
 * chosen by the application (e.g. in response to some external event).
 *
 * 

A {@code DeferredResultProcessingInterceptor} is invoked before the start * of async processing, after the {@code DeferredResult} is set as well as on * timeout, or or after completing for any reason including a timeout or network * error. * *

As a general rule exceptions raised by interceptor methods will cause * async processing to resume by dispatching back to the container and using * the Exception instance as the concurrent result. Such exceptions will then * be processed through the {@code HandlerExceptionResolver} mechanism. * *

The {@link #handleTimeout(NativeWebRequest, DeferredResult) afterTimeout} * method can set the {@code DeferredResult} in order to resume processing. * * @author Rossen Stoyanchev * @author Rob Winch * @since 3.2 */ public interface DeferredResultProcessingInterceptor { /** * Invoked immediately before the start of concurrent handling, in the same * thread that started it. This method may be used to capture state just prior * to the start of concurrent processing with the given {@code DeferredResult}. * @param request the current request * @param deferredResult the DeferredResult for the current request * @throws Exception in case of errors */ void beforeConcurrentHandling(NativeWebRequest request, DeferredResult deferredResult) throws Exception; /** * Invoked immediately after the start of concurrent handling, in the same * thread that started it. This method may be used to detect the start of * concurrent processing with the given {@code DeferredResult}. *

The {@code DeferredResult} may have already been set, for example at * the time of its creation or by another thread. * @param request the current request * @param deferredResult the DeferredResult for the current request * @throws Exception in case of errors */ void preProcess(NativeWebRequest request, DeferredResult deferredResult) throws Exception; /** * Invoked after a {@code DeferredResult} has been set, via * {@link DeferredResult#setResult(Object)} or * {@link DeferredResult#setErrorResult(Object)}, and is also ready to * handle the concurrent result. *

This method may also be invoked after a timeout when the * {@code DeferredResult} was created with a constructor accepting a default * timeout result. * @param request the current request * @param deferredResult the DeferredResult for the current request * @param concurrentResult the result to which the {@code DeferredResult} * @throws Exception in case of errors */ void postProcess(NativeWebRequest request, DeferredResult deferredResult, Object concurrentResult) throws Exception; /** * Invoked from a container thread when an async request times out before * the {@code DeferredResult} has been set. Implementations may invoke * {@link DeferredResult#setResult(Object) setResult} or * {@link DeferredResult#setErrorResult(Object) setErrorResult} to resume processing. * @param request the current request * @param deferredResult the DeferredResult for the current request; if the * {@code DeferredResult} is set, then concurrent processing is resumed and * subsequent interceptors are not invoked * @return {@code true} if processing should continue, or {@code false} if * other interceptors should not be invoked * @throws Exception in case of errors */ boolean handleTimeout(NativeWebRequest request, DeferredResult deferredResult) throws Exception; /** * Invoked from a container thread when an async request completed for any * reason including timeout and network error. This method is useful for * detecting that a {@code DeferredResult} instance is no longer usable. * @param request the current request * @param deferredResult the DeferredResult for the current request * @throws Exception in case of errors */ void afterCompletion(NativeWebRequest request, DeferredResult deferredResult) throws Exception; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy