X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?p=controller.git;a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-akka-raft%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fcluster%2Fraft%2FRaftActorContextImpl.java;h=b71b3be3522e1082e46f56f681a0ee49440ab79d;hp=1fdc3c628fcb659fd26074d307709c0b1726801b;hb=bd8beb1bfee9f421ad8f2d07b1424b21038234a2;hpb=0032979e6c27ffdc879eabc9bb9dee2ca75ee2d8 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 1fdc3c628f..b71b3be352 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 @@ -8,15 +8,16 @@ package org.opendaylight.controller.cluster.raft; +import static com.google.common.base.Preconditions.checkState; import akka.actor.ActorRef; import akka.actor.ActorSelection; import akka.actor.ActorSystem; import akka.actor.Props; import akka.actor.UntypedActorContext; +import java.util.Map; +import org.slf4j.Logger; -import java.util.concurrent.atomic.AtomicLong; - -public class RaftActorContextImpl implements RaftActorContext{ +public class RaftActorContextImpl implements RaftActorContext { private final ActorRef actor; @@ -26,16 +27,26 @@ public class RaftActorContextImpl implements RaftActorContext{ private final ElectionTerm termInformation; - private final AtomicLong commitIndex; + private long commitIndex; + + private long lastApplied; + + private ReplicatedLog replicatedLog; + + private final Map peerAddresses; + + private final Logger LOG; - private final AtomicLong lastApplied; + private final ConfigParams configParams; - private final ReplicatedLog replicatedLog; + private boolean snapshotCaptureInitiated; public RaftActorContextImpl(ActorRef actor, UntypedActorContext context, String id, - ElectionTerm termInformation, AtomicLong commitIndex, - AtomicLong lastApplied, ReplicatedLog replicatedLog) { + ElectionTerm termInformation, long commitIndex, + long lastApplied, ReplicatedLog replicatedLog, + Map peerAddresses, ConfigParams configParams, + Logger logger) { this.actor = actor; this.context = context; this.id = id; @@ -43,36 +54,58 @@ public class RaftActorContextImpl implements RaftActorContext{ this.commitIndex = commitIndex; this.lastApplied = lastApplied; this.replicatedLog = replicatedLog; + this.peerAddresses = peerAddresses; + this.configParams = configParams; + this.LOG = logger; } + @Override public ActorRef actorOf(Props props){ return context.actorOf(props); } + @Override public ActorSelection actorSelection(String path){ return context.actorSelection(path); } + @Override public String getId() { return id; } + @Override public ActorRef getActor() { return actor; } + @Override public ElectionTerm getTermInformation() { return termInformation; } - public AtomicLong getCommitIndex() { + @Override + public long getCommitIndex() { return commitIndex; } - public AtomicLong getLastApplied() { + @Override public void setCommitIndex(long commitIndex) { + this.commitIndex = commitIndex; + } + + @Override + public long getLastApplied() { return lastApplied; } + @Override public void setLastApplied(long lastApplied) { + this.lastApplied = lastApplied; + } + + @Override public void setReplicatedLog(ReplicatedLog replicatedLog) { + this.replicatedLog = replicatedLog; + } + @Override public ReplicatedLog getReplicatedLog() { return replicatedLog; } @@ -80,4 +113,53 @@ public class RaftActorContextImpl implements RaftActorContext{ @Override public ActorSystem getActorSystem() { return context.system(); } + + @Override public Logger getLogger() { + return this.LOG; + } + + @Override public Map getPeerAddresses() { + return peerAddresses; + } + + @Override public String getPeerAddress(String peerId) { + return peerAddresses.get(peerId); + } + + @Override public ConfigParams getConfigParams() { + return configParams; + } + + @Override + public void setSnapshotCaptureInitiated(boolean snapshotCaptureInitiated) { + this.snapshotCaptureInitiated = snapshotCaptureInitiated; + } + + @Override + public boolean isSnapshotCaptureInitiated() { + return snapshotCaptureInitiated; + } + + @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); + } }