errorEmail.js 957 B

123456789101112131415161718192021222324252627282930313233
  1. 'use strict';
  2. const _ = require('lodash');
  3. module.exports = options => {
  4. return async function errorEmail(ctx, next) {
  5. try {
  6. await next();
  7. } catch (e) {
  8. let errcode = -1,
  9. errmsg = '服务发生错误',
  10. details;
  11. const emailData = {};
  12. if (_.isNumber(e.errcode)) {
  13. errcode = _.get(e, 'errcode');
  14. errmsg = _.get(e, 'errmsg');
  15. details = _.get(e, 'details');
  16. emailData.errmsg = errmsg;
  17. emailData.details = details;
  18. } else {
  19. emailData.errmsg = e.stack;
  20. }
  21. emailData.errcode = errcode;
  22. console.log(emailData.errmsg);
  23. // 未定义的错误需要发邮件,定义的错误不需要
  24. if (!_.isNumber(e.errcode)) {
  25. // 非开发模式发送邮件
  26. if (process.env.NODE_ENV !== 'development') {
  27. ctx.service.util.email.errorEmail(emailData);
  28. }
  29. }
  30. ctx.fail(errcode, errmsg, details);
  31. }
  32. };
  33. };