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=c5e3a6b05966c9c30f12c5f6f7dab93a78fbebf7;hb=cad857b425b1a0072681066b2ba37b0b0dc8c111;hp=1348e65aa30679cbdb8ae539eb0aa91d4d54594c;hpb=af01f3ff581487d002140ca08a94e4636546d649;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 1348e65aa3..c5e3a6b059 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,12 +8,54 @@ package org.opendaylight.controller.cluster.datastore.messages; -import org.opendaylight.yangtools.yang.data.api.InstanceIdentifier; +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; -public class WriteData extends ModifyData{ +public class WriteData extends ModifyData implements VersionedSerializableMessage { + private static final long serialVersionUID = 1L; - public WriteData(InstanceIdentifier path, NormalizedNode data) { - super(path, data); - } + public static final Class SERIALIZABLE_CLASS = WriteData.class; + + public WriteData() { + } + + public WriteData(YangInstanceIdentifier path, NormalizedNode data) { + super(path, data); + } + + @Override + 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.WriteData.newBuilder() + .setInstanceIdentifierPathArguments(encoded.getEncodedPath()) + .setNormalizedNode(encoded.getEncodedNode().getNormalizedNode()).build(); + } + } + + 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()); + } + } + + public static boolean isSerializedType(Object message) { + return SERIALIZABLE_CLASS.isAssignableFrom(message.getClass()) || + message instanceof ShardTransactionMessages.WriteData; + } }