bonus-checkVerify-app/store/modules/user.js

123 lines
3.6 KiB
JavaScript
Raw Normal View History

2025-10-20 09:12:27 +08:00
import config from '@/config'
import storage from '@/utils/storage'
import constant from '@/utils/constant'
import { login, logout, getInfo } from '@/api/login'
import { getToken, setToken, removeToken } from '@/utils/auth'
import Cookies from "js-cookie";
import { encryptWithSM4 } from '@/utils/sm'
const baseUrl = config.baseUrl
const user = {
state: {
token: getToken(),
name: storage.get(constant.name),
avatar: storage.get(constant.avatar),
roles: storage.get(constant.roles)
},
mutations: {
SET_TOKEN: (state, token) => {
state.token = token
},
SET_NAME: (state, name) => {
state.name = name
storage.set(constant.name, name)
},
SET_AVATAR: (state, avatar) => {
state.avatar = avatar
storage.set(constant.avatar, avatar)
},
SET_ROLES: (state, roles) => {
state.roles = roles
storage.set(constant.roles, roles)
},
SET_PERMISSIONS: (state, permissions) => {
state.permissions = permissions
storage.set(constant.permissions, permissions)
},
SET_ACCOUNT_ID: (state, id) => {
state.userId = id
}
},
actions: {
// 登录
Login({ commit }, userInfo) {
const formData = {
username: encryptWithSM4(userInfo.username),
password: encryptWithSM4(userInfo.password),
// loginType: 'USERNAME_PASSWORD',
// loginType: 'PHONE_PASSWORD',//CUST_PHONE_PASSWORD
loginType: 'USERNAME_PASSWORD',//CUST_PHONE_PASSWORD
sourceType: 7,
// code: userInfo.code,
// uuid: userInfo.uuid
}
return new Promise((resolve, reject) => {
console.log('🚀 ~ login ~ formData11:', formData)
login(formData).then(res => {
console.log('🚀 ~ login ~ res:', res)
setToken(res.data.access_token)
uni.setStorageSync('pwd', userInfo.encryptPassword)
uni.setStorageSync('token', res.data.access_token)
Cookies.set('token', res.data.access_token,{expires:90})
resolve()
})
.catch(error => {
reject(error)
})
})
},
// 获取用户信息
GetInfo({ commit, state }) {
return new Promise((resolve, reject) => {
getInfo().then(res => {
const user = res.user
const avatar =
user == null || user.avatar == '' || user.avatar == null
? require('@/static/images/profile.jpg')
: baseUrl + user.avatar
const username = user == null || user.userName == '' || user.userName == null ? '' : user.userName
if (res.roles && res.roles.length > 0) {
commit('SET_ROLES', res.roles)
commit('SET_PERMISSIONS', res.permissions)
} else {
commit('SET_ROLES', ['ROLE_DEFAULT'])
}
commit('SET_NAME', username)
commit('SET_AVATAR', avatar)
resolve(res)
})
.catch(error => {
reject(error)
})
})
},
// 退出系统
LogOut({ commit, state }) {
return new Promise((resolve, reject) => {
logout(state.token).then(() => {
commit('SET_TOKEN', '');
commit('SET_ROLES', []);
commit('SET_PERMISSIONS', []);
removeToken();
storage.clean();
resolve();
}).catch(error => {
reject(error);
});
// commit('SET_TOKEN', '')
// commit('SET_ROLES', [])
// commit('SET_PERMISSIONS', [])
// removeToken()
// storage.clean()
// resolve()
})
}
}
}
export default user