| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120 | 'use strict';/** * * * @author Ellisran * @date 2020/10/15 * @version */const status = require('../const/audit').changeApply.status;const _ = require('lodash');module.exports = options => {    /**     * 标段校验 中间件     * 1. 读取标段数据(包括属性)     * 2. 检验用户是否可见标段(不校验具体权限)     *     * @param {function} next - 中间件继续执行的方法     * @return {void}     */    return function* changeApplyCheck(next) {        try {            // 获取revise            if (!this.session.sessionProject.page_show.openChangeApply) {                throw '该功能已关闭';            }            const caid = this.params.caid || this.request.body.caid;            if (!caid) {                throw '您访问的变更立项不存在';            }            const change = yield this.service.changeApply.getDataById(caid);            // 读取原报、审核人数据            change.auditors = yield this.service.changeApplyAudit.getAuditors(change.id, change.times);            change.curAuditor = yield this.service.changeApplyAudit.getCurAuditor(change.id, change.times);            // decimal小数位设置            change.decimal = change.decimal ? JSON.parse(change.decimal) : { tp: this.tender.info.decimal.tp, up: this.tender.info.decimal.up, precision: this.tender.info.precision };            if (!change) throw '变更令数据有误';            // 权限相关            // todo 校验权限 (标段参与人、分享)            const accountId = this.session.sessionUser.accountId,                auditorIds = _.map(change.auditors, 'aid'),                shareIds = [];            if (accountId === change.uid) { // 原报                // if (change.curAuditor) {                //     change.readOnly = change.status === status.checking && change.curAuditor.user_id === accountId;                // } else {                //     change.readOnly = change.status !== status.uncheck && change.status !== status.back;                // }                change.curTimes = change.times;                if (change.status === status.uncheck || change.status === status.checkNo) {                    change.curOrder = 0;                } else if (change.status === status.checked) {                    change.curOrder = _.max(_.map(change.auditors, 'order'));                } else {                    change.curOrder = change.curAuditor.aid === accountId ? change.curAuditor.order : change.curAuditor.order - 1;                }                change.filePermission = true;            } else if (this.tender.isTourist) {                change.curTimes = change.times;                if (change.status === status.uncheck || change.status === status.checkNo) {                    change.curOrder = 0;                } else if (change.status === status.checked) {                    change.curOrder = _.max(_.map(change.auditors, 'order'));                } else {                    change.curOrder = change.curAuditor.order;                }                change.filePermission = this.tender.touristPermission.file || auditorIds.indexOf(accountId) !== -1;            } else if (auditorIds.indexOf(accountId) !== -1) { // 审批人                if (change.status === status.uncheck) {                    throw '您无权查看该数据';                }                // change.readOnly = change.status !== status.checking || accountId !== change.curAuditor.aid;                change.curTimes = change.status === status.checkNo ? change.times - 1 : change.times;                if (change.status === status.checked) {                    change.curOrder = _.max(_.map(change.auditors, 'order'));                } else if (change.status === status.checkNo) {                    const audit = this.service.changeApplyAudit.getDataByCondition({                        caid: change.id, times: change.times, status: status.checkNo,                    });                    change.curOrder = audit.order;                } else {                    change.curOrder = accountId === change.curAuditor.aid ? change.curAuditor.order : change.curAuditor.order - 1;                }                change.filePermission = true;            } else if (shareIds.indexOf(accountId) !== -1) { // 分享人                if (change.status === status.uncheck) {                    throw '您无权查看该数据';                }                // change.readOnly = true;                change.curTimes = change.status === status.checkNo ? change.times - 1 : change.times;                change.curOrder = change.status === status.checked ? _.max(_.map(change.auditors, 'order')) : change.curAuditor.order - 1;                change.filePermission = false;            } else { // 其他不可见                throw '您无权查看该数据';            }            // 调差的readOnly 指表格和页面只能看不能改,和审批无关            change.readOnly = !((change.status === status.uncheck || change.status === status.checkNo) && accountId === change.uid);            this.change = change;            yield next;        } catch (err) {            console.log(err);            // 输出错误到日志            if (err.stack) {                this.logger.error(err);            } else {                this.getLogger('fail').info(JSON.stringify({                    error: err,                    project: this.session.sessionProject,                    user: this.session.sessionUser,                    body: this.session.body,                }));            }            // 重定向值标段管理            this.redirect(this.request.headers.referer);        }    };};
 |