X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?p=controller.git;a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-distributed-datastore%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fcluster%2Fdatastore%2FAbstractShardDataTreeTransaction.java;h=bec1a38f2453790d6a80e786e1be7d3dfa6c560b;hp=dd8ec0b12ab30f3a947ac1d795347772cd119e0d;hb=3402cfce32b05957219e54754dd7ca5b0a54cd0e;hpb=559c2b6afa7714572e01b52029acaa4d5a7315e2 diff --git a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/AbstractShardDataTreeTransaction.java b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/AbstractShardDataTreeTransaction.java index dd8ec0b12a..bec1a38f24 100644 --- a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/AbstractShardDataTreeTransaction.java +++ b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/AbstractShardDataTreeTransaction.java @@ -7,25 +7,42 @@ */ package org.opendaylight.controller.cluster.datastore; +import static com.google.common.base.Preconditions.checkState; +import static java.util.Objects.requireNonNull; + import com.google.common.base.MoreObjects; -import com.google.common.base.Preconditions; -import javax.annotation.concurrent.NotThreadSafe; +import org.opendaylight.controller.cluster.access.concepts.TransactionIdentifier; +import org.opendaylight.controller.cluster.datastore.persisted.AbortTransactionPayload; +import org.opendaylight.yangtools.concepts.Identifiable; import org.opendaylight.yangtools.yang.data.api.schema.tree.DataTreeSnapshot; /** - * Abstract base for transactions running on SharrdDataTree. + * Abstract base for transactions running on SharrdDataTree. This class is NOT thread-safe. * * @param Backing transaction type. */ -@NotThreadSafe -abstract class AbstractShardDataTreeTransaction { +abstract class AbstractShardDataTreeTransaction + implements Identifiable { + private final ShardDataTreeTransactionParent parent; + private final TransactionIdentifier id; private final T snapshot; - private final String id; + private boolean closed; - protected AbstractShardDataTreeTransaction(final String id, final T snapshot) { - this.snapshot = Preconditions.checkNotNull(snapshot); - this.id = Preconditions.checkNotNull(id); + AbstractShardDataTreeTransaction(final ShardDataTreeTransactionParent parent, final TransactionIdentifier id, + final T snapshot) { + this.parent = requireNonNull(parent); + this.snapshot = requireNonNull(snapshot); + this.id = requireNonNull(id); + } + + @Override + public final TransactionIdentifier getIdentifier() { + return id; + } + + final ShardDataTreeTransactionParent getParent() { + return parent; } final T getSnapshot() { @@ -50,10 +67,28 @@ abstract class AbstractShardDataTreeTransaction { return true; } + final void abort(final Runnable callback) { + checkState(close(), "Transaction is already closed"); + parent.abortTransaction(this, callback); + } + + /** + * This method is exposed for sake of {@link ShardTransaction}, which is an actor. We need to ensure that + * the parent is updated to reflect the transaction has been closed, but no journal actions may be invoked. + * + *

+ * ShardTransaction is responsible for additionally sending a request to persist an {@link AbortTransactionPayload} + * via a message to the Shard actor. + */ + final void abortFromTransactionActor() { + if (close()) { + parent.abortFromTransactionActor(this); + } + } + @Override public final String toString() { - return MoreObjects.toStringHelper(this).add("id", id).add("closed", closed).add("snapshot", snapshot).toString(); + return MoreObjects.toStringHelper(this).add("id", id).add("closed", closed).add("snapshot", snapshot) + .toString(); } - - abstract void abort(); }