A Dart package for logging application errors and messages to Rollbar.
Import rollbar.dart.
import 'package:rollbar/rollbar.dart';
Initialize an instance of Rollbar
with your access token and environment.
var rollbar = new Rollbar(token, environment);
Log errors to Rollbar with the Rollbar.trace()
method.
try {
throw "Some error";
} catch (error, stackTrace) {
rollbar.trace(error, stackTrace);
}
Log messages to Rollbar with the Rollbar.message()
method.
rollbar.message("User clicked Checkout");
Use Rollbar.traceErrorsInZone()
to run a block of a code in a new zone, and log any of the its uncaught errors to Rollbar. The method will catch both synchronous and asynchronous errors. This method is useful for logging all the uncaught errors in your application. See this guide for more information about zones in Dart.
rollbar.traceErrorsInZone(() {
new Future.error("oh noes");
});
The Rollbar
constructor allows you to define data to be sent on each request to Rollbar. Use the constructor's config
parameter to set this data.
var rollbar = new Rollbar(token, environment, config: {
"person": {
"id": 1,
"username": "jimmyp",
"email": "jimmyp@mixbook.com"
}
})
Methods that send data to Rollbar, Rollbar.message()
, Rollbar.trace()
and Rollbar.traceErrorsInZone()
all allow you to define additional data to send to Rollbar.
rollbar.trace(error, stackTrace, otherData: {
"custom": {
"project_id": 5
}
})
The data will be merged into the default payload. Check the API docs for all the options that Rollbar supports (section "Data Format").
You also can provide your own logger. The plugin will write debug info to it in the 'finer' level. If no logger is provided, a default one will be used.
var logger = new Logger("mylogger");
var rollbar = new Rollbar(token, environment, logger: logger);
Rollbar supports source maps for your JavaScript stack traces.
By default, source maps are disabled, but you can enable them by setting the appropriate flags in the Rollbar
constructor.
var rollbar = new Rollbar(token, environment, config: {
"client": {
"javascript": {
"source_map_enabled": true, // required
"code_version": "1.0", // required
"guess_uncaught_frames": true // optional value
}
}
});
The source maps will need to be available to Rollbar. Check their documentation for how to do this.