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%2FMergeData.java;h=ae0d630cf267aa75b0ef403b8df7e7733d06e082;hb=20156b149d56b1b14a06d344366b8e1af1c22fe8;hp=eb1f3495bdf2c04328ad5336eb44b248149bd242;hpb=5ed4ad773ce1bdd1a1511fe8ce66e0db00ae0a3b;p=controller.git diff --git a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/MergeData.java b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/MergeData.java index eb1f3495bd..ae0d630cf2 100644 --- a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/MergeData.java +++ b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/MergeData.java @@ -8,36 +8,54 @@ package org.opendaylight.controller.cluster.datastore.messages; +import org.opendaylight.controller.cluster.datastore.DataStoreVersions; import org.opendaylight.controller.cluster.datastore.node.NormalizedNodeToNodeCodec; import org.opendaylight.controller.cluster.datastore.node.NormalizedNodeToNodeCodec.Decoded; import org.opendaylight.controller.cluster.datastore.node.NormalizedNodeToNodeCodec.Encoded; import org.opendaylight.controller.protobuff.messages.transaction.ShardTransactionMessages; import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier; import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode; -import org.opendaylight.yangtools.yang.model.api.SchemaContext; -public class MergeData extends ModifyData{ +public class MergeData extends ModifyData implements VersionedSerializableMessage { + private static final long serialVersionUID = 1L; - public static final Class SERIALIZABLE_CLASS = - ShardTransactionMessages.MergeData.class; + public static final Class SERIALIZABLE_CLASS = MergeData.class; - public MergeData(YangInstanceIdentifier path, NormalizedNode data, - SchemaContext context) { - super(path, data, context); + public MergeData() { + } + + public MergeData(YangInstanceIdentifier path, NormalizedNode data) { + super(path, data); } @Override - public Object toSerializable() { - Encoded encoded = new NormalizedNodeToNodeCodec(schemaContext).encode(path, data); - return ShardTransactionMessages.MergeData.newBuilder() - .setInstanceIdentifierPathArguments(encoded.getEncodedPath()) - .setNormalizedNode(encoded.getEncodedNode().getNormalizedNode()).build(); + public Object toSerializable(short toVersion) { + if(toVersion >= DataStoreVersions.LITHIUM_VERSION) { + setVersion(toVersion); + return this; + } else { + // To base or R1 Helium version + Encoded encoded = new NormalizedNodeToNodeCodec(null).encode(getPath(), getData()); + return ShardTransactionMessages.MergeData.newBuilder() + .setInstanceIdentifierPathArguments(encoded.getEncodedPath()) + .setNormalizedNode(encoded.getEncodedNode().getNormalizedNode()).build(); + } + } + + public static MergeData fromSerializable(Object serializable){ + if(serializable instanceof MergeData) { + return (MergeData) serializable; + } else { + // From base or R1 Helium version + ShardTransactionMessages.MergeData o = (ShardTransactionMessages.MergeData) serializable; + Decoded decoded = new NormalizedNodeToNodeCodec(null).decode( + o.getInstanceIdentifierPathArguments(), o.getNormalizedNode()); + return new MergeData(decoded.getDecodedPath(), decoded.getDecodedNode()); + } } - public static MergeData fromSerializable(Object serializable, SchemaContext schemaContext){ - ShardTransactionMessages.MergeData o = (ShardTransactionMessages.MergeData) serializable; - Decoded decoded = new NormalizedNodeToNodeCodec(schemaContext).decode( - o.getInstanceIdentifierPathArguments(), o.getNormalizedNode()); - return new MergeData(decoded.getDecodedPath(), decoded.getDecodedNode(), schemaContext); + public static boolean isSerializedType(Object message) { + return SERIALIZABLE_CLASS.isInstance(message) || + message instanceof ShardTransactionMessages.MergeData; } }