| | 1 | | using Despesas.Backend.Controllers.Abstractions; |
| | 2 | | using Domain.Core.ValueObject; |
| | 3 | | using Microsoft.AspNetCore.Mvc; |
| | 4 | | using System.IdentityModel.Tokens.Jwt; |
| | 5 | |
|
| | 6 | | namespace Despesas.Backend.Controllers; |
| | 7 | |
|
| | 8 | | [Route("api/[controller]")] |
| | 9 | | [ApiController] |
| | 10 | | public class AuthController : UnitControllerBase |
| | 11 | | { |
| 261 | 12 | | public AuthController() : base() { } |
| | 13 | | protected PerfilUsuario PerfilUsuario |
| | 14 | | { |
| | 15 | | get |
| 0 | 16 | | { |
| | 17 | | try |
| 0 | 18 | | { |
| 0 | 19 | | var tokenHandler = new JwtSecurityTokenHandler(); |
| 0 | 20 | | var token = HttpContext.Request.Headers.Authorization.ToString(); |
| 0 | 21 | | var jwtToken = tokenHandler.ReadToken(token.Replace("Bearer ", "")) as JwtSecurityToken; |
| 0 | 22 | | var roleClaim = jwtToken.Claims.FirstOrDefault(c => c.Type == "role")?.Value; |
| 0 | 23 | | if (roleClaim == null) throw new ArgumentNullException(); |
| | 24 | |
|
| 0 | 25 | | if (!Enum.TryParse<PerfilUsuario.Perfil>(roleClaim, out var perfilEnum)) |
| 0 | 26 | | throw new ArgumentNullException(); |
| | 27 | |
|
| 0 | 28 | | return new PerfilUsuario(perfilEnum); |
| | 29 | | } |
| 0 | 30 | | catch |
| 0 | 31 | | { |
| 0 | 32 | | return null; |
| | 33 | | } |
| | 34 | |
|
| 0 | 35 | | } |
| | 36 | | } |
| | 37 | | } |