Improve segmented journal actor metrics
[controller.git] / opendaylight / md-sal / sal-distributed-datastore / src / main / java / org / opendaylight / controller / cluster / datastore / messages / DataExistsReply.java
index 24ca6464543911c9d4c6d05fe1f3f2d8731c920e..799cd8b86e3d8d2f1903a753dcdbd1e3586b9131 100644 (file)
@@ -5,18 +5,24 @@
  * terms of the Eclipse Public License v1.0 which accompanies this distribution,
  * and is available at http://www.eclipse.org/legal/epl-v10.html
  */
-
 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;
+
+@Deprecated(since = "9.0.0", forRemoval = true)
+public class DataExistsReply extends VersionedExternalizableMessage {
+    private static final long serialVersionUID = 1L;
 
-public class DataExistsReply implements SerializableMessage{
-    public static final Class<ShardTransactionMessages.DataExistsReply> SERIALIZABLE_CLASS =
-            ShardTransactionMessages.DataExistsReply.class;
+    private boolean exists;
 
-    private final boolean exists;
+    public DataExistsReply() {
+    }
 
-    public DataExistsReply(final boolean exists) {
+    public DataExistsReply(final boolean exists, final short version) {
+        super(version);
         this.exists = exists;
     }
 
@@ -24,14 +30,24 @@ public class DataExistsReply implements SerializableMessage{
         return exists;
     }
 
-    @Override public Object toSerializable() {
-        return ShardTransactionMessages.DataExistsReply.newBuilder()
-            .setExists(exists).build();
+    @Override
+    public void readExternal(final ObjectInput in) throws IOException, ClassNotFoundException {
+        super.readExternal(in);
+        exists = in.readBoolean();
     }
 
-    public static DataExistsReply fromSerializable(final Object serializable){
-        ShardTransactionMessages.DataExistsReply o = (ShardTransactionMessages.DataExistsReply) serializable;
-        return new DataExistsReply(o.getExists());
+    @Override
+    public void writeExternal(final ObjectOutput out) throws IOException {
+        super.writeExternal(out);
+        out.writeBoolean(exists);
     }
 
+    public static DataExistsReply fromSerializable(final Object serializable) {
+        Preconditions.checkArgument(serializable instanceof DataExistsReply);
+        return (DataExistsReply)serializable;
+    }
+
+    public static boolean isSerializedType(final Object message) {
+        return message instanceof DataExistsReply;
+    }
 }