Class AbstractSynchronousTransactionManager<T>
- java.lang.Object
- 
- io.micronaut.transaction.support.AbstractSynchronousStateTransactionManager<T>
- 
- io.micronaut.transaction.support.AbstractSynchronousTransactionManager<T>
 
 
- 
- Type Parameters:
- T- The resource type
 - All Implemented Interfaces:
- TransactionStateOperations<T,SynchronousTransactionState>,- SynchronousTransactionManager<T>,- TransactionManager,- TransactionOperations<T>,- java.io.Serializable
 - Direct Known Subclasses:
- DataSourceTransactionManager,- HibernateTransactionManager,- MongoSynchronousTransactionManager
 
 @Internal public abstract class AbstractSynchronousTransactionManager<T> extends AbstractSynchronousStateTransactionManager<T> implements SynchronousTransactionManager<T>, java.io.Serializable NOTICE: This is a fork of Spring'sAbstractPlatformTransactionManagermodernizing it to use enums, Slf4j and decoupling from Spring. Abstract base class that implements standard transaction workflow, serving as basis for concrete platform transaction managers.This base class provides the following workflow handling: - determines if there is an existing transaction;
- applies the appropriate propagation behavior;
- suspends and resumes transactions if necessary;
- checks the rollback-only flag on commit;
- applies the appropriate modification on rollback (actual rollback or setting rollback-only);
- triggers registered synchronization callbacks (if transaction synchronization is active).
 Subclasses have to implement specific template methods for specific states of a transaction, e.g.: begin, suspend, resume, commit, rollback. The most important of them are abstract and must be provided by a concrete implementation; for the rest, defaults are provided, so overriding is optional. Transaction synchronization is a generic mechanism for registering callbacks that get invoked at transaction completion time. This is mainly used internally by the data access support classes for JDBC, Hibernate, JPA, etc when running within a JTA transaction: They register resources that are opened within the transaction for closing at transaction completion time, allowing e.g. for reuse of the same Hibernate Session within the transaction. The same mechanism can also be leveraged for custom synchronization needs in an application. The state of this class is serializable, to allow for serializing the transaction strategy along with proxies that carry a transaction interceptor. It is up to subclasses if they wish to make their state to be serializable too. They should implement the java.io.Serializablemarker interface in that case, and potentially a privatereadObject()method (according to Java serialization rules) if they need to restore any transient state.- Since:
- 28.03.2003
- Author:
- Juergen Hoeller, graemerocher
- See Also:
- AbstractSynchronousStateTransactionManager.setTransactionSynchronization(io.micronaut.transaction.support.AbstractSynchronousStateTransactionManager.Synchronization),- TransactionSynchronizationManager, Serialized Form
 
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description protected static classAbstractSynchronousTransactionManager.SuspendedResourcesHolderHolder for suspended resources.
 - 
Field Summary- 
Fields inherited from class io.micronaut.transaction.support.AbstractSynchronousStateTransactionManagerlogger
 
- 
 - 
