Esempio n. 1
0
        public async Task <IActionResult> Autenticar(string email, string senha)
        {
            try
            {
                var usuario = cadastroUsuarioServico.BuscaUsuarioPorEmailSenha(email, senha);
                if (usuario == null)
                {
                    TempData["falhaAutenticacao"] = string.Format("Usuário ou senha incorreto!");
                    return(View("Index"));
                }

                var claims = new List <Claim> {
                    new Claim(ClaimTypes.Role, usuario.TipoUsuario.ToString()),
                    new Claim(ClaimTypes.Name, usuario.Nome),
                    new Claim("IdUsuario", usuario.Id.ToString()),
                };

                var             userIdentity = new ClaimsIdentity(claims, "login");
                ClaimsPrincipal principal    = new ClaimsPrincipal(userIdentity);
                await HttpContext.SignInAsync(principal);

                return(RedirectToAction("Index", "Home"));
            }
            catch (Exception ex)
            {
                return(View("~/Views/Shared/Error.cshtml", ex));
            }
        }