zhangwei
2025-08-19 78921416615f450f4cc29ec4f740fbf1b47d8b00
src/utils/auth.ts
@@ -2,6 +2,7 @@
import { useUserStoreHook } from "@/store/modules/user";
import { storageLocal, isString, isIncludeAllChildren } from "@pureadmin/utils";
import type { nowRoleType } from "@/store/types";
import type { LoginResult, RoleItem } from "@/api/types";
export interface DataInfo<T> {
  /** token */
@@ -16,8 +17,10 @@
  username?: string;
  /** 昵称 */
  nickname?: string;
  /** 当前登录用户的角色 */
  /** 当前登录用户的角色列表 */
  exRoles?: Array<string>;
  /** 当前登录用户的角色 */
  roles?: Array<string>;
  /** 当前登录用户的按钮级别权限 */
  permissions?: Array<string>;
}
@@ -170,7 +173,7 @@
 * 将`accessToken`、`expires`、`refreshToken`这三条信息放在key值为authorized-token的cookie里(过期自动销毁)
 * 将`avatar`、`username`、`nickname`、`exRoles`、`permissions`、`refreshToken`、`expires`这七条信息放在key值为`user-info`的localStorage里(利用`multipleTabsKey`当浏览器完全关闭后自动销毁)
 */
export function setToken(data: DataInfo<Date>) {
export function setToken(data: LoginResult) {
  let expires = 0;
  const { accessToken, refreshToken } = data;
  const { isRemembered, loginDay } = useUserStoreHook();
@@ -193,11 +196,19 @@
      : {}
  );
  function setUserKey({ avatar, username, nickname, exRoles, permissions }) {
  function setUserKey({
    avatar,
    username,
    nickname,
    exRoles,
    permissions,
    roles
  }) {
    useUserStoreHook().SET_AVATAR(avatar);
    useUserStoreHook().SET_USERNAME(username);
    useUserStoreHook().SET_NICKNAME(nickname);
    useUserStoreHook().SET_ROLES(exRoles);
    useUserStoreHook().SET_EXROLES(exRoles);
    useUserStoreHook().SET_ROLES(roles);
    useUserStoreHook().SET_PERMS(permissions);
    storageLocal().setItem(userKey, {
      refreshToken,
@@ -206,17 +217,19 @@
      username,
      nickname,
      exRoles,
      roles,
      permissions
    });
  }
  if (data.exRoles) {
    const { username, exRoles } = data;
  if (data.exRoles && data.roles) {
    const { username, exRoles, roles } = data;
    setUserKey({
      avatar: data?.avatar ?? "",
      username,
      nickname: data?.nickname ?? "",
      exRoles,
      roles,
      permissions: data?.permissions ?? []
    });
  } else {
@@ -228,6 +241,8 @@
      storageLocal().getItem<DataInfo<number>>(userKey)?.nickname ?? "";
    const exRoles =
      storageLocal().getItem<DataInfo<number>>(userKey)?.exRoles ?? [];
    const roles =
      storageLocal().getItem<DataInfo<number>>(userKey)?.roles ?? [];
    const permissions =
      storageLocal().getItem<DataInfo<number>>(userKey)?.permissions ?? [];
    setUserKey({
@@ -235,6 +250,7 @@
      username,
      nickname,
      exRoles,
      roles,
      permissions
    });
  }
@@ -249,8 +265,8 @@
  storageLocal().setItem(userKey, obj);
}
export function setRoleListInfo(data: DataInfo<string>) {
  useUserStoreHook().SET_ROLES_LIST(data);
export function setRoleListInfo(data: RoleItem[]) {
  useUserStoreHook().SET_EXROLES_LIST(data);
  storageLocal().setItem("rolesList", data);
}
@@ -260,8 +276,9 @@
    const obj = list.find(item => {
      return item.code == data.code;
    });
    data = { ...obj, ...data };
    data = Object.assign(obj, data);
  }
  useUserStoreHook().SET_ROLES([data.name]);
  useUserStoreHook().SET_NOW_ROLE(data);
  storageLocal().setItem("nowRole", data);
}