errorEmail.js 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637
  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. const request = ctx.request;
  23. const url = _.get(request, 'url');
  24. let body = _.get(request, 'body');
  25. if (body) body = JSON.stringify(body, null, 1);
  26. emailData.errmsg = `${url}\n${body}\n${emailData.errmsg}`;
  27. // 未定义的错误需要发邮件,定义的错误不需要
  28. if (!_.isNumber(e.errcode)) {
  29. // 非开发模式发送邮件
  30. if (process.env.NODE_ENV !== 'development') {
  31. ctx.service.util.email.errorEmail(emailData);
  32. }
  33. }
  34. ctx.fail(errcode, errmsg, details);
  35. }
  36. };
  37. };