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%2FRegisterChangeListener.java;h=1d8edece1a5161137daab2abb03e6b968a920615;hb=95115ca49f3b16b936e0f6c88aedfc17cd0ee92c;hp=0123a701471e29ef5a81ad41dc3fb2304e4cbf62;hpb=2a35e5ab8c3300757a425841d017097c1fa31e68;p=controller.git diff --git a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/RegisterChangeListener.java b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/RegisterChangeListener.java index 0123a70147..1d8edece1a 100644 --- a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/RegisterChangeListener.java +++ b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/messages/RegisterChangeListener.java @@ -8,32 +8,60 @@ package org.opendaylight.controller.cluster.datastore.messages; +import akka.actor.ActorPath; +import akka.actor.ActorRef; +import akka.actor.ActorSystem; +import akka.serialization.Serialization; +import org.opendaylight.controller.cluster.datastore.util.InstanceIdentifierUtils; import org.opendaylight.controller.md.sal.common.api.data.AsyncDataBroker; -import org.opendaylight.controller.md.sal.common.api.data.AsyncDataChangeListener; -import org.opendaylight.yangtools.yang.data.api.InstanceIdentifier; -import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode; +import org.opendaylight.controller.protobuff.messages.registration.ListenerRegistrationMessages; +import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier; -public class RegisterChangeListener { - private final InstanceIdentifier path; - private final AsyncDataChangeListener> listener; - private final AsyncDataBroker.DataChangeScope scope; +public class RegisterChangeListener implements SerializableMessage { + public static final Class SERIALIZABLE_CLASS = + ListenerRegistrationMessages.RegisterChangeListener.class; + private final YangInstanceIdentifier path; + private final ActorRef dataChangeListener; + private final AsyncDataBroker.DataChangeScope scope; - public RegisterChangeListener(InstanceIdentifier path, AsyncDataChangeListener> listener, AsyncDataBroker.DataChangeScope scope) { - this.path = path; - this.listener = listener; - this.scope = scope; - } - public InstanceIdentifier getPath() { - return path; - } + public RegisterChangeListener(YangInstanceIdentifier path, + ActorRef dataChangeListener, + AsyncDataBroker.DataChangeScope scope) { + this.path = path; + this.dataChangeListener = dataChangeListener; + this.scope = scope; + } - public AsyncDataChangeListener> getListener() { - return listener; - } + public YangInstanceIdentifier getPath() { + return path; + } + + + public AsyncDataBroker.DataChangeScope getScope() { + return scope; + } - public AsyncDataBroker.DataChangeScope getScope() { - return scope; + public ActorPath getDataChangeListenerPath() { + return dataChangeListener.path(); + } + + + @Override + public ListenerRegistrationMessages.RegisterChangeListener toSerializable() { + return ListenerRegistrationMessages.RegisterChangeListener.newBuilder() + .setInstanceIdentifierPath(InstanceIdentifierUtils.toSerializable(path)) + .setDataChangeListenerActorPath(Serialization.serializedActorPath(dataChangeListener)) + .setDataChangeScope(scope.ordinal()).build(); + } + + public static RegisterChangeListener fromSerializable(ActorSystem actorSystem, Object serializable){ + ListenerRegistrationMessages.RegisterChangeListener o = (ListenerRegistrationMessages.RegisterChangeListener) serializable; + return new RegisterChangeListener(InstanceIdentifierUtils.fromSerializable(o.getInstanceIdentifierPath()), + actorSystem.provider().resolveActorRef(o.getDataChangeListenerActorPath()), + AsyncDataBroker.DataChangeScope.values()[o.getDataChangeScope()]); } + + }