org.apache.openejb.ri.sp.PseudoTransactionService Maven / Gradle / Ivy
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.openejb.ri.sp;
import org.apache.openejb.spi.TransactionService;
import org.apache.openejb.util.LogCategory;
import org.apache.openejb.util.Logger;
import javax.transaction.InvalidTransactionException;
import javax.transaction.NotSupportedException;
import javax.transaction.RollbackException;
import javax.transaction.Status;
import javax.transaction.Synchronization;
import javax.transaction.Transaction;
import javax.transaction.TransactionManager;
import javax.transaction.TransactionSynchronizationRegistry;
import javax.transaction.xa.XAException;
import javax.transaction.xa.XAResource;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Properties;
/**
* @org.apache.xbean.XBean element="pseudoTransactionService"
*/
public class PseudoTransactionService implements TransactionService, TransactionManager, TransactionSynchronizationRegistry {
private static final Logger logger = Logger.getInstance(LogCategory.OPENEJB, "org.apache.openejb.core.cmp");
private final ThreadLocal threadTransaction = new ThreadLocal<>();
public void init(final Properties props) {
}
public TransactionManager getTransactionManager() {
return this;
}
public TransactionSynchronizationRegistry getTransactionSynchronizationRegistry() {
return this;
}
public int getStatus() {
final MyTransaction tx = threadTransaction.get();
if (tx == null) {
return Status.STATUS_NO_TRANSACTION;
}
return tx.getStatus();
}
public Transaction getTransaction() {
return threadTransaction.get();
}
public boolean getRollbackOnly() {
final MyTransaction tx = threadTransaction.get();
if (tx == null) {
throw new IllegalStateException("No transaction active");
}
return tx.getRollbackOnly();
}
public void setRollbackOnly() {
final MyTransaction tx = threadTransaction.get();
if (tx == null) {
throw new IllegalStateException("No transaction active");
}
tx.setRollbackOnly();
}
public void begin() throws NotSupportedException {
if (threadTransaction.get() != null) {
throw new NotSupportedException("A transaction is already active");
}
final MyTransaction tx = new MyTransaction();
threadTransaction.set(tx);
}
public void commit() throws RollbackException {
final MyTransaction tx = threadTransaction.get();
if (tx == null) {
throw new IllegalStateException("No transaction active");
}
try {
tx.commit();
} finally {
threadTransaction.set(null);
}
}
public void rollback() {
final MyTransaction tx = threadTransaction.get();
if (tx == null) {
throw new IllegalStateException("No transaction active");
}
try {
tx.rollback();
} finally {
threadTransaction.set(null);
}
}
public Transaction suspend() {
return threadTransaction.get();
}
public void resume(final Transaction tx) throws InvalidTransactionException {
if (tx == null) {
throw new InvalidTransactionException("Transaction is null");
}
if (!(tx instanceof MyTransaction)) {
throw new InvalidTransactionException("Unknown transaction type " + tx.getClass().getName());
}
final MyTransaction myTransaction = (MyTransaction) tx;
if (threadTransaction.get() != null) {
throw new IllegalStateException("A transaction is already active");
}
final int status = myTransaction.getStatus();
if (status != Status.STATUS_ACTIVE && status != Status.STATUS_MARKED_ROLLBACK) {
throw new InvalidTransactionException("Expected transaction to be STATUS_ACTIVE or STATUS_MARKED_ROLLBACK, but was " + status);
}
threadTransaction.set(myTransaction);
}
public Object getTransactionKey() {
return getTransaction();
}
public int getTransactionStatus() {
return getStatus();
}
public Object getResource(final Object key) {
final MyTransaction tx = threadTransaction.get();
if (tx == null) {
throw new IllegalStateException("No transaction active");
}
final Object value = tx.getResource(key);
return value;
}
public void putResource(final Object key, final Object value) {
final MyTransaction tx = threadTransaction.get();
if (tx == null) {
throw new IllegalStateException("No transaction active");
}
tx.putResource(key, value);
}
public void registerInterposedSynchronization(final Synchronization synchronization) {
final MyTransaction tx = threadTransaction.get();
if (tx == null) {
throw new IllegalStateException("No transaction active");
}
tx.registerInterposedSynchronization(synchronization);
}
public void setTransactionTimeout(final int seconds) {
}
public class MyTransaction implements Transaction {
private final List registeredSynchronizations = Collections.synchronizedList(new ArrayList<>());
private final List xaResources = Collections.synchronizedList(new ArrayList<>());
private final Map
© 2015 - 2025 Weber Informatics LLC | Privacy Policy