Class AbstractTransaction
- java.lang.Object
- 
- org.apache.tinkerpop.gremlin.structure.util.AbstractTransaction
 
- 
- All Implemented Interfaces:
- AutoCloseable,- Transaction
 - Direct Known Subclasses:
- AbstractThreadedTransaction,- AbstractThreadLocalTransaction
 
 public abstract class AbstractTransaction extends Object implements Transaction A simple base class forTransactionthat provides some common functionality and default behavior. While providers can choose to use this class, it is generally better to extend fromAbstractThreadedTransactionorAbstractThreadLocalTransactionwhich include default "listener" functionality. Implementers should note that this class assumes that threaded transactions are not enabled and should explicitly overridecreateThreadedTx()to implement that functionality if required.- Author:
- Stephen Mallette (http://stephen.genoprime.com)
 
- 
- 
Nested Class Summary- 
Nested classes/interfaces inherited from interface org.apache.tinkerpop.gremlin.structure.TransactionTransaction.CLOSE_BEHAVIOR, Transaction.Exceptions, Transaction.READ_WRITE_BEHAVIOR, Transaction.Status
 
- 
 - 
Field Summary- 
Fields inherited from interface org.apache.tinkerpop.gremlin.structure.TransactionNO_OP
 
- 
 - 
Constructor SummaryConstructors Constructor Description AbstractTransaction(Graph graph)
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description <T extends TraversalSource>
 Tbegin(Class<T> traversalSourceClass)Starts a transaction in the context of a particularTraversalSourceinstance.voidclose()Closes the transaction where the default close behavior defined by {Transaction.onClose(Consumer)} will be executed.voidcommit()Commits a transaction.<G extends Graph>
 GcreateThreadedTx()Creates a transaction that can be executed across multiple threads.protected abstract voiddoClose()Calledclose().protected abstract voiddoCommit()Called withcommit()after theTransaction.onReadWrite(Consumer)has been notified.protected abstract voiddoOpen()Called withinopen()if it is determined that the transaction is not yet open givenTransaction.isOpen().protected abstract voiddoReadWrite()CalledreadWrite().protected abstract voiddoRollback()Called withrollback()after theTransaction.onReadWrite(Consumer)has been notified.protected abstract voidfireOnCommit()Called withincommit()just after the internal call todoCommit().protected abstract voidfireOnRollback()Called withinrollback()just after the internal call todoRollback()()}.voidopen()Opens a transaction.voidreadWrite()An internal function that signals a read or a write has occurred - not meant to be called directly by end users.voidrollback()Rolls back a transaction.- 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface org.apache.tinkerpop.gremlin.structure.TransactionaddTransactionListener, begin, clearTransactionListeners, isOpen, onClose, onReadWrite, removeTransactionListener
 
- 
 
- 
- 
- 
Constructor Detail- 
AbstractTransactionpublic AbstractTransaction(Graph graph) 
 
- 
 - 
Method Detail- 
doOpenprotected abstract void doOpen() Called withinopen()if it is determined that the transaction is not yet open givenTransaction.isOpen(). Implementers should assume the transaction is not yet started and should thus open one.
 - 
doCommitprotected abstract void doCommit() throws TransactionExceptionCalled withcommit()after theTransaction.onReadWrite(Consumer)has been notified. Implementers should include their commit logic here.- Throws:
- TransactionException
 
 - 
doRollbackprotected abstract void doRollback() throws TransactionExceptionCalled withrollback()after theTransaction.onReadWrite(Consumer)has been notified. Implementers should include their rollback logic here.- Throws:
- TransactionException
 
 - 
fireOnCommitprotected abstract void fireOnCommit() Called withincommit()just after the internal call todoCommit(). Implementations of this method should raiseTransaction.Status.COMMITevents to any listeners added viaTransaction.addTransactionListener(Consumer).
 - 
fireOnRollbackprotected abstract void fireOnRollback() Called withinrollback()just after the internal call todoRollback()()}. Implementations of this method should raiseTransaction.Status.ROLLBACKevents to any listeners added viaTransaction.addTransactionListener(Consumer).
 - 
doReadWriteprotected abstract void doReadWrite() CalledreadWrite(). Implementers should run their readWrite consumer here.
 - 
doCloseprotected abstract void doClose() Calledclose(). Implementers should run their readWrite consumer here.
 - 
openpublic void open() Opens a transaction.- Specified by:
- openin interface- Transaction
 
 - 
commitpublic void commit() Commits a transaction. This method may optionally throwTransactionExceptionon error. Providers should consider wrapping their transaction exceptions in this TinkerPop exception as it will lead to better error handling with Gremlin Server and other parts of the stack.- Specified by:
- commitin interface- Transaction
 
 - 
rollbackpublic void rollback() Rolls back a transaction. This method may optionally throwTransactionExceptionon error. Providers should consider wrapping their transaction exceptions in this TinkerPop exception as it will lead to better error handling with Gremlin Server and other parts of the stack.- Specified by:
- rollbackin interface- Transaction
 
 - 
createThreadedTxpublic <G extends Graph> G createThreadedTx() Creates a transaction that can be executed across multiple threads. TheGraphreturned from this method is not meant to represent some form of child transaction that can be committed from this object. A threaded transaction is aGraphinstance that has a transaction context that enables multiple threads to collaborate on the same transaction. A standard transactional context tied to aGraphthat supports transactions will typically bind a transaction to a single thread viaThreadLocal.- Specified by:
- createThreadedTxin interface- Transaction
 
 - 
beginpublic <T extends TraversalSource> T begin(Class<T> traversalSourceClass) Description copied from interface:TransactionStarts a transaction in the context of a particularTraversalSourceinstance. It is up to theTransactionimplementation to decide what this means and up to users to be aware of that meaning.- Specified by:
- beginin interface- Transaction
 
 - 
readWritepublic void readWrite() An internal function that signals a read or a write has occurred - not meant to be called directly by end users.- Specified by:
- readWritein interface- Transaction
 
 - 
closepublic void close() Closes the transaction where the default close behavior defined by {Transaction.onClose(Consumer)} will be executed.- Specified by:
- closein interface- AutoCloseable
- Specified by:
- closein interface- Transaction
 
 
- 
 
-