Como direcionar para páginas específicas de determinado tipo de usuário no ASP.NET Identity?
Estou usando o ASP.NET.Core.Identity (2.1.3) e gostaria que, no processo de autenticação, o usuário, caso fosse do tipo User (comum) fosse para a página HomeUser, caso fosse Admin, fosse para a página HomeAdmin. Mas como ainda conheço pouco das tecnologias, estou cheio de dúvidas:
1. Admin ou User serão Role ou Claim, no Identity?
2. Tenho as tabelas dbo.AspNetRoleClaims e dbo.AspNetRoles, dependendo da que eu escolher, o cadastro eu faço direto no banco, certo?
3. No código abaixo é que eu quero fazer o redirecionamento, como seria a verificação do claim ou role no código abaixo?
4. O código abaixo é do registro de usuário, como podem ver eu não defino o claim ou role, como insiro esse registro para o usuário?
Como podem ver eu conheço quase nada do Identity, se puderem me indicar um material mais atual e bom para eu estudar, agradeço muito!
1. Admin ou User serão Role ou Claim, no Identity?
2. Tenho as tabelas dbo.AspNetRoleClaims e dbo.AspNetRoles, dependendo da que eu escolher, o cadastro eu faço direto no banco, certo?
3. No código abaixo é que eu quero fazer o redirecionamento, como seria a verificação do claim ou role no código abaixo?
[HttpPost]
[AllowAnonymous]
[ValidateAntiForgeryToken]
public async Task<IActionResult> Login(LoginViewModel model, string returnUrl = null)
{
ViewData["ReturnUrl"] = returnUrl;
if (ModelState.IsValid)
{
// This doesn't count login failures towards account lockout
// To enable password failures to trigger account lockout, set lockoutOnFailure: true
var result = await _signInManager.PasswordSignInAsync(model.Email, model.Password, model.RememberMe, lockoutOnFailure: false);
if (result.Succeeded)
{
_logger.LogInformation("Usuário logado.");
//return RedirectToLocal(returnUrl);
return RedirectToAction("HomeAdmin", "Account");
}
if (result.IsLockedOut)
{
_logger.LogWarning("User account locked out.");
return RedirectToAction(nameof(Lockout));
}
else
{
ModelState.AddModelError("InvalidLogin", "O usuário ou senha incorreto.");
return View();
}
}
// If we got this far, something failed, redisplay form
return View(model);
}4. O código abaixo é do registro de usuário, como podem ver eu não defino o claim ou role, como insiro esse registro para o usuário?
[HttpPost]
[AllowAnonymous]
[ValidateAntiForgeryToken]
public async Task<IActionResult> Register(RegisterViewModel model)
{
if (ModelState.IsValid)
{
var user = new ApplicationUser
{
FirstName = model.FirstName,
LastName = model.LastName,
UserName = model.Email,
Email = model.Email,
Profile = "user"
};
var result = await _userManager.CreateAsync(user, model.Password);
if (result.Succeeded)
{
_logger.LogInformation("O usuário criou uma nova conta com senha.");
var code = await _userManager.GenerateEmailConfirmationTokenAsync(user);
var callbackUrl = Url.Action("ConfirmEmail", "Account", new { userId = user.Id, code = code }, protocol: HttpContext.Request.Scheme);
// await IEmailSender.SendEmailAsync(model.Email, "Confirm your account", $"Por favor, confirme seu email clicando neste link: <a href=''>link</a>");
await _signInManager.SignInAsync(user, isPersistent: false);
_logger.LogInformation("O usuário criou uma nova conta com senha.");
return RedirectToLocal("DisplayEmail");
}
AddErrors(result);
}
// No caso de falha, reexibir a view
return View();
}Como podem ver eu conheço quase nada do Identity, se puderem me indicar um material mais atual e bom para eu estudar, agradeço muito!
Cesar Murilo
Curtidas 0