import { login, logout, getInfo, getMenu ,getImgCode,updateUserAvatarNickname,loginapi,logoutapi } from '@/api/user' import { getToken, setToken, setUserUrl, removeToken ,removUserUrl,getUserUrl,getUseType,removUseType,setUseType,getExp,setExp,removeExp,setWebSiteId,getWebSiteId,removeWebSiteId } from '@/utils/auth' import router, { resetRouter } from '@/router' import axios from 'axios' const state = { token: getToken(), name: '', avatar: '', introduction: '', roles: [], userid:'', role_id:'', userurl: getUserUrl(), usertype: getUseType(), exp:getExp(), websiteid:getWebSiteId(), } const mutations = { SET_TOKEN: (state, token) => { state.token = token }, SET_URL: (state, url) => { state.userurl = url }, SET_USE_TYPE: (state, user_type) => { state.usertype = user_type }, SET_INTRODUCTION: (state, introduction) => { state.introduction = introduction }, SET_NAME: (state, name) => { state.name = name }, SET_AVATAR: (state, avatar) => { state.avatar = avatar }, SET_ROLE_ID: (state, role_id) => { state.role_id = role_id }, SET_ROLES: (state, roles) => { state.roles = roles }, SET_USERID: (state, id) => { state.userid = id }, SET_EXP: (state, exp) => { state.exp = exp }, SET_WEBSITEID: (state, websiteid) => { state.websiteid = websiteid }, // 退出登录逻辑直接放在 mutations 中 LOGOUT(state) { state.token = ''; state.roles = []; state.userid = ''; state.role_id = ''; state.name = ''; state.avatar = ''; state.introduction = ''; removeToken(); removUserUrl(); resetRouter(); removUseType(); removeExp(); //退出登录跳转回原网站 window.location.href = "http://" + state.userurl } } const actions = { // 用户登录 login({ commit }, userInfo) { const { username, password, type, captcha, code } = userInfo //会员登录进入系统并储存 if(userInfo.userurl){ //设置axios请求头 axios.defaults.headers.common['userurl'] = userInfo.userurl } //会员登录不进入系统 if(userInfo.backurl){ //设置axios请求头 axios.defaults.headers.common['userurl'] = userInfo.backurl } return new Promise((resolve, reject) => { login({ username: username.trim(), password: password, type: type, captcha: captcha.trim(), code: code}).then(response => { const { data } = response; if(data.token==undefined){ console.log("登录失败!userurl非法!") }else{ //会员登录跳转 但不储存 if(userInfo.backurl){ console.log("不储存用户的userurl!") //设置用户url setUserUrl(userInfo.backurl,data.exp) commit('SET_URL',userInfo.backurl) //只设置token 不储存url setToken(data.token,data.exp) commit('SET_TOKEN',data.token) //储存过期时间 setExp(data.exp,data.exp) commit('SET_EXP',data.exp) } //会员登录进入系统,储存所属url if(userInfo.userurl){ console.log("储存用户的userurl!") setUserUrl(userInfo.userurl,data.exp) commit('SET_URL',userInfo.userurl) //设置token setToken(data.token,data.exp) commit('SET_TOKEN',data.token) //储存过期时间 setExp(data.exp,data.exp) commit('SET_EXP',data.exp) } } resolve(response) }).catch(error => { reject(error) }) }) }, // 获取用户身份信息 getInfo({ commit, state }) { return new Promise((resolve, reject) => { getInfo(state.token).then(response => { const { data } = response // if (!data) { // reject('Verification failed, please Login again.') // } // 所有用户的身份都为admin const roles = ['admin'] const { nickname, avatar, introduction,role_id } = data data.roles = roles // 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_USERID', data.id) commit('SET_NAME', nickname) commit('SET_AVATAR', avatar) commit('SET_INTRODUCTION', introduction) commit('SET_ROLE_ID', role_id) //设置用户等级 commit('SET_USE_TYPE',data.type_id) setUseType(data.type_id,state.exp) console.log(data.type_id) console.log(state.exp) //设置用户网站 console.log(123456789) console.log(data.website_id) commit('SET_WEBSITEID',data.website_id) setWebSiteId(data.website_id,state.exp) resolve(data) }).catch(error => { reject(error) }) }) }, // 获取图形验证码 getImgCode() { return new Promise((resolve, reject) => { getImgCode({}).then(response => { resolve(response) }).catch(error => { reject(error) }) }) }, // 用户退出 // logout({ commit, state, dispatch }) { // return new Promise((resolve, reject) => { // logout(state.token).then(() => { // commit('SET_TOKEN', '') // commit('SET_ROLES', []) // removeToken() // resetRouter() // // 重置已经访问过的视图 // // to fixed https://github.com/PanJiaChen/vue-element-admin/issues/2485 // dispatch('tagsView/delAllViews', null, { root: true }) // resolve() // }).catch(error => { // reject(error) // }) // }) // }, // 清理token resetToken({ commit }) { return new Promise(resolve => { commit('SET_TOKEN', '') commit('SET_ROLES', []) removeToken() resolve() }) }, // 用户切换时重置路由 async changeRoles({ commit, dispatch }, role) { 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 }) }, //修改用户名和密码 updateUserAvatarNickname({commit},data) { return new Promise((resolve, reject) => { updateUserAvatarNickname(data).then(response => { resolve(response) }).catch(error => { reject(error) }) }) }, //单点登录 loginapi({commit},data) { return new Promise((resolve, reject) => { loginapi(data).then(response => { resolve(response) }).catch(error => { reject(error) }) }) }, //单点登录退出 logoutapi({commit},data) { return new Promise((resolve, reject) => { logoutapi(data).then(response => { resolve(response) }).catch(error => { reject(error) }) }) }, } export default { namespaced: true, state, mutations, actions }