io.atomix.copycat.server.response.AppendResponse Maven / Gradle / Ivy
/*
* Copyright 2015 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package io.atomix.copycat.server.response;
import io.atomix.catalyst.buffer.BufferInput;
import io.atomix.catalyst.buffer.BufferOutput;
import io.atomix.catalyst.serializer.SerializeWith;
import io.atomix.catalyst.serializer.Serializer;
import io.atomix.catalyst.util.Assert;
import io.atomix.copycat.client.error.RaftError;
import io.atomix.copycat.client.response.AbstractResponse;
import io.atomix.copycat.client.response.Response;
import java.util.Objects;
/**
* Protocol append response.
*
* @author Jordan Halterman
*/
@SerializeWith(id=208)
public class AppendResponse extends AbstractResponse {
/**
* Returns a new append response builder.
*
* @return A new append response builder.
*/
public static Builder builder() {
return new Builder(new AppendResponse());
}
/**
* Returns an append response builder for an existing response.
*
* @param response The response to build.
* @return The append response builder.
*/
public static Builder builder(AppendResponse response) {
return new Builder(response);
}
private long term;
private boolean succeeded;
private long logIndex;
/**
* Returns the requesting node's current term.
*
* @return The requesting node's current term.
*/
public long term() {
return term;
}
/**
* Returns a boolean indicating whether the append was successful.
*
* @return Indicates whether the append was successful.
*/
public boolean succeeded() {
return succeeded;
}
/**
* Returns the last index of the replica's log.
*
* @return The last index of the responding replica's log.
*/
public long logIndex() {
return logIndex;
}
@Override
public void readObject(BufferInput buffer, Serializer serializer) {
status = Status.forId(buffer.readByte());
if (status == Response.Status.OK) {
error = null;
term = buffer.readLong();
succeeded = buffer.readBoolean();
logIndex = buffer.readLong();
} else {
error = RaftError.forId(buffer.readByte());
}
}
@Override
public void writeObject(BufferOutput buffer, Serializer serializer) {
buffer.writeByte(status.id());
if (status == Response.Status.OK) {
buffer.writeLong(term)
.writeBoolean(succeeded)
.writeLong(logIndex);
} else {
buffer.writeByte(error.id());
}
}
@Override
public int hashCode() {
return Objects.hash(getClass(), status, term, succeeded, logIndex);
}
@Override
public boolean equals(Object object) {
if (object instanceof AppendResponse) {
AppendResponse response = (AppendResponse) object;
return response.status == status
&& response.term == term
&& response.succeeded == succeeded
&& response.logIndex == logIndex;
}
return false;
}
@Override
public String toString() {
return String.format("%s[status=%s, term=%d, succeeded=%b, logIndex=%d]", getClass().getSimpleName(), status, term, succeeded, logIndex);
}
/**
* Append response builder.
*/
public static class Builder extends AbstractResponse.Builder {
protected Builder(AppendResponse response) {
super(response);
}
/**
* Sets the response term.
*
* @param term The response term.
* @return The append response builder
* @throws IllegalArgumentException if {@code term} is not positive
*/
public Builder withTerm(long term) {
response.term = Assert.argNot(term, term <= 0, "term must be positive");
return this;
}
/**
* Sets whether the request succeeded.
*
* @param succeeded Whether the append request succeeded.
* @return The append response builder.
*/
public Builder withSucceeded(boolean succeeded) {
response.succeeded = succeeded;
return this;
}
/**
* Sets the last index of the replica's log.
*
* @param index The last index of the replica's log.
* @return The append response builder.
* @throws IllegalArgumentException if {@code index} is negative
*/
public Builder withLogIndex(long index) {
response.logIndex = Assert.argNot(index, index < 0, "term must not be negative");
return this;
}
/**
* @throws IllegalStateException if status is ok and term is not positive or log index is negative
*/
@Override
public AppendResponse build() {
super.build();
if (response.status == Response.Status.OK) {
Assert.stateNot(response.term <= 0, "term must be positive");
Assert.stateNot(response.logIndex < 0, "log index must be positive");
}
return response;
}
@Override
public int hashCode() {
return Objects.hash(response);
}
@Override
public boolean equals(Object object) {
return object instanceof Builder && ((Builder) object).response.equals(response);
}
@Override
public String toString() {
return String.format("%s[response=%s]", getClass().getCanonicalName(), response);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy