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

com.rabbitmq.stream.MessageHandler Maven / Gradle / Ivy

Go to download

The RabbitMQ Stream Java client library allows Java applications to interface with RabbitMQ Stream.

The newest version!
// Copyright (c) 2020-2023 Broadcom. All Rights Reserved.
// The term "Broadcom" refers to Broadcom Inc. and/or its subsidiaries.
//
// This software, the RabbitMQ Stream Java client library, is dual-licensed under the
// Mozilla Public License 2.0 ("MPL"), and the Apache License version 2 ("ASL").
// For the MPL, please see LICENSE-MPL-RabbitMQ. For the ASL,
// please see LICENSE-APACHE2.
//
// This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND,
// either express or implied. See the LICENSE file for specific language governing
// rights and limitations of this software.
//
// If you have any questions regarding licensing, please contact us at
// [email protected].
package com.rabbitmq.stream;

/**
 * Callback API for inbound messages.
 *
 * @see ConsumerBuilder#messageHandler(MessageHandler)
 * @see Consumer
 */
public interface MessageHandler {

  /**
   * Callback for an inbound message.
   *
   * @param context context on the message
   * @param message the message
   */
  void handle(Context context, Message message);

  /** Information about the message. */
  interface Context {

    /**
     * The offset of the message in the stream.
     *
     * @return the offset of the current message
     */
    long offset();

    /**
     * Shortcut to send a store order for the message offset.
     *
     * @see Consumer#store(long)
     */
    void storeOffset();

    /**
     * The timestamp of the message chunk.
     *
     * @return the timestamp of the message chunk
     */
    long timestamp();

    /**
     * The ID (offset) of the committed chunk (block of messages) in the stream.
     *
     * 

It is the offset of the first message in the last chunk confirmed by a quorum of the * stream cluster members (leader and replicas). * *

The committed chunk ID is a good indication of what the last offset of a stream can be at * a given time. The value can be stale as soon as the application reads it though, as the * committed chunk ID for a stream that is published to changes all the time. * *

This requires RabbitMQ 3.11 or more. The method always returns 0 otherwise. * * @return committed chunk ID in this stream * @see StreamStats#committedChunkId() */ long committedChunkId(); /** * The stream the message comes from. * * @return the stream the message comes from */ String stream(); /** * The consumer that receives the message. * * @return the consumer instance * @see Consumer#store(long) */ Consumer consumer(); /** * Mark the message as processed, potentially asking for more messages from the broker. * *

The exact behavior depends on the {@link ConsumerFlowStrategy} chosen when creating the * consumer with {@link ConsumerBuilder#flow()}. * *

The call is a no-op for strategies like {@link * ConsumerFlowStrategy#creditOnChunkArrival()} and {@link * ConsumerFlowStrategy#creditOnChunkArrival(int)}. * *

Calling this method for each message is mandatory for strategies like {@link * ConsumerFlowStrategy#creditWhenHalfMessagesProcessed()}, {@link * ConsumerFlowStrategy#creditWhenHalfMessagesProcessed(int)}, and {@link * ConsumerFlowStrategy#creditOnProcessedMessageCount(int, double)}, otherwise the broker may * stop sending messages to the consumer. * *

Applications should make sure to call processed() only once on each context, * as this method does not have to be idempotent. What several calls on the same context does * depends on the underlying {@link ConsumerFlowStrategy} implementation. */ void processed(); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy