All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.micronaut.configuration.kafka.KafkaMessage Maven / Gradle / Ivy

/*
 * Copyright 2017-2021 original authors
 *
 * Licensed 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
 *
 * https://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 io.micronaut.configuration.kafka;

import io.micronaut.core.annotation.NonNull;
import io.micronaut.core.annotation.Nullable;

import java.util.Map;

/**
 * Message payload representation.
 *
 * @param  The key type
 * @param  The value type
 * @author Denis Stepanov
 * @since 4.1.0
 */
public final class KafkaMessage {

    private final String topic;
    private final K key;
    private final V body;
    private final Integer partition;
    private final Long timestamp;
    private final Map headers;

    /**
     * The default constructor.
     *
     * @param topic     The topic
     * @param key       The key
     * @param body      The body
     * @param partition The partition
     * @param timestamp The timestamp
     * @param headers   The headers
     */
    public KafkaMessage(@Nullable String topic, @Nullable K key, @Nullable V body, @Nullable Integer partition,
                        @Nullable Long timestamp, @Nullable Map headers) {
        this.topic = topic;
        this.key = key;
        this.body = body;
        this.partition = partition;
        this.timestamp = timestamp;
        this.headers = headers;
    }

    @Nullable
    public String getTopic() {
        return topic;
    }

    @Nullable
    public K getKey() {
        return key;
    }

    @Nullable
    public V getBody() {
        return body;
    }

    @Nullable
    public Integer getPartition() {
        return partition;
    }

    @Nullable
    public Long getTimestamp() {
        return timestamp;
    }

    @Nullable
    public Map getHeaders() {
        return headers;
    }

    /**
     * The message builder.
     * @param  The key type
     * @param  The value type
     */
    public static final class Builder {
        private String topic;
        private K key;
        private V body;
        private Integer partition;
        private Long timestamp;
        private Map headers;

        @NonNull
        public static  Builder withBody(@Nullable F body) {
            Builder builder = new Builder<>();
            builder.body = body;
            return builder;
        }

        @NonNull
        public static  Builder withoutBody() {
            Builder builder = new Builder<>();
            return builder;
        }

        @NonNull
        public Builder topic(@Nullable String topic) {
            this.topic = topic;
            return this;
        }

        @NonNull
        public Builder key(@Nullable K key) {
            this.key = key;
            return this;
        }

        @NonNull
        public Builder body(@Nullable V body) {
            this.body = body;
            return this;
        }

        @NonNull
        public Builder header(@Nullable Map headers) {
            this.headers = headers;
            return this;
        }

        @NonNull
        public Builder partition(@Nullable Integer partition) {
            this.partition = partition;
            return this;
        }

        @NonNull
        public Builder timestamp(@Nullable Long timestamp) {
            this.timestamp = timestamp;
            return this;
        }

        @NonNull
        public KafkaMessage build() {
            return new KafkaMessage(topic, key, body, partition, timestamp, headers);
        }
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy