X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?p=controller.git;a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-binding-broker%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fmd%2Fsal%2Fbinding%2Fimpl%2FBindingToNormalizedNodeCodec.java;h=ab07f50941a25711c231073e902c5d3a09782921;hp=d9e58e538d54256fa8a5121b325a40c493b3777b;hb=8da5b805c9a27699677af56a8fd9926bd63909da;hpb=52da008f461eb10786758eb45af16c1327d5b974 diff --git a/opendaylight/md-sal/sal-binding-broker/src/main/java/org/opendaylight/controller/md/sal/binding/impl/BindingToNormalizedNodeCodec.java b/opendaylight/md-sal/sal-binding-broker/src/main/java/org/opendaylight/controller/md/sal/binding/impl/BindingToNormalizedNodeCodec.java index d9e58e538d..ab07f50941 100644 --- a/opendaylight/md-sal/sal-binding-broker/src/main/java/org/opendaylight/controller/md/sal/binding/impl/BindingToNormalizedNodeCodec.java +++ b/opendaylight/md-sal/sal-binding-broker/src/main/java/org/opendaylight/controller/md/sal/binding/impl/BindingToNormalizedNodeCodec.java @@ -9,16 +9,22 @@ package org.opendaylight.controller.md.sal.binding.impl; import com.google.common.base.Function; import com.google.common.base.Optional; +import com.google.common.base.Preconditions; import com.google.common.collect.ImmutableBiMap; import java.lang.reflect.Method; +import java.util.AbstractMap.SimpleEntry; +import java.util.HashSet; import java.util.Iterator; +import java.util.Map; import java.util.Map.Entry; +import java.util.Set; import javax.annotation.Nonnull; import org.opendaylight.controller.md.sal.common.impl.util.compat.DataNormalizationException; import org.opendaylight.controller.md.sal.common.impl.util.compat.DataNormalizationOperation; import org.opendaylight.controller.md.sal.common.impl.util.compat.DataNormalizer; import org.opendaylight.yangtools.binding.data.codec.api.BindingCodecTree; import org.opendaylight.yangtools.binding.data.codec.api.BindingCodecTreeFactory; +import org.opendaylight.yangtools.binding.data.codec.api.BindingCodecTreeNode; import org.opendaylight.yangtools.binding.data.codec.api.BindingNormalizedNodeSerializer; import org.opendaylight.yangtools.binding.data.codec.impl.BindingNormalizedNodeCodecRegistry; import org.opendaylight.yangtools.sal.binding.generator.impl.GeneratedClassLoadingStrategy; @@ -37,6 +43,7 @@ import org.opendaylight.yangtools.yang.data.api.schema.ContainerNode; import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode; import org.opendaylight.yangtools.yang.data.impl.codec.DeserializationException; import org.opendaylight.yangtools.yang.model.api.Module; +import org.opendaylight.yangtools.yang.model.api.NotificationDefinition; import org.opendaylight.yangtools.yang.model.api.RpcDefinition; import org.opendaylight.yangtools.yang.model.api.SchemaContext; import org.opendaylight.yangtools.yang.model.api.SchemaContextListener; @@ -61,13 +68,13 @@ public class BindingToNormalizedNodeCodec implements BindingCodecTreeFactory, Bi } @Override - public YangInstanceIdentifier toYangInstanceIdentifier(InstanceIdentifier binding) { + public YangInstanceIdentifier toYangInstanceIdentifier(final InstanceIdentifier binding) { return codecRegistry.toYangInstanceIdentifier(binding); } @Override public Entry> toNormalizedNode( - InstanceIdentifier path, T data) { + final InstanceIdentifier path, final T data) { return codecRegistry.toNormalizedNode(path, data); } @@ -78,33 +85,33 @@ public class BindingToNormalizedNodeCodec implements BindingCodecTreeFactory, Bi } @Override - public Entry, DataObject> fromNormalizedNode(YangInstanceIdentifier path, - NormalizedNode data) { + public Entry, DataObject> fromNormalizedNode(final YangInstanceIdentifier path, + final NormalizedNode data) { return codecRegistry.fromNormalizedNode(path, data); } @Override - public Notification fromNormalizedNodeNotification(SchemaPath path, ContainerNode data) { + public Notification fromNormalizedNodeNotification(final SchemaPath path, final ContainerNode data) { return codecRegistry.fromNormalizedNodeNotification(path, data); } @Override - public DataObject fromNormalizedNodeRpcData(SchemaPath path, ContainerNode data) { + public DataObject fromNormalizedNodeRpcData(final SchemaPath path, final ContainerNode data) { return codecRegistry.fromNormalizedNodeRpcData(path, data); } @Override - public InstanceIdentifier fromYangInstanceIdentifier(YangInstanceIdentifier dom) { + public InstanceIdentifier fromYangInstanceIdentifier(final YangInstanceIdentifier dom) { return codecRegistry.fromYangInstanceIdentifier(dom); } @Override - public ContainerNode toNormalizedNodeNotification(Notification data) { + public ContainerNode toNormalizedNodeNotification(final Notification data) { return codecRegistry.toNormalizedNodeNotification(data); } @Override - public ContainerNode toNormalizedNodeRpcData(DataContainer data) { + public ContainerNode toNormalizedNodeRpcData(final DataContainer data) { return codecRegistry.toNormalizedNodeRpcData(data); } @@ -225,13 +232,42 @@ public class BindingToNormalizedNodeCodec implements BindingCodecTreeFactory, Bi } @Override - public BindingCodecTree create(BindingRuntimeContext context) { + public BindingCodecTree create(final BindingRuntimeContext context) { return codecRegistry.create(context); } @Override - public BindingCodecTree create(SchemaContext context, Class... bindingClasses) { + public BindingCodecTree create(final SchemaContext context, final Class... bindingClasses) { return codecRegistry.create(context, bindingClasses); } + @Nonnull protected Map.Entry, BindingCodecTreeNode> getSubtreeCodec( + final YangInstanceIdentifier domIdentifier) { + + final BindingCodecTree currentCodecTree = codecRegistry.getCodecContext(); + final InstanceIdentifier bindingPath = codecRegistry.fromYangInstanceIdentifier(domIdentifier); + Preconditions.checkArgument(bindingPath != null); + /** + * If we are able to deserialize YANG instance identifier, getSubtreeCodec must + * return non-null value. + */ + final BindingCodecTreeNode codecContext = currentCodecTree.getSubtreeCodec(bindingPath); + return new SimpleEntry, BindingCodecTreeNode>(bindingPath, codecContext); + } + + public Set> getNotificationClasses(final Set interested) { + final Set> result = new HashSet<>(); + final Set knownNotifications = runtimeContext.getSchemaContext().getNotifications(); + for (final NotificationDefinition notification : knownNotifications) { + if (interested.contains(notification.getPath())) { + try { + result.add((Class) runtimeContext.getClassForSchema(notification)); + } catch (final IllegalStateException e) { + // Ignore + } + } + } + return result; + } + }