Como direcionar para páginas específicas de determinado tipo de usuário no ASP.NET Identity?

11/10/2018

0

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?

[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

Cesar Murilo

Responder

Assista grátis a nossa aula inaugural

Assitir aula

Saiba por que programar é uma questão de
sobrevivência e como aprender sem riscos

Assistir agora

Utilizamos cookies para fornecer uma melhor experiência para nossos usuários, consulte nossa política de privacidade.

Aceitar