Constructor SummaryConstructors Constructor Description AbstractSynchronousTransactionManager()
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description voidcommit(TransactionStatus<T> status)This implementation of commit handles participating in existing transactions and programmatic rollback requests.protected voiddoCleanupAfterCompletion(SynchronousTransactionState state, java.lang.Object transaction)Cleanup resources after transaction completion.protected voiddoCleanupAfterCompletion(java.lang.Object transaction)Cleanup resources after transaction completion.protected voiddoDestroyState(SynchronousTransactionState state)Destroy the state.protected abstract java.lang.ObjectdoGetTransaction()Return a transaction object for the current transaction state.protected java.lang.ObjectdoGetTransaction(SynchronousTransactionState state)Return a transaction object for the current transaction state.<R> Rexecute(TransactionDefinition definition, TransactionCallback<T,R> callback)Execute a transaction within the context of the function.<R> RexecuteRead(TransactionCallback<T,R> callback)Execute a read-only transaction within the context of the function.<R> RexecuteWrite(TransactionCallback<T,R> callback)Execute a default transaction within the context of the function.java.util.Optional<SynchronousTransactionState>find()Find optional transaction state.protected SynchronousTransactionStatefindOrCreateState()Find or create a new state.protected TgetConnection(SynchronousTransactionState state, java.lang.Object transaction)The connection for the given transaction object.protected abstract TgetConnection(java.lang.Object transaction)The connection for the given transaction object.protected SynchronousTransactionStategetState()Return required current transaction state.TransactionStatus<T>getTransaction(TransactionDefinition definition)Return a currently active transaction or create a new one, according to the specified propagation behavior.protected @NotNull java.lang.ObjectgetTransactionStateKey()Get the transaction state key that should be used to store the state.protected voidinvokeAfterCompletion(java.util.List<TransactionSynchronization> synchronizations, TransactionSynchronization.Status completionStatus)Actually invoke theafterCompletionmethods of the given Spring TransactionSynchronization objects.protected booleanisExistingTransaction(SynchronousTransactionState state, java.lang.Object transaction)Check if the given transaction object indicates an existing transaction (that is, a transaction which has already started).protected booleanisExistingTransaction(java.lang.Object transaction)Check if the given transaction object indicates an existing transaction (that is, a transaction which has already started).protected DefaultTransactionStatus<T>newTransactionStatus(SynchronousTransactionState state, TransactionDefinition definition, java.lang.Object transaction, boolean newTransaction, boolean newSynchronization, boolean debug, java.lang.Object suspendedResources)Create a TransactionStatus instance for the given arguments.protected DefaultTransactionStatus<T>newTransactionStatus(TransactionDefinition definition, java.lang.Object transaction, boolean newTransaction, boolean newSynchronization, boolean debug, java.lang.Object suspendedResources)Create a TransactionStatus instance for the given arguments.protected voidprepareSynchronization(DefaultTransactionStatus<T> status, TransactionDefinition definition)Initialize transaction synchronization as appropriate.protected voidprepareSynchronization(SynchronousTransactionState state, DefaultTransactionStatus<T> status, TransactionDefinition definition)Initialize transaction synchronization as appropriate.protected DefaultTransactionStatus<T>prepareTransactionStatus(TransactionDefinition definition, java.lang.Object transaction, boolean newTransaction, boolean newSynchronization, boolean debug, java.lang.Object suspendedResources)Create a new TransactionStatus for the given arguments, also initializing transaction synchronization as appropriate.protected voidregisterAfterCompletionWithExistingTransaction(SynchronousTransactionState state, java.lang.Object transaction, java.util.List<TransactionSynchronization> synchronizations)Register the given list of transaction synchronizations with the existing transaction.protected voidregisterAfterCompletionWithExistingTransaction(java.lang.Object transaction, java.util.List<TransactionSynchronization> synchronizations)Register the given list of transaction synchronizations with the existing transaction.protected voidresume(java.lang.Object transaction, AbstractSynchronousTransactionManager.SuspendedResourcesHolder resourcesHolder)Resume the given transaction.voidrollback(TransactionStatus<T> status)This implementation of rollback handles participating in existing transactions.protected AbstractSynchronousTransactionManager.SuspendedResourcesHoldersuspend(java.lang.Object transaction)Suspend the given transaction.protected voidtriggerBeforeCommit(DefaultTransactionStatus<T> status)TriggerbeforeCommitcallbacks.protected voidtriggerBeforeCompletion(DefaultTransactionStatus<T> status)TriggerbeforeCompletioncallbacks.- 
Methods inherited from class io.micronaut.transaction.support.AbstractSynchronousStateTransactionManagercommit, determineTimeout, doBegin, doCommit, doResume, doRollback, doSetRollbackOnly, doSuspend, execute, executeRead, executeWrite, getDefaultTimeout, getTransaction, getTransactionSynchronization, invokeAfterCompletion, isFailEarlyOnGlobalRollbackOnly, isGlobalRollbackOnParticipationFailure, isNestedTransactionAllowed, isRollbackOnCommitFailure, isValidateExistingTransaction, prepareForCommit, prepareTransactionStatus, resume, rollback, setDefaultTimeout, setFailEarlyOnGlobalRollbackOnly, setGlobalRollbackOnParticipationFailure, setNestedTransactionAllowed, setRollbackOnCommitFailure, setTransactionSynchronization, setValidateExistingTransaction, shouldCommitOnGlobalRollbackOnly, suspend, triggerBeforeCommit, triggerBeforeCompletion, useSavepointForNestedTransaction
 - 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface io.micronaut.transaction.TransactionOperationsgetConnection, hasConnection
 
