namespace Brizco.Repository.Handlers.Complexes; public class CreateComplexUserCommandHandler : IRequestHandler { private readonly IRepositoryWrapper _repositoryWrapper; private readonly UserManager _userManager; private readonly RoleManager _roleManager; private readonly ILogger _logger; public CreateComplexUserCommandHandler(IRepositoryWrapper repositoryWrapper, UserManager userManager, RoleManager roleManager, ILogger logger) { _repositoryWrapper = repositoryWrapper; _userManager = userManager; _roleManager = roleManager; _logger = logger; } public async Task Handle(CreateComplexUserCommand request, CancellationToken cancellationToken) { try { //await _repositoryWrapper.BeginTransaction(cancellationToken); var complex = await _repositoryWrapper.SetRepository().TableNoTracking .FirstOrDefaultAsync(c => c.Id == request.ComplexId, cancellationToken); if (complex == null) throw new AppException("Complex not found", ApiResultStatusCode.NotFound); var user = await _userManager.FindByIdAsync(request.UserId.ToString()); if (user == null) throw new AppException("User not found", ApiResultStatusCode.NotFound); var complexUser = await _repositoryWrapper.SetRepository() .TableNoTracking .FirstOrDefaultAsync(f => f.ComplexId == request.ComplexId && f.UserId == request.UserId, cancellationToken); if (complexUser != null) throw new AppException("این کاربر در این رستوران وجود دارد"); complexUser = complex.AddComplexUser(request.UserId); foreach (var roleId in request.RoleIds) { var role = await _roleManager.FindByIdAsync(roleId.ToString()); var result = await _userManager.AddToRoleAsync(user, role.Name); if (!result.Succeeded) throw new AppException(string.Join('|', result.Errors)); complexUser.AddRole(role.Id); } _repositoryWrapper.SetRepository().Add(complexUser); await _repositoryWrapper.SaveChangesAsync(cancellationToken); //await _repositoryWrapper.CommitAsync(cancellationToken); return complexUser.AdaptToSDto(); } catch (Exception) { await _repositoryWrapper.RollBackAsync(cancellationToken); throw; } } }