1
0
mirror of https://github.com/zclzone/vue-naive-admin.git synced 2025-05-02 15:19:01 +08:00
vue-naive-admin/src/router/guards/permission-guard.js
2024-03-31 18:33:58 +08:00

53 lines
1.9 KiB
JavaScript

/**********************************
* @Author: Ronnie Zhang
* @LastEditor: Ronnie Zhang
* @LastEditTime: 2023/12/05 21:25:07
* @Email: zclzone@outlook.com
* Copyright © 2023 Ronnie Zhang(大脸怪) | https://isme.top
**********************************/
import { useAuthStore, usePermissionStore, useUserStore } from '@/store'
import api from '@/api'
import { getPermissions, getUserInfo } from '@/store/helper'
const WHITE_LIST = ['/login', '/404']
export function createPermissionGuard(router) {
router.beforeEach(async (to) => {
const authStore = useAuthStore()
const token = authStore.accessToken
/** 没有token */
if (!token) {
if (WHITE_LIST.includes(to.path)) return true
return { path: 'login', query: { ...to.query, redirect: to.path } }
}
// 有token的情况
if (to.path === '/login') return { path: '/' }
if (WHITE_LIST.includes(to.path)) return true
const userStore = useUserStore()
const permissionStore = usePermissionStore()
if (!userStore.userInfo) {
const [user, permissions] = await Promise.all([getUserInfo(), getPermissions()])
userStore.setUser(user)
permissionStore.setPermissions(permissions)
const routeComponents = import.meta.glob('@/views/**/*.vue')
permissionStore.accessRoutes.forEach((route) => {
route.component = routeComponents[route.component] || undefined
!router.hasRoute(route.name) && router.addRoute(route)
})
return { ...to, replace: true }
}
const routes = router.getRoutes()
if (routes.find((route) => route.name === to.name)) return true
// 判断是无权限还是404
const { data: hasMenu } = await api.validateMenuPath(to.path)
return hasMenu
? { name: '403', query: { path: to.fullPath }, state: { from: 'permission-guard' } }
: { name: '404', query: { path: to.fullPath } }
})
}