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%2FClusterWrapperImpl.java;h=df0128cb56ce32e3f3deca0545915acc89c45120;hp=8910137ec4583272b55ead555b0ed12e11caa02c;hb=b14856a01f6515e6063f82e5fb448f7e9a57029b;hpb=bc7b4edec3c868a14e0a0de3a3b8e1af2406448b diff --git a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/ClusterWrapperImpl.java b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/ClusterWrapperImpl.java index 8910137ec4..df0128cb56 100644 --- a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/ClusterWrapperImpl.java +++ b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/ClusterWrapperImpl.java @@ -10,6 +10,7 @@ package org.opendaylight.controller.cluster.datastore; import akka.actor.ActorRef; import akka.actor.ActorSystem; +import akka.actor.Address; import akka.cluster.Cluster; import akka.cluster.ClusterEvent; import com.google.common.base.Preconditions; @@ -17,6 +18,7 @@ import com.google.common.base.Preconditions; public class ClusterWrapperImpl implements ClusterWrapper { private final Cluster cluster; private final String currentMemberName; + private final Address selfAddress; public ClusterWrapperImpl(ActorSystem actorSystem){ Preconditions.checkNotNull(actorSystem, "actorSystem should not be null"); @@ -30,19 +32,27 @@ public class ClusterWrapperImpl implements ClusterWrapper { "member-3 here would be the name of the member" ); - currentMemberName = (String) cluster.getSelfRoles().toArray()[0]; - + currentMemberName = cluster.getSelfRoles().iterator().next(); + selfAddress = cluster.selfAddress(); } + @Override public void subscribeToMemberEvents(ActorRef actorRef){ Preconditions.checkNotNull(actorRef, "actorRef should not be null"); cluster.subscribe(actorRef, ClusterEvent.initialStateAsEvents(), ClusterEvent.MemberEvent.class, - ClusterEvent.UnreachableMember.class); + ClusterEvent.UnreachableMember.class, + ClusterEvent.ReachableMember.class); } + @Override public String getCurrentMemberName() { return currentMemberName; } + + @Override + public Address getSelfAddress() { + return selfAddress; + } }