2017-08-23 15 views
0

特定の権限を持つすべてのユーザーを取得するにはどうすればよいですか? たとえば、特定のアクセス許可を持つすべてのユーザーを列挙する必要があります。このようなコード特定の権限を持つすべてのユーザーを取得しますか?

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

このような方法はありません。あなたはAbpPermissionsテーブルから自分自身を照会するためにリポジトリを使うべきです(それを理解するためのテーブルの列を参照してください) – hikalkan

+0

@hikalkan userManagerやpermissionManagerにこのようなメソッドを置くと便利です。この素晴らしいフレームワークをありがとう –

答えて

1

権限でユーザをフィルタするためのクエリを書く必要があります。これはあなたを導くかもしれません:

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(); 
関連する問題