// +---------------------------------------------------------------------- // | CRMEB [ CRMEB赋能开发者,助力企业发展 ] // +---------------------------------------------------------------------- // | Copyright (c) 2016~2023 https://www.crmeb.com All rights reserved. // +---------------------------------------------------------------------- // | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权 // +---------------------------------------------------------------------- // | Author: CRMEB Team // +---------------------------------------------------------------------- import { login, logout, getInfo } from '@/api/user'; import { getToken, setToken, removeToken } from '@/utils/auth'; import router, { resetRouter } from '@/router'; import { isLoginApi } from '@/api/sms'; import Cookies from 'js-cookie'; import { oAuth, getQueryString } from '@/libs/wechat'; import { Loading } from 'element-ui'; /* API */ import { autoLoginApi } from '@/api/user'; const state = { token: getToken(), name: '', avatar: '', introduction: '', roles: [], isLogin: Cookies.get('isLogin'), permissions: [], captcha: { captchaVerification: '', secretKey: '', token: '', }, //滑块验证token }; const mutations = { SET_TOKEN: (state, token) => { state.token = token; }, SET_ISLOGIN: (state, isLogin) => { state.isLogin = isLogin; Cookies.set(isLogin); }, SET_INTRODUCTION: (state, introduction) => { state.introduction = introduction; }, SET_NAME: (state, name) => { state.name = name; }, SET_AVATAR: (state, avatar) => { state.avatar = avatar; }, SET_ROLES: (state, roles) => { state.roles = roles; }, SET_PERMISSIONS: (state, permissions) => { state.permissions = permissions; }, SET_CAPTCHA: (state, captcha) => { state.captcha = captcha; }, }; const actions = { // user login login ({ commit }, userInfo) { const { account, pwd, key, code, wxCode } = userInfo; Loading.service(); return new Promise((resolve, reject) => { login(userInfo) .then((data) => { let loadingInstance = Loading.service(); loadingInstance.close(); commit('SET_TOKEN', data.token); Cookies.set('JavaInfo', JSON.stringify(data)); setToken(data.token); resolve(); }) .catch((error) => { reject(error); }); }); }, // auto login autoLogin ({ commit }, accesstoken) { let params = { bcxToken: accesstoken }; return new Promise((resolve, reject) => { autoLoginApi(params).then(res => { let { token } = res; commit('SET_TOKEN', token); Cookies.set('JavaInfo', JSON.stringify(res)); setToken(token) localStorage.setItem('plat_token', token); resolve(token) }).catch(err => reject(err)); }); }, // 短信是否登录 isLogin ({ commit }, userInfo) { return new Promise((resolve, reject) => { isLoginApi() .then(async (res) => { commit('SET_ISLOGIN', res.isLogin); resolve(res); }) .catch((res) => { commit('SET_ISLOGIN', false); reject(res); }); }); }, // get user info getInfo ({ commit, state }) { return new Promise((resolve, reject) => { getInfo(state.token) .then((data) => { if (!data) { reject('Verification failed, please Login again.'); } const { roles, account } = data; // roles must be a non-empty array if (!roles || roles.length <= 0) { reject('getInfo: roles must be a non-null array!'); } commit('SET_ROLES', roles); // commit('SET_ROLES', ['admin']) commit('SET_NAME', account); // commit('SET_AVATAR', avatar) commit('SET_AVATAR', 'http://kaifa.crmeb.net/system/images/admin_logo.png'); commit('SET_INTRODUCTION', 'CRMEB admin'); commit('SET_PERMISSIONS', data.permissionsList); //权限标识 resolve(data); }) .catch((error) => { reject(error); }); }); }, // user logout logout ({ commit, state, dispatch }) { Loading.service(); return new Promise((resolve, reject) => { logout(state.token) .then(() => { let loadingInstance = Loading.service(); loadingInstance.close(); commit('SET_TOKEN', ''); commit('SET_ROLES', []); commit('SET_PERMISSIONS', []); removeToken(); resetRouter(); // localStorage.clear(); Cookies.remove('storeStaffList'); Cookies.remove('JavaInfo'); localStorage.clear('sidebarRouters'); sessionStorage.removeItem('token'); // reset visited views and cached views // to fixed https://github.com/PanJiaChen/vue-element-admin/issues/2485 dispatch('tagsView/delAllViews', null, { root: true }); resolve(); }) .catch((error) => { reject(error); }); }); }, // remove token resetToken ({ commit }) { return new Promise((resolve) => { commit('SET_TOKEN', ''); commit('SET_ROLES', []); removeToken(); resolve(); }); }, // 设置token setToken ({ commit }, state) { return new Promise((resolve) => { commit('SET_TOKEN', state.token); Cookies.set('JavaInfo', JSON.stringify(state)); setToken(data.token); resolve(); }); }, // dynamically modify permissions changeRoles ({ commit, dispatch }, role) { return new Promise(async (resolve) => { const token = role + '-token'; commit('SET_TOKEN', token); setToken(token); const { roles } = await dispatch('getInfo'); resetRouter(); // generate accessible routes map based on roles const accessRoutes = await dispatch('permission/generateRoutes', roles, { root: true }); // dynamically add accessible routes router.addRoutes(accessRoutes); // reset visited views and cached views dispatch('tagsView/delAllViews', null, { root: true }); resolve(); }); }, }; export default { namespaced: true, state, mutations, actions, };