AccountController.cs 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. using DutchTreat.Data.Entities;
  2. using DutchTreat.ViewModels;
  3. using Microsoft.AspNetCore.Identity;
  4. using Microsoft.AspNetCore.Mvc;
  5. using Microsoft.Extensions.Configuration;
  6. using Microsoft.Extensions.Logging;
  7. using Microsoft.IdentityModel.Tokens;
  8. using System;
  9. using System.Collections.Generic;
  10. using System.IdentityModel.Tokens.Jwt;
  11. using System.Linq;
  12. using System.Security.Claims;
  13. using System.Text;
  14. using System.Threading.Tasks;
  15. namespace DutchTreat.Controllers
  16. {
  17. public class AccountController : Controller
  18. {
  19. private readonly ILogger<AccountController> _logger;
  20. private readonly SignInManager<StoreUser> _signInManager;
  21. private readonly UserManager<StoreUser> _userManager;
  22. private readonly IConfiguration _config;
  23. public AccountController(ILogger<AccountController> logger,
  24. SignInManager<StoreUser> signInManager,
  25. UserManager<StoreUser> userManager,
  26. IConfiguration config)
  27. {
  28. _logger = logger;
  29. _signInManager = signInManager;
  30. _userManager = userManager;
  31. _config = config;
  32. }
  33. public IActionResult Login()
  34. {
  35. if (this.User.Identity.IsAuthenticated)
  36. {
  37. return RedirectToAction("Index", "App");
  38. }
  39. return View();
  40. }
  41. [HttpPost]
  42. public async Task<IActionResult> Login(LoginViewModel model)
  43. {
  44. if (ModelState.IsValid)
  45. {
  46. var result = await _signInManager.PasswordSignInAsync(
  47. model.Username,
  48. model.Password,
  49. model.RemenberMe,
  50. false);
  51. if (result.Succeeded)
  52. {
  53. if (Request.Query.Keys.Contains("ReturnUrl"))
  54. {
  55. return Redirect(Request.Query["ReturnUrl"].First());
  56. }
  57. else
  58. {
  59. return RedirectToAction("Shop", "App");
  60. }
  61. }
  62. }
  63. ModelState.AddModelError("", "Failed to login");
  64. return View();
  65. }
  66. [HttpGet]
  67. public async Task<IActionResult> Logout()
  68. {
  69. await _signInManager.SignOutAsync();
  70. return RedirectToAction("Index", "App");
  71. }
  72. [HttpPost]
  73. public async Task<IActionResult> CreateTokenAsync([FromBody] LoginViewModel model)
  74. {
  75. if (ModelState.IsValid)
  76. {
  77. var user = await _userManager.FindByNameAsync(model.Username);
  78. if (user != null)
  79. {
  80. var result = await _signInManager.CheckPasswordSignInAsync(user, model.Password, false);
  81. if (result.Succeeded)
  82. {
  83. var claims = new[]
  84. {
  85. new Claim(JwtRegisteredClaimNames.Sub, user.Email),
  86. new Claim(JwtRegisteredClaimNames.Jti, Guid.NewGuid().ToString()),
  87. new Claim(JwtRegisteredClaimNames.UniqueName, user.UserName)
  88. };
  89. var key = new SymmetricSecurityKey(Encoding.UTF8.GetBytes(_config["Token:Key"]));
  90. var creds = new SigningCredentials(key, SecurityAlgorithms.HmacSha256);
  91. var token = new JwtSecurityToken(
  92. _config["Token:Issuer"],
  93. _config["Token:Audience"],
  94. claims,
  95. signingCredentials: creds,
  96. expires: DateTime.UtcNow.AddMinutes(20));
  97. return Created("", new
  98. {
  99. token = new JwtSecurityTokenHandler().WriteToken(token),
  100. expiration = token.ValidTo
  101. });
  102. }
  103. }
  104. }
  105. return BadRequest();
  106. }
  107. }
  108. }