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%2FBindingDOMNotificationServiceAdapter.java;h=cdf03fa5527d76c911cccb30cc6b40b586f08b6f;hp=50a0a2815f2efbc675a045d6c8074d862a96ea7e;hb=123daf0f2b4f600d30c460fe9729ab925b96b545;hpb=79501c28d5f3e179cb67390fb160a63fc44bac8f diff --git a/opendaylight/md-sal/sal-binding-broker/src/main/java/org/opendaylight/controller/md/sal/binding/impl/BindingDOMNotificationServiceAdapter.java b/opendaylight/md-sal/sal-binding-broker/src/main/java/org/opendaylight/controller/md/sal/binding/impl/BindingDOMNotificationServiceAdapter.java index 50a0a2815f..cdf03fa552 100644 --- a/opendaylight/md-sal/sal-binding-broker/src/main/java/org/opendaylight/controller/md/sal/binding/impl/BindingDOMNotificationServiceAdapter.java +++ b/opendaylight/md-sal/sal-binding-broker/src/main/java/org/opendaylight/controller/md/sal/binding/impl/BindingDOMNotificationServiceAdapter.java @@ -9,15 +9,9 @@ package org.opendaylight.controller.md.sal.binding.impl; import com.google.common.collect.ClassToInstanceMap; import com.google.common.collect.ImmutableSet; -import java.util.ArrayList; -import java.util.Collection; -import java.util.List; import java.util.Set; -import javax.annotation.Nonnull; import org.opendaylight.controller.md.sal.binding.api.NotificationService; import org.opendaylight.controller.md.sal.binding.impl.BindingDOMAdapterBuilder.Factory; -import org.opendaylight.controller.md.sal.dom.api.DOMNotification; -import org.opendaylight.controller.md.sal.dom.api.DOMNotificationListener; import org.opendaylight.controller.md.sal.dom.api.DOMNotificationService; import org.opendaylight.controller.md.sal.dom.api.DOMService; import org.opendaylight.controller.sal.binding.codegen.impl.SingletonHolder; @@ -25,10 +19,7 @@ import org.opendaylight.controller.sal.binding.spi.NotificationInvokerFactory; import org.opendaylight.yangtools.binding.data.codec.api.BindingNormalizedNodeSerializer; import org.opendaylight.yangtools.concepts.AbstractListenerRegistration; import org.opendaylight.yangtools.concepts.ListenerRegistration; -import org.opendaylight.yangtools.yang.binding.Notification; import org.opendaylight.yangtools.yang.binding.NotificationListener; -import org.opendaylight.yangtools.yang.binding.util.BindingReflections; -import org.opendaylight.yangtools.yang.model.api.SchemaPath; public class BindingDOMNotificationServiceAdapter implements NotificationService, AutoCloseable { @@ -42,34 +33,20 @@ public class BindingDOMNotificationServiceAdapter implements NotificationService }; private final BindingNormalizedNodeSerializer codec; private final DOMNotificationService domNotifService; - private final NotificationInvokerFactory notificationInvokerFactory; - public BindingDOMNotificationServiceAdapter(BindingNormalizedNodeSerializer codec, DOMNotificationService domNotifService, NotificationInvokerFactory notificationInvokerFactory) { + public BindingDOMNotificationServiceAdapter(final BindingNormalizedNodeSerializer codec, final DOMNotificationService domNotifService, final NotificationInvokerFactory notificationInvokerFactory) { this.codec = codec; this.domNotifService = domNotifService; - this.notificationInvokerFactory = notificationInvokerFactory; } @Override - public ListenerRegistration registerNotificationListener(T listener) { - final NotificationInvokerFactory.NotificationInvoker invoker = notificationInvokerFactory.invokerFor(listener); - final DOMNotificationListener domListener = new NotificationInvokerImpl(invoker); - final Collection schemaPaths = convertNotifTypesToSchemaPath(invoker.getSupportedNotifications()); - final ListenerRegistration domRegistration = - domNotifService.registerNotificationListener(domListener, schemaPaths); + public ListenerRegistration registerNotificationListener(final T listener) { + final BindingDOMNotificationListenerAdapter domListener = new BindingDOMNotificationListenerAdapter(codec, listener); + final ListenerRegistration domRegistration = + domNotifService.registerNotificationListener(domListener, domListener.getSupportedNotifications()); return new ListenerRegistrationImpl<>(listener, domRegistration); } - - - private Collection convertNotifTypesToSchemaPath(Set> notificationTypes) { - final List schemaPaths = new ArrayList<>(); - for (Class notificationType : notificationTypes) { - schemaPaths.add(SchemaPath.create(true, BindingReflections.findQName(notificationType))); - } - return schemaPaths; - } - @Override public void close() throws Exception { @@ -78,7 +55,7 @@ public class BindingDOMNotificationServiceAdapter implements NotificationService private static class ListenerRegistrationImpl extends AbstractListenerRegistration { private final ListenerRegistration listenerRegistration; - public ListenerRegistrationImpl(T listener, ListenerRegistration listenerRegistration) { + public ListenerRegistrationImpl(final T listener, final ListenerRegistration listenerRegistration) { super(listener); this.listenerRegistration = listenerRegistration; } @@ -89,30 +66,13 @@ public class BindingDOMNotificationServiceAdapter implements NotificationService } } - private class NotificationInvokerImpl implements DOMNotificationListener { - private final NotificationInvokerFactory.NotificationInvoker invoker; - - public NotificationInvokerImpl(NotificationInvokerFactory.NotificationInvoker invoker) { - this.invoker = invoker; - } - - @Override - public void onNotification(@Nonnull DOMNotification notification) { - final Notification baNotification = - codec.fromNormalizedNodeNotification(notification.getType(), notification.getBody()); - invoker.getInvocationProxy().onNotification(baNotification); - - } - } - private static class Builder extends BindingDOMAdapterBuilder { - @Override - protected NotificationService createInstance(BindingToNormalizedNodeCodec codec, - ClassToInstanceMap delegates) { - DOMNotificationService domNotification = delegates.getInstance(DOMNotificationService.class); - NotificationInvokerFactory invokerFactory = SingletonHolder.INVOKER_FACTORY; + protected NotificationService createInstance(final BindingToNormalizedNodeCodec codec, + final ClassToInstanceMap delegates) { + final DOMNotificationService domNotification = delegates.getInstance(DOMNotificationService.class); + final NotificationInvokerFactory invokerFactory = SingletonHolder.INVOKER_FACTORY; return new BindingDOMNotificationServiceAdapter(codec.getCodecRegistry(), domNotification, invokerFactory); } @@ -120,8 +80,5 @@ public class BindingDOMNotificationServiceAdapter implements NotificationService public Set> getRequiredDelegates() { return ImmutableSet.of(DOMNotificationService.class); } - - - } }