|
|
|
import { login, logout, getInfo } from '@/api/user'
|
|
|
|
import { getStorage, setStorage, removeStorage } from '@/utils/auth'
|
|
|
|
|
|
|
|
import router, { resetRouter } from '@/router'
|
|
|
|
|
|
|
|
const state = {
|
|
|
|
token: getStorage(),
|
|
|
|
userInfo: '',
|
|
|
|
menus: ''
|
|
|
|
}
|
|
|
|
|
|
|
|
const mutations = {
|
|
|
|
SET_TOKEN: (state, token) => {
|
|
|
|
state.token = token
|
|
|
|
},
|
|
|
|
SET_UESRINFO: (state, userInfo) => {
|
|
|
|
state.userInfo = userInfo
|
|
|
|
},
|
|
|
|
SET_MENUS: (state, menus) => {
|
|
|
|
state.menus = menus
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
const actions = {
|
|
|
|
// user login
|
|
|
|
login({ commit }, userInfo) {
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
login(userInfo).then(response => {
|
|
|
|
const { data } = response
|
|
|
|
commit('SET_TOKEN', data.token)
|
|
|
|
setStorage(data.token)
|
|
|
|
let user = {
|
|
|
|
roleSid: data.roleSid,
|
|
|
|
name: data.name,
|
|
|
|
userName: data.userName,
|
|
|
|
departmentName: data.departmentName,
|
|
|
|
isAdmin: data.isAdmin,
|
|
|
|
staffSid: data.staffSid,
|
|
|
|
userSid: data.sid,
|
|
|
|
orgSid: data.organizationSid,
|
|
|
|
Orgname: data.organizationName,
|
|
|
|
dwjb: data.dwjb,
|
|
|
|
pNameAndDepartmentNameAndPostName: data.pNameAndDepartmentNameAndPostName,
|
|
|
|
roleName: data.roleName,
|
|
|
|
defaultOrgPathName: data.defaultOrgPathName,
|
|
|
|
defaultOrgPath: data.defaultOrgPath,
|
|
|
|
postName: data.postName,
|
|
|
|
sid: data.sid,
|
|
|
|
type:data.type
|
|
|
|
}
|
|
|
|
commit('SET_UESRINFO', user)
|
|
|
|
window.sessionStorage.setItem('userSid', user.userSid)
|
|
|
|
window.sessionStorage.setItem('userName', user.userName)
|
|
|
|
window.sessionStorage.setItem('Orgname', user.Orgname)
|
|
|
|
window.sessionStorage.setItem('departmentName', user.departmentName)
|
|
|
|
window.sessionStorage.setItem('name', user.name)
|
|
|
|
window.sessionStorage.setItem('pNameAndDepartmentNameAndPostName', user.pNameAndDepartmentNameAndPostName)
|
|
|
|
window.sessionStorage.setItem('roleName', user.roleName)
|
|
|
|
window.sessionStorage.setItem('defaultOrgPathName', user.defaultOrgPathName)
|
|
|
|
window.sessionStorage.setItem('defaultOrgPath', user.defaultOrgPath)
|
|
|
|
window.sessionStorage.setItem('postName', user.postName)
|
|
|
|
window.sessionStorage.setItem('sid', user.sid)
|
|
|
|
window.sessionStorage.setItem('type', user.type)
|
|
|
|
resolve(data)
|
|
|
|
}).catch(error => {
|
|
|
|
reject(error)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
},
|
|
|
|
|
|
|
|
// get user info
|
|
|
|
getInfo({ commit, state }) {
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
getInfo().then(response => {
|
|
|
|
const { data } = response
|
|
|
|
if (!data) {
|
|
|
|
removeStorage()
|
|
|
|
reject('Verification failed, please Login again.')
|
|
|
|
}
|
|
|
|
let user = {
|
|
|
|
roleSid: data.roleSid,
|
|
|
|
name: data.name,
|
|
|
|
userName: data.userName,
|
|
|
|
orgRoleName: data.orgRoleName,
|
|
|
|
isAdmin: data.isAdmin,
|
|
|
|
staffSid: data.staffSid,
|
|
|
|
userSid: data.sid,
|
|
|
|
orgSid: data.organizationSid,
|
|
|
|
Orgname: data.organizationName,
|
|
|
|
dwjb: data.dwjb
|
|
|
|
}
|
|
|
|
commit('SET_UESRINFO', user)
|
|
|
|
resolve(data)
|
|
|
|
}).catch((error) => {
|
|
|
|
removeStorage()
|
|
|
|
router.push({ path: '/' })
|
|
|
|
// reject(error)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
},
|
|
|
|
|
|
|
|
getMenus({ commit, state }) {
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
getInfo().then(response => {
|
|
|
|
const { data } = response
|
|
|
|
commit('SET_UESRINFO', user)
|
|
|
|
resolve(data)
|
|
|
|
}).catch(error => {
|
|
|
|
reject(error)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
},
|
|
|
|
|
|
|
|
// user logout
|
|
|
|
logout({ commit, state, dispatch }) {
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
logout(state.token).then(() => {
|
|
|
|
commit('SET_TOKEN', '')
|
|
|
|
commit('SET_UESRINFO', '')
|
|
|
|
removeStorage()
|
|
|
|
resetRouter()
|
|
|
|
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
|
|
|
|
}
|