X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-akka-raft%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fcluster%2Fraft%2FRaftActorContextImpl.java;h=833c8a9e8ad1ca7b8fe170aadffc25b3c12b6b24;hb=8c6fac2a853a107c49983fb17934958eadaee416;hp=845011a7e372548999c9b643d26630528543e473;hpb=7be62e955c32ff7fa10753c4307199b287b1904c;p=controller.git diff --git a/opendaylight/md-sal/sal-akka-raft/src/main/java/org/opendaylight/controller/cluster/raft/RaftActorContextImpl.java b/opendaylight/md-sal/sal-akka-raft/src/main/java/org/opendaylight/controller/cluster/raft/RaftActorContextImpl.java index 845011a7e3..833c8a9e8a 100644 --- a/opendaylight/md-sal/sal-akka-raft/src/main/java/org/opendaylight/controller/cluster/raft/RaftActorContextImpl.java +++ b/opendaylight/md-sal/sal-akka-raft/src/main/java/org/opendaylight/controller/cluster/raft/RaftActorContextImpl.java @@ -13,6 +13,11 @@ import akka.actor.ActorSelection; import akka.actor.ActorSystem; import akka.actor.Props; import akka.actor.UntypedActorContext; +import akka.event.LoggingAdapter; + +import java.util.Map; + +import static com.google.common.base.Preconditions.checkState; public class RaftActorContextImpl implements RaftActorContext{ @@ -30,10 +35,14 @@ public class RaftActorContextImpl implements RaftActorContext{ private final ReplicatedLog replicatedLog; + private final Map peerAddresses; + + private final LoggingAdapter LOG; + public RaftActorContextImpl(ActorRef actor, UntypedActorContext context, String id, ElectionTerm termInformation, long commitIndex, - long lastApplied, ReplicatedLog replicatedLog) { + long lastApplied, ReplicatedLog replicatedLog, Map peerAddresses, LoggingAdapter logger) { this.actor = actor; this.context = context; this.id = id; @@ -41,6 +50,8 @@ public class RaftActorContextImpl implements RaftActorContext{ this.commitIndex = commitIndex; this.lastApplied = lastApplied; this.replicatedLog = replicatedLog; + this.peerAddresses = peerAddresses; + this.LOG = logger; } public ActorRef actorOf(Props props){ @@ -86,4 +97,39 @@ public class RaftActorContextImpl implements RaftActorContext{ @Override public ActorSystem getActorSystem() { return context.system(); } + + @Override public LoggingAdapter getLogger() { + return this.LOG; + } + + @Override public Map getPeerAddresses() { + return peerAddresses; + } + + @Override public String getPeerAddress(String peerId) { + return peerAddresses.get(peerId); + } + + @Override public void addToPeers(String name, String address) { + peerAddresses.put(name, address); + } + + @Override public void removePeer(String name) { + peerAddresses.remove(name); + } + + @Override public ActorSelection getPeerActorSelection(String peerId) { + String peerAddress = getPeerAddress(peerId); + if(peerAddress != null){ + return actorSelection(peerAddress); + } + return null; + } + + @Override public void setPeerAddress(String peerId, String peerAddress) { + LOG.info("Peer address for peer {} set to {}", peerId, peerAddress); + checkState(peerAddresses.containsKey(peerId), peerId + " is unknown"); + + peerAddresses.put(peerId, peerAddress); + } }