using System; using System.Collections.Generic; using System.IdentityModel.Tokens.Jwt; using System.Linq; using System.Security.Claims; using System.Text; using Microsoft.AspNetCore.Authentication; using Microsoft.AspNetCore.Authentication.Cookies; using Microsoft.AspNetCore.Http; using Microsoft.Extensions.Configuration; using Microsoft.IdentityModel.Tokens; namespace Infrastructure.Extensions { public static class HttpContextExtensions { public static void SignIn(this HttpContext httpContext, string userName, IEnumerable roles, bool rememberMe) { var claims = new List { new Claim("Name", userName) }; claims.AddRange(roles.Select(o => new Claim("Role", o)).ToList()); var claimsPrincipal = new ClaimsPrincipal(new ClaimsIdentity(claims, CookieAuthenticationDefaults.AuthenticationScheme, "Name", "Role")); httpContext.SignInAsync(CookieAuthenticationDefaults.AuthenticationScheme, claimsPrincipal, new AuthenticationProperties { IsPersistent = rememberMe }); } public static void SignIn(this HttpContext httpContext, string userName, IEnumerable roles, bool rememberMe, IConfiguration cfg) { var key = new SymmetricSecurityKey(Encoding.UTF8.GetBytes(cfg["jwt:key"])); var creds = new SigningCredentials(key, SecurityAlgorithms.HmacSha256); var claims = new List { new Claim("Name", userName) }; claims.AddRange(roles.Select(o => new Claim("Role", o)).ToList()); var claimsPrincipal = new ClaimsPrincipal(new ClaimsIdentity(claims, CookieAuthenticationDefaults.AuthenticationScheme, "Name", "Role")); var token = new JwtSecurityToken( issuer: cfg["jwt:issuer"], audience: cfg["jwt:audience"], claims: claims, expires: DateTime.Now.AddMinutes(rememberMe ? 3600 : 3), signingCredentials: creds); var tokenText = new JwtSecurityTokenHandler().WriteToken(token); var newBearerToken = "Bearer " + tokenText; httpContext.Response.Cookies.Delete("jwt"); httpContext.Response.Cookies.Append("jwt", tokenText); //httpContext.SignInAsync(CookieAuthenticationDefaults.AuthenticationScheme, claimsPrincipal, new AuthenticationProperties { IsPersistent = rememberMe }); } } }