Configure Sentry with more information (#1782)

* build-logic: remove error path in Sentry plugin

* gradle: fix UnstableApiUsage warning

* build-logic: configure Sentry Gradle Plugin

* app: set traces sample-rate to 1.0

* sentry-stub: init

* app: populate Sentry user field with feature flags
This commit is contained in:
Harsh Shandilya 2022-03-13 17:41:01 +05:30 committed by GitHub
parent 20725219bd
commit 861ca58a58
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
14 changed files with 76 additions and 8 deletions

View file

@ -101,6 +101,7 @@ dependencies {
debugImplementation(libs.thirdparty.leakcanary)
add("nonFreeImplementation", libs.thirdparty.nonfree.googlePlayAuthApiPhone)
add("nonFreeImplementation", libs.thirdparty.nonfree.sentry)
add("freeImplementation", projects.sentryStub)
androidTestImplementation(libs.bundles.testDependencies)
androidTestImplementation(libs.bundles.androidTestDependencies)

View file

@ -15,11 +15,15 @@ import dagger.hilt.android.HiltAndroidApp
import dev.msfjarvis.aps.injection.context.FilesDirPath
import dev.msfjarvis.aps.injection.prefs.SettingsPreferences
import dev.msfjarvis.aps.util.extensions.getString
import dev.msfjarvis.aps.util.features.Feature
import dev.msfjarvis.aps.util.features.Features
import dev.msfjarvis.aps.util.git.sshj.setUpBouncyCastleForSshj
import dev.msfjarvis.aps.util.proxy.ProxyUtils
import dev.msfjarvis.aps.util.settings.GitSettings
import dev.msfjarvis.aps.util.settings.PreferenceKeys
import dev.msfjarvis.aps.util.settings.runMigrations
import io.sentry.Sentry
import io.sentry.protocol.User
import javax.inject.Inject
import logcat.AndroidLogcatLogger
import logcat.LogPriority.DEBUG
@ -33,6 +37,7 @@ class Application : android.app.Application(), SharedPreferences.OnSharedPrefere
@Inject @FilesDirPath lateinit var filesDirPath: String
@Inject lateinit var proxyUtils: ProxyUtils
@Inject lateinit var gitSettings: GitSettings
@Inject lateinit var features: Features
override fun onCreate() {
super.onCreate()
@ -48,6 +53,14 @@ class Application : android.app.Application(), SharedPreferences.OnSharedPrefere
runMigrations(filesDirPath, prefs, gitSettings)
proxyUtils.setDefaultProxy()
DynamicColors.applyToActivitiesIfAvailable(this)
Sentry.configureScope { scope ->
val user = User()
user.others =
Feature.VALUES.associate { feature ->
"features.${feature.configKey}" to features.isEnabled(feature).toString()
}
scope.user = user
}
}
override fun onTerminate() {

View file

@ -15,4 +15,9 @@ enum class Feature(
/** Opt into the new PGP backend powered by the PGPainless library. */
EnablePGPainlessBackend(false, "enable_pgp_v2_backend"),
;
companion object {
@JvmField val VALUES = values()
}
}

View file

@ -6,6 +6,6 @@
<manifest xmlns:android="http://schemas.android.com/apk/res/android">
<application>
<meta-data android:name="io.sentry.dsn" android:value="${sentryDsn}" />
<meta-data android:name="io.sentry.traces.sample-rate" android:value="0.0" />
<meta-data android:name="io.sentry.traces.sample-rate" android:value="1.0" />
</application>
</manifest>

View file

@ -35,4 +35,5 @@ dependencies {
implementation(libs.build.dokka)
implementation(libs.build.mavenpublish)
implementation(libs.build.semver)
implementation(libs.build.sentry)
}

View file

@ -2,11 +2,14 @@
import flavors.FlavorDimensions
import flavors.ProductFlavors
import io.sentry.android.gradle.InstrumentationFeature
plugins { id("com.android.application") }
plugins {
id("com.android.application")
id("io.sentry.android.gradle")
}
val SENTRY_DSN_PROPERTY = "SENTRY_DSN"
val INVOKED_FROM_IDE_PROPERTY = "android.injected.invoked.from.ide"
android {
androidComponents {
@ -14,12 +17,17 @@ android {
val sentryDsn = project.providers.environmentVariable(SENTRY_DSN_PROPERTY)
if (sentryDsn.isPresent) {
variant.manifestPlaceholders.put("sentryDsn", sentryDsn.get())
} else if (project.providers.gradleProperty(INVOKED_FROM_IDE_PROPERTY).orNull != "true") {
// Checking for 'INVOKED_FROM_IDE_PROPERTY' prevents failures during Gradle sync by the IDE
throw GradleException(
"The '${SENTRY_DSN_PROPERTY}' environment variable must be set when building the ${ProductFlavors.NON_FREE} flavor"
)
}
}
}
}
sentry {
autoUploadProguardMapping.set(true)
ignoredBuildTypes.set(setOf("debug"))
ignoredFlavors.set(setOf(ProductFlavors.FREE))
tracingInstrumentation {
enabled.set(true)
features.set(setOf(InstrumentationFeature.FILE_IO))
}
}

View file

@ -16,6 +16,7 @@ apiValidation {
"format-common",
"diceware",
"random",
"sentry-stub",
"ui-compose",
)
}

View file

@ -2,6 +2,7 @@
* Copyright © 2014-2021 The Android Password Store Authors. All Rights Reserved.
* SPDX-License-Identifier: GPL-3.0-only
*/
@file:Suppress("UnstableApiUsage")
rootProject.name = "build-logic"

View file

@ -50,6 +50,7 @@ build-mavenpublish = "com.vanniktech:gradle-maven-publish-plugin:0.19.0"
build-okhttp = "com.squareup.okhttp3:okhttp:4.9.3"
build-r8 = "com.android.tools:r8:3.3.15-dev"
build-semver = "com.vdurmont:semver4j:3.1.0"
build-sentry = "io.sentry.android.gradle:io.sentry.android.gradle.gradle.plugin:3.0.0-rc.3"
build-spotless = "com.diffplug.spotless:spotless-plugin-gradle:6.3.0"
dagger-hilt-android = { module = "com.google.dagger:hilt-android", version.ref = "hilt" }

View file

@ -0,0 +1,4 @@
plugins {
kotlin("jvm")
id("com.github.android-password-store.kotlin-library")
}

View file

@ -0,0 +1,10 @@
@file:Suppress("Unused", "UNUSED_PARAMETER")
package io.sentry
import io.sentry.protocol.User
public class Scope {
public var user: User? = null
public fun setTag(tag: String, value: String) {}
}

View file

@ -0,0 +1,8 @@
@file:Suppress("Unused", "UNUSED_PARAMETER")
package io.sentry
/** Stubs for the Sentry SDK */
public object Sentry {
public fun configureScope(callback: (Scope) -> Unit) {}
}

View file

@ -0,0 +1,12 @@
@file:Suppress("Unused", "UNUSED_PARAMETER")
package io.sentry.protocol
public data class User(
public var email: String? = null,
public var id: String? = null,
public var username: String? = null,
public var ipAddress: String? = null,
public var others: Map<String?, String>? = null,
public var unknown: Map<String?, String>? = null,
)

View file

@ -2,6 +2,7 @@
* Copyright © 2014-2021 The Android Password Store Authors. All Rights Reserved.
* SPDX-License-Identifier: GPL-3.0-only
*/
@file:Suppress("UnstableApiUsage")
rootProject.name = "APS"
@ -54,4 +55,6 @@ include("passgen:diceware")
include("passgen:random")
include("sentry-stub")
include("ui-compose")