Class SessionPropertiesListenerDefault
- Assembly
- Diffusion.Client.dll
This provides a default implementation of ISessionPropertiesListener which will simply log session properties callbacks at debug level. This should only be used for diagnostic purposes.
public class SessionPropertiesListenerDefault : ISessionPropertiesListener, IServerHandler
- Inheritance
-
SessionPropertiesListenerDefault
- Implements
- Inherited Members
Methods
OnClose()
Called if the handler is closed. This happens if the call to register the handler fails, or the handler is unregistered.
public virtual void OnClose()
OnError(ErrorReason)
Notification of a contextual error related to this handler. This is
analogous to an unchecked exception being raised. Situations in which
onError is called include the session being closed before the
handler is registered, a communication timeout, or a problem with the
provided parameters. No further calls will be made to this handler.
public virtual void OnError(ErrorReason errorReason)
Parameters
errorReasonErrorReasonA value representing the error; this can be one of the constants defined in ErrorReason, or a feature-specific reason.
OnRegistered(IRegistration)
Called when the handler has been successfully registered with the server.
A session can register at most one handler of each type. If
there is already a handler registered the operation will fail,
registeredHandler will be closed, and the session error handler
will be notified. To change the handler, first
close the previous handler.
public virtual void OnRegistered(IRegistration registration)
Parameters
registrationIRegistrationA reference that allows the handler to be closed.
OnSessionClose(ISessionId, IDictionary<string, string>, CloseReason)
Notification that a client session has closed.
This will be called for every client that closes whilst the listener is registered regardless of requested session properties.
public virtual void OnSessionClose(ISessionId sessionId, IDictionary<string, string> properties, CloseReason closeReason)
Parameters
sessionIdISessionIdThe session identifier of the client that has closed.
propertiesIDictionary<string, string>The map of requested property values at the point when the session was closed. This can be empty if no properties were requested. If a requested property did not exist then it will not be present in the map.
closeReasonCloseReasonWhy the session was closed.
OnSessionEvent(ISessionId, SessionPropertiesListenerEventType?, IDictionary<string, string>, IDictionary<string, string>)
Notification of a session event that can result in a change of properties.
public virtual void OnSessionEvent(ISessionId sessionId, SessionPropertiesListenerEventType? eventType, IDictionary<string, string> properties, IDictionary<string, string> previousValues)
Parameters
sessionIdISessionIdThe client session id.
eventTypeSessionPropertiesListenerEventType?Indicates the type of event.
propertiesIDictionary<string, string>The map of current requested property values. This may be empty if no properties were requested.
previousValuesIDictionary<string, string>A map of the previous values of keys that have changed. This will only contain keys that have changed and not the whole required property set. This can be empty if an event is being reported that did not result in the change of any of the required properties. When a new property is added then the value in this map will be null. When a property is removed then it will have a value in this map but not in
properties.
OnSessionOpen(ISessionId, IDictionary<string, string>)
Notification that a new client session has been opened.
When the listener is registered, this will be called for all existing sessions. It will then be called for every new session that opens whilst the listener is registered.
This will be called for every client session regardless of requested session properties.
public virtual void OnSessionOpen(ISessionId sessionId, IDictionary<string, string> properties)
Parameters
sessionIdISessionIdThe session identifier.
propertiesIDictionary<string, string>The map of requested session property values. This can be empty if no properties were requested. If a requested property did not exist then it will not be present in the map.