2 changed files with 63 additions and 0 deletions
@ -0,0 +1,60 @@ |
|||||
|
import store from '@/store' |
||||
|
|
||||
|
function authPermission(permission) { |
||||
|
const all_permission = "*:*:*"; |
||||
|
const permissions = store.getters && store.getters.permissions |
||||
|
if (permission && permission.length > 0) { |
||||
|
return permissions.some(v => { |
||||
|
return all_permission === v || v === permission |
||||
|
}) |
||||
|
} else { |
||||
|
return false |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
function authRole(role) { |
||||
|
const super_admin = "admin"; |
||||
|
const roles = store.getters && store.getters.roles |
||||
|
if (role && role.length > 0) { |
||||
|
return roles.some(v => { |
||||
|
return super_admin === v || v === role |
||||
|
}) |
||||
|
} else { |
||||
|
return false |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
export default { |
||||
|
// 验证用户是否具备某权限
|
||||
|
hasPermi(permission) { |
||||
|
return authPermission(permission); |
||||
|
}, |
||||
|
// 验证用户是否含有指定权限,只需包含其中一个
|
||||
|
hasPermiOr(permissions) { |
||||
|
return permissions.some(item => { |
||||
|
return authPermission(item) |
||||
|
}) |
||||
|
}, |
||||
|
// 验证用户是否含有指定权限,必须全部拥有
|
||||
|
hasPermiAnd(permissions) { |
||||
|
return permissions.every(item => { |
||||
|
return authPermission(item) |
||||
|
}) |
||||
|
}, |
||||
|
// 验证用户是否具备某角色
|
||||
|
hasRole(role) { |
||||
|
return authRole(role); |
||||
|
}, |
||||
|
// 验证用户是否含有指定角色,只需包含其中一个
|
||||
|
hasRoleOr(roles) { |
||||
|
return roles.some(item => { |
||||
|
return authRole(item) |
||||
|
}) |
||||
|
}, |
||||
|
// 验证用户是否含有指定角色,必须全部拥有
|
||||
|
hasRoleAnd(roles) { |
||||
|
return roles.every(item => { |
||||
|
return authRole(item) |
||||
|
}) |
||||
|
} |
||||
|
} |
Loading…
Reference in new issue