1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798 |
- 'use strict';
- // 加密类
- const crypto = require('crypto');
- const messageType = require('../const/message_type');
- module.exports = options => {
- /**
- * session判断中间件
- *
- * @param {function} next - 中间件继续执行的方法
- * @return {void}
- */
- return function* sessionAuth(next) {
- try {
- // 判断session
- const sessionUser = this.session.sessionUser;
- if (sessionUser === undefined) {
- throw '不存在session';
- }
- // 校验session
- if (sessionUser.account === undefined || sessionUser.loginTime === undefined) {
- throw '用户数据不完整';
- }
- // 校验session
- const sessionToken = crypto.createHmac('sha1', sessionUser.loginTime + '')
- .update(sessionUser.account).digest('hex').toString('base64');
- if (sessionToken !== sessionUser.sessionToken) {
- throw 'session数据错误';
- }
- // 获取用户新建标段权利
- const accountInfo = yield this.service.projectAccount.getDataById(this.session.sessionUser.accountId);
- this.session.sessionUser.permission = accountInfo !== undefined && accountInfo.permission !== '' ? JSON.parse(accountInfo.permission) : null;
- const projectData = yield this.service.project.getDataById(this.session.sessionProject.id);
- this.session.sessionProject.page_show = yield this.service.projectAccount.getPageShow(projectData.page_show);
- this.session.sessionProject.custom = projectData.custom;
- this.session.sessionProject.dataCollect = projectData.data_collect;
- this.session.sessionProject.customType = projectData.customType;
- // 判断是否有权限查看决策大屏
- let showDataCollect = 0;
- if (projectData.data_collect) {
- if (sessionUser.is_admin) {
- showDataCollect = 1;
- } else {
- const grounpInfo = yield this.service.datacollectAudit.getGroupInfo(projectData.id, accountInfo.account_group);
- if (grounpInfo) {
- showDataCollect = 1;
- } else {
- const auditInfo = yield this.service.datacollectAudit.getDataByCondition({ pid: projectData.id, uid: accountInfo.id });
- if (auditInfo) {
- showDataCollect = 1;
- }
- }
- }
- }
- this.session.sessionProject.showDataCollect = showDataCollect;
- // 同步消息
- yield this.service.notify.syncNotifyData();
- // 同步系统维护信息
- yield this.service.maintain.syncMaintainData();
- if (this.session === null) {
- throw '系统维护中~';
- }
- // 对sub_menu项目默认打开页进行配置
- const path = yield this.service.settingShow.getDefaultPath(this.session.sessionProject.id);
- path && (this.curListUrl = path);
- } catch (error) {
- if (this.helper.isAjax(this.request)) {
- return this.body = {
- err: 2,
- msg: '登录信息异常,请重新登录',
- data: '',
- };
- } else if (this.session === null) {
- if (this.helper.isWap(this.request)) {
- this.session.wapTenderID = this.params.id ? this.params.id : null;
- return this.redirect('/wap/login?referer=' + this.url);
- }
- return this.redirect('/login?referer=' + this.url);
- }
- if (this.helper.isWap(this.request)) {
- this.session.wapTenderID = this.params.id ? this.params.id : null;
- return this.redirect('/wap/login?referer=' + this.url);
- }
- this.session.message = {
- type: messageType.ERROR,
- icon: 'exclamation-circle',
- message: '登录信息异常,请重新登录',
- };
- return this.redirect('/login?referer=' + this.url);
- }
- yield next;
- };
- };
|