- 
 
- 
- 
- 
Method Detail- 
getTransactionStateKey@NotNull protected @NotNull java.lang.Object getTransactionStateKey() Get the transaction state key that should be used to store the state.- Returns:
- The key
 
 - 
getState@NonNull protected SynchronousTransactionState getState() Return required current transaction state.- Returns:
- The state
 
 - 
findOrCreateState@NonNull protected SynchronousTransactionState findOrCreateState() Find or create a new state.- Returns:
- The state
 
 - 
find@NonNull public java.util.Optional<SynchronousTransactionState> find() Find optional transaction state.- Returns:
- The state
 
 - 
doDestroyStateprotected void doDestroyState(SynchronousTransactionState state) Destroy the state.- Overrides:
- doDestroyStatein class- AbstractSynchronousStateTransactionManager<T>
- Parameters:
- state- The state
 
 - 
executepublic <R> R execute(@NonNull TransactionDefinition definition, @NonNull TransactionCallback<T,R> callback)Description copied from interface:TransactionOperationsExecute a transaction within the context of the function.- Specified by:
- executein interface- TransactionOperations<T>
- Type Parameters:
- R- The result
- Parameters:
- definition- The transaction definition
- callback- The call back
- Returns:
- The result
 
 - 
executeReadpublic <R> R executeRead(@NonNull TransactionCallback<T,R> callback)Description copied from interface:TransactionOperationsExecute a read-only transaction within the context of the function.- Specified by:
- executeReadin interface- TransactionOperations<T>
- Type Parameters:
- R- The result
- Parameters:
- callback- The call back
- Returns:
- The result
 
 - 
executeWritepublic <R> R executeWrite(@NonNull TransactionCallback<T,R> callback)Description copied from interface:TransactionOperationsExecute a default transaction within the context of the function.- Specified by:
- executeWritein interface- TransactionOperations<T>
- Type Parameters:
- R- The result
- Parameters:
- callback- The call back
- Returns:
- The result
 
 - 
getTransaction@NonNull public final TransactionStatus<T> getTransaction(@Nullable TransactionDefinition definition) throws TransactionException Description copied from interface:SynchronousTransactionManagerReturn a currently active transaction or create a new one, according to the specified propagation behavior.Note that parameters like isolation level or timeout will only be applied to new transactions, and thus be ignored when participating in active ones. Furthermore, not all transaction definition settings will be supported by every transaction manager: A proper transaction manager implementation should throw an exception when unsupported settings are encountered. An exception to the above rule is the read-only flag, which should be ignored if no explicit read-only mode is supported. Essentially, the read-only flag is just a hint for potential optimization. - Specified by:
- getTransactionin interface- SynchronousTransactionManager<T>
- Parameters:
- definition- the TransactionDefinition instance (can be- nullfor defaults), describing propagation behavior, isolation level, timeout etc.
- Returns:
- transaction status object representing the new or current transaction
- Throws:
- TransactionException- in case of lookup, creation, or system errors
- IllegalTransactionStateException- if the given transaction definition cannot be executed (for example, if a currently active transaction is in conflict with the specified propagation behavior)
- See Also:
- TransactionDefinition.getPropagationBehavior(),- TransactionDefinition.getIsolationLevel(),- TransactionDefinition.getTimeout(),- TransactionDefinition.isReadOnly()
 
 - 
