public interface ClientControl extends Feature
It allows for notifications of client sessions starting and closing as well as the ability to manage client sessions (forcibly closing them etc).
VIEW_SESSION
permission to be able to
listen for notifications using
setSessionPropertiesListener(SessionPropertiesListener, String...)
or
get properties
of other sessions or listen for
queue events
. In addition
REGISTER_HANDLER
permission is
required to set a session properties listener or queue event handler.
In order to perform operations that change a session's state (such as
conflating, closing the session, or changing roles), both
VIEW_SESSION
and
MODIFY_SESSION
permissions are
required.
session
as follows:
ClientControl clientControl = session.feature(ClientControl.class);
Modifier and Type | Interface and Description |
---|---|
static interface |
ClientControl.ClientCallback
Deprecated.
since 6.7
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead. |
static interface |
ClientControl.ClientContextCallback<C>
Deprecated.
since 6.7
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead. |
static class |
ClientControl.CloseReason
The server's view of why a client session was closed.
|
static interface |
ClientControl.QueueEventHandler
Deprecated.
since 6.7
Use |
static interface |
ClientControl.QueueEventStream
Handler for client queue events.
|
static interface |
ClientControl.SessionFilterOperationResult
Result of ClientControl operations that identify sessions using a client
filter and provide a result through a
CompletableFuture . |
static interface |
ClientControl.SessionPropertiesCallback
Deprecated.
since 6.7
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead. |
static interface |
ClientControl.SessionPropertiesContextCallback<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 |
ClientControl.SessionPropertiesListener
Deprecated.
since 6.7
Use |
static interface |
ClientControl.SessionPropertiesStream
The handler for session properties listener notifications.
|
Modifier and Type | Method and Description |
---|---|
CompletableFuture<?> |
changeRoles(SessionId sessionId,
Set<String> rolesToRemove,
Set<String> rolesToAdd)
Changes the assigned roles of another session.
|
CompletableFuture<Integer> |
changeRoles(String filter,
Set<String> rolesToRemove,
Set<String> rolesToAdd)
Allows a session to change the assigned roles of all sessions that
satisfy a given session filter.
|
CompletableFuture<?> |
close(SessionId sessionId)
Close a client session.
|
<C> void |
close(SessionId sessionId,
C context,
ClientControl.ClientContextCallback<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 |
close(SessionId sessionId,
ClientControl.ClientCallback callback)
Deprecated.
since 6.7
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead. |
CompletableFuture<ClientControl.SessionFilterOperationResult> |
close(String filter)
Close all client sessions matching a given session filter.
|
CompletableFuture<Map<String,String>> |
getSessionProperties(SessionId sessionId,
Collection<String> requiredProperties)
Query the server for property values of a specified client session.
|
<C> void |
getSessionProperties(SessionId sessionId,
Collection<String> requiredProperties,
C context,
ClientControl.SessionPropertiesContextCallback<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 |
getSessionProperties(SessionId sessionId,
Collection<String> requiredProperties,
ClientControl.SessionPropertiesCallback callback)
Deprecated.
since 6.7
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead. |
SessionId |
sessionIdFromString(String sessionIdAsString)
Deprecated.
since 6.7
Use |
CompletableFuture<?> |
setConflated(SessionId sessionId,
boolean conflate)
Control client queue conflation.
|
<C> void |
setConflated(SessionId sessionId,
boolean conflate,
C context,
ClientControl.ClientContextCallback<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 |
setConflated(SessionId sessionId,
boolean conflate,
ClientControl.ClientCallback callback)
Deprecated.
since 6.7
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead. |
CompletableFuture<ClientControl.SessionFilterOperationResult> |
setConflated(String filter,
boolean conflate)
Control client queue conflation.
|
void |
setQueueEventHandler(ClientControl.QueueEventHandler handler)
Deprecated.
since 6.7
The CompletableFuture-based alternative
|
CompletableFuture<Registration> |
setQueueEventHandler(ClientControl.QueueEventStream handler)
Register a handler for client queue threshold events.
|
CompletableFuture<Map<String,String>> |
setSessionProperties(SessionId sessionId,
Map<String,String> properties)
Send a request to the server to change the user-defined session
properties for a session.
|
CompletableFuture<ClientControl.SessionFilterOperationResult> |
setSessionProperties(String filter,
Map<String,String> properties)
Send a request to the server to set all sessions that satisfy a session
filter with the new user-defined session properties.
|
void |
setSessionPropertiesListener(ClientControl.SessionPropertiesListener listener,
String... requiredProperties)
Deprecated.
since 6.7
The CompletableFuture-based alternative
|
CompletableFuture<Registration> |
setSessionPropertiesListener(ClientControl.SessionPropertiesStream listener,
String... requiredProperties)
Register a listener that will be notified when client sessions are
opened, disconnected, reconnected, closed or when selected session
property values are updated.
|
getSession
CompletableFuture<Registration> setSessionPropertiesListener(ClientControl.SessionPropertiesStream listener, String... requiredProperties)
When a listener is first set, it will be called with the required
properties of all currently open client sessions. The amount of data
transferred from the server is proportional to the number of connected
clients and is potentially large. The amount of data can be reduced using
the requiredProperties
parameter.
Each control session can register a single listener. When the listener is
no longer required, it may be closed using the Registration
provided by the CompletableFuture result. To change the listener, the
previous listener must first be closed.
The requiredProperties
parameter is used to select the property
values required.
The requested property set controls the level of detail provided and whether the listener is called for updates to sessions. If no properties are requested, the listener is not called when session properties are updated.
listener
- the listener to be called with session notificationsrequiredProperties
- a list of required property keys. See
Session
for a full list of available fixed property keys.
To request no properties supply an empty list. To request all
fixed properties include Session.ALL_FIXED_PROPERTIES
as a
key. In this case any other fixed property keys would be ignored.
To request all user properties include
Session.ALL_USER_PROPERTIES
as a key. In this case any
other user properties are ignored.Registration
which can be used to
unregister the listener.
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;
HandlerConflictException
– if the session has
already registered a queue event handler;
PermissionsException
– if the session does
not have REGISTER_HANDLER
permission;
PermissionsException
– if the session does
not have VIEW_SESSION
permission.
@Deprecated void setSessionPropertiesListener(ClientControl.SessionPropertiesListener listener, String... requiredProperties)
The CompletableFuture-based alternative
setSessionPropertiesListener(SessionPropertiesStream, String...)
should be preferred since it provides better error reporting.
When a listener is first set, it will be called with the required
properties of all currently open client sessions. The amount of data
transferred from the server is proportional to the number of connected
clients and is potentially large. The amount of data can be reduced using
the requiredProperties
parameter.
Each control session can register a single listener. (See
ServerHandler.onRegistered(Registration)
). A listener
may be closed (using Registration.close()
) if no longer required.
To set a different listener the current listener must first be closed.
The requiredProperties
parameter is used to select the property
values required.
The requested property set controls the level of detail provided and whether the listener is called for updates to sessions. If no properties are requested, the listener is not called when session properties are updated.
listener
- the listener to be called with session notificationsrequiredProperties
- a list of required property keys. See
Session
for a full list of available fixed property keys.
To request no properties supply an empty list. To request all
fixed properties include Session.ALL_FIXED_PROPERTIES
as a
key. In this case any other fixed property keys would be ignored.
To request all user properties include
Session.ALL_USER_PROPERTIES
as a key. In this case any
other user properties are ignored.CompletableFuture<Map<String,String>> getSessionProperties(SessionId sessionId, Collection<String> requiredProperties)
sessionId
- identifies the client sessionrequiredProperties
- a list of required property keys. See
Session
for a full list of available fixed property keys.
To request no properties supply an empty list. To request all
fixed properties include Session.ALL_FIXED_PROPERTIES
as a
key. In this case any other fixed property keys would be ignored.
To request all user properties include
Session.ALL_USER_PROPERTIES
as a key. In this case any
other user properties are ignored.If the session properties were retrieved, the CompletableFuture will complete successfully. The result type is a map of properties that were required. If no properties were selected, the map will be empty.
Otherwise, the CompletableFuture will complete exceptionally with
a CompletionException
. Common reasons for failure, listed
by the exception reported as the
cause
, include:
NoSuchSessionException
– if the identified
session was closed before the response was delivered;
PermissionsException
– if the calling
session does not have the VIEW_SESSION
permission;
SessionClosedException
– if the calling session
is closed.
@Deprecated void getSessionProperties(SessionId sessionId, Collection<String> requiredProperties, ClientControl.SessionPropertiesCallback callback)
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead.
sessionId
- identifies the client sessionrequiredProperties
- a list of required property keys. See
Session
for a full list of available fixed property keys.
To request no properties supply an empty list. To request all
fixed properties include Session.ALL_FIXED_PROPERTIES
as a
key. In this case any other fixed property keys would be ignored.
To request all user properties include
Session.ALL_USER_PROPERTIES
as a key. In this case any
other user properties are ignored.callback
- called with the response@Deprecated <C> void getSessionProperties(SessionId sessionId, Collection<String> requiredProperties, C context, ClientControl.SessionPropertiesContextCallback<C> callback)
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead.
C
- the context object typesessionId
- identifies the client sessionrequiredProperties
- a list of required property keys. See
Session
for a full list of available fixed property keys.
To request no properties supply an empty list. To request all
fixed properties include Session.ALL_FIXED_PROPERTIES
as a
key. In this case any other fixed property keys would be ignored.
To request all user properties include
Session.ALL_USER_PROPERTIES
as a key. In this case any
other user properties are ignored.context
- passed to the callback to allow requests and responses to
be correlated. The caller can use any convenient object reference,
including null
callback
- called with the responseCompletableFuture<Map<String,String>> setSessionProperties(SessionId sessionId, Map<String,String> properties)
It is also permissible to change the values of the following fixed session properties :-
$Country
- will be normalised to upper case
$Language
- will be normalised to lower case
$Latitude
- Invalid value will be set to "NaN"
$Longitude
- Invalid value will be set to "NaN"
sessionId
- identifies the client sessionproperties
- the properties to change. Each entry in the map is a
property name and the new value. If the value is null
, any
existing property with that name will be removed (unless it is a
fixed property). Otherwise if the property name does not match any
existing property, that entry will be added as a new property
(although new properties starting with '$' will be ignored).
If the session properties were updated, the CompletableFuture
will complete successfully. The result type is a map of
properties that changed with their previous values. If no
properties were changed, the map will be empty. If any new
properties were added, the values in the map will be null
to indicate that they do not have an old value.
Otherwise, the CompletableFuture will complete exceptionally with
a CompletionException
. Common reasons for failure, listed
by the exception reported as the
cause
, include:
NoSuchSessionException
– if the identified
session was closed before the response was delivered;
PermissionsException
– if the calling
session does not have MODIFY_SESSION
and
VIEW_SESSION
permission;
SessionClosedException
– if the calling session
is closed.
CompletableFuture<ClientControl.SessionFilterOperationResult> setSessionProperties(String filter, Map<String,String> properties)
It is also permissible to change the values of the following fixed session properties:
$Country
- will be normalised to upper case
$Language
- will be normalised to lower case
$Latitude
- Invalid value will be set to
"NaN"
$Longitude
- Invalid value will be set to
"NaN"
filter
- the session filterproperties
- the properties to change. Each key should be a valid
session property key (see Session
). Further, keys starting
with '$' should be one of the allowed fixed session property keys
listed above. If the value is null, any existing user-defined
session property with the key will be removed. Fixed session
properties cannot be removed. If the value is non-null, it will be
used to set the value of the the session property with the given
key, adding it if necessary.
If the sessions properties were updated for the sessions that
satisfied the filter, the CompletableFuture will complete
successfully with a ClientControl.SessionFilterOperationResult
.
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 MODIFY_SESSION
and
VIEW_SESSION
permission;
SessionClosedException
– if the calling session
is closed.
CompletableFuture<Registration> setQueueEventHandler(ClientControl.QueueEventStream handler)
Each control session can register a single handler. When the handler is
no longer required, it may be closed using the Registration
provided by the CompletableFuture result. To set a different handler the
current handler must first be closed. For each event, the server will
select a single handler.
The control session may choose to act upon queue events for a session by activating conflation for the session.
handler
- the queue handler to setRegistration
which can be used to
unregister the handler.
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;
HandlerConflictException
– if the session has
already registered a queue event handler;
PermissionsException
– if the session does
not have REGISTER_HANDLER
permission;
PermissionsException
– if the session does
not have VIEW_SESSION
permission.
@Deprecated void setQueueEventHandler(ClientControl.QueueEventHandler handler)
The CompletableFuture-based alternative
setQueueEventHandler(QueueEventStream)
should be
preferred since it provides better error reporting.
Each control session can register a single handler. (See
ServerHandler.onActive(RegisteredHandler)
). A handler may be
closed (using RegisteredHandler.close()
) if no longer required.
To set a different handler the current handler must first be closed. For
each event, the server will select a single handler.
The control session may choose to act upon queue events for a session by activating conflation for the session.
handler
- the queue handler to setCompletableFuture<?> close(SessionId sessionId)
sessionId
- identifies the client session to closeIf the identified session was closed, the CompletableFuture will complete successfully. 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:
NoSuchSessionException
– if the identified
session was closed before the response was delivered;
PermissionsException
– if the calling
session does not have MODIFY_SESSION
and
VIEW_SESSION
permissions;
SessionClosedException
– if the calling session
is closed.
CompletableFuture<ClientControl.SessionFilterOperationResult> close(String filter)
filter
- matches the set of client sessions to close. For details on
specifying session filters see Session
.CompletableFuture
that completes when the matching
sessions have been closed.
If the CompletableFuture completes normally then it returns a
ClientControl.SessionFilterOperationResult
which provides the number of
sessions that matched the filter and have been closed.
Otherwise, the CompletableFuture will complete exceptionally with
a CompletionException
. Common reasons for failure, listed
by the exception reported as the
cause
, include:
InvalidFilterException
– if the filter
was invalid;
PermissionsException
– if the calling
session does not have MODIFY_SESSION
and
VIEW_SESSION
permissions;
SessionClosedException
– if the calling session
is closed.
@Deprecated void close(SessionId sessionId, ClientControl.ClientCallback callback)
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead.
The CompletableFuture-based alternative close(SessionId)
should
be preferred since it provides better error reporting.
sessionId
- identifies the client session to closecallback
- the operation callback@Deprecated <C> void close(SessionId sessionId, C context, ClientControl.ClientContextCallback<C> callback)
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead.
The CompletableFuture-based alternative close(SessionId)
should
be preferred since it provides better error reporting.
C
- the context typesessionId
- identifies the client session to closecontext
- the context object to pass to the callbackcallback
- the operation callbackCompletableFuture<?> setConflated(SessionId sessionId, boolean conflate)
Each session begins with conflation enabled or disabled based on the queue configuration of the connector it is using. This method allows conflation to be enabled or disabled for specific sessions at runtime.
Conflation is the process of merging or discarding topic updates queued
for a session to reduce the server memory footprint and network data.
Conflation needs to be enabled for a session and a policy configured for
the topic to have an effect. Policies are configured on a per-topic
basis using the
topic property CONFLATION
.
sessionId
- identifies the client sessionconflate
- true
to enable conflation, false
to
disable conflationIf the conflation policy was updated for the identified session, the CompletableFuture will complete successfully. 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:
NoSuchSessionException
– if the identified
session was closed before the response was delivered;
PermissionsException
– if the calling
session does not have MODIFY_SESSION
and
{code VIEW_SESSION} permissions;
SessionClosedException
– if the calling session
is closed.
CompletableFuture<ClientControl.SessionFilterOperationResult> setConflated(String filter, boolean conflate)
Each session begins with conflation enabled or disabled based on the
queue configuration of the connector it is using. This method allows
conflation to be enabled or disabled for a set of sessions matching a
filter at runtime. For more detail on specifying session filters see
Session
.
Conflation is the process of merging or discarding topic updates queued
for a session to reduce the server memory footprint and network data.
Conflation needs to be enabled for a session and a policy configured for
the topic to have an effect. Policies are configured on a per-topic
basis using the
topic property CONFLATION
.
filter
- identifies the client sessionsconflate
- true
to enable conflation, false
to
disable conflationClientControl.SessionFilterOperationResult
with the number of sessions
that matched the filter.
If the conflation policy was updated for the identified sessions,
the CompletableFuture will complete successfully. The result type
is a ClientControl.SessionFilterOperationResult
rather than Integer to
provide forward compatibility with future iterations of this API
that may provide additional information.
Otherwise, the CompletableFuture will complete exceptionally with
a CompletionException
. Common reasons for failure, listed
by the exception reported as the
cause
, include:
InvalidFilterException
– if the filter
parameter could not be parsed;
PermissionsException
– if the calling
session does not have MODIFY_SESSION
or
VIEW_SESSION
permissions;
SessionClosedException
– if the calling session
is closed.
@Deprecated void setConflated(SessionId sessionId, boolean conflate, ClientControl.ClientCallback callback)
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead.
Each session begins with conflation enabled or disabled based on the queue configuration of the connector it is using. This method allows conflation to be enabled or disabled for specific sessions at runtime.
Conflation is the process of merging or discarding topic updates queued
for a session to reduce the server memory footprint and network data.
Conflation needs to be enabled for a session and a policy configured for
the topic to have an effect. Policies are configured on a per-topic
basis using the
topic property CONFLATION
.
The CompletableFuture-based alternative
setConflated(SessionId, boolean)
should be preferred since it
provides better error reporting.
sessionId
- identifies the client sessionconflate
- true
to enable conflation, false
to
disable conflationcallback
- the operation callback@Deprecated <C> void setConflated(SessionId sessionId, boolean conflate, C context, ClientControl.ClientContextCallback<C> callback)
Methods that use callbacks are deprecated and will be removed in a future release. Use CompletableFuture variant instead.
The CompletableFuture-based alternative
setConflated(SessionId, boolean)
should be preferred since it
provides better error reporting.
C
- the context typesessionId
- identifies the client sessionconflate
- true
to enable conflation, false
to
disable conflationcontext
- the context to pass to the callbackcallback
- the operation callback@Deprecated SessionId sessionIdFromString(String sessionIdAsString) throws IllegalArgumentException
Use Diffusion.sessionIdFromString(java.lang.String)
which allows the
method to be statically imported. This method will be removed
in a future release.
SessionId
from a string.
This method allows a SessionId
to be converted to a string with
SessionId.toString()
and later recovered from the string. This is
a client operation. A session that has been closed will not be recreated.
sessionIdAsString
- a string, previously created with
SessionId.toString()
SessionId
IllegalArgumentException
- if the string was not generated by
SessionId.toString()
CompletableFuture<?> changeRoles(SessionId sessionId, Set<String> rolesToRemove, Set<String> rolesToAdd) throws IllegalArgumentException
Initially a session has a set of roles assigned during authentication.
The set of assigned roles can be obtained from the session's $Roles
session
property.
When a session's assigned roles change, its $Roles property changes accordingly. Changing the assigned roles can change the READ_TOPIC permissions granted to the session. The session's subscriptions will be updated accordingly.
The same role must not occur in both rolesToRemove
and
rolesToAdd
sets. Either set can be an empty set but not both.
sessionId
- identifies the client session for which the change will be
appliedrolesToRemove
- a set of roles to be removed from the session. If
one or more roles from the list are not currently assigned, they
are ignored.rolesToAdd
- a set of roles to be added to the session. If one or
more roles from the list are already assigned, they are ignored.CompletableFuture
that completes when session roles have
been changed.
If the CompletableFuture completes normally then it indicates that the specified role changes have been applied to the session.
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 MODIFY_SESSION
and
VIEW_SESSION
permission;
NoSuchSessionException
– if there is no session
with the given sessionId
;
SessionClosedException
– if the calling session
is closed.
IllegalArgumentException
- if the same role occurs in both
rolesToRemove
and rolesToAdd
sets or if both sets
are emptyCompletableFuture<Integer> changeRoles(String filter, Set<String> rolesToRemove, Set<String> rolesToAdd) throws IllegalArgumentException
Initially a session has a set of roles assigned during authentication.
A current roles set can be obtained from the $Roles Session
property.
When a set of session roles changes, its $Roles property changes accordingly. As a role can constrain 'topic' permissions, session subscriptions are re-evaluated based on the new roles set.
The same role must not occur in both rolesToRemove
and
rolesToAdd
sets. Either set can be an empty set but not both.
filter
- identifies the set of client sessions for which the change
will be applied. For details on how to specify session filters see
Session
.rolesToRemove
- a set of roles to be removed from the session. If
one or more roles from the list are not currently assigned, they
are ignored.rolesToAdd
- a set of roles to be added to the session. If one or
more roles from the list are already assigned, they are ignored.CompletableFuture
that completes when session roles have
been changed.
If the CompletableFuture completes normally then it returns an integer value which represents a number of sessions that have matched the filter and for which the specified role changes have been applied.
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 MODIFY_SESSION
and
VIEW_SESSION
permissions;
SessionClosedException
– if the calling session
is closed.
InvalidFilterException
– if the filter
parameter could not be parsed;
IllegalArgumentException
- if the same role occurs in both
rolesToRemove
and rolesToAdd
sets or if both sets
are emptyCopyright © 2022 Push Technology Ltd. All Rights Reserved.