import { token, logout, getUsersByToken, getUsersByUserName } from '@/api/wms-auth' import { getToken, setToken, removeToken, } from '@/utils/auth' import router, { resetRouter } from '@/router' import qs from 'qs' import store from '@/store' import { mgr } from "@/oidc/oidc-client"; const state = { introduction: '', userInfo:null } const mutations = { SET_INTRODUCTION: (state, introduction) => { state.introduction = introduction }, SET_USERINFO: (state, data) => { state.userInfo = data } } // 登录(token)成功后处理 const loginSuccess = (res,username,resolve,reject) => { setToken(res.token_type + ' ' + res.access_token) localStorage.setItem('isLoginTokenName',username) store.dispatch('user/getUserInfo',username).then(()=>{ resolve() }).catch(()=>{ reject() }) } // 单点登录(token)成功后处理 const loginSuccessBySignin = (res,resolve, reject,commit) => { let _token = res.token_type + ' ' + res.access_token setToken(_token) store.dispatch('user/getUserInfoByToken',res.access_token).then(()=>{ resolve() }).catch(()=>{ reject() }) } const actions = { // 登录,需要密码 login({ commit, }, userInfo) { const { password, username, } = userInfo return new Promise((resolve, reject) => { let params = qs.stringify({ password: password, username: username, client_id:localStorage.getItem('appClientId'), scopes:localStorage.getItem('appClientScope'), grant_type:'password' }); token(params).then(response => { if (response.access_token == null) { reject() } else { loginSuccess(response,username,resolve,reject,commit) } }).catch(error => { reject(error) }) }) }, // 自动登录,不需要密码 todo:更改接口,去掉password loginOnlyName({ commit, }, userInfo) { const { password, username, } = userInfo return new Promise((resolve, reject) => { let params = qs.stringify({ password: '1q2w3E*', username: username, client_id:localStorage.getItem('appClientId'), scopes:localStorage.getItem('appClientScope'), grant_type:'password' }); token(params).then(response => { if (response.access_token == null) { reject() } else { loginSuccess(response,username,resolve,reject,commit) } }).catch(error => { reject(error) }) }) }, // 单点登录 loginBySignin({ commit, }) { return new Promise((resolve, reject) => { mgr.signinRedirectCallback() .then(() => { mgr.getUser() .then((res_token) => { if(res_token){ loginSuccessBySignin(res_token,resolve, reject,commit) }else{ mgr.signinRedirect(); //执行重定向 } }) }) .catch(function(e) { // console.log('catch') mgr.signinRedirect(); //执行重定向 console.error("CallBack 错误信息" + e); }); }) }, // user logout logout({ commit, dispatch }) { return new Promise((resolve, reject) => { // logout().then(() => { dispatch('permission/setUserRoles',[]) dispatch('tagsView/delAllViews', null, { root: true }).then(()=>{ removeToken() resetRouter() resolve() }) // reset visited views and cached views // to fixed https://github.com/PanJiaChen/vue-element-admin/issues/2485 // 防止路由叠加(打开后单点登录的退出无效) // location.reload() // }).catch(error => { // reject(error) // }) }) }, // remove token resetToken({ commit }) { return new Promise(resolve => { commit('SET_ROLES', []) localStorage.setItem('isLoginTokenName',null) removeToken() resolve() }) }, // get userInfo getUserInfo({ commit },username) { return new Promise((resolve, reject) => { getUsersByUserName(username).then(res=>{ if(res && JSON.stringify(res).length > 0){ commit('SET_USERINFO', res) resolve(res) }else{ reject('获取用户信息失败,请重试') } }) .catch(err => { reject(err) console.log('获取用户信息失败,请重试') }) }) }, // get userInfo getUserInfoByToken({ commit },access_token) { return new Promise((resolve, reject) => { getUsersByToken(access_token) .then(info=>{ if(info){ let _info = info _info.userInfo = info.preferred_username _info.id = info.sub commit('SET_USERINFO', _info) resolve(_info) }else{ reject('用户信息获取失败') } }) .catch(err=>{ reject(err) }) }) }, } export default { namespaced: true, state, mutations, actions }