Пример #1
0
        public async Task <IActionResult> Login(LoginViewModel vm)
        {
            if (User.Identity.IsAuthenticated)
            {
                return(RedirectToAction("Index", "THome"));
            }
            var user = await _userManager.FindByNameAsync(vm.User);

            var usuario = await _context.Usuario.FirstOrDefaultAsync(c => c.UserName == vm.User);

            if (ModelState.IsValid)
            {
                if (user == null)
                {
                    ModelState.AddModelError("NoUser", "Usuario no Existente");
                }
                else
                {
                    if (await _userManager.GetAccessFailedCountAsync(user) > 2)
                    {
                        usuario.Estado = "Inactivo";
                        _context.Usuario.Update(usuario);
                        await _userManager.SetLockoutEnabledAsync(user, true);

                        await _context.SaveChangesAsync();

                        ModelState.AddModelError("UserDeactivated", "Usuario Inactivo, resuelva con el admin");
                    }
                    else if (usuario.Estado == "Inactivo")
                    {
                        ModelState.AddModelError("UserDeactivated", "Usuario Inactivo, resuelva con el admin");
                    }
                    else
                    {
                        var result = await _signInManager.PasswordSignInAsync(vm.User, vm.Password, false, false);

                        if (result.Succeeded)
                        {
                            return(RedirectToAction("Index", "THome"));
                        }
                        ModelState.AddModelError("UserOrPasswordInvalid", "Usuario o Contraseña inválida");
                        await _userManager.AccessFailedAsync(user);
                    }
                }
            }

            return(View(vm));
        }