auth-helper.js 3.06 KB
'use strict';

const md5 = require('md5');
const aes = require('./aes-pwd');
const cache = global.yoho.cache;
const sign = global.yoho.sign;
const api = global.yoho.API;

const Auth = {
    signin(area, profile, password, shoppingKey) {
        let param = {
            method: 'app.passport.signin',
            area: area,
            profile: profile,
            password: password
        };

        if (shoppingKey) {
            param.shopping_key = shoppingKey;
        }

        return api.post('', param);
    },
    signinAes(area, profile, password, shoppingKey) {
        let param = {
            method: 'app.passport.signinAES',
            area: area,
            profile: profile,
            password: aes.aesPwd(password)
        };

        if (shoppingKey) {
            param.shopping_key = shoppingKey;
        }

        return api.post('', param);
    },
    signinByOpenID(nickname, openId, sourceType, shoppingKey) {
        let param = {
            nickname: nickname,
            openId: openId,
            source_type: sourceType,
            method: 'app.passport.signinByOpenID'
        };

        if (shoppingKey) {
            param.shopping_key = shoppingKey;
        }

        return api.get('', param);
    },
    signinByWechat(nickname, openId, unionId, sourceType, shoppingKey) {
        let param = {
            nickname: nickname,
            openId: openId,
            unionId: unionId,
            source_type: sourceType,
            method: 'app.passport.signinByWechat'
        };

        if (shoppingKey) {
            param.shopping_key = shoppingKey;
        }

        return api.get('', param);
    },
    profile(uid) {
        let param = {
            uid: uid,
            method: 'app.passport.profile'
        };

        return api.get('', param);
    },
    syncUserSession(uid, req, res) {
        return Auth.profile(uid).then((userInfo) => {
            let token = sign.makeToken(uid);
            let data = userInfo.data;
            let encryptionUid = aes.encryptionUid(data.uid);

            if (data) {
                let uidCookie = `{data.profile_name}::${encryptionUid}::${data.vip_info.title}::${token}`;

                req.session._TOKEN = token;
                req.session._LOGIN_UID = uid;

                res.cookie('_UID', uidCookie, {
                    domain: 'yohobuy.com'
                });
            }
            req.session._TOKEN = token; // esline-disable-line
            req.session._LOGIN_UID = uid; // esline-disable-line
            res.cookie('_TOKEN', token, {
                domain: 'yohobuy.com'
            }); // esline-disable-line
        }).catch(console.log);
    },
    rememberAccount(accountInfo, req, res) {
        let aWeek = (new Date()).getTime() / 1000 + 504000; // 504000-一周
        let rememKey = md5(md5(accountInfo.account + accountInfo.password + accountInfo.area));

        res.cookie('isRemember', true, aWeek);
        res.cookie('remem', rememKey, aWeek);
        if (!cache.get(rememKey)) {
            cache.set(rememKey, accountInfo, aWeek);
        }
    }
};

module.exports = Auth;