| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectorg.springframework.transaction.interceptor.AbstractFallbackTransactionAttributeSource
public abstract class AbstractFallbackTransactionAttributeSource
Abstract implementation of TransactionAttributeSource that caches
 attributes for methods and implements a fallback policy: 1. specific target
 method; 2. target class; 3. declaring method; 4. declaring class/interface.
 
Defaults to using the target class's transaction attribute if none is associated with the target method. Any transaction attribute associated with the target method completely overrides a class transaction attribute. If none found on the target class, the interface that the invoked method has been called through (in case of a JDK proxy) will be checked.
This implementation caches attributes by method after they are first used. If it is ever desirable to allow dynamic changing of transaction attributes (which is very unlikely), caching could be made configurable. Caching is desirable because of the cost of evaluating rollback rules.
| Field Summary | |
|---|---|
| (package private)  Map | attributeCacheCache of TransactionAttributes, keyed by Method and target class. | 
| protected  Log | loggerLogger available to subclasses. | 
| Constructor Summary | |
|---|---|
| AbstractFallbackTransactionAttributeSource() | |
| Method Summary | |
|---|---|
| protected abstract  Collection | findAllAttributes(Class clazz)Subclasses should implement this to return all attributes for this class. | 
| protected abstract  Collection | findAllAttributes(Method method)Subclasses should implement this to return all attributes for this method. | 
| protected  TransactionAttribute | findTransactionAttribute(Collection atts)Return the transaction attribute, given this set of attributes attached to a method or class. | 
| protected  Object | getCacheKey(Method method,
            Class targetClass)Determine a cache key for the given method and target class. | 
|  TransactionAttribute | getTransactionAttribute(Method method,
                        Class targetClass)Determine the transaction attribute for this method invocation. | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait | 
| Field Detail | 
|---|
protected final Log logger
As this base class is not marked Serializable, the logger will be recreated after serialization - provided that the concrete subclass is Serializable.
final Map attributeCache
As this base class is not marked Serializable, the cache will be recreated after serialization - provided that the concrete subclass is Serializable.
| Constructor Detail | 
|---|
public AbstractFallbackTransactionAttributeSource()
| Method Detail | 
|---|
public TransactionAttribute getTransactionAttribute(Method method,
                                                    Class targetClass)
Defaults to the class's transaction attribute if no method attribute is found.
getTransactionAttribute in interface TransactionAttributeSourcemethod - the method for the current invocation (never null)targetClass - the target class for this invocation (may be null)
null if the method
 is not transactional
protected Object getCacheKey(Method method,
                             Class targetClass)
Must not produce same key for overloaded methods. Must produce same key for different instances of the same method.
method - the method (never null)targetClass - the target class (may be null)
null)protected abstract Collection findAllAttributes(Method method)
method - the method to retrieve attributes for
null)protected abstract Collection findAllAttributes(Class clazz)
clazz - class to retrieve attributes for
null)protected TransactionAttribute findTransactionAttribute(Collection atts)
Protected rather than private as subclasses may want to customize how this is done: for example, returning a TransactionAttribute affected by the values of other attributes.
This implementation takes into account RollbackRuleAttributes, if the TransactionAttribute is a RuleBasedTransactionAttribute.
atts - attributes attached to a method or class (may be null)
null if none was found| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||