@grafana/faro-esbuild-plugin
v0.2.0
Published
Upload a source map to the Faro source map API from an esbuild build pipeline
Downloads
9
Readme
Faro source map upload plugin - esbuild
[!WARNING] This package is currently experimental. While it provides feature parity with the rollup and webpack plugins, it may have issues or limitations. Please report any problems you encounter.
This plugin uploads source maps to the Faro collector to enable de-obfuscation of stack traces in the Grafana Cloud Frontend Observability UI.
[!NOTE] The Faro JavaScript bundler plugins work with client-side rendered applications. Server-side rendering isn't yet supported.
Installation
To install the Faro JavaScript Bundler Plugins for esbuild, use the package manager of your choice.
To install the esbuild plugin with npm, run:
npm install --save-dev @grafana/faro-esbuild-pluginTo install the esbuild plugin with yarn, run:
yarn add --dev @grafana/faro-esbuild-pluginUsage
Details of how to use the plugins with your bundler reside in the Frontend Observability plugin under the "Settings" -> "Source Maps" tab after clicking into your instrumented app.
That tab includes the necessary configuration for the Faro JavaScript bundler plugins, including the appName, appId, and endpoint values that you need for the plugins to work with your app. The details provided below are general instructions for how to use the plugins with your bundler.
esbuild
To use the esbuild plugin, add the following to your build script:
import * as esbuild from 'esbuild';
import faroEsbuildPlugin from '@grafana/faro-esbuild-plugin';
await esbuild.build({
entryPoints: ['src/index.ts'],
bundle: true,
outdir: 'dist',
plugins: [
faroEsbuildPlugin({
appName: "$your-app-name",
// this URL is different from the Faro Collector URL - find this value in the Frontend Observability plugin under "Settings" -> "Source Maps" -> "Configure source map uploads"
endpoint: "$your-faro-sourcemap-api-url",
apiKey: "$your-api-key",
appId: "$your-app-id",
stackId: "$your-stack-id",
gzipContents: true,
}),
],
});Configuration Options
The following options are available for the Faro JavaScript bundler plugins:
appName: stringrequired: The name of your application. This should match theappNamevalue you are using in your Faro Web SDK configuration.endpoint: stringrequired: The URL of your Faro Collector endpoint. This value is in the Frontend Observability plugin under "Settings" -> "Source Maps" -> "Configure source map uploads".apiKey: stringrequired: The API key for your Faro Collector. This value gets generated on grafana.com by creating a new scope (details provided in the plugin and in the "Obtaining API key" section of this document).appId: stringrequired: The ID of your application. This should match theappIdvalue you are using in your Faro Web SDK configuration.stackId: stringrequired: The ID of the stack, found in Frontend Observability under Settings -> Source Maps -> Configure source map uploadsoutputPath: stringoptional: Override the output directory path where source maps are located, by default uses esbuild'soutdiroroutfiledirectoryoutputFiles: string[] | RegExpoptional: An array of source map files to upload or a regex pattern to match files, by default Faro uploads all source mapsbundleId: stringoptional: The ID of the bundle/build, by default auto-generated, or specify an ID to filter by bundle ID in Frontend ObservabilitykeepSourcemaps: booleanoptional: Whether to keep the source maps in your generated bundle after uploading, defaultfalsegzipContents: booleanoptional: Whether to archive and compress the source maps before uploading, defaulttrueverbose: booleanoptional: Whether to log verbose output during the upload process, defaultfalseskipUpload: booleanoptional: Whether to skip uploading source maps and only export the bundleId to an environment file, defaultfalsemaxUploadSize: numberoptional: Maximum upload size in bytes, default is 30MB. The Faro API has a 30MB limit for individual file uploads by default. In special circumstances, this limit may be changed by contacting Grafana Cloud support.recursive: booleanoptional: Whether to recursively search subdirectories for source maps, defaultfalseproxy: stringoptional: Proxy URL to use for source map uploads. Supports both HTTP and HTTPS proxies. If your proxy requires authentication, include credentials in the URL format:http://username:[email protected]:8080. Example:http://proxy.example.com:8080orhttps://user:[email protected]:8080
After initial configuration, the Faro JavaScript bundler plugins automatically uploads your source maps to Grafana Cloud when you build your application. You can verify that the source maps upload successfully by in the "Settings" -> "Source Maps" tab in the Frontend Observability plugin. From there you are able to see the source maps that you have uploaded.
After you have completed all the required steps, you have finished - the Faro Collector begins processing your source maps and associating them with your telemetry data. The portions of your stack traces with source maps uploaded to the Faro Collector are automatically de-obfuscated and displayed in the Frontend Observability plugin when viewing your error data.
