Blame view

node_modules/errorhandler/README.md 4.03 KB
f7563de62   Palak Handa   first commit
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
  # errorhandler
  
  [![NPM Version][npm-image]][npm-url]
  [![NPM Downloads][downloads-image]][downloads-url]
  [![Build Status][travis-image]][travis-url]
  [![Test Coverage][coveralls-image]][coveralls-url]
  [![Gratipay][gratipay-image]][gratipay-url]
  
  Development-only error handler middleware.
  
  This middleware is only intended to be used in a development environment, as
  the _full error stack traces and internal details of any object passed to this
  module_ will be sent back to the client when an error occurs.
  
  When an object is provided to Express as an error, this module will display
  as much about this object as possible, and will do so by using content negotiation
  for the response between HTML, JSON, and plain text.
  
    * When the object is a standard `Error` object, the string provided by the
      `stack` property will be returned in HTML/text responses.
    * When the object is a non-`Error` object, the result of
      [util.inspect](https://nodejs.org/api/util.html#util_util_inspect_object_options)
      will be returned in HTML/text responses.
    * For JSON responses, the result will be an object with all enumerable properties
      from the object in the response.
  
  ## Install
  
  This is a [Node.js](https://nodejs.org/en/) module available through the
  [npm registry](https://www.npmjs.com/). Installation is done using the
  [`npm install` command](https://docs.npmjs.com/getting-started/installing-npm-packages-locally):
  
  ```sh
  $ npm install errorhandler
  ```
  
  ## API
  
  ```js
  var errorhandler = require('errorhandler')
  ```
  
  ### errorhandler(options)
  
  Create new middleware to handle errors and respond with content negotiation.
  
  #### Options
  
  Error handler accepts these properties in the options object.
  
  ##### log
  
  Provide a function to be called with the error and a string representation of
  the error. Can be used to write the error to any desired location, or set to
  `false` to only send the error back in the response. Called as
  `log(err, str, req, res)` where `err` is the `Error` object, `str` is a string
  representation of the error, `req` is the request object and `res` is the
  response object (note, this function is invoked _after_ the response has been
  written).
  
  The default value for this option is `true` unless `process.env.NODE_ENV === 'test'`.
  
  Possible values:
  
    * `true`: Log errors using `console.error(str)`.
    * `false`: Only send the error back in the response.
    * A function: pass the error to a function for handling.
  
  ## Examples
  
  ### Simple example
  
  Basic example of adding this middleware as the error handler only in development
  with `connect` (`express` also can be used in this example).
  
  ```js
  var connect = require('connect')
  var errorhandler = require('errorhandler')
  
  var app = connect()
  
  if (process.env.NODE_ENV === 'development') {
    // only use in development
    app.use(errorhandler())
  }
  ```
  
  ### Custom output location
  
  Sometimes you may want to output the errors to a different location than STDERR
  during development, like a system notification, for example.
  
  ```js
  var connect = require('connect')
  var errorhandler = require('errorhandler')
  var notifier = require('node-notifier')
  
  var app = connect()
  
  if (process.env.NODE_ENV === 'development') {
    // only use in development
    app.use(errorhandler({log: errorNotification}))
  }
  
  function errorNotification(err, str, req) {
    var title = 'Error in ' + req.method + ' ' + req.url
  
    notifier.notify({
      title: title,
      message: str
    })
  }
  ```
  
  ## License
  
  [MIT](LICENSE)
  
  [npm-image]: https://img.shields.io/npm/v/errorhandler.svg
  [npm-url]: https://npmjs.org/package/errorhandler
  [travis-image]: https://img.shields.io/travis/expressjs/errorhandler/master.svg
  [travis-url]: https://travis-ci.org/expressjs/errorhandler
  [coveralls-image]: https://img.shields.io/coveralls/expressjs/errorhandler/master.svg
  [coveralls-url]: https://coveralls.io/r/expressjs/errorhandler?branch=master
  [downloads-image]: https://img.shields.io/npm/dm/errorhandler.svg
  [downloads-url]: https://npmjs.org/package/errorhandler
  [gratipay-image]: https://img.shields.io/gratipay/dougwilson.svg
  [gratipay-url]: https://www.gratipay.com/dougwilson/