user.js 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. import { login, logout, getInfo } from '@/api/login'
  2. import { getToken, setToken, removeToken } from '@/utils/auth'
  3. const user = {
  4. state: {
  5. token: getToken(),
  6. name: '',
  7. avatar: '',
  8. roles: [],
  9. permissions: []
  10. },
  11. mutations: {
  12. SET_TOKEN: (state, token) => {
  13. state.token = token
  14. },
  15. SET_NAME: (state, name) => {
  16. state.name = name
  17. },
  18. SET_AVATAR: (state, avatar) => {
  19. state.avatar = avatar
  20. },
  21. SET_ROLES: (state, roles) => {
  22. state.roles = roles
  23. },
  24. SET_PERMISSIONS: (state, permissions) => {
  25. state.permissions = permissions
  26. }
  27. },
  28. actions: {
  29. // 登录
  30. Login({ commit }, userInfo) {
  31. const username = userInfo.username.trim()
  32. const password = userInfo.password
  33. const code = userInfo.code
  34. const uuid = userInfo.uuid
  35. return new Promise((resolve, reject) => {
  36. login(username, password, code, uuid).then(res => {
  37. res = res.data;
  38. setToken(res.token)
  39. commit('SET_TOKEN', res.token)
  40. resolve()
  41. }).catch(error => {
  42. reject(error)
  43. })
  44. })
  45. },
  46. // 获取用户信息
  47. GetInfo({ commit, state }) {
  48. return new Promise((resolve, reject) => {
  49. getInfo(state.token).then(res => {
  50. res = res.data; // 读取 data 数据
  51. const user = res.user
  52. const avatar = user.avatar === "" ? require("@/assets/images/profile.jpg") : user.avatar;
  53. if (res.roles && res.roles.length > 0) { // 验证返回的roles是否是一个非空数组
  54. commit('SET_ROLES', res.roles)
  55. commit('SET_PERMISSIONS', res.permissions)
  56. } else {
  57. commit('SET_ROLES', ['ROLE_DEFAULT'])
  58. }
  59. commit('SET_NAME', user.userName)
  60. commit('SET_AVATAR', avatar)
  61. resolve(res)
  62. }).catch(error => {
  63. reject(error)
  64. })
  65. })
  66. },
  67. // 退出系统
  68. LogOut({ commit, state }) {
  69. return new Promise((resolve, reject) => {
  70. logout(state.token).then(() => {
  71. commit('SET_TOKEN', '')
  72. commit('SET_ROLES', [])
  73. commit('SET_PERMISSIONS', [])
  74. removeToken()
  75. resolve()
  76. }).catch(error => {
  77. reject(error)
  78. })
  79. })
  80. },
  81. // 前端 登出
  82. FedLogOut({ commit }) {
  83. return new Promise(resolve => {
  84. commit('SET_TOKEN', '')
  85. removeToken()
  86. resolve()
  87. })
  88. }
  89. }
  90. }
  91. export default user