package io.ebeaninternal.api;

import io.ebean.TxScope;
import io.ebeaninternal.server.transaction.TransactionScopeManager;

import javax.sql.DataSource;
import java.sql.Connection;
import java.sql.SQLException;

Service provider interface for the transaction manager.
/** * Service provider interface for the transaction manager. */
public interface SpiTransactionManager {
Return the scope manager for this server.
/** * Return the scope manager for this server. */
TransactionScopeManager scope();
Return the main DataSource.
/** * Return the main DataSource. */
DataSource getDataSource();
Return the read only DataSource (if defined).
/** * Return the read only DataSource (if defined). */
DataSource getReadOnlyDataSource();
Return the currently active transaction (can be null).
/** * Return the currently active transaction (can be null). */
SpiTransaction getActive();
Push an externally managed transaction into scope (e.g. Spring managed transaction).
/** * Push an externally managed transaction into scope (e.g. Spring managed transaction). */
ScopedTransaction externalBeginTransaction(SpiTransaction transaction, TxScope txScope);
Called when an externally managed transaction has completed.
/** * Called when an externally managed transaction has completed. */
void externalRemoveTransaction();
Notify of a transaction commit.
/** * Notify of a transaction commit. */
void notifyOfCommit(SpiTransaction transaction);
Notify of a transaction rollback.
/** * Notify of a transaction rollback. */
void notifyOfRollback(SpiTransaction transaction, Throwable cause);
Notify of a query only transaction commit.
/** * Notify of a query only transaction commit. */
void notifyOfQueryOnly(SpiTransaction transaction);
Return a connection used for query plan collection.
/** * Return a connection used for query plan collection. */
Connection getQueryPlanConnection() throws SQLException; }