44 lines
1.4 KiB
C#
44 lines
1.4 KiB
C#
|
using API.Models;
|
||
|
using API.Persistence.Repositories;
|
||
|
using Microsoft.AspNetCore.Mvc;
|
||
|
using Microsoft.EntityFrameworkCore;
|
||
|
using Microsoft.IdentityModel.Tokens;
|
||
|
using Microsoft.VisualStudio.Web.CodeGenerators.Mvc.Templates.BlazorIdentity.Pages;
|
||
|
using System.Configuration;
|
||
|
using System.IdentityModel.Tokens.Jwt;
|
||
|
using System.Security.Claims;
|
||
|
using System.Text;
|
||
|
using Helpers;
|
||
|
|
||
|
namespace Helpers;
|
||
|
|
||
|
public class TokenHelper
|
||
|
{
|
||
|
private readonly IConfiguration _configuration;
|
||
|
|
||
|
public TokenHelper(IConfiguration configuration)
|
||
|
{
|
||
|
_configuration = configuration;
|
||
|
}
|
||
|
|
||
|
public string GenerateJwtToken(User user)
|
||
|
{
|
||
|
var claims = new[]
|
||
|
{
|
||
|
new Claim(JwtRegisteredClaimNames.Sub, user.Id),
|
||
|
new Claim(JwtRegisteredClaimNames.Jti, Guid.NewGuid().ToString()),
|
||
|
new Claim(ClaimTypes.Name, user.Username)
|
||
|
};
|
||
|
|
||
|
var key = new SymmetricSecurityKey(Encoding.UTF8.GetBytes(_configuration["JwtSettings:Key"]));
|
||
|
var creds = new SigningCredentials(key, SecurityAlgorithms.HmacSha256);
|
||
|
var token = new JwtSecurityToken(
|
||
|
_configuration["JwtSettings:Issuer"],
|
||
|
_configuration["JwtSettings:Audience"],
|
||
|
claims,
|
||
|
expires: DateTime.Now.AddMinutes(30),
|
||
|
signingCredentials: creds);
|
||
|
|
||
|
return new JwtSecurityTokenHandler().WriteToken(token);
|
||
|
}
|
||
|
}
|