package at.gv.egovernment.moa.spss.server.transaction;
/**
* Provides each thread with an instance of TransactionContext
.
*
* The single instance of the TransactionContextManager
should be
* used to access contextual information for each web service transaction, e.g.
* the transaction ID, MOA configuration, client certificate, etc.
*
* @author Stefan Knirsch
* @author Patrick Peck
*/
public class TransactionContextManager {
/** The single instance of TransactionContextManager
*/
private static TransactionContextManager instance = null;
/** Contains a single TransactionContext
for each thread. */
private ThreadLocal context = null;
/**
* Get the single instance of TransactionContextManager
.
*
* @return The single instanc of TransactionContextManager
.
*/
public static synchronized TransactionContextManager getInstance() {
if (instance == null) {
instance = new TransactionContextManager();
}
return instance;
}
/**
* Creates a new TransactionContextManager
.
*
* Protected to disallow direct instantiation.
*/
protected TransactionContextManager() {
context = new ThreadLocal();
}
/**
* Set the TransactionContext
for the current thread.
*
* @param txContext The TransactionContext
for this thread.
*/
public void setTransactionContext(TransactionContext txContext) {
context.set(txContext);
}
/**
* Get the TransactionContext
for the current thread.
*
* @return The TransactionContext
for the current thread or
* null
, if none has been set (or if this method is being invoked
* outside the bounds of a transaction).
*/
public TransactionContext getTransactionContext() {
return (TransactionContext) context.get();
}
}