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

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

There is a newer version: 2.2.3
Show newest version
// 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.streaming;

import java.io.IOException;

/**
 * A client uses a {@code Subscription} object to receive messages that have been published to a
 * subject.
 *
 * 

Each {@code Subscription} object is unique, even if the subscription is to the same subject. * This means that if {@code StreamingConnection.subscribe("foo", cb)} is called twice in a row, * each of the * resulting {@code Subscription} objects will be unique, and any message delivered on subject "foo" * will be delivered individually to both {@code Subscription} objects. */ public interface Subscription extends AutoCloseable { /** * Retrieves the subject of interest from the {@code Subscription} object. * * @return the subject of interest */ String getSubject(); /** * Returns the optional queue group name. If present, all subscriptions with the same name will * form a distributed queue, and each message will only be processed by one member of the group. * * @return the name of the queue group this Subscription belongs to. */ String getQueue(); /** * Removes interest in the {@code Subscription}. * *

For durables, it means that the durable interest is also removed from the server. * Restarting a durable with the same name will not resume the subscription, it will be * considered a new one. * *

This call is equivalent to {@code close(true)} * * @throws IOException if an error occurs while notifying the server */ void unsubscribe() throws IOException; /** * Removes this subscriber from the server without removing durable interest (if it exists). * *

This call is equivalent to {@code close(false)} * * @throws IOException if the close request times out or the client is connected to a server * for which this features is not available. * @see java.lang.AutoCloseable#close() */ void close() throws IOException; /** * Removes this subscriber from the server. * * @param unsubscribe if {@code true}, durable interest is also removed. * @throws IOException if the close request times out or the client is connected to a server * for which this features is not available. */ void close(boolean unsubscribe) throws IOException; /** * Returns the {@code SubscriptionOptions} object for this {@code Subscription} object. * * @return this {@code Subscription}'s code SubscriptionOptions} object. * @see io.nats.streaming.SubscriptionOptions */ SubscriptionOptions getOptions(); /** * @return the inbox used by this subscription for acks. */ String getAckInbox(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy