change_plan_check.js 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. 'use strict';
  2. /**
  3. *
  4. *
  5. * @author Ellisran
  6. * @date 2020/10/15
  7. * @version
  8. */
  9. const status = require('../const/audit').changeApply.status;
  10. const _ = require('lodash');
  11. module.exports = options => {
  12. /**
  13. * 标段校验 中间件
  14. * 1. 读取标段数据(包括属性)
  15. * 2. 检验用户是否可见标段(不校验具体权限)
  16. *
  17. * @param {function} next - 中间件继续执行的方法
  18. * @return {void}
  19. */
  20. return function* changePlanCheck(next) {
  21. try {
  22. // 获取revise
  23. if (!this.session.sessionProject.page_show.openChangePlan) {
  24. throw '该功能已关闭';
  25. }
  26. const cpid = this.params.cpid || this.request.body.cpid;
  27. if (!cpid) {
  28. throw '您访问的变更方案不存在';
  29. }
  30. const change = yield this.service.changePlan.getDataById(cpid);
  31. // 读取原报、审核人数据
  32. change.auditors = yield this.service.changePlanAudit.getAuditors(change.id, change.times);
  33. change.curAuditor = yield this.service.changePlanAudit.getCurAuditor(change.id, change.times);
  34. if (!change) throw '变更令数据有误';
  35. // 权限相关
  36. // todo 校验权限 (标段参与人、分享)
  37. const accountId = this.session.sessionUser.accountId,
  38. auditorIds = _.map(change.auditors, 'aid'),
  39. shareIds = [];
  40. if (accountId === change.uid) { // 原报
  41. // if (change.curAuditor) {
  42. // change.readOnly = change.status === status.checking && change.curAuditor.user_id === accountId;
  43. // } else {
  44. // change.readOnly = change.status !== status.uncheck && change.status !== status.back;
  45. // }
  46. change.curTimes = change.times;
  47. if (change.status === status.uncheck || change.status === status.checkNo) {
  48. change.curOrder = 0;
  49. } else if (change.status === status.checked) {
  50. change.curOrder = _.max(_.map(change.auditors, 'order'));
  51. } else {
  52. change.curOrder = change.curAuditor.aid === accountId ? change.curAuditor.order : change.curAuditor.order - 1;
  53. }
  54. change.filePermission = true;
  55. } else if (this.tender.isTourist) {
  56. change.curTimes = change.times;
  57. if (change.status === status.uncheck || change.status === status.checkNo) {
  58. change.curOrder = 0;
  59. } else if (change.status === status.checked) {
  60. change.curOrder = _.max(_.map(change.auditors, 'order'));
  61. } else {
  62. change.curOrder = change.curAuditor.order;
  63. }
  64. change.filePermission = this.tender.touristPermission.file || auditorIds.indexOf(accountId) !== -1;
  65. } else if (auditorIds.indexOf(accountId) !== -1) { // 审批人
  66. if (change.status === status.uncheck) {
  67. throw '您无权查看该数据';
  68. }
  69. // change.readOnly = change.status !== status.checking || accountId !== change.curAuditor.aid;
  70. change.curTimes = change.status === status.checkNo ? change.times - 1 : change.times;
  71. if (change.status === status.checked) {
  72. change.curOrder = _.max(_.map(change.auditors, 'order'));
  73. } else if (change.status === status.checkNo) {
  74. const audit = this.service.changePlanAudit.getDataByCondition({
  75. cpid: change.id, times: change.times, status: status.checkNo,
  76. });
  77. change.curOrder = audit.order;
  78. } else {
  79. change.curOrder = accountId === change.curAuditor.aid ? change.curAuditor.order : change.curAuditor.order - 1;
  80. }
  81. change.filePermission = true;
  82. } else if (shareIds.indexOf(accountId) !== -1) { // 分享人
  83. if (change.status === status.uncheck) {
  84. throw '您无权查看该数据';
  85. }
  86. // change.readOnly = true;
  87. change.curTimes = change.status === status.checkNo ? change.times - 1 : change.times;
  88. change.curOrder = change.status === status.checked ? _.max(_.map(change.auditors, 'order')) : change.curAuditor.order - 1;
  89. change.filePermission = false;
  90. } else { // 其他不可见
  91. throw '您无权查看该数据';
  92. }
  93. // 调差的readOnly 指表格和页面只能看不能改,和审批无关
  94. change.readOnly = !((change.status === status.uncheck || change.status === status.checkNo) && accountId === change.uid);
  95. change.shenpiPower = change.status === status.checking && change.curAuditor.aid === accountId;
  96. this.change = change;
  97. yield next;
  98. } catch (err) {
  99. console.log(err);
  100. // 输出错误到日志
  101. if (err.stack) {
  102. this.logger.error(err);
  103. } else {
  104. this.getLogger('fail').info(JSON.stringify({
  105. error: err,
  106. project: this.session.sessionProject,
  107. user: this.session.sessionUser,
  108. body: this.session.body,
  109. }));
  110. }
  111. // 重定向值标段管理
  112. this.redirect(this.request.headers.referer);
  113. }
  114. };
  115. };