X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?p=controller.git;a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-distributed-datastore%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fcluster%2Fdatastore%2FShardDataChangeListenerPublisherActorProxy.java;h=a17c603596d1e9b0d8045f521bfb08b23c3953fa;hp=e3c71830a85df1b8d8d3f0e240257f280c577c0f;hb=ec870dee9bacb971f11bc747b69e84ac37f5d746;hpb=e7512222d7d9e3149feb6a90eeb726e9391887fa diff --git a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/ShardDataChangeListenerPublisherActorProxy.java b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/ShardDataChangeListenerPublisherActorProxy.java index e3c71830a8..a17c603596 100644 --- a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/ShardDataChangeListenerPublisherActorProxy.java +++ b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/ShardDataChangeListenerPublisherActorProxy.java @@ -8,12 +8,17 @@ package org.opendaylight.controller.cluster.datastore; import akka.actor.ActorContext; +import akka.actor.ActorRef; +import akka.actor.Props; +import com.google.common.base.Optional; +import java.util.function.Consumer; import javax.annotation.concurrent.NotThreadSafe; import org.opendaylight.controller.md.sal.common.api.data.AsyncDataBroker.DataChangeScope; import org.opendaylight.controller.md.sal.common.api.data.AsyncDataChangeListener; -import org.opendaylight.controller.md.sal.dom.store.impl.DataChangeListenerRegistration; +import org.opendaylight.yangtools.concepts.ListenerRegistration; import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier; import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode; +import org.opendaylight.yangtools.yang.data.api.schema.tree.DataTreeCandidate; /** * Implementation of ShardDataChangeListenerPublisher that offloads the generation and publication @@ -25,30 +30,22 @@ import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode; class ShardDataChangeListenerPublisherActorProxy extends AbstractShardDataTreeNotificationPublisherActorProxy implements ShardDataChangeListenerPublisher { - private final ShardDataChangeListenerPublisher delegatePublisher = new DefaultShardDataChangeListenerPublisher(); - - ShardDataChangeListenerPublisherActorProxy(ActorContext actorContext, String actorName) { - super(actorContext, actorName); - } - - private ShardDataChangeListenerPublisherActorProxy(ShardDataChangeListenerPublisherActorProxy other) { - super(other); - } - - @Override - public >> - DataChangeListenerRegistration registerDataChangeListener(YangInstanceIdentifier path, L listener, - DataChangeScope scope) { - return delegatePublisher.registerDataChangeListener(path, listener, scope); + ShardDataChangeListenerPublisherActorProxy(ActorContext actorContext, String actorName, String logContext) { + super(actorContext, actorName, logContext); } @Override - public ShardDataChangeListenerPublisher newInstance() { - return new ShardDataChangeListenerPublisherActorProxy(this); + public void registerDataChangeListener(YangInstanceIdentifier path, + AsyncDataChangeListener> listener, DataChangeScope scope, + Optional initialState, + Consumer>>> + onRegistration) { + notifierActor().tell(new ShardDataChangePublisherActor.RegisterListener(path, listener, scope, initialState, + onRegistration), ActorRef.noSender()); } @Override - protected ShardDataTreeNotificationPublisher getDelegatePublisher() { - return delegatePublisher; + protected Props props() { + return ShardDataChangePublisherActor.props(actorName(), logContext()); } }