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

io.ebeaninternal.api.SpiTransaction Maven / Gradle / Ivy

There is a newer version: 15.8.1
Show newest version
package io.ebeaninternal.api;

import io.ebean.ProfileLocation;
import io.ebean.Transaction;
import io.ebean.annotation.DocStoreMode;
import io.ebean.event.changelog.BeanChange;
import io.ebean.event.changelog.ChangeSet;
import io.ebeaninternal.server.core.PersistDeferredRelationship;
import io.ebeaninternal.server.core.PersistRequestBean;
import io.ebeaninternal.server.persist.BatchControl;
import io.ebeaninternal.server.transaction.ProfileStream;
import io.ebeanservice.docstore.api.DocStoreTransaction;

import jakarta.persistence.PersistenceException;
import java.sql.Connection;
import java.sql.SQLException;

/**
 * Extends Transaction with additional API required on server.
 * 

* Provides support for batching and TransactionContext. */ public interface SpiTransaction extends Transaction { /** * Return the user defined label for the transaction. */ String label(); /** * Return true if generated SQL and Bind values should be logged to the * transaction log. */ boolean isLogSql(); /** * Return true if summary level events should be logged to the transaction * log. */ boolean isLogSummary(); /** * Log a message to the SQL logger. */ void logSql(String msg, Object... args); /** * Log a summary message to the SUMMARY logger. */ void logSummary(String msg, Object... args); /** * Log a transaction message to the transaction logger. */ void logTxn(String msg, Object... args); /** * Register a "Deferred Relationship" that requires an additional update later. */ void registerDeferred(PersistDeferredRelationship derived); /** * Add a deleting bean to the registered list. *

* This is to handle bi-directional relationships where both sides Cascade. */ void registerDeleteBean(Integer hash); /** * Return true if this is a bean that has already been saved/deleted. */ boolean isRegisteredDeleteBean(Integer hash); /** * Unregister the persisted beans. Expected after persisting top level beans * and hence including all beans that were cascade persisted. */ void unregisterBeans(); /** * Return true if this is a bean that has already been persisted in the * current recursive save request. The goal is to stop recursively saving * the bean when cascade persist is on both sides of a relationship). *

* This will register the bean if it is not already. */ boolean isRegisteredBean(Object bean); /** * Returns a String used to identify the transaction. This id is used for * Transaction logging. */ String id(); /** * Return the start timestamp for the transaction (JVM side). */ long startNanoTime(); /** * Return true if this transaction has updateAllLoadedProperties set. * If null is returned the server default is used (set on DatabaseConfig). */ Boolean isUpdateAllLoadedProperties(); /** * Return the batchSize specifically set for this transaction or 0. *

* Returning 0 implies to use the system wide default batch size. */ DocStoreMode docStoreMode(); /** * Return the batch size to us for ElasticSearch Bulk API calls * as a result of this transaction. */ int getDocStoreBatchSize(); /** * Return the batchSize specifically set for this transaction or 0. *

* Returning 0 implies to use the system wide default batch size. */ @Override int getBatchSize(); /** * Return the getGeneratedKeys setting for this transaction. */ Boolean getBatchGetGeneratedKeys(); /** * Modify the current 'depth' of the transaction. *

* As we cascade save or delete we traverse the object graph tree. Going up * to Assoc Ones the depth decreases and going down to Assoc Manys the depth * increases. *

* The depth is used for ordering batching statements. The lowest depth get * executed first during save. */ default void depth(int diff) { // do nothing } /** * Decrement the depth BUT only if depth is greater than 0. * Return the amount that depth should be incremented by (0 or 1). */ default void depthDecrement() { // do nothing } /** * Reset the depth back to 0 - done at the end of top level insert and update. */ default void depthReset() { // do nothing } /** * Return the current depth. */ default int depth() { return 0; } /** * Return true if dirty beans are automatically persisted. */ boolean isAutoPersistUpdates(); /** * Return true if this transaction was created explicitly via * Ebean.beginTransaction(). */ boolean isExplicit(); /** * Get the object that holds the event details. *

* This information is used maintain the table state, cache and text * indexes. On commit the Table modifications this generates is broadcast * around the cluster (if you have a cluster). */ TransactionEvent event(); /** * Whether persistCascade is on for save and delete. */ boolean isPersistCascade(); /** * Return true if this request should be batched. Conversely returns false * if this request should be executed immediately. */ boolean isBatchThisRequest(); /** * Return the BatchControl used to batch up persist requests. */ BatchControl batchControl(); /** * Set the BatchControl used to batch up persist requests. There should only be one * PersistQueue set per transaction. */ void setBatchControl(BatchControl control); /** * Return the persistence context associated with this transaction. *

* You may wish to hold onto this and set it against another transaction * later. This is along the lines of 'extended persistence context' * behaviour. */ SpiPersistenceContext persistenceContext(); /** * Set the persistence context to this transaction. *

* This could be considered similar to 'EJB3 Extended Persistence Context'. * In that you can get the PersistenceContext from a transaction, hold onto * it, and then set it back later to a second transaction. In general there * is one PersistenceContext per Transaction. The getPersistenceContext() * and setPersistenceContext() enable a developer to reuse a single * PersistenceContext with multiple transactions. */ void setPersistenceContext(SpiPersistenceContext context); /** * Return the underlying Connection for internal use. *

* If the connection is made from Transaction and the user code calls * that method we can no longer trust the query only status of a * Transaction. */ Connection internalConnection(); /** * Return true if the manyToMany intersection should be persisted for this particular relationship direction. */ boolean isSaveAssocManyIntersection(String intersectionTable, String beanName); /** * Return true if batch mode got escalated for this request (and associated cascades). */ boolean checkBatchEscalationOnCascade(PersistRequestBean request); /** * If batch mode was turned on for the request then flush the batch. */ void flushBatchOnCascade(); /** * If batch was on then effectively clear the batch such that we can handle exceptions and continue. */ void flushBatchOnRollback(); /** * Translate the SQLException. */ PersistenceException translate(String message, SQLException cause); /** * Mark the transaction explicitly as not being query only. */ void markNotQueryOnly(); /** * Potentially escalate batch mode on saving or deleting a collection. */ void checkBatchEscalationOnCollection(); /** * Flush batch if we escalated batch mode on saving or deleting a collection. */ void flushBatchOnCollection(); /** * Add a bean change to the change log. */ void addBeanChange(BeanChange beanChange); /** * Send the change set to be prepared and then logged. */ void sendChangeLog(ChangeSet changeSet); /** * Return a document store transaction. */ DocStoreTransaction docStoreTransaction(); /** * Set the current Tenant Id. */ void setTenantId(Object tenantId); /** * Return the current Tenant Id. */ Object tenantId(); /** * Return the offset time from the start of the transaction. */ long profileOffset(); /** * Check if the event should be added to a profiling transaction. */ void profileEvent(SpiProfileTransactionEvent event); /** * Set the profileStream to catch and time all the events for this transaction. */ void setProfileStream(ProfileStream profileStream); /** * Return the stream that profiling events are written to. */ ProfileStream profileStream(); /** * Set the profile location for this transaction. */ void setProfileLocation(ProfileLocation profileLocation); /** * Return the profile location for this transaction. */ ProfileLocation profileLocation(); /** * Return true when nested transactions should create Savepoints. */ boolean isNestedUseSavepoint(); /** * Return true if explicitly set to skip cache (ignores skipOnWrite). */ boolean isSkipCacheExplicit(); /** * Fire pre commit processing/listeners. */ void preCommit(); /** * Fire post commit events and listeners. */ void postCommit(); /** * Fire post rollback events and listeners. */ void postRollback(Throwable cause); /** * Set the transaction to be inactive via external transaction manager. */ void deactivateExternal(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy