com.github.ddth.kafka.KafkaMessage Maven / Gradle / Ivy
package com.github.ddth.kafka;
import java.io.Serializable;
import java.nio.charset.Charset;
import org.apache.commons.lang3.builder.EqualsBuilder;
import org.apache.commons.lang3.builder.HashCodeBuilder;
import org.apache.commons.lang3.builder.ToStringBuilder;
import org.apache.kafka.clients.consumer.ConsumerRecord;
/**
* Represents a Kafka message.
*
* @author Thanh Ba Nguyen
* @since 1.0.0
*/
public class KafkaMessage implements Serializable {
private static final long serialVersionUID = 1L;
public static Charset utf8 = Charset.forName("UTF-8");
private String topic, key;
private byte[] content;
private int partition;
private long offset;
public KafkaMessage() {
}
public KafkaMessage(String topic, byte[] content) {
topic(topic);
content(content);
}
public KafkaMessage(String topic, String key, byte[] content) {
topic(topic);
key(key);
content(content);
}
public KafkaMessage(String topic, byte[] key, byte[] content) {
topic(topic);
key(key);
content(content);
}
public KafkaMessage(String topic, String content) {
topic(topic);
content(content);
}
public KafkaMessage(String topic, String key, String content) {
topic(topic);
key(key);
content(content);
}
public KafkaMessage(String topic, byte[] key, String content) {
topic(topic);
key(key);
content(content);
}
/**
* Constructs a new {@link KafkaMessage} from a {@link ConsumerRecord}.
*
* @param cr
* @since 1.2.0
*/
public KafkaMessage(ConsumerRecord cr) {
topic(cr.topic());
key(cr.key());
content(cr.value());
partition(cr.partition());
offset(cr.offset());
}
/**
* Constructs a new {@link KafkaMessage} from another {@link KafkaMessage}.
*
* @param another
*/
public KafkaMessage(KafkaMessage another) {
topic(another.topic());
key(another.key());
content(another.content());
partition(another.partition());
offset(another.offset());
}
public String topic() {
return topic;
}
public KafkaMessage topic(String value) {
this.topic = value;
return this;
}
public String key() {
return key;
}
public KafkaMessage key(byte[] value) {
this.key = value != null ? new String(value, utf8) : null;
return this;
}
public KafkaMessage key(String value) {
this.key = value;
return this;
}
public byte[] content() {
return content;
}
public KafkaMessage content(byte[] value) {
this.content = value;
return this;
}
public KafkaMessage content(String value) {
this.content = value != null ? value.getBytes(utf8) : null;
return this;
}
public String contentAsString() {
return content != null ? new String(content, utf8) : null;
}
public KafkaMessage partition(int value) {
this.partition = value;
return this;
}
public int partition() {
return partition;
}
public KafkaMessage offset(long value) {
this.offset = value;
return this;
}
public long offset() {
return offset;
}
/*----------------------------------------------------------------------*/
/**
* {@inheritDoc}
*/
@Override
public String toString() {
ToStringBuilder tsb = new ToStringBuilder(this);
tsb.append("topic", topic);
tsb.append("key", key);
tsb.append("content", content);
tsb.append("partition", partition);
tsb.append("offset", offset);
return tsb.build();
}
/**
* {@inheritDoc}
*/
@Override
public int hashCode() {
HashCodeBuilder hcb = new HashCodeBuilder(19, 81);
hcb.append(topic).append(key).append(content);
return hcb.hashCode();
}
/**
* {@inheritDoc}
*/
@Override
public boolean equals(Object obj) {
if (obj instanceof KafkaMessage) {
KafkaMessage other = (KafkaMessage) obj;
EqualsBuilder eq = new EqualsBuilder();
eq.append(topic, other.topic);
eq.append(key, other.key);
eq.append(content, other.content);
eq.append(partition, other.partition);
eq.append(offset, other.offset);
}
return false;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy