Ejemplo n.º 1
0
        public async Task <IActionResult> Login(LoginUsuarioDto loginUsuarioDto)
        {
            var usuarioRepo = await _repo.Login(loginUsuarioDto.Login, loginUsuarioDto.Senha);

            if (usuarioRepo == null)
            {
                return(Unauthorized());
            }

            var claims = new[]
            {
                new Claim(ClaimTypes.NameIdentifier, usuarioRepo.Id.ToString()),
                new Claim(ClaimTypes.Name, usuarioRepo.Login)
            };

            var key = new SymmetricSecurityKey(Encoding.UTF8.GetBytes(_config.GetSection("AppSettings:Token").Value));

            var creds = new SigningCredentials(key, SecurityAlgorithms.HmacSha512Signature);

            var tokenDescriptor = new SecurityTokenDescriptor
            {
                Subject            = new ClaimsIdentity(claims),
                Expires            = DateTime.Now.AddDays(1),
                SigningCredentials = creds
            };

            var tokenHandler = new JwtSecurityTokenHandler();

            var token = tokenHandler.CreateToken(tokenDescriptor);

            return(Ok(new {
                token = tokenHandler.WriteToken(token)
            }));
        }
Ejemplo n.º 2
0
        public IActionResult Post(LoginUsuarioDto user)
        {
            try
            {
                var result = _serv.LoginUsuario(user);

                return(Ok(result));
            }
            catch (Exception ex)
            {
                return(BadRequest(ex));
            }
        }
Ejemplo n.º 3
0
        public UsuarioLogadoDto LoginUsuario(LoginUsuarioDto loginDto)
        {
            var result = _repo.GetUsuario(loginDto.Login, loginDto.Senha);
            UsuarioLogadoDto usuarioDto = null;

            // Verifica se retornou algum resultado para aquele login
            if (result != null)
            {
                var token = TokenService.GenerateToken(result);
                usuarioDto = new UsuarioLogadoDto
                {
                    Nome        = result.Nome,
                    AccessToken = token
                };
            }
            // Gera o Token
            return(usuarioDto);
        }