prepareTransactionStatusprotected final DefaultTransactionStatus<T> prepareTransactionStatus(TransactionDefinition definition, @Nullable java.lang.Object transaction, boolean newTransaction, boolean newSynchronization, boolean debug, @Nullable java.lang.Object suspendedResources) Create a new TransactionStatus for the given arguments, also initializing transaction synchronization as appropriate.- Parameters:
- definition- The definition
- transaction- The transaction object
- newTransaction- Is this is a new transaction
- newSynchronization- Is this a new synchronization
- debug- Is debug enabled
- suspendedResources- Any suspended resources
- Returns:
- The status
- See Also:
- newTransactionStatus(io.micronaut.transaction.support.SynchronousTransactionState, io.micronaut.transaction.TransactionDefinition, java.lang.Object, boolean, boolean, boolean, java.lang.Object),- prepareTransactionStatus(io.micronaut.transaction.TransactionDefinition, java.lang.Object, boolean, boolean, boolean, java.lang.Object)
 
 - 
newTransactionStatusprotected DefaultTransactionStatus<T> newTransactionStatus(SynchronousTransactionState state, TransactionDefinition definition, java.lang.Object transaction, boolean newTransaction, boolean newSynchronization, boolean debug, java.lang.Object suspendedResources) Description copied from class:AbstractSynchronousStateTransactionManagerCreate a TransactionStatus instance for the given arguments.- Overrides:
- newTransactionStatusin class- AbstractSynchronousStateTransactionManager<T>
- Parameters:
- state- The transaction state
- definition- The definition
- transaction- The transaction object
- newTransaction- Is this is a new transaction
- newSynchronization- Is this a new synchronization
- debug- Is debug enabled
- suspendedResources- Any suspended resources
- Returns:
- The status
 
 - 
newTransactionStatusprotected DefaultTransactionStatus<T> newTransactionStatus(TransactionDefinition definition, @Nullable java.lang.Object transaction, boolean newTransaction, boolean newSynchronization, boolean debug, @Nullable java.lang.Object suspendedResources) Create a TransactionStatus instance for the given arguments.- Parameters:
- definition- The definition
- transaction- The transaction object
- newTransaction- Is this is a new transaction
- newSynchronization- Is this a new synchronization
- debug- Is debug enabled
- suspendedResources- Any suspended resources
- Returns:
- The status
 
 - 
getConnectionprotected T getConnection(SynchronousTransactionState state, java.lang.Object transaction) Description copied from class:AbstractSynchronousStateTransactionManagerThe connection for the given transaction object.- Specified by:
- getConnectionin class- AbstractSynchronousStateTransactionManager<T>
- Parameters:
- state- The transaction state
- transaction- The transaction
- Returns:
- The connection.
 
 - 
getConnection@Nullable protected abstract T getConnection(java.lang.Object transaction) The connection for the given transaction object.- Parameters:
- transaction- The transaction
- Returns:
- The connection.
 
 - 
prepareSynchronizationprotected void prepareSynchronization(SynchronousTransactionState state, DefaultTransactionStatus<T> status, TransactionDefinition definition) Description copied from class:AbstractSynchronousStateTransactionManagerInitialize transaction synchronization as appropriate.- Overrides:
- prepareSynchronizationin class- AbstractSynchronousStateTransactionManager<T>
- Parameters:
- state- The transaction state
- status- The status
- definition- The definition
 
 - 
prepareSynchronizationprotected void prepareSynchronization(@NonNull DefaultTransactionStatus<T> status, @NonNull TransactionDefinition definition)Initialize transaction synchronization as appropriate.- Parameters:
- status- The status
- definition- The definition
 
 - 
suspend@Nullable protected final AbstractSynchronousTransactionManager.SuspendedResourcesHolder suspend(@Nullable java.lang.Object transaction) throws TransactionException Suspend the given transaction. Suspends transaction synchronization first, then delegates to thedoSuspendtemplate method.- Parameters:
- transaction- the current transaction object (or- nullto just suspend active synchronizations, if any)
- Returns:
- an object that holds suspended resources
 (or nullif neither transaction nor synchronization active)
