payment_tender_check.js 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. 'use strict';
  2. /**
  3. *
  4. *
  5. * @author Mai
  6. * @date
  7. * @version
  8. */
  9. const messageType = require('../const/message_type');
  10. const paymentConst = require('../const/payment');
  11. const _ = require('lodash');
  12. module.exports = options => {
  13. /**
  14. * 标段校验 中间件
  15. * 1. 读取标段数据(包括属性)
  16. * 2. 检验用户是否可见标段(不校验具体权限)
  17. *
  18. * @param {function} next - 中间件继续执行的方法
  19. * @return {void}
  20. */
  21. return function* paymentTenderCheck(next) {
  22. try {
  23. if (!this.params.id) {
  24. throw '当前未打开标段';
  25. }
  26. const tender = yield this.service.paymentTender.getDataById(this.params.id);
  27. const projectInfo = yield this.service.project.getDataById(this.session.sessionProject.id);
  28. const modes = projectInfo.payment_setting ? JSON.parse(projectInfo.payment_setting) : _.cloneDeep(paymentConst.setting_modes);
  29. for (const m in paymentConst.setting_modes) {
  30. if (!modes[m]) modes[m] = _.cloneDeep(paymentConst.setting_modes[m]);
  31. }
  32. const auditPermission = yield this.service.paymentPermissionAudit.getOnePermission(this.session.sessionUser.is_admin, this.session.sessionUser.accountId);
  33. if (!auditPermission) {
  34. throw '权限不足';
  35. }
  36. if (!tender) {
  37. throw '标段不存在';
  38. }
  39. const payment = {
  40. auditPermission,
  41. project_setting: modes,
  42. }
  43. this.tender = tender;
  44. this.payment = payment;
  45. yield next;
  46. } catch (err) {
  47. // 输出错误到日志
  48. if (err.stack) {
  49. this.logger.error(err);
  50. } else {
  51. this.session.message = {
  52. type: messageType.ERROR,
  53. icon: 'exclamation-circle',
  54. message: err,
  55. };
  56. this.getLogger('fail').info(JSON.stringify({
  57. error: err,
  58. project: this.session.sessionProject,
  59. user: this.session.sessionUser,
  60. body: this.session.body,
  61. }));
  62. }
  63. if (this.helper.isAjax(this.request)) {
  64. if (err.stack) {
  65. this.body = {err: 4, msg: '标段数据未知错误', data: null};
  66. } else {
  67. this.body = {err: 3, msg: err.toString(), data: null};
  68. }
  69. } else {
  70. if (this.helper.isWap(this.request)) {
  71. this.redirect('/wap/list');
  72. } else {
  73. err === '您无权查看该内容' ? this.redirect(this.request.headers.referer) : this.redirect('/payment');
  74. }
  75. }
  76. }
  77. };
  78. };