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;
}
- callback for events
2/2/2019 - (1.8.0):
- bumps to latest native SDK releases
- implements improved data converter(#22)
- adds data to SentryUser
Thanks to @bradmartin and @jerbob92!
28/11/2018 - (1.6.1):
- back to native approach thanks to @bradmartin
- update dependencies
- update test app
- working native breadcrums for ios
- fix dsn init thanks to @kvnvelasco
11/12/2017 - (1.5.0):
BREAKING CHANGES
capture()
method was deprecated in favor ofcaptureMessage
/captureException
Features
- Moving to an hybrid approach with both clients(web/native)
- breadcrums
- tags
- user info
- set tags and extra for each event
28-08-2017 - (1.3.0):
- fix Aot compilation for angular apps
- fix typos thanks to @muratcorlu
2-08-2017 - (1.2.0):
- update demos dependencies
- update ios and android native dependencies
- fix ios event capture
24-07-2017 - (1.1.0):
- fix stringify
- fix angular error handler
- @hypery2k: for his nativescript-fabric(helped me a lot!)