auth.js
1.1 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
/**
* 登录判断
* @author: xuqi<qi.xu@yoho.cn>
* @date: 2016/4/25
*/
'use strict';
const _ = require('lodash');
const helpers = global.yoho.helpers;
module.exports = (req, res, next) => {
let refer = req.method === 'GET' ? req.get('Referer') : '';
let loginAPI = helpers.urlFormat('/passport/login', {refer: refer});
let loginPage = helpers.urlFormat('/passport/login', {refer: req.fullUrl()});
if (_.isEmpty(req.user) || !req.user.uid.isValid()) {
if (req.xhr) {
return res.json({
code: 400,
message: '抱歉,您暂未登录!',
data: {refer: loginAPI}
});
}
return res.redirect(loginPage);
} else if (!req.xhr && req.cookies.CSToken && req.cookies.canSkip && req.cookies.canSkip !== 'Y' &&
req.path.indexOf('passport/back/weak') < 0) {
// 登录状态,不是ajax请求 检测弱密码
return res.redirect(helpers.urlFormat('/passport/back/weak', {
refer: refer && refer.indexOf('passport/back/weak') > -1 ? '/' : refer
}));
}
next();
};