io.quarkus.narayana.jta.RunOptions Maven / Gradle / Ivy
Show all versions of quarkus-narayana-jta Show documentation
package io.quarkus.narayana.jta;
import java.util.function.Function;
/**
* Builder interface to allow a transaction to be customized, including things like timeout and semantics when an existing
* transaction is present.
*/
public class RunOptions {
Semantic semantic = Semantic.REQUIRE_NEW;
int timeout = 0;
Function exceptionHandler;
/**
* Sets the transaction timeout for transactions created by this builder. A value of zero refers to the system default.
*
* @throws IllegalArgumentException If seconds is negative
* @param seconds The timeout in seconds
* @return This builder
*/
public RunOptions timeout(int seconds) {
if (seconds < 0) {
throw new IllegalArgumentException("seconds cannot be negative");
}
this.timeout = seconds;
return this;
}
/**
* Sets the transaction semantic that is used to determine the action to take if a transaction is already active.
*
*
* @param semantic The semantic
* @return This builder
*/
public RunOptions semantic(Semantic semantic) {
this.semantic = semantic;
return this;
}
/**
* Provides an exception handler that can make a decision to rollback or commit based on the type of exception. If the
* predicate returns {@link ExceptionResult#ROLLBACK} the transaction is rolled back,
* otherwise it is committed.
*
* This exception will still be propagated to the caller, so this method should not log or perform any other actions other
* than determine what should happen to the current transaction.
*
* By default the exception is always rolled back.
*
* @param handler The exception handler
* @return This builder
*/
public RunOptions exceptionHandler(Function handler) {
this.exceptionHandler = handler;
return this;
}
/**
* Enum that can be used to control the transaction behaviour in the presence or absence of an existing transaction.
*/
public enum Semantic {
/**
* 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.
*/
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 #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 ExceptionResult#ROLLBACK} will result in the TX marked as rollback only, while a result of
* {@link ExceptionResult#COMMIT} will result in no action being taken.
*/
JOIN_EXISTING,
/**
* This is the default semantic.
*
* If an existing transaction is already associated with the current thread then the transaction is suspended, and
* resumed once
* the current transaction is complete.
*
* A new transaction is started after the existing transaction is suspended, and follows all the normal lifecycle rules.
*
*/
REQUIRE_NEW,
/**
* If no transaction is active then this semantic is 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 this semantic is in use, specifying both an exception handler and
* this semantic is considered an error.
*
* This semantic allows for code to easily be run outside the scope of a transaction.
*/
SUSPEND_EXISTING
}
public enum ExceptionResult {
/**
* The transaction should be committed.
*/
COMMIT,
/**
* The transaction should be rolled back.
*/
ROLLBACK
}
}