public virtual async Task <GetPermissionListResultDto> GetAsync(string providerName, string providerKey) { await CheckProviderPolicy(providerName); var result = new GetPermissionListResultDto { EntityDisplayName = providerKey, Groups = new List <PermissionGroupDto>() }; var multiTenancySide = CurrentTenant.GetMultiTenancySide(); foreach (var group in PermissionDefinitionManager.GetGroups()) { var groupDto = new PermissionGroupDto { Name = group.Name, DisplayName = group.DisplayName.Localize(StringLocalizerFactory), Permissions = new List <PermissionGrantInfoDto>() }; var neededCheckPermissions = new List <PermissionDefinition>(); foreach (var permission in group.GetPermissionsWithChildren() .Where(x => x.IsEnabled) .Where(x => !x.Providers.Any() || x.Providers.Contains(providerName)) .Where(x => x.MultiTenancySide.HasFlag(multiTenancySide))) { if (await SimpleStateCheckerManager.IsEnabledAsync(permission)) { neededCheckPermissions.Add(permission); } } if (!neededCheckPermissions.Any()) { continue; } var grantInfoDtos = neededCheckPermissions.Select(x => new PermissionGrantInfoDto { Name = x.Name, DisplayName = x.DisplayName.Localize(StringLocalizerFactory), ParentName = x.Parent?.Name, AllowedProviders = x.Providers, GrantedProviders = new List <ProviderInfoDto>() }).ToList(); var multipleGrantInfo = await PermissionManager.GetAsync(neededCheckPermissions.Select(x => x.Name).ToArray(), providerName, providerKey); foreach (var grantInfo in multipleGrantInfo.Result) { var grantInfoDto = grantInfoDtos.First(x => x.Name == grantInfo.Name); grantInfoDto.IsGranted = grantInfo.IsGranted; foreach (var provider in grantInfo.Providers) { grantInfoDto.GrantedProviders.Add(new ProviderInfoDto { ProviderName = provider.Name, ProviderKey = provider.Key, }); } groupDto.Permissions.Add(grantInfoDto); } if (groupDto.Permissions.Any()) { result.Groups.Add(groupDto); } } return(result); }
public virtual async Task <GetPermissionListResultDto> GetAsync(string providerName, string providerKey) { await CheckProviderPolicy(providerName); var result = new GetPermissionListResultDto { EntityDisplayName = providerKey, Groups = new List <PermissionGroupDto>() }; var multiTenancySide = CurrentTenant.GetMultiTenancySide(); foreach (var group in PermissionDefinitionManager.GetGroups()) { var groupDto = new PermissionGroupDto { Name = group.Name, DisplayName = group.DisplayName.Localize(StringLocalizerFactory), Permissions = new List <PermissionGrantInfoDto>() }; foreach (var permission in group.GetPermissionsWithChildren()) { if (!permission.IsEnabled) { continue; } if (permission.Providers.Any() && !permission.Providers.Contains(providerName)) { continue; } if (!permission.MultiTenancySide.HasFlag(multiTenancySide)) { continue; } var grantInfoDto = new PermissionGrantInfoDto { Name = permission.Name, DisplayName = permission.DisplayName.Localize(StringLocalizerFactory), ParentName = permission.Parent?.Name, AllowedProviders = permission.Providers, GrantedProviders = new List <ProviderInfoDto>() }; var grantInfo = await PermissionManager.GetAsync(permission.Name, providerName, providerKey); grantInfoDto.IsGranted = grantInfo.IsGranted; foreach (var provider in grantInfo.Providers) { grantInfoDto.GrantedProviders.Add(new ProviderInfoDto { ProviderName = provider.Name, ProviderKey = provider.Key, }); } groupDto.Permissions.Add(grantInfoDto); } if (groupDto.Permissions.Any()) { result.Groups.Add(groupDto); } } return(result); }
public virtual async Task <GetPermissionListResultDto> GetAsync(string providerName, string providerKey) { var permissionListResult = new GetPermissionListResultDto { EntityDisplayName = providerKey, Groups = new List <PermissionGroupDto>() }; var multiTenancySide = CurrentTenant.GetMultiTenancySide(); var permissionGroups = PermissionDefinitionManager.GetGroups(); IEnumerable <PermissionGrant> permissions = await PermissionGrantRepository.GetListAsync(providerName, providerKey); // 如果是当前用户权限,还需要查询角色权限 if (providerName.Equals("U")) { var userId = CurrentUser.GetId().ToString(); if (providerKey.Equals(userId)) { foreach (var role in CurrentUser.Roles) { var rolePermissions = await PermissionGrantRepository .GetListAsync(RolePermissionValueProvider.ProviderName, role); permissions = permissions.Union(rolePermissions); } } } foreach (var permissionGroup in permissionGroups) { var groupDto = new PermissionGroupDto { Name = permissionGroup.Name, DisplayName = permissionGroup.DisplayName.Localize(StringLocalizerFactory), Permissions = new List <PermissionGrantInfoDto>() }; foreach (var permission in permissionGroup.GetPermissionsWithChildren()) { if (!permission.IsEnabled) { continue; } if (permission.Providers.Any() && !permission.Providers.Contains(providerName)) { continue; } if (!permission.MultiTenancySide.HasFlag(multiTenancySide)) { continue; } var grantInfoDto = new PermissionGrantInfoDto { Name = permission.Name, DisplayName = permission.DisplayName.Localize(StringLocalizerFactory), ParentName = permission.Parent?.Name, AllowedProviders = permission.Providers, GrantedProviders = new List <ProviderInfoDto>() }; var grantedPermissions = permissions.Where(p => p.Name.Equals(permission.Name)); foreach (var grantedPermission in grantedPermissions) { grantInfoDto.IsGranted = true; grantInfoDto.GrantedProviders.Add(new ProviderInfoDto { ProviderKey = grantedPermission.ProviderKey, ProviderName = grantedPermission.ProviderName }); } groupDto.Permissions.Add(grantInfoDto); } if (groupDto.Permissions.Any()) { permissionListResult.Groups.Add(groupDto); } } return(permissionListResult); }