| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192 | 'use strict';/** * * * @author Mai * @date * @version */const messageType = require('../const/message_type');const _ = require('lodash');const financialConst = require('../const/financial');const status = require('../const/audit').financial.status;module.exports = options => {    /**     * 标段校验 中间件     * 1. 读取标段数据(包括属性)     * 2. 检验用户是否可见标段(不校验具体权限)     *     * @param {function} next - 中间件继续执行的方法     * @return {void}     */    return function* financialPayCheck(next) {        try {            if (!this.subProject) throw '项目不存在';            if (!this.subProject.page_show.openFinancial) {                throw '该功能已关闭或无法查看';            }            const fpid = this.params.fpid;            if (!fpid) {                throw '参数数据错误';            }            const financialPay = yield this.service.financialPay.getOnePay(fpid);            yield this.service.financialPay.loadPayUser(financialPay);            // 权限相关            // todo 校验权限 (标段参与人、分享)            const accountId = this.session.sessionUser.accountId,                auditorIds = _.map(financialPay.auditors, 'aid');            if (financialPay.permission.pay_show) {                const fptAudits = yield this.service.financialPayTenderAudit.getDataByCondition({ spid: financialPay.spid, tid: financialPay.tid, uid: accountId });                if (!this.session.sessionUser.is_admin && !fptAudits) {                    throw '您无权查看该数据';                }                financialPay.filePermission = financialPay.permission.pay_file ||                    (financialPay.status === status.checking && auditorIds.indexOf(accountId) !== -1) ||                    ((financialPay.status === status.uncheck || financialPay.status === status.checkNo) && accountId === financialPay.uid);            } else { // 其他不可见                throw '您无权查看该数据';            }            financialPay.filePermission = financialPay.filePermission ? true : financialPay.permission.pay_file;            // 调差的readOnly 指表格和页面只能看不能改,和审批无关            // financialPay.readOnly = true;            financialPay.readOnly = !((financialPay.status === status.uncheck || financialPay.status === status.checkNo) && accountId === financialPay.uid);            financialPay.shenpiPower = financialPay.status === status.checking && financialPay.curAuditorIds.indexOf(accountId) !== -1;            this.financialPay = financialPay;            yield next;        } catch (err) {            // 输出错误到日志            if (err.stack) {                this.logger.error(err);            } else {                this.session.message = {                    type: messageType.ERROR,                    icon: 'exclamation-circle',                    message: err,                };                this.getLogger('fail').info(JSON.stringify({                    error: err,                    project: this.session.sessionProject,                    user: this.session.sessionUser,                    body: this.session.body,                }));            }            if (this.helper.isAjax(this.request)) {                if (err.stack) {                    this.body = { err: 4, msg: '标段数据未知错误', data: null };                } else {                    this.body = { err: 3, msg: err.toString(), data: null };                }            } else {                if (this.helper.isWap(this.request)) {                    this.redirect('/wap/list');                } else {                    this.postError(err, '未知错误');                    err === '该功能已关闭或无法查看' ? this.redirect('/dashboard') : this.request.headers.referer ? this.redirect(this.request.headers.referer) : this.redirect(`/sp/${this.subProject.id}/financial`);                }            }        }    };};
 |