mirror of
https://github.com/nodemailer/wildduck.git
synced 2025-01-04 07:02:45 +08:00
66 lines
1.5 KiB
JavaScript
66 lines
1.5 KiB
JavaScript
/* eslint global-require: 0, no-console: 0 */
|
|
'use strict';
|
|
|
|
const config = require('wild-config');
|
|
let bugsnag;
|
|
|
|
if (config.bugsnagCode) {
|
|
bugsnag = require('bugsnag');
|
|
bugsnag.register(config.bugsnagCode);
|
|
}
|
|
|
|
module.exports.notify = (...args) => {
|
|
if (bugsnag) {
|
|
bugsnag.notify(...args);
|
|
} else {
|
|
console.error(...args);
|
|
}
|
|
};
|
|
|
|
module.exports.notifyConnection = (connection, ...args) => {
|
|
let err = args[0];
|
|
let metaData = args[1] || {};
|
|
|
|
if (connection) {
|
|
if (connection.selected) {
|
|
metaData.selected = connection.selected.mailbox;
|
|
}
|
|
|
|
if (connection.session.user) {
|
|
metaData.userId = connection.session.user.id.toString();
|
|
}
|
|
|
|
metaData.remoteAddress = connection.session.remoteAddress;
|
|
metaData.isUTF8Enabled = !!connection.acceptUTF8Enabled;
|
|
}
|
|
|
|
Object.keys(err.meta || {}).forEach(key => {
|
|
metaData[key] = err.meta[key];
|
|
});
|
|
|
|
args[1] = metaData;
|
|
|
|
if (bugsnag) {
|
|
bugsnag.notify(...args);
|
|
} else {
|
|
console.error(...args);
|
|
}
|
|
};
|
|
|
|
module.exports.intercept = (...args) => {
|
|
if (bugsnag) {
|
|
return bugsnag.intercept(...args);
|
|
}
|
|
let cb;
|
|
if (args.length) {
|
|
cb = args[args.length - 1];
|
|
if (typeof cb === 'function') {
|
|
args[args.length - 1] = function(...rArgs) {
|
|
if (rArgs.length > 1 && rArgs[0]) {
|
|
console.error(rArgs[0]);
|
|
}
|
|
return cb(...rArgs);
|
|
};
|
|
}
|
|
}
|
|
};
|