Example #1
0
        public async Task <ActionResult> Login(LoginViewModel model, string returnUrl)
        {
            if (!ModelState.IsValid)
            {
                return(View(model));
            }

            // This doesn't count login failures towards account lockout
            // To enable password failures to trigger account lockout, change to shouldLockout: true
            var result = await SignInManager.PasswordSignInAsync(model.Email, model.Password, model.RememberMe, shouldLockout : false);


            switch (result)
            {
            case SignInStatus.Success:
            {
                var Obj      = RknaContext.AspNetUsers.Where(Us => Us.Email == model.Email).FirstOrDefault();
                var UserRule = RknaContext.AspNetUserRoles.Where(user => user.UserId == Obj.Id).FirstOrDefault();

                LoginUserRule.SetRule(UserRule.RoleId);
                if (UserRule.RoleId == "admin")
                {
                    return(RedirectToLocal("~/Manag_Account/Index"));
                }
                else if (UserRule.RoleId == "manger")
                {
                    return(RedirectToLocal("~/Company/Index"));
                }
                else
                {
                    return(RedirectToLocal("~/Home/Index"));
                }
            }

            case SignInStatus.LockedOut:
                return(View("Lockout"));

            case SignInStatus.RequiresVerification:
                return(RedirectToAction("SendCode", new { ReturnUrl = returnUrl, RememberMe = model.RememberMe }));

            case SignInStatus.Failure:
            default:
                ModelState.AddModelError("", "Invalid login attempt.");
                return(View(model));
            }
        }
Example #2
0
 //
 // POST: /Account/LogOff
 //  [HttpPost]
 // [ValidateAntiForgeryToken]
 public ActionResult LogOff()
 {
     AuthenticationManager.SignOut(DefaultAuthenticationTypes.ApplicationCookie);
     LoginUserRule.SetRule("");
     return(RedirectToAction("Login", "Account"));
 }