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=87fa010b373d679eae58ff306a262de406c9c148;hb=d0bf270d0493c04ac2e9e4a9f7de56e5b65a4ef2;hp=913da06775a0d6dab240e9dfee24cd21ea727342;hpb=40d9485acea90c26af4658ab3e90f969bd476f60;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 913da06775..87fa010b37 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,17 +8,42 @@ package org.opendaylight.controller.cluster.datastore.messages; -import org.opendaylight.yangtools.yang.data.api.InstanceIdentifier; +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.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 WriteData(InstanceIdentifier path, NormalizedNode data, SchemaContext schemaContext) { + 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() { - throw new UnsupportedOperationException("toSerializable"); + + NormalizedNodeMessages.Node normalizedNode = + new NormalizedNodeToNodeCodec(schemaContext).encode(path, data) + .getNormalizedNode(); + return ShardTransactionMessages.WriteData.newBuilder() + .setInstanceIdentifierPathArguments(InstanceIdentifierUtils.toSerializable(path)) + .setNormalizedNode(normalizedNode).build(); + + } + + public static WriteData fromSerializable(Object serializable, SchemaContext schemaContext){ + ShardTransactionMessages.WriteData o = (ShardTransactionMessages.WriteData) serializable; + YangInstanceIdentifier identifier = InstanceIdentifierUtils.fromSerializable(o.getInstanceIdentifierPathArguments()); + + NormalizedNode normalizedNode = + new NormalizedNodeToNodeCodec(schemaContext) + .decode(identifier, o.getNormalizedNode()); + + return new WriteData(identifier, normalizedNode, schemaContext); } + }