Dynatrace allows you to identify users across sessions and devices, manage session lifecycle, and attach properties that apply to all events in a session.
Use identifyUser() to tag the current session with a user identifier. This enables you to track individual users across different sessions, browsers, and devices.
identifyUser() for every new session.When the user closes the app or when privacy settings change, sessions are not automatically re-tagged. You must call identifyUser() again after the new session starts.
// After user logs inDynatrace.identifyUser("user@example.com")// Or use an internal user IDDynatrace.identifyUser("user-12345")
To remove the user tag (for example, on logout), pass null or an empty string:
fun logout() {// Clear user identificationDynatrace.identifyUser(null)}
Session properties are key-value pairs that apply to all events in the current session. Use them to add context that characterizes the user's session.
Event and session properties must be configured before they can be used. Incoming event and session properties that are not configured are dropped during event ingest.
Dynatrace.sendSessionPropertyEvent(SessionPropertyEventData().addSessionProperty("session_properties.product_tier", "premium").addSessionProperty("session_properties.loyalty_status", "gold").addSessionProperty("session_properties.onboarding_complete", true))
Keys must be prefixed with session_properties. and must follow the rules specified in Event and session properties.
Session properties require server-side configuration in Dynatrace. Properties that are not configured are dropped during ingest.
You can send session properties multiple times during a session. However, if you send the same property multiple times, session aggregation keeps only one value (first or last, depending on configuration).
// Initial propertiesDynatrace.sendSessionPropertyEvent(SessionPropertyEventData().addSessionProperty("session_properties.cart_value", 0))// Update after user adds itemsDynatrace.sendSessionPropertyEvent(SessionPropertyEventData().addSessionProperty("session_properties.cart_value", 149.99))