Skip to content

Creates bug reports for uncaught exceptions and unhandled rejections

License

Notifications You must be signed in to change notification settings

tuplo/unhandler

Repository files navigation


Logo

unhandler

Creates bug reports for uncaught exceptions and unhandled rejections

Why

Creates bug reports for uncaught exceptions and unhandled rejections. Works like a DYI Sentry client for NodeJS. Can publish bug reports on different trackers simultaneously. Not suited to be used on browsers as it would need to expose your APIs' access secrets to the public.

Install

$ npm install @tuplo/unhandler

# or with yarn
$ yarn add @tuplo/unhandler

Usage

import { unhandler } from '@tuplo/unhandler';

Registers event handlers for uncaughtException and unhandledRejection

unhandler({
  appName: 'my-app-1',
  providers: {
    github: {
      user: 'tuplo',
      repo: 'unhandler',
      token: 'secret-token-xxxxxxx',
    },
  },
});

throw new Error('buggy bug');

// will create a GitHub issue with title "[my-app-1] buggy bug"

Creates bug reports directly with submitError

import { submitError } from '@tuplo/unhandler';

const error = new Error('buggy bug');

await submitError(error, {
  appName: 'my-app-1',
  providers: {
    github: {
      user: 'tuplo',
      repo: 'unhandler',
      token: 'secret-token-xxxxxxx',
    },
  },
});

// will create a GitHub issue with title "[my-app-1] buggy bug"

Registers an event handler onBeforeSubmitError or onAfterSubmitError

import { submitError } from '@tuplo/unhandler';

const error = new Error('buggy bug');

await submitError(error, {
  appName: 'my-app-1',
  onBeforeSubmitError: (error) => console.error(error),
  onAfterSubmitError: (error) => console.error(error),
  providers: {
    github: {
      user: 'tuplo',
      repo: 'unhandler',
     token: 'secret-token-xxxxxxx',
   },
  },
});

// will output the error before and after submitting

Error tracking providers

  • GitHub Issues
  • Trello
  • JIRA

Options

appName

string

The name of the application triggering the error.

onBeforeSubmitError

(error) => Promise<void> | optional

An optional function to be called just before submitting the error.

onAfterSubmitError

(error) => Promise<void> | optional

An optional function to be called just after submitting the error.

providers

Provider[]

shouldSubmitError

boolean | optional

Decides if the error should actually be submitted. Normally coupled with onBeforeSubmitError to do something else with the Error but not submit it. If false it doesn't submit the error and doesn't call onAfterSubmitError. Defaults to true.

GitHub
name type description
user string The user or organization, owner of the repository where issues will be created.
repo string The name of the repository where issues will be created.
token string GitHub's personal access token with a repo scope.

License

MIT