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=28b58f72628d04131bd45c4deb972592d704fdf6;hp=0b898ede3c1ed656d014476032156eb1e25cef90;hb=2bc808b02828fde2da3dd9bfabab658156faa3c6;hpb=a46305fbc6bb7ec6883c21298d356a5e4fbbb015 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 0b898ede3c..28b58f7262 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,29 +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) { + publisherActor().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()); } }