You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
137 lines
2.5 KiB
137 lines
2.5 KiB
|
4 years ago
|
import {
|
||
|
|
login,
|
||
|
|
logout,
|
||
|
|
getInfo
|
||
|
|
} from '@/api/user'
|
||
|
|
import {
|
||
|
|
getToken,
|
||
|
|
setToken,
|
||
|
|
removeToken
|
||
|
|
} from '@/utils/auth'
|
||
|
|
import {
|
||
|
|
resetRouter
|
||
|
|
} from '@/router'
|
||
|
|
|
||
|
|
const getDefaultState = () => {
|
||
|
|
return {
|
||
|
|
token: getToken(),
|
||
|
|
name: '',
|
||
|
|
avatar: '',
|
||
|
|
roles: []
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
const state = getDefaultState()
|
||
|
|
|
||
|
|
const mutations = {
|
||
|
|
RESET_STATE: (state) => {
|
||
|
|
Object.assign(state, getDefaultState())
|
||
|
|
},
|
||
|
|
SET_TOKEN: (state, token) => {
|
||
|
|
state.token = token
|
||
|
|
},
|
||
|
|
SET_NAME: (state, name) => {
|
||
|
|
state.name = name
|
||
|
|
},
|
||
|
|
SET_AVATAR: (state, avatar) => {
|
||
|
|
state.avatar = avatar
|
||
|
|
},
|
||
|
|
SET_ROLES: (state, roles) => {
|
||
|
|
state.roles = roles
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
const actions = {
|
||
|
|
// user login
|
||
|
|
login({
|
||
|
|
commit
|
||
|
|
}, userInfo) {
|
||
|
|
const {
|
||
|
|
username,
|
||
|
|
password
|
||
|
|
} = userInfo
|
||
|
|
return new Promise((resolve, reject) => {
|
||
|
|
login({
|
||
|
|
username: username.trim(),
|
||
|
|
password: password
|
||
|
|
}).then(response => {
|
||
|
|
console.log(response)
|
||
|
|
const {
|
||
|
|
data
|
||
|
|
} = response;
|
||
|
|
console.log(response.access_token)
|
||
|
|
commit('SET_TOKEN', response.access_token)
|
||
|
|
setToken(response.access_token)
|
||
|
|
resolve()
|
||
|
|
}).catch(error => {
|
||
|
|
reject(error)
|
||
|
|
})
|
||
|
|
})
|
||
|
|
},
|
||
|
|
|
||
|
|
// get user info
|
||
|
|
getInfo({
|
||
|
|
commit,
|
||
|
|
state
|
||
|
|
}) {
|
||
|
|
return new Promise((resolve, reject) => {
|
||
|
|
getInfo(state.token).then(response => {
|
||
|
|
|
||
|
|
if (!response) {
|
||
|
|
reject('身份验证失败请重新登录')
|
||
|
|
}
|
||
|
|
response["roles"] = ["admin"];
|
||
|
|
const {
|
||
|
|
roles,
|
||
|
|
name,
|
||
|
|
avatar
|
||
|
|
} = response
|
||
|
|
|
||
|
|
|
||
|
|
|
||
|
|
commit('SET_ROLES', roles)
|
||
|
|
commit('SET_NAME', name)
|
||
|
|
commit('SET_AVATAR', avatar)
|
||
|
|
resolve(response)
|
||
|
|
}).catch(error => {
|
||
|
|
reject(error)
|
||
|
|
})
|
||
|
|
})
|
||
|
|
},
|
||
|
|
|
||
|
|
// user logout
|
||
|
|
logout({
|
||
|
|
commit,
|
||
|
|
state
|
||
|
|
}) {
|
||
|
|
return new Promise((resolve, reject) => {
|
||
|
|
logout(state.token).then(() => {
|
||
|
|
removeToken() // must remove token first
|
||
|
|
resetRouter()
|
||
|
|
commit('RESET_STATE')
|
||
|
|
resolve()
|
||
|
|
}).catch(error => {
|
||
|
|
reject(error)
|
||
|
|
})
|
||
|
|
})
|
||
|
|
},
|
||
|
|
|
||
|
|
// remove token
|
||
|
|
resetToken({
|
||
|
|
commit
|
||
|
|
}) {
|
||
|
|
return new Promise(resolve => {
|
||
|
|
removeToken() // must remove token first
|
||
|
|
commit('RESET_STATE')
|
||
|
|
resolve()
|
||
|
|
})
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
export default {
|
||
|
|
namespaced: true,
|
||
|
|
state,
|
||
|
|
mutations,
|
||
|
|
actions
|
||
|
|
}
|