- Throws:
- TransactionException- Thrown if an error occurs suspending the transaction
- See Also:
- AbstractSynchronousStateTransactionManager.doSuspend(java.lang.Object),- resume(java.lang.Object, io.micronaut.transaction.support.AbstractSynchronousTransactionManager.SuspendedResourcesHolder)
 
 - 
resumeprotected final void resume(@Nullable java.lang.Object transaction, @Nullable AbstractSynchronousTransactionManager.SuspendedResourcesHolder resourcesHolder) throws TransactionExceptionResume the given transaction. Delegates to thedoResumetemplate method first, then resuming transaction synchronization.- Parameters:
- transaction- the current transaction object
- resourcesHolder- the object that holds suspended resources, as returned by- suspend(or- nullto just resume synchronizations, if any)
- Throws:
- TransactionException- Thrown if an error occurs resuming the transaction
- See Also:
- AbstractSynchronousStateTransactionManager.doResume(java.lang.Object, java.lang.Object),- suspend(java.lang.Object)
 
 - 
commitpublic final void commit(TransactionStatus<T> status) throws TransactionException This implementation of commit handles participating in existing transactions and programmatic rollback requests. Delegates toisRollbackOnly,doCommitandrollback.- Specified by:
- commitin interface- SynchronousTransactionManager<T>
- Parameters:
- status- object returned by the- getTransactionmethod
- Throws:
- UnexpectedRollbackException- in case of an unexpected rollback that the transaction coordinator initiated
- HeuristicCompletionException- in case of a transaction failure caused by a heuristic decision on the side of the transaction coordinator
- TransactionSystemException- in case of commit or system errors (typically caused by fundamental resource failures)
- IllegalTransactionStateException- if the given transaction is already completed (that is, committed or rolled back)
- TransactionException- if something goes wrong during commit
- See Also:
- TransactionExecution.isRollbackOnly(),- AbstractSynchronousStateTransactionManager.doCommit(io.micronaut.transaction.support.DefaultTransactionStatus<T>),- rollback(io.micronaut.transaction.TransactionStatus<T>)
 
 - 
rollbackpublic final void rollback(TransactionStatus<T> status) throws TransactionException This implementation of rollback handles participating in existing transactions. Delegates todoRollbackanddoSetRollbackOnly.- Specified by:
- rollbackin interface- SynchronousTransactionManager<T>
- Parameters:
- status- object returned by the- getTransactionmethod
- Throws:
- TransactionSystemException- in case of rollback or system errors (typically caused by fundamental resource failures)
- IllegalTransactionStateException- if the given transaction is already completed (that is, committed or rolled back)
- TransactionException- if something goes wrong during rollback
- See Also:
- AbstractSynchronousStateTransactionManager.doRollback(io.micronaut.transaction.support.DefaultTransactionStatus<T>),- AbstractSynchronousStateTransactionManager.doSetRollbackOnly(io.micronaut.transaction.support.DefaultTransactionStatus<T>)
 
 - 
triggerBeforeCommitprotected final void triggerBeforeCommit(DefaultTransactionStatus<T> status) TriggerbeforeCommitcallbacks.- Parameters:
- status- object representing the transaction
 
 - 
triggerBeforeCompletionprotected final void triggerBeforeCompletion(DefaultTransactionStatus<T> status) TriggerbeforeCompletioncallbacks.- Parameters:
- status- object representing the transaction
 
 - 
