namespace Brizco.Repository.Handlers.Position; public class UpdatePositionCommandHandler : IRequestHandler { private readonly IRepositoryWrapper _repositoryWrapper; private readonly ICurrentUserService _currentUserService; public UpdatePositionCommandHandler(IRepositoryWrapper repositoryWrapper, ICurrentUserService currentUserService) { _repositoryWrapper = repositoryWrapper; _currentUserService = currentUserService; } public async Task Handle(UpdatePositionCommand request, CancellationToken cancellationToken) { var ent = await _repositoryWrapper.SetRepository() .TableNoTracking.FirstOrDefaultAsync(s => s.Id == request.Id, cancellationToken); if (ent == null) throw new AppException("Postion not found", ApiResultStatusCode.NotFound); if (_currentUserService.ComplexId == null) throw new AppException("ComplexId is null", ApiResultStatusCode.NotFound); if (!Guid.TryParse(_currentUserService.ComplexId, out Guid complexId)) throw new AppException("ComplexId is wrong", ApiResultStatusCode.NotFound); var newPosition = Domain.Entities.Complex.Position.Create(request.Title, request.Description, complexId, request.SectionId); newPosition.Id = request.Id; newPosition.CreatedAt = ent.CreatedAt; newPosition.CreatedBy = ent.CreatedBy; var permissionsDb = await _repositoryWrapper.SetRepository() .TableNoTracking .Where(f => f.PositionId == ent.Id) .ToListAsync(cancellationToken); foreach (var permissionDb in permissionsDb.Where(p=>!request.Permissions.Contains(p.Permission))) { _repositoryWrapper.SetRepository() .Delete(permissionDb); await _repositoryWrapper.SaveChangesAsync(cancellationToken); } foreach (var permission in request.Permissions.Where(p => !permissionsDb.Select(d => d.Permission).Contains(p))) newPosition.AddPermission(permission); _repositoryWrapper.SetRepository() .Update(newPosition); await _repositoryWrapper.SaveChangesAsync(cancellationToken); return true; } }