import { login, logout, getInfo } from '@/api/auth' import { getToken, setToken, removeToken } from '@/utils/auth' import router, { resetRouter } from '@/router' const state = { token:getToken(), name: '', urId:'', avatar: '', companyId:'', roles: [], info:{} } const mutations = { SET_TOKEN: (state, token) => { state.token = token }, SET_urId: (state, urId) => { state.urId = urId }, SET_NAME: (state, name) => { state.name = name }, SET_AVATAR: (state, avatar) => { state.avatar = avatar }, SET_ROLES: (state, roles) => { state.roles = roles }, SET_INFO: (state, info) => { state.info=info }, SET_COMPANYID: (state,companyId) => { state.companyId = companyId } } const actions = { // user login login({ commit }, userInfo) { const { username, password } = userInfo return new Promise((resolve, reject) => { login({ username: username.trim(), password: password }).then(response => { const { data } = response commit('SET_TOKEN', data) setToken(data) resolve(response) }).catch(error => { reject(error) }) }) }, // get user info getInfo({ commit, state }) { return new Promise((resolve, reject) => { getInfo(state.info).then(response => { const { data } = response if (!data) { reject('Verification failed, please Login again.') } //userId 用户id //roles 用户角色 //userName 用户名字 //avatar 用户头像 //introduction 用户多余向 const { userId,roles, userName,companyId} = data // roles must be a non-empty array commit('SET_INFO',response.data) commit('SET_urId',userId) commit('SET_ROLES', roles) commit('SET_NAME', userName) commit('SET_AVATAR', "profile.gif") commit('SET_COMPANYID', companyId) resolve(data) }).catch(error => { reject(error) }) }) }, // user logout logout({ commit, state, dispatch }) { return new Promise((resolve, reject) => { logout().then(() => { commit('SET_TOKEN', '') commit('SET_ROLES', []) removeToken() resetRouter() 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() }) }, // dynamically modify permissions 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 }) } } export default { namespaced: true, state, mutations, actions }