This repository has been archived by the owner on Mar 11, 2018. It is now read-only.
/
index.js
60 lines (47 loc) · 1.62 KB
/
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
55
56
57
58
59
60
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = SentryHandler;
var _raven = require('raven');
var _nightingaleLevels = require('nightingale-levels');
var _nightingaleLevels2 = _interopRequireDefault(_nightingaleLevels);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
const mapToSentryLevel = {
[_nightingaleLevels2.default.TRACE]: 'debug',
[_nightingaleLevels2.default.DEBUG]: 'debug',
[_nightingaleLevels2.default.INFO]: 'info',
[_nightingaleLevels2.default.WARNING]: 'warning',
[_nightingaleLevels2.default.ERROR]: 'error',
[_nightingaleLevels2.default.FATAL]: 'fatal',
[_nightingaleLevels2.default.EMERGENCY]: 'fatal'
};
const createHandler = (ravenUrl, { getUser = () => {}, getTags = () => {} } = {}) => {
const ravenClient = new _raven.Client(ravenUrl);
return record => {
const { key, level, metadata, extra } = record;
let error = metadata && metadata.error;
if (!error) {
return;
}
const extraData = Object.assign({}, metadata, { extra });
delete extraData.error;
if (error.originalError) {
// error-processor
extraData.parsedStack = error.stackTrace.toArray();
error = error.originalError;
}
ravenClient.captureError(error, {
logger: key,
level: mapToSentryLevel[level] || 'error',
extra: extraData,
user: getUser(record),
tags: getTags(record)
});
};
};
function SentryHandler(ravenUrl, minLevel, options) {
this.minLevel = minLevel;
this.handle = createHandler(ravenUrl, options);
}
//# sourceMappingURL=index.js.map