io.nats.streaming.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.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();
}