正在查看: Barstool v5.21.2 应用的 AnrPlugin.java JAVA 源代码文件
本页面展示 JAVA 反编译生成的源代码文件,支持语法高亮显示。 仅供安全研究与技术分析使用,严禁用于任何非法用途。请遵守相关法律法规。
正在查看: Barstool v5.21.2 应用的 AnrPlugin.java JAVA 源代码文件
本页面展示 JAVA 反编译生成的源代码文件,支持语法高亮显示。 仅供安全研究与技术分析使用,严禁用于任何非法用途。请遵守相关法律法规。
package com.bugsnag.android;
import android.os.Handler;
import android.os.Looper;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.concurrent.atomic.AtomicBoolean;
import kotlin.collections.ArraysKt;
import kotlin.collections.CollectionsKt;
import kotlin.jvm.internal.DefaultConstructorMarker;
@kotlin.Metadata(d1 = {"\u0000N\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0000\n\u0002\u0010\u0002\n\u0002\b\u0004\n\u0002\u0018\u0002\n\u0000\n\u0002\u0010\u000e\n\u0002\b\u0002\n\u0002\u0010 \n\u0002\u0018\u0002\n\u0002\b\u0003\n\u0002\u0010\t\n\u0002\b\u0003\b\u0000\u0018\u0000 \u001d2\u00020\u0001:\u0001\u001dB\u0005¢\u0006\u0002\u0010\u0002J\t\u0010\u000b\u001a\u00020\fH\u0082 J\t\u0010\r\u001a\u00020\fH\u0082 J\b\u0010\u000e\u001a\u00020\fH\u0002J\u0010\u0010\u000f\u001a\u00020\f2\u0006\u0010\u0003\u001a\u00020\u0004H\u0016J\u0016\u0010\u0010\u001a\b\u0012\u0002\b\u0003\u0018\u00010\u00112\u0006\u0010\u0012\u001a\u00020\u0013H\u0002J\u0016\u0010\u0014\u001a\u00020\f2\f\u0010\u0015\u001a\b\u0012\u0004\u0012\u00020\u00170\u0016H\u0002J\u0010\u0010\u0018\u001a\u00020\f2\u0006\u0010\u0003\u001a\u00020\u0004H\u0002J\u0011\u0010\u0019\u001a\u00020\f2\u0006\u0010\u001a\u001a\u00020\u001bH\u0082 J\b\u0010\u001c\u001a\u00020\fH\u0016R\u000e\u0010\u0003\u001a\u00020\u0004X\u0082.¢\u0006\u0002\n\u0000R\u000e\u0010\u0005\u001a\u00020\u0006X\u0082\u0004¢\u0006\u0002\n\u0000R\u000e\u0010\u0007\u001a\u00020\bX\u0082\u0004¢\u0006\u0002\n\u0000R\u000e\u0010\t\u001a\u00020\nX\u0082\u0004¢\u0006\u0002\n\u0000¨\u0006\u001e"}, d2 = {"Lcom/bugsnag/android/AnrPlugin;", "Lcom/bugsnag/android/Plugin;", "()V", "client", "Lcom/bugsnag/android/Client;", "collector", "Lcom/bugsnag/android/AnrDetailsCollector;", "libraryLoader", "Lcom/bugsnag/android/LibraryLoader;", "oneTimeSetupPerformed", "Ljava/util/concurrent/atomic/AtomicBoolean;", "disableAnrReporting", "", "enableAnrReporting", "initNativePlugin", "load", "loadClass", "Ljava/lang/Class;", "clz", "", "notifyAnrDetected", "nativeTrace", "", "Lcom/bugsnag/android/NativeStackframe;", "performOneTimeSetup", "setUnwindFunction", "unwindFunction", "", "unload", "Companion", "bugsnag-plugin-android-anr_release"}, k = 1, mv = {1, 5, 1}, xi = 48)
public final class AnrPlugin implements Plugin {
private static final String ANR_ERROR_CLASS = "ANR";
private static final String ANR_ERROR_MSG = "Application did not respond to UI input";
public static final Companion INSTANCE = new Companion(null);
private static final String LOAD_ERR_MSG = "Native library could not be linked. Bugsnag will not report ANRs. See https://docs.bugsnag.com/platforms/android/anr-link-errors";
private Client client;
private final LibraryLoader libraryLoader = new LibraryLoader();
private final AtomicBoolean oneTimeSetupPerformed = new AtomicBoolean(false);
private final AnrDetailsCollector collector = new AnrDetailsCollector();
private final native void disableAnrReporting();
private final native void enableAnrReporting();
private final native void setUnwindFunction(long unwindFunction);
@kotlin.Metadata(d1 = {"\u0000&\n\u0002\u0018\u0002\n\u0002\u0010\u0000\n\u0002\b\u0002\n\u0002\u0010\u000e\n\u0002\b\u0003\n\u0002\u0010\u000b\n\u0000\n\u0002\u0010\u0011\n\u0002\u0018\u0002\n\u0002\b\u0003\b\u0080\u0003\u0018\u00002\u00020\u0001B\u0007\b\u0002¢\u0006\u0002\u0010\u0002J\u001d\u0010\u0007\u001a\u00020\b2\f\u0010\t\u001a\b\u0012\u0004\u0012\u00020\u000b0\nH\u0000¢\u0006\u0004\b\f\u0010\rR\u000e\u0010\u0003\u001a\u00020\u0004X\u0082T¢\u0006\u0002\n\u0000R\u000e\u0010\u0005\u001a\u00020\u0004X\u0082T¢\u0006\u0002\n\u0000R\u000e\u0010\u0006\u001a\u00020\u0004X\u0082T¢\u0006\u0002\n\u0000¨\u0006\u000e"}, d2 = {"Lcom/bugsnag/android/AnrPlugin$Companion;", "", "()V", "ANR_ERROR_CLASS", "", "ANR_ERROR_MSG", "LOAD_ERR_MSG", "doesJavaTraceLeadToNativeTrace", "", "javaTrace", "", "Ljava/lang/StackTraceElement;", "doesJavaTraceLeadToNativeTrace$bugsnag_plugin_android_anr_release", "([Ljava/lang/StackTraceElement;)Z", "bugsnag-plugin-android-anr_release"}, k = 1, mv = {1, 5, 1}, xi = 48)
public static final class Companion {
public Companion(DefaultConstructorMarker defaultConstructorMarker) {
this();
}
private Companion() {
}
public final boolean doesJavaTraceLeadToNativeTrace$bugsnag_plugin_android_anr_release(StackTraceElement[] javaTrace) {
if (javaTrace.length == 0) {
return false;
}
return ((StackTraceElement) ArraysKt.first(javaTrace)).isNativeMethod();
}
}
private final Class<?> loadClass(String clz) {
try {
return Class.forName(clz);
} catch (Throwable unused) {
return null;
}
}
@Override
public void load(Client client) {
this.client = client;
if (!this.oneTimeSetupPerformed.getAndSet(true)) {
performOneTimeSetup(client);
}
if (this.libraryLoader.isLoaded()) {
Looper mainLooper = Looper.getMainLooper();
if (kotlin.jvm.internal.Intrinsics.areEqual(Looper.myLooper(), mainLooper)) {
initNativePlugin();
return;
} else {
new Handler(mainLooper).postAtFrontOfQueue(new Runnable() {
@Override
public final void run() {
AnrPlugin.this.initNativePlugin();
}
});
return;
}
}
client.logger.e(LOAD_ERR_MSG);
}
public final void initNativePlugin() {
enableAnrReporting();
Client client = this.client;
if (client == null) {
kotlin.jvm.internal.Intrinsics.throwUninitializedPropertyAccessException("client");
client = null;
}
client.logger.i("Initialised ANR Plugin");
}
private final void performOneTimeSetup(Client client) {
Class<?> loadClass;
Plugin plugin;
if (!this.libraryLoader.loadLibrary("bugsnag-plugin-android-anr", client, new OnErrorCallback() {
@Override
public final boolean onError(Event event) {
boolean m636performOneTimeSetup$lambda1;
m636performOneTimeSetup$lambda1 = AnrPlugin.m636performOneTimeSetup$lambda1(event);
return m636performOneTimeSetup$lambda1;
}
}) || (loadClass = loadClass("com.bugsnag.android.NdkPlugin")) == null || (plugin = client.getPlugin(loadClass)) == null) {
return;
}
Object invoke = plugin.getClass().getMethod("getSignalUnwindStackFunction", new Class[0]).invoke(plugin, new Object[0]);
if (invoke == null) {
throw new NullPointerException("null cannot be cast to non-null type kotlin.Long");
}
setUnwindFunction(((Long) invoke).longValue());
}
public static final boolean m636performOneTimeSetup$lambda1(Event event) {
Error error = event.getErrors().get(0);
event.addMetadata("LinkError", "errorClass", error.getErrorClass());
event.addMetadata("LinkError", "errorMessage", error.getErrorMessage());
error.setErrorClass("AnrLinkError");
error.setErrorMessage(LOAD_ERR_MSG);
return true;
}
@Override
public void unload() {
if (this.libraryLoader.isLoaded()) {
disableAnrReporting();
}
}
private final void notifyAnrDetected(List<NativeStackframe> nativeTrace) {
Object obj;
List<Stackframe> stacktrace;
Client client = null;
try {
Client client2 = this.client;
if (client2 == null) {
kotlin.jvm.internal.Intrinsics.throwUninitializedPropertyAccessException("client");
client2 = null;
}
if (client2.immutableConfig.shouldDiscardError(ANR_ERROR_CLASS)) {
return;
}
StackTraceElement[] stackTrace = Looper.getMainLooper().getThread().getStackTrace();
boolean doesJavaTraceLeadToNativeTrace$bugsnag_plugin_android_anr_release = INSTANCE.doesJavaTraceLeadToNativeTrace$bugsnag_plugin_android_anr_release(stackTrace);
RuntimeException runtimeException = new RuntimeException();
runtimeException.setStackTrace(stackTrace);
RuntimeException runtimeException2 = runtimeException;
Client client3 = this.client;
if (client3 == null) {
kotlin.jvm.internal.Intrinsics.throwUninitializedPropertyAccessException("client");
client3 = null;
}
Event createEvent = NativeInterface.createEvent(runtimeException2, client3, SeverityReason.newInstance("anrError"));
Error error = createEvent.getErrors().get(0);
error.setErrorClass(ANR_ERROR_CLASS);
error.setErrorMessage(ANR_ERROR_MSG);
if (doesJavaTraceLeadToNativeTrace$bugsnag_plugin_android_anr_release) {
List<NativeStackframe> list = nativeTrace;
ArrayList arrayList = new ArrayList(CollectionsKt.collectionSizeOrDefault(list, 10));
Iterator<T> it = list.iterator();
while (it.hasNext()) {
arrayList.add(new Stackframe((NativeStackframe) it.next()));
}
ArrayList arrayList2 = arrayList;
error.getStacktrace().addAll(0, arrayList2);
Iterator<T> it2 = createEvent.getThreads().iterator();
while (true) {
if (!it2.hasNext()) {
obj = null;
break;
} else {
obj = it2.next();
if (((Thread) obj).getErrorReportingThread()) {
break;
}
}
}
Thread thread = (Thread) obj;
if (thread != null && (stacktrace = thread.getStacktrace()) != null) {
stacktrace.addAll(0, arrayList2);
}
}
AnrDetailsCollector anrDetailsCollector = this.collector;
Client client4 = this.client;
if (client4 == null) {
kotlin.jvm.internal.Intrinsics.throwUninitializedPropertyAccessException("client");
client4 = null;
}
anrDetailsCollector.collectAnrErrorDetails$bugsnag_plugin_android_anr_release(client4, createEvent);
} catch (Exception e) {
Client client5 = this.client;
if (client5 == null) {
kotlin.jvm.internal.Intrinsics.throwUninitializedPropertyAccessException("client");
} else {
client = client5;
}
client.logger.e("Internal error reporting ANR", e);
}
}
}