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%2Fmessages%2FRV.java;fp=opendaylight%2Fmd-sal%2Fsal-akka-raft%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fcluster%2Fraft%2Fmessages%2FRV.java;h=b75f1b7dabd675dc0e4353860d6ec38ffba4927e;hp=0000000000000000000000000000000000000000;hb=9a091425d16dadf09a5be4e764785707f5253013;hpb=10e35192bf210eeadcba20bd0c17a61bc8fd9716 diff --git a/opendaylight/md-sal/sal-akka-raft/src/main/java/org/opendaylight/controller/cluster/raft/messages/RV.java b/opendaylight/md-sal/sal-akka-raft/src/main/java/org/opendaylight/controller/cluster/raft/messages/RV.java new file mode 100644 index 0000000000..b75f1b7dab --- /dev/null +++ b/opendaylight/md-sal/sal-akka-raft/src/main/java/org/opendaylight/controller/cluster/raft/messages/RV.java @@ -0,0 +1,59 @@ +/* + * Copyright (c) 2022 PANTHEON.tech, s.r.o. and others. All rights reserved. + * + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v1.0 which accompanies this distribution, + * and is available at http://www.eclipse.org/legal/epl-v10.html + */ +package org.opendaylight.controller.cluster.raft.messages; + +import static java.util.Objects.requireNonNull; + +import java.io.Externalizable; +import java.io.IOException; +import java.io.ObjectInput; +import java.io.ObjectOutput; +import org.opendaylight.yangtools.concepts.WritableObjects; + +/** + * Serialization proxy for {@link RequestVote}. + */ +final class RV implements Externalizable { + @java.io.Serial + private static final long serialVersionUID = 1L; + + private RequestVote requestVote; + + @SuppressWarnings("checkstyle:RedundantModifier") + public RV() { + // For Externalizable + } + + RV(final RequestVote requestVote) { + this.requestVote = requireNonNull(requestVote); + } + + @Override + public void writeExternal(final ObjectOutput out) throws IOException { + WritableObjects.writeLong(out, requestVote.getTerm()); + out.writeObject(requestVote.getCandidateId()); + WritableObjects.writeLongs(out, requestVote.getLastLogIndex(), requestVote.getLastLogTerm()); + } + + @Override + public void readExternal(final ObjectInput in) throws IOException, ClassNotFoundException { + long term = WritableObjects.readLong(in); + String candidateId = (String) in.readObject(); + + final byte hdr = WritableObjects.readLongHeader(in); + long lastLogIndex = WritableObjects.readFirstLong(in, hdr); + long lastLogTerm = WritableObjects.readSecondLong(in, hdr); + + requestVote = new RequestVote(term, candidateId, lastLogIndex, lastLogTerm); + } + + @java.io.Serial + private Object readResolve() { + return requestVote; + } +}