All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.quarkus.narayana.jta.runtime.internal.tsr.TransactionSynchronizationRegistryWrapper Maven / Gradle / Ivy

package io.quarkus.narayana.jta.runtime.internal.tsr;

import jakarta.transaction.Synchronization;
import jakarta.transaction.TransactionSynchronizationRegistry;

import org.jboss.logging.Logger;

import com.arjuna.ats.internal.jta.transaction.arjunacore.TransactionSynchronizationRegistryImple;

/**
 * Agroal registers an interposed synchronization which validates that connections have been released.
 * Components such as hibernate release connections in an interposed synchronization.
 * Therefore, we must ensure that Agroal runs last.
 * 

* * This wrapper re-orders interposed synchronizations as follows: [other, hibernate-orm, agroal]. *

* * Synchronizations are placed into groups according to their package name and the groups are ordered which means * that all hibernate synchronizations run before Agroal ones and all other synchs run before the hibernate ones. *

* * See {@code AgroalOrderedLastSynchronizationList} for details of the re-ordering. */ public class TransactionSynchronizationRegistryWrapper implements TransactionSynchronizationRegistry { private final Object key = new Object(); private static final Logger LOG = Logger.getLogger(TransactionSynchronizationRegistryWrapper.class); private final TransactionSynchronizationRegistryImple tsr; private transient com.arjuna.ats.internal.jta.transaction.arjunacore.TransactionManagerImple delegate; public TransactionSynchronizationRegistryWrapper( TransactionSynchronizationRegistryImple transactionSynchronizationRegistryImple) { this.tsr = transactionSynchronizationRegistryImple; } @Override public void registerInterposedSynchronization(Synchronization sync) { AgroalOrderedLastSynchronizationList agroalOrderedLastSynchronization = (AgroalOrderedLastSynchronizationList) tsr .getResource(key); if (agroalOrderedLastSynchronization == null) { synchronized (key) { agroalOrderedLastSynchronization = (AgroalOrderedLastSynchronizationList) tsr.getResource(key); if (agroalOrderedLastSynchronization == null) { agroalOrderedLastSynchronization = new AgroalOrderedLastSynchronizationList(this); tsr.putResource(key, agroalOrderedLastSynchronization); tsr.registerInterposedSynchronization(agroalOrderedLastSynchronization); } } } // add the synchronization to the list that does the reordering agroalOrderedLastSynchronization.registerInterposedSynchronization(sync); } @Override public Object getTransactionKey() { return tsr.getTransactionKey(); } @Override public int getTransactionStatus() { return tsr.getTransactionStatus(); } @Override public boolean getRollbackOnly() { return tsr.getRollbackOnly(); } @Override public void setRollbackOnly() { tsr.setRollbackOnly(); } @Override public Object getResource(Object key) { return tsr.getResource(key); } @Override public void putResource(Object key, Object value) { tsr.putResource(key, value); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy