26 lines
743 B
C#
26 lines
743 B
C#
|
namespace Parking_space_WebAPI.Authorization;
|
||
|
|
||
|
using Parking_space_WebAPI.Services;
|
||
|
|
||
|
public class JwtMiddleware
|
||
|
{
|
||
|
private readonly RequestDelegate _next;
|
||
|
|
||
|
public JwtMiddleware(RequestDelegate next)
|
||
|
{
|
||
|
_next = next;
|
||
|
}
|
||
|
|
||
|
public async Task Invoke(HttpContext context, IUserService userService, IJwtUtils jwtUtils)
|
||
|
{
|
||
|
var token = context.Request.Headers["Authorization"].FirstOrDefault()?.Split(" ").Last();
|
||
|
var userId = jwtUtils.ValidateJwtToken(token);
|
||
|
if (userId != null)
|
||
|
{
|
||
|
// attach user to context on successful jwt validation
|
||
|
context.Items["User"] = userService.GetById(userId.Value);
|
||
|
}
|
||
|
var stop = "1";
|
||
|
await _next(context);
|
||
|
}
|
||
|
}
|