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.
Modifier and Type | Method and Description |
---|---|
void |
addValve(GlassFishValve valve)
Add a new Valve to the end of the pipeline associated with this
Container.
|
void |
addValve(Valve valve)
Add Tomcat-style valve.
|
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).
|
GlassFishValve getBasic()
Return the Valve instance that has been distinguished as the basic Valve for this Pipeline (if any).
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
implements Contained
, with the owning Container as an
argument. The method may throw an IllegalArgumentException
if this Valve chooses not to be associated with this Container, or
IllegalStateException
if it is already associated with
a different Container.
valve
- Valve to be distinguished as the basic Valveboolean hasNonBasicValves()
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 implements
Contained
, with the owning Container as an argument.
The method may throw an
IllegalArgumentException
if this Valve chooses not to
be associated with this Container, or IllegalStateException
if it is already associated with a different Container.
valve
- Valve to be addedIllegalArgumentException
- 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 Containervoid addValve(Valve valve)
valve
- the Tomcat-style valve to be addedGlassFishValve[] getValves()
void invoke(Request request, Response response) throws IOException, javax.servlet.ServletException
request
- The servlet request we are processingresponse
- The servlet response we are creatingIOException
- if an input/output error occursjavax.servlet.ServletException
- if a servlet exception is thrownvoid removeValve(GlassFishValve valve)
setContainer(null)
method
will be called if it implements Contained
.valve
- Valve to be removedCopyright © 2018. All rights reserved.