package io.ebeaninternal.server.transaction;

import io.ebeaninternal.api.SpiTransaction;
import io.ebeaninternal.api.SpiTransactionScopeManager;

Manages the Transactions typically held in a ThreadLocal.
/** * Manages the Transactions typically held in a ThreadLocal. */
public abstract class TransactionScopeManager implements SpiTransactionScopeManager { protected final String serverName; public TransactionScopeManager(String serverName) { this.serverName = serverName; }
Register the transaction manager (for use by external transaction scopes).
/** * Register the transaction manager (for use by external transaction scopes). */
public abstract void register(TransactionManager manager);
Return the current Transaction from internal Ebean scope.
/** * Return the current Transaction from internal Ebean scope. */
public abstract SpiTransaction getInScope();
Return the current Transaction potentially looking in external scope (like Spring).
/** * Return the current Transaction potentially looking in external scope (like Spring). */
public abstract SpiTransaction getActive();
Set a new Transaction for this serverName and Thread.
/** * Set a new Transaction for this serverName and Thread. */
public abstract void set(SpiTransaction trans);
Replace the current transaction with this one.

Used for Background fetching and Nested transaction scopes.

Used for background fetching. Replaces the current transaction with a 'dummy' transaction. The current transaction is given to the background thread so it can continue the fetch.

/** * Replace the current transaction with this one. * <p> * Used for Background fetching and Nested transaction scopes. * </p> * <p> * Used for background fetching. Replaces the current transaction with a * 'dummy' transaction. The current transaction is given to the background * thread so it can continue the fetch. * </p> */
@Override public abstract void replace(SpiTransaction trans); }