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%2Fmessages%2FCreateTransaction.java;h=21f16e7bfeef07bf1c64ec97baa33b683420a216;hp=d5c9e21611af20df37bb1999d00ead9a44495fda;hb=bea73749199179ffc19184c717dd4c585185ccb7;hpb=c911a187bdcd6160c1929e53466cd9de681c2098 diff --git a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/CreateTransaction.java b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/CreateTransaction.java index d5c9e21611..21f16e7bfe 100644 --- a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/CreateTransaction.java +++ b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/CreateTransaction.java @@ -9,34 +9,66 @@ package org.opendaylight.controller.cluster.datastore.messages; +import com.google.common.base.Preconditions; +import org.opendaylight.controller.cluster.datastore.DataStoreVersions; import org.opendaylight.controller.protobuff.messages.transaction.ShardTransactionMessages; public class CreateTransaction implements SerializableMessage { - public static final Class SERIALIZABLE_CLASS = ShardTransactionMessages.CreateTransaction.class; - private final String transactionId; - private final int transactionType; + public static final Class SERIALIZABLE_CLASS = + ShardTransactionMessages.CreateTransaction.class; - public CreateTransaction(String transactionId, int transactionType){ + private final String transactionId; + private final int transactionType; + private final String transactionChainId; + private final short version; - this.transactionId = transactionId; - this.transactionType = transactionType; - } + public CreateTransaction(String transactionId, int transactionType) { + this(transactionId, transactionType, ""); + } - public String getTransactionId() { - return transactionId; - } + public CreateTransaction(String transactionId, int transactionType, String transactionChainId) { + this(transactionId, transactionType, transactionChainId, DataStoreVersions.CURRENT_VERSION); + } - public int getTransactionType() { return transactionType;} + private CreateTransaction(String transactionId, int transactionType, String transactionChainId, + short version) { + this.transactionId = Preconditions.checkNotNull(transactionId); + this.transactionType = transactionType; + this.transactionChainId = transactionChainId; + this.version = version; + } - @Override - public Object toSerializable() { - return ShardTransactionMessages.CreateTransaction.newBuilder().setTransactionId(transactionId).setTransactionType(transactionType).build(); - } + public String getTransactionId() { + return transactionId; + } - public static CreateTransaction fromSerializable(Object message){ - ShardTransactionMessages.CreateTransaction createTransaction = (ShardTransactionMessages.CreateTransaction)message; - return new CreateTransaction(createTransaction.getTransactionId(),createTransaction.getTransactionType() ); - } + public int getTransactionType() { + return transactionType; + } + public short getVersion() { + return version; + } + + @Override + public Object toSerializable() { + return ShardTransactionMessages.CreateTransaction.newBuilder() + .setTransactionId(transactionId) + .setTransactionType(transactionType) + .setTransactionChainId(transactionChainId) + .setMessageVersion(version).build(); + } + + public static CreateTransaction fromSerializable(Object message) { + ShardTransactionMessages.CreateTransaction createTransaction = + (ShardTransactionMessages.CreateTransaction) message; + return new CreateTransaction(createTransaction.getTransactionId(), + createTransaction.getTransactionType(), createTransaction.getTransactionChainId(), + (short)createTransaction.getMessageVersion()); + } + + public String getTransactionChainId() { + return transactionChainId; + } }