
org.apache.ignite.internal.raft.RaftGroupConfigurationSerializer Maven / Gradle / Ivy
The newest version!
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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 org.apache.ignite.internal.raft;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import org.apache.ignite.internal.util.io.IgniteDataInput;
import org.apache.ignite.internal.util.io.IgniteDataOutput;
import org.apache.ignite.internal.versioned.VersionedSerializer;
import org.jetbrains.annotations.Nullable;
/**
* {@link VersionedSerializer} for {@link RaftGroupConfiguration} instances.
*/
public class RaftGroupConfigurationSerializer extends VersionedSerializer {
/** Serializer instance. */
public static final RaftGroupConfigurationSerializer INSTANCE = new RaftGroupConfigurationSerializer();
@Override
protected void writeExternalData(RaftGroupConfiguration config, IgniteDataOutput out) throws IOException {
writeStringList(config.peers(), out);
writeStringList(config.learners(), out);
writeNullableStringList(config.oldPeers(), out);
writeNullableStringList(config.oldLearners(), out);
}
private static void writeStringList(List strings, IgniteDataOutput out) throws IOException {
out.writeVarInt(strings.size());
for (String str : strings) {
out.writeUTF(str);
}
}
private static void writeNullableStringList(@Nullable List strings, IgniteDataOutput out) throws IOException {
if (strings == null) {
out.writeVarInt(-1);
} else {
writeStringList(strings, out);
}
}
@Override
protected RaftGroupConfiguration readExternalData(byte protoVer, IgniteDataInput in) throws IOException {
List peers = readStringList(in);
List learners = readStringList(in);
List oldPeers = readNullableStringList(in);
List oldLearners = readNullableStringList(in);
return new RaftGroupConfiguration(peers, learners, oldPeers, oldLearners);
}
private static List readStringList(IgniteDataInput in) throws IOException {
int length = in.readVarIntAsInt();
return readStringList(length, in);
}
private static List readStringList(int length, IgniteDataInput in) throws IOException {
assert length >= 0 : "Invalid length: " + length;
var list = new ArrayList();
for (int i = 0; i < length; i++) {
list.add(in.readUTF());
}
return list;
}
private static @Nullable List readNullableStringList(IgniteDataInput in) throws IOException {
int lengthOrMinusOne = in.readVarIntAsInt();
if (lengthOrMinusOne == -1) {
return null;
}
return readStringList(lengthOrMinusOne, in);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy