This article covers the installation of Session Replay for Android using the standalone SDK. If you use a provider other than Amplitude for in-product analytics, choose this option. If your app is already instrumented with Amplitude Android SDK, use the Session Replay Android SDK Plugin.
To report issues with Session Replay for Android, see the AmplitudeSessionReplay-Android GitHub repository.
Amplitude built Session Replay to minimize impact on the performance of the Android apps in which it's installed by:
Use the latest version of the Session Replay SDK above version 0.15.2
. For a list of available versions, see the release versions on Maven Central.
Session Replay Standalone SDK requires that:
Session ID
and Device ID
you pass to the Standalone SDK must match those sent as event properties to Amplitude.The Standalone SDK doesn't provide Session management capabilities. Your application or a third-party integration must update the SDK with changes to Session ID
and Device ID
.
Session replay supports down to Android 5.0 with a minimum SDK of 21 minSdk = 21
. This should support over 99.6% of global Android devices according to Google's distribution data in Android Studio.
Add the latest version Session Replay SDK to your project dependencies.
1implementation("com.amplitude:session-replay-android:0.15.2")
Configure your application code.
val sessionReplay = SessionReplay()
object to begin collecting replays. Pass the API key, session identifier, and device identifier.sessionReplay.setSessionId
or sessionReplay.setDeviceId
.sessionReplay.getSessionReplayProperties
sessionReplay.flush
to send session replay data to Amplitude. Always call flush
before exiting the app or sending it to the background. For longer sessions, call flush
often to prevent high memory use (alpha). 1import com.amplitude.android.sessionreplay.SessionReplay 2import com.example.ThirdPartyAnalytics 3 4// Initialize the standalone session replay SDK 5val sessionReplay = SessionReplay( 6 apiKey = "api-key", 7 context = applicationContext, 8 deviceId = "device-id", 9 sessionId = Date().time,10 sampleRate = 1.0,11)12 13// Track an event14// Get session replay properties for this session15val sessionReplayProperties = sessionReplay.getSessionReplayProperties()16// Add session replay properties to the event before tracking17ThirdPartyAnalytics.track(18 eventName,19 if (eventProperties == null) sessionReplayProperties else eventProperties + sessionReplayProperties20)21 22// Handle session ID change23// Whenever the session ID changes24ThirdPartyAnalytics.setSessionId(sessionId)25// Update the session ID in session replay26sessionReplay.setSessionId(ThirdPartyAnalytics.getSessionId())27 28// Handle device ID change29// When the device ID changes30ThirdPartyAnalytics.setDeviceId(deviceId)31//Update the device ID in session replay32sessionReplay.setDeviceId(ThirdPartyAnalytics.getDeviceId())33 34 35// Send session replay data to the server36// This should always be called before app exit37sessionReplay.flush()
Pass the following configuration options when you initialize the Session Replay SDK.
Name | Type | Required | Default | Description |
---|---|---|---|---|
deviceId |
String |
Yes | null |
Sets an identifier for the device running your application. |
sessionId |
Long |
Yes | null |
Sets an identifier for the users current session. The value must be in milliseconds since epoch (Unix Timestamp). |
sampleRate |
Number |
No | 0.0 |
Use this option to control how many sessions to select for replay collection. The number should be a decimal between 0 and 1, for example 0.4 , representing the fraction of sessions to have randomly selected for replay collection. Over a large number of sessions, 0.4 would select 40% of those sessions. |
optOut |
Boolean |
No | false |
Sets permission to collect replays for sessions. Setting a value of true prevents Amplitude from collecting session replays. |
logger |
Logger |
No | LogcatLogger |
Sets a custom logger class from the Logger to emit log messages to desired destination. Set to null to disable logging. |
serverZone |
ServerZone |
No | ServerZone.US |
ServerZone.EU or ServerZone.US . Sets the Amplitude server zone. Set this to EU for Amplitude projects created in EU data center. |
enableRemoteConfig |
boolean |
No | true |
Enables or disables remote configuration for this instance of Session Replay. |
maskLevel |
String |
No | medium |
Sets the privacy mask level. |
Enable remote configuration to set Sample Rate and Masking Level in Amplitude.
With enableRemoteConfig
set to true
, settings you define in Amplitude take precedence over settings you define locally in the SDK. For this reason, while testing your application, you should disable remote configuration to ensure you can set sampleRate
to 1
, and ensure you capture test sessions.
The Session Replay SDK offers three ways to mask user input, text, and other view components.
Session Replay for Android supports three levels of masking, configurable with the the maskLevel
config option.
Use this option in the Session Replay configuration.
Mask level | Description |
---|---|
light |
Masks all password, email address, and phone numbers. Doesn't block credit card numbers. |
medium |
Masks all editable text views. |
conservative |
Masks all text views. |
Use this option in your application's layout XML.
View | Description |
---|---|
<EditText> |
Session Replay masks all text input fields by default. When a users enters text into an input field, Session Replay captures asterisks in place of text. To unmask a text input, add the tag amp-unmask . For example: <EditText android:tag="amp-unmask" android:text="Unmask this"> . |
<TextView> |
To mask text within non-input elements, add the tag amp-mask . For example, <TextView android:tag="amp-mask" android:text="Mask this"/> . When masked, Session Replay captures masked text as a series of asterisks. |
non-text elements | To block a non-text element, add the tag amp-block . For example, <ImageView android:tag="amp-block"/> . Session Replay replaces blocked elements with a placeholder of the same dimensions. |
Import the SessionReplay
class, then call one of the methods below from your application's code.
1import com.amplitude.android.SessionReplay
Method | Description |
---|---|
unmask(view: View) |
Session Replay masks all text input views by default. When a user enters text into an input view, Session Replay captures asterisks in place of text. To unmask a text input, call SessionReplay.unmask(view) where view is a reference to the text input you want to unmask. |
mask(view: View) |
To mask text within non-input views, call SessionReplay.mask(view) where view is a reference to the text input you want to mask. When masked, Session Replay captures masked text as a series of asterisks. |
block(view: View) |
To block a non-text view, call SessionReplay.unmask(view) where view is a reference to the View you want to block. Session Replay replaces blocked views with a placeholder of the same dimensions. |
Session Replay provides an option for opt-out configuration. This prevents Amplitude from collecting session replays when passed as part of initialization. For example:
1// Pass a boolean value to indicate a users opt-out status2val sessionReplay = SessionReplay(3 apiKey = API_KEY,4 optOpt = true,5 /* other session replay options */6)
Session Replay is available to Amplitude Customers who use the EU data center. Set the serverZone
configuration option to EU
during initialization. For example:
1// Set serverZone to EU2val sessionReplay = SessionReplay(3 apiKey = API_KEY,4 serverZone = ServerZone.EU,5 /* other session replay options */6)
By default, Session Replay captures 0% of sessions for replay. Use the sampleRate
configuration option to set the percentage of total sessions that Session Replay captures. For example:
To set the sampleRate
consider the monthly quota on your Session Replay plan. For example, if your monthly quota is 2,500,000 sessions, and you average 3,000,000 monthly sessions, your quota is 83% of your average sessions. In this case, to ensure sampling lasts through the month, set sampleRate
to .83
or lower.
Keep the following in mind as you consider your sample rate:
.01
. If this value doesn't capture enough replays, raise the rate over the course of a few days. For ways to monitor the number of session replays captured, see View the number of captured sessions.1// This configuration samples 1% of all sessions2val sessionReplay = SessionReplay(3 apiKey = API_KEY,4 sampleRate = 0.01,5 /* other session replay options */6)
Once enabled, Session Replay runs on your app until either:
sessionReplay.shutdown()
Call sessionReplay.shutdown()
before a user navigates to a restricted area of your app to disable replay collection while the user is in that area.
Create a new instance sessionReplay = SessionReplay(apiKey = API_KEY, /* options */)
to re-enable replay collection when the return to an unrestricted area of your app.
You can also use a feature flag product like Amplitude Experiment to create logic that enables or disables replay collection based on criteria like location. For example, you can create a feature flag that targets a specific user group, and add that to your initialization logic:
1import com.amplitude.android.sessionreplay.SessionReplay 2import com.example.ThirdPartyAnalytics 3 4val sessionReplay = SessionReplay( 5 apiKey = API_KEY, 6 deviceId = "device-id", 7 sessionId = Date().time, 8 sampleRate = 1.0, 9 /* other session replay options */10)11 12if (nonEUCountryFlagEnabled) {13 val sessionReplayProperties = sessionReplay.getSessionReplayProperties()14 ThirdPartyAnalytics.track(15 eventName = 'event',16 eventProperties = eventProperties + sessionReplayProperties17 )18}
Session replay uses existing Amplitude tools and APIs to handle privacy and deletion requests.
While privacy laws and regulations vary across states and countries, certain constants exist, including the requirements to disclose in a privacy notice the categories of personal information you are collecting, the purposes for its use, and the categories of third parties with which personal information is shared. When implementing a session replay tool, you should review your privacy notice to make sure your disclosures remain accurate and complete. And as a best practice, review your notice with legal counsel to make sure it complies with the constantly evolving privacy laws and requirements applicable to your business and personal information data practices.
If your Amplitude plan includes Session Replay, Amplitude retains raw replay data for 30 days from the date of ingestion.
If you purchase extra session volume, Amplitude retains raw replay data for 90 days from the date of ingestion. If you need a more strict policy, contact Amplitude support to set the value to 30 days.
Changes to the retention period impact replays ingested after the change. Sessions captured and ingested before a retention period change retain the previous retention period.
Retention periods are set at the organization level. Replays that are outside of the retention period aren't viewable in Amplitude.
The Amplitude DSAR API returns metadata about session replays, but not the raw replay data. All events that are part of a session replay include a [Amplitude] Session Replay ID
event property. This event provides information about the sessions collected for replay for the user, and includes all metadata collected with each event.
1{ 2 "amplitude_id": 123456789, 3 "app": 12345, 4 "event_time": "2020-02-15 01:00:00.123456", 5 "event_type": "first_event", 6 "server_upload_time": "2020-02-18 01:00:00.234567", 7 "device_id": "your device id", 8 "user_properties": { ... } 9 "event_properties": {10 "[Amplitude] Session Replay ID": "cb6ade06-cbdf-4e0c-8156-32c2863379d6/1699922971244"11 }12 "session_id": 1699922971244,13}
Session Replay uses Amplitude's User Privacy API to handle deletion requests. Successful deletion requests remove all session replays for the specified user.
When you delete the Amplitude project on which you use Session Replay, Amplitude deletes that replay data.
Session Replay uses the same block filter available in the Amplitude app. Session Replay doesn't block traffic based on event or user properties.
If a user opts out tracking in your app, use the optOut
configuration option to disable replay collection for that user.
flush()
to transfer the session replay data to the server.Keep the following limitations in mind as you implement Session Replay:
Session Replay doesn't stitch together replays from a single user across multiple projects. For example:
The User Sessions chart doesn't show session replays if your organization uses a custom session definition.
Session Replay for Android doesn't support Jetpack Compose
Session Replay can't capture the following Android views:
For more information about individual statuses and errors, see the Session Replay Ingestion Monitor. |
Session replays may not appear in Amplitude due to:
Ensure your app has access to the internet then try again.
As mentioned above, the default sampleRate
for Session Replay is 0
. Update the rate to a higher number. For more information see, Sampling rate.
Session replay doesn't require that all events in a session have the [Amplitude] Session Replay ID
property, only that one event in the session has it. Reasons why [Amplitude] Session Replay ID
may not be present in an event include:
sampleRate
. Increasing the sampleRate
captures more sessions.getSessionReplayProperties()
doesn't return the [Amplitude] Session Replay ID
property. This can result from optOut
and sampleRate
configuration settings. Check that optOut
and sampleRate
are set to include the session.In general, replays should be available within minutes of ingestion. Delays or errors may be the result of one or more of the following:
Thanks for your feedback!
October 30th, 2024
Need help? Contact Support
Visit Amplitude.com
Have a look at the Amplitude Blog
Learn more at Amplitude Academy
© 2024 Amplitude, Inc. All rights reserved. Amplitude is a registered trademark of Amplitude, Inc.