public class SimpleTransactionManager {
private UserTransactionFactory factory;
- private ThreadSpecificProxyFactory<UserTransaction> transaction;
+ private ThreadLocal<UserTransaction> transaction;
private UserTransactionCallback callback;
private List<TransactionResource> resources;
*/
public SimpleTransactionManager(UserTransactionFactory aFactory) {
factory = aFactory;
- transaction = new ThreadSpecificProxyFactory<UserTransaction>(UserTransaction.class);
+ transaction = new ThreadLocal<UserTransaction>();
callback = new UserTransactionCallback() {
@Override
* @return User transaction.
*/
public UserTransaction getTransaction() {
+ return new AutoCreateUserTransaction(this);
+ }
+
+ UserTransaction getOrCreateThreadSpecificTransaction() {
UserTransaction tx = transaction.get();
if (tx == null) {
tx = factory.create(callback, resources);
transaction.set(tx);
}
- return transaction.getProxy();
+ return tx;
}
/**