X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-distributed-datastore%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fcluster%2Fdatastore%2FShardTransaction.java;h=ebec5a101491690f891605fd7908a1dac7aac0c3;hb=bb1891e328feee08ccd29c96034e967f1eeccece;hp=c6d13dcc8180553af87e0d75364999203e4b8636;hpb=11e722671c6dc194761471038a4e3ca5f7fd8970;p=controller.git diff --git a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/ShardTransaction.java b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/ShardTransaction.java index c6d13dcc81..ebec5a1014 100644 --- a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/ShardTransaction.java +++ b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/ShardTransaction.java @@ -41,27 +41,21 @@ import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode; *

*/ public abstract class ShardTransaction extends AbstractUntypedActorWithMetering { - - protected static final boolean SERIALIZED_REPLY = true; - private final ActorRef shardActor; private final ShardStats shardStats; private final String transactionID; - private final short clientTxVersion; - protected ShardTransaction(ActorRef shardActor, ShardStats shardStats, String transactionID, - short clientTxVersion) { + protected ShardTransaction(ActorRef shardActor, ShardStats shardStats, String transactionID) { super("shard-tx"); //actor name override used for metering. This does not change the "real" actor name this.shardActor = shardActor; this.shardStats = shardStats; this.transactionID = Preconditions.checkNotNull(transactionID); - this.clientTxVersion = clientTxVersion; } public static Props props(TransactionType type, AbstractShardDataTreeTransaction transaction, ActorRef shardActor, - DatastoreContext datastoreContext, ShardStats shardStats, String transactionID, short txnClientVersion) { + DatastoreContext datastoreContext, ShardStats shardStats, String transactionID) { return Props.create(new ShardTransactionCreator(type, transaction, shardActor, - datastoreContext, shardStats, transactionID, txnClientVersion)); + datastoreContext, shardStats, transactionID)); } protected abstract AbstractShardDataTreeTransaction getDOMStoreTransaction(); @@ -74,10 +68,6 @@ public abstract class ShardTransaction extends AbstractUntypedActorWithMetering return transactionID; } - protected short getClientTxVersion() { - return clientTxVersion; - } - @Override public void handleReceive(Object message) throws Exception { if (CloseTransaction.isSerializedType(message)) { @@ -115,31 +105,25 @@ public abstract class ShardTransaction extends AbstractUntypedActorWithMetering return ret; } - protected void readData(AbstractShardDataTreeTransaction transaction, ReadData message, - final boolean returnSerialized) { - + protected void readData(AbstractShardDataTreeTransaction transaction, ReadData message) { if (checkClosed(transaction)) { return; } final YangInstanceIdentifier path = message.getPath(); Optional> optional = transaction.getSnapshot().readNode(path); - ReadDataReply readDataReply = new ReadDataReply(optional.orNull(), clientTxVersion); - sender().tell((returnSerialized ? readDataReply.toSerializable(): readDataReply), self()); + ReadDataReply readDataReply = new ReadDataReply(optional.orNull(), message.getVersion()); + sender().tell(readDataReply.toSerializable(), self()); } - protected void dataExists(AbstractShardDataTreeTransaction transaction, DataExists message, - final boolean returnSerialized) { - + protected void dataExists(AbstractShardDataTreeTransaction transaction, DataExists message) { if (checkClosed(transaction)) { return; } final YangInstanceIdentifier path = message.getPath(); boolean exists = transaction.getSnapshot().readNode(path).isPresent(); - DataExistsReply dataExistsReply = DataExistsReply.create(exists); - getSender().tell(returnSerialized ? dataExistsReply.toSerializable() : - dataExistsReply, getSelf()); + getSender().tell(new DataExistsReply(exists, message.getVersion()).toSerializable(), getSelf()); } private static class ShardTransactionCreator implements Creator { @@ -151,17 +135,15 @@ public abstract class ShardTransaction extends AbstractUntypedActorWithMetering final DatastoreContext datastoreContext; final ShardStats shardStats; final String transactionID; - final short txnClientVersion; final TransactionType type; ShardTransactionCreator(TransactionType type, AbstractShardDataTreeTransaction transaction, ActorRef shardActor, - DatastoreContext datastoreContext, ShardStats shardStats, String transactionID, short txnClientVersion) { + DatastoreContext datastoreContext, ShardStats shardStats, String transactionID) { this.transaction = Preconditions.checkNotNull(transaction); this.shardActor = shardActor; this.shardStats = shardStats; this.datastoreContext = datastoreContext; this.transactionID = Preconditions.checkNotNull(transactionID); - this.txnClientVersion = txnClientVersion; this.type = type; } @@ -171,15 +153,15 @@ public abstract class ShardTransaction extends AbstractUntypedActorWithMetering switch (type) { case READ_ONLY: tx = new ShardReadTransaction(transaction, shardActor, - shardStats, transactionID, txnClientVersion); + shardStats, transactionID); break; case READ_WRITE: tx = new ShardReadWriteTransaction((ReadWriteShardDataTreeTransaction)transaction, - shardActor, shardStats, transactionID, txnClientVersion); + shardActor, shardStats, transactionID); break; case WRITE_ONLY: tx = new ShardWriteTransaction((ReadWriteShardDataTreeTransaction)transaction, - shardActor, shardStats, transactionID, txnClientVersion); + shardActor, shardStats, transactionID); break; default: throw new IllegalArgumentException("Unhandled transaction type " + type);