react-native-sentry (alpha iOS only)
Requirments:
react-native >= 0.41
sentry-cli > 0.25:
https://github.com/getsentry/sentry-cli
OR
brew install getsentry/tools/sentry-cli
Sentry can provide mixed stacktraces, which means if your app happens to crash on the native side you will also see the last call from javascript.
data:image/s3,"s3://crabby-images/a5823/a5823089eab4aacd7f080bf7ca7954fdadf52e7e" alt="Mixed Stacktrace"
Getting started
If you don't have a react native project up and running follow this guide.
https://facebook.github.io/react-native/docs/getting-started.html
Start with adding sentry:
$ npm install react-native-sentry --save
Mostly automatic installation
$ react-native link react-native-sentry
How to integrate it into you Xcode project
react-native init AwesomeProject
cd AwesomeProject
Add framework search paths:
$(SRCROOT)/../node_modules/react-native-sentry/ios
data:image/s3,"s3://crabby-images/23a10/23a108a3cdb704e5f891321b8286e7b1fdb4ab6c" alt="Framework Search Paths"
Always embed swift libraries:
data:image/s3,"s3://crabby-images/642bd/642bd25133d174ecd58f020d5e09ab87d101fc17" alt="Always embed swift libraries"
Copy files phase:
data:image/s3,"s3://crabby-images/b6a20/b6a200f7d8365695046731c27088ea3fee6b1fd9" alt="Copy files phase"
Copy frameworks:
data:image/s3,"s3://crabby-images/23ead/23eadc6d4305a06a1d2e23bedc420dd2e54d2050" alt="Copy frameworks"
Add run script phase to upload your debug symbols and source maps:
data:image/s3,"s3://crabby-images/c4fac/c4facb089caf3ed30c02399ebcbd03cb7e3f6517" alt="Run script"
Change this variables with your values:
SENTRY_ORG
SENTRY_PROJECT
SENTRY_AUTH_TOKEN
if which sentry-cli >/dev/null; then
export SENTRY_ORG=YOUR-ORG
export SENTRY_PROJECT=YOUR-PROJECT
export SENTRY_AUTH_TOKEN=YOUR-AUTH-TOKEN
ERROR=$(sentry-cli upload-dsym 2>&1 >/dev/null)
if [ ! -z "$ERROR" ]; then
echo "warning: sentry-cli - $ERROR"
fi
RELEASE=$(/usr/libexec/PlistBuddy -c "print :CFBundleShortVersionString" $INFOPLIST_FILE)
BUILD=$(/usr/libexec/PlistBuddy -c "print :CFBundleVersion" $INFOPLIST_FILE)
../node_modules/react-native-sentry/bin/sourcemap_upload $RELEASE $BUILD
else
echo "warning: sentry-cli not installed, download from https://github.com/getsentry/sentry-cli/releases"
fi
Add sentry to your index.ios.js
...
import {
AppRegistry,
StyleSheet,
Text,
View
} from 'react-native';
import {
SentryClient,
SentrySeverity,
SentryLog,
User
} from 'react-native-sentry';
SentryClient.setLogLevel(SentryLog.Debug);
SentryClient.shared = new SentryClient("Your DSN");
SentryClient.shared.activateStacktraceMerging(require('BatchedBridge'), require('parseErrorStack'));
export default class AwesomeProject extends Component {
...
Change AppDelegate.m
#import "AppDelegate.h"
#import <React/RCTBundleURLProvider.h>
#import <React/RCTRootView.h>
#import <React/RNSentry.h>
@interface AppDelegate()
@property (nonatomic, strong) RNSentry *sentry;
@end
@implementation AppDelegate
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
NSURL *jsCodeLocation;
jsCodeLocation = [[RCTBundleURLProvider sharedSettings] jsBundleURLForBundleRoot:@"index.ios" fallbackResource:nil];
self.sentry = [[RNSentry alloc] init];
RCTBridge *bridge = [[RCTBridge alloc] initWithBundleURL:jsCodeLocation
moduleProvider:^NSArray<id<RCTBridgeModule>> *{
id<RCTExceptionsManagerDelegate> customDelegate = self.sentry;
return @[[[RCTExceptionsManager alloc] initWithDelegate:customDelegate]];
}
launchOptions:launchOptions];
RCTRootView *rootView = [[RCTRootView alloc] initWithBridge:bridge moduleName:@"AwesomeProject" initialProperties:nil];
rootView.backgroundColor = [[UIColor alloc] initWithRed:1.0f green:1.0f blue:1.0f alpha:1];
self.window = [[UIWindow alloc] initWithFrame:[UIScreen mainScreen].bounds];
UIViewController *rootViewController = [UIViewController new];
rootViewController.view = rootView;
self.window.rootViewController = rootViewController;
[self.window makeKeyAndVisible];
return YES;
}
@end
Documentation
These are functions you can call in your javascript code:
SentryClient.shared.setExtras({
"a_thing": 3,
"some_things": {"green": "red"},
"foobar": ["a", "b", "c"],
"react": true,
"float": 2.43
});
SentryClient.shared.setTags({
"environment": "production",
"react": true
});
SentryClient.shared.setUser(new User(
"12341",
"john@apple.com",
"username",
{
"is_admin": false
}
));
SentryClient.shared.captureMessage("TEST message", SentrySeverity.Warning);