Package org.eclipse.jetty.server.handler
Class HandlerCollection
- java.lang.Object
-
- org.eclipse.jetty.util.component.AbstractLifeCycle
-
- org.eclipse.jetty.util.component.ContainerLifeCycle
-
- org.eclipse.jetty.server.handler.AbstractHandler
-
- org.eclipse.jetty.server.handler.AbstractHandlerContainer
-
- org.eclipse.jetty.server.handler.HandlerCollection
-
- All Implemented Interfaces:
Handler
,HandlerContainer
,Container
,Destroyable
,Dumpable
,Dumpable.DumpableContainer
,LifeCycle
- Direct Known Subclasses:
ContextHandlerCollection
,HandlerList
@ManagedObject("Handler of multiple handlers") public class HandlerCollection extends AbstractHandlerContainer
A collection of handlers.The default implementations calls all handlers in list order, regardless of the response status or exceptions. Derived implementation may alter the order or the conditions of calling the contained handlers.
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description protected static class
HandlerCollection.Handlers
-
Nested classes/interfaces inherited from class org.eclipse.jetty.server.handler.AbstractHandler
AbstractHandler.ErrorDispatchHandler
-
Nested classes/interfaces inherited from class org.eclipse.jetty.util.component.AbstractLifeCycle
AbstractLifeCycle.AbstractLifeCycleListener
-
Nested classes/interfaces inherited from interface org.eclipse.jetty.util.component.Container
Container.InheritedListener, Container.Listener
-
Nested classes/interfaces inherited from interface org.eclipse.jetty.util.component.Dumpable
Dumpable.DumpableContainer
-
Nested classes/interfaces inherited from interface org.eclipse.jetty.util.component.LifeCycle
LifeCycle.Listener
-
-
Field Summary
Fields Modifier and Type Field Description protected java.util.concurrent.atomic.AtomicReference<HandlerCollection.Handlers>
_handlers
-
Constructor Summary
Constructors Constructor Description HandlerCollection()
HandlerCollection(boolean mutableWhenRunning, Handler... handlers)
HandlerCollection(Handler... handlers)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description void
addHandler(Handler handler)
Adds a handler.void
destroy()
Destroys the managed Destroyable beans in the reverse order they were added.protected void
expandChildren(java.util.List<Handler> list, java.lang.Class<?> byClass)
Handler[]
getHandlers()
void
handle(java.lang.String target, Request baseRequest, javax.servlet.http.HttpServletRequest request, javax.servlet.http.HttpServletResponse response)
Handle a request.protected HandlerCollection.Handlers
newHandlers(Handler[] handlers)
void
prependHandler(Handler handler)
Prepends a handler.void
removeHandler(Handler handler)
void
setHandlers(Handler[] handlers)
protected boolean
updateHandlers(HandlerCollection.Handlers old, HandlerCollection.Handlers handlers)
-
Methods inherited from class org.eclipse.jetty.server.handler.AbstractHandlerContainer
doShutdown, expandHandler, findContainerOf, getChildHandlerByClass, getChildHandlers, getChildHandlersByClass, setServer
-
Methods inherited from class org.eclipse.jetty.server.handler.AbstractHandler
doError, doStart, doStop, getServer
-
Methods inherited from class org.eclipse.jetty.util.component.ContainerLifeCycle
addBean, addBean, addEventListener, addManaged, contains, dump, dump, dump, dump, dump, dumpBeans, dumpObject, dumpObjects, dumpStdErr, dumpThis, getBean, getBeans, getBeans, getContainedBeans, getContainedBeans, isAuto, isManaged, isUnmanaged, manage, removeBean, removeBeans, removeEventListener, setBeans, setStopTimeout, start, stop, unmanage, updateBean, updateBean, updateBeans
-
Methods inherited from class org.eclipse.jetty.util.component.AbstractLifeCycle
addLifeCycleListener, getState, getState, getStopTimeout, isFailed, isRunning, isStarted, isStarting, isStopped, isStopping, removeLifeCycleListener, start, stop, toString
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface org.eclipse.jetty.util.component.Dumpable.DumpableContainer
isDumpable
-
Methods inherited from interface org.eclipse.jetty.util.component.LifeCycle
addLifeCycleListener, isFailed, isRunning, isStarted, isStarting, isStopped, isStopping, removeLifeCycleListener, start, stop
-
-
-
-
Field Detail
-
_handlers
protected final java.util.concurrent.atomic.AtomicReference<HandlerCollection.Handlers> _handlers
-
-
Method Detail
-
getHandlers
@ManagedAttribute(value="Wrapped handlers", readonly=true) public Handler[] getHandlers()
- Returns:
- the array of handlers.
-
setHandlers
public void setHandlers(Handler[] handlers)
- Parameters:
handlers
- the array of handlers to set.
-
newHandlers
protected HandlerCollection.Handlers newHandlers(Handler[] handlers)
-
updateHandlers
protected boolean updateHandlers(HandlerCollection.Handlers old, HandlerCollection.Handlers handlers)
-
handle
public void handle(java.lang.String target, Request baseRequest, javax.servlet.http.HttpServletRequest request, javax.servlet.http.HttpServletResponse response) throws java.io.IOException, javax.servlet.ServletException
Description copied from interface:Handler
Handle a request.- Specified by:
handle
in interfaceHandler
- Specified by:
handle
in 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 theRequest
object or a wrapper of that request. The
method can be used access the Request object if required.HttpConnection.getCurrentConnection()
.getHttpChannel()
.getRequest()
response
- The response as theResponse
object or a wrapper of that request. The
method can be used access the Response object if required.HttpConnection.getCurrentConnection()
.getHttpChannel()
.getResponse()
- Throws:
java.io.IOException
- if unable to handle the request or response processingjavax.servlet.ServletException
- if unable to handle the request or response due to underlying servlet issue
-
addHandler
public void addHandler(Handler handler)
Adds a handler. This implementation adds the passed handler to the end of the existing collection of handlers. If the handler is already added, it is removed and readded
-
prependHandler
public void prependHandler(Handler handler)
Prepends a handler. This implementation adds the passed handler to the start of the existing collection of handlers.
-
removeHandler
public void removeHandler(Handler handler)
-
expandChildren
protected void expandChildren(java.util.List<Handler> list, java.lang.Class<?> byClass)
- Overrides:
expandChildren
in classAbstractHandlerContainer
-
destroy
public void destroy()
Description copied from class:ContainerLifeCycle
Destroys the managed Destroyable beans in the reverse order they were added.- Specified by:
destroy
in interfaceDestroyable
- Specified by:
destroy
in interfaceHandler
- Overrides:
destroy
in classAbstractHandler
-
-