|
|
@ -19,6 +19,7 @@ import androidx.annotation.Nullable;
|
|
|
|
import androidx.annotation.VisibleForTesting;
|
|
|
|
import androidx.annotation.VisibleForTesting;
|
|
|
|
|
|
|
|
|
|
|
|
import kotlin.Unit;
|
|
|
|
import kotlin.Unit;
|
|
|
|
|
|
|
|
import kotlin.jvm.functions.Function1;
|
|
|
|
import kotlin.jvm.functions.Function2;
|
|
|
|
import kotlin.jvm.functions.Function2;
|
|
|
|
|
|
|
|
|
|
|
|
import java.util.ArrayList;
|
|
|
|
import java.util.ArrayList;
|
|
|
@ -83,7 +84,7 @@ public class Client implements MetadataAware, CallbackAware, UserAware {
|
|
|
|
final Logger logger;
|
|
|
|
final Logger logger;
|
|
|
|
final DeliveryDelegate deliveryDelegate;
|
|
|
|
final DeliveryDelegate deliveryDelegate;
|
|
|
|
|
|
|
|
|
|
|
|
final ClientObservable clientObservable = new ClientObservable();
|
|
|
|
final ClientObservable clientObservable;
|
|
|
|
private PluginClient pluginClient;
|
|
|
|
private PluginClient pluginClient;
|
|
|
|
|
|
|
|
|
|
|
|
final Notifier notifier = new Notifier();
|
|
|
|
final Notifier notifier = new Notifier();
|
|
|
@ -93,6 +94,7 @@ public class Client implements MetadataAware, CallbackAware, UserAware {
|
|
|
|
final LastRunInfoStore lastRunInfoStore;
|
|
|
|
final LastRunInfoStore lastRunInfoStore;
|
|
|
|
final LaunchCrashTracker launchCrashTracker;
|
|
|
|
final LaunchCrashTracker launchCrashTracker;
|
|
|
|
final BackgroundTaskService bgTaskService = new BackgroundTaskService();
|
|
|
|
final BackgroundTaskService bgTaskService = new BackgroundTaskService();
|
|
|
|
|
|
|
|
private final ExceptionHandler exceptionHandler;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
* Initialize a Bugsnag client
|
|
|
|
* Initialize a Bugsnag client
|
|
|
@ -142,6 +144,7 @@ public class Client implements MetadataAware, CallbackAware, UserAware {
|
|
|
|
immutableConfig = sanitiseConfiguration(appContext, configuration, connectivity);
|
|
|
|
immutableConfig = sanitiseConfiguration(appContext, configuration, connectivity);
|
|
|
|
logger = immutableConfig.getLogger();
|
|
|
|
logger = immutableConfig.getLogger();
|
|
|
|
warnIfNotAppContext(androidContext);
|
|
|
|
warnIfNotAppContext(androidContext);
|
|
|
|
|
|
|
|
clientObservable = new ClientObservable();
|
|
|
|
|
|
|
|
|
|
|
|
// Set up breadcrumbs
|
|
|
|
// Set up breadcrumbs
|
|
|
|
callbackState = configuration.impl.callbackState.copy();
|
|
|
|
callbackState = configuration.impl.callbackState.copy();
|
|
|
@ -213,14 +216,16 @@ public class Client implements MetadataAware, CallbackAware, UserAware {
|
|
|
|
immutableConfig, breadcrumbState, notifier, bgTaskService);
|
|
|
|
immutableConfig, breadcrumbState, notifier, bgTaskService);
|
|
|
|
|
|
|
|
|
|
|
|
// Install a default exception handler with this client
|
|
|
|
// Install a default exception handler with this client
|
|
|
|
|
|
|
|
exceptionHandler = new ExceptionHandler(this, logger);
|
|
|
|
if (immutableConfig.getEnabledErrorTypes().getUnhandledExceptions()) {
|
|
|
|
if (immutableConfig.getEnabledErrorTypes().getUnhandledExceptions()) {
|
|
|
|
new ExceptionHandler(this, logger);
|
|
|
|
exceptionHandler.install();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// register a receiver for automatic breadcrumbs
|
|
|
|
// register a receiver for automatic breadcrumbs
|
|
|
|
systemBroadcastReceiver = SystemBroadcastReceiver.register(this, logger, bgTaskService);
|
|
|
|
systemBroadcastReceiver = SystemBroadcastReceiver.register(this, logger, bgTaskService);
|
|
|
|
|
|
|
|
|
|
|
|
registerOrientationChangeListener();
|
|
|
|
registerOrientationChangeListener();
|
|
|
|
|
|
|
|
registerMemoryTrimListener();
|
|
|
|
|
|
|
|
|
|
|
|
// load last run info
|
|
|
|
// load last run info
|
|
|
|
lastRunInfoStore = new LastRunInfoStore(immutableConfig);
|
|
|
|
lastRunInfoStore = new LastRunInfoStore(immutableConfig);
|
|
|
@ -249,6 +254,7 @@ public class Client implements MetadataAware, CallbackAware, UserAware {
|
|
|
|
ContextState contextState,
|
|
|
|
ContextState contextState,
|
|
|
|
CallbackState callbackState,
|
|
|
|
CallbackState callbackState,
|
|
|
|
UserState userState,
|
|
|
|
UserState userState,
|
|
|
|
|
|
|
|
ClientObservable clientObservable,
|
|
|
|
Context appContext,
|
|
|
|
Context appContext,
|
|
|
|
@NonNull DeviceDataCollector deviceDataCollector,
|
|
|
|
@NonNull DeviceDataCollector deviceDataCollector,
|
|
|
|
@NonNull AppDataCollector appDataCollector,
|
|
|
|
@NonNull AppDataCollector appDataCollector,
|
|
|
@ -264,13 +270,15 @@ public class Client implements MetadataAware, CallbackAware, UserAware {
|
|
|
|
Logger logger,
|
|
|
|
Logger logger,
|
|
|
|
DeliveryDelegate deliveryDelegate,
|
|
|
|
DeliveryDelegate deliveryDelegate,
|
|
|
|
LastRunInfoStore lastRunInfoStore,
|
|
|
|
LastRunInfoStore lastRunInfoStore,
|
|
|
|
LaunchCrashTracker launchCrashTracker
|
|
|
|
LaunchCrashTracker launchCrashTracker,
|
|
|
|
|
|
|
|
ExceptionHandler exceptionHandler
|
|
|
|
) {
|
|
|
|
) {
|
|
|
|
this.immutableConfig = immutableConfig;
|
|
|
|
this.immutableConfig = immutableConfig;
|
|
|
|
this.metadataState = metadataState;
|
|
|
|
this.metadataState = metadataState;
|
|
|
|
this.contextState = contextState;
|
|
|
|
this.contextState = contextState;
|
|
|
|
this.callbackState = callbackState;
|
|
|
|
this.callbackState = callbackState;
|
|
|
|
this.userState = userState;
|
|
|
|
this.userState = userState;
|
|
|
|
|
|
|
|
this.clientObservable = clientObservable;
|
|
|
|
this.appContext = appContext;
|
|
|
|
this.appContext = appContext;
|
|
|
|
this.deviceDataCollector = deviceDataCollector;
|
|
|
|
this.deviceDataCollector = deviceDataCollector;
|
|
|
|
this.appDataCollector = appDataCollector;
|
|
|
|
this.appDataCollector = appDataCollector;
|
|
|
@ -288,6 +296,7 @@ public class Client implements MetadataAware, CallbackAware, UserAware {
|
|
|
|
this.lastRunInfoStore = lastRunInfoStore;
|
|
|
|
this.lastRunInfoStore = lastRunInfoStore;
|
|
|
|
this.launchCrashTracker = launchCrashTracker;
|
|
|
|
this.launchCrashTracker = launchCrashTracker;
|
|
|
|
this.lastRunInfo = null;
|
|
|
|
this.lastRunInfo = null;
|
|
|
|
|
|
|
|
this.exceptionHandler = exceptionHandler;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private LastRunInfo loadLastRunInfo() {
|
|
|
|
private LastRunInfo loadLastRunInfo() {
|
|
|
@ -350,6 +359,18 @@ public class Client implements MetadataAware, CallbackAware, UserAware {
|
|
|
|
ContextExtensionsKt.registerReceiverSafe(appContext, receiver, configFilter, logger);
|
|
|
|
ContextExtensionsKt.registerReceiverSafe(appContext, receiver, configFilter, logger);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private void registerMemoryTrimListener() {
|
|
|
|
|
|
|
|
appContext.registerComponentCallbacks(new ClientComponentCallbacks(
|
|
|
|
|
|
|
|
new Function1<Boolean, Unit>() {
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
|
|
|
public Unit invoke(Boolean isLowMemory) {
|
|
|
|
|
|
|
|
clientObservable.postMemoryTrimEvent(isLowMemory);
|
|
|
|
|
|
|
|
return null;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
));
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void setupNdkPlugin() {
|
|
|
|
void setupNdkPlugin() {
|
|
|
|
String lastRunInfoPath = lastRunInfoStore.getFile().getAbsolutePath();
|
|
|
|
String lastRunInfoPath = lastRunInfoStore.getFile().getAbsolutePath();
|
|
|
|
int crashes = (lastRunInfo != null) ? lastRunInfo.getConsecutiveLaunchCrashes() : 0;
|
|
|
|
int crashes = (lastRunInfo != null) ? lastRunInfo.getConsecutiveLaunchCrashes() : 0;
|
|
|
@ -369,6 +390,17 @@ public class Client implements MetadataAware, CallbackAware, UserAware {
|
|
|
|
launchCrashTracker.addObserver(observer);
|
|
|
|
launchCrashTracker.addObserver(observer);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void unregisterObserver(Observer observer) {
|
|
|
|
|
|
|
|
metadataState.deleteObserver(observer);
|
|
|
|
|
|
|
|
breadcrumbState.deleteObserver(observer);
|
|
|
|
|
|
|
|
sessionTracker.deleteObserver(observer);
|
|
|
|
|
|
|
|
clientObservable.deleteObserver(observer);
|
|
|
|
|
|
|
|
userState.deleteObserver(observer);
|
|
|
|
|
|
|
|
contextState.deleteObserver(observer);
|
|
|
|
|
|
|
|
deliveryDelegate.deleteObserver(observer);
|
|
|
|
|
|
|
|
launchCrashTracker.deleteObserver(observer);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
* Sends initial state values for Metadata/User/Context to any registered observers.
|
|
|
|
* Sends initial state values for Metadata/User/Context to any registered observers.
|
|
|
|
*/
|
|
|
|
*/
|
|
|
@ -990,13 +1022,7 @@ public class Client implements MetadataAware, CallbackAware, UserAware {
|
|
|
|
@SuppressWarnings("rawtypes")
|
|
|
|
@SuppressWarnings("rawtypes")
|
|
|
|
@Nullable
|
|
|
|
@Nullable
|
|
|
|
Plugin getPlugin(@NonNull Class clz) {
|
|
|
|
Plugin getPlugin(@NonNull Class clz) {
|
|
|
|
Set<Plugin> plugins = pluginClient.getPlugins();
|
|
|
|
return pluginClient.findPlugin(clz);
|
|
|
|
for (Plugin plugin : plugins) {
|
|
|
|
|
|
|
|
if (plugin.getClass().equals(clz)) {
|
|
|
|
|
|
|
|
return plugin;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
return null;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Notifier getNotifier() {
|
|
|
|
Notifier getNotifier() {
|
|
|
@ -1006,4 +1032,18 @@ public class Client implements MetadataAware, CallbackAware, UserAware {
|
|
|
|
MetadataState getMetadataState() {
|
|
|
|
MetadataState getMetadataState() {
|
|
|
|
return metadataState;
|
|
|
|
return metadataState;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void setAutoNotify(boolean autoNotify) {
|
|
|
|
|
|
|
|
pluginClient.setAutoNotify(this, autoNotify);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (autoNotify) {
|
|
|
|
|
|
|
|
exceptionHandler.install();
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
exceptionHandler.uninstall();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void setAutoDetectAnrs(boolean autoDetectAnrs) {
|
|
|
|
|
|
|
|
pluginClient.setAutoDetectAnrs(this, autoDetectAnrs);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|