| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124 |
- namespace Diligent.WebAPI.Business.Services
- {
-
- public class UserService : IUserService
- {
- private readonly FrontEndSettings _frontEndSettings;
- private readonly UserManager<User> _userManager;
- private readonly IMapper _mapper;
- private readonly DatabaseContext _databaseContext;
- private readonly IEmailer _emailer;
- private readonly ILogger<UserService> _logger;
-
- public UserService(IOptions<FrontEndSettings> frontEndSettings, UserManager<User> userManager, IMapper mapper, DatabaseContext databaseContext, IEmailer emailer, ILogger<UserService> logger)
- {
- _frontEndSettings = frontEndSettings.Value;
- _userManager = userManager;
- _mapper = mapper;
- _databaseContext = databaseContext;
- _emailer = emailer;
- _logger = logger;
- }
-
- public async Task<IEnumerable<User?>> GetAll()
- {
- _logger.LogInformation("Start getting all users");
- _logger.LogInformation("Getting data from DB");
- var fromDb = await _userManager.Users.ToListAsync();
- _logger.LogInformation($"Received {fromDb.Count} ads from db.");
- return fromDb;
- }
- public async Task<User> GetFirst()
- {
- var result = await _userManager.Users.FirstOrDefaultAsync();
- if (result == null)
- throw new EntityNotFoundException("No users in database");
- return result;
- }
- #region REFACTORING CODE HERE TO CHECK IF USER IS NULL
- public async Task<User?> GetById(int id)
- {
- _logger.LogInformation($"Start searching user with id = {id}");
- var result = await _userManager.FindByIdAsync(id.ToString());
- return result;
- }
- public async Task<User?> GetByEmail(string email) =>
- await _userManager.FindByEmailAsync(email);
- #endregion
- public async Task CreateUser(CreateUserRequestDto model)
- {
- _logger.LogInformation($"Start creating user");
- var user = _mapper.Map<User>(model);
- _logger.LogInformation($"User created successfully");
-
- _logger.LogInformation($"Saving user to db...");
- await _userManager.CreateAsync(user, model.Password);
- _logger.LogInformation($"User saved to DB");
- }
- public async Task RemoveUser(User user)
- {
- await _userManager.DeleteAsync(user);
-
- await _databaseContext.SaveChangesAsync();
- }
-
- public async Task<bool?> ToggleEnable(User user)
- {
- user.IsEnabled = !user.IsEnabled;
-
- await _databaseContext.SaveChangesAsync();
-
- return user.IsEnabled;
- }
-
- public async Task<ServiceResponseDTO<object>> SendRegistrationLink(InviteDTO invite)
- {
- // check if user exists
- var check = await _userManager.FindByEmailAsync(invite.Email);
- if (check != null)
- return new ServiceResponseDTO<object>()
- {
- IsError = true,
- ErrorMessage = "User already registered."
- };
-
- // create template user
- // this user is disabled to log in until confirming invitation
- var user = new User
- {
- UserName = invite.Email,
- Email = invite.Email,
- FirstName = invite.FirstName,
- LastName = invite.LastName,
- IsEnabled = false
- };
-
- await _userManager.CreateAsync(user, StringGenerator.GenerateRandomPassword());
-
- // generate invitation token for user
- // encoded for URLs
- var token = await _userManager.GeneratePasswordResetTokenAsync(user);
- token = HttpUtility.UrlEncode(token);
-
- // send link
- await _emailer.SendEmailAndWriteToDbAsync(invite.Email, "Welcome", HTMLHelper.RenderRegisterPage($"{_frontEndSettings.BaseUrl}/register?token={token}&email={invite.Email}"), isHtml: true);
-
- await _databaseContext.SaveChangesAsync();
-
- return new ServiceResponseDTO<object>
- {
- Data = new { Message = "Link has been sent!" }
- };
- }
-
- public async Task<bool> VerifyToken(User user, string token)
- {
- // this method is going to be updated
- // curent new password value is static and only used for testing
- // method is not complete and is currently only used to check if valid reset token is sent
- var result = await _userManager.ResetPasswordAsync(user, token, "Nekasifra123!");
- return result.Succeeded;
- }
-
- }
- }
|