Copyright © TIBCO Software Inc. All Rights Reserved
Copyright © TIBCO Software Inc. All Rights Reserved


Chapter 9 Session : tibemsSession : tibemsSession_CreateDurableSubscriber

tibemsSession_CreateDurableSubscriber
Function
Purpose
Create a durable topic subscriber.
C Declaration
tibems_status tibemsSession_CreateDurableSubscriber(
    tibemsSession session,
    tibemsMsgConsumer* msgConsumer,
    tibemsTopic topic,
    const char* name,
    const char* messageSelector,
    tibems_bool noLocal );
COBOL Call
CALL "tibemsSession_CreateDurableSubscriber"
USING BY VALUE session,
BY REFERENCE msgConsumer,
BY VALUE topic,
BY REFERENCE name,
BY REFERENCE messageSelector,
BY VALUE noLocal,
RETURNING tibems-status
END-CALL.
 
session, msgConsumer, and topic have usage pointer.
Parameters
 
When true, the server filters messages so the subscriber does not receive messages that originate locally—that is, messages sent through the same connection.
When false, the consumer receives messages with local origin.
Remarks
The server associates a durable subscription with at most one subscriber object at a time. When a subscriber object exists, the subscription is active, and the server delivers messages to it; when no subscriber object exists, the subscription is inactive.
Durable subscriptions guarantee message delivery across periods during which the subscriber is inactive. The server retains unacknowledged messages until the subscriber acknowledges them, or until the messages expire.
Subscription Continuity
Continuity across inactive periods uses two data items from the client:
Subscription Name  a parameter of this call
Client ID  an optional property of the tibemsConnection (used only when supplied)
 
 
The server uses one or both of these two items to match a subscriber object with its subscription. If a matching subscription exists, and it is inactive, then the server associates it with the subscriber (and the subscription becomes active). The server delivers unacknowledged messages to the subscriber.
If a matching subscription exists, but it is already active, this function fails with TIBEMS_INVALID_CONSUMER.
If a matching subscription to the topic does not yet exist, the server creates one.
Matching Client ID
If the tibemsConnection’s client ID is non-null when a session creates a durable subscription, then only sessions of a connection with the same client ID can attach to that subscription.
If the tibemsConnection’s client ID is null when a session creates a durable subscription, then any session can attach to that subscription (to receive its messages).
Changing Topic or Selector
Notice that the server does not use the topic and message selector arguments to match a subscriber to an existing subscription. As a result, client programs can change a subscription by altering either or both of these arguments. The effect is equivalent to deleting the existing subscription (from the server) and creating a new one (albeit with the same client ID and subscription name).
See Also
tibemsTopic on page 158
tibemsMsgConsumer on page 164
tibemsConnection on page 210

Copyright © TIBCO Software Inc. All Rights Reserved
Copyright © TIBCO Software Inc. All Rights Reserved