user.js 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. import { loginByUsername, logout, getUserInfo } from '@/api/login'
  2. import { getToken, setToken, removeToken } from '@/utils/auth'
  3. const user = {
  4. state: {
  5. user: '',
  6. status: '',
  7. code: '',
  8. token: getToken(),
  9. name: '',
  10. avatar: '',
  11. introduction: '',
  12. roles: [],
  13. perms: [],
  14. setting: {
  15. articlePlatform: []
  16. }
  17. },
  18. mutations: {
  19. SET_CODE: (state, code) => {
  20. state.code = code
  21. },
  22. SET_TOKEN: (state, token) => {
  23. state.token = token
  24. },
  25. SET_INTRODUCTION: (state, introduction) => {
  26. state.introduction = introduction
  27. },
  28. SET_SETTING: (state, setting) => {
  29. state.setting = setting
  30. },
  31. SET_STATUS: (state, status) => {
  32. state.status = status
  33. },
  34. SET_NAME: (state, name) => {
  35. state.name = name
  36. },
  37. SET_AVATAR: (state, avatar) => {
  38. state.avatar = avatar
  39. },
  40. SET_ROLES: (state, roles) => {
  41. state.roles = roles
  42. },
  43. SET_PERMS: (state, perms) => {
  44. state.perms = perms
  45. }
  46. },
  47. actions: {
  48. // 用户名登录
  49. LoginByUsername({ commit }, userInfo) {
  50. const username = userInfo.username.trim()
  51. return new Promise((resolve, reject) => {
  52. loginByUsername(username, userInfo.password, userInfo.verifyCode).then(response => {
  53. const token = response.data.data
  54. commit('SET_TOKEN', token)
  55. setToken(token)
  56. resolve()
  57. }).catch(error => {
  58. reject(error)
  59. })
  60. })
  61. },
  62. // 获取用户信息
  63. GetUserInfo({ commit, state }) {
  64. return new Promise((resolve, reject) => {
  65. getUserInfo(state.token).then(response => {
  66. debugger
  67. const data = response.data.data
  68. if (data.perms && data.perms.length > 0) { // 验证返回的perms是否是一个非空数组
  69. commit('SET_PERMS', data.perms)
  70. } else {
  71. reject('getInfo: perms must be a non-null array !')
  72. }
  73. localStorage.setItem('user', data.username)
  74. commit('SET_ROLES', data.roles)
  75. commit('SET_NAME', data.name)
  76. commit('SET_AVATAR', data.avatar)
  77. commit('SET_INTRODUCTION', data.introduction)
  78. resolve(response)
  79. }).catch(error => {
  80. reject(error)
  81. })
  82. })
  83. },
  84. // 第三方验证登录
  85. // LoginByThirdparty({ commit, state }, code) {
  86. // return new Promise((resolve, reject) => {
  87. // commit('SET_CODE', code)
  88. // loginByThirdparty(state.status, state.email, state.code).then(response => {
  89. // commit('SET_TOKEN', response.data.token)
  90. // setToken(response.data.token)
  91. // resolve()
  92. // }).catch(error => {
  93. // reject(error)
  94. // })
  95. // })
  96. // },
  97. // 登出
  98. LogOut({ commit, state }) {
  99. return new Promise((resolve, reject) => {
  100. logout(state.token).then(() => {
  101. commit('SET_TOKEN', '')
  102. commit('SET_ROLES', [])
  103. commit('SET_PERMS', [])
  104. removeToken()
  105. localStorage.clear()
  106. resolve()
  107. }).catch(error => {
  108. reject(error)
  109. })
  110. })
  111. },
  112. // 前端 登出
  113. FedLogOut({ commit }) {
  114. return new Promise(resolve => {
  115. commit('SET_TOKEN', '')
  116. removeToken()
  117. resolve()
  118. })
  119. },
  120. // 动态修改权限
  121. ChangeRoles({ commit, dispatch }, role) {
  122. return new Promise(resolve => {
  123. commit('SET_TOKEN', role)
  124. setToken(role)
  125. getUserInfo(role).then(response => {
  126. const data = response.data
  127. commit('SET_ROLES', data.roles)
  128. commit('SET_PERMS', data.perms)
  129. commit('SET_NAME', data.name)
  130. commit('SET_AVATAR', data.avatar)
  131. commit('SET_INTRODUCTION', data.introduction)
  132. dispatch('GenerateRoutes', data) // 动态修改权限后 重绘侧边菜单
  133. resolve()
  134. })
  135. })
  136. }
  137. }
  138. }
  139. export default user