获取所有具有特定权限的用户? [英] Get all users with specific permission?

查看:90
本文介绍了获取所有具有特定权限的用户?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

如何获得所有具有特定权限的用户?例如,我们需要枚举允许特定权限的所有用户.这样的代码

How can I get all users that have specific permission? for example we need to enumerate to all users that permitted to specific permission. code like this

var v=_userManager.GetAllUserWithSpecificPermission("ISO.Report.ReportV1");
foreach(var t in v)
{
   Logger.Info(t.UserName);
}

推荐答案

您需要编写查询以按权限过滤用户.这可能会指导您:

You need to write a query to filter users by a permission. This may guide you:

var query =     from user in UserManager.Users
                join ur in _userRoleRepository.GetAll() on user.Id equals ur.UserId into urJoined
                from ur in urJoined.DefaultIfEmpty()
                join up in _userPermissionRepository.GetAll() on new {UserId = user.Id, Name = input.Permission} equals
                new {up.UserId, up.Name} into upJoined
                from up in upJoined.DefaultIfEmpty()
                join rp in _rolePermissionRepository.GetAll() on new {RoleId = ur.RoleId, Name = input.Permission}
                equals new {rp.RoleId, rp.Name} into rpJoined
                from rp in rpJoined.DefaultIfEmpty()
                where (up != null && up.IsGranted) || (up == null && rp != null)
                group user by user
                into userGrouped
                select userGrouped.Key;

var users = await query.ToListAsync();

这篇关于获取所有具有特定权限的用户?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