Files
hcs/Hcs.WebApp/Controllers/IdentityController.cs
2025-10-09 17:32:56 +09:00

80 lines
2.5 KiB
C#

using Hcs.WebApp.Data;
using Microsoft.AspNetCore.Identity;
using Microsoft.AspNetCore.Mvc;
using Radzen;
namespace Hcs.WebApp.Controllers
{
[Route("identity/[action]")]
public class IdentityController(
IUserStore<AppUser> userStore,
UserManager<AppUser> userManager,
SignInManager<AppUser> signInManager) : Controller
{
private readonly IUserStore<AppUser> userStore = userStore;
private readonly UserManager<AppUser> userManager = userManager;
private readonly SignInManager<AppUser> signInManager = signInManager;
[HttpPost]
public async Task<IActionResult> Register(string userName, string password, string returnUrl)
{
var user = Activator.CreateInstance<AppUser>();
await userStore.SetUserNameAsync(user, userName, CancellationToken.None);
var result = await userManager.CreateAsync(user, password);
if (!result.Succeeded)
{
var error = string.Join(", ", result.Errors.Select(error => error.Description));
if (!string.IsNullOrEmpty(returnUrl))
{
return Redirect($"/account/register?error={error}&returnUrl={Uri.EscapeDataString(returnUrl)}");
}
else
{
return Redirect($"/account/register?error={error}");
}
}
await signInManager.SignInAsync(user, isPersistent: false);
if (string.IsNullOrEmpty(returnUrl))
{
Redirect("/");
}
return Redirect(returnUrl);
}
[HttpPost]
public async Task<IActionResult> Login(string userName, string password, string returnUrl)
{
var result = await signInManager.PasswordSignInAsync(userName, password, false, false);
if (!result.Succeeded)
{
if (!string.IsNullOrEmpty(returnUrl))
{
return Redirect($"/account/login?status=failed&returnUrl={Uri.EscapeDataString(returnUrl)}");
}
else
{
return Redirect($"/account/login?status=failed");
}
}
if (string.IsNullOrEmpty(returnUrl))
{
Redirect("/");
}
return Redirect(returnUrl);
}
public async Task<IActionResult> Logout()
{
await signInManager.SignOutAsync();
return Redirect("/");
}
}
}