Skip to content

Files

Latest commit

979fe8f · Mar 28, 2025

History

History
This branch is 2 commits behind develop.

bun

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
Nov 30, 2023
Mar 24, 2025
Mar 5, 2025
Dec 13, 2024
Jan 23, 2025
Feb 15, 2025
Mar 28, 2025
Mar 13, 2024
Mar 13, 2024
Feb 25, 2025
Sep 18, 2023

Sentry

Official Sentry SDK for Bun (Beta)

npm version npm dm npm dt

Links

The Sentry Bun SDK is in beta. Please help us improve the SDK by reporting any issues or giving us feedback.

Usage

To use this SDK, call init(options) as early as possible in the main entry module. This will initialize the SDK and hook into the environment. Note that you can turn off almost all side effects using the respective options.

// CJS Syntax
const Sentry = require('@sentry/bun');
// ESM Syntax
import * as Sentry from '@sentry/bun';

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

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

// Set user information, as well as tags and further extras
Sentry.setExtra('battery', 0.7);
Sentry.setTag('user_mode', 'admin');
Sentry.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: [
    // ...
  ],
});

It's not possible to capture unhandled exceptions, unhandled promise rejections now - Bun is working on adding support for it. Github Issue follow this issue. To report errors to Sentry, you have to manually try-catch and call Sentry.captureException in the catch block.

import * as Sentry from '@sentry/bun';

try {
  throw new Error('test');
} catch (e) {
  Sentry.captureException(e);
}