Browser Extensions
Rollbar.js supports both manifest v2 and manifest v3 browser extensions.
For both versions, rollbar.js must be included in the extension package. Add rollbar.min.js from the dist directory to your extension folder. When updating the version of rollbar.js, this file will need to be updated to the new version.
Manifest v3
Look here for a full working manifest v3 example.
Requirements for integrating Rollbar in a manifest v3 extension.
- In your extension's manifest.json, the host permissions must include "https://api.rollbar.com/".
"host_permissions": ["https://api.rollbar.com/"]
- The
content_scripts
key must include a config.js and rollbar.min.js in the correct order:
"content_scripts": [
{
"matches": ["<all_urls>"],
"js": ["config.js", "rollbar.min.js", "content_script.js"]
}
]
The config.js will include your Rollbar config and must load before rollbar.min.js, which must load before your other content script files.
- The config.js contains the Rollbar config. This must be assigned to
window._rollbarConfig
.
window._rollbarConfig = {
accessToken: 'ROLLBAR_CLIENT_TOKEN',
captureUncaught: true,
captureUnhandledRejections: true
};
After the above steps, Rollbar is ready to use in your content scripts:
Rollbar.info('Content script message');
- To import Rollbar into your service worker, add the Rollbar config in the service worker script:
const _rollbarConfig = {
accessToken: 'ROLLBAR_CLIENT_TOKEN',
captureUncaught: true,
captureUnhandledRejections: true
};
- Then for es6 modules, import:
import './rollbar.min.js';
Or for non-es6, use importScripts:
self.importScripts('./rollbar.min.js');
- Then use the config to initialize Rollbar. Note that the default Rollbar object is lowercase
rollbar
.
rollbar.init(_rollbarConfig);
- After the above steps, Rollbar is ready to use in your service worker script.
rollbar.info('Service worker message');
Manifest v2
Look here for a full working manifest v2 example.
Requirements for integrating Rollbar in a manifest v3 extension.
- In your extension's manifest.json, the
permissions
key must include "https://api.rollbar.com/".
"permissions": ["https://api.rollbar.com/"]
- The
content_security_policy
key must include https://cdn.rollbar.com inscript-src
andobject-src
. (This ensures Firefox compatibility, which doesn't acceptdefault-src
.
"content_security_policy": "script-src 'self' https://cdn.rollbar.com; object-src 'self' https://cdn.rollbar.com;"
- The
content_scripts
key must include a config.js and rollbar.min.js in the correct order:
"content_scripts": [
{
"matches": ["<all_urls>"],
"js": ["config.js", "rollbar.min.js", "content_script.js"]
}
]
The config.js will include your Rollbar config and must load before rollbar.min.js, which must load before your other content script files.
- The config.js contains the Rollbar config. This must be assigned to
window._rollbarConfig
.
window._rollbarConfig = {
accessToken: 'ROLLBAR_CLIENT_TOKEN',
captureUncaught: true,
captureUnhandledRejections: true
};
After the above steps, Rollbar is ready to use in your content scripts:
Rollbar.info('Content script message');
- To import Rollbar into your service worker, add the Rollbar config in the background script:
const _rollbarConfig = {
accessToken: 'ROLLBAR_CLIENT_TOKEN',
captureUncaught: true,
captureUnhandledRejections: true
};
-
Add the Rollbar snippet inline in the background script. The latest version can always be found here.
-
After the above steps, Rollbar is ready to use in your background script.
Rollbar.info('Background script message');
Firefox compatibility
This guide and the complete example are written to be Firefox compatible.
Firefox has slightly different manifest.json requirements. The example is written
so that the same manifest.json can be used across all browsers.
content_security_policy
According to the browser extension spec, it should be OK to only set default-src
.
This won't work for Firefox, which requires setting both script-src
and object-src
.
The example uses the Firefox compatible content security policy, since it also
works fine on Chrome and Edge.
background.persistent
Firefox emits a warning when the background.persistent
key is set false.
The example sets the key true, as this setting works across all browsers.
Rollbar configuration
There are some limitations on Firefox in the content script. The background script
is not affected by these limitations.
Firefox requires setting captureUncaught
false in the content script, because it doesn't allow
Rollbar.js to wrap window.onerror
.
Firefox requires setting autoInstrument.network
false in the content script,
because it doesn't allow Rollbar.js to wrap window.fetch
.
The content script config is in ./config.js in the example, and is configured
with Firefox compatible settings.
{
accessToken: 'ROLLBAR_CLIENT_TOKEN',
captureUncaught: false, // Only required for Firefox, other browser targets
// may set true.
captureUnhandledRejections: true,
autoInstrument: {
network: false // Only required for Firefox, other browser targets
// may set true.
}
}
For more information on rollbar.js, see the docs here.
Updated 9 months ago