-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathindex.js
54 lines (44 loc) · 925 Bytes
/
index.js
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
/**
* Module dependencies.
*/
var assert = require('assert');
/**
* Initialize jstrace middleware with `opts`.
*
* @param {Object} opts
* @return {Function}
* @api public
*/
module.exports = function(opts){
assert(opts, 'settings required');
assert(opts.trace, '.trace function required');
var trace = opts.trace;
var ids = 0;
return function(req, res, next){
var id = ++ids;
// start
trace('express:request:start', {
header: req.headers,
method: req.method,
url: req.url,
id: id
});
// end
res.on('finish', function(){
trace('express:request:end', {
status: res.statusCode,
header: res._headers,
id: id
});
});
// close
req.on('close', function(){
trace('express:request:close', {
status: res.statusCode,
header: res._headers,
id: id
});
});
next();
}
};