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%2FDataExists.java;h=db62547d424506efb26236610e9d1567e032e6fd;hp=84b8df167607701ea35caf4c32fa301451744e83;hb=24c074a4b32ac97980a652b78824b7c2f97ffb78;hpb=91fb9d932840c79f73197bbe6feb9df321f5f47e diff --git a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/DataExists.java b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/DataExists.java index 84b8df1676..db62547d42 100644 --- a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/DataExists.java +++ b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/DataExists.java @@ -8,34 +8,48 @@ package org.opendaylight.controller.cluster.datastore.messages; -import org.opendaylight.controller.cluster.datastore.util.InstanceIdentifierUtils; -import org.opendaylight.controller.protobuff.messages.transaction.ShardTransactionMessages; +import com.google.common.base.Preconditions; +import com.google.common.util.concurrent.CheckedFuture; +import com.google.common.util.concurrent.SettableFuture; +import org.opendaylight.controller.md.sal.common.api.data.ReadFailedException; +import org.opendaylight.controller.sal.core.spi.data.DOMStoreReadTransaction; import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier; -public class DataExists implements SerializableMessage{ +public class DataExists extends AbstractRead { + private static final long serialVersionUID = 1L; - public static final Class SERIALIZABLE_CLASS = - ShardTransactionMessages.DataExists.class; + public DataExists() { + } - private final YangInstanceIdentifier path; + public DataExists(final YangInstanceIdentifier path, final short version) { + super(path, version); + } - public DataExists(final YangInstanceIdentifier path) { - this.path = path; + @Override + public CheckedFuture apply(DOMStoreReadTransaction readDelegate) { + return readDelegate.exists(getPath()); } - public YangInstanceIdentifier getPath() { - return path; + @Override + public void processResponse(Object response, SettableFuture returnFuture) { + if(DataExistsReply.isSerializedType(response)) { + returnFuture.set(Boolean.valueOf(DataExistsReply.fromSerializable(response).exists())); + } else { + returnFuture.setException(new ReadFailedException("Invalid response checking exists for path " + getPath())); + } } - @Override public Object toSerializable() { - return ShardTransactionMessages.DataExists.newBuilder() - .setInstanceIdentifierPathArguments( - InstanceIdentifierUtils.toSerializable(path)).build(); + @Override + protected AbstractRead newInstance(short withVersion) { + return new DataExists(getPath(), withVersion); } public static DataExists fromSerializable(final Object serializable){ - ShardTransactionMessages.DataExists o = (ShardTransactionMessages.DataExists) serializable; - return new DataExists(InstanceIdentifierUtils.fromSerializable(o.getInstanceIdentifierPathArguments())); + Preconditions.checkArgument(serializable instanceof DataExists); + return (DataExists)serializable; } + public static boolean isSerializedType(Object message) { + return message instanceof DataExists; + } }