Skip to content

getsentry/sentry-electron

Folders and files

NameName
Last commit message
Last commit date

Latest commit

090634e · Mar 27, 2025
Jan 16, 2025
Aug 13, 2020
Feb 19, 2025
Feb 11, 2025
Mar 27, 2025
Mar 20, 2025
Jun 16, 2021
Oct 28, 2024
Oct 4, 2024
Oct 4, 2024
Jul 25, 2018
Mar 24, 2025
Jan 23, 2025
Feb 11, 2025
Jun 24, 2024
Mar 27, 2025
Oct 4, 2024
Apr 3, 2024
Oct 2, 2023
Oct 2, 2023
Apr 4, 2024
Mar 27, 2025

Repository files navigation

Sentry

Official Sentry SDK for Electron

Build & Test Documentation npm version license Discord

Features

  • Captures Node errors in the main process (using @sentry/node)
  • Captures JavaScript errors in renderer processes (using @sentry/browser)
  • Captures native crashes (Minidump crash reports) from renderers and the main process
  • Collects breadcrumbs and context information along with events across renderers and the main process
  • Supports electron >= v15

Usage

To use this SDK, call init(options) as early as possible in the entry modules in the main process as well as all renderer processes or further sub processes you spawn. This will initialize the SDK and hook the environment.

In the Electron main process:

import { init } from '@sentry/electron/main';

init({
  dsn: '__DSN__',
  // ...
});

In all Electron renderer processes:

// In the Electron renderer processes
import { init } from '@sentry/electron/renderer';

init();

If you are using a framework specific Sentry SDK, you can pass that init function as the second parameter in the renderer and the two SDKs functionalities will be combined:

import { init } from '@sentry/electron/renderer';
import { init as reactInit } from '@sentry/react';

init({ /* config */ }, reactInit);

To set context information or send manual events, use the exported functions of @sentry/electron. Note that these functions will not perform any action before you have called init():

import * as Sentry from '@sentry/electron/main';

// Set user information, as well as tags and further extras
const scope = Sentry.getCurrentScope();
scope.setExtra('battery', 0.7);
scope.setTag('user_mode', 'admin');
scope.setUser({ id: '4711' });

// Add a breadcrumb for future events
Sentry.addBreadcrumb({
  message: 'My Breadcrumb',
  // ...
});

// Capture exceptions, messages or manual events
Sentry.captureMessage('Hello, world!');
Sentry.captureException(new Error('Good bye'));
Sentry.captureEvent({
  message: 'Manual',
  stacktrace: [
    // ...
  ],
});

Contributors

Thanks to everyone who contributed to the Sentry Electron SDK!