io.apicurio.registry.serde.DefaultIdHandler Maven / Gradle / Ivy
package io.apicurio.registry.serde;
import io.apicurio.registry.resolver.strategy.ArtifactReference;
import io.apicurio.registry.serde.config.BaseKafkaSerDeConfig;
import io.apicurio.registry.serde.config.IdOption;
import org.apache.kafka.common.errors.SerializationException;
import java.io.IOException;
import java.io.OutputStream;
import java.nio.ByteBuffer;
import java.util.Map;
public class DefaultIdHandler implements IdHandler {
static final int idSize = 8; // we use 8 / long
private IdOption idOption = IdOption.globalId;
@Override
public void configure(Map configs, boolean isKey) {
BaseKafkaSerDeConfig config = new BaseKafkaSerDeConfig(configs);
idOption = config.useIdOption();
}
@Override
public void writeId(ArtifactReference reference, OutputStream out) throws IOException {
long id;
if (idOption == IdOption.contentId) {
if (reference.getContentId() == null) {
throw new SerializationException(
"Missing contentId. IdOption is contentId but there is no contentId in the ArtifactReference");
}
id = reference.getContentId();
} else {
id = reference.getGlobalId();
}
out.write(ByteBuffer.allocate(idSize).putLong(id).array());
}
@Override
public void writeId(ArtifactReference reference, ByteBuffer buffer) {
long id;
if (idOption == IdOption.contentId) {
if (reference.getContentId() == null) {
throw new SerializationException(
"Missing contentId. IdOption is contentId but there is no contentId in the ArtifactReference");
}
id = reference.getContentId();
} else {
id = reference.getGlobalId();
}
buffer.putLong(id);
}
@Override
public ArtifactReference readId(ByteBuffer buffer) {
if (idOption == IdOption.contentId) {
return ArtifactReference.builder().contentId(buffer.getLong()).build();
} else {
return ArtifactReference.builder().globalId(buffer.getLong()).build();
}
}
@Override
public int idSize() {
return idSize;
}
}