Package org.apache.torque.manager
Class AbstractBaseManager<T extends Persistent>
- java.lang.Object
- 
- org.apache.torque.manager.AbstractBaseManager<T>
 
- 
- Type Parameters:
- T- the class of the database object managed by this class.
 - All Implemented Interfaces:
- Serializable
 
 public abstract class AbstractBaseManager<T extends Persistent> extends Object implements Serializable This class contains common functionality of a Manager for instantiating OM's.- Version:
- $Id: AbstractBaseManager.java 1870542 2019-11-28 09:32:40Z tv $
- Author:
- John McNally
- See Also:
- Serialized Form
 
- 
- 
Field SummaryFields Modifier and Type Field Description protected org.apache.commons.jcs.access.CacheAccess<ObjectKey<?>,T>cacheused to cache the om objects. cache is set by the region propertyprotected org.apache.commons.jcs.access.GroupCacheAccess<MethodCacheKey,Object>groupCacheused to cache the method result objects. cache is set by the region propertyprotected static org.apache.logging.log4j.Loggerlogthe logprotected MethodResultCachemrCachemethod results cache
 - 
Constructor SummaryConstructors Constructor Description AbstractBaseManager()
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description voidaddCacheListenerImpl(CacheListener<?> listener)Add a new listenerprotected voidaddValidField(Column... columns)Add variable number of fields to the list potentially monitored by a listenerprotected TcacheGet(ObjectKey<?> key)Get an object from cacheprotected voidclearImpl()Clears the cachevoiddispose()Disposes of the manager.StringgetClassName()Get the classname to instantiate for getInstance()MethodResultCachegetMethodResultCache()Get the object usable for result cachingprotected Class<T>getOMClass()Get the Class instanceprotected TgetOMInstance()Get a fresh instance of an omprotected TgetOMInstance(ObjectKey<?> id)Return an instance of an om based on the idprotected TgetOMInstance(ObjectKey<?> key, boolean fromCache)Return an instance of an om based on the idprotected List<T>getOMs(List<? extends ObjectKey<?>> ids)Gets a list of om's based on id's.protected List<T>getOMs(List<? extends ObjectKey<?>> ids, boolean fromCache)Gets a list of om's based on id's.protected List<T>getOMs(ObjectKey<?>... ids)Gets a list of om's based on id's.StringgetRegion()Get the cache region used for JCS.protected <TT extends Persistent>
 voidnotifyListeners(Column column, TT oldOm, TT om)Notify all listeners associated to the column that an object has changedprotected TputInstanceImpl(ObjectKey<?> key, T om)Put an object into the cacheprotected TputInstanceImpl(T om)Put an object into the cacheprotected voidregisterAsListener()NoOp version.protected TremoveInstanceImpl(ObjectKey<?> key)Remove an object from the cacheprotected abstract TretrieveStoredOM(ObjectKey<?> id)Retrieve an object from persistent storageprotected abstract List<T>retrieveStoredOMs(List<? extends ObjectKey<?>> ids)Gets a list of om's based on id's.voidsetClassName(String v)Set the classname to instantiate for getInstance()protected voidsetOMClass(Class<T> omClass)Set the Class that will be instantiated by this managervoidsetRegion(String v)Set the cache region used for JCS.
 
- 
- 
- 
Field Detail- 
logprotected static final org.apache.logging.log4j.Logger log the log
 - 
cacheprotected transient org.apache.commons.jcs.access.CacheAccess<ObjectKey<?>,T extends Persistent> cache used to cache the om objects. cache is set by the region property
 - 
groupCacheprotected transient org.apache.commons.jcs.access.GroupCacheAccess<MethodCacheKey,Object> groupCache used to cache the method result objects. cache is set by the region property
 - 
mrCacheprotected transient MethodResultCache mrCache method results cache
 
- 
 - 
Method Detail- 
setOMClassprotected void setOMClass(Class<T> omClass) Set the Class that will be instantiated by this manager- Parameters:
- omClass- the om class
 
 - 
addValidFieldprotected void addValidField(Column... columns) Add variable number of fields to the list potentially monitored by a listener- Parameters:
- columns- array of columns
 
 - 
getOMInstanceprotected T getOMInstance() throws TorqueException Get a fresh instance of an om- Returns:
- an instance of the om class
- Throws:
- TorqueException- Any exceptions caught during processing will be rethrown wrapped into a TorqueException.
 
 - 
getClassNamepublic String getClassName() Get the classname to instantiate for getInstance()- Returns:
- value of className.
 
 - 
setClassNamepublic void setClassName(String v) throws TorqueException Set the classname to instantiate for getInstance()- Parameters:
- v- Value to assign to className.
- Throws:
- TorqueException- Any exceptions caught during processing will be rethrown wrapped into a TorqueException.
 
 - 
getOMInstanceprotected T getOMInstance(ObjectKey<?> id) throws TorqueException Return an instance of an om based on the id- Parameters:
- id- the primary key of the object
- Returns:
- the object from persistent storage or from cache
- Throws:
- TorqueException- Any exceptions caught during processing will be rethrown wrapped into a TorqueException.
 
 - 
