|
|
|
|
@ -3,22 +3,18 @@ import router from '@/router' |
|
|
|
|
import cache from '@/plugins/cache' |
|
|
|
|
import { MessageBox } from 'element-ui' |
|
|
|
|
import { login, logout, getInfo, getCommonConfigOptions } from '@/api/login' |
|
|
|
|
import { getToken, setToken, removeToken } from '@/utils/auth' |
|
|
|
|
import { getToken, getLoginInfo, setToken, setLoginInfo, removeToken, removeLoginInfo } from '@/utils/auth' |
|
|
|
|
import { isHttp, isEmpty } from "@/utils/validate" |
|
|
|
|
import defAva from '@/assets/images/profile.jpg' |
|
|
|
|
import { initMinioClient, parseMinioFilePath } from '@/utils/requestMinio' |
|
|
|
|
|
|
|
|
|
const user = { |
|
|
|
|
state: { |
|
|
|
|
loginInfo: getLoginInfo(), |
|
|
|
|
userInfo: {}, |
|
|
|
|
token: getToken(), |
|
|
|
|
id: '', |
|
|
|
|
name: '', |
|
|
|
|
nickName: '', |
|
|
|
|
avatar: '', |
|
|
|
|
roles: [], |
|
|
|
|
permissions: [], |
|
|
|
|
dept: '', |
|
|
|
|
status: '', |
|
|
|
|
netConfig: {} |
|
|
|
|
}, |
|
|
|
|
|
|
|
|
|
@ -26,29 +22,17 @@ const user = { |
|
|
|
|
SET_TOKEN: (state, token) => { |
|
|
|
|
state.token = token |
|
|
|
|
}, |
|
|
|
|
SET_ID: (state, id) => { |
|
|
|
|
state.id = id |
|
|
|
|
}, |
|
|
|
|
SET_NAME: (state, name) => { |
|
|
|
|
state.name = name |
|
|
|
|
}, |
|
|
|
|
SET_NICK_NAME: (state, nickName) => { |
|
|
|
|
state.nickName = nickName |
|
|
|
|
}, |
|
|
|
|
SET_AVATAR: (state, avatar) => { |
|
|
|
|
state.avatar = avatar |
|
|
|
|
}, |
|
|
|
|
SET_ROLES: (state, roles) => { |
|
|
|
|
state.roles = roles |
|
|
|
|
}, |
|
|
|
|
SET_PERMISSIONS: (state, permissions) => { |
|
|
|
|
state.permissions = permissions |
|
|
|
|
}, |
|
|
|
|
SET_DEPT: (state, dept) => { |
|
|
|
|
state.dept = dept |
|
|
|
|
SET_LOGIN_INFO: (state, loginInfo) => { |
|
|
|
|
state.loginInfo = loginInfo |
|
|
|
|
}, |
|
|
|
|
SET_STATUS: (state, status) => { |
|
|
|
|
state.status = status |
|
|
|
|
SET_USER_INFO: (state, userInfo) => { |
|
|
|
|
state.userInfo = userInfo |
|
|
|
|
}, |
|
|
|
|
SET_NET_CONFIG: (state, netConfig) => { |
|
|
|
|
state.netConfig = netConfig |
|
|
|
|
@ -60,7 +44,10 @@ const user = { |
|
|
|
|
return new Promise((resolve, reject) => { |
|
|
|
|
login(userInfo).then(res => { |
|
|
|
|
setToken(res.data.token) |
|
|
|
|
setLoginInfo(res.data) |
|
|
|
|
commit('SET_TOKEN', res.data.token) |
|
|
|
|
commit('SET_LOGIN_INFO', res.data) |
|
|
|
|
// 设置 userInfo,包含完整的用户信息
|
|
|
|
|
store.dispatch('lock/unlockScreen') |
|
|
|
|
resolve() |
|
|
|
|
}).catch(error => { |
|
|
|
|
@ -76,20 +63,15 @@ const user = { |
|
|
|
|
const user = res.data |
|
|
|
|
let avatar = user.avatar || "" |
|
|
|
|
if (!isHttp(avatar)) { |
|
|
|
|
avatar = (isEmpty(avatar)) ? defAva : process.env.VUE_APP_BASE_API + avatar |
|
|
|
|
avatar = (isEmpty(avatar)) ? defAva : state.netConfig.MINIO_ENDPOINT_HTTPS + avatar |
|
|
|
|
} |
|
|
|
|
if (res.roles && res.roles.length > 0) { // 验证返回的roles是否是一个非空数组
|
|
|
|
|
if (res.roles && res.roles.length > 0) { // 验证返回的 roles 是否是一个非空数组
|
|
|
|
|
commit('SET_ROLES', res.roles) |
|
|
|
|
commit('SET_PERMISSIONS', res.permissions) |
|
|
|
|
} else { |
|
|
|
|
commit('SET_ROLES', ['ROLE_DEFAULT']) |
|
|
|
|
} |
|
|
|
|
commit('SET_ID', user.userId) |
|
|
|
|
commit('SET_NAME', user.userName) |
|
|
|
|
commit('SET_NICK_NAME', user.nickName) |
|
|
|
|
commit('SET_AVATAR', avatar) |
|
|
|
|
commit('SET_DEPT', user.grp_name) |
|
|
|
|
commit('SET_STATUS', user.status) |
|
|
|
|
commit('SET_USER_INFO', user) |
|
|
|
|
cache.session.set('pwrChrtype', res.pwdChrtype) |
|
|
|
|
/* 初始密码提示 */ |
|
|
|
|
if (res.isDefaultModifyPwd) { |
|
|
|
|
@ -143,6 +125,7 @@ const user = { |
|
|
|
|
commit('SET_ROLES', []) |
|
|
|
|
commit('SET_PERMISSIONS', []) |
|
|
|
|
removeToken() |
|
|
|
|
removeLoginInfo() |
|
|
|
|
resolve() |
|
|
|
|
}).catch(error => { |
|
|
|
|
reject(error) |
|
|
|
|
@ -155,6 +138,7 @@ const user = { |
|
|
|
|
return new Promise(resolve => { |
|
|
|
|
commit('SET_TOKEN', '') |
|
|
|
|
removeToken() |
|
|
|
|
removeLoginInfo() |
|
|
|
|
resolve() |
|
|
|
|
}) |
|
|
|
|
} |
|
|
|
|
|