2022-08-24 16:52:01 +08:00
|
|
|
|
import { ref } from "vue"
|
2022-04-22 01:16:02 +08:00
|
|
|
|
import store from "@/store"
|
|
|
|
|
import { defineStore } from "pinia"
|
2022-10-18 15:07:42 +08:00
|
|
|
|
import { type RouteRecordRaw } from "vue-router"
|
2024-02-25 19:26:35 +08:00
|
|
|
|
import { constantRoutes, dynamicRoutes } from "@/router"
|
2023-08-07 15:14:15 +08:00
|
|
|
|
import { flatMultiLevelRoutes } from "@/router/helper"
|
|
|
|
|
import routeSettings from "@/config/route"
|
2022-04-21 18:20:39 +08:00
|
|
|
|
|
|
|
|
|
const hasPermission = (roles: string[], route: RouteRecordRaw) => {
|
2023-05-24 18:25:49 +08:00
|
|
|
|
const routeRoles = route.meta?.roles
|
|
|
|
|
return routeRoles ? roles.some((role) => routeRoles.includes(role)) : true
|
2022-04-21 18:20:39 +08:00
|
|
|
|
}
|
|
|
|
|
|
2024-02-25 19:26:35 +08:00
|
|
|
|
const filterDynamicRoutes = (routes: RouteRecordRaw[], roles: string[]) => {
|
2022-04-21 18:20:39 +08:00
|
|
|
|
const res: RouteRecordRaw[] = []
|
|
|
|
|
routes.forEach((route) => {
|
2023-05-24 18:25:49 +08:00
|
|
|
|
const tempRoute = { ...route }
|
|
|
|
|
if (hasPermission(roles, tempRoute)) {
|
|
|
|
|
if (tempRoute.children) {
|
2024-02-25 19:26:35 +08:00
|
|
|
|
tempRoute.children = filterDynamicRoutes(tempRoute.children, roles)
|
2022-04-21 18:20:39 +08:00
|
|
|
|
}
|
2023-05-24 18:25:49 +08:00
|
|
|
|
res.push(tempRoute)
|
2022-04-21 18:20:39 +08:00
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
return res
|
|
|
|
|
}
|
|
|
|
|
|
2022-08-24 16:52:01 +08:00
|
|
|
|
export const usePermissionStore = defineStore("permission", () => {
|
2024-02-25 19:26:35 +08:00
|
|
|
|
/** 可访问的路由 */
|
2022-08-24 16:52:01 +08:00
|
|
|
|
const routes = ref<RouteRecordRaw[]>([])
|
2024-02-25 19:26:35 +08:00
|
|
|
|
/** 有访问权限的动态路由 */
|
|
|
|
|
const addRoutes = ref<RouteRecordRaw[]>([])
|
2022-08-24 16:52:01 +08:00
|
|
|
|
|
2024-02-25 19:26:35 +08:00
|
|
|
|
/** 根据角色生成可访问的 Routes(可访问的路由 = 常驻路由 + 有访问权限的动态路由) */
|
2022-08-24 16:52:01 +08:00
|
|
|
|
const setRoutes = (roles: string[]) => {
|
2024-02-25 19:26:35 +08:00
|
|
|
|
const accessedRoutes = filterDynamicRoutes(dynamicRoutes, roles)
|
2024-02-06 20:22:07 +08:00
|
|
|
|
_set(accessedRoutes)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/** 所有路由 = 所有常驻路由 + 所有动态路由 */
|
|
|
|
|
const setAllRoutes = () => {
|
2024-02-25 19:26:35 +08:00
|
|
|
|
_set(dynamicRoutes)
|
2024-02-06 20:22:07 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const _set = (accessedRoutes: RouteRecordRaw[]) => {
|
2022-08-24 16:52:01 +08:00
|
|
|
|
routes.value = constantRoutes.concat(accessedRoutes)
|
2024-02-25 19:26:35 +08:00
|
|
|
|
addRoutes.value = routeSettings.thirdLevelRouteCache ? flatMultiLevelRoutes(accessedRoutes) : accessedRoutes
|
2022-04-21 18:20:39 +08:00
|
|
|
|
}
|
2022-08-24 16:52:01 +08:00
|
|
|
|
|
2024-02-25 19:26:35 +08:00
|
|
|
|
return { routes, addRoutes, setRoutes, setAllRoutes }
|
2022-04-21 18:20:39 +08:00
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
/** 在 setup 外使用 */
|
|
|
|
|
export function usePermissionStoreHook() {
|
|
|
|
|
return usePermissionStore(store)
|
|
|
|
|
}
|