小程序端
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.
 
 
 
 
 

149 lines
5.4 KiB

import config from '@/config'
import storage from '@/utils/storage'
import constant from '@/utils/constant'
import {login, logout, getInfo, selectAllBase} from '@/api/login'
import {setToken, removeToken} from '@/utils/auth'
import * as CryptoUtils from '@/utils/cryptoUtils.js'
import store from '@/store'
const baseUrl = config.baseUrl
const user = {
state: {
id: 0, // 用户编号
name: storage.get(constant.name),
avatar: storage.get(constant.avatar),
roles: storage.get(constant.roles),
permissions: storage.get(constant.permissions),
baseId: storage.get(constant.baseId),
baseName: storage.get(constant.baseName),
baseLeader: storage.get(constant.baseLeader),
// baseList: storage.get(constant.baseList)
},
mutations: {
SET_ID: (state, id) => {
state.id = id
},
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_BASEID: (state, permissions) => {
state.baseId = permissions
storage.set(constant.baseId, permissions)
},
SET_BASENAME: (state, permissions) => {
state.baseName = permissions
storage.set(constant.baseName, permissions)
},
SET_BASELEADER: (state, permissions) => {
state.baseLeader = permissions
storage.set(constant.baseLeader, permissions)
},
CHANGE_BASEID: (state, permissions) => {
state.baseId = permissions
storage.set(constant.baseId, permissions)
},
// SET_BASELIST: (state, permissions) => {
// state.baseList = permissions
// storage.set(constant.baseList, permissions)
// }
},
actions: {
// 登录
Login({commit}, userInfo) {
const username = userInfo.username.trim()
const password = userInfo.password
// 密码加密
let publicKey = 'MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCFxCJ1OtfPlic9h59q7t2WvlW/gLT6n/FObump2EvhNJW3HsMeFaAINYR8nAjFrj/HIDIfzkGa/TGn0hxqsFURw3eYf3HOffWYNd3K3MoX70OWljwyLcBnj49wnXANhTkvj1FBb68P5vFO8KlP22c9vDNSvWcp4R3SU6C4GN7xuQIDAQAB'
const cipherText = CryptoUtils.encryptByRSA(publicKey, password)
const captchaVerification = userInfo.captchaVerification
return new Promise((resolve, reject) => {
login(username, cipherText, captchaVerification).then(res => {
res = res.data;
// 设置 token
setToken(res)
store.dispatch('dict/loadDictDatas')
resolve()
}).catch(error => {
reject(error)
})
})
},
// 获取用户信息
GetInfo({commit, state}) {
return new Promise((resolve, reject) => {
getInfo().then(res => {
res = res.data; // 读取 data 数据
const user = res.user
const avatar = (user == null || user.avatar === "" || user.avatar == null) ? require("@/static/images/profile.png") : user.avatar
const nickname = (user == null || user.nickname === "" || user.nickname == null) ? "" : user.nickname
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', nickname)
commit('SET_AVATAR', avatar)
resolve(res)
}).catch(error => {
reject(error)
})
})
},
// 退出系统
LogOut({commit, state}) {
return new Promise((resolve, reject) => {
logout(state.token).then(() => {
commit('SET_ROLES', [])
commit('SET_PERMISSIONS', [])
removeToken()
storage.clean()
resolve()
}).catch(error => {
reject(error)
})
})
},
getBaseList({commit, state}) {
return new Promise((resolve, reject) => {
selectAllBase().then(res => {
const baseList = res.data
commit('SET_BASEID', baseList[0].id)
// commit('SET_BASELIST', baseList)
resolve(baseList)
}).catch(error => {
reject(error)
})
})
},
changeBaseId({commit}, state) {
commit('CHANGE_BASEID', state)
},
changeBaseName({commit}, state) {
commit('SET_BASENAME', state)
},
changeBaseLeader({commit}, state) {
commit('SET_BASELEADER', state)
}
}
}
export default user