GitXplorerGitXplorer
j

err-hndlr

public
0 stars
0 forks
0 issues

Commits

List of commits on branch master.
Unverified
52d9d3b2417028f0e415a5dfa738277d327c3d22

0.1.1

jjneidel committed 6 years ago
Unverified
811471126d9d3c3856d9d625aaec34865e161c5d

Fix throwing new error if data.err passed

jjneidel committed 6 years ago
Unverified
749e01d2f61194bf4b7ec63bd83727bfb85f8a70

Lint files

jjneidel committed 6 years ago
Unverified
1063d743332c0b010b5d2589ce6bdcff09f54101

0.1.0

jjneidel committed 6 years ago
Unverified
044e7f1686b3fd6eef18972060d0438518b3a87a

Rename errHndlr.error -> errHndlr.throw

jjneidel committed 6 years ago
Unverified
de43c0cf0bcb93fc43335d484f7f3c167801ca0e

Add api documentation

jjneidel committed 6 years ago

README

The README file for this repository.

err-hndlr

Error handler for either throwing locally or sending a bug ticket to a rest api

Travis Build Status License MIT Npm Downloads

Install

Npm Version

$ npm install err-hndlr

Usage

const errHndlr = require( "err-hndlr" );

errHndlr.init(
  process.argv[2] === "--debug",
  "https://api.jneidel.com/errors/submit",
  {
    applicationId: "1337"
  }
)

errHndlr.throw(
  "smt went wrong",
  {
    env: {...},
  },
  false
)

// If --debug flag was passed:
//=> Error: something went wrong

// If --debug flag was not passed:
// POST https://api.jneidel.com/error/submit
//    {
//      applicationId: "1337",
//      error: {
//        msg: "smt went wrong",
//        stack: "...",
//      },
//      env: {...},
//    }

API

init( isThrow, apiAddress, data, options )

Globally initializes the error handler. This function has to be run before throwing any errors.

errHndlr.init(
  false,
  http://api.jneidel.com/errors/submit,
  { id: "1337" },
)

isThrow:

Default: true Type: boolean

Whenever errors should be thrown locally (true) or be sent to the rest api (false).

apiAddress:

Type: string

Rest api endpoint where error requests should be sent if isThrow=false. The data will be sent in the body of the POST request.

data:

Default: {} Type: object

The data that will be sent along on every request. You might want to include device specific data (os, etc.) and application data (name, version, etc.) here.

options:

Default: {} Type: object

Currently supported options are:

app:

Require your package.json through the app option to include the app's name and version in every request.

// options:
{
  app: require( "../package.json" )
}
// POST request:
{
  ...
  app: {
    name: "err-hndlr",
    version: "0.0.1",
  }
}

os:

Pass a truthy value to include the os.type() and os.platform() in every request.

// options:
{
  os: true
}
// POST request:
{
  ...
  os: {
    type: "Linux",
    platform: "linux",
  }
}

throw( msg, data, isExit )

errHndlr.throw(
  "something went wrong",
  data: {
    env: {...}
  },
  false,
).catch( err => {...} ) // To handle connection errors (ECONNREFUSED)

msg:

Type: string

The message used to call new Error( msg ).

data:

Default: {} Type: object

Data to be include on this specific request. Might include environmental variables, state, etc.

isExit:

Default: false Type: boolean

Whenever the process should exit if the error is thrown.

Related

License

MIT © Jonathan Neidel