mirror of
https://github.com/bitwarden/server.git
synced 2024-11-25 12:45:18 +01:00
Refactor RemoveOrganizationUserCommand to improve variable naming and remove unused logging method
This commit is contained in:
parent
5a493c43eb
commit
b711506fde
@ -95,11 +95,11 @@ public class RemoveOrganizationUserCommand : IRemoveOrganizationUserCommand
|
|||||||
deletingUserIsOwner = await _currentContext.OrganizationOwner(organizationId);
|
deletingUserIsOwner = await _currentContext.OrganizationOwner(organizationId);
|
||||||
}
|
}
|
||||||
|
|
||||||
var managementStatus = _featureService.IsEnabled(FeatureFlagKeys.AccountDeprovisioning) ?
|
var managementStatus = _featureService.IsEnabled(FeatureFlagKeys.AccountDeprovisioning)
|
||||||
await _getOrganizationUsersManagementStatusQuery.GetUsersOrganizationManagementStatusAsync(organizationId, filteredUsers.Select(u => u.Id)) :
|
? await _getOrganizationUsersManagementStatusQuery.GetUsersOrganizationManagementStatusAsync(organizationId, filteredUsers.Select(u => u.Id))
|
||||||
filteredUsers.ToDictionary(u => u.Id, u => false);
|
: filteredUsers.ToDictionary(u => u.Id, u => false);
|
||||||
var result = new List<(Guid OrganizationUserId, string ErrorMessage)>();
|
var result = new List<(Guid OrganizationUserId, string ErrorMessage)>();
|
||||||
var deletedUserIds = new List<Guid>();
|
var userIdsToDelete = new List<Guid>();
|
||||||
foreach (var orgUser in filteredUsers)
|
foreach (var orgUser in filteredUsers)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
@ -126,7 +126,7 @@ public class RemoveOrganizationUserCommand : IRemoveOrganizationUserCommand
|
|||||||
await DeleteAndPushUserRegistrationAsync(organizationId, orgUser.UserId.Value);
|
await DeleteAndPushUserRegistrationAsync(organizationId, orgUser.UserId.Value);
|
||||||
}
|
}
|
||||||
result.Add((orgUser.Id, string.Empty));
|
result.Add((orgUser.Id, string.Empty));
|
||||||
deletedUserIds.Add(orgUser.Id);
|
userIdsToDelete.Add(orgUser.Id);
|
||||||
}
|
}
|
||||||
catch (BadRequestException e)
|
catch (BadRequestException e)
|
||||||
{
|
{
|
||||||
@ -134,12 +134,12 @@ public class RemoveOrganizationUserCommand : IRemoveOrganizationUserCommand
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (deletedUserIds.Any())
|
if (userIdsToDelete.Any())
|
||||||
{
|
{
|
||||||
DateTime? eventDate = DateTime.UtcNow;
|
DateTime? eventDate = DateTime.UtcNow;
|
||||||
await _organizationUserRepository.DeleteManyAsync(deletedUserIds);
|
await _organizationUserRepository.DeleteManyAsync(userIdsToDelete);
|
||||||
await _eventService.LogOrganizationUserEventsAsync(
|
await _eventService.LogOrganizationUserEventsAsync(
|
||||||
orgUsers.Where(u => deletedUserIds.Contains(u.Id))
|
filteredUsers.Where(u => userIdsToDelete.Contains(u.Id))
|
||||||
.Select(u => (u, EventType.OrganizationUser_Removed, eventDate)));
|
.Select(u => (u, EventType.OrganizationUser_Removed, eventDate)));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -206,29 +206,4 @@ public class RemoveOrganizationUserCommand : IRemoveOrganizationUserCommand
|
|||||||
organizationId.ToString());
|
organizationId.ToString());
|
||||||
await _pushNotificationService.PushSyncOrgKeysAsync(userId);
|
await _pushNotificationService.PushSyncOrgKeysAsync(userId);
|
||||||
}
|
}
|
||||||
|
|
||||||
private async Task LogDeletedOrganizationUsersAsync(
|
|
||||||
IEnumerable<OrganizationUser> orgUsers,
|
|
||||||
IEnumerable<(Guid OrgUserId, string ErrorMessage)> results)
|
|
||||||
{
|
|
||||||
var eventDate = DateTime.UtcNow;
|
|
||||||
var events = new List<(OrganizationUser OrgUser, EventType Event, DateTime? EventDate)>();
|
|
||||||
|
|
||||||
foreach (var (orgUserId, errorMessage) in results)
|
|
||||||
{
|
|
||||||
var orgUser = orgUsers.FirstOrDefault(ou => ou.Id == orgUserId);
|
|
||||||
// If the user was not found or there was an error, we skip logging the event
|
|
||||||
if (orgUser == null || !string.IsNullOrEmpty(errorMessage))
|
|
||||||
{
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
events.Add((orgUser, EventType.OrganizationUser_Deleted, eventDate));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (events.Any())
|
|
||||||
{
|
|
||||||
await _eventService.LogOrganizationUserEventsAsync(events);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user