doGetTransactionprotected java.lang.Object doGetTransaction(@NonNull SynchronousTransactionState state) throws TransactionExceptionDescription copied from class:AbstractSynchronousStateTransactionManagerReturn a transaction object for the current transaction state.The returned object will usually be specific to the concrete transaction manager implementation, carrying corresponding transaction state in a modifiable fashion. This object will be passed into the other template methods (e.g. doBegin and doCommit), either directly or as part of a DefaultTransactionStatus instance. The returned object should contain information about any existing transaction, that is, a transaction that has already started before the current getTransactioncall on the transaction manager. Consequently, adoGetTransactionimplementation will usually look for an existing transaction and store corresponding state in the returned transaction object.- Specified by:
- doGetTransactionin class- AbstractSynchronousStateTransactionManager<T>
- Parameters:
- state- The transaction state
- Returns:
- the current transaction object
- Throws:
- CannotCreateTransactionException- if transaction support is not available
- TransactionException- in case of lookup or system errors
- See Also:
- AbstractSynchronousStateTransactionManager.doBegin(java.lang.Object, io.micronaut.transaction.TransactionDefinition),- AbstractSynchronousStateTransactionManager.doCommit(io.micronaut.transaction.support.DefaultTransactionStatus<T>),- AbstractSynchronousStateTransactionManager.doRollback(io.micronaut.transaction.support.DefaultTransactionStatus<T>),- DefaultTransactionStatus.getTransaction()
 
 - 
isExistingTransactionprotected boolean isExistingTransaction(@NonNull SynchronousTransactionState state, @NonNull java.lang.Object transaction) throws TransactionExceptionDescription copied from class:AbstractSynchronousStateTransactionManagerCheck if the given transaction object indicates an existing transaction (that is, a transaction which has already started).The result will be evaluated according to the specified propagation behavior for the new transaction. An existing transaction might get suspended (in case of PROPAGATION_REQUIRES_NEW), or the new transaction might participate in the existing one (in case of PROPAGATION_REQUIRED). The default implementation returns false, assuming that participating in existing transactions is generally not supported. Subclasses are of course encouraged to provide such support.- Overrides:
- isExistingTransactionin class- AbstractSynchronousStateTransactionManager<T>
- Parameters:
- state- The transaction state
- transaction- transaction object returned by doGetTransaction
- Returns:
- if there is an existing transaction
- Throws:
- TransactionException- in case of system errors
- See Also:
- AbstractSynchronousStateTransactionManager.doGetTransaction(io.micronaut.transaction.support.SynchronousTransactionState)
 
 - 
invokeAfterCompletionprotected final void invokeAfterCompletion(java.util.List<TransactionSynchronization> synchronizations, TransactionSynchronization.Status completionStatus) Actually invoke theafterCompletionmethods of the given Spring TransactionSynchronization objects.To be called by this abstract manager itself, or by special implementations of the registerAfterCompletionWithExistingTransactioncallback.- Parameters:
- synchronizations- a List of TransactionSynchronization objects
- completionStatus- the completion status according to the constants in the TransactionSynchronization interface
- See Also:
- registerAfterCompletionWithExistingTransaction(SynchronousTransactionState, Object, List),- TransactionSynchronization.Status.COMMITTED,- TransactionSynchronization.Status.ROLLED_BACK,- TransactionSynchronization.Status.UNKNOWN
 
 - 
doGetTransaction@NonNull protected abstract java.lang.Object doGetTransaction() throws TransactionExceptionReturn a transaction object for the current transaction state.The returned object will usually be specific to the concrete transaction manager implementation, carrying corresponding transaction state in a modifiable fashion. This object will be passed into the other template methods (e.g. doBegin and doCommit), either directly or as part of a DefaultTransactionStatus instance. The returned object should contain information about any existing transaction, that is, a transaction that has already started before the current getTransactioncall on the transaction manager. Consequently, adoGetTransactionimplementation will usually look for an existing transaction and store corresponding state in the returned transaction object.- Returns:
- the current transaction object
- Throws:
- CannotCreateTransactionException- if transaction support is not available
- TransactionException- in case of lookup or system errors
- See Also:
- AbstractSynchronousStateTransactionManager.doBegin(java.lang.Object, io.micronaut.transaction.TransactionDefinition),- AbstractSynchronousStateTransactionManager.doCommit(io.micronaut.transaction.support.DefaultTransactionStatus<T>),- AbstractSynchronousStateTransactionManager.doRollback(io.micronaut.transaction.support.DefaultTransactionStatus<T>),- DefaultTransactionStatus.getTransaction()
 
 - 
