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

io.quarkus.narayana.jta.TransactionSemantics Maven / Gradle / Ivy

package io.quarkus.narayana.jta;

import java.util.function.Function;

/**
 * Enum that can be used to control the transaction behaviour in the presence or absence of an existing transaction.
 *
 * @see QuarkusTransaction#joiningExisting()
 * @see QuarkusTransaction#requiringNew()
 * @see QuarkusTransaction#disallowingExisting()
 * @see QuarkusTransaction#suspendingExisting()
 * @see QuarkusTransaction#runner(TransactionSemantics)
 */
public enum TransactionSemantics {

    /**
     * If a transaction is already associated with the current thread a {@link QuarkusTransactionException} will be thrown,
     * otherwise a new transaction is started, and follows all the normal lifecycle rules.
     *
     * @see QuarkusTransaction#disallowingExisting()
     * @see QuarkusTransaction#runner(TransactionSemantics)
     */
    DISALLOW_EXISTING,

    /**
     * If no transaction is active then a new transaction will be started, and committed when the method ends.
     * If an exception is thrown the exception handler registered by
     * {@link TransactionRunnerOptions#exceptionHandler(Function)} will be called to
     * decide if the TX should be committed or rolled back.
     * 

* If an existing transaction is active then the method is run in the context of the existing transaction. If an * exception is thrown the exception handler will be called, however * a result of {@link TransactionExceptionResult#ROLLBACK} will result in the TX marked as rollback only, while a result of * {@link TransactionExceptionResult#COMMIT} will result in no action being taken. * * @see QuarkusTransaction#joiningExisting() * @see QuarkusTransaction#runner(TransactionSemantics) */ JOIN_EXISTING, /** * If an existing transaction is already associated with the current thread then the transaction is suspended, * then a new transaction is started which follows all the normal lifecycle rules, * and when it's complete the original transaction is resumed. *

* Otherwise, a new transaction is started, and follows all the normal lifecycle rules. * * @see QuarkusTransaction#requiringNew() * @see QuarkusTransaction#runner(TransactionSemantics) */ REQUIRE_NEW, /** * If no transaction is active then these semantics are basically a no-op. *

* If a transaction is active then it is suspended, and resumed after the task is run. *

* The exception handler will never be consulted when these semantics are in use, specifying both an exception handler and * these semantics are considered an error. *

* These semantics allows for code to easily be run outside the scope of a transaction. * * @see QuarkusTransaction#suspendingExisting() * @see QuarkusTransaction#runner(TransactionSemantics) */ SUSPEND_EXISTING }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy