Class FacesRequestProcessor
- All Implemented Interfaces:
Serializable
Concrete implementation of RequestProcessor
that
implements the standard Struts request processing lifecycle on a
request that was received as an ActionEvent
by our
associated ActionListener
. It replaces the request processor
instance normally configured by Struts, so it must support non-Faces
requests as well.
- Version:
- $Rev$ $Date$
- See Also:
-
Field Summary
Fields inherited from class org.apache.struts.action.RequestProcessor
actions, INCLUDE_PATH_INFO, INCLUDE_SERVLET_PATH, moduleConfig, servlet
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionprotected void
doForward
(String uri, HttpServletRequest request, HttpServletResponse response) Set up a Faces Request if we are not already processing one.protected Action
processActionCreate
(HttpServletRequest request, HttpServletResponse response, ActionMapping mapping) Return anAction
instance that will be used to process the current request, creating a new one if necessary.protected ActionForm
processActionForm
(HttpServletRequest request, HttpServletResponse response, ActionMapping mapping) Retrieve and return theActionForm
associated with this mapping, creating and retaining one if necessary.protected ActionForward
processActionPerform
(HttpServletRequest request, HttpServletResponse response, Action action, ActionForm form, ActionMapping mapping) Ask the specifiedAction
instance to handle this request.protected boolean
processForward
(HttpServletRequest request, HttpServletResponse response, ActionMapping mapping) Process a forward requested by this mapping (if any).protected void
processForwardConfig
(HttpServletRequest request, HttpServletResponse response, ForwardConfig forward) Forward or redirect to the specified destination, by the specified mechanism.protected boolean
processInclude
(HttpServletRequest request, HttpServletResponse response, ActionMapping mapping) Process an include requested by this mapping (if any).protected String
processPath
(HttpServletRequest request, HttpServletResponse response) Identify and return the path component (from the request URI for a non-Faces request, or from the form event for a Faces request) that we will use to select an ActionMapping to dispatch with.protected void
processPopulate
(HttpServletRequest request, HttpServletResponse response, ActionForm form, ActionMapping mapping) Populate the properties of the specifiedActionForm
instance from the request parameters included with this request, IF this is a non-Faces request.protected boolean
processValidate
(HttpServletRequest request, HttpServletResponse response, ActionForm form, ActionMapping mapping) If this request was not cancelled, and the request'sActionMapping
has not disabled validation, call thevalidate
method of the specifiedActionForm
, and forward to the input path if there were any errors.Methods inherited from class org.apache.struts.action.RequestProcessor
destroy, doInclude, getInternal, getServletContext, init, internalModuleRelativeForward, internalModuleRelativeInclude, process, processCachedMessages, processContent, processException, processLocale, processMapping, processMultipart, processNoCache, processPreprocess, processRoles
-
Field Details
-
LIFECYCLE_ID_ATTR
The lifecycle id.
- See Also:
-
-
Constructor Details
-
FacesRequestProcessor
public FacesRequestProcessor()
-
-
Method Details
-
doForward
protected void doForward(String uri, HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException Set up a Faces Request if we are not already processing one. Next, create a new view if the specified
uri
is different from the current view identifier. Finally, cause the new view to be rendered, and callFacesContext.responseComplete()
to indicate that this has already been done.- Overrides:
doForward
in classRequestProcessor
- Parameters:
uri
- Context-relative path to forward torequest
- Current page requestresponse
- Current page response- Throws:
IOException
- if an input/output error occursServletException
- if a servlet error occurs
-
processActionCreate
protected Action processActionCreate(HttpServletRequest request, HttpServletResponse response, ActionMapping mapping) throws IOException Description copied from class:RequestProcessor
Return an
Action
instance that will be used to process the current request, creating a new one if necessary.- Overrides:
processActionCreate
in classRequestProcessor
- Parameters:
request
- The servlet request we are processingresponse
- The servlet response we are creatingmapping
- The mapping we are using- Returns:
- An
Action
instance that will be used to process the current request. - Throws:
IOException
- if an input/output error occurs
-
processActionForm
protected ActionForm processActionForm(HttpServletRequest request, HttpServletResponse response, ActionMapping mapping) Description copied from class:RequestProcessor
Retrieve and return the
ActionForm
associated with this mapping, creating and retaining one if necessary. If there is noActionForm
associated with this mapping, returnnull
.- Overrides:
processActionForm
in classRequestProcessor
- Parameters:
request
- The servlet request we are processingresponse
- The servlet response we are creatingmapping
- The mapping we are using- Returns:
- The
ActionForm
associated with this mapping.
-
processActionPerform
protected ActionForward processActionPerform(HttpServletRequest request, HttpServletResponse response, Action action, ActionForm form, ActionMapping mapping) throws IOException, ServletException Description copied from class:RequestProcessor
Ask the specified
Action
instance to handle this request. Return theActionForward
instance (if any) returned by the calledAction
for further processing.- Overrides:
processActionPerform
in classRequestProcessor
- Parameters:
request
- The servlet request we are processingresponse
- The servlet response we are creatingaction
- The Action instance to be usedform
- The ActionForm instance to pass to this Actionmapping
- The ActionMapping instance to pass to this Action- Returns:
- The
ActionForward
instance (if any) returned by the calledAction
. - Throws:
IOException
- if an input/output error occursServletException
- if a servlet exception occurs
-
processForward
protected boolean processForward(HttpServletRequest request, HttpServletResponse response, ActionMapping mapping) throws IOException, ServletException Description copied from class:RequestProcessor
Process a forward requested by this mapping (if any). Return
true
if standard processing should continue, orfalse
if we have already handled this request.- Overrides:
processForward
in classRequestProcessor
- Parameters:
request
- The servlet request we are processingresponse
- The servlet response we are creatingmapping
- The ActionMapping we are using- Returns:
true
to continue normal processing;false
if a response has been created.- Throws:
IOException
- if an input/output error occursServletException
- if a servlet exception occurs
-
processForwardConfig
protected void processForwardConfig(HttpServletRequest request, HttpServletResponse response, ForwardConfig forward) throws IOException, ServletException Description copied from class:RequestProcessor
Forward or redirect to the specified destination, by the specified mechanism. This method uses a
ForwardConfig
object instead anActionForward
.- Overrides:
processForwardConfig
in classRequestProcessor
- Parameters:
request
- The servlet request we are processingresponse
- The servlet response we are creatingforward
- The ForwardConfig controlling where we go next- Throws:
IOException
- if an input/output error occursServletException
- if a servlet exception occurs
-
processInclude
protected boolean processInclude(HttpServletRequest request, HttpServletResponse response, ActionMapping mapping) throws IOException, ServletException Description copied from class:RequestProcessor
Process an include requested by this mapping (if any). Return
true
if standard processing should continue, orfalse
if we have already handled this request.- Overrides:
processInclude
in classRequestProcessor
- Parameters:
request
- The servlet request we are processingresponse
- The servlet response we are creatingmapping
- The ActionMapping we are using- Returns:
true
to continue normal processing;false
if a response has been created.- Throws:
IOException
- if an input/output error occursServletException
- if thrown by invoked methods
-
processPath
protected String processPath(HttpServletRequest request, HttpServletResponse response) throws IOException Identify and return the path component (from the request URI for a non-Faces request, or from the form event for a Faces request) that we will use to select an ActionMapping to dispatch with. If no such path can be identified, create an error response and return
null
.- Overrides:
processPath
in classRequestProcessor
- Parameters:
request
- The servlet request we are processingresponse
- The servlet response we are creating- Returns:
- The path that will be used to select an action mapping.
- Throws:
IOException
- if an input/output error occurs
-
processPopulate
protected void processPopulate(HttpServletRequest request, HttpServletResponse response, ActionForm form, ActionMapping mapping) throws ServletException Populate the properties of the specified
ActionForm
instance from the request parameters included with this request, IF this is a non-Faces request. For a Faces request, this will have already been done by the Update Model Values phase of the request processing lifecycle, so all we have to do is recognize whether the request was cancelled or not.- Overrides:
processPopulate
in classRequestProcessor
- Parameters:
request
- The servlet request we are processingresponse
- The servlet response we are creatingform
- The ActionForm instance we are populatingmapping
- The ActionMapping we are using- Throws:
ServletException
- if thrown by RequestUtils.populate()
-
processValidate
protected boolean processValidate(HttpServletRequest request, HttpServletResponse response, ActionForm form, ActionMapping mapping) throws IOException, ServletException, InvalidCancelException Description copied from class:RequestProcessor
If this request was not cancelled, and the request's
ActionMapping
has not disabled validation, call thevalidate
method of the specifiedActionForm
, and forward to the input path if there were any errors. Returntrue
if we should continue processing, orfalse
if we have already forwarded control back to the input form.- Overrides:
processValidate
in classRequestProcessor
- Parameters:
request
- The servlet request we are processingresponse
- The servlet response we are creatingform
- The ActionForm instance we are populatingmapping
- The ActionMapping we are using- Returns:
true
to continue normal processing;false
if a response has been created.- Throws:
IOException
- if an input/output error occursServletException
- if a servlet exception occursInvalidCancelException
- if a cancellation is attempted without the proper action configuration.
-