Interface Pipeline
-
- All Known Implementing Classes:
AdHocWebModule
,ContainerBase
,ContextFacade
,PEVirtualServer
,PwcWebModule
,StandardContext
,StandardEngine
,StandardHost
,StandardPipeline
,StandardWrapper
,VirtualServer
,VirtualServerPipeline
,WebModule
,WebPipeline
public interface Pipeline
Interface describing a collection of Valves that should be executed in sequence when the
invoke()
method is invoked. It is required that a Valve somewhere in the pipeline (usually the last one) must process the request and create the corresponding response, rather than trying to pass the request on.There is generally a single Pipeline instance associated with each Container. The container's normal request processing functionality is generally encapsulated in a container-specific Valve, which should always be executed at the end of a pipeline. To facilitate this, the
setBasic()
method is provided to set the Valve instance that will always be executed last. Other Valves will be executed in the order that they were added, before the basic Valve is executed.- Version:
- $Revision: 1.2 $ $Date: 2005/12/08 01:27:18 $
- Author:
- Craig R. McClanahan, Peter Donald
-
-
Method Summary
All Methods Instance Methods Abstract Methods Modifier and Type Method Description void
addValve(Valve valve)
Add Tomcat-style valve.void
addValve(GlassFishValve valve)
Add a new Valve to the end of the pipeline associated with this Container.GlassFishValve
getBasic()
Return the Valve instance that has been distinguished as the basic Valve for this Pipeline (if any).GlassFishValve[]
getValves()
Return the set of Valves in the pipeline associated with this Container, including the basic Valve (if any).boolean
hasNonBasicValves()
void
invoke(Request request, Response response)
Cause the specified request and response to be processed by the Valves associated with this pipeline, until one of these valves causes the response to be created and returned.void
removeValve(GlassFishValve valve)
Remove the specified Valve from the pipeline associated with this Container, if it is found; otherwise, do nothing.void
setBasic(GlassFishValve valve)
Set the Valve instance that has been distinguished as the basic Valve for this Pipeline (if any).
-
-
-
Method Detail
-
getBasic
GlassFishValve getBasic()
Return the Valve instance that has been distinguished as the basic Valve for this Pipeline (if any).
-
setBasic
void setBasic(GlassFishValve valve)
Set the Valve instance that has been distinguished as the basic Valve for this Pipeline (if any). Prior to setting the basic Valve, the Valve's
setContainer()
will be called, if it implementsContained
, with the owning Container as an argument. The method may throw anIllegalArgumentException
if this Valve chooses not to be associated with this Container, orIllegalStateException
if it is already associated with a different Container.- Parameters:
valve
- Valve to be distinguished as the basic Valve
-
hasNonBasicValves
boolean hasNonBasicValves()
- Returns:
- true if this pipeline has any non basic valves, false otherwise
-
addValve
void addValve(GlassFishValve valve)
Add a new Valve to the end of the pipeline associated with this Container. Prior to adding the Valve, the Valve's
setContainer()
method will be called, if it implementsContained
, with the owning Container as an argument. The method may throw anIllegalArgumentException
if this Valve chooses not to be associated with this Container, orIllegalStateException
if it is already associated with a different Container.- Parameters:
valve
- Valve to be added- Throws:
IllegalArgumentException
- if this Container refused to accept the specified ValveIllegalArgumentException
- if the specified Valve refuses to be associated with this ContainerIllegalStateException
- if the specified Valve is already associated with a different Container
-
addValve
void addValve(Valve valve)
Add Tomcat-style valve.- Parameters:
valve
- the Tomcat-style valve to be added
-
getValves
GlassFishValve[] getValves()
Return the set of Valves in the pipeline associated with this Container, including the basic Valve (if any). If there are no such Valves, a zero-length array is returned.
-
invoke
void invoke(Request request, Response response) throws IOException, jakarta.servlet.ServletException
Cause the specified request and response to be processed by the Valves associated with this pipeline, until one of these valves causes the response to be created and returned. The implementation must ensure that multiple simultaneous requests (on different threads) can be processed through the same Pipeline without interfering with each other's control flow.- Parameters:
request
- The servlet request we are processingresponse
- The servlet response we are creating- Throws:
IOException
- if an input/output error occursjakarta.servlet.ServletException
- if a servlet exception is thrown
-
removeValve
void removeValve(GlassFishValve valve)
Remove the specified Valve from the pipeline associated with this Container, if it is found; otherwise, do nothing. If the Valve is found and removed, the Valve'ssetContainer(null)
method will be called if it implementsContained
.- Parameters:
valve
- Valve to be removed
-
-