isExistingTransactionprotected boolean isExistingTransaction(@NonNull java.lang.Object transaction) throws TransactionExceptionCheck if the given transaction object indicates an existing transaction (that is, a transaction which has already started).The result will be evaluated according to the specified propagation behavior for the new transaction. An existing transaction might get suspended (in case of PROPAGATION_REQUIRES_NEW), or the new transaction might participate in the existing one (in case of PROPAGATION_REQUIRED). The default implementation returns false, assuming that participating in existing transactions is generally not supported. Subclasses are of course encouraged to provide such support.- Parameters:
- transaction- transaction object returned by doGetTransaction
- Returns:
- if there is an existing transaction
- Throws:
- TransactionException- in case of system errors
- See Also:
- doGetTransaction(io.micronaut.transaction.support.SynchronousTransactionState)
 
 - 
registerAfterCompletionWithExistingTransactionprotected void registerAfterCompletionWithExistingTransaction(SynchronousTransactionState state, java.lang.Object transaction, java.util.List<TransactionSynchronization> synchronizations) throws TransactionException Description copied from class:AbstractSynchronousStateTransactionManagerRegister the given list of transaction synchronizations with the existing transaction.Invoked when the control of the transaction manager and thus all transaction synchronizations end, without the transaction being completed yet. This is for example the case when participating in an existing JTA or EJB CMT transaction. The default implementation simply invokes the afterCompletionmethods immediately, passing in "STATUS_UNKNOWN". This is the best we can do if there's no chance to determine the actual outcome of the outer transaction.- Overrides:
- registerAfterCompletionWithExistingTransactionin class- AbstractSynchronousStateTransactionManager<T>
- Parameters:
- state- The transaction state
- transaction- transaction object returned by- doGetTransaction
- synchronizations- a List of TransactionSynchronization objects
- Throws:
- TransactionException- in case of system errors
- See Also:
- AbstractSynchronousStateTransactionManager.invokeAfterCompletion(SynchronousTransactionState, List, TransactionSynchronization.Status),- TransactionSynchronization.afterCompletion(TransactionSynchronization.Status),- TransactionSynchronization.Status.UNKNOWN
 
 - 
registerAfterCompletionWithExistingTransactionprotected void registerAfterCompletionWithExistingTransaction(java.lang.Object transaction, java.util.List<TransactionSynchronization> synchronizations) throws TransactionExceptionRegister the given list of transaction synchronizations with the existing transaction.Invoked when the control of the Spring transaction manager and thus all Spring transaction synchronizations end, without the transaction being completed yet. This is for example the case when participating in an existing JTA or EJB CMT transaction. The default implementation simply invokes the afterCompletionmethods immediately, passing in "STATUS_UNKNOWN". This is the best we can do if there's no chance to determine the actual outcome of the outer transaction.- Parameters:
- transaction- transaction object returned by- doGetTransaction
- synchronizations- a List of TransactionSynchronization objects
- Throws:
- TransactionException- in case of system errors
- See Also:
- invokeAfterCompletion(List, TransactionSynchronization.Status),- TransactionSynchronization.afterCompletion(TransactionSynchronization.Status),- TransactionSynchronization.Status.UNKNOWN
 
 - 
doCleanupAfterCompletionprotected void doCleanupAfterCompletion(SynchronousTransactionState state, java.lang.Object transaction) Description copied from class:AbstractSynchronousStateTransactionManagerCleanup resources after transaction completion.Called after doCommitanddoRollbackexecution, on any outcome. The default implementation does nothing.Should not throw any exceptions but just issue warnings on errors. - Overrides:
- doCleanupAfterCompletionin class- AbstractSynchronousStateTransactionManager<T>
- Parameters:
- state- The state
- transaction- transaction object returned by- doGetTransaction
 
 - 
doCleanupAfterCompletionprotected void doCleanupAfterCompletion(java.lang.Object transaction) Cleanup resources after transaction completion.Called after doCommitanddoRollbackexecution, on any outcome. The default implementation does nothing.Should not throw any exceptions but just issue warnings on errors. - Parameters:
- transaction- transaction object returned by- doGetTransaction
 
 
- 
 
-