permission.js 3.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. import router from './router'
  2. import store from './store'
  3. import NProgress from 'nprogress' // progress bar
  4. import 'nprogress/nprogress.css' // progress bar style
  5. // import { getToken } from '@/utils/auth' // get token from cookie
  6. NProgress.configure({ showSpinner: false }) // NProgress Configuration
  7. const whiteList = ['/login', '/resetpassword', '/help', '/echarts'] // no redirect whitelist
  8. // eslint-disable-next-line prettier/prettier
  9. router.beforeEach(async(to, from, next) => {
  10. // start progress bar
  11. NProgress.start()
  12. // set page title
  13. // determine whether the user has logged in
  14. // const hasToken = getToken()
  15. const hasToken = store.getters.id
  16. if (to.query.courseid !== '' && to.query.courseid !== undefined) {
  17. console.log(to.query.courseid)
  18. await store.commit('SET_COURSEID', to.query.courseid)
  19. }
  20. if (to.query.testid !== '' && to.query.testid !== undefined) {
  21. await store.commit('SET_TESTID', to.query.testid)
  22. }
  23. const shareCourseId =
  24. window.location.href.indexOf('?shareCourseId=') != -1
  25. ? window.location.href.split('?shareCourseId=')[1].toString()
  26. : ''
  27. if (shareCourseId) {
  28. await store.commit('SET_SHARECOURSEID', shareCourseId)
  29. }
  30. if (hasToken) {
  31. if (to.path === '/login') {
  32. // if is logged in, redirect to the home page
  33. next({ path: '/' })
  34. NProgress.done()
  35. } else {
  36. const userinfo = store.getters.userinfo && Object.keys(store.getters.userinfo).length > 0
  37. console.log('store.getters', store.getters)
  38. console.log('userinfo', userinfo)
  39. // console.log('to', {...to} )
  40. if (userinfo) {
  41. next()
  42. } else {
  43. try {
  44. // 获取用户信息
  45. const data = await store.dispatch('user/getInfo')
  46. await store.commit('user/SET_USERINFO', data)
  47. const courseId = store.getters.courseId
  48. const testId = store.getters.testId
  49. const shareCourseId = store.getters.shareCourseId
  50. await store.commit('SET_TESTID', '')
  51. await store.commit('SET_COURSEID', '')
  52. await store.commit('SET_SHARECOURSEID', '')
  53. // // 根据角色生成可访问的路线图
  54. if (courseId) {
  55. next({ ...to, query: { courseid: courseId }, replace: true })
  56. } else if (testId) {
  57. next({ ...to, query: { courseid: testId }, replace: true })
  58. } else if (shareCourseId) {
  59. next({ path: '/courseDetail', query: { courseid: shareCourseId, urlType: 1 }, replace: true })
  60. } else {
  61. next({ ...to, replace: true })
  62. }
  63. } catch (error) {
  64. // remove token and go to login page to re-login
  65. // await store.dispatch('user/resetToken')
  66. // Notify({ type: 'danger', message: error || '发生异常' })
  67. next(`/login?redirect=${to.path}`)
  68. NProgress.done()
  69. }
  70. }
  71. }
  72. } else {
  73. // next()
  74. /* has no token*/
  75. if (whiteList.indexOf(to.path) !== -1) {
  76. // in the free login whitelist, go directly
  77. next()
  78. } else {
  79. // // other pages that do not have permission to access are redirected to the login page.
  80. next(`/login?redirect=${to.path}`)
  81. NProgress.done()
  82. }
  83. }
  84. })
  85. router.afterEach(() => {
  86. // finish progress bar
  87. NProgress.done()
  88. })