Class HandlerWrapper
- All Implemented Interfaces:
Handler, HandlerContainer, Container, Destroyable, Dumpable, Dumpable.DumpableContainer, LifeCycle
- Direct Known Subclasses:
AsyncDelayHandler, BufferedResponseHandler, DebugHandler, IdleTimeoutHandler, InetAccessHandler, ResourceHandler, ScopedHandler, SecuredRedirectHandler, SecurityHandler, ThreadLimitHandler
@ManagedObject("Handler wrapping another Handler")
public class HandlerWrapper
extends AbstractHandlerContainer
A
HandlerWrapper acts as a Handler but delegates the handle method and
life cycle events to a delegate. This is primarily used to implement the Decorator pattern.-
Nested Class Summary
Nested classes/interfaces inherited from class AbstractHandler
AbstractHandler.ErrorDispatchHandlerNested classes/interfaces inherited from class AbstractLifeCycle
AbstractLifeCycle.AbstractLifeCycleListener, AbstractLifeCycle.StopExceptionNested classes/interfaces inherited from interface Container
Container.InheritedListener, Container.ListenerNested classes/interfaces inherited from interface Dumpable
Dumpable.DumpableContainerNested classes/interfaces inherited from interface LifeCycle
LifeCycle.Listener -
Field Summary
Fields -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoiddestroy()Destroys the managed Destroyable beans in the reverse order they were added.protected voidexpandChildren(List<Handler> list, Class<?> byClass) Handler[]getTail()Get the tail of a chain ofHandlerWrappers.voidhandle(String target, Request baseRequest, jakarta.servlet.http.HttpServletRequest request, jakarta.servlet.http.HttpServletResponse response) Handle a request.voidinsertHandler(HandlerWrapper wrapper) Replace the current handler with another HandlerWrapper linked to the current handler.static voidsetAsParent(Handler.Container parent, Handler handler) Make aHandler.Containerthe parent of aHandlervoidsetHandler(Handler handler) Methods inherited from class AbstractHandlerContainer
expandHandler, findContainerOf, getChildHandlerByClass, getChildHandlers, getChildHandlersByClass, setServerMethods inherited from class AbstractHandler
doError, doStart, doStop, getServerMethods inherited from class ContainerLifeCycle
addBean, addBean, addEventListener, addManaged, contains, dump, dump, dump, dumpObjects, dumpStdErr, getBean, getBeans, getBeans, getContainedBeans, getContainedBeans, installBean, installBean, isAuto, isManaged, isUnmanaged, manage, removeBean, removeBeans, removeEventListener, setBeans, start, stop, unmanage, updateBean, updateBean, updateBeans, updateBeansMethods inherited from class AbstractLifeCycle
getEventListeners, getState, getState, isFailed, isRunning, isStarted, isStarting, isStopped, isStopping, setEventListeners, start, stop, toStringMethods inherited from class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface Container
getCachedBeans, getEventListenersMethods inherited from interface Dumpable.DumpableContainer
isDumpableMethods inherited from interface LifeCycle
addEventListener, isFailed, isRunning, isStarted, isStarting, isStopped, isStopping, removeEventListener, start, stop
-
Field Details
-
_handler
-
-
Constructor Details
-
HandlerWrapper
public HandlerWrapper()
-
-
Method Details
-
getHandler
- Returns:
- Returns the handlers.
-
getHandlers
- Returns:
- Returns the handlers.
-
setHandler
-
getTail
Get the tail of a chain ofHandlerWrappers.- Returns:
- The last
HandlerWrapperin a chain ofHandlerWrappers
-
insertHandler
Replace the current handler with another HandlerWrapper linked to the current handler.This is equivalent to:
wrapper.setHandler(getHandler()); setHandler(wrapper);
- Parameters:
wrapper- the wrapper to insert
-
handle
public void handle(String target, Request baseRequest, jakarta.servlet.http.HttpServletRequest request, jakarta.servlet.http.HttpServletResponse response) throws IOException, jakarta.servlet.ServletException Description copied from interface:HandlerHandle a request.- Specified by:
handlein interfaceHandler- Specified by:
handlein classAbstractHandler- Parameters:
target- The target of the request - either a URI or a name.baseRequest- The original unwrapped request object.request- The request either as theRequestobject or a wrapper of that request.response- The response as theResponseobject or a wrapper of that request.- Throws:
IOException- if unable to handle the request or response processingjakarta.servlet.ServletException- if unable to handle the request or response due to underlying servlet issue
-
expandChildren
- Overrides:
expandChildrenin classAbstractHandlerContainer
-
destroy
public void destroy()Description copied from class:ContainerLifeCycleDestroys the managed Destroyable beans in the reverse order they were added.- Specified by:
destroyin interfaceDestroyable- Specified by:
destroyin interfaceHandler- Overrides:
destroyin classAbstractHandler
-
setAsParent
Make a
Handler.Containerthe parent of aHandler- Parameters:
parent- TheHandler.Containerthat will be the parenthandler- TheHandlerthat will be the child
-