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

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

// Copyright 2015-2018 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 java.time.Duration;

/**
 * A Subscription encapsulates an incoming queue of messages associated with a single
 * subject and optional queue name. Subscriptions can be in one of two modes. Either the
 * subscription can be used for synchronous reading of messages with {@link #nextMessage(Duration) nextMessage()}
 * or the subscription can be owned by a Dispatcher. When a subscription is owned by a dispatcher
 * it cannot be used to get messages or unsubscribe, those operations must be performed on the dispatcher.
 * 
 * 

Subscriptions support the concept of auto-unsubscribe. This concept is a bit tricky, as it involves * the client library, the server and the Subscriptions history. If told to unsubscribe after 5 messages, a subscription * will stop receiving messages when one of the following occurs: *

    *
  • The subscription delivers 5 messages with next messages, including any previous messages. *
  • The server sends 5 messages to the subscription. *
  • The subscription already received 5 or more messages. *
*

In the case of a reconnect, the remaining message count, as maintained by the subscription, will be sent * to the server. So if you unsubscribe with a max of 5, then disconnect after 2, the new server will be told to * unsubscribe after 3. *

The other, possibly confusing case, is that unsubscribe is based on total messages. So if you make a subscription and * receive 5 messages on it, then say unsubscribe with a maximum of 5, the subscription will immediately stop handling messages. */ public interface Subscription extends Consumer { /** * @return the subject associated with this subscription, will be non-null */ String getSubject(); /** * @return the queue associated with this subscription, may be null. */ String getQueueName(); /** * @return the Dispatcher that owns this subscription, or null */ Dispatcher getDispatcher(); /** * Read the next message for a subscription, or block until one is available. * While useful in some situations, i.e. tests and simple examples, using a * Dispatcher is generally easier and likely preferred for application code. * *

Will return null if the calls times out. * *

Use a timeout of 0 to wait indefinitely. This could still be interrupted if * the subscription is unsubscribed or the client connection is closed. * * * @param timeout the maximum time to wait * @return the next message for this subscriber or null if there is a timeout * @throws IllegalStateException if the subscription belongs to a dispatcher, or is not active * @throws InterruptedException if one occurs while waiting for the message */ Message nextMessage(Duration timeout) throws InterruptedException, IllegalStateException; /** * Read the next message for a subscription, or block until one is available. * While useful in some situations, i.e. tests and simple examples, using a * Dispatcher is generally easier and likely preferred for application code. * *

Will return null if the calls times out. * *

Use a timeout of 0 to wait indefinitely. This could still be interrupted if * the subscription is unsubscribed or the client connection is closed. * * * @param timeoutMillis the maximum time to wait in millis * @return the next message for this subscriber or null if there is a timeout * @throws IllegalStateException if the subscription belongs to a dispatcher, or is not active * @throws InterruptedException if one occurs while waiting for the message */ Message nextMessage(long timeoutMillis) throws InterruptedException, IllegalStateException; /** * Unsubscribe this subscription and stop listening for messages. * *

Stops messages to the subscription locally and notifies the server. * * @throws IllegalStateException if the subscription belongs to a dispatcher, or is not active */ void unsubscribe(); /** * Unsubscribe this subscription and stop listening for messages, after the * specified number of messages. * *

If the subscription has already received after messages, it will not receive * more. The provided limit is a lifetime total for the subscription, with the caveat * that if the subscription already received more than after when unsubscribe is called * the client will not travel back in time to stop them. * *

Supports chaining so that you can do things like: *

     * nc = Nats.connect()
     * m = nc.subscribe("hello").unsubscribe(1).nextMessage(Duration.ZERO);
     * 
* * @param after the number of messages to accept before unsubscribing * @return the subscription so that calls can be chained * @throws IllegalStateException if the subscription belongs to a dispatcher, or is not active */ Subscription unsubscribe(int after); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy