🚧 NOTE: Mobile recording is currently only available on Android and iOS and is considered
beta
. We are keen to gather as much feedback as possible so if you try this out please let us know. You can send feedback via the in-app support panel or one of our other support options.
Mobile recording is free and unlimited while it is considered
beta
.
Overview
Mobile Session Recording allows you to record user sessions on mobile devices. This includes screen recordings, network requests, logs, and touches. This data can then be used to understand how users are interacting with your app and to identify bugs and issues.
How it works
We have taken our time to make sure we provide a useful and detailed recording experience whilst keeping the performance and security of your app as a top priority. By default, the configuration is restrictive with automatic masking.
Wireframe mode (Default)
Mobile recording is primarily done using native APIs to grab the view hierarchy state when the screen is drawn. This is done carefully so as not to affect performance in any way a user may notice.
The view hierarchy is transformed to a JSON data structure and later rendered as an HTML wireframe. Since it is a wireframe, the UI won't have the original look and feel but it should be close enough to understand the user's behavior.
Screenshot mode
If the screenshot
(Android) or screenshotMode
(iOS) option is enabled, the SDK will take a screenshot of the screen instead of making a representation of the user's screen (A.k.a. Wireframe mode). The screenshot may contain sensitive information, use it with caution. The automatic masking for the screenshot mode already works on Android and we'll be working on the iOS next.
Network recording
If the captureNetworkTelemetry
option is enabled, the SDK will record Network requests. Only metric-like data is currently gathered to give a picture of speed, size, and response code. No data is captured from the request or response body.
Installation
Android
Add the dependency, check out the installation docs.
Initialize the SDK, check out the configuration docs.
Add the OkHttp Interceptor for enabling the captureNetworkTelemetry
option.
import com.posthog.PostHogOkHttpInterceptorimport okhttp3.OkHttpClientprivate val client = OkHttpClient.Builder().addInterceptor(PostHogOkHttpInterceptor(captureNetworkTelemetry = true)).build()
Recording specific configuration
SDK configurations during the SDK initialization.
val config = PostHogAndroidConfig(apiKey = POSTHOG_API_KEY).apply {// enable session recording, requires enabling on the project configuration as well.sessionReplay = true// all texts are masked or redacted (default is enabled).// this isn't supported if using Jetpack Compose views, use with caution.sessionReplayConfig.maskAllTextInputs = false// all images are placeholders or redacted (default is enabled).// this isn't supported if using Jetpack Compose views, use with caution.sessionReplayConfig.maskAllImages = false// capture logs automatically (default is enabled)sessionReplayConfig.captureLogcat = true// screenshot is disabled by default// The screenshot may contain sensitive information, use with cautionsessionReplayConfig.screenshot = false// debouncerDelayMs is 500ms by defaultsessionReplayConfig.debouncerDelayMs = 500}
Masking and Redaction
🚧 NOTE: Currently, this isn't supported if using Jetpack Compose views, We're investigating this issue.
View configuration, if setting the View#tag to ph-no-capture
, the view will be a placeholder or redacted, this setting applies to any type of View
.
<ImageViewandroid:id="@+id/imvProfilePhoto"android:layout_width="200dp"android:layout_height="200dp"android:tag="ph-no-capture"/>
Limitations
- Requires the PostHog Android SDK version >= 3.4.0 - use the latest version.
- Requires Android API >= 26, otherwise it's a NoOp.
- Jetpack Compose is only supported if the
screenshot
option is enabled.- Masking and Redaction aren't supported yet, We're investigating this issue.
- Custom views is partly supported, and only fully supported if the
screenshot
option is enabled. - WebView is not supported, a placeholder will be shown.
- Keyboard is not supported, a placeholder will be shown.
- React Native and Flutter for Android aren't supported.
iOS
Add the dependency, check out the installation docs.
Initialize the SDK, check out the configuration docs.
Recording specific configuration
SDK configurations during the SDK initialization.
let config = PostHogConfig(apiKey: apiKey)// sessionReplay is disabled by defaultconfig.sessionReplay = true// sessionReplayConfig is optional, they are enabled by defaultconfig.sessionReplayConfig.maskAllTextInputs = trueconfig.sessionReplayConfig.maskAllImages = trueconfig.sessionReplayConfig.captureNetworkTelemetry = true// screenshotMode is disabled by default// The screenshot may contain sensitive information, use with cautionconfig.sessionReplayConfig.screenshotMode = true
Masking and Redaction
UIView configuration, if setting the accessibilityIdentifier or accessibilityLabel to ph-no-capture
, the view will be a placeholder or redacted, this setting applies to any type of UIView
.
let imvProfilePhoto = UIImageView(frame: CGRect(x: 50, y: 50, width: 100, height: 100))imvProfilePhoto.accessibilityIdentifier = "ph-no-capture"
The SwiftUI TextField when used in combination with UITextInputTraits by setting traits such as TextField("Email", text: ...).keyboardType(.emailAddress)
will always be automatically masked since it's for private text.
The SwiftUI SecureField view is always automatically masked since it's for private text.
The SwiftUI accessibilityLabel and SwiftUI accessibilityIdentifier configurations aren't supported yet for SwiftUI, We're investigating this issue.
The SwiftUI Text view is detected as a SwiftUI Image view and it'll be automatically masked if the option maskAllImages
is enabled even if the maskAllTextInputs
option is disabled, We're investigating this issue.
Limitations
- Requires the PostHog iOS SDK version >= 3.6.0 - use the latest version.
- SwiftUI is only supported if the
screenshotMode
option is enabled. - It's a representation of the user's screen, not a video recording nor a screenshot.
- Custom views are not fully supported.
- If the option
screenshotMode
is enabled, the SDK will take a screenshot of the screen instead of making a representation of the user's screen.
- WebView is not supported, a placeholder will be shown.
- React Native and Flutter for iOS aren't supported.