public interface Topics extends TopicUpdate, TopicViews, SessionTrees
Specifically, the feature provides the ability to:
topic update feature
, update topics
with new values;
topic views feature
, manage topic
views.
A session can issue requests to subscribe to topics at any time, even if the
topics do not exist at the server. Each subscription request provides a
topic selector
that is evaluated by the server to
select matching topics. The session will be subscribed to any topics that
match the selector unless they are already subscribed, or the session has
insufficient permission. The subscription request is also retained at the
server and the session will be automatically subscribed to newly created
topics that match the selector (unless a subsequent unsubscription cancels
the request).
Sessions receive notifications from topics that they are subscribed to via subscription streams (see below). When a session is subscribed to a topic, all matching streams will first receive a subscription notification that provides details about the topic. If the server has a value for the topic, the value will be delivered to the streams before any other notifications.
A session can unsubscribe from topics at any time. This is also specified
using a topic selector. On unsubscription, matching streams are notified via
the onUnsubscription
notification. This notification will give the
reason for unsubscription (for example, by request of the session, request of
the server, or topic removal).
Subscriptions and unsubscriptions can occur for reasons other than requests
from the session. A session can be subscribed to or unsubscribed from a topic
by another session using the SubscriptionControl
feature. The removal
of a topic also automatically causes unsubscription for subscribed sessions.
Subscription requests are subject to authorization checks. The session must
have SELECT_TOPIC
permission for the
topic selector used to subscribe. Matching topics will be further filtered to
those for which the session has READ_TOPIC
permission.
A session can listen to subscription events and updates for a selection of topics by adding one or more streams. A stream is registered using a topic selector which specifies the topics that the stream applies to. When an update is received for a topic then it will be routed to every stream that matches both the topic selector and the stream's value type. If more than one stream matches, all will receive the update; the order in which they are notified is not defined.
A stream can be added several times for different selectors. If the same
stream (determined by equals
) is registered for
several selectors that match an event, the stream will only be notified of
the event once. The mapping of topic selectors to streams is maintained
locally in the client process.
It is also possible to add one or more fallback streams which will
receive updates that do not match any stream registered with a selector. This
is useful for default processing or simply to catch unprocessed updates. A
fallback stream can be added using addFallbackStream
. Zero, one, or more fallback streams may be assigned. If
no fallback stream is specified, any updates that are not routed to any other
stream will simply be discarded.
If the session is already subscribed to a topic when a matching stream is added, the stream will immediately receive a subscription notification. For most topic types, the latest value is locally cached and will be provided to the stream following the subscription notification.
A stream will receive an
onClose
callback when unregistered and an
onError(SESSION_CLOSED)
callback if the session is closed.
A ValueStream
receives values for matching topics as and
when updates are received from the server. Delta updates received from the
server are automatically applied to locally cached values so that the stream
always receives full values for each update.
Value streams are typed to a specified value class and only updates for compatible topics will be routed to the stream. The following table shows how the value class maps to compatible topic types that will be routed to the stream:
Value Class | Compatible Topic Types |
---|---|
JSON |
JSON STRING
INT64 DOUBLE
|
String |
STRING |
Long |
INT64 |
Double |
DOUBLE |
Binary |
BINARY |
Bytes |
JSON STRING
INT64 DOUBLE
BINARY RECORD_V2 |
RecordV2 |
RECORD_V2 |
Value stream implementations can be added using
addStream
.
A value stream can be added to received updates from time
series topics
using addTimeSeriesStream
. The following table shows how the value class specified
when adding the stream maps to the event value class of time series topics
that will be routed to the stream:
Event Value Class | Time Series Event Value Class |
---|---|
JSON |
JSON STRING
INT64 DOUBLE
|
String |
STRING |
Long |
INT64 |
Double |
DOUBLE |
Binary |
BINARY |
Bytes |
JSON STRING
INT64 DOUBLE
BINARY RECORD_V2 |
RecordV2 |
RECORD_V2 |
A session can issue a request to fetch details of a topic or topics (subject to authorization) at any time. The topics required are specified using a topic selector.
The results of a fetch will return the topic path and type of each selected topic. The results may also optionally return the topic values and/or properties.
A new request can be created using fetchRequest()
and modified to
specify additional requirements of the fetch operation. The request is issued
to the server using the fetch
method on the request. This will return the results via a
CompletableFuture
.
A session must have SELECT_TOPIC
permission for the path prefix of the topic selector used to
subscribe
or fetch
.
The topics that result from a subscription or fetch request are further
filtered using the READ_TOPIC
permission.
No access control restrictions are applied to
unsubscription
.
This feature can be obtained from a session
as follows:
Topics topics = session.feature(Topics.class);
Modifier and Type | Interface and Description |
---|---|
static interface |
Topics.CompletionCallback
Deprecated.
since 6.7
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead. |
static interface |
Topics.CompletionContextCallback<C>
Deprecated.
since 6.7
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead. |
static interface |
Topics.FetchRequest<V>
A parameterised query that can be used to search the topic tree.
|
static interface |
Topics.FetchResult<V>
Encapsulates the results from a fetch operation issued to the server.
|
static interface |
Topics.SubscriberStream
Base subscriber stream interface.
|
static class |
Topics.UnsubscribeReason
The reason that an unsubscription occurred.
|
static interface |
Topics.ValueStream<V>
Stream interface that can be registered to receive subscription and value
events whenever an update is received from the server.
|
TopicUpdate.FailedPatchException, TopicUpdate.InvalidPatchException, TopicUpdate.JsonPatchResult
SessionTrees.BranchMapping, SessionTrees.BranchMappingTable, SessionTrees.InvalidBranchMappingException
Modifier and Type | Method and Description |
---|---|
<V> void |
addFallbackStream(Class<? extends V> valueClass,
Topics.ValueStream<V> stream)
Add a fallback stream.
|
<V> void |
addStream(String topics,
Class<? extends V> valueClass,
Topics.ValueStream<V> stream)
Add a value stream to receive topic events for topics that match a given
TopicSelector expression and have a value class that matches a
specified type. |
<V> void |
addStream(TopicSelector topics,
Class<? extends V> valueClass,
Topics.ValueStream<V> stream)
Add a value stream to receive topic events for topics that match a given
TopicSelector and have a value class that matches a specified
type. |
<V> void |
addTimeSeriesStream(String topics,
Class<? extends V> eventValueClass,
Topics.ValueStream<TimeSeries.Event<V>> stream)
Add a value stream to receive topic events for time series topics that
match a given
TopicSelector expression and have a compatible time
series value class. |
<V> void |
addTimeSeriesStream(TopicSelector topics,
Class<? extends V> eventValueClass,
Topics.ValueStream<TimeSeries.Event<V>> stream)
Add a value stream to receive topic events for time series topics that
match a given
TopicSelector and have a compatible time series
event value class. |
Topics.FetchRequest<Void> |
fetchRequest()
Creates an unconfigured fetch request.
|
void |
removeStream(Stream stream)
Remove a stream.
|
CompletableFuture<?> |
subscribe(String topics)
Request subscription to topics.
|
<C> void |
subscribe(String topics,
C context,
Topics.CompletionContextCallback<C> callback)
Deprecated.
since 6.7
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead. |
void |
subscribe(String topics,
Topics.CompletionCallback callback)
Deprecated.
since 6.7
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead. |
CompletableFuture<?> |
subscribe(TopicSelector topics)
Request subscription to topics.
|
<C> void |
subscribe(TopicSelector topics,
C context,
Topics.CompletionContextCallback<C> callback)
Deprecated.
since 6.7
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead. |
void |
subscribe(TopicSelector topics,
Topics.CompletionCallback callback)
Deprecated.
since 6.7
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead. |
CompletableFuture<?> |
unsubscribe(String topics)
Unsubscribe from topics.
|
<C> void |
unsubscribe(String topics,
C context,
Topics.CompletionContextCallback<C> callback)
Deprecated.
since 6.7
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead. |
void |
unsubscribe(String topics,
Topics.CompletionCallback callback)
Deprecated.
since 6.7
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead. |
CompletableFuture<?> |
unsubscribe(TopicSelector topics)
Unsubscribe from topics.
|
<C> void |
unsubscribe(TopicSelector topics,
C context,
Topics.CompletionContextCallback<C> callback)
Deprecated.
since 6.7
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead. |
void |
unsubscribe(TopicSelector topics,
Topics.CompletionCallback callback)
Deprecated.
since 6.7
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead. |
addAndSet, addAndSet, applyJsonPatch, applyJsonPatch, createUpdateStream, createUpdateStream, createUpdateStream, createUpdateStream, set, set
createTopicView, getTopicView, listTopicViews, removeTopicView
getBranchMappingTable, listSessionTreeBranchesWithMappings, putBranchMappingTable
getSession
<V> void addStream(TopicSelector topics, Class<? extends V> valueClass, Topics.ValueStream<V> stream)
TopicSelector
and have a value class that matches a specified
type. If the stream matches a time series topic with a compatible time
series event type it will receive onValue events without metadata.
See Topics
class documentation for full details of the use of
value streams.
V
- the value classtopics
- selector of one or more topicsvalueClass
- the class of values that the stream acceptsstream
- the stream to add<V> void addStream(String topics, Class<? extends V> valueClass, Topics.ValueStream<V> stream) throws IllegalArgumentException
TopicSelector
expression and have a value class that matches a
specified type. If the stream matches a time series topic with a
compatible time series event type it will receive onValue events without
metadata.
See Topics
class documentation for full details of the use of
value streams.
V
- the value classtopics
- as a TopicSelector
expressionvalueClass
- the class of values that the stream acceptsstream
- the stream to addIllegalArgumentException
- if topics
is not a valid
selector expression<V> void addFallbackStream(Class<? extends V> valueClass, Topics.ValueStream<V> stream)
See Topics
class documentation for full details regarding the use
of fallback streams.
valueClass
- the class of values that the stream acceptsstream
- the stream to add<V> void addTimeSeriesStream(TopicSelector topics, Class<? extends V> eventValueClass, Topics.ValueStream<TimeSeries.Event<V>> stream)
TopicSelector
and have a compatible time series
event value class.
See the Topics
class documentation for details of the use of
value streams, and the TimeSeries
class documentation for details
of time series topics.
This method must be used instead of
addStream
to add a
ValueStream<TimeSeries.Event<V>>
because there is no way to
express a class literal of type Class<TimeSeries.Event<V>>
. The
stream can be removed with removeStream(com.pushtechnology.diffusion.client.callbacks.Stream)
.
V
- the time series value classtopics
- selector of one or more topicseventValueClass
- The type of event values accepted by this stream.
The registration will match time series topics with a compatible
event value class. See the Topics
class documentation for
details.stream
- the stream to add<V> void addTimeSeriesStream(String topics, Class<? extends V> eventValueClass, Topics.ValueStream<TimeSeries.Event<V>> stream) throws IllegalArgumentException
TopicSelector
expression and have a compatible time
series value class.
See the Topics
class documentation for details of the use of
value streams, and the TimeSeries
class documentation for details
of time series topics.
This method must be used instead of
addStream
to add a
ValueStream<TimeSeries.Event<V>>
because Java has no way to
express a class literal of type Class<TimeSeries.Event<V>>
. The
stream can be removed with removeStream(com.pushtechnology.diffusion.client.callbacks.Stream)
.
V
- the time series value classtopics
- as a TopicSelector
expressioneventValueClass
- The type of event values accepted by this stream.
The registration will match time series topics with a compatible
event value class. See the Topics
class documentation for
details.stream
- the stream to addIllegalArgumentException
- if topics
is not a valid
selector expressionvoid removeStream(Stream stream)
More formally, this method removes all streams that compare equal to
stream
, regardless of the topic selector for which they are
registered. It will also remove any fallback stream equal to
stream
. If there are no such streams, no changes are made.
stream
- the value stream to removeCompletableFuture<?> subscribe(TopicSelector topics)
The session will become subscribed to each existing topic matching the
selector unless the session is already subscribed to the topic, or the
session does not have READ_TOPIC
permission for the topic path. For each topic to which the session
becomes subscribed, a subscription notification and initial value (if
any) will be delivered to registered value streams before the returned
CompletableFuture completes.
The subscription request is also retained at the server and the session will be automatically subscribed to newly created topics that match the selector (unless a subsequent unsubscription cancels the request).
topics
- specifies the topics to request subscription toIf the task completes successfully, the CompletableFuture result will be null. The result type is any rather than Void to provide forward compatibility with future iterations of this API that may provide a non-null result with a more specific result type.
Otherwise, the CompletableFuture will complete exceptionally with
a CompletionException
. Common reasons for failure, listed
by the exception reported as the
cause
, include:
PermissionsException
– if the calling
session does not have SELECT_TOPIC
permission for the
path prefix of the selector expression;
SessionClosedException
– if the session is
closed.
CompletableFuture<?> subscribe(String topics)
This is equivalent to calling subscribe(TopicSelector)
with a
selector parsed using TopicSelectors.parse(String)
.
topics
- specifies the topics to request subscription toIf the task completes successfully, the CompletableFuture result will be null. The result type is any rather than Void to provide forward compatibility with future iterations of this API that may provide a non-null result with a more specific result type.
Otherwise, the CompletableFuture will complete exceptionally with
a CompletionException
. Common reasons for failure, listed
by the exception reported as the
cause
, include:
PermissionsException
– if the calling
session does not have SELECT_TOPIC
permission for the
path prefix of the selector expression;
SessionClosedException
– if the session is
closed.
IllegalArgumentException
- if topics is an invalid topic selector
expressionCompletableFuture<?> unsubscribe(TopicSelector topics)
This can be used at any time whilst connected to reduce the set of topics to which the session is subscribed or negate earlier subscription requests.
topics
- the topics to unsubscribe fromIf the task completes successfully, the CompletableFuture result will be null. The result type is any rather than Void to provide forward compatibility with future iterations of this API that may provide a non-null result with a more specific result type.
Otherwise, the CompletableFuture will complete exceptionally with
a CompletionException
. Common reasons for failure, listed
by the exception reported as the
cause
, include:
SessionClosedException
– if the session is
closed.
CompletableFuture<?> unsubscribe(String topics)
This is equivalent to calling unsubscribe(TopicSelector)
with a
selector parsed using TopicSelectors.parse(String)
.
topics
- the topics to unsubscribe fromIf the task completes successfully, the CompletableFuture result will be null. The result type is any rather than Void to provide forward compatibility with future iterations of this API that may provide a non-null result with a more specific result type.
Otherwise, the CompletableFuture will complete exceptionally with
a CompletionException
. Common reasons for failure, listed
by the exception reported as the
cause
, include:
SessionClosedException
– if the session is
closed.
IllegalArgumentException
- if topics is an invalid topic selector
expression@Deprecated void subscribe(TopicSelector topics, Topics.CompletionCallback callback)
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead.
topics
- specifies the topics to request subscription tocallback
- the callback object to receive status notifications for
this operation@Deprecated void subscribe(String topics, Topics.CompletionCallback callback) throws IllegalArgumentException
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead.
This is equivalent to calling
subscribe(TopicSelector, CompletionCallback)
with a selector
parsed using TopicSelectors.parse(String)
.
topics
- a TopicSelector
expression specifying the topics to
request subscription tocallback
- the callback object to receive status notifications for
this operationIllegalArgumentException
- if topics
is not a valid
selector expression@Deprecated <C> void subscribe(TopicSelector topics, C context, Topics.CompletionContextCallback<C> callback)
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead.
C
- context object typetopics
- specifies the topics to request subscription tocontext
- an object passed to the callback with the reply to allow
requests and replies to be correlated. The caller can use any
convenient object reference, including null
callback
- the callback object to receive status notifications for
this operation@Deprecated <C> void subscribe(String topics, C context, Topics.CompletionContextCallback<C> callback) throws IllegalArgumentException
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead.
This is equivalent to calling
subscribe(TopicSelector, Object, CompletionContextCallback)
with
a selector parsed using TopicSelectors.parse(String)
.
C
- context object typetopics
- a TopicSelector
expression specifying the topics to
request subscription tocontext
- an object passed to the callback with the reply to allow
requests and replies to be correlated. The caller can use any
convenient object reference, including null
callback
- the callback object to receive status notifications for
this operationIllegalArgumentException
- if topics
is not a valid
selector expression@Deprecated void unsubscribe(TopicSelector topics, Topics.CompletionCallback callback)
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead.
This can be used at any time whilst connected to reduce the set of topics to which the session is subscribed or negate earlier subscription requests.
topics
- the topics to unsubscribe fromcallback
- the callback handler for status notifications of this
operation@Deprecated void unsubscribe(String topics, Topics.CompletionCallback callback) throws IllegalArgumentException
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead.
This is equivalent to calling
unsubscribe(TopicSelector, CompletionCallback)
with a selector
parsed using TopicSelectors.parse(String)
.
topics
- the topics to unsubscribe fromcallback
- the callback handler for status notifications of this
operationIllegalArgumentException
- if topics
is not a valid
selector expression@Deprecated <C> void unsubscribe(TopicSelector topics, C context, Topics.CompletionContextCallback<C> callback)
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead.
This can be used at any time whilst connected to reduce the set of topics to which the session is subscribed or negate earlier subscription requests.
C
- context object typetopics
- the topics to unsubscribe fromcontext
- an object passed to the callback with the reply to allow
requests and replies to be correlated. The caller can use any
convenient object reference, including null
callback
- the callback handler for status notifications of this
operation@Deprecated <C> void unsubscribe(String topics, C context, Topics.CompletionContextCallback<C> callback) throws IllegalArgumentException
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead.
This is equivalent to calling
unsubscribe(TopicSelector, Object, CompletionContextCallback)
with a selector parsed using TopicSelectors.parse(String)
.
C
- context object typetopics
- the topics to unsubscribe fromcontext
- an object passed to the callback with the reply to allow
requests and replies to be correlated. The caller can use any
convenient object reference, including null
callback
- the callback handler for status notifications of this
operationIllegalArgumentException
- if topics
is not a valid
selector expressionTopics.FetchRequest<Void> fetchRequest()
The returned request can be invoked with
fetch
. The server will evaluate
the query and return a fetch result that provides the paths and types of
the matching topics which the session has
READ_TOPIC
permission.
You will usually want to restrict the query to a subset of the topic
tree, and to retrieve the topic values and/or properties. This is
achieved by applying one or more of the fluent builder methods provided
by FetchRequest
to produce more refined requests.
For example:
FetchResult result =
topics.fetchRequest().withValues(String.class).fetch("*A/B//").get();
Topics.FetchRequest
Copyright © 2022 Push Technology Ltd. All Rights Reserved.