Merge changes I3e404877,Ida2a5c32,I9e6ce426,I6a4b90f6,I79717533
[controller.git] / opendaylight / md-sal / sal-distributed-datastore / src / main / java / org / opendaylight / controller / cluster / datastore / messages / CreateTransaction.java
index d5c9e21611af20df37bb1999d00ead9a44495fda..ea3caef093320ab1b9c4aa7d27e74df2f144b102 100644 (file)
@@ -9,34 +9,65 @@
 package org.opendaylight.controller.cluster.datastore.messages;
 
 
+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<ShardTransactionMessages.CreateTransaction> 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 = 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;
+    }
 }