The Rollbar client for EmberJS applications.
This one just works!
- Automatic logger for:
js window
errorsember
errors
- No
Bower
dependency - Fastboot compatible
- Practical wrapper with access to pure
Rollbar
- Compatible with Ember 2.8 and up
ember install ember-rollbar-client
- Add your
accessToken
inconfig/environment.js
module.exports = function(environment) {
var ENV = {
'emberRollbarClient': {
accessToken: 'rollbar-write-client-token',
// By default Rollbar logging is enabled in every environment except test and development.
// Here is an example if you want to use it only in production
enabled: environment === 'production'
};
};
return ENV;
}
In your component, controller, route, object (or whatever) you can inject the rollbar
service, eg:
import Ember from 'ember';
const { Component, inject } = Ember;
export default Component.extend({
rollbar: inject.service()
});
And then you can use following API to log errors:
this.get('rollbar').critical(message, data = {})
this.get('rollbar').error(message, data = {})
this.get('rollbar').warning(message, data = {})
this.get('rollbar').info(message, data = {})
this.get('rollbar').debug(message, data = {})
To set current user use just a normal setter in your session service:
this.set('rollbar.currentUser', { email: 'user@email.com', id: 66 })
If you can not find in our API a proper wrapper, you can always use the current Rollbar instance:
this.get('rollbar.notifier')
Create the following instance initializer in your app:
// app/instance-initializer/rsvp-error-handler.js
import RSVP from "rsvp";
export function initialize(appInstance) {
let rollbarService = appInstance.lookup('service:rollbar');
RSVP.on('error', function(reason) {
rollbarService.error(reason);
});
}
export default {
name: 'rsvp-error-handler',
initialize
};
You can use rollbarClient
function of the Rollbar Service
to create a new instance of Rollbar notifier. Optionally you can pass your own config.
this.get('rollbar').rollbarClient(/* config */)
You can overwrite Rollbar configuration in environment's config. Here is the default config:
'emberRollbarClient': {
enabled: environment !== 'test' && environment !== 'development',
accessToken: '',
verbose: true,
captureUncaught: environment !== 'test',
captureUnhandledRejections: environment !== 'test',
payload: {
environment: environment,
client: {
javascript: {
source_map_enabled: true,
guess_uncaught_frames: true
// code_version: "some version string, such as a version number or git sha",
}
}
}
};
git clone https://github.com/Exelord/ember-rollbar-client
cd ember-rollbar-client
npm install
ember serve
- Visit your app at http://localhost:4200.
npm test
(Runsember try:each
to test your addon against multiple Ember versions)ember test
ember test --server
ember build
For more information on using ember-cli, visit https://ember-cli.com/.
This version of the package is available as open source under the terms of the MIT License.