package io.vertx.reactivex.kafka.client.consumer;
import io.vertx.reactivex.RxHelper;
import io.vertx.reactivex.ObservableHelper;
import io.vertx.reactivex.FlowableHelper;
import io.vertx.reactivex.impl.AsyncResultMaybe;
import io.vertx.reactivex.impl.AsyncResultSingle;
import io.vertx.reactivex.impl.AsyncResultCompletable;
import io.vertx.reactivex.WriteStreamObserver;
import io.vertx.reactivex.WriteStreamSubscriber;
import java.util.Map;
import java.util.Set;
import java.util.List;
import java.util.Iterator;
import java.util.function.Function;
import java.util.stream.Collectors;
import io.vertx.core.Handler;
import io.vertx.core.AsyncResult;
import io.vertx.core.json.JsonObject;
import io.vertx.core.json.JsonArray;
import io.vertx.lang.rx.RxGen;
import io.vertx.lang.rx.TypeArg;
import io.vertx.lang.rx.MappingIterator;
@RxGen(io.vertx.kafka.client.consumer.KafkaConsumerRecord.class)
public class KafkaConsumerRecord<K,V> {
@Override
public String toString() {
return delegate.toString();
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
KafkaConsumerRecord that = (KafkaConsumerRecord) o;
return delegate.equals(that.delegate);
}
@Override
public int hashCode() {
return delegate.hashCode();
}
public static final TypeArg<KafkaConsumerRecord> __TYPE_ARG = new TypeArg<>( obj -> new KafkaConsumerRecord((io.vertx.kafka.client.consumer.KafkaConsumerRecord) obj),
KafkaConsumerRecord::getDelegate
);
private final io.vertx.kafka.client.consumer.KafkaConsumerRecord<K,V> delegate;
public final TypeArg<K> __typeArg_0;
public final TypeArg<V> __typeArg_1;
public KafkaConsumerRecord(io.vertx.kafka.client.consumer.KafkaConsumerRecord delegate) {
this.delegate = delegate;
this.__typeArg_0 = TypeArg.unknown(); this.__typeArg_1 = TypeArg.unknown(); }
public KafkaConsumerRecord(Object delegate, TypeArg<K> typeArg_0, TypeArg<V> typeArg_1) {
this.delegate = (io.vertx.kafka.client.consumer.KafkaConsumerRecord)delegate;
this.__typeArg_0 = typeArg_0;
this.__typeArg_1 = typeArg_1;
}
public io.vertx.kafka.client.consumer.KafkaConsumerRecord getDelegate() {
return delegate;
}
private static final TypeArg<io.vertx.reactivex.kafka.client.producer.KafkaHeader> TYPE_ARG_0 = new TypeArg<io.vertx.reactivex.kafka.client.producer.KafkaHeader>(o1 -> io.vertx.reactivex.kafka.client.producer.KafkaHeader.newInstance((io.vertx.kafka.client.producer.KafkaHeader)o1), o1 -> o1.getDelegate());
public String topic() {
String ret = delegate.topic();
return ret;
}
public int partition() {
int ret = delegate.partition();
return ret;
}
public long offset() {
long ret = delegate.offset();
return ret;
}
public long timestamp() {
long ret = delegate.timestamp();
return ret;
}
public org.apache.kafka.common.record.TimestampType timestampType() {
org.apache.kafka.common.record.TimestampType ret = delegate.timestampType();
return ret;
}
@Deprecated()
public long checksum() {
long ret = delegate.checksum();
return ret;
}
public K key() {
K ret = (K)__typeArg_0.wrap(delegate.key());
return ret;
}
public V value() {
V ret = (V)__typeArg_1.wrap(delegate.value());
return ret;
}
public List<io.vertx.reactivex.kafka.client.producer.KafkaHeader> () {
List<io.vertx.reactivex.kafka.client.producer.KafkaHeader> ret = delegate.headers().stream().map(elt -> io.vertx.reactivex.kafka.client.producer.KafkaHeader.newInstance((io.vertx.kafka.client.producer.KafkaHeader)elt)).collect(Collectors.toList());
return ret;
}
public static <K,V> KafkaConsumerRecord<K,V> newInstance(io.vertx.kafka.client.consumer.KafkaConsumerRecord arg) {
return arg != null ? new KafkaConsumerRecord<K,V>(arg) : null;
}
public static <K,V> KafkaConsumerRecord<K,V> newInstance(io.vertx.kafka.client.consumer.KafkaConsumerRecord arg, TypeArg<K> __typeArg_K, TypeArg<V> __typeArg_V) {
return arg != null ? new KafkaConsumerRecord<K,V>(arg, __typeArg_K, __typeArg_V) : null;
}
}