|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Objectcom.opensymphony.xwork2.interceptor.AbstractInterceptor
org.apache.struts2.interceptor.ScopeInterceptor
public class ScopeInterceptor
This is designed to solve a few simple issues related to wizard-like functionality in Struts. One of those issues is that some applications have a application-wide parameters commonly used, such pageLen (used for records per page). Rather than requiring that each action check if such parameters are supplied, this interceptor can look for specified parameters and pull them out of the session.
This works by setting listed properties at action start with values from session/application attributes keyed after the action's class, the action's name, or any supplied key. After action is executed all the listed properties are taken back and put in session or application context. To make sure that each execution of the action is consistent it makes use of session-level locking. This way it guarantees that each action execution is atomic at the session level. It doesn't guarantee application level consistency however there has yet to be enough reasons to do so. Application level consistency would also be a big performance overkill. Note that this interceptor takes a snapshot of action properties just before result is presented (using aPreResultListener
), rather than after action is invoked. There is a reason for that: At this moment we know that
action's state is "complete" as it's values may depend on the rest of the stack and specifically - on the values of
nested interceptors.
Interceptor parameters:
<!-- As the filter and orderBy parameters are common for all my browse-type actions, you can move control to the scope interceptor. In the session parameter you can list action properties that are going to be automatically managed over session. You can do the same for application-scoped variables--> <action name="someAction" class="com.examples.SomeAction"> <interceptor-ref name="basicStack"/> <interceptor-ref name="hibernate"/> <interceptor-ref name="scope"> <param name="session">filter,orderBy</param> <param name="autoCreateSession">true</param> </interceptor-ref> <result name="success">good_result.ftl</result> </action>
Nested Class Summary | |
---|---|
private static class |
ScopeInterceptor.NULLClass
|
Field Summary | |
---|---|
private String[] |
application
|
private boolean |
autoCreateSession
|
private String |
key
|
private static Map |
locks
|
private static Logger |
LOG
|
private static Object |
NULL
|
private boolean |
reset
|
private static long |
serialVersionUID
|
private String[] |
session
|
private String |
sessionReset
|
private String |
type
|
Constructor Summary | |
---|---|
ScopeInterceptor()
The constructor |
Method Summary | |
---|---|
protected void |
after(ActionInvocation invocation,
String result)
|
protected void |
before(ActionInvocation invocation)
|
void |
beforeResult(ActionInvocation invocation,
String resultCode)
This callback method will be called after the Action execution and
before the Result execution. |
private String |
getKey(ActionInvocation invocation)
|
String |
getSessionReset()
|
String |
getType()
|
String |
intercept(ActionInvocation invocation)
Override to handle interception |
boolean |
isReset()
|
(package private) static void |
lock(Object o,
ActionInvocation invocation)
|
private static Object |
nullConvert(Object o)
|
void |
setApplication(String s)
Sets a list of application scoped properties |
void |
setAutoCreateSession(String value)
Sets if the session should be automatically created |
void |
setKey(String key)
|
void |
setReset(boolean reset)
|
void |
setSession(String s)
Sets a list of session scoped properties |
void |
setSessionReset(String sessionReset)
|
void |
setType(String type)
Sets the type of scope operation |
(package private) static void |
unlock(Object o)
|
Methods inherited from class com.opensymphony.xwork2.interceptor.AbstractInterceptor |
---|
destroy, init |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
---|
private static final long serialVersionUID
private static final Logger LOG
private String[] application
private String[] session
private String key
private String type
private boolean autoCreateSession
private String sessionReset
private boolean reset
private static final Object NULL
private static Map locks
Constructor Detail |
---|
public ScopeInterceptor()
Method Detail |
---|
public void setApplication(String s)
s
- A comma-delimited listpublic void setSession(String s)
s
- A comma-delimited listpublic void setAutoCreateSession(String value)
value
- True if it should be createdprivate String getKey(ActionInvocation invocation)
private static final Object nullConvert(Object o)
static final void lock(Object o, ActionInvocation invocation) throws Exception
Exception
static final void unlock(Object o)
protected void after(ActionInvocation invocation, String result) throws Exception
Exception
protected void before(ActionInvocation invocation) throws Exception
Exception
public void setKey(String key)
public void beforeResult(ActionInvocation invocation, String resultCode)
PreResultListener
Action
execution and
before the Result
execution.
beforeResult
in interface PreResultListener
invocation
- the action invocationresultCode
- the result code returned by the action (eg. success
).public String getType()
public void setType(String type)
type
- Either "start" or "end"public String getSessionReset()
public void setSessionReset(String sessionReset)
sessionReset
- The session reset parameter namepublic String intercept(ActionInvocation invocation) throws Exception
AbstractInterceptor
intercept
in interface Interceptor
intercept
in class AbstractInterceptor
invocation
- the action invocation
ActionInvocation.invoke()
, or from the interceptor itself.
Exception
- any system-level error, as defined in Action.execute()
.public boolean isReset()
public void setReset(boolean reset)
reset
- True if the scope should be reset
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |