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%2FWriteData.java;h=a4f648b6b3ccb1a99fe1f3c66241f6801c4290bc;hb=9302c5052c431ae2add87d4e14a68570ef7604ec;hp=87fa010b373d679eae58ff306a262de406c9c148;hpb=ed693440aa741fee9b94447f8404d89b4020f616;p=controller.git diff --git a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/WriteData.java b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/WriteData.java index 87fa010b37..a4f648b6b3 100644 --- a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/WriteData.java +++ b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/WriteData.java @@ -8,42 +8,58 @@ 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.utils.InstanceIdentifierUtils; -import org.opendaylight.controller.protobuff.messages.common.NormalizedNodeMessages; +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 WriteData extends ModifyData{ - - public static final Class SERIALIZABLE_CLASS = ShardTransactionMessages.WriteData.class; - - public WriteData(YangInstanceIdentifier path, NormalizedNode data, SchemaContext schemaContext) { - super(path, data, schemaContext); - } - - @Override public Object toSerializable() { +/** + * @deprecated Replaced by BatchedModifications. + */ +@Deprecated +public class WriteData extends ModifyData { + private static final long serialVersionUID = 1L; - NormalizedNodeMessages.Node normalizedNode = - new NormalizedNodeToNodeCodec(schemaContext).encode(path, data) - .getNormalizedNode(); - return ShardTransactionMessages.WriteData.newBuilder() - .setInstanceIdentifierPathArguments(InstanceIdentifierUtils.toSerializable(path)) - .setNormalizedNode(normalizedNode).build(); + public static final Class SERIALIZABLE_CLASS = WriteData.class; + public WriteData() { } - public static WriteData fromSerializable(Object serializable, SchemaContext schemaContext){ - ShardTransactionMessages.WriteData o = (ShardTransactionMessages.WriteData) serializable; - YangInstanceIdentifier identifier = InstanceIdentifierUtils.fromSerializable(o.getInstanceIdentifierPathArguments()); + public WriteData(YangInstanceIdentifier path, NormalizedNode data, short version) { + super(path, data, version); + } - NormalizedNode normalizedNode = - new NormalizedNodeToNodeCodec(schemaContext) - .decode(identifier, o.getNormalizedNode()); + @Override + public Object toSerializable() { + if(getVersion() >= DataStoreVersions.LITHIUM_VERSION) { + return this; + } else { + // To base or R1 Helium version + Encoded encoded = new NormalizedNodeToNodeCodec(null).encode(getPath(), getData()); + return ShardTransactionMessages.WriteData.newBuilder() + .setInstanceIdentifierPathArguments(encoded.getEncodedPath()) + .setNormalizedNode(encoded.getEncodedNode().getNormalizedNode()).build(); + } + } - return new WriteData(identifier, normalizedNode, schemaContext); + public static WriteData fromSerializable(Object serializable) { + if(serializable instanceof WriteData) { + return (WriteData) serializable; + } else { + // From base or R1 Helium version + ShardTransactionMessages.WriteData o = (ShardTransactionMessages.WriteData) serializable; + Decoded decoded = new NormalizedNodeToNodeCodec(null).decode( + o.getInstanceIdentifierPathArguments(), o.getNormalizedNode()); + return new WriteData(decoded.getDecodedPath(), decoded.getDecodedNode(), + DataStoreVersions.HELIUM_2_VERSION); + } } + public static boolean isSerializedType(Object message) { + return SERIALIZABLE_CLASS.isInstance(message) || + message instanceof ShardTransactionMessages.WriteData; + } }