sub_project_check.js 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. 'use strict';
  2. /**
  3. *
  4. *
  5. * @author Mai
  6. * @date
  7. * @version
  8. */
  9. module.exports = options => {
  10. /**
  11. * 标段校验 中间件
  12. * 1. 读取标段数据(包括属性)
  13. * 2. 检验用户是否可见标段(不校验具体权限)
  14. *
  15. * @param {function} next - 中间件继续执行的方法
  16. * @return {void}
  17. */
  18. return function* subProjectCheck(next) {
  19. try {
  20. // 读取标段数据
  21. let id = this.tender ? this.tender.data.spid : this.params.id || this.query.id;
  22. // subProjectId不一定在url上给出,在项目中报表数据的调用是放到独立参数对象中的sp_id属性中
  23. if (!id) {
  24. if (this.request.body.params) {
  25. const params = JSON.parse(this.request.body.params);
  26. if (params.sp_id && params.sp_id !== -1 && params.sp_id !== '-1') {
  27. id = params.sp_id;
  28. }
  29. }
  30. }
  31. if (!id) throw '参数错误';
  32. this.subProject = yield this.service.subProject.getDataById(id);
  33. if (this.subProject.project_id !== this.session.sessionProject.id) throw '您无权查看该项目';
  34. if (!this.subProject) throw '项目不存在';
  35. // 解析属性并加载默认值
  36. this.subProject.page_show = this.service.subProject.getPageShow(this.subProject.page_show);
  37. this.subProject.fun_set = this.service.subProject.getFunSet(this.subProject.fun_set);
  38. this.subProject.fun_rela = this.service.subProject.getFunRela(this.subProject);
  39. if (this.session.sessionUser.is_admin) {
  40. this.subProject.readOnly = false;
  41. this.subProject.permission = this.service.subProjPermission.adminPermission;
  42. } else {
  43. const bp = yield this.service.subProjPermission.getSubProjectUserPermission(id, this.session.sessionUser.accountId);
  44. if (!bp) throw '您无权查看该项目';
  45. this.subProject.permission = bp;
  46. }
  47. const financialPermission = yield this.service.subProjPermission.getFinancailPermission(this.subProject.permission.fund_trans_permission, this.subProject.permission.fund_pay_permission);
  48. if (financialPermission.transfer_show) {
  49. this.subProject.financialToUrl = 'transfer';
  50. } else if (financialPermission.pay_show) {
  51. this.subProject.financialToUrl = 'pay';
  52. } else if (!financialPermission.transfer_show && !financialPermission.pay_show) {
  53. this.subProject.financialToUrl = 'transfer';
  54. }
  55. // 判断是否有权限查看决策大屏
  56. // const accountInfo = yield this.service.projectAccount.getDataById(this.session.sessionUser.accountId);
  57. // const projectData = yield this.service.project.getDataById(this.session.sessionProject.id);
  58. // let showDataCollect = 0;
  59. // if (projectData.data_collect && this.subProject.page_show.openDataCollect) {
  60. // if (this.session.sessionUser.is_admin) {
  61. // showDataCollect = 1;
  62. // } else {
  63. // const auditInfo = yield this.service.datacollectAudit.getDataByCondition({ pid: projectData.id, uid: accountInfo.id });
  64. // if (auditInfo) {
  65. // showDataCollect = 1;
  66. // } else {
  67. // let companyInfo = null;
  68. // if (accountInfo.company_id) {
  69. // companyInfo = yield this.service.datacollectAudit.getDataByCondition({
  70. // pid: projectData.id,
  71. // company_id: accountInfo.company_id,
  72. // });
  73. // } else {
  74. // const cuInfo = yield this.service.constructionUnit.getDataByCondition({
  75. // pid: projectData.id,
  76. // name: accountInfo.company,
  77. // });
  78. // if (cuInfo) {
  79. // companyInfo = yield this.service.datacollectAudit.getDataByCondition({
  80. // pid: projectData.id,
  81. // company_id: cuInfo.id,
  82. // });
  83. // yield this.service.projectAccount.update({ company_id: cuInfo.id }, { id: accountInfo.id });
  84. // }
  85. // }
  86. // if (companyInfo) {
  87. // showDataCollect = 1;
  88. // } else {
  89. // const grounpInfo = yield this.service.datacollectAudit.getGroupInfo(projectData.id, accountInfo.account_group);
  90. // if (grounpInfo) {
  91. // showDataCollect = 1;
  92. // }
  93. // }
  94. // }
  95. // }
  96. // }
  97. // this.session.sessionProject.showDataCollect = showDataCollect;
  98. // 判断是否有权限查看支付审批
  99. let showPayment = 0;
  100. if (this.session.sessionUser.is_admin) {
  101. showPayment = this.subProject.page_show.openPayment ? 1 : 0;
  102. } else {
  103. if (this.subProject.page_show.openPayment) {
  104. const auditInfo = yield this.service.subProjPermission.showPayment(this.session.sessionUser.accountId, this.subProject.id);
  105. if (auditInfo) {
  106. showPayment = 1;
  107. }
  108. }
  109. }
  110. this.subProject.showPayment = showPayment;
  111. if (this.helper.isAjax(this.request) || this.method === 'POST' || this.service.subProjPermission.checkViewPermission(this)) {
  112. yield next;
  113. } else {
  114. this.redirect(`/sp/${this.subProject.id}/nop/${this.controllerName}`);
  115. }
  116. } catch (err) {
  117. this.log(err);
  118. if (this.helper.isAjax(this.request)) {
  119. this.ajaxErrorBody(err, '未知错误');
  120. } else {
  121. this.postError(err, '未知错误');
  122. err === '该功能已关闭或无法查看' ? this.redirect('/dashboard') : this.redirect(this.request.headers.referer);
  123. }
  124. }
  125. };
  126. };