From 2d03936b4f511c0e70a594a693f600ebd164acb3 Mon Sep 17 00:00:00 2001 From: jonathanmos <48201295+jonathanmos@users.noreply.github.com> Date: Mon, 14 Oct 2024 12:31:20 +0300 Subject: [PATCH] Add rule to prevent obfuscation of fgm enums --- .../dd-sdk-android-session-replay/api/apiSurface | 7 ++++--- .../api/dd-sdk-android-session-replay.api | 9 ++++++--- .../dd-sdk-android-session-replay/consumer-rules.pro | 3 +++ .../datadog/android/sessionreplay/ImagePrivacy.kt | 2 +- .../datadog/android/sessionreplay/PrivacyLevel.kt | 12 ++++++++++++ .../android/sessionreplay/TextAndInputPrivacy.kt | 2 +- .../datadog/android/sessionreplay/TouchPrivacy.kt | 2 +- 7 files changed, 28 insertions(+), 9 deletions(-) create mode 100644 features/dd-sdk-android-session-replay/src/main/kotlin/com/datadog/android/sessionreplay/PrivacyLevel.kt diff --git a/features/dd-sdk-android-session-replay/api/apiSurface b/features/dd-sdk-android-session-replay/api/apiSurface index 6d8826ca40..81ec329a4b 100644 --- a/features/dd-sdk-android-session-replay/api/apiSurface +++ b/features/dd-sdk-android-session-replay/api/apiSurface @@ -1,7 +1,7 @@ interface com.datadog.android.sessionreplay.ExtensionSupport fun getCustomViewMappers(): List> fun getOptionSelectorDetectors(): List -enum com.datadog.android.sessionreplay.ImagePrivacy +enum com.datadog.android.sessionreplay.ImagePrivacy : PrivacyLevel - MASK_NONE - MASK_LARGE_ONLY - MASK_ALL @@ -9,6 +9,7 @@ data class com.datadog.android.sessionreplay.MapperTypeWrapper, com.datadog.android.sessionreplay.recorder.mapper.WireframeMapper) fun supportsView(android.view.View): Boolean fun getUnsafeMapper(): com.datadog.android.sessionreplay.recorder.mapper.WireframeMapper +interface com.datadog.android.sessionreplay.PrivacyLevel fun android.view.View.setSessionReplayHidden(Boolean) fun android.view.View.setSessionReplayImagePrivacy(ImagePrivacy?) fun android.view.View.setSessionReplayTextAndInputPrivacy(TextAndInputPrivacy?) @@ -41,11 +42,11 @@ class com.datadog.android.sessionreplay.SystemRequirementsConfiguration companion object val BASIC: SystemRequirementsConfiguration val NONE: SystemRequirementsConfiguration -enum com.datadog.android.sessionreplay.TextAndInputPrivacy +enum com.datadog.android.sessionreplay.TextAndInputPrivacy : PrivacyLevel - MASK_SENSITIVE_INPUTS - MASK_ALL_INPUTS - MASK_ALL -enum com.datadog.android.sessionreplay.TouchPrivacy +enum com.datadog.android.sessionreplay.TouchPrivacy : PrivacyLevel - SHOW - HIDE data class com.datadog.android.sessionreplay.recorder.MappingContext diff --git a/features/dd-sdk-android-session-replay/api/dd-sdk-android-session-replay.api b/features/dd-sdk-android-session-replay/api/dd-sdk-android-session-replay.api index 40ec44e26e..7b04236aa1 100644 --- a/features/dd-sdk-android-session-replay/api/dd-sdk-android-session-replay.api +++ b/features/dd-sdk-android-session-replay/api/dd-sdk-android-session-replay.api @@ -3,7 +3,7 @@ public abstract interface class com/datadog/android/sessionreplay/ExtensionSuppo public abstract fun getOptionSelectorDetectors ()Ljava/util/List; } -public final class com/datadog/android/sessionreplay/ImagePrivacy : java/lang/Enum { +public final class com/datadog/android/sessionreplay/ImagePrivacy : java/lang/Enum, com/datadog/android/sessionreplay/PrivacyLevel { public static final field MASK_ALL Lcom/datadog/android/sessionreplay/ImagePrivacy; public static final field MASK_LARGE_ONLY Lcom/datadog/android/sessionreplay/ImagePrivacy; public static final field MASK_NONE Lcom/datadog/android/sessionreplay/ImagePrivacy; @@ -22,6 +22,9 @@ public final class com/datadog/android/sessionreplay/MapperTypeWrapper { public fun toString ()Ljava/lang/String; } +public abstract interface class com/datadog/android/sessionreplay/PrivacyLevel { +} + public final class com/datadog/android/sessionreplay/PrivacyOverrideExtensionsKt { public static final fun setSessionReplayHidden (Landroid/view/View;Z)V public static final fun setSessionReplayImagePrivacy (Landroid/view/View;Lcom/datadog/android/sessionreplay/ImagePrivacy;)V @@ -85,7 +88,7 @@ public final class com/datadog/android/sessionreplay/SystemRequirementsConfigura public final fun getNONE ()Lcom/datadog/android/sessionreplay/SystemRequirementsConfiguration; } -public final class com/datadog/android/sessionreplay/TextAndInputPrivacy : java/lang/Enum { +public final class com/datadog/android/sessionreplay/TextAndInputPrivacy : java/lang/Enum, com/datadog/android/sessionreplay/PrivacyLevel { public static final field MASK_ALL Lcom/datadog/android/sessionreplay/TextAndInputPrivacy; public static final field MASK_ALL_INPUTS Lcom/datadog/android/sessionreplay/TextAndInputPrivacy; public static final field MASK_SENSITIVE_INPUTS Lcom/datadog/android/sessionreplay/TextAndInputPrivacy; @@ -93,7 +96,7 @@ public final class com/datadog/android/sessionreplay/TextAndInputPrivacy : java/ public static fun values ()[Lcom/datadog/android/sessionreplay/TextAndInputPrivacy; } -public final class com/datadog/android/sessionreplay/TouchPrivacy : java/lang/Enum { +public final class com/datadog/android/sessionreplay/TouchPrivacy : java/lang/Enum, com/datadog/android/sessionreplay/PrivacyLevel { public static final field HIDE Lcom/datadog/android/sessionreplay/TouchPrivacy; public static final field SHOW Lcom/datadog/android/sessionreplay/TouchPrivacy; public static fun valueOf (Ljava/lang/String;)Lcom/datadog/android/sessionreplay/TouchPrivacy; diff --git a/features/dd-sdk-android-session-replay/consumer-rules.pro b/features/dd-sdk-android-session-replay/consumer-rules.pro index e511394ccc..0276df9fec 100644 --- a/features/dd-sdk-android-session-replay/consumer-rules.pro +++ b/features/dd-sdk-android-session-replay/consumer-rules.pro @@ -7,3 +7,6 @@ -keepnames class com.datadog.android.sessionreplay.internal.recorder.listener.WindowsOnDrawListener -keepnames class * extends com.datadog.android.sessionreplay.recorder.mapper.WireframeMapper -keepnames class * extends com.datadog.android.sessionreplay.internal.async.RecordedDataQueueItem + +# Keep the fine grained masking level enums +-keepnames enum * extends com.datadog.android.sessionreplay.PrivacyLevel { *; } diff --git a/features/dd-sdk-android-session-replay/src/main/kotlin/com/datadog/android/sessionreplay/ImagePrivacy.kt b/features/dd-sdk-android-session-replay/src/main/kotlin/com/datadog/android/sessionreplay/ImagePrivacy.kt index 9d4c535c49..13f5f83f07 100644 --- a/features/dd-sdk-android-session-replay/src/main/kotlin/com/datadog/android/sessionreplay/ImagePrivacy.kt +++ b/features/dd-sdk-android-session-replay/src/main/kotlin/com/datadog/android/sessionreplay/ImagePrivacy.kt @@ -12,7 +12,7 @@ package com.datadog.android.sessionreplay * @see ImagePrivacy.MASK_LARGE_ONLY * @see ImagePrivacy.MASK_ALL */ -enum class ImagePrivacy { +enum class ImagePrivacy : PrivacyLevel { /** * All images will be recorded, including those downloaded from the Internet during app runtime. */ diff --git a/features/dd-sdk-android-session-replay/src/main/kotlin/com/datadog/android/sessionreplay/PrivacyLevel.kt b/features/dd-sdk-android-session-replay/src/main/kotlin/com/datadog/android/sessionreplay/PrivacyLevel.kt new file mode 100644 index 0000000000..6b9899172a --- /dev/null +++ b/features/dd-sdk-android-session-replay/src/main/kotlin/com/datadog/android/sessionreplay/PrivacyLevel.kt @@ -0,0 +1,12 @@ +/* + * Unless explicitly stated otherwise all files in this repository are licensed under the Apache License Version 2.0. + * This product includes software developed at Datadog (https://www.datadoghq.com/). + * Copyright 2016-Present Datadog, Inc. + */ + +package com.datadog.android.sessionreplay + +/** + * Base interface for privacy masking levels. + */ +interface PrivacyLevel diff --git a/features/dd-sdk-android-session-replay/src/main/kotlin/com/datadog/android/sessionreplay/TextAndInputPrivacy.kt b/features/dd-sdk-android-session-replay/src/main/kotlin/com/datadog/android/sessionreplay/TextAndInputPrivacy.kt index 6825c465b6..2bcd4d22bd 100644 --- a/features/dd-sdk-android-session-replay/src/main/kotlin/com/datadog/android/sessionreplay/TextAndInputPrivacy.kt +++ b/features/dd-sdk-android-session-replay/src/main/kotlin/com/datadog/android/sessionreplay/TextAndInputPrivacy.kt @@ -12,7 +12,7 @@ package com.datadog.android.sessionreplay * @see TextAndInputPrivacy.MASK_ALL_INPUTS * @see TextAndInputPrivacy.MASK_ALL */ -enum class TextAndInputPrivacy { +enum class TextAndInputPrivacy : PrivacyLevel { /** * All text and inputs considered sensitive will be masked. diff --git a/features/dd-sdk-android-session-replay/src/main/kotlin/com/datadog/android/sessionreplay/TouchPrivacy.kt b/features/dd-sdk-android-session-replay/src/main/kotlin/com/datadog/android/sessionreplay/TouchPrivacy.kt index 5c7eeb1d1f..b89dfc4e57 100644 --- a/features/dd-sdk-android-session-replay/src/main/kotlin/com/datadog/android/sessionreplay/TouchPrivacy.kt +++ b/features/dd-sdk-android-session-replay/src/main/kotlin/com/datadog/android/sessionreplay/TouchPrivacy.kt @@ -11,7 +11,7 @@ package com.datadog.android.sessionreplay * @see TouchPrivacy.SHOW * @see TouchPrivacy.HIDE */ -enum class TouchPrivacy { +enum class TouchPrivacy : PrivacyLevel { /** * All touch interactions will be recorded. */