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

io.nats.client.JetStreamSubscription Maven / Gradle / Ivy

// Copyright 2020 The NATS 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:
//
// http://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.nats.client;

import io.nats.client.api.ConsumerInfo;

import java.io.IOException;
import java.time.Duration;
import java.util.Iterator;
import java.util.List;

/**
 * Subscription on a JetStream context.
 */
public interface JetStreamSubscription extends Subscription {

    /**
     * Gets the consumer name associated with the subscription.
     * @return the consumer name
     */
    String getConsumerName();

    /**
     * Initiate pull with the specified batch size.
     * ! Pull subscriptions only. Push subscription will throw IllegalStateException
     * ! Primitive API for ADVANCED use only, officially not supported. Prefer fetch, iterate or reader.
     *
     * @param batchSize the size of the batch
     * @throws IllegalStateException if not a pull subscription.
     */
    void pull(int batchSize);

    /**
     * Initiate pull with the specified request options
     * ! Pull subscriptions only. Push subscription will throw IllegalStateException
     * ! Primitive API for ADVANCED use only, officially not supported. Prefer fetch, iterate or reader.
     *
     * @param pullRequestOptions the options object
     * @throws IllegalStateException if not a pull subscription.
     */
    void pull(PullRequestOptions pullRequestOptions);

    /**
     * Initiate pull in noWait mode with the specified batch size.
     *
     * ! Pull subscriptions only. Push subscription will throw IllegalStateException
     * ! Primitive API for ADVANCED use only, officially not supported. Prefer fetch, iterate or reader.
     *
     * @param batchSize the size of the batch
     * @throws IllegalStateException if not a pull subscription.
     */
    void pullNoWait(int batchSize);

    /**
     * Initiate pull in noWait mode with the specified batch size.
     * ! Pull subscriptions only. Push subscription will throw IllegalStateException
     * ! Primitive API for ADVANCED use only, officially not supported. Prefer fetch, iterate or reader.
     *
     * @param batchSize the size of the batch
     * @param expiresIn how long from now this request should be expired from the server wait list
     * @throws IllegalStateException if not a pull subscription.
     */
    void pullNoWait(int batchSize, Duration expiresIn);

    /**
     * Initiate pull in noWait mode with the specified batch size.
     * ! Pull subscriptions only. Push subscription will throw IllegalStateException
     * ! Primitive API for ADVANCED use only, officially not supported. Prefer fetch, iterate or reader.
     *
     * @param batchSize the size of the batch
     * @param expiresInMillis how long from now this request should be expired from the server wait list, in milliseconds
     * @throws IllegalStateException if not a pull subscription.
     */
    void pullNoWait(int batchSize, long expiresInMillis);

    /**
     * Initiate pull for all messages available before expiration.
     * 

* sub.nextMessage(timeout) can return a: *

    *
  • regular JetStream message *
  • null *
*

* ! Pull subscriptions only. Push subscription will throw IllegalStateException * ! Primitive API for ADVANCED use only, officially not supported. Prefer fetch, iterate or reader. * * @param batchSize the size of the batch * @param expiresIn how long from now this request should be expired from the server wait list * @throws IllegalStateException if not a pull subscription. */ void pullExpiresIn(int batchSize, Duration expiresIn); /** * Initiate pull for all messages available before expiration. * This can only be used when the subscription is pull based. *

* sub.nextMessage(timeout) can return a: *

    *
  • regular JetStream message *
  • null *
*

* ! Pull subscriptions only. Push subscription will throw IllegalStateException * ! Primitive API for ADVANCED use only, officially not supported. Prefer fetch, iterate or reader. * * @param batchSize the size of the batch * @param expiresInMillis how long from now this request should be expired from the server wait list, in milliseconds * @throws IllegalStateException if not a pull subscription. */ void pullExpiresIn(int batchSize, long expiresInMillis); /** * Fetch a list of messages up to the batch size, waiting no longer than maxWait. * This uses pullExpiresIn under the covers, and manages all responses * from sub.nextMessage(...) to only return regular JetStream messages. * This can only be used when the subscription is pull based. * ! Pull subscriptions only. Push subscription will throw IllegalStateException * * @param batchSize the size of the batch * @param maxWait the maximum time to wait for the first message. * * @return the list of messages * @throws IllegalStateException if not a pull subscription. */ List fetch(int batchSize, Duration maxWait); /** * Fetch a list of messages up to the batch size, waiting no longer than maxWait. * This uses pullExpiresIn under the covers, and manages all responses * from sub.nextMessage(...) to only return regular JetStream messages. * This can only be used when the subscription is pull based. * ! Pull subscriptions only. Push subscription will throw IllegalStateException * * @param batchSize the size of the batch * @param maxWaitMillis the maximum time to wait for the first message, in milliseconds. * * @return the list of messages * @throws IllegalStateException if not a pull subscription. */ List fetch(int batchSize, long maxWaitMillis); /** * Prepares an iterator. This uses pullExpiresIn under the covers, * and manages all responses. The iterator will have no messages if it does not * receive the first message within the max wait period. It will stop if the batch is * fulfilled or if there are fewer than batch size messages. 408 Status messages * are ignored and will not count toward the fulfilled batch size. * ! Pull subscriptions only. Push subscription will throw IllegalStateException * * @param batchSize the size of the batch * @param maxWait the maximum time to wait for the first message. * * @return the message iterator * @throws IllegalStateException if not a pull subscription. */ Iterator iterate(int batchSize, Duration maxWait); /** * Prepares an iterator. This uses pullExpiresIn under the covers, * and manages all responses. The iterator will have no messages if it does not * receive the first message within the max wait period. It will stop if the batch is * fulfilled or if there are fewer than batch size messages. 408 Status messages * are ignored and will not count toward the fulfilled batch size. * ! Pull subscriptions only. Push subscription will throw IllegalStateException * * @param batchSize the size of the batch * @param maxWaitMillis the maximum time to wait for the first message, in milliseconds. * * @return the message iterator * @throws IllegalStateException if not a pull subscription. */ Iterator iterate(int batchSize, long maxWaitMillis); /** * Prepares a reader. A reader looks like a push sync subscription, * meaning it is just an endless stream of messages to ask for by nextMessage, * but uses pull under the covers. * ! Pull subscriptions only. Push subscription will throw IllegalStateException * * @param batchSize the size of the batch * @param repullAt the point in the current batch to tell the server to start the next batch * * @return the message iterator * @throws IllegalStateException if not a pull subscription. */ JetStreamReader reader(int batchSize, int repullAt); /** * Gets information about the consumer behind this subscription. * @return consumer information * @throws IOException covers various communication issues with the NATS * server such as timeout or interruption * @throws JetStreamApiException the request had an error related to the data */ ConsumerInfo getConsumerInfo() throws IOException, JetStreamApiException; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy