...
|
...
|
@@ -10,20 +10,20 @@ const service = require('../models/back-service'); |
|
|
const passportHelper = require('../models/passport-helper');
|
|
|
const _ = require('lodash');
|
|
|
|
|
|
//helpers.urlFormat = (url, qs) => {
|
|
|
// let localhost = 'http://localhost:6002';
|
|
|
//
|
|
|
// if (_.isEmpty(qs)) {
|
|
|
// return localhost + url;
|
|
|
// }
|
|
|
//
|
|
|
// const queryString = require('queryString');
|
|
|
//
|
|
|
// let str = queryString.stringify(qs);
|
|
|
//
|
|
|
// return localhost + url + '?' + str;
|
|
|
//
|
|
|
//};
|
|
|
helpers.urlFormat = (url, qs) => {
|
|
|
let localhost = 'http://localhost:6002';
|
|
|
|
|
|
if (_.isEmpty(qs)) {
|
|
|
return localhost + url;
|
|
|
}
|
|
|
|
|
|
const queryString = require('queryString');
|
|
|
|
|
|
let str = queryString.stringify(qs);
|
|
|
|
|
|
return localhost + url + '?' + str;
|
|
|
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
* 找回密码主页面
|
...
|
...
|
@@ -93,11 +93,11 @@ const sendCodePage = (req, res, next) => { |
|
|
service.sendCodeToUserAsync(inputInfo.type, inputInfo.phone, inputInfo.area)
|
|
|
.then(result => {
|
|
|
|
|
|
if (result.code && result.code === 200) {
|
|
|
return next();
|
|
|
} else {
|
|
|
if (!(result.code && result.code === 200)) {
|
|
|
return res.redirect(helpers.urlFormat('/passport/back/index'));
|
|
|
}
|
|
|
|
|
|
return next();
|
|
|
})
|
|
|
.catch(next);
|
|
|
};
|
...
|
...
|
@@ -142,24 +142,23 @@ const validateMobileAPI = (req, res, next) => { |
|
|
|
|
|
if (!passportHelper.validator.isAreaMobile(passportHelper.makeAreaMobile(area, mobile))) {
|
|
|
return res.json(ERR);
|
|
|
} else {
|
|
|
return next();
|
|
|
}
|
|
|
|
|
|
next();
|
|
|
};
|
|
|
|
|
|
const validateEmailInSession = (req, res, next) => {
|
|
|
let email = req.session.email || '';
|
|
|
|
|
|
if (!email) {
|
|
|
res.redirect(helpers.urlFormat('/passport/back/index'));
|
|
|
return res.redirect(helpers.urlFormat('/passport/back/index'));
|
|
|
}
|
|
|
|
|
|
let isp = email.split('@')[1];
|
|
|
const mapperEmailISP = {
|
|
|
'yoho.cn': 'http://smail.yoho.cn'
|
|
|
};
|
|
|
|
|
|
let isp = email.split('@')[1];
|
|
|
|
|
|
req.body.emailUrl = mapperEmailISP[isp] || `http://mail.${isp}`;
|
|
|
next();
|
|
|
};
|
...
|
...
|
@@ -187,8 +186,7 @@ const validateCodeByEmailPage = (req, res, next) => { |
|
|
let code = req.query.code || '';
|
|
|
|
|
|
if (!_.isEmpty(req.mobileAuth)) {
|
|
|
next();
|
|
|
return;
|
|
|
return next();
|
|
|
}
|
|
|
|
|
|
service.checkEmailCodeAsync(code)
|
...
|
...
|
@@ -253,12 +251,12 @@ const verifyCodeByMobilePage = (req, res, next) => { |
|
|
const checkSuccessStatusPage = (req, res, next) => {
|
|
|
let successType = req.session.successType || '';
|
|
|
|
|
|
if (successType) {
|
|
|
delete req.session.successType;
|
|
|
next();
|
|
|
} else {
|
|
|
res.redirect(helpers.urlFormat('/passport/back/index'));
|
|
|
if (!successType) {
|
|
|
return res.redirect(helpers.urlFormat('/passport/back/index'));
|
|
|
}
|
|
|
|
|
|
delete req.session.successType;
|
|
|
next();
|
|
|
};
|
|
|
|
|
|
const resetPwdSuccessPage = (req, res, next) => {
|
...
|
...
|
@@ -282,7 +280,7 @@ const verifyCodeByMobileAPI = (req, res) => { |
|
|
let mobile = req.param('mobile', '');
|
|
|
let area = req.param('area', '86');
|
|
|
let mobileCode = req.param('code', '');
|
|
|
const session = req.session;
|
|
|
//const session = req.session;
|
|
|
|
|
|
const ERR = {
|
|
|
code : 400,
|
...
|
...
|
@@ -304,7 +302,7 @@ const verifyCodeByMobileAPI = (req, res) => { |
|
|
};
|
|
|
|
|
|
const validateExistCodePage = (req, res, next) => {
|
|
|
let code = req.param('code', '');
|
|
|
let code = req.query.code || req.body.code;
|
|
|
|
|
|
if (!code) {
|
|
|
return res.redirect(helpers.urlFormat('/passport/back/index'));
|
...
|
...
|
@@ -314,24 +312,25 @@ const validateExistCodePage = (req, res, next) => { |
|
|
};
|
|
|
|
|
|
const validateCodeByMobilePage = (req, res, next) => {
|
|
|
let code = req.param('code', '');
|
|
|
let mobile = req.param('mobile', '');
|
|
|
let code = req.query.code || req.body.code;
|
|
|
let mobile = req.query.mobile || req.body.mobile;
|
|
|
let area = req.query.area || req.body.area;
|
|
|
let token = req.query.token || req.body.token;
|
|
|
let createdAt = req.query.createdAt || req.body.createdAt;
|
|
|
|
|
|
if (!mobile) {
|
|
|
req.mobileAuth = {};
|
|
|
next();
|
|
|
return;
|
|
|
return next();
|
|
|
}
|
|
|
|
|
|
let data = {
|
|
|
mobile : mobile,
|
|
|
area : req.param('area', ''),
|
|
|
token : req.param('token', ''),
|
|
|
create_time: req.param('create_time', 0)
|
|
|
mobile : mobile,
|
|
|
area : area,
|
|
|
token : token,
|
|
|
createdAt: createdAt
|
|
|
};
|
|
|
|
|
|
code = new Buffer(code, 'base64').toString();
|
|
|
|
|
|
req.mobileAuth = service.authRequest(data, code);
|
|
|
|
|
|
next();
|
...
|
...
|
@@ -340,11 +339,11 @@ const validateCodeByMobilePage = (req, res, next) => { |
|
|
const validatePwdPage = (req, res, next) => {
|
|
|
let pwd = req.body.pwd || '';
|
|
|
|
|
|
if (helpers.isPassword(pwd)) {
|
|
|
next();
|
|
|
} else {
|
|
|
res.redirect(helpers.urlFormat('/passport/back/index'));
|
|
|
if (!passportHelper.validator.isPassword(pwd)) {
|
|
|
return res.redirect(helpers.urlFormat('/passport/back/index'));
|
|
|
}
|
|
|
|
|
|
next();
|
|
|
};
|
|
|
|
|
|
const updatePwdAPI = (req, res, next) => {
|
...
|
...
|
@@ -365,20 +364,15 @@ const updatePwdAPI = (req, res, next) => { |
|
|
};
|
|
|
|
|
|
const validateMobileInSession = (req, res, next) => {
|
|
|
|
|
|
console.log(req.session.mobile);
|
|
|
console.log(req.session.area);
|
|
|
|
|
|
|
|
|
req.body.mobile = req.session.mobile || '';
|
|
|
req.body.verifyCode = req.session.verifyCode || '';
|
|
|
req.body.area = req.session.area || '';
|
|
|
|
|
|
if (req.body.mobile && req.body.verifyCode) {
|
|
|
return next();
|
|
|
} else {
|
|
|
if (!(req.body.mobile && req.body.verifyCode)) {
|
|
|
return res.redirect(helpers.urlFormat('/passport/back/index'));
|
|
|
}
|
|
|
|
|
|
next();
|
|
|
};
|
|
|
|
|
|
module.exports = {
|
...
|
...
|
|