
io.dropwizard.kafka.serializer.StringSerializerFactory Maven / Gradle / Ivy
package io.dropwizard.kafka.serializer;
import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.annotation.JsonTypeName;
import io.dropwizard.validation.ValidationMethod;
import org.apache.kafka.clients.producer.ProducerConfig;
import org.apache.kafka.common.serialization.Serializer;
import org.apache.kafka.common.serialization.StringSerializer;
import java.nio.charset.Charset;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;
import javax.validation.constraints.NotNull;
@JsonTypeName("string")
public class StringSerializerFactory extends SerializerFactory {
@NotNull
@JsonProperty
private String encoding = "UTF8";
public String getEncoding() {
return encoding;
}
public void setEncoding(final String encoding) {
this.encoding = encoding;
}
@JsonIgnore
@ValidationMethod(message = "Invalid charset used for StringSerializerFactory")
public boolean isEncodingValid() {
return Charset.isSupported(encoding);
}
@Override
public Class extends Serializer> getSerializerClass() {
return StringSerializer.class;
}
@Override
public Map build(final boolean isKey) {
final String serializerPropertyName = isKey ?
ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG : ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG;
final String encodingPropertyName = isKey ? "key.serializer.encoding" : "value.serializer.encoding";
final Map config = new HashMap<>();
config.put(serializerPropertyName, getSerializerClass());
config.put(encodingPropertyName, encoding);
return Collections.unmodifiableMap(config);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy