daoyou_manage_web/src/plugins/auth.ts

61 lines
1.6 KiB
TypeScript
Raw Normal View History

2024-12-02 16:59:30 +08:00
import useUserStore from '@/store/modules/user';
const authPermission = (permission: string): boolean => {
const all_permission = '*:*:*';
const permissions: string[] = useUserStore().permissions;
if (permission && permission.length > 0) {
return permissions.some((v) => {
return all_permission === v || v === permission;
});
} else {
return false;
}
};
const authRole = (role: string): boolean => {
const super_admin = 'admin';
const roles = useUserStore().roles;
if (role && role.length > 0) {
return roles.some((v) => {
return super_admin === v || v === role;
});
} else {
return false;
}
};
export default {
// 验证用户是否具备某权限
hasPermi(permission: string): boolean {
return authPermission(permission);
},
// 验证用户是否含有指定权限,只需包含其中一个
hasPermiOr(permissions: string[]): boolean {
return permissions.some((item) => {
return authPermission(item);
});
},
// 验证用户是否含有指定权限,必须全部拥有
hasPermiAnd(permissions: string[]): boolean {
return permissions.every((item) => {
return authPermission(item);
});
},
// 验证用户是否具备某角色
hasRole(role: string): boolean {
return authRole(role);
},
// 验证用户是否含有指定角色,只需包含其中一个
hasRoleOr(roles: string[]): boolean {
return roles.some((item) => {
return authRole(item);
});
},
// 验证用户是否含有指定角色,必须全部拥有
hasRoleAnd(roles: string[]): boolean {
return roles.every((item) => {
return authRole(item);
});
}
};