getOMInstanceprotected T getOMInstance(ObjectKey<?> key, boolean fromCache) throws TorqueException Return an instance of an om based on the id- Parameters:
- key- the primary key of the object
- fromCache- true if the object should be retrieved from cache
- Returns:
- the object from persistent storage or from cache
- Throws:
- TorqueException- Any exceptions caught during processing will be rethrown wrapped into a TorqueException.
 
 - 
cacheGetprotected T cacheGet(ObjectKey<?> key) Get an object from cache- Parameters:
- key- the primary key of the object
- Returns:
- the object from cache
 
 - 
clearImplprotected void clearImpl() throws TorqueExceptionClears the cache- Throws:
- TorqueException- Any exceptions caught during processing will be rethrown wrapped into a TorqueException.
 
 - 
disposepublic void dispose() Disposes of the manager. This triggers a shutdown of the connected cache instances. This method should only be used during shutdown of Torque. The manager instance will not cache anymore after this call.
 - 
removeInstanceImplprotected T removeInstanceImpl(ObjectKey<?> key) throws TorqueException Remove an object from the cache- Parameters:
- key- the cache key for the object
- Returns:
- the object one last time
- Throws:
- TorqueException- Any exceptions caught during processing will be rethrown wrapped into a TorqueException.
 
 - 
putInstanceImplprotected T putInstanceImpl(T om) throws TorqueException Put an object into the cache- Parameters:
- om- the object
- Returns:
- if an object with the same key already is in the cache this object will be returned, else null
- Throws:
- TorqueException- Any exceptions caught during processing will be rethrown wrapped into a TorqueException.
 
 - 
putInstanceImplprotected T putInstanceImpl(ObjectKey<?> key, T om) throws TorqueException Put an object into the cache- Parameters:
- key- the cache key for the object
- om- the object
- Returns:
- if an object with this key already is in the cache this object will be returned, else null
- Throws:
- TorqueException- Any exceptions caught during processing will be rethrown wrapped into a TorqueException.
 
 - 
retrieveStoredOMprotected abstract T retrieveStoredOM(ObjectKey<?> id) throws TorqueException Retrieve an object from persistent storage- Parameters:
- id- the primary key of the object
- Returns:
- the object
- Throws:
- TorqueException- Any exceptions caught during processing will be rethrown wrapped into a TorqueException.
 
 - 
getOMsprotected List<T> getOMs(ObjectKey<?>... ids) throws TorqueException Gets a list of om's based on id's.- Parameters:
- ids- a number of object ids
- Returns:
- a Listof objects
- Throws:
- TorqueException- Any exceptions caught during processing will be rethrown wrapped into a TorqueException.
 
 - 
getOMsprotected List<T> getOMs(List<? extends ObjectKey<?>> ids) throws TorqueException Gets a list of om's based on id's.- Parameters:
- ids- a- Listof- ObjectKey's
- Returns:
- a Listvalue
- Throws:
- TorqueException- Any exceptions caught during processing will be rethrown wrapped into a TorqueException.
 
 - 
getOMsprotected List<T> getOMs(List<? extends ObjectKey<?>> ids, boolean fromCache) throws TorqueException Gets a list of om's based on id's.- Parameters:
- ids- a- Listof- ObjectKey's.
- fromCache- boolean flag if we are to use the cache
- Returns:
- a Listvalue, not null.
- Throws:
- TorqueException- Any exceptions caught during processing will be rethrown wrapped into a TorqueException.
 
 - 
retrieveStoredOMsprotected abstract List<T> retrieveStoredOMs(List<? extends ObjectKey<?>> ids) throws TorqueException Gets a list of om's based on id's. This method must be implemented in the derived class- Parameters:
- ids- a- Listof- ObjectKey's
- Returns:
- a Listvalue
- Throws:
- TorqueException- Any exceptions caught during processing will be rethrown wrapped into a TorqueException.
 
 - 
getRegionpublic String getRegion() Get the cache region used for JCS.- Returns:
- the cache region used for JCS.
 
 - 
setRegionpublic void setRegion(String v) throws TorqueException Set the cache region used for JCS.- Parameters:
- v- Value to assign to region.
- Throws:
- TorqueException- Any exceptions caught during processing will be rethrown wrapped into a TorqueException.
 
 - 
getMethodResultCachepublic MethodResultCache getMethodResultCache() Get the object usable for result caching- Returns:
- The cache instance.
 
 - 
registerAsListenerprotected void registerAsListener() NoOp version. Managers should override this method to notify other managers that they are interested in CacheEvents.
 - 
addCacheListenerImplpublic void addCacheListenerImpl(CacheListener<?> listener) Add a new listener- Parameters:
- listener- A new listener for cache events.
 
 - 
notifyListenersprotected <TT extends Persistent> void notifyListeners(Column column, TT oldOm, TT om) Notify all listeners associated to the column that an object has changed- Type Parameters:
- TT- column type class
- Parameters:
- column- the column related to the listeners
- oldOm- the previous object, null if the object has been added
- om- the new object, null if the object has been removed
 
 
- 
 
-