X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;ds=sidebyside;f=opendaylight%2Fmd-sal%2Fsal-akka-raft%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fcluster%2Fraft%2FServerConfigurationPayload.java;fp=opendaylight%2Fmd-sal%2Fsal-akka-raft%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fcluster%2Fraft%2FServerConfigurationPayload.java;h=112c7d56e00faa62a84051cfda87fb2ab39102a4;hb=af65c60b352ab06eb32294ccd9879f5e43585e31;hp=db1f193cba360fd389a683d435a9fa8a6ff61698;hpb=40005e3a40684d2cd4f10ac303bd87a5dd524517;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 db1f193cba..112c7d56e0 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,6 +7,7 @@ */ package org.opendaylight.controller.cluster.raft; +import com.google.common.base.Preconditions; import com.google.protobuf.GeneratedMessage.GeneratedExtension; import java.io.ByteArrayOutputStream; import java.io.IOException; @@ -14,6 +15,7 @@ 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.slf4j.Logger; @@ -29,22 +31,16 @@ public class ServerConfigurationPayload extends Payload implements Serializable 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 +49,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; @@ -82,7 +77,51 @@ public class ServerConfigurationPayload extends Payload implements Serializable @Override public String toString() { - return "ServerConfigurationPayload [newServerConfig=" + newServerConfig + ", oldServerConfig=" - + oldServerConfig + "]"; + return "ServerConfigurationPayload [serverConfig=" + serverConfig + "]"; + } + + 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 + "]"; + } } }