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%2Fmessages%2FCreateTransactionReply.java;h=e8d9b199947eddf70a423dd5073c52f87622a5eb;hb=81674d6fd50b419b868d0851062e23f34b34557d;hp=18b29c67d09b87f5ea99d3d82b73d8c77759e46a;hpb=fe4049d34de103016d11f3a9050853c6380646d3;p=controller.git diff --git a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/CreateTransactionReply.java b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/CreateTransactionReply.java index 18b29c67d0..e8d9b19994 100644 --- a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/CreateTransactionReply.java +++ b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/CreateTransactionReply.java @@ -8,38 +8,63 @@ package org.opendaylight.controller.cluster.datastore.messages; -import org.opendaylight.controller.protobuff.messages.transaction.ShardTransactionMessages; +import com.google.common.base.Preconditions; +import java.io.IOException; +import java.io.ObjectInput; +import java.io.ObjectOutput; +import org.opendaylight.controller.cluster.access.concepts.TransactionIdentifier; -public class CreateTransactionReply implements SerializableMessage { +public class CreateTransactionReply extends VersionedExternalizableMessage { + private static final long serialVersionUID = 1L; - public static final Class SERIALIZABLE_CLASS = ShardTransactionMessages.CreateTransactionReply.class; - private final String transactionPath; - private final String transactionId; + private String transactionPath; + private TransactionIdentifier transactionId; - public CreateTransactionReply(String transactionPath, - String transactionId) { - this.transactionPath = transactionPath; - this.transactionId = transactionId; + public CreateTransactionReply() { + } + + public CreateTransactionReply(final String transactionPath, final TransactionIdentifier transactionId, + final short version) { + super(version); + this.transactionPath = Preconditions.checkNotNull(transactionPath); + this.transactionId = Preconditions.checkNotNull(transactionId); } public String getTransactionPath() { return transactionPath; } - public String getTransactionId() { + public TransactionIdentifier getTransactionId() { return transactionId; } - public Object toSerializable(){ - return ShardTransactionMessages.CreateTransactionReply.newBuilder() - .setTransactionActorPath(transactionPath.toString()) - .setTransactionId(transactionId) - .build(); + @Override + public void readExternal(ObjectInput in) throws IOException, ClassNotFoundException { + super.readExternal(in); + transactionId = TransactionIdentifier.readFrom(in); + transactionPath = in.readUTF(); + } + + @Override + public void writeExternal(ObjectOutput out) throws IOException { + super.writeExternal(out); + transactionId.writeTo(out); + out.writeUTF(transactionPath); } - public static CreateTransactionReply fromSerializable(Object serializable){ - ShardTransactionMessages.CreateTransactionReply o = (ShardTransactionMessages.CreateTransactionReply) serializable; - return new CreateTransactionReply(o.getTransactionActorPath(), o.getTransactionId()); + @Override + public String toString() { + return "CreateTransactionReply [transactionPath=" + transactionPath + + ", transactionId=" + transactionId + + ", version=" + getVersion() + "]"; } + public static CreateTransactionReply fromSerializable(Object serializable) { + Preconditions.checkNotNull(serializable instanceof CreateTransactionReply); + return (CreateTransactionReply)serializable; + } + + public static boolean isSerializedType(Object message) { + return message instanceof CreateTransactionReply; + } }