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

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

/*******************************************************************************
 * Copyright (c) 2015-2016 Apcera Inc. All rights reserved. This program and the accompanying
 * materials are made available under the terms of the MIT License (MIT) which accompanies this
 * distribution, and is available at http://opensource.org/licenses/MIT
 *******************************************************************************/

package io.nats.stan;

import java.io.IOException;
import java.util.concurrent.TimeoutException;

/**
 * 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 Connection.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} object's subject immediately. * * @throws IOException if an error occurs while notifying the server * @throws TimeoutException if the unsubscribe request times out without a response */ void unsubscribe() throws IOException, TimeoutException; /** * Removes interest in the {@code Subscription}'s subject immediately. * * @see io.nats.client.Subscription#close() * @see java.lang.AutoCloseable#close() */ void close(); /** * Returns the {@code SubscriptionOptions} object for this {@code Subscription} object. * * @return this {@code Subscription}'s code SubscriptionOptions} object. * @see io.nats.stan.SubscriptionOptions */ SubscriptionOptions getOptions(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy