
com.googlecode.mycontainer.ejb.transaction.RequiresNewTransactionHandler Maven / Gradle / Ivy
/*
* Copyright 2008 Whohoo Licensed 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 com.googlecode.mycontainer.ejb.transaction;
import javax.transaction.Transaction;
import javax.transaction.TransactionManager;
import com.googlecode.mycontainer.kernel.reflect.proxy.ProxyChain;
import com.googlecode.mycontainer.kernel.reflect.proxy.Request;
public class RequiresNewTransactionHandler extends AbstractTransactionHandler {
private static final long serialVersionUID = -893446076524561628L;
private static final org.slf4j.Logger LOG = org.slf4j.LoggerFactory.getLogger(RequiresNewTransactionHandler.class);
public Object intercept(Request request, ProxyChain chain) throws Throwable {
TransactionManager tm = getTransactionManager();
Transaction old = tm.suspend();
LOG.trace("Creating transaction");
tm.begin();
try {
Object ret = chain.proceed(request);
LOG.trace("Commiting transaction");
tm.commit();
return ret;
} catch (Exception e) {
try {
LOG.trace("Rolling back transaction");
tm.rollback();
} catch (Exception e1) {
LOG.error("Error on rollback. It will not raise", e1);
}
throw e;
} finally {
if (old != null) {
try {
tm.resume(old);
} catch (Exception e1) {
LOG.error("Error on finally. It will not raise", e1);
}
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy