summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorJason A. Donenfeld <Jason@zx2c4.com>2018-07-26 13:28:34 +0200
committerJason A. Donenfeld <Jason@zx2c4.com>2018-07-26 13:46:18 +0200
commit520df168854bc9d39fdaab18de6b658fd3cfacec (patch)
tree82a3980e8374671f887ee0ae0eeaa789b1d601b0
parentc905ef6083a090a0917627c30fdd712377c04831 (diff)
Set ACRA install source
Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
-rw-r--r--app/src/main/java/com/wireguard/android/Application.java23
1 files changed, 15 insertions, 8 deletions
diff --git a/app/src/main/java/com/wireguard/android/Application.java b/app/src/main/java/com/wireguard/android/Application.java
index 8dff8a54..7218c606 100644
--- a/app/src/main/java/com/wireguard/android/Application.java
+++ b/app/src/main/java/com/wireguard/android/Application.java
@@ -69,9 +69,10 @@ public class Application extends android.app.Application {
* check the DN of the certs that signed the apk, without even bothering to try
* validating that they're authentic. It's a good enough heuristic.
*/
- private static boolean shouldEnableCrashReporting(final Context context) {
+ @Nullable
+ private static String getInstallSource(final Context context) {
if (BuildConfig.DEBUG)
- return false;
+ return null;
try {
final CertificateFactory cf = CertificateFactory.getInstance("X509");
for (final Signature sig : context.getPackageManager().getPackageInfo(context.getPackageName(), PackageManager.GET_SIGNATURES).signatures) {
@@ -82,21 +83,25 @@ public class Application extends android.app.Application {
continue;
switch (parts[1]) {
case "Google Inc.":
+ return "Play Store";
case "fdroid.org":
- return true;
+ return "F-Droid";
}
}
} catch (final Exception ignored) { }
}
} catch (final Exception ignored) { }
- return false;
+ return null;
}
@Override
protected void attachBaseContext(final Context context) {
super.attachBaseContext(context);
- if (shouldEnableCrashReporting(context))
+ final String installSource = getInstallSource(context);
+ if (installSource != null) {
ACRA.init(this);
+ ACRA.getErrorReporter().putCustomData("installSource", installSource);
+ }
}
public static Application get() {
@@ -165,9 +170,11 @@ public class Application extends android.app.Application {
asyncWorker.supplyAsync(Application::getBackend).thenAccept(backend -> {
futureBackend.complete(backend);
- ACRA.getErrorReporter().putCustomData("backend", backend.getClass().getSimpleName());
- asyncWorker.supplyAsync(backend::getVersion).thenAccept(version ->
- ACRA.getErrorReporter().putCustomData("backendVersion", version));
+ if (ACRA.isInitialised()) {
+ ACRA.getErrorReporter().putCustomData("backend", backend.getClass().getSimpleName());
+ asyncWorker.supplyAsync(backend::getVersion).thenAccept(version ->
+ ACRA.getErrorReporter().putCustomData("backendVersion", version));
+ }
});
}
}