Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[SR] Session Replay #3339

Merged
merged 239 commits into from
Jul 15, 2024
Merged
Show file tree
Hide file tree
Changes from 231 commits
Commits
Show all changes
239 commits
Select commit Hold shift + click to select a range
2dbe2ce
Add new sentry-android-replay module
romtsn Feb 1, 2024
d702876
Add screenshot recorder
romtsn Feb 1, 2024
b1ced85
Add sentry replay envelope and event
romtsn Feb 1, 2024
fdd4363
Merge pull request #3202 from getsentry/rz/feat/session-replay-new-mo…
romtsn Feb 13, 2024
11f699c
Add TODOs and license headers
romtsn Feb 13, 2024
dd0e9a4
Api dump
romtsn Feb 13, 2024
d34ddee
Formatting
romtsn Feb 13, 2024
0cca47c
Lint
romtsn Feb 13, 2024
0a26e8d
Merge branch 'rz/feat/session-replay' into rz/feat/session-replay-sou…
romtsn Feb 13, 2024
5ebdfed
Format code
getsentry-bot Feb 13, 2024
04f43ed
More comments
romtsn Feb 13, 2024
b461847
Disable detekt plugin for now
romtsn Feb 13, 2024
f8419d1
Merge branch 'rz/feat/session-replay-sources' into rz/feat/session-re…
romtsn Feb 13, 2024
a63cac1
WIP
romtsn Feb 15, 2024
fa72057
Add replay envelopes
romtsn Feb 19, 2024
6cfb511
Remove jsonValue
romtsn Feb 19, 2024
0d031d7
Remove
romtsn Feb 19, 2024
07e6b26
Fix json
romtsn Feb 19, 2024
18af924
Finalize replay envelopes
romtsn Feb 20, 2024
64cedfa
Introduce MapObjectReader
romtsn Feb 20, 2024
b8cb924
Add missing test
romtsn Feb 20, 2024
28d341f
Merge branch 'rz/feat/session-replay-envelopes' into rz/feat/session-…
romtsn Feb 20, 2024
1e76fc7
Add test for MapObjectReader
romtsn Feb 22, 2024
13c1971
Add MapObjectWriter change
romtsn Feb 22, 2024
a14e090
Merge branch 'rz/feat/session-replay-envelopes' into rz/feat/session-…
romtsn Feb 22, 2024
86baf7f
Add finals
romtsn Feb 22, 2024
f1ca9f6
Fix test
romtsn Feb 22, 2024
fbbe0d9
Fix test
romtsn Feb 22, 2024
688233f
Merge branch 'rz/feat/session-replay-envelopes' into rz/feat/session-…
romtsn Feb 22, 2024
fd63960
Address review
romtsn Feb 28, 2024
93785cc
Add finals and annotations
romtsn Feb 28, 2024
4db19e0
Merge pull request #3215 from getsentry/rz/feat/session-replay-map-ob…
romtsn Feb 28, 2024
4e55ec0
Specify SHA for license headers
romtsn Feb 28, 2024
9603672
Address review from Dhiogo
romtsn Feb 28, 2024
1ce57cb
Address review from Markus
romtsn Mar 1, 2024
62477b4
Remove public captureReplay method
romtsn Mar 1, 2024
af42fb3
Fix test
romtsn Mar 1, 2024
1951891
api dump
romtsn Mar 1, 2024
cd09739
Merge branch 'rz/feat/session-replay-sources' into rz/feat/session-re…
romtsn Mar 1, 2024
4e54c77
api dump
romtsn Mar 1, 2024
b2940c4
Address review from Markus
romtsn Mar 4, 2024
002a0f3
Api dump
romtsn Mar 4, 2024
64f70c5
Merge pull request #3203 from getsentry/rz/feat/session-replay-sources
romtsn Mar 4, 2024
fb14ecb
Merge branch 'rz/feat/session-replay' into rz/feat/session-replay-env…
romtsn Mar 4, 2024
79151e9
Merge pull request #3214 from getsentry/rz/feat/session-replay-envelopes
romtsn Mar 4, 2024
9e87fe8
Add replay integration
romtsn Mar 19, 2024
2e954f7
Uncomment redacting
romtsn Mar 19, 2024
8bc6219
Update proguard rules
romtsn Mar 20, 2024
a5aa4be
Add missing rule for AndroidTest
romtsn Mar 20, 2024
f72e45f
Add ReplayCache tests
romtsn Mar 21, 2024
545712c
Add tests
romtsn Mar 21, 2024
2df34a3
Add SessionReplayOptions
romtsn Mar 25, 2024
c02f1db
Call listeners when installing RootViewsSpy
romtsn Mar 25, 2024
bee240b
Call listeners when installing RootViewsSpy
romtsn Mar 25, 2024
e2a821c
Merge branch 'rz/feat/session-replay-integration' into rz/feat/sessio…
romtsn Mar 25, 2024
d6bb9ab
SessionReplayOptions -> SentryReplayOptions
romtsn Mar 25, 2024
7854e4f
Fix test
romtsn Mar 26, 2024
2cddcc4
Add AndroidManifest options for replays
romtsn Mar 26, 2024
ef3d62c
Add buffer mode and link replays with events/transactions
romtsn Mar 28, 2024
f7ac74f
Pass hint to captureReplay
romtsn Mar 28, 2024
5faeb4e
Better error handling
romtsn Mar 28, 2024
65d35ec
recycler lastScreenshot before re-assigning
romtsn Mar 28, 2024
0f4e718
Expose ReplayCache as public api
romtsn Mar 28, 2024
fd6e633
Fix redacting out of sync
romtsn Mar 28, 2024
915bd29
Merge branch 'rz/feat/session-replay-integration' into rz/feat/sessio…
romtsn Mar 28, 2024
1a5c4da
_experimental -> experimental
romtsn Mar 28, 2024
fd92dc7
Merge branch 'rz/feat/session-replay-options' into rz/feat/session-re…
romtsn Mar 28, 2024
da37c89
Merge conflicts
romtsn Mar 28, 2024
c53a975
Fix tests
romtsn Apr 2, 2024
18eb67e
Add more tests
romtsn Apr 2, 2024
a7ae2b7
Improve ReplayCache logic
romtsn Apr 2, 2024
bf14d83
frameUsec -> frameDurationUsec
romtsn Apr 2, 2024
82fe21a
bottom/right -> height/width
romtsn Apr 2, 2024
de56e35
add todos
romtsn Apr 2, 2024
fa8c527
duration -> durationMs
romtsn Apr 2, 2024
dfbb992
replaId non-nullable
romtsn Apr 2, 2024
4ada96f
Merge branch 'rz/feat/session-replay-integration' into rz/feat/sessio…
romtsn Apr 2, 2024
c6a993f
Merge branch 'rz/feat/session-replay-options' into rz/feat/session-re…
romtsn Apr 2, 2024
ad7d78d
More conflicts
romtsn Apr 2, 2024
ab00547
More conflicts
romtsn Apr 2, 2024
7f78fee
Fix tests
romtsn Apr 2, 2024
9f252bc
Address PR review
romtsn Apr 3, 2024
27b15d7
Add kdoc
romtsn Apr 3, 2024
5278c86
Merge branch 'rz/feat/session-replay-integration' into rz/feat/sessio…
romtsn Apr 3, 2024
27674b1
Merge branch 'rz/feat/session-replay-options' into rz/feat/session-re…
romtsn Apr 3, 2024
957f0cf
Add kdoc
romtsn Apr 3, 2024
da3560d
Fix tests
romtsn Apr 3, 2024
b04aaf2
Merge pull request #3272 from getsentry/rz/feat/session-replay-integr…
romtsn Apr 3, 2024
023cb5f
Merge pull request #3283 from getsentry/rz/feat/session-replay-options
romtsn Apr 3, 2024
1a77d17
Add comment for experimental options
romtsn Apr 3, 2024
b88b1b9
Do not run recorder if full session was not sampled
romtsn Apr 3, 2024
4d533fb
Add more tests
romtsn Apr 3, 2024
4276264
Add session deadline of 1h
romtsn Apr 3, 2024
3fe5e0f
Clean up older replays when starting a new one
romtsn Apr 3, 2024
ca9f9d4
Remove unnecessary extension fun
romtsn Apr 3, 2024
7079d7a
[SR] Add buffer mode and link replays with events/transactions
romtsn Apr 4, 2024
ea417e4
Safe executors
romtsn Apr 4, 2024
f994ac9
Merge branch 'rz/feat/session-replay' into rz/feat/session-replay-cle…
romtsn Apr 4, 2024
0c5e4b0
Fix crashing MediaCodec and use density to determine recording resolu…
romtsn Apr 5, 2024
3e0894d
Add redact options and align naming
romtsn Apr 5, 2024
1fc9aa2
Fix tests
romtsn Apr 5, 2024
15e61dd
Merge branch 'rz/fix/session-replay-media-codec' into rz/feat/session…
romtsn Apr 5, 2024
ad98acd
Fix tests
romtsn Apr 5, 2024
5b8ed7c
Merge branch 'rz/fix/session-replay-media-codec' into rz/feat/session…
romtsn Apr 5, 2024
227c22a
WIP
romtsn Apr 5, 2024
0fca8ad
Try-catch release of encoder
romtsn Apr 5, 2024
5e37622
Support orientation change for session mode
romtsn Apr 8, 2024
d0b4d5c
WIP
romtsn Apr 8, 2024
f0fcf5d
Merge branch 'rz/fix/session-replay-media-codec' into rz/feat/session…
romtsn Apr 8, 2024
d7a7123
Merge branch 'rz/feat/session-replay-redact-options' into rz/feat/ses…
romtsn Apr 8, 2024
236ee2c
Spotless
romtsn Apr 8, 2024
e9bf0b3
TODO
romtsn Apr 8, 2024
bf8f49a
[SR] Cleanups and session deadline
romtsn Apr 9, 2024
71837c1
Update sentry/src/main/java/io/sentry/SentryReplayOptions.java
romtsn Apr 9, 2024
1430e7e
[SR] Fix crashing MediaCodec and use density to determine recording r…
romtsn Apr 9, 2024
a0c2678
[SR] Handle orientation change
romtsn Apr 9, 2024
3ef9f06
[SR] Add redact options and align naming
romtsn Apr 9, 2024
59b63e0
More gates
romtsn Apr 9, 2024
a9e3405
Merge branch 'rz/feat/session-replay' into rz/feat/session-replay-gates
romtsn Apr 9, 2024
21239ca
Revert addAll
romtsn Apr 9, 2024
b27a905
[SR] More gates
romtsn Apr 9, 2024
b83a894
Merge branch 'main' into rz/feat/session-replay
romtsn Apr 9, 2024
9cafe43
Fix conflicts
romtsn Apr 9, 2024
6c9baea
fix test
romtsn Apr 9, 2024
62a0984
Merge branch 'main' into rz/feat/session-replay
romtsn Apr 9, 2024
2057e22
release: 7.8.0-alpha.0
getsentry-bot Apr 9, 2024
7b24e7c
Merge branch 'release/7.8.0-alpha.0' into rz/feat/session-replay
Apr 9, 2024
5e33e95
Merge branch 'rz/feat/session-replay' into rz/feat/session-replay-cap…
romtsn Apr 9, 2024
f8f5698
Introduce CaptureStrategy for buffer and session modes
romtsn Apr 15, 2024
5c59bf7
Formatting
romtsn Apr 15, 2024
247f1c9
WIP
romtsn Apr 16, 2024
c2be16f
Expose public API for flutter
romtsn Apr 16, 2024
06d4b6d
Spotless
romtsn Apr 16, 2024
59056ef
Spotless
romtsn Apr 16, 2024
06495d8
Merge branch 'rz/feat/session-replay-breadcrumbs' into rz/feat/sessio…
romtsn Apr 16, 2024
0e951eb
Remove breadcrumb import
romtsn Apr 16, 2024
9686a74
Merge branch 'rz/feat/session-replay-breadcrumbs' into rz/feat/sessio…
romtsn Apr 16, 2024
e33b29c
Send temporary breadcrumbs and add test
romtsn Apr 18, 2024
27e17c1
Formatting
romtsn Apr 18, 2024
51cc432
Sort rrweb events
romtsn Apr 18, 2024
82680fb
Merge branch 'rz/feat/session-replay-breadcrumbs' into rz/feat/sessio…
romtsn Apr 18, 2024
4c7d1a0
Formatting
romtsn Apr 18, 2024
32fb5f0
Merge branch 'rz/feat/session-replay-breadcrumbs' into rz/feat/sessio…
romtsn Apr 18, 2024
c6b16ed
Expose replayCacheDir
romtsn Apr 18, 2024
6f3dc0a
Capture network requests
romtsn Apr 22, 2024
4c562fb
Change op name to resource.http
romtsn Apr 22, 2024
cd4fd9e
feat(replay): Add `sendReplay` method for Hybrid SDKs
krystofwoldrich Apr 23, 2024
e836f49
fix apiDump
krystofwoldrich Apr 23, 2024
4f240d4
Address PR review
romtsn Apr 23, 2024
12c0eb7
Merge pull request #3357 from getsentry/rz/feat/session-replay-captur…
romtsn Apr 25, 2024
db66737
[SR] Capture breadcrumbs (temporary)
romtsn Apr 25, 2024
33cd776
[SR] Expose public API for flutter
romtsn Apr 25, 2024
bdd9db5
[SR] Capture network requests
romtsn Apr 25, 2024
9295f0f
[SR] Add `sendReplay` method for Hybrid SDKs
romtsn Apr 25, 2024
f6b464b
Capture motion events as incremental rrweb events
romtsn Apr 25, 2024
2d508c9
Spotless
romtsn Apr 25, 2024
c0158eb
Merge branch 'rz/feat/session-replay' into rz/feat/session-replay-tou…
romtsn Apr 25, 2024
234b789
Revert
romtsn Apr 25, 2024
a68e88e
Merge branch 'main' into rz/feat/session-replay
romtsn Apr 26, 2024
b3ee659
Changelog
romtsn Apr 26, 2024
e89a3ef
release: 7.9.0-alpha.1
getsentry-bot Apr 26, 2024
2c0977b
Fix test
romtsn Apr 26, 2024
d4ac484
Merge branch 'release/7.9.0-alpha.1' into rz/feat/session-replay
Apr 26, 2024
5c05b6f
WIP
romtsn May 1, 2024
0476132
Adhere to rrweb move event expectations
romtsn May 2, 2024
7823d87
formatting
romtsn May 2, 2024
9596bb9
Align breadcrumbs with frontend and iOS
romtsn May 3, 2024
733b490
Add tests and fix deserialization
romtsn May 6, 2024
1217bb1
Rotate buffered motion events in buffer mode
romtsn May 6, 2024
647822c
Merge branch 'rz/feat/session-replay' into rz/feat/session-replay-tou…
romtsn May 6, 2024
6f83386
Merge branch 'rz/feat/session-replay-touch-events' into rz/feat/sessi…
romtsn May 6, 2024
69e5144
Add Nullables
romtsn May 29, 2024
a3d581c
Address PR feedback
romtsn May 29, 2024
d93e609
Formatting
romtsn May 29, 2024
0af0984
[SR] Capture gestures/motion events
romtsn May 29, 2024
5e119af
Merge branch 'rz/feat/session-replay' into rz/feat/session-replay-bre…
romtsn May 29, 2024
b9b78df
Rotate current events until segment end exclusively
romtsn May 29, 2024
50443a4
[SR] Align breadcrumbs with frontend (#3406)
romtsn May 29, 2024
f37c593
Allow rrweb breadcrumb customization from hybrid SDKs
romtsn May 30, 2024
730dc66
Fix proguard rules
romtsn Jun 3, 2024
69b23cc
WIP
romtsn Jun 3, 2024
c2dcad5
Add tests
romtsn Jun 3, 2024
d8fda33
Detect obscured views
romtsn Jun 7, 2024
26df8c6
revert some thigns
romtsn Jun 7, 2024
9c874d7
Remove commented code
romtsn Jun 7, 2024
db4ed1b
Merge branch 'rz/feat/session-replay-breadcrumbs-customizer' into rz/…
romtsn Jun 7, 2024
7b01de3
Suppress lint
romtsn Jun 10, 2024
aa2a5a9
Support multi-touch gestures
romtsn Jun 11, 2024
4aa50c2
Address PR feedback
romtsn Jun 18, 2024
11437d4
[SR] Allow RRWeb breadcrumb customization from hybrid SDKs
romtsn Jun 18, 2024
e3623e5
[SR] Redaction fixes part 1
romtsn Jun 18, 2024
5b412ae
Merge branch 'main' into rz/feat/session-replay
romtsn Jun 18, 2024
522b586
Changelog
romtsn Jun 18, 2024
263e147
release: 7.11.0-alpha.2
getsentry-bot Jun 18, 2024
a83b5d9
Merge branch 'release/7.11.0-alpha.2' into rz/feat/session-replay
Jun 18, 2024
9444da9
Make multi-touch work
romtsn Jun 18, 2024
54056cb
Fix tests
romtsn Jun 19, 2024
587b6d0
Merge branch 'rz/feat/session-replay' into rz/feat/session-replay-mul…
romtsn Jun 19, 2024
df7270e
WIP
romtsn Jun 20, 2024
53d5fbc
Capture screen names as urls for replay
romtsn Jun 21, 2024
a783326
Fix
romtsn Jun 21, 2024
01b7d67
Ignore warning
romtsn Jun 22, 2024
c832416
Address PR feedback
romtsn Jun 22, 2024
cfc52d9
[SR] Support multi-touch gestures
romtsn Jun 22, 2024
eef3c11
Tests
romtsn Jun 24, 2024
97d530c
Add quality settings
romtsn Jun 24, 2024
5557450
Fix redacting out of sync
romtsn Jun 24, 2024
213ff9e
Remove time measuring
romtsn Jul 2, 2024
fc7138b
Mark isEnableScreenTracking as experimental
romtsn Jul 2, 2024
d655d52
Format code
getsentry-bot Jul 2, 2024
a154cd0
Address PR feedback
romtsn Jul 2, 2024
2f727bc
[SR] Capture screen names as urls
romtsn Jul 2, 2024
17a4d22
[SR] Add quality settings
romtsn Jul 2, 2024
402587d
Clean up
romtsn Jul 2, 2024
71bdb5a
Spotless
romtsn Jul 2, 2024
a54f92f
[SR] Redaction fixes pt. 2
romtsn Jul 3, 2024
da59406
Merge branch 'main' into rz/feat/session-replay
romtsn Jul 3, 2024
67efa10
Format code
getsentry-bot Jul 3, 2024
89f5186
Changelog
romtsn Jul 3, 2024
befe3fe
release: 7.12.0-alpha.3
getsentry-bot Jul 3, 2024
615bb0e
Merge branch 'release/7.12.0-alpha.3' into rz/feat/session-replay
Jul 3, 2024
837e911
[SR] Add `redactClasses` option (#3546)
krystofwoldrich Jul 8, 2024
50c1d50
misc(changelog): Prepare for next alpha
krystofwoldrich Jul 9, 2024
361f73a
fix(changelog): Bump alpha version number
krystofwoldrich Jul 9, 2024
061ac4b
release: 7.12.0-alpha.4
getsentry-bot Jul 9, 2024
092f714
Merge branch 'release/7.12.0-alpha.4' into rz/feat/session-replay
Jul 9, 2024
6abb150
Redaction fixes for RN
romtsn Jul 11, 2024
9c13079
Add stopgap for offline session recording
romtsn Jul 12, 2024
7a9658d
Recycle unused bitmap
romtsn Jul 12, 2024
027a378
[SR] Redaction fixes for RN
romtsn Jul 12, 2024
5816d75
[SR] Add stopgap for offline session recording
romtsn Jul 12, 2024
ece807c
Add tests for sentry
romtsn Jul 12, 2024
9e625e7
Add ReplayIntegrationTest
romtsn Jul 12, 2024
91e3c61
Replay SmokeTest
romtsn Jul 15, 2024
3799a59
Fix test
romtsn Jul 15, 2024
f56d31f
Fix test
romtsn Jul 15, 2024
8060100
[SR] Add tests
romtsn Jul 15, 2024
dd3ef83
Fix events linking with buffered replays
romtsn Jul 15, 2024
cf43993
Changelog
romtsn Jul 15, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
12 changes: 12 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,17 @@
# Changelog

## 7.12.0-alpha.4

- Session Replay for Android ([#3339](https://github.com/getsentry/sentry-java/pull/3339))

We released our fifth Alpha version of the SDK with support. To get access, it requires adding your Sentry org to our feature flag. Please let us know on the [waitlist](https://sentry.io/lp/mobile-replay-beta/) if you're interested

## 7.12.0-alpha.3

- Session Replay for Android ([#3339](https://github.com/getsentry/sentry-java/pull/3339))

We released our fourth Alpha version of the SDK with support. To get access, it requires adding your Sentry org to our feature flag. Please let us know on the [waitlist](https://sentry.io/lp/mobile-replay-beta/) if you're interested

## 7.11.0

### Features
Expand Down
5 changes: 4 additions & 1 deletion build.gradle.kts
Original file line number Diff line number Diff line change
Expand Up @@ -112,6 +112,7 @@ subprojects {
"sentry-android-ndk",
"sentry-android-okhttp",
"sentry-android-sqlite",
"sentry-android-replay",
"sentry-android-timber"
)
if (jacocoAndroidModules.contains(name)) {
Expand Down Expand Up @@ -296,7 +297,9 @@ private val androidLibs = setOf(
"sentry-android-navigation",
"sentry-android-okhttp",
"sentry-android-timber",
"sentry-compose-android"
"sentry-compose-android",
"sentry-android-sqlite",
"sentry-android-replay"
)

private val androidXLibs = listOf(
Expand Down
2 changes: 2 additions & 0 deletions buildSrc/src/main/java/Config.kt
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@ object Config {

val minSdkVersion = 19
val minSdkVersionOkHttp = 21
val minSdkVersionReplay = 19
val minSdkVersionNdk = 19
val minSdkVersionCompose = 21
val targetSdkVersion = sdkVersion
Expand Down Expand Up @@ -194,6 +195,7 @@ object Config {
val jsonUnit = "net.javacrumbs.json-unit:json-unit:2.32.0"
val hsqldb = "org.hsqldb:hsqldb:2.6.1"
val javaFaker = "com.github.javafaker:javafaker:1.0.2"
val msgpack = "org.msgpack:msgpack-core:0.9.8"
}

object QualityPlugins {
Expand Down
2 changes: 1 addition & 1 deletion gradle.properties
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ android.useAndroidX=true
android.defaults.buildfeatures.buildconfig=true

# Release information
versionName=7.11.0
versionName=7.12.0-alpha.4

# Override the SDK name on native crashes on Android
sentryAndroidSdkName=sentry.native.android
Expand Down
2 changes: 2 additions & 0 deletions sentry-android-core/api/sentry-android-core.api
Original file line number Diff line number Diff line change
Expand Up @@ -184,9 +184,11 @@ public final class io/sentry/android/core/CurrentActivityIntegration : android/a
public final class io/sentry/android/core/DeviceInfoUtil {
public fun <init> (Landroid/content/Context;Lio/sentry/android/core/SentryAndroidOptions;)V
public fun collectDeviceInformation (ZZ)Lio/sentry/protocol/Device;
public static fun getBatteryLevel (Landroid/content/Intent;Lio/sentry/SentryOptions;)Ljava/lang/Float;
public static fun getInstance (Landroid/content/Context;Lio/sentry/android/core/SentryAndroidOptions;)Lio/sentry/android/core/DeviceInfoUtil;
public fun getOperatingSystem ()Lio/sentry/protocol/OperatingSystem;
public fun getSideLoadedInfo ()Lio/sentry/android/core/ContextUtils$SideLoadedInfo;
public static fun isCharging (Landroid/content/Intent;Lio/sentry/SentryOptions;)Ljava/lang/Boolean;
public static fun resetInstance ()V
}

Expand Down
2 changes: 2 additions & 0 deletions sentry-android-core/build.gradle.kts
Original file line number Diff line number Diff line change
Expand Up @@ -76,6 +76,7 @@ dependencies {
api(projects.sentry)
compileOnly(projects.sentryAndroidFragment)
compileOnly(projects.sentryAndroidTimber)
compileOnly(projects.sentryAndroidReplay)
compileOnly(projects.sentryCompose)
compileOnly(projects.sentryComposeHelper)

Expand Down Expand Up @@ -104,6 +105,7 @@ dependencies {
testImplementation(projects.sentryTestSupport)
testImplementation(projects.sentryAndroidFragment)
testImplementation(projects.sentryAndroidTimber)
testImplementation(projects.sentryAndroidReplay)
testImplementation(projects.sentryComposeHelper)
testImplementation(projects.sentryAndroidNdk)
testRuntimeOnly(Config.Libs.composeUi)
Expand Down
6 changes: 6 additions & 0 deletions sentry-android-core/proguard-rules.pro
Original file line number Diff line number Diff line change
Expand Up @@ -72,3 +72,9 @@
-keepnames class io.sentry.exception.SentryHttpClientException

##---------------End: proguard configuration for sentry-okhttp ----------

##---------------Begin: proguard configuration for sentry-android-replay ----------
-dontwarn io.sentry.android.replay.ReplayIntegration
-dontwarn io.sentry.android.replay.DefaultReplayBreadcrumbConverter
-keepnames class io.sentry.android.replay.ReplayIntegration
##---------------End: proguard configuration for sentry-android-replay ----------
Original file line number Diff line number Diff line change
Expand Up @@ -371,7 +371,7 @@ private void finishTransaction(
public synchronized void onActivityCreated(
final @NotNull Activity activity, final @Nullable Bundle savedInstanceState) {
setColdStart(savedInstanceState);
if (hub != null) {
if (hub != null && options != null && options.isEnableScreenTracking()) {
final @Nullable String activityClassName = ClassUtil.getClassName(activity);
hub.configureScope(scope -> scope.setScreen(activityClassName));
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,13 +22,16 @@
import io.sentry.android.core.internal.util.SentryFrameMetricsCollector;
import io.sentry.android.core.performance.AppStartMetrics;
import io.sentry.android.fragment.FragmentLifecycleIntegration;
import io.sentry.android.replay.DefaultReplayBreadcrumbConverter;
import io.sentry.android.replay.ReplayIntegration;
import io.sentry.android.timber.SentryTimberIntegration;
import io.sentry.cache.PersistingOptionsObserver;
import io.sentry.cache.PersistingScopeObserver;
import io.sentry.compose.gestures.ComposeGestureTargetLocator;
import io.sentry.compose.viewhierarchy.ComposeViewHierarchyExporter;
import io.sentry.internal.gestures.GestureTargetLocator;
import io.sentry.internal.viewhierarchy.ViewHierarchyExporter;
import io.sentry.transport.CurrentDateProvider;
import io.sentry.transport.NoOpEnvelopeCache;
import io.sentry.util.LazyEvaluator;
import io.sentry.util.Objects;
Expand Down Expand Up @@ -237,7 +240,8 @@ static void installDefaultIntegrations(
final @NotNull LoadClass loadClass,
final @NotNull ActivityFramesTracker activityFramesTracker,
final boolean isFragmentAvailable,
final boolean isTimberAvailable) {
final boolean isTimberAvailable,
final boolean isReplayAvailable) {

// Integration MUST NOT cache option values in ctor, as they will be configured later by the
// user
Expand Down Expand Up @@ -302,6 +306,13 @@ static void installDefaultIntegrations(
new NetworkBreadcrumbsIntegration(context, buildInfoProvider, options.getLogger()));
options.addIntegration(new TempSensorBreadcrumbsIntegration(context));
options.addIntegration(new PhoneStateBreadcrumbsIntegration(context));
if (isReplayAvailable) {
final ReplayIntegration replay =
new ReplayIntegration(context, CurrentDateProvider.getInstance());
replay.setBreadcrumbConverter(new DefaultReplayBreadcrumbConverter());
options.addIntegration(replay);
options.setReplayController(replay);
}
}

/**
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
import io.sentry.SentryBaseEvent;
import io.sentry.SentryEvent;
import io.sentry.SentryLevel;
import io.sentry.SentryReplayEvent;
import io.sentry.android.core.internal.util.AndroidMainThreadChecker;
import io.sentry.android.core.performance.AppStartMetrics;
import io.sentry.android.core.performance.TimeSpan;
Expand Down Expand Up @@ -303,4 +304,17 @@ private void setSideLoadedInfo(final @NotNull SentryBaseEvent event) {

return transaction;
}

@Override
public @NotNull SentryReplayEvent process(
final @NotNull SentryReplayEvent event, final @NotNull Hint hint) {
final boolean applyScopeData = shouldApplyScopeData(event, hint);
if (applyScopeData) {
processNonCachedEvent(event, hint);
}

setCommons(event, false, applyScopeData);

return event;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@
import android.util.DisplayMetrics;
import io.sentry.DateUtils;
import io.sentry.SentryLevel;
import io.sentry.SentryOptions;
import io.sentry.android.core.internal.util.CpuInfoUtils;
import io.sentry.android.core.internal.util.DeviceOrientations;
import io.sentry.android.core.internal.util.RootChecker;
Expand Down Expand Up @@ -184,8 +185,8 @@ public ContextUtils.SideLoadedInfo getSideLoadedInfo() {
private void setDeviceIO(final @NotNull Device device, final boolean includeDynamicData) {
final Intent batteryIntent = getBatteryIntent();
if (batteryIntent != null) {
device.setBatteryLevel(getBatteryLevel(batteryIntent));
device.setCharging(isCharging(batteryIntent));
device.setBatteryLevel(getBatteryLevel(batteryIntent, options));
device.setCharging(isCharging(batteryIntent, options));
device.setBatteryTemperature(getBatteryTemperature(batteryIntent));
}

Expand Down Expand Up @@ -270,7 +271,8 @@ private Intent getBatteryIntent() {
* @return the device's current battery level (as a percentage of total), or null if unknown
*/
@Nullable
private Float getBatteryLevel(final @NotNull Intent batteryIntent) {
public static Float getBatteryLevel(
final @NotNull Intent batteryIntent, final @NotNull SentryOptions options) {
try {
int level = batteryIntent.getIntExtra(BatteryManager.EXTRA_LEVEL, -1);
int scale = batteryIntent.getIntExtra(BatteryManager.EXTRA_SCALE, -1);
Expand All @@ -294,7 +296,8 @@ private Float getBatteryLevel(final @NotNull Intent batteryIntent) {
* @return whether or not the device is currently plugged in and charging, or null if unknown
*/
@Nullable
private Boolean isCharging(final @NotNull Intent batteryIntent) {
public static Boolean isCharging(
final @NotNull Intent batteryIntent, final @NotNull SentryOptions options) {
try {
int plugged = batteryIntent.getIntExtra(BatteryManager.EXTRA_PLUGGED, -1);
return plugged == BatteryManager.BATTERY_PLUGGED_AC
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
import io.sentry.transport.ICurrentDateProvider;
import java.util.Timer;
import java.util.TimerTask;
import java.util.concurrent.atomic.AtomicBoolean;
import java.util.concurrent.atomic.AtomicLong;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
Expand All @@ -19,11 +20,12 @@
final class LifecycleWatcher implements DefaultLifecycleObserver {

private final AtomicLong lastUpdatedSession = new AtomicLong(0L);
private final AtomicBoolean isFreshSession = new AtomicBoolean(false);

private final long sessionIntervalMillis;

private @Nullable TimerTask timerTask;
private final @Nullable Timer timer;
private final @NotNull Timer timer = new Timer(true);
private final @NotNull Object timerLock = new Object();
private final @NotNull IHub hub;
private final boolean enableSessionTracking;
Expand Down Expand Up @@ -55,11 +57,6 @@ final class LifecycleWatcher implements DefaultLifecycleObserver {
this.enableAppLifecycleBreadcrumbs = enableAppLifecycleBreadcrumbs;
this.hub = hub;
this.currentDateProvider = currentDateProvider;
if (enableSessionTracking) {
timer = new Timer(true);
} else {
timer = null;
}
}

// App goes to foreground
Expand All @@ -74,41 +71,46 @@ public void onStart(final @NotNull LifecycleOwner owner) {
}

private void startSession() {
if (enableSessionTracking) {
cancelTask();
cancelTask();

final long currentTimeMillis = currentDateProvider.getCurrentTimeMillis();
final long currentTimeMillis = currentDateProvider.getCurrentTimeMillis();

hub.configureScope(
scope -> {
if (lastUpdatedSession.get() == 0L) {
final @Nullable Session currentSession = scope.getSession();
if (currentSession != null && currentSession.getStarted() != null) {
lastUpdatedSession.set(currentSession.getStarted().getTime());
}
hub.configureScope(
scope -> {
if (lastUpdatedSession.get() == 0L) {
final @Nullable Session currentSession = scope.getSession();
if (currentSession != null && currentSession.getStarted() != null) {
lastUpdatedSession.set(currentSession.getStarted().getTime());
isFreshSession.set(true);
}
});
}
});

final long lastUpdatedSession = this.lastUpdatedSession.get();
if (lastUpdatedSession == 0L
|| (lastUpdatedSession + sessionIntervalMillis) <= currentTimeMillis) {
final long lastUpdatedSession = this.lastUpdatedSession.get();
if (lastUpdatedSession == 0L
|| (lastUpdatedSession + sessionIntervalMillis) <= currentTimeMillis) {
if (enableSessionTracking) {
addSessionBreadcrumb("start");
hub.startSession();
}
this.lastUpdatedSession.set(currentTimeMillis);
hub.getOptions().getReplayController().start();
} else if (!isFreshSession.get()) {
// only resume if it's not a fresh session, which has been started in SentryAndroid.init
hub.getOptions().getReplayController().resume();
}
isFreshSession.set(false);
this.lastUpdatedSession.set(currentTimeMillis);
}

// App went to background and triggered this callback after 700ms
// as no new screen was shown
@Override
public void onStop(final @NotNull LifecycleOwner owner) {
if (enableSessionTracking) {
final long currentTimeMillis = currentDateProvider.getCurrentTimeMillis();
this.lastUpdatedSession.set(currentTimeMillis);
final long currentTimeMillis = currentDateProvider.getCurrentTimeMillis();
this.lastUpdatedSession.set(currentTimeMillis);

scheduleEndSession();
}
hub.getOptions().getReplayController().pause();
scheduleEndSession();

AppState.getInstance().setInBackground(true);
addAppBreadcrumb("background");
Expand All @@ -122,8 +124,11 @@ private void scheduleEndSession() {
new TimerTask() {
@Override
public void run() {
addSessionBreadcrumb("end");
hub.endSession();
if (enableSessionTracking) {
addSessionBreadcrumb("end");
hub.endSession();
}
hub.getOptions().getReplayController().stop();
}
};

Expand Down Expand Up @@ -164,7 +169,7 @@ TimerTask getTimerTask() {
}

@TestOnly
@Nullable
@NotNull
Timer getTimer() {
return timer;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -104,6 +104,14 @@ final class ManifestMetadataReader {

static final String ENABLE_METRICS = "io.sentry.enable-metrics";

static final String REPLAYS_SESSION_SAMPLE_RATE = "io.sentry.session-replay.session-sample-rate";

static final String REPLAYS_ERROR_SAMPLE_RATE = "io.sentry.session-replay.error-sample-rate";

static final String REPLAYS_REDACT_ALL_TEXT = "io.sentry.session-replay.redact-all-text";

static final String REPLAYS_REDACT_ALL_IMAGES = "io.sentry.session-replay.redact-all-images";

/** ManifestMetadataReader ctor */
private ManifestMetadataReader() {}

Expand Down Expand Up @@ -382,6 +390,41 @@ static void applyMetadata(

options.setEnableMetrics(
readBool(metadata, logger, ENABLE_METRICS, options.isEnableMetrics()));

if (options.getExperimental().getSessionReplay().getSessionSampleRate() == null) {
final Double sessionSampleRate =
readDouble(metadata, logger, REPLAYS_SESSION_SAMPLE_RATE);
if (sessionSampleRate != -1) {
options.getExperimental().getSessionReplay().setSessionSampleRate(sessionSampleRate);
}
}

if (options.getExperimental().getSessionReplay().getErrorSampleRate() == null) {
final Double errorSampleRate = readDouble(metadata, logger, REPLAYS_ERROR_SAMPLE_RATE);
if (errorSampleRate != -1) {
options.getExperimental().getSessionReplay().setErrorSampleRate(errorSampleRate);
}
}

options
.getExperimental()
.getSessionReplay()
.setRedactAllText(
readBool(
metadata,
logger,
REPLAYS_REDACT_ALL_TEXT,
options.getExperimental().getSessionReplay().getRedactAllText()));

options
.getExperimental()
.getSessionReplay()
.setRedactAllImages(
readBool(
metadata,
logger,
REPLAYS_REDACT_ALL_IMAGES,
options.getExperimental().getSessionReplay().getRedactAllImages()));
}

options
Expand Down
Loading
Loading