2024-06-02 20:47:50 +08:00
|
|
|
import type { MenuRecordRaw } from '@vben-core/typings';
|
2024-05-19 21:20:42 +08:00
|
|
|
import type { RouteRecordRaw } from 'vue-router';
|
|
|
|
|
|
|
|
import { acceptHMRUpdate, defineStore } from 'pinia';
|
|
|
|
|
|
|
|
type AccessToken = null | string;
|
|
|
|
|
2024-06-02 20:47:50 +08:00
|
|
|
interface BasicUserInfo {
|
|
|
|
/**
|
|
|
|
* 头像
|
|
|
|
*/
|
|
|
|
avatar: string;
|
|
|
|
/**
|
|
|
|
* 用户昵称
|
|
|
|
*/
|
|
|
|
realName: string;
|
2024-06-30 14:09:44 +08:00
|
|
|
/**
|
|
|
|
* 用户角色
|
|
|
|
*/
|
|
|
|
roles?: string[];
|
2024-06-02 20:47:50 +08:00
|
|
|
/**
|
|
|
|
* 用户id
|
|
|
|
*/
|
|
|
|
userId: string;
|
|
|
|
/**
|
|
|
|
* 用户名
|
|
|
|
*/
|
|
|
|
username: string;
|
|
|
|
}
|
|
|
|
|
2024-05-19 21:20:42 +08:00
|
|
|
interface AccessState {
|
2024-07-06 13:28:08 +08:00
|
|
|
/**
|
|
|
|
* 权限码
|
|
|
|
*/
|
|
|
|
accessCodes: string[];
|
2024-05-19 21:20:42 +08:00
|
|
|
/**
|
|
|
|
* 可访问的菜单列表
|
|
|
|
*/
|
|
|
|
accessMenus: MenuRecordRaw[];
|
|
|
|
/**
|
|
|
|
* 可访问的路由列表
|
|
|
|
*/
|
|
|
|
accessRoutes: RouteRecordRaw[];
|
|
|
|
/**
|
|
|
|
* 登录 accessToken
|
|
|
|
*/
|
|
|
|
accessToken: AccessToken;
|
2024-06-30 14:09:44 +08:00
|
|
|
/**
|
|
|
|
* 登录 accessToken
|
|
|
|
*/
|
|
|
|
refreshToken: AccessToken;
|
2024-05-19 21:20:42 +08:00
|
|
|
/**
|
|
|
|
* 用户信息
|
|
|
|
*/
|
2024-06-02 20:47:50 +08:00
|
|
|
userInfo: BasicUserInfo | null;
|
2024-05-19 21:20:42 +08:00
|
|
|
/**
|
|
|
|
* 用户角色
|
|
|
|
*/
|
|
|
|
userRoles: string[];
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @zh_CN 访问权限相关
|
|
|
|
*/
|
2024-07-23 00:03:59 +08:00
|
|
|
export const useCoreAccessStore = defineStore('core-access', {
|
2024-05-19 21:20:42 +08:00
|
|
|
actions: {
|
2024-07-06 13:28:08 +08:00
|
|
|
setAccessCodes(codes: string[]) {
|
|
|
|
this.accessCodes = codes;
|
|
|
|
},
|
2024-05-19 21:20:42 +08:00
|
|
|
setAccessMenus(menus: MenuRecordRaw[]) {
|
|
|
|
this.accessMenus = menus;
|
|
|
|
},
|
|
|
|
setAccessRoutes(routes: RouteRecordRaw[]) {
|
|
|
|
this.accessRoutes = routes;
|
|
|
|
},
|
|
|
|
setAccessToken(token: AccessToken) {
|
|
|
|
this.accessToken = token;
|
|
|
|
},
|
2024-06-30 14:09:44 +08:00
|
|
|
setRefreshToken(token: AccessToken) {
|
|
|
|
this.refreshToken = token;
|
|
|
|
},
|
2024-07-05 23:15:46 +08:00
|
|
|
setUserInfo(userInfo: BasicUserInfo | null) {
|
2024-05-19 21:20:42 +08:00
|
|
|
// 设置用户信息
|
|
|
|
this.userInfo = userInfo;
|
|
|
|
// 设置角色信息
|
|
|
|
const roles = userInfo?.roles ?? [];
|
2024-06-30 14:09:44 +08:00
|
|
|
this.setUserRoles(roles);
|
2024-05-19 21:20:42 +08:00
|
|
|
},
|
|
|
|
setUserRoles(roles: string[]) {
|
|
|
|
this.userRoles = roles;
|
|
|
|
},
|
|
|
|
},
|
|
|
|
persist: {
|
|
|
|
// 持久化
|
2024-07-06 13:28:08 +08:00
|
|
|
paths: ['accessToken', 'refreshToken', 'accessCodes'],
|
2024-05-19 21:20:42 +08:00
|
|
|
},
|
|
|
|
state: (): AccessState => ({
|
2024-07-06 13:28:08 +08:00
|
|
|
accessCodes: [],
|
2024-05-19 21:20:42 +08:00
|
|
|
accessMenus: [],
|
|
|
|
accessRoutes: [],
|
|
|
|
accessToken: null,
|
2024-06-30 14:09:44 +08:00
|
|
|
refreshToken: null,
|
2024-05-19 21:20:42 +08:00
|
|
|
userInfo: null,
|
|
|
|
userRoles: [],
|
|
|
|
}),
|
|
|
|
});
|
|
|
|
|
|
|
|
// 解决热更新问题
|
|
|
|
const hot = import.meta.hot;
|
|
|
|
if (hot) {
|
2024-07-05 23:15:46 +08:00
|
|
|
hot.accept(acceptHMRUpdate(useCoreAccessStore, hot));
|
2024-05-19 21:20:42 +08:00
|
|
|
}
|