Class MessageStoreInterceptor
- All Implemented Interfaces:
- Serializable,- ConditionalInterceptor,- Interceptor
 An interceptor to store a ValidationAware action's messages / errors and field errors into
 HTTP Session, such that it will be retrievable at a later stage. This allows the action's message /
 errors and field errors to be available longer that just the particular HTTP request.
 
If no session exists, nothing will be stored and can be retrieved later. In other terms, the application is responsible to open the session.
 In the 'STORE' mode, the interceptor will store the ValidationAware action's message / errors
 and field errors into HTTP session.
 
 In the 'RETRIEVE' mode, the interceptor will retrieve the stored action's message / errors  and field
 errors and put them back into the ValidationAware action.
 
 In the 'AUTOMATIC' mode, the interceptor will always retrieve the stored action's message / errors
 and field errors and put them back into the ValidationAware action, and after Action execution,
 if the Result is an instance of ServletRedirectResult, the action's message / errors
 and field errors into automatically be stored in the HTTP session..
 
The interceptor does nothing in the 'NONE' mode, which is the default.
 The operation mode could be switched using:
 1] Setting the interceptor parameter eg.
 
   <action name="submitApplication" ...>
      <interceptor-ref name="store">
         <param name="operationMode">STORE</param>
      </interceptor-ref>
      <interceptor-ref name="defaultStack" />
      ....
   </action>
 
 2] Through request parameter (allowRequestParameterSwitch must be 'true' which is the default)
// the request will have the operation mode in 'STORE' http://localhost:8080/context/submitApplication.action?operationMode=STORE
- allowRequestParameterSwitch - To enable request parameter that could switch the operation mode of this interceptor.
- requestParameterSwitch - The request parameter that will indicate what mode this interceptor is in.
- operationMode - The operation mode this interceptor should be in (either 'STORE', 'RETRIEVE', 'AUTOMATIC', or 'NONE'). 'NONE' being the default.
The following method could be overridden:
- getRequestOperationMode - get the operation mode of this interceptor based on the request parameters
- mergeCollection - merge two collections
- mergeMap - merge two map
 
 <action name="submitApplication" ....>
    <interceptor-ref name="store">
      <param name="operationMode">aSTORE</param>
    </interceptor-ref>
    <interceptor-ref name="defaultStack" />
    <result name="input" type="redirect">aapplicationFailed.action</result>
    <result type="dispatcher">applicationSuccess.jsp</result>
 </action>
 <action name="applicationFailed" ....>
    <interceptor-ref name="store">
       <param name="operationMode">RETRIEVE</param>
    </interceptor-ref>
    <result>applicationFailed.jsp</result>
 </action>
 
 
 
 With the example above, 'submitApplication.action' will have the action messages / errors / field errors stored in the HTTP Session. Later when needed, (in this case, when 'applicationFailed.action' is fired, it will get the action messages / errors / field errors stored in the HTTP Session and put them back into the action.
- See Also:
- 
Field SummaryFields
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionprotected voidbefore(ActionInvocation invocation) Handle the retrieving of field errors / action messages / field errors, which is done before action invocation, and theoperationModeis 'RETRIEVE'.protected MessageStorePreResultListenercreatePreResultListener(ActionInvocation invocation) booleanprotected StringgetRequestOperationMode(ActionInvocation invocation) Get the operationMode through request parameter, ifallowRequestParameterSwitchis 'true', else it simply returns 'NONE', meaning its neither in the 'STORE_MODE' nor 'RETRIEVE_MODE'.intercept(ActionInvocation invocation) Override to handle interceptionprotected CollectionmergeCollection(Collection col1, Collection col2) Mergecol1andcol2and return the compositeCollection.protected MapMergemap1andmap2and return the compositeMapvoidsetAllowRequestParameterSwitch(boolean allowRequestParameterSwitch) voidsetOperationMode(String operationMode) voidsetRequestParameterSwitch(String requestParameterSwitch) Methods inherited from class org.apache.struts2.interceptor.AbstractInterceptordestroy, init, setDisabled, shouldIntercept
- 
Field Details- 
AUTOMATIC_MODE- See Also:
 
- 
STORE_MODE- See Also:
 
- 
RETRIEVE_MODE- See Also:
 
- 
NONE- See Also:
 
- 
fieldErrorsSessionKey- See Also:
 
- 
actionErrorsSessionKey- See Also:
 
- 
actionMessagesSessionKey- See Also:
 
 
- 
- 
Constructor Details- 
MessageStoreInterceptorpublic MessageStoreInterceptor()
 
- 
- 
Method Details- 
setAllowRequestParameterSwitchpublic void setAllowRequestParameterSwitch(boolean allowRequestParameterSwitch) 
- 
getAllowRequestParameterSwitchpublic boolean getAllowRequestParameterSwitch()
- 
setRequestParameterSwitch
- 
getRequestParameterSwitch
- 
setOperationMode
- 
getOperationModel
- 
interceptDescription copied from class:AbstractInterceptorOverride to handle interception- Specified by:
- interceptin interface- Interceptor
- Specified by:
- interceptin class- AbstractInterceptor
- Parameters:
- invocation- the action invocation
- Returns:
- the return code, either returned from ActionInvocation.invoke(), or from the interceptor itself.
- Throws:
- Exception- any system-level error, as defined in- Action.execute().
 
- 
createPreResultListener
- 
beforeHandle the retrieving of field errors / action messages / field errors, which is done before action invocation, and theoperationModeis 'RETRIEVE'.- Parameters:
- invocation- the action invocation
- Throws:
- Exception- in case of any error
 
- 
getRequestOperationModeGet the operationMode through request parameter, ifallowRequestParameterSwitchis 'true', else it simply returns 'NONE', meaning its neither in the 'STORE_MODE' nor 'RETRIEVE_MODE'.- Parameters:
- invocation- the action invocation
- Returns:
- the request operation mode
 
- 
mergeCollectionMergecol1andcol2and return the compositeCollection.- Parameters:
- col1- first collection
- col2- second collection
- Returns:
- the merged collection
 
- 
mergeMapMergemap1andmap2and return the compositeMap- Parameters:
- map1- first map
- map2- second map
- Returns:
- the merged map
 
 
-