feat: Integrate ASP.NET Core Identity for user authentication
This commit integrates ASP.NET Core Identity into the application to enable user registration, login, and management. This lays the groundwork for securing data per user.
**Key Changes:**
*   **DbContext Configuration:**
    *   Modified `ApplicationDbContext.cs` to inherit from `IdentityDbContext<IdentityUser>`.
    *   Removed an unnecessary `using` statement from `ApplicationDbContext.cs`.
*   **Program.cs Setup:**
    *   Configured `AddDefaultIdentity<IdentityUser>` with `AddEntityFrameworkStores<ApplicationDbContext>()` to register Identity services.
    *   Ensured correct ordering of `UseAuthentication()` and `UseAuthorization()` middleware.
    *   Added `app.MapRazorPages()` to enable the Identity UI pages.
    *   Verified core package versions in `turf_tasker.csproj` for consistency across EF Core and Identity components (`8.0.6`).
*   **Identity UI:**
    *   Scaffolded ASP.NET Core Identity pages (Login, Register, Manage, etc.) to provide the user interface for authentication.
    *   Added a `_LoginPartial.cshtml` partial view to the `Views/Shared` folder.
    *   Rendered `_LoginPartial` in `Views/Shared/_Layout.cshtml` to display login/register/logout links in the navigation bar.
*   **Migrations:**
    *   Created and applied a new migration (`AddIdentitySchema`) to create the necessary ASP.NET Core Identity database tables (e.g., `AspNetUsers`, `AspNetRoles`).
			
			
This commit is contained in:
		
							parent
							
								
									60567d7969
								
							
						
					
					
						commit
						b24beb3154
					
				
					 79 changed files with 5246 additions and 12 deletions
				
			
		
							
								
								
									
										112
									
								
								Areas/Identity/Pages/Account/LoginWithRecoveryCode.cshtml.cs
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										112
									
								
								Areas/Identity/Pages/Account/LoginWithRecoveryCode.cshtml.cs
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,112 @@ | |||
| // Licensed to the .NET Foundation under one or more agreements. | ||||
| // The .NET Foundation licenses this file to you under the MIT license. | ||||
| #nullable disable | ||||
| 
 | ||||
| using System; | ||||
| using System.ComponentModel.DataAnnotations; | ||||
| using System.Threading.Tasks; | ||||
| using Microsoft.AspNetCore.Authorization; | ||||
| using Microsoft.AspNetCore.Identity; | ||||
| using Microsoft.AspNetCore.Mvc; | ||||
| using Microsoft.AspNetCore.Mvc.RazorPages; | ||||
| using Microsoft.Extensions.Logging; | ||||
| namespace turf_tasker.Areas.Identity.Pages.Account | ||||
| { | ||||
|     public class LoginWithRecoveryCodeModel : PageModel | ||||
|     { | ||||
|         private readonly SignInManager<IdentityUser> _signInManager; | ||||
|         private readonly UserManager<IdentityUser> _userManager; | ||||
|         private readonly ILogger<LoginWithRecoveryCodeModel> _logger; | ||||
| 
 | ||||
|         public LoginWithRecoveryCodeModel( | ||||
|             SignInManager<IdentityUser> signInManager, | ||||
|             UserManager<IdentityUser> userManager, | ||||
|             ILogger<LoginWithRecoveryCodeModel> logger) | ||||
|         { | ||||
|             _signInManager = signInManager; | ||||
|             _userManager = userManager; | ||||
|             _logger = logger; | ||||
|         } | ||||
| 
 | ||||
|         /// <summary> | ||||
|         ///     This API supports the ASP.NET Core Identity default UI infrastructure and is not intended to be used | ||||
|         ///     directly from your code. This API may change or be removed in future releases. | ||||
|         /// </summary> | ||||
|         [BindProperty] | ||||
|         public InputModel Input { get; set; } | ||||
| 
 | ||||
|         /// <summary> | ||||
|         ///     This API supports the ASP.NET Core Identity default UI infrastructure and is not intended to be used | ||||
|         ///     directly from your code. This API may change or be removed in future releases. | ||||
|         /// </summary> | ||||
|         public string ReturnUrl { get; set; } | ||||
| 
 | ||||
|         /// <summary> | ||||
|         ///     This API supports the ASP.NET Core Identity default UI infrastructure and is not intended to be used | ||||
|         ///     directly from your code. This API may change or be removed in future releases. | ||||
|         /// </summary> | ||||
|         public class InputModel | ||||
|         { | ||||
|             /// <summary> | ||||
|             ///     This API supports the ASP.NET Core Identity default UI infrastructure and is not intended to be used | ||||
|             ///     directly from your code. This API may change or be removed in future releases. | ||||
|             /// </summary> | ||||
|             [BindProperty] | ||||
|             [Required] | ||||
|             [DataType(DataType.Text)] | ||||
|             [Display(Name = "Recovery Code")] | ||||
|             public string RecoveryCode { get; set; } | ||||
|         } | ||||
| 
 | ||||
|         public async Task<IActionResult> OnGetAsync(string returnUrl = null) | ||||
|         { | ||||
|             // Ensure the user has gone through the username & password screen first | ||||
|             var user = await _signInManager.GetTwoFactorAuthenticationUserAsync(); | ||||
|             if (user == null) | ||||
|             { | ||||
|                 throw new InvalidOperationException($"Unable to load two-factor authentication user."); | ||||
|             } | ||||
| 
 | ||||
|             ReturnUrl = returnUrl; | ||||
| 
 | ||||
|             return Page(); | ||||
|         } | ||||
| 
 | ||||
|         public async Task<IActionResult> OnPostAsync(string returnUrl = null) | ||||
|         { | ||||
|             if (!ModelState.IsValid) | ||||
|             { | ||||
|                 return Page(); | ||||
|             } | ||||
| 
 | ||||
|             var user = await _signInManager.GetTwoFactorAuthenticationUserAsync(); | ||||
|             if (user == null) | ||||
|             { | ||||
|                 throw new InvalidOperationException($"Unable to load two-factor authentication user."); | ||||
|             } | ||||
| 
 | ||||
|             var recoveryCode = Input.RecoveryCode.Replace(" ", string.Empty); | ||||
| 
 | ||||
|             var result = await _signInManager.TwoFactorRecoveryCodeSignInAsync(recoveryCode); | ||||
| 
 | ||||
|             var userId = await _userManager.GetUserIdAsync(user); | ||||
| 
 | ||||
|             if (result.Succeeded) | ||||
|             { | ||||
|                 _logger.LogInformation("User with ID '{UserId}' logged in with a recovery code.", user.Id); | ||||
|                 return LocalRedirect(returnUrl ?? Url.Content("~/")); | ||||
|             } | ||||
|             if (result.IsLockedOut) | ||||
|             { | ||||
|                 _logger.LogWarning("User account locked out."); | ||||
|                 return RedirectToPage("./Lockout"); | ||||
|             } | ||||
|             else | ||||
|             { | ||||
|                 _logger.LogWarning("Invalid recovery code entered for user with ID '{UserId}' ", user.Id); | ||||
|                 ModelState.AddModelError(string.Empty, "Invalid recovery code entered."); | ||||
|                 return Page(); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Blake Ridgway
						Blake Ridgway