This plugin uses sentry-android and sentry-cocoa to catch native errors/stack traces and send them to a sentry server.
NOTE: If you have a native exeption and the app exits the plugin will save the log and send it in the next app startup, this is how the native plugins are implemented and it is expected behavior
Sentry has an optional dependency on SLF4J on Android. Which when not present will log an error about it not being in the application.
System.err: SLF4J: Failed to load class >"org.slf4j.impl.StaticLoggerBinder". System.err: SLF4J: Defaulting to no-operation (NOP) logger implementation System.err: SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder >for further details.
To get rid of this log warning you can add a dependency to your app's app.gradle file located in
App_Resources/Android/app.gradle
to include:compile 'org.slf4j:slf4j-nop:1.7.25'
in the dependencies. See the demo app here
tns plugin add nativescript-sentry
import { Sentry } from 'nativescript-sentry';
const dsn = 'https://<key>:<secret>@host/<project>';
Sentry.init(dsn);
import { SentryModule } from 'nativescript-sentry/angular';
NgModule({
...
imports: [
SentryModule.forRoot({dsn: 'https://<key>:<secret>@host/<project>'})
],
Note: this plugin adds a custom ErrorHandler to your angular app
Sentry.captureException(exeption: Error, options?: ExceptionOptions);
Example:
try {
throw 'try catch Exception example';
} catch (error) {
Sentry.captureException(error, {});
}
Sentry.captureMessage(message: string, options?: MessageOptions)
Sentry.captureBreadcrumb(breadcrumb: BreadCrumb)
Sentry.setContextUser(user: SentryUser)
Sentry.setContextTags(tags: object)
Sentry.setContextExtra(extra: object)
Sentry.clearContext();
export enum Level {
Fatal = 'fatal',
Error = 'error',
Warning = 'warning',
Info = 'info',
Debug = 'debug'
}
export interface SentryUser {
id: string;
email?: string;
username?: string;
}
export interface BreadCrumb {
message: string;
category: string;
level: Level;
}
export interface MessageOptions {
level?: Level;
/**
* Object of additional Key/value pairs which generate breakdowns charts and search filters.
*/
tags?: object;
/**
* Object of unstructured data which is stored with events.
*/
extra?: object;
}
export interface ExceptionOptions {
/**
* Object of additional Key/value pairs which generate breakdowns charts and search filters in Sentry.
*/
tags?: object;
/**
* Object of unstructured data which is stored with events.
*/
extra?: object;
}
2/2/2019 - (1.8.0):
Thanks to @bradmartin and @jerbob92!
28/11/2018 - (1.6.1):
11/12/2017 - (1.5.0):
BREAKING CHANGES
capture()
method was deprecated in favor of captureMessage
/captureException
Features
28-08-2017 - (1.3.0):
2-08-2017 - (1.2.0):
24-07-2017 - (1.1.0):