gaoluyang
3 天以前 5f5486731922637d9522b41dc54d932fdd29ebc4
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
import useUserStore from "@/store/modules/user";
function authPermission(permission: string): boolean {
  const all_permission = "*:*:*";
  const permissions: Array<string> = useUserStore().permissions;
  if (permission && permission.length > 0) {
    return permissions.some((v) => {
      return all_permission === v || v === permission;
    });
  } else {
    return false;
  }
}
 
function authRole(role: string): boolean {
  const super_admin = "admin";
  const roles: Array<string> = useUserStore().roles;
  if (role && role.length > 0) {
    return roles.some((v) => {
      return super_admin === v || v === role;
    });
  } else {
    return false;
  }
}
 
export default {
  /**
   * 验证用户是否具备某权限
   * @param permission 权限符
   * @returns
   */
  hasPermi(permission: string): boolean {
    return authPermission(permission);
  },
  /**
   * 验证用户是否含有指定权限,只需包含其中一个
   * @param permissions 权限符数组
   * @returns
   */
  hasPermiOr(permissions: Array<string>): boolean {
    return permissions.some((item) => {
      return authPermission(item);
    });
  },
  /**
   * 验证用户是否含有指定权限,必须全部拥有
   * @param permissions 权限符数组
   * @returns
   */
  hasPermiAnd(permissions: Array<string>): boolean {
    return permissions.every((item) => {
      return authPermission(item);
    });
  },
  /**
   * 验证用户是否具备某角色
   * @param role 角色
   * @returns
   */
  hasRole(role: string): boolean {
    return authRole(role);
  },
  /**
   * 验证用户是否含有指定角色,只需包含其中一个
   * @param roles 角色数组
   * @returns
   */
  hasRoleOr(roles: Array<string>): boolean {
    return roles.some((item) => {
      return authRole(item);
    });
  },
  /**
   * 验证用户是否含有指定角色,必须全部拥有
   * @param roles 角色数组
   * @returns
   */
  hasRoleAnd(roles: Array<string>): boolean {
    return roles.every((item) => {
      return authRole(item);
    });
  },
};