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%2FServerConfigurationPayload.java;h=034af3b48bb140bc39222eab080598cde35eb2c5;hb=61e85d54cfcd70053993f910092eba1ab3fcc850;hp=32cb458c2076a3a56cd6bf86df12759f1133f766;hpb=3bc363a69d6d48709f7fd741ef018ecd75b8f99b;p=controller.git diff --git a/opendaylight/md-sal/sal-akka-raft/src/main/java/org/opendaylight/controller/cluster/raft/ServerConfigurationPayload.java b/opendaylight/md-sal/sal-akka-raft/src/main/java/org/opendaylight/controller/cluster/raft/ServerConfigurationPayload.java index 32cb458c20..034af3b48b 100644 --- a/opendaylight/md-sal/sal-akka-raft/src/main/java/org/opendaylight/controller/cluster/raft/ServerConfigurationPayload.java +++ b/opendaylight/md-sal/sal-akka-raft/src/main/java/org/opendaylight/controller/cluster/raft/ServerConfigurationPayload.java @@ -7,15 +7,15 @@ */ package org.opendaylight.controller.cluster.raft; -import com.google.protobuf.GeneratedMessage.GeneratedExtension; +import com.google.common.base.Preconditions; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.ObjectOutputStream; import java.io.Serializable; import java.util.List; -import java.util.Map; +import javax.annotation.Nonnull; import org.opendaylight.controller.cluster.raft.protobuff.client.messages.Payload; -import org.opendaylight.controller.protobuff.messages.cluster.raft.AppendEntriesMessages; +import org.opendaylight.controller.cluster.raft.protobuff.client.messages.PersistentPayload; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -24,27 +24,21 @@ import org.slf4j.LoggerFactory; * * @author Thomas Pantelis */ -public class ServerConfigurationPayload extends Payload implements Serializable { +public class ServerConfigurationPayload extends Payload implements PersistentPayload, Serializable { private static final long serialVersionUID = 1L; private static final Logger LOG = LoggerFactory.getLogger(ServerConfigurationPayload.class); - private final List newServerConfig; - private final List oldServerConfig; + private final List serverConfig; private transient int serializedSize = -1; - public ServerConfigurationPayload(List newServerConfig, List oldServerConfig) { - this.newServerConfig = newServerConfig; - this.oldServerConfig = oldServerConfig; + public ServerConfigurationPayload(@Nonnull List serverConfig) { + this.serverConfig = Preconditions.checkNotNull(serverConfig); } - public List getNewServerConfig() { - return newServerConfig; - } - - - public List getOldServerConfig() { - return oldServerConfig; + @Nonnull + public List getServerConfig() { + return serverConfig; } @Override @@ -53,8 +47,7 @@ public class ServerConfigurationPayload extends Payload implements Serializable try { ByteArrayOutputStream bos = new ByteArrayOutputStream(); ObjectOutputStream out = new ObjectOutputStream(bos); - out.writeObject(newServerConfig); - out.writeObject(oldServerConfig); + out.writeObject(serverConfig); out.close(); serializedSize = bos.toByteArray().length; @@ -68,15 +61,52 @@ public class ServerConfigurationPayload extends Payload implements Serializable } @Override - @Deprecated - @SuppressWarnings("rawtypes") - public Map encode() { - return null; + public String toString() { + return "ServerConfigurationPayload [serverConfig=" + serverConfig + "]"; } - @Override - @Deprecated - public Payload decode(AppendEntriesMessages.AppendEntries.ReplicatedLogEntry.Payload payload) { - return null; + public static class ServerInfo implements Serializable { + private static final long serialVersionUID = 1L; + + private final String id; + private final boolean isVoting; + + public ServerInfo(@Nonnull String id, boolean isVoting) { + this.id = Preconditions.checkNotNull(id); + this.isVoting = isVoting; + } + + @Nonnull + public String getId() { + return id; + } + + public boolean isVoting() { + return isVoting; + } + + @Override + public int hashCode() { + final int prime = 31; + int result = 1; + result = prime * result + (isVoting ? 1231 : 1237); + result = prime * result + id.hashCode(); + return result; + } + + @Override + public boolean equals(Object obj) { + if (obj == null || getClass() != obj.getClass()) { + return false; + } + + ServerInfo other = (ServerInfo) obj; + return isVoting == other.isVoting && id.equals(other.id); + } + + @Override + public String toString() { + return "ServerInfo [id=" + id + ", isVoting=" + isVoting + "]